<html>
<head>
<meta content="text/html; charset=utf-8" http-equiv="Content-Type">
</head>
<body bgcolor="#FFFFFF" text="#000000">
<p><br>
</p>
<div class="moz-cite-prefix">On 12/18/2016 02:02 AM, Sean Silva
wrote:<br>
</div>
<blockquote
cite="mid:CAHnXoamu+1xcTtKO4Vm2i3iCPCmDTxi6UmQ+m4S=RsVFo367+w@mail.gmail.com"
type="cite">
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<div dir="ltr">Do you have contact with the folks that develop
these proxy apps?</div>
</blockquote>
<br>
Yes. The XSBench author helped me construct the "runs for a few
seconds" input configuration.<br>
<br>
<blockquote
cite="mid:CAHnXoamu+1xcTtKO4Vm2i3iCPCmDTxi6UmQ+m4S=RsVFo367+w@mail.gmail.com"
type="cite">
<div dir="ltr">
<div><br>
</div>
<div>It seems like RSBench includes its own RNG. It seems like
it would be beneficial overall to the benchmarks for them to
not rely on details of the system rand(). Maybe it's as easy
as copypasting it into the other proxy apps?</div>
<div><a moz-do-not-send="true"
href="https://github.com/ANL-CESAR/RSBench/blob/master/src/utils.c">https://github.com/ANL-CESAR/RSBench/blob/master/src/utils.c</a><br>
</div>
</div>
</blockquote>
<br>
So, as it turns out, I screwed this up. XSBench also contains its
own RNG that is used in verification mode. As a result, the glibc
rand emulation code is not necessary. The problem on ARM (and also
on any other 32-bit architecture) was that this rn_v routine used
'unsigned long' instead of uint64_t, and so produced different
numbers on 64-bit and 32-bit architectures (thus causing the output
to fail to match the reference output). This is easy to fix and I'll
remove the unnecessary glibc-rand-emulation code I added before
recommiting.<br>
<br>
Thanks again,<br>
Hal<br>
<br>
<blockquote
cite="mid:CAHnXoamu+1xcTtKO4Vm2i3iCPCmDTxi6UmQ+m4S=RsVFo367+w@mail.gmail.com"
type="cite">
<div dir="ltr">
<div>
<div><br>
</div>
<div><br>
</div>
<div>-- Sean Silva</div>
</div>
</div>
<div class="gmail_extra"><br>
<div class="gmail_quote">On Wed, Dec 14, 2016 at 8:42 AM, Hal
Finkel via llvm-commits <span dir="ltr"><<a
moz-do-not-send="true"
href="mailto:llvm-commits@lists.llvm.org" target="_blank">llvm-commits@lists.llvm.org</a>></span>
wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0
.8ex;border-left:1px #ccc solid;padding-left:1ex">Author:
hfinkel<br>
Date: Wed Dec 14 10:42:31 2016<br>
New Revision: 289666<br>
<br>
URL: <a moz-do-not-send="true"
href="http://llvm.org/viewvc/llvm-project?rev=289666&view=rev"
rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-<wbr>project?rev=289666&view=rev</a><br>
Log:<br>
Add XSBench<br>
<br>
The US Department of Energy (DOE) has open-sourced a
significant number of<br>
so-called proxy applications (i.e. small applications,
representative of our<br>
larger workloads in some respects, intended for use as
benchmarks and test beds<br>
for various kind of porting exercises). Many of these are
useful as compiler<br>
tests, and I'd like to add these to our test suite. Doing so
will increase the<br>
representation within our test suite of HPC/scientific
applications and allow<br>
us to better track how Clang/LLVM is doing in this area.
Scientific<br>
applications are certainly a diverse group in themselves,
and so my long term<br>
goal is to add a significant number of these proxies to
ensure good coverage.<br>
<br>
Some months ago, I compiled a list of our open-source proxy
applications<br>
released by the various DOE laboratories<br>
(<a moz-do-not-send="true"
href="https://gitlab.com/llvm-doe/public/wikis/DOEProxyApps"
rel="noreferrer" target="_blank">https://gitlab.com/llvm-doe/<wbr>public/wikis/DOEProxyApps</a>).
By my estimate, of the<br>
approximately 40 proxy applications on that list, around
half could be<br>
reasonably added to our test suite. We're continuing to
develop new proxies,<br>
and so the number of suitable applications should grow
somewhat in the future.<br>
<br>
In any case, here's the first one: XSBench. This is a C
application with a<br>
straightforward reference output. It is designed to
represent a key<br>
computational kernel of the Monte-Carlo neutronics
application OpenMC. The<br>
builtin "small" test configuration is mostly suitable for
our test suite - the<br>
parameters have been adjusted slightly so that the test uses
only ~27MB of<br>
memory and runs in a few seconds. The only complication in
adding this<br>
application is its dependence on rand(). The developer's
provided known-good<br>
output will work only for glibc's implementation of rand
(other rand<br>
implementation obviously may produce a different series of
random numbers given<br>
the same initial seed). Luckily, the algorithm that glibc
uses for rand() is<br>
reasonably well described by various web pages, and so I
constructed a small<br>
independent implementation. This is in the
glibc_compat_rand.{c,h} files.<br>
<br>
As a reflection of my desire to add more of these
applications, I've place this<br>
in a subdirectory named DOE-ProxyApps-C (the idea being that
the C++ proxy<br>
applications will get a DOE-ProxyApps-C++ directory or
similar).<br>
<br>
Differential Revision: <a moz-do-not-send="true"
href="https://reviews.llvm.org/D27311" rel="noreferrer"
target="_blank">https://reviews.llvm.org/<wbr>D27311</a><br>
<br>
Added:<br>
test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<br>
test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>CMakeLists.txt<br>
test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>Makefile<br>
test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/<br>
test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/CMakeLists.txt<br>
test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/CalculateXS.c<br>
test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/GridInit.c<br>
test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/LICENSE<br>
test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/Main.c<br>
test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/Makefile<br>
test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/Materials.c<br>
test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/XSBench.reference_<wbr>output<br>
test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/XSbench_header.h<br>
test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/XSutils.c<br>
test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/glibc_compat_rand.c<br>
test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/glibc_compat_rand.h<br>
test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/io.c<br>
Modified:<br>
test-suite/trunk/MultiSource/<wbr>Benchmarks/CMakeLists.txt<br>
test-suite/trunk/MultiSource/<wbr>Benchmarks/Makefile<br>
<br>
Modified: test-suite/trunk/MultiSource/<wbr>Benchmarks/CMakeLists.txt<br>
URL: <a moz-do-not-send="true"
href="http://llvm.org/viewvc/llvm-project/test-suite/trunk/MultiSource/Benchmarks/CMakeLists.txt?rev=289666&r1=289665&r2=289666&view=diff"
rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-<wbr>project/test-suite/trunk/<wbr>MultiSource/Benchmarks/<wbr>CMakeLists.txt?rev=289666&r1=<wbr>289665&r2=289666&view=diff</a><br>
==============================<wbr>==============================<wbr>==================<br>
--- test-suite/trunk/MultiSource/<wbr>Benchmarks/CMakeLists.txt
(original)<br>
+++ test-suite/trunk/MultiSource/<wbr>Benchmarks/CMakeLists.txt
Wed Dec 14 10:42:31 2016<br>
@@ -18,6 +18,7 @@ add_subdirectory(llubenchmark)<br>
add_subdirectory(mediabench)<br>
add_subdirectory(nbench)<br>
add_subdirectory(sim)<br>
+add_subdirectory(DOE-<wbr>ProxyApps-C)<br>
<br>
if((NOT "${TARGET_OS}" STREQUAL "Darwin") OR (NOT "${ARCH}"
STREQUAL "ARM"))<br>
add_subdirectory(TSVC)<br>
<br>
Added: test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>CMakeLists.txt<br>
URL: <a moz-do-not-send="true"
href="http://llvm.org/viewvc/llvm-project/test-suite/trunk/MultiSource/Benchmarks/DOE-ProxyApps-C/CMakeLists.txt?rev=289666&view=auto"
rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-<wbr>project/test-suite/trunk/<wbr>MultiSource/Benchmarks/DOE-<wbr>ProxyApps-C/CMakeLists.txt?<wbr>rev=289666&view=auto</a><br>
==============================<wbr>==============================<wbr>==================<br>
--- test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>CMakeLists.txt
(added)<br>
+++ test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>CMakeLists.txt
Wed Dec 14 10:42:31 2016<br>
@@ -0,0 +1,2 @@<br>
+add_subdirectory(XSBench)<br>
+<br>
<br>
Added: test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>Makefile<br>
URL: <a moz-do-not-send="true"
href="http://llvm.org/viewvc/llvm-project/test-suite/trunk/MultiSource/Benchmarks/DOE-ProxyApps-C/Makefile?rev=289666&view=auto"
rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-<wbr>project/test-suite/trunk/<wbr>MultiSource/Benchmarks/DOE-<wbr>ProxyApps-C/Makefile?rev=<wbr>289666&view=auto</a><br>
==============================<wbr>==============================<wbr>==================<br>
--- test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>Makefile
(added)<br>
+++ test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>Makefile
Wed Dec 14 10:42:31 2016<br>
@@ -0,0 +1,7 @@<br>
+# MultiSource/DOE-ProxyApps-C Makefile: Build all
subdirectories automatically<br>
+<br>
+LEVEL = ../../..<br>
+PARALLEL_DIRS = XSBench<br>
+<br>
+<br>
+include $(LEVEL)/Makefile.programs<br>
<br>
Added: test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/CMakeLists.txt<br>
URL: <a moz-do-not-send="true"
href="http://llvm.org/viewvc/llvm-project/test-suite/trunk/MultiSource/Benchmarks/DOE-ProxyApps-C/XSBench/CMakeLists.txt?rev=289666&view=auto"
rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-<wbr>project/test-suite/trunk/<wbr>MultiSource/Benchmarks/DOE-<wbr>ProxyApps-C/XSBench/<wbr>CMakeLists.txt?rev=289666&<wbr>view=auto</a><br>
==============================<wbr>==============================<wbr>==================<br>
--- test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/CMakeLists.txt
(added)<br>
+++ test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/CMakeLists.txt
Wed Dec 14 10:42:31 2016<br>
@@ -0,0 +1,5 @@<br>
+set(PROG XSBench)<br>
+set(CPPFLAGS -DVERIFICATION)<br>
+set(LDFLAGS -lm)<br>
+set(RUN_OPTIONS -s small -g 1250 -l 1000000)<br>
+llvm_multisource()<br>
<br>
Added: test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/CalculateXS.c<br>
URL: <a moz-do-not-send="true"
href="http://llvm.org/viewvc/llvm-project/test-suite/trunk/MultiSource/Benchmarks/DOE-ProxyApps-C/XSBench/CalculateXS.c?rev=289666&view=auto"
rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-<wbr>project/test-suite/trunk/<wbr>MultiSource/Benchmarks/DOE-<wbr>ProxyApps-C/XSBench/<wbr>CalculateXS.c?rev=289666&view=<wbr>auto</a><br>
==============================<wbr>==============================<wbr>==================<br>
--- test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/CalculateXS.c
(added)<br>
+++ test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/CalculateXS.c
Wed Dec 14 10:42:31 2016<br>
@@ -0,0 +1,124 @@<br>
+#include "XSbench_header.h"<br>
+<br>
+// Calculates the microscopic cross section for a given
nuclide & energy<br>
+void calculate_micro_xs( double p_energy, int nuc, long
n_isotopes,<br>
+ long n_gridpoints,<br>
+ GridPoint * restrict
energy_grid,<br>
+ NuclideGridPoint ** restrict
nuclide_grids,<br>
+ int idx, double * restrict
xs_vector ){<br>
+<br>
+ // Variables<br>
+ double f;<br>
+ NuclideGridPoint * low, * high;<br>
+<br>
+ // pull ptr from energy grid and check to ensure
that<br>
+ // we're not reading off the end of the nuclide's
grid<br>
+ if( energy_grid[idx].xs_ptrs[nuc] == n_gridpoints -
1 )<br>
+ low = &nuclide_grids[nuc][energy_<wbr>grid[idx].xs_ptrs[nuc]
- 1];<br>
+ else<br>
+ low = &nuclide_grids[nuc][energy_<wbr>grid[idx].xs_ptrs[nuc]];<br>
+<br>
+ high = low + 1;<br>
+<br>
+ // calculate the re-useable interpolation factor<br>
+ f = (high->energy - p_energy) / (high->energy
- low->energy);<br>
+<br>
+ // Total XS<br>
+ xs_vector[0] = high->total_xs - f *
(high->total_xs - low->total_xs);<br>
+<br>
+ // Elastic XS<br>
+ xs_vector[1] = high->elastic_xs - f *
(high->elastic_xs - low->elastic_xs);<br>
+<br>
+ // Absorbtion XS<br>
+ xs_vector[2] = high->absorbtion_xs - f *
(high->absorbtion_xs - low->absorbtion_xs);<br>
+<br>
+ // Fission XS<br>
+ xs_vector[3] = high->fission_xs - f *
(high->fission_xs - low->fission_xs);<br>
+<br>
+ // Nu Fission XS<br>
+ xs_vector[4] = high->nu_fission_xs - f *
(high->nu_fission_xs - low->nu_fission_xs);<br>
+<br>
+ //test<br>
+ /*<br>
+ if( omp_get_thread_num() == 0 )<br>
+ {<br>
+ printf("Lookup: Energy = %lf, nuc = %d\n",
p_energy, nuc);<br>
+ printf("e_h = %lf e_l = %lf\n",
high->energy , low->energy);<br>
+ printf("xs_h = %lf xs_l = %lf\n",
high->elastic_xs, low->elastic_xs);<br>
+ printf("total_xs = %lf\n\n", xs_vector[1]);<br>
+ }<br>
+ */<br>
+<br>
+}<br>
+<br>
+// Calculates macroscopic cross section based on a given
material & energy<br>
+void calculate_macro_xs( double p_energy, int mat, long
n_isotopes,<br>
+ long n_gridpoints, int * restrict
num_nucs,<br>
+ double ** restrict concs,<br>
+ GridPoint * restrict energy_grid,<br>
+ NuclideGridPoint ** restrict
nuclide_grids,<br>
+ int ** restrict mats,<br>
+ double * restrict macro_xs_vector
){<br>
+ double xs_vector[5];<br>
+ int p_nuc; // the nuclide we are looking up<br>
+ long idx = 0;<br>
+ double conc; // the concentration of the nuclide in
the material<br>
+<br>
+ // cleans out macro_xs_vector<br>
+ for( int k = 0; k < 5; k++ )<br>
+ macro_xs_vector[k] = 0;<br>
+<br>
+ // binary search for energy on unionized energy grid
(UEG)<br>
+ idx = grid_search( n_isotopes * n_gridpoints,
p_energy,<br>
+ energy_grid);<br>
+<br>
+ // Once we find the pointer array on the UEG, we can
pull the data<br>
+ // from the respective nuclide grids, as well as the
nuclide<br>
+ // concentration data for the material<br>
+ // Each nuclide from the material needs to have its
micro-XS array<br>
+ // looked up & interpolatied (via
calculate_micro_xs). Then, the<br>
+ // micro XS is multiplied by the concentration of
that nuclide<br>
+ // in the material, and added to the total macro XS
array.<br>
+ for( int j = 0; j < num_nucs[mat]; j++ )<br>
+ {<br>
+ p_nuc = mats[mat][j];<br>
+ conc = concs[mat][j];<br>
+ calculate_micro_xs( p_energy, p_nuc,
n_isotopes,<br>
+ n_gridpoints,
energy_grid,<br>
+ nuclide_grids, idx,
xs_vector );<br>
+ for( int k = 0; k < 5; k++ )<br>
+ macro_xs_vector[k] += xs_vector[k] *
conc;<br>
+ }<br>
+<br>
+ //test<br>
+ /*<br>
+ for( int k = 0; k < 5; k++ )<br>
+ printf("Energy: %lf, Material: %d,
XSVector[%d]: %lf\n",<br>
+ p_energy, mat, k,
macro_xs_vector[k]);<br>
+ */<br>
+}<br>
+<br>
+<br>
+// (fixed) binary search for energy on unionized energy
grid<br>
+// returns lower index<br>
+long grid_search( long n, double quarry, GridPoint * A)<br>
+{<br>
+ long lowerLimit = 0;<br>
+ long upperLimit = n-1;<br>
+ long examinationPoint;<br>
+ long length = upperLimit - lowerLimit;<br>
+<br>
+ while( length > 1 )<br>
+ {<br>
+ examinationPoint = lowerLimit + ( length / 2
);<br>
+<br>
+ if( A[examinationPoint].energy > quarry )<br>
+ upperLimit = examinationPoint;<br>
+ else<br>
+ lowerLimit = examinationPoint;<br>
+<br>
+ length = upperLimit - lowerLimit;<br>
+ }<br>
+<br>
+ return lowerLimit;<br>
+}<br>
<br>
Added: test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/GridInit.c<br>
URL: <a moz-do-not-send="true"
href="http://llvm.org/viewvc/llvm-project/test-suite/trunk/MultiSource/Benchmarks/DOE-ProxyApps-C/XSBench/GridInit.c?rev=289666&view=auto"
rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-<wbr>project/test-suite/trunk/<wbr>MultiSource/Benchmarks/DOE-<wbr>ProxyApps-C/XSBench/GridInit.<wbr>c?rev=289666&view=auto</a><br>
==============================<wbr>==============================<wbr>==================<br>
--- test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/GridInit.c
(added)<br>
+++ test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/GridInit.c
Wed Dec 14 10:42:31 2016<br>
@@ -0,0 +1,171 @@<br>
+#include "XSbench_header.h"<br>
+<br>
+#ifdef MPI<br>
+#include<mpi.h><br>
+#endif<br>
+<br>
+// Generates randomized energy grid for each nuclide<br>
+// Note that this is done as part of initialization
(serial), so<br>
+// rand() is used.<br>
+void generate_grids( NuclideGridPoint ** nuclide_grids,<br>
+ long n_isotopes, long n_gridpoints ) {<br>
+ for( long i = 0; i < n_isotopes; i++ )<br>
+ for( long j = 0; j < n_gridpoints; j++ )<br>
+ {<br>
+ nuclide_grids[i][j].energy
=((double)rand()/(double)RAND_<wbr>MAX);<br>
+ nuclide_grids[i][j].total_xs
=((double)rand()/(double)RAND_<wbr>MAX);<br>
+ nuclide_grids[i][j].elastic_xs
=((double)rand()/(double)RAND_<wbr>MAX);<br>
+ nuclide_grids[i][j].<wbr>absorbtion_xs=((double)rand()/<wbr>(double)RAND_MAX);<br>
+ nuclide_grids[i][j].fission_xs
=((double)rand()/(double)RAND_<wbr>MAX);<br>
+ nuclide_grids[i][j].nu_<wbr>fission_xs=((double)rand()/(<wbr>double)RAND_MAX);<br>
+ }<br>
+}<br>
+<br>
+// Verification version of this function (tighter control
over RNG)<br>
+void generate_grids_v( NuclideGridPoint ** nuclide_grids,<br>
+ long n_isotopes, long n_gridpoints ) {<br>
+ for( long i = 0; i < n_isotopes; i++ )<br>
+ for( long j = 0; j < n_gridpoints; j++ )<br>
+ {<br>
+ nuclide_grids[i][j].energy =
rn_v();<br>
+ nuclide_grids[i][j].total_xs =
rn_v();<br>
+ nuclide_grids[i][j].elastic_xs =
rn_v();<br>
+ nuclide_grids[i][j].<wbr>absorbtion_xs=
rn_v();<br>
+ nuclide_grids[i][j].fission_xs =
rn_v();<br>
+ nuclide_grids[i][j].nu_<wbr>fission_xs=
rn_v();<br>
+ }<br>
+}<br>
+<br>
+// Sorts the nuclide grids by energy (lowest -> highest)<br>
+void sort_nuclide_grids( NuclideGridPoint ** nuclide_grids,
long n_isotopes,<br>
+ long n_gridpoints )<br>
+{<br>
+ int (*cmp) (const void *, const void *);<br>
+ cmp = NGP_compare;<br>
+<br>
+ for( long i = 0; i < n_isotopes; i++ )<br>
+ qsort( nuclide_grids[i], n_gridpoints,
sizeof(NuclideGridPoint),<br>
+ cmp );<br>
+<br>
+ // error debug check<br>
+ /*<br>
+ for( int i = 0; i < n_isotopes; i++ )<br>
+ {<br>
+ printf("NUCLIDE %d
==============================<wbr>\n", i);<br>
+ for( int j = 0; j < n_gridpoints; j++ )<br>
+ printf("E%d = %lf\n", j,
nuclide_grids[i][j].energy);<br>
+ }<br>
+ */<br>
+}<br>
+<br>
+// Allocates unionized energy grid, and assigns union of
energy levels<br>
+// from nuclide grids to it.<br>
+GridPoint * generate_energy_grid( long n_isotopes, long
n_gridpoints,<br>
+ NuclideGridPoint **
nuclide_grids) {<br>
+ int mype = 0;<br>
+<br>
+ #ifdef MPI<br>
+ MPI_Comm_rank(MPI_COMM_WORLD, &mype);<br>
+ #endif<br>
+<br>
+ if( mype == 0 ) printf("Generating Unionized Energy
Grid...\n");<br>
+<br>
+ long n_unionized_grid_points =
n_isotopes*n_gridpoints;<br>
+ int (*cmp) (const void *, const void *);<br>
+ cmp = NGP_compare;<br>
+<br>
+ GridPoint * energy_grid = (GridPoint *)malloc(
n_unionized_grid_points<br>
+ *
sizeof( GridPoint ) );<br>
+ if( mype == 0 ) printf("Copying and Sorting all
nuclide grids...\n");<br>
+<br>
+ NuclideGridPoint ** n_grid_sorted = gpmatrix(
n_isotopes, n_gridpoints );<br>
+<br>
+<br>
+ memcpy( n_grid_sorted[0], nuclide_grids[0],
n_isotopes*n_gridpoints*<br>
+ sizeof(
NuclideGridPoint ) );<br>
+<br>
+ qsort( &n_grid_sorted[0][0],
n_unionized_grid_points,<br>
+ sizeof(NuclideGridPoint), cmp);<br>
+<br>
+ if( mype == 0 ) printf("Assigning energies to
unionized grid...\n");<br>
+<br>
+ for( long i = 0; i < n_unionized_grid_points; i++
)<br>
+ energy_grid[i].energy =
n_grid_sorted[0][i].energy;<br>
+<br>
+<br>
+ gpmatrix_free(n_grid_sorted);<br>
+<br>
+ int * full = (int *) malloc( n_isotopes *
n_unionized_grid_points<br>
+ * sizeof(int) );<br>
+ if( full == NULL )<br>
+ {<br>
+ fprintf(stderr,"ERROR - Out Of Memory!\n");<br>
+ exit(1);<br>
+ }<br>
+<br>
+ for( long i = 0; i < n_unionized_grid_points; i++
)<br>
+ energy_grid[i].xs_ptrs =
&full[n_isotopes * i];<br>
+<br>
+ // debug error checking<br>
+ /*<br>
+ for( int i = 0; i < n_unionized_grid_points; i++
)<br>
+ printf("E%d = %lf\n", i,
energy_grid[i].energy);<br>
+ */<br>
+<br>
+ return energy_grid;<br>
+}<br>
+<br>
+// Searches each nuclide grid for the closest energy level
and assigns<br>
+// pointer from unionized grid to the correct spot in the
nuclide grid.<br>
+// This process is time consuming, as the number of binary
searches<br>
+// required is: binary searches = n_gridpoints *
n_isotopes^2<br>
+void set_grid_ptrs( GridPoint * energy_grid,
NuclideGridPoint ** nuclide_grids,<br>
+ long n_isotopes, long n_gridpoints )<br>
+{<br>
+ int mype = 0;<br>
+<br>
+ #ifdef MPI<br>
+ MPI_Comm_rank(MPI_COMM_WORLD, &mype);<br>
+ #endif<br>
+<br>
+ if( mype == 0 ) printf("Assigning pointers to
Unionized Energy Grid...\n");<br>
+ #ifdef OPENMP<br>
+ #pragma omp parallel for default(none) \<br>
+ shared( energy_grid, nuclide_grids, n_isotopes,
n_gridpoints, mype )<br>
+ #endif<br>
+ for( long i = 0; i < n_isotopes * n_gridpoints ;
i++ )<br>
+ {<br>
+ int nthreads = 1, tid = 0;<br>
+ double quarry = energy_grid[i].energy;<br>
+<br>
+ #ifdef OPENMP<br>
+ nthreads = omp_get_num_threads();<br>
+ tid = omp_get_thread_num();<br>
+ #endif<br>
+<br>
+ if( INFO && mype == 0 && tid
== 0 && i % 200 == 0 )<br>
+ printf("\rAligning Unionized
Grid...(%.0lf%% complete)",<br>
+ 100.0 * (double) i /
(n_isotopes*n_gridpoints /<br>
+
nthreads) );<br>
+ for( long j = 0; j < n_isotopes; j++ )<br>
+ {<br>
+ // j is the nuclide i.d.<br>
+ // log n binary search<br>
+ energy_grid[i].xs_ptrs[j] =<br>
+ binary_search(
nuclide_grids[j], quarry, n_gridpoints);<br>
+ }<br>
+ }<br>
+ if( mype == 0 ) printf("\n");<br>
+<br>
+ //test<br>
+ /*<br>
+ for( int i=0; i < n_isotopes * n_gridpoints; i++
)<br>
+ for( int j = 0; j < n_isotopes; j++ )<br>
+ printf("E = %.4lf\tNuclide
%d->%p->%.4lf\n",<br>
+ energy_grid[i].energy,<br>
+ j,<br>
+
energy_grid[i].xs_ptrs[j],<br>
+
(energy_grid[i].xs_ptrs[j])-><wbr>energy<br>
+ );<br>
+ */<br>
+}<br>
<br>
Added: test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/LICENSE<br>
URL: <a moz-do-not-send="true"
href="http://llvm.org/viewvc/llvm-project/test-suite/trunk/MultiSource/Benchmarks/DOE-ProxyApps-C/XSBench/LICENSE?rev=289666&view=auto"
rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-<wbr>project/test-suite/trunk/<wbr>MultiSource/Benchmarks/DOE-<wbr>ProxyApps-C/XSBench/LICENSE?<wbr>rev=289666&view=auto</a><br>
==============================<wbr>==============================<wbr>==================<br>
--- test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/LICENSE
(added)<br>
+++ test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/LICENSE
Wed Dec 14 10:42:31 2016<br>
@@ -0,0 +1,18 @@<br>
+Copyright (c) 2012-2013 Argonne National Laboratory<br>
+<br>
+Permission is hereby granted, free of charge, to any person
obtaining a copy of<br>
+this software and associated documentation files (the
"Software"), to deal in<br>
+the Software without restriction, including without
limitation the rights to<br>
+use, copy, modify, merge, publish, distribute, sublicense,
and/or sell copies of<br>
+the Software, and to permit persons to whom the Software is
furnished to do so,<br>
+subject to the following conditions:<br>
+<br>
+The above copyright notice and this permission notice shall
be included in all<br>
+copies or substantial portions of the Software.<br>
+<br>
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY
KIND, EXPRESS OR<br>
+IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
MERCHANTABILITY, FITNESS<br>
+FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT
SHALL THE AUTHORS OR<br>
+COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER<br>
+IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN<br>
+CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
IN THE SOFTWARE.<br>
<br>
Added: test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/Main.c<br>
URL: <a moz-do-not-send="true"
href="http://llvm.org/viewvc/llvm-project/test-suite/trunk/MultiSource/Benchmarks/DOE-ProxyApps-C/XSBench/Main.c?rev=289666&view=auto"
rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-<wbr>project/test-suite/trunk/<wbr>MultiSource/Benchmarks/DOE-<wbr>ProxyApps-C/XSBench/Main.c?<wbr>rev=289666&view=auto</a><br>
==============================<wbr>==============================<wbr>==================<br>
--- test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/Main.c
(added)<br>
+++ test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/Main.c
Wed Dec 14 10:42:31 2016<br>
@@ -0,0 +1,285 @@<br>
+#include "XSbench_header.h"<br>
+<br>
+#ifdef MPI<br>
+#include<mpi.h><br>
+#endif<br>
+<br>
+int main( int argc, char* argv[] )<br>
+{<br>
+ // ==============================<wbr>==============================<wbr>=========<br>
+ // Initialization & Command Line Read-In<br>
+ // ==============================<wbr>==============================<wbr>=========<br>
+ int version = 13;<br>
+ int mype = 0;<br>
+ #ifdef OPENMP<br>
+ int max_procs = omp_get_num_procs();<br>
+ #else<br>
+ int max_procs = 1;<br>
+ #endif<br>
+ int i, thread = 0, mat;<br>
+ unsigned long seed;<br>
+ double omp_start = 0.0, omp_end = 0.0, p_energy;<br>
+ unsigned long long vhash = 0;<br>
+ int nprocs;<br>
+<br>
+ #ifdef MPI<br>
+ MPI_Status stat;<br>
+ MPI_Init(&argc, &argv);<br>
+ MPI_Comm_size(MPI_COMM_WORLD, &nprocs);<br>
+ MPI_Comm_rank(MPI_COMM_WORLD, &mype);<br>
+ #endif<br>
+<br>
+ // rand() is only used in the serial initialization
stages.<br>
+ // A custom RNG is used in parallel portions.<br>
+ #ifdef VERIFICATION<br>
+ srand(26);<br>
+ #else<br>
+ srand(time(NULL));<br>
+ #endif<br>
+<br>
+ // Process CLI Fields -- store in "Inputs" structure<br>
+ Inputs in = read_CLI( argc, argv );<br>
+<br>
+ #ifdef OPENMP<br>
+ // Set number of OpenMP Threads<br>
+ omp_set_num_threads(in.<wbr>nthreads);<br>
+ #endif<br>
+<br>
+ // Print-out of Input Summary<br>
+ if( mype == 0 )<br>
+ print_inputs( in, nprocs, version );<br>
+<br>
+ // ==============================<wbr>==============================<wbr>=========<br>
+ // Prepare Nuclide Energy Grids, Unionized Energy
Grid, & Material Data<br>
+ // ==============================<wbr>==============================<wbr>=========<br>
+<br>
+ // Allocate & fill energy grids<br>
+ #ifndef BINARY_READ<br>
+ if( mype == 0) printf("Generating Nuclide Energy
Grids...\n");<br>
+ #endif<br>
+<br>
+ NuclideGridPoint ** nuclide_grids =
gpmatrix(in.n_isotopes,in.n_<wbr>gridpoints);<br>
+<br>
+ #ifdef VERIFICATION<br>
+ generate_grids_v( nuclide_grids, in.n_isotopes,
in.n_gridpoints );<br>
+ #else<br>
+ generate_grids( nuclide_grids, in.n_isotopes,
in.n_gridpoints );<br>
+ #endif<br>
+<br>
+ // Sort grids by energy<br>
+ #ifndef BINARY_READ<br>
+ if( mype == 0) printf("Sorting Nuclide Energy
Grids...\n");<br>
+ sort_nuclide_grids( nuclide_grids, in.n_isotopes,
in.n_gridpoints );<br>
+ #endif<br>
+<br>
+ // Prepare Unionized Energy Grid Framework<br>
+ #ifndef BINARY_READ<br>
+ GridPoint * energy_grid = generate_energy_grid(
in.n_isotopes,<br>
+ in.n_gridpoints,
nuclide_grids );<br>
+ #else<br>
+ GridPoint * energy_grid = (GridPoint *)malloc(
in.n_isotopes *<br>
+ in.n_gridpoints * sizeof(
GridPoint ) );<br>
+ int * index_data = (int *) malloc( in.n_isotopes *
in.n_gridpoints<br>
+ * in.n_isotopes * sizeof(int));<br>
+ for( i = 0; i < in.n_isotopes*in.n_gridpoints;
i++ )<br>
+ energy_grid[i].xs_ptrs =
&index_data[i*in.n_isotopes];<br>
+ #endif<br>
+<br>
+ // Double Indexing. Filling in energy_grid with
pointers to the<br>
+ // nuclide_energy_grids.<br>
+ #ifndef BINARY_READ<br>
+ set_grid_ptrs( energy_grid, nuclide_grids,
in.n_isotopes, in.n_gridpoints );<br>
+ #endif<br>
+<br>
+ #ifdef BINARY_READ<br>
+ if( mype == 0 ) printf("Reading data from
\"XS_data.dat\" file...\n");<br>
+ binary_read(in.n_isotopes, in.n_gridpoints,
nuclide_grids, energy_grid);<br>
+ #endif<br>
+<br>
+ // Get material data<br>
+ if( mype == 0 )<br>
+ printf("Loading Mats...\n");<br>
+ int *num_nucs = load_num_nucs(in.n_isotopes);<br>
+ int **mats = load_mats(num_nucs, in.n_isotopes);<br>
+<br>
+ #ifdef VERIFICATION<br>
+ double **concs = load_concs_v(num_nucs);<br>
+ #else<br>
+ double **concs = load_concs(num_nucs);<br>
+ #endif<br>
+<br>
+ #ifdef BINARY_DUMP<br>
+ if( mype == 0 ) printf("Dumping data to binary
file...\n");<br>
+ binary_dump(in.n_isotopes, in.n_gridpoints,
nuclide_grids, energy_grid);<br>
+ if( mype == 0 ) printf("Binary file \"XS_data.dat\"
written! Exiting...\n");<br>
+ return 0;<br>
+ #endif<br>
+<br>
+ // ==============================<wbr>==============================<wbr>=========<br>
+ // Cross Section (XS) Parallel Lookup Simulation
Begins<br>
+ // ==============================<wbr>==============================<wbr>=========<br>
+<br>
+ // Outer benchmark loop can loop through all
possible # of threads<br>
+ #if defined(BENCHMARK) && defined(OPENMP)<br>
+ for( int bench_n = 1; bench_n
<=omp_get_num_procs(); bench_n++ )<br>
+ {<br>
+ in.nthreads = bench_n;<br>
+ omp_set_num_threads(in.<wbr>nthreads);<br>
+ #endif<br>
+<br>
+ if( mype == 0 )<br>
+ {<br>
+ printf("\n");<br>
+ border_print();<br>
+ center_print("SIMULATION", 79);<br>
+ border_print();<br>
+ }<br>
+<br>
+ #if defined(TIMING) && defined(OPENMP)<br>
+ omp_start = omp_get_wtime();<br>
+ #endif<br>
+<br>
+ //initialize papi with one thread (master) here<br>
+ #ifdef PAPI<br>
+ if ( PAPI_library_init(PAPI_VER_<wbr>CURRENT) !=
PAPI_VER_CURRENT){<br>
+ fprintf(stderr, "PAPI library init
error!\n");<br>
+ exit(1);<br>
+ }<br>
+ #endif<br>
+<br>
+ // OpenMP compiler directives - declaring variables
as shared or private<br>
+ #ifdef OPENMP<br>
+ #pragma omp parallel default(none) \<br>
+ private(i, thread, p_energy, mat, seed) \<br>
+ shared( max_procs, in, energy_grid, nuclide_grids, \<br>
+ mats, concs, num_nucs, mype, vhash)<br>
+ #endif<br>
+ {<br>
+ // Initialize parallel PAPI counters<br>
+ #ifdef PAPI<br>
+ int eventset = PAPI_NULL;<br>
+ int num_papi_events;<br>
+ #ifdef OPENMP<br>
+ #pragma omp critical<br>
+ #endif<br>
+ {<br>
+ counter_init(&eventset,
&num_papi_events);<br>
+ }<br>
+ #endif<br>
+<br>
+ double macro_xs_vector[5];<br>
+ double * xs = (double *) calloc(5,
sizeof(double));<br>
+<br>
+ // Initialize RNG seeds for threads<br>
+ #ifdef OPENMP<br>
+ thread = omp_get_thread_num();<br>
+ #endif<br>
+ seed = (thread+1)*19+17;<br>
+<br>
+ // XS Lookup Loop<br>
+ #ifdef OPENMP<br>
+ #pragma omp for schedule(dynamic)<br>
+ #endif<br>
+ for( i = 0; i < in.lookups; i++ )<br>
+ {<br>
+ // Status text<br>
+ if( INFO && mype == 0
&& thread == 0 && i % 1000 == 0 )<br>
+ printf("\rCalculating
XS's... (%.0lf%% completed)",<br>
+ (i / (
(double)in.lookups / (double) in.nthreads ))<br>
+ / (double)
in.nthreads * 100.0);<br>
+<br>
+ // Randomly pick an energy and
material for the particle<br>
+ #ifdef VERIFICATION<br>
+ #ifdef OPENMP<br>
+ #pragma omp critical<br>
+ #endif<br>
+ {<br>
+ p_energy = rn_v();<br>
+ mat =
pick_mat(&seed);<br>
+ }<br>
+ #else<br>
+ p_energy = rn(&seed);<br>
+ mat = pick_mat(&seed);<br>
+ #endif<br>
+<br>
+ // debugging<br>
+ //printf("E = %lf mat = %d\n",
p_energy, mat);<br>
+<br>
+ // This returns the macro_xs_vector,
but we're not going<br>
+ // to do anything with it in this
program, so return value<br>
+ // is written over.<br>
+ calculate_macro_xs( p_energy, mat,
in.n_isotopes,<br>
+ in.n_gridpoints,
num_nucs, concs,<br>
+ energy_grid,
nuclide_grids, mats,<br>
+ macro_xs_vector );<br>
+<br>
+ // Copy results from above function
call onto heap<br>
+ // so that compiler cannot optimize
function out<br>
+ // (only occurs if -flto flag is
used)<br>
+ memcpy(xs, macro_xs_vector,
5*sizeof(double));<br>
+<br>
+ // Verification hash calculation<br>
+ // This method provides a consistent
hash accross<br>
+ // architectures and compilers.<br>
+ #ifdef VERIFICATION<br>
+ char line[256];<br>
+ sprintf(line, "%.5lf %d %.5lf %.5lf
%.5lf %.5lf %.5lf",<br>
+ p_energy, mat,<br>
+ macro_xs_vector[0],<br>
+ macro_xs_vector[1],<br>
+ macro_xs_vector[2],<br>
+ macro_xs_vector[3],<br>
+ macro_xs_vector[4]);<br>
+ unsigned long long vhash_local =
hash(line, 10000);<br>
+ #ifdef OPENMP<br>
+ #pragma omp atomic<br>
+ #endif<br>
+ vhash += vhash_local;<br>
+ #endif<br>
+ }<br>
+<br>
+ // Prints out thread local PAPI counters<br>
+ #ifdef PAPI<br>
+ if( mype == 0 && thread == 0 )<br>
+ {<br>
+ printf("\n");<br>
+ border_print();<br>
+ center_print("PAPI COUNTER RESULTS",
79);<br>
+ border_print();<br>
+ printf("Count \tSmybol
\tDescription\n");<br>
+ }<br>
+ {<br>
+ #ifdef OPENMP<br>
+ #pragma omp barrier<br>
+ #endif<br>
+ }<br>
+ counter_stop(&eventset,
num_papi_events);<br>
+ #endif<br>
+<br>
+ }<br>
+<br>
+ #ifndef PAPI<br>
+ if( mype == 0)<br>
+ {<br>
+ printf("\n" );<br>
+ printf("Simulation complete.\n" );<br>
+ }<br>
+ #endif<br>
+<br>
+ #if defined(TIMING) && defined(OPENMP)<br>
+ omp_end = omp_get_wtime();<br>
+ #endif<br>
+<br>
+ // Print / Save Results and Exit<br>
+ print_results( in, mype, omp_end-omp_start, nprocs,
vhash );<br>
+<br>
+ #ifdef BENCHMARK<br>
+ }<br>
+ #endif<br>
+<br>
+ #ifdef MPI<br>
+ MPI_Finalize();<br>
+ #endif<br>
+<br>
+ return 0;<br>
+}<br>
<br>
Added: test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/Makefile<br>
URL: <a moz-do-not-send="true"
href="http://llvm.org/viewvc/llvm-project/test-suite/trunk/MultiSource/Benchmarks/DOE-ProxyApps-C/XSBench/Makefile?rev=289666&view=auto"
rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-<wbr>project/test-suite/trunk/<wbr>MultiSource/Benchmarks/DOE-<wbr>ProxyApps-C/XSBench/Makefile?<wbr>rev=289666&view=auto</a><br>
==============================<wbr>==============================<wbr>==================<br>
--- test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/Makefile
(added)<br>
+++ test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/Makefile
Wed Dec 14 10:42:31 2016<br>
@@ -0,0 +1,8 @@<br>
+LEVEL = ../../../..<br>
+<br>
+PROG = XSBench<br>
+CPPFLAGS = -DVERIFICATION<br>
+LDFLAGS = -lm<br>
+RUN_OPTIONS = -s small -g 1250 -l 1000000<br>
+include $(LEVEL)/MultiSource/Makefile.<wbr>multisrc<br>
+<br>
<br>
Added: test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/Materials.c<br>
URL: <a moz-do-not-send="true"
href="http://llvm.org/viewvc/llvm-project/test-suite/trunk/MultiSource/Benchmarks/DOE-ProxyApps-C/XSBench/Materials.c?rev=289666&view=auto"
rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-<wbr>project/test-suite/trunk/<wbr>MultiSource/Benchmarks/DOE-<wbr>ProxyApps-C/XSBench/Materials.<wbr>c?rev=289666&view=auto</a><br>
==============================<wbr>==============================<wbr>==================<br>
--- test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/Materials.c
(added)<br>
+++ test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/Materials.c
Wed Dec 14 10:42:31 2016<br>
@@ -0,0 +1,188 @@<br>
+// Material data is hard coded into the functions in this
file.<br>
+// Note that there are 12 materials present in H-M (large
or small)<br>
+<br>
+#include "XSbench_header.h"<br>
+<br>
+// num_nucs represents the number of nuclides that each
material contains<br>
+int * load_num_nucs(long n_isotopes)<br>
+{<br>
+ int * num_nucs = (int*)malloc(12*sizeof(int));<br>
+<br>
+ // Material 0 is a special case (fuel). The H-M
small reactor uses<br>
+ // 34 nuclides, while H-M larges uses 300.<br>
+ if( n_isotopes == 68 )<br>
+ num_nucs[0] = 34; // HM Small is 34, H-M
Large is 321<br>
+ else<br>
+ num_nucs[0] = 321; // HM Small is 34, H-M
Large is 321<br>
+<br>
+ num_nucs[1] = 5;<br>
+ num_nucs[2] = 4;<br>
+ num_nucs[3] = 4;<br>
+ num_nucs[4] = 27;<br>
+ num_nucs[5] = 21;<br>
+ num_nucs[6] = 21;<br>
+ num_nucs[7] = 21;<br>
+ num_nucs[8] = 21;<br>
+ num_nucs[9] = 21;<br>
+ num_nucs[10] = 9;<br>
+ num_nucs[11] = 9;<br>
+<br>
+ return num_nucs;<br>
+}<br>
+<br>
+// Assigns an array of nuclide ID's to each material<br>
+int ** load_mats( int * num_nucs, long n_isotopes )<br>
+{<br>
+ int ** mats = (int **) malloc( 12 * sizeof(int *) );<br>
+ for( int i = 0; i < 12; i++ )<br>
+ mats[i] = (int *) malloc(num_nucs[i] *
sizeof(int) );<br>
+<br>
+ // Small H-M has 34 fuel nuclides<br>
+ int mats0_Sml[] = { 58, 59, 60, 61, 40, 42, 43, 44,
45, 46, 1, 2, 3, 7,<br>
+ 8, 9, 10, 29, 57, 47, 48, 0, 62,
15, 33, 34, 52, 53,<br>
+ 54, 55, 56, 18, 23, 41 }; //fuel<br>
+ // Large H-M has 300 fuel nuclides<br>
+ int mats0_Lrg[321] = { 58, 59, 60, 61, 40, 42, 43,
44, 45, 46, 1, 2, 3, 7,<br>
+ 8, 9, 10, 29, 57, 47, 48, 0, 62,
15, 33, 34, 52, 53,<br>
+ 54, 55, 56, 18, 23, 41 }; //fuel<br>
+ for( int i = 0; i < 321-34; i++ )<br>
+ mats0_Lrg[34+i] = 68 + i; // H-M large adds
nuclides to fuel only<br>
+<br>
+ // These are the non-fuel materials<br>
+ int mats1[] = { 63, 64, 65, 66, 67 }; // cladding<br>
+ int mats2[] = { 24, 41, 4, 5 }; // cold borated
water<br>
+ int mats3[] = { 24, 41, 4, 5 }; // hot borated
water<br>
+ int mats4[] = { 19, 20, 21, 22, 35, 36, 37, 38, 39,
25, 27, 28, 29,<br>
+ 30, 31, 32, 26, 49, 50, 51, 11, 12,
13, 14, 6, 16,<br>
+ 17 }; // RPV<br>
+ int mats5[] = { 24, 41, 4, 5, 19, 20, 21, 22, 35,
36, 37, 38, 39, 25,<br>
+ 49, 50, 51, 11, 12, 13, 14 }; //
lower radial reflector<br>
+ int mats6[] = { 24, 41, 4, 5, 19, 20, 21, 22, 35,
36, 37, 38, 39, 25,<br>
+ 49, 50, 51, 11, 12, 13, 14 }; //
top reflector / plate<br>
+ int mats7[] = { 24, 41, 4, 5, 19, 20, 21, 22, 35,
36, 37, 38, 39, 25,<br>
+ 49, 50, 51, 11, 12, 13, 14 }; //
bottom plate<br>
+ int mats8[] = { 24, 41, 4, 5, 19, 20, 21, 22, 35,
36, 37, 38, 39, 25,<br>
+ 49, 50, 51, 11, 12, 13, 14 }; //
bottom nozzle<br>
+ int mats9[] = { 24, 41, 4, 5, 19, 20, 21, 22, 35,
36, 37, 38, 39, 25,<br>
+ 49, 50, 51, 11, 12, 13, 14 }; //
top nozzle<br>
+ int mats10[] = { 24, 41, 4, 5, 63, 64, 65, 66, 67 };
// top of FA's<br>
+ int mats11[] = { 24, 41, 4, 5, 63, 64, 65, 66, 67 };
// bottom FA's<br>
+<br>
+ // H-M large v small dependency<br>
+ if( n_isotopes == 68 )<br>
+ memcpy( mats[0], mats0_Sml, num_nucs[0] *
sizeof(int) );<br>
+ else<br>
+ memcpy( mats[0], mats0_Lrg, num_nucs[0] *
sizeof(int) );<br>
+<br>
+ // Copy other materials<br>
+ memcpy( mats[1], mats1, num_nucs[1] * sizeof(int)
);<br>
+ memcpy( mats[2], mats2, num_nucs[2] * sizeof(int)
);<br>
+ memcpy( mats[3], mats3, num_nucs[3] * sizeof(int)
);<br>
+ memcpy( mats[4], mats4, num_nucs[4] * sizeof(int)
);<br>
+ memcpy( mats[5], mats5, num_nucs[5] * sizeof(int)
);<br>
+ memcpy( mats[6], mats6, num_nucs[6] * sizeof(int)
);<br>
+ memcpy( mats[7], mats7, num_nucs[7] * sizeof(int)
);<br>
+ memcpy( mats[8], mats8, num_nucs[8] * sizeof(int)
);<br>
+ memcpy( mats[9], mats9, num_nucs[9] * sizeof(int)
);<br>
+ memcpy( mats[10], mats10, num_nucs[10] * sizeof(int)
);<br>
+ memcpy( mats[11], mats11, num_nucs[11] * sizeof(int)
);<br>
+<br>
+ // test<br>
+ /*<br>
+ for( int i = 0; i < 12; i++ )<br>
+ for( int j = 0; j < num_nucs[i]; j++ )<br>
+ printf("material %d - Nuclide %d:
%d\n",<br>
+ i, j, mats[i][j]);<br>
+ */<br>
+<br>
+ return mats;<br>
+}<br>
+<br>
+// Creates a randomized array of 'concentrations' of
nuclides in each mat<br>
+double ** load_concs( int * num_nucs )<br>
+{<br>
+ double ** concs = (double **)malloc( 12 * sizeof(
double *) );<br>
+<br>
+ for( int i = 0; i < 12; i++ )<br>
+ concs[i] = (double *)malloc( num_nucs[i] *
sizeof(double) );<br>
+<br>
+ for( int i = 0; i < 12; i++ )<br>
+ for( int j = 0; j < num_nucs[i]; j++ )<br>
+ concs[i][j] = (double) rand() /
(double) RAND_MAX;<br>
+<br>
+ // test<br>
+ /*<br>
+ for( int i = 0; i < 12; i++ )<br>
+ for( int j = 0; j < num_nucs[i]; j++ )<br>
+ printf("concs[%d][%d] = %lf\n", i,
j, concs[i][j] );<br>
+ */<br>
+<br>
+ return concs;<br>
+}<br>
+<br>
+// Verification version of this function (tighter control
over RNG)<br>
+double ** load_concs_v( int * num_nucs )<br>
+{<br>
+ double ** concs = (double **)malloc( 12 * sizeof(
double *) );<br>
+<br>
+ for( int i = 0; i < 12; i++ )<br>
+ concs[i] = (double *)malloc( num_nucs[i] *
sizeof(double) );<br>
+<br>
+ for( int i = 0; i < 12; i++ )<br>
+ for( int j = 0; j < num_nucs[i]; j++ )<br>
+ concs[i][j] = rn_v();<br>
+<br>
+ // test<br>
+ /*<br>
+ for( int i = 0; i < 12; i++ )<br>
+ for( int j = 0; j < num_nucs[i]; j++ )<br>
+ printf("concs[%d][%d] = %lf\n", i,
j, concs[i][j] );<br>
+ */<br>
+<br>
+ return concs;<br>
+}<br>
+<br>
+// picks a material based on a probabilistic distribution<br>
+int pick_mat( unsigned long * seed )<br>
+{<br>
+ // I have a nice spreadsheet supporting these
numbers. They are<br>
+ // the fractions (by volume) of material in the
core. Not a<br>
+ // *perfect* approximation of where XS lookups are
going to occur,<br>
+ // but this will do a good job of biasing the system
nonetheless.<br>
+<br>
+ // Also could be argued that doing fractions by
weight would be<br>
+ // a better approximation, but volume does a good
enough job for now.<br>
+<br>
+ double dist[12];<br>
+ dist[0] = 0.140; // fuel<br>
+ dist[1] = 0.052; // cladding<br>
+ dist[2] = 0.275; // cold, borated water<br>
+ dist[3] = 0.134; // hot, borated water<br>
+ dist[4] = 0.154; // RPV<br>
+ dist[5] = 0.064; // Lower, radial reflector<br>
+ dist[6] = 0.066; // Upper reflector / top
plate<br>
+ dist[7] = 0.055; // bottom plate<br>
+ dist[8] = 0.008; // bottom nozzle<br>
+ dist[9] = 0.015; // top nozzle<br>
+ dist[10] = 0.025; // top of fuel assemblies<br>
+ dist[11] = 0.013; // bottom of fuel assemblies<br>
+<br>
+ //double roll = (double) rand() / (double) RAND_MAX;<br>
+ #ifdef VERIFICATION<br>
+ double roll = rn_v();<br>
+ #else<br>
+ double roll = rn(seed);<br>
+ #endif<br>
+<br>
+ // makes a pick based on the distro<br>
+ for( int i = 0; i < 12; i++ )<br>
+ {<br>
+ double running = 0;<br>
+ for( int j = i; j > 0; j-- )<br>
+ running += dist[j];<br>
+ if( roll < running )<br>
+ return i;<br>
+ }<br>
+<br>
+ return 0;<br>
+}<br>
<br>
Added: test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/XSBench.reference_<wbr>output<br>
URL: <a moz-do-not-send="true"
href="http://llvm.org/viewvc/llvm-project/test-suite/trunk/MultiSource/Benchmarks/DOE-ProxyApps-C/XSBench/XSBench.reference_output?rev=289666&view=auto"
rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-<wbr>project/test-suite/trunk/<wbr>MultiSource/Benchmarks/DOE-<wbr>ProxyApps-C/XSBench/XSBench.<wbr>reference_output?rev=289666&<wbr>view=auto</a><br>
==============================<wbr>==============================<wbr>==================<br>
--- test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/XSBench.reference_<wbr>output
(added)<br>
+++ test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/XSBench.reference_<wbr>output
Wed Dec 14 10:42:31 2016<br>
@@ -0,0 +1,47 @@<br>
+=============================<wbr>==============================<wbr>=====================<br>
+ __ __ ___________ _<br>
+ \ \ / // ___| ___ \ | |<br>
+ \ V / \ `--.| |_/ / ___ _ __ ___| |__<br>
+ / \ `--. \ ___ \/ _ \ '_ \ / __| '_
\<br>
+ / /^\ \/\__/ / |_/ / __/ | | | (__| | |
|<br>
+ \/ \/\____/\____/ \___|_| |_|\___|_|
|_|<br>
+<br>
+=============================<wbr>==============================<wbr>=====================<br>
+ Developed at Argonne National
Laboratory<br>
+ Version: 13<br>
+=============================<wbr>==============================<wbr>=====================<br>
+ INPUT SUMMARY<br>
+=============================<wbr>==============================<wbr>=====================<br>
+Verification Mode: on<br>
+Materials: 12<br>
+H-M Benchmark Size: small<br>
+Total Nuclides: 68<br>
+Gridpoints (per Nuclide): 1,250<br>
+Unionized Energy Gridpoints: 85,000<br>
+XS Lookups: 1,000,000<br>
+Threads: 1<br>
+Est. Memory Usage (MB): 27<br>
+=============================<wbr>==============================<wbr>=====================<br>
+ INITIALIZATION<br>
+=============================<wbr>==============================<wbr>=====================<br>
+Generating Nuclide Energy Grids...<br>
+Sorting Nuclide Energy Grids...<br>
+Generating Unionized Energy Grid...<br>
+Copying and Sorting all nuclide grids...<br>
+Assigning energies to unionized grid...<br>
+Assigning pointers to Unionized Energy Grid...<br>
+<br>
+Loading Mats...<br>
+<br>
+=============================<wbr>==============================<wbr>=====================<br>
+ SIMULATION<br>
+=============================<wbr>==============================<wbr>=====================<br>
+<br>
+Simulation complete.<br>
+=============================<wbr>==============================<wbr>=====================<br>
+ RESULTS<br>
+=============================<wbr>==============================<wbr>=====================<br>
+Threads: 1<br>
+Verification checksum: 5000647235<br>
+=============================<wbr>==============================<wbr>=====================<br>
+exit 0<br>
<br>
Added: test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/XSbench_header.h<br>
URL: <a moz-do-not-send="true"
href="http://llvm.org/viewvc/llvm-project/test-suite/trunk/MultiSource/Benchmarks/DOE-ProxyApps-C/XSBench/XSbench_header.h?rev=289666&view=auto"
rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-<wbr>project/test-suite/trunk/<wbr>MultiSource/Benchmarks/DOE-<wbr>ProxyApps-C/XSBench/XSbench_<wbr>header.h?rev=289666&view=auto</a><br>
==============================<wbr>==============================<wbr>==================<br>
--- test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/XSbench_header.h
(added)<br>
+++ test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/XSbench_header.h
Wed Dec 14 10:42:31 2016<br>
@@ -0,0 +1,124 @@<br>
+#ifndef __XSBENCH_HEADER_H__<br>
+#define __XSBENCH_HEADER_H__<br>
+<br>
+#include<stdio.h><br>
+#include<stdlib.h><br>
+#include<time.h><br>
+#include<string.h><br>
+#include<strings.h><br>
+#include<math.h><br>
+#ifdef OPENMP<br>
+#include<omp.h><br>
+#endif<br>
+#include<unistd.h><br>
+#include<sys/time.h><br>
+<br>
+// The verification depends on the rand algorithm.<br>
+#include "glibc_compat_rand.h"<br>
+#ifndef NO_GLIBC_COMPAT_RAND<br>
+#define rand glibc_compat_rand<br>
+#define srand glibc_compat_srand<br>
+#endif<br>
+<br>
+// Papi Header<br>
+#ifdef PAPI<br>
+#include "papi.h"<br>
+#endif<br>
+<br>
+// I/O Specifiers<br>
+#define INFO 0<br>
+#define DEBUG 0<br>
+#define SAVE 0<br>
+<br>
+// Structures<br>
+typedef struct{<br>
+ double energy;<br>
+ double total_xs;<br>
+ double elastic_xs;<br>
+ double absorbtion_xs;<br>
+ double fission_xs;<br>
+ double nu_fission_xs;<br>
+} NuclideGridPoint;<br>
+<br>
+typedef struct{<br>
+ double energy;<br>
+ int * xs_ptrs;<br>
+} GridPoint;<br>
+<br>
+typedef struct{<br>
+ int nthreads;<br>
+ long n_isotopes;<br>
+ long n_gridpoints;<br>
+ int lookups;<br>
+ char * HM;<br>
+} Inputs;<br>
+<br>
+// Function Prototypes<br>
+void logo(int version);<br>
+void center_print(const char *s, int width);<br>
+void border_print(void);<br>
+void fancy_int(long a);<br>
+<br>
+NuclideGridPoint ** gpmatrix(size_t m, size_t n);<br>
+<br>
+void gpmatrix_free( NuclideGridPoint ** M );<br>
+<br>
+int NGP_compare( const void * a, const void * b );<br>
+<br>
+void generate_grids( NuclideGridPoint ** nuclide_grids,<br>
+ long n_isotopes, long n_gridpoints );<br>
+void generate_grids_v( NuclideGridPoint ** nuclide_grids,<br>
+ long n_isotopes, long n_gridpoints );<br>
+<br>
+void sort_nuclide_grids( NuclideGridPoint ** nuclide_grids,
long n_isotopes,<br>
+ long n_gridpoints );<br>
+<br>
+GridPoint * generate_energy_grid( long n_isotopes, long
n_gridpoints,<br>
+ NuclideGridPoint **
nuclide_grids);<br>
+<br>
+void set_grid_ptrs( GridPoint * energy_grid,
NuclideGridPoint ** nuclide_grids,<br>
+ long n_isotopes, long n_gridpoints );<br>
+<br>
+int binary_search( NuclideGridPoint * A, double quarry, int
n );<br>
+<br>
+void calculate_macro_xs( double p_energy, int mat, long
n_isotopes,<br>
+ long n_gridpoints, int *
restrict num_nucs,<br>
+ double ** restrict concs,<br>
+ GridPoint
* restrict energy_grid,<br>
+ NuclideGridPoint ** restrict
nuclide_grids,<br>
+ int **
restrict mats,<br>
+ double * restrict
macro_xs_vector );<br>
+<br>
+void calculate_micro_xs( double p_energy, int nuc, long
n_isotopes,<br>
+ long n_gridpoints,<br>
+ GridPoint * restrict
energy_grid,<br>
+ NuclideGridPoint ** restrict
nuclide_grids, int idx,<br>
+ double * restrict xs_vector );<br>
+<br>
+long grid_search( long n, double quarry, GridPoint * A);<br>
+<br>
+int * load_num_nucs(long n_isotopes);<br>
+int ** load_mats( int * num_nucs, long n_isotopes );<br>
+double ** load_concs( int * num_nucs );<br>
+double ** load_concs_v( int * num_nucs );<br>
+int pick_mat(unsigned long * seed);<br>
+double rn(unsigned long * seed);<br>
+int rn_int(unsigned long * seed);<br>
+void counter_stop( int * eventset, int num_papi_events );<br>
+void counter_init( int * eventset, int * num_papi_events );<br>
+void do_flops(void);<br>
+void do_loads( int nuc,<br>
+ NuclideGridPoint ** restrict nuclide_grids,<br>
+ long n_gridpoints );<br>
+Inputs read_CLI( int argc, char * argv[] );<br>
+void print_CLI_error(void);<br>
+double rn_v(void);<br>
+double round_double( double input );<br>
+unsigned int hash(unsigned char *str, int nbins);<br>
+size_t estimate_mem_usage( Inputs in );<br>
+void print_inputs(Inputs in, int nprocs, int version);<br>
+void print_results( Inputs in, int mype, double runtime,
int nprocs, unsigned long long vhash );<br>
+void binary_dump(long n_isotopes, long n_gridpoints,
NuclideGridPoint ** nuclide_grids, GridPoint * energy_grid);<br>
+void binary_read(long n_isotopes, long n_gridpoints,
NuclideGridPoint ** nuclide_grids, GridPoint * energy_grid);<br>
+<br>
+#endif<br>
<br>
Added: test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/XSutils.c<br>
URL: <a moz-do-not-send="true"
href="http://llvm.org/viewvc/llvm-project/test-suite/trunk/MultiSource/Benchmarks/DOE-ProxyApps-C/XSBench/XSutils.c?rev=289666&view=auto"
rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-<wbr>project/test-suite/trunk/<wbr>MultiSource/Benchmarks/DOE-<wbr>ProxyApps-C/XSBench/XSutils.c?<wbr>rev=289666&view=auto</a><br>
==============================<wbr>==============================<wbr>==================<br>
--- test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/XSutils.c
(added)<br>
+++ test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/XSutils.c
Wed Dec 14 10:42:31 2016<br>
@@ -0,0 +1,169 @@<br>
+#include "XSbench_header.h"<br>
+<br>
+// Allocates nuclide matrix<br>
+NuclideGridPoint ** gpmatrix(size_t m, size_t n)<br>
+{<br>
+ int i,j;<br>
+ NuclideGridPoint * full = (NuclideGridPoint *)
malloc( m * n *<br>
+ sizeof( NuclideGridPoint )
);<br>
+ NuclideGridPoint ** M = (NuclideGridPoint **)
malloc( m *<br>
+ sizeof(NuclideGridPoint *)
);<br>
+<br>
+ for( i = 0, j=0; i < m*n; i++ )<br>
+ if( i % n == 0 )<br>
+ M[j++] = &full[i];<br>
+<br>
+ return M;<br>
+}<br>
+<br>
+// Frees nuclide matrix<br>
+void gpmatrix_free( NuclideGridPoint ** M )<br>
+{<br>
+ free( *M );<br>
+ free( M );<br>
+}<br>
+<br>
+// Compare function for two grid points. Used for sorting
during init<br>
+int NGP_compare( const void * a, const void * b )<br>
+{<br>
+ NuclideGridPoint *i, *j;<br>
+<br>
+ i = (NuclideGridPoint *) a;<br>
+ j = (NuclideGridPoint *) b;<br>
+<br>
+ if( i->energy > j->energy )<br>
+ return 1;<br>
+ else if ( i->energy < j->energy)<br>
+ return -1;<br>
+ else<br>
+ return 0;<br>
+}<br>
+<br>
+<br>
+<br>
+// Binary Search function for nuclide grid<br>
+// Returns ptr to energy less than the quarry that is
closest to the quarry<br>
+int binary_search( NuclideGridPoint * A, double quarry, int
n )<br>
+{<br>
+ int min = 0;<br>
+ int max = n-1;<br>
+ int mid;<br>
+<br>
+ // checks to ensure we're not reading off the end of
the grid<br>
+ if( A[0].energy > quarry )<br>
+ return 0;<br>
+ else if( A[n-1].energy < quarry )<br>
+ return n-2;<br>
+<br>
+ // Begins binary search<br>
+ while( max >= min )<br>
+ {<br>
+ mid = min + floor( (max-min) / 2.0);<br>
+ if( A[mid].energy < quarry )<br>
+ min = mid+1;<br>
+ else if( A[mid].energy > quarry )<br>
+ max = mid-1;<br>
+ else<br>
+ return mid;<br>
+ }<br>
+ return max;<br>
+}<br>
+<br>
+// Park & Miller Multiplicative Conguential Algorithm<br>
+// From "Numerical Recipes" Second Edition<br>
+double rn(unsigned long * seed)<br>
+{<br>
+ double ret;<br>
+ unsigned long n1;<br>
+ unsigned long a = 16807;<br>
+ unsigned long m = 2147483647;<br>
+ n1 = ( a * (*seed) ) % m;<br>
+ *seed = n1;<br>
+ ret = (double) n1 / m;<br>
+ return ret;<br>
+}<br>
+<br>
+<br>
+<br>
+// RNG Used for Verification Option.<br>
+// This one has a static seed (must be set manually in
source).<br>
+// Park & Miller Multiplicative Conguential Algorithm<br>
+// From "Numerical Recipes" Second Edition<br>
+double rn_v(void)<br>
+{<br>
+ static unsigned long seed = 1337;<br>
+ double ret;<br>
+ unsigned long n1;<br>
+ unsigned long a = 16807;<br>
+ unsigned long m = 2147483647;<br>
+ n1 = ( a * (seed) ) % m;<br>
+ seed = n1;<br>
+ ret = (double) n1 / m;<br>
+ return ret;<br>
+}<br>
+<br>
+unsigned int hash(unsigned char *str, int nbins)<br>
+{<br>
+ unsigned int hash = 5381;<br>
+ int c;<br>
+<br>
+ while (c = *str++)<br>
+ hash = ((hash << 5) + hash) + c;<br>
+<br>
+ return hash % nbins;<br>
+}<br>
+<br>
+size_t estimate_mem_usage( Inputs in )<br>
+{<br>
+ size_t single_nuclide_grid = in.n_gridpoints *
sizeof( NuclideGridPoint );<br>
+ size_t all_nuclide_grids = in.n_isotopes *
single_nuclide_grid;<br>
+ size_t size_GridPoint = sizeof(GridPoint) +
in.n_isotopes*sizeof(int);<br>
+ size_t size_UEG =
in.n_isotopes*in.n_gridpoints * size_GridPoint;<br>
+ size_t memtotal;<br>
+<br>
+ memtotal = all_nuclide_grids + size_UEG;<br>
+ all_nuclide_grids = all_nuclide_grids / 1048576;<br>
+ size_UEG = size_UEG / 1048576;<br>
+ memtotal = memtotal / 1048576;<br>
+ return memtotal;<br>
+}<br>
+<br>
+void binary_dump(long n_isotopes, long n_gridpoints,
NuclideGridPoint ** nuclide_grids, GridPoint * energy_grid)<br>
+{<br>
+ FILE * fp = fopen("XS_data.dat", "wb");<br>
+ // Dump Nuclide Grid Data<br>
+ for( long i = 0; i < n_isotopes; i++ )<br>
+ fwrite(nuclide_grids[i],
sizeof(NuclideGridPoint), n_gridpoints, fp);<br>
+ // Dump UEG Data<br>
+ for( long i = 0; i < n_isotopes * n_gridpoints;
i++ )<br>
+ {<br>
+ // Write energy level<br>
+ fwrite(&energy_grid[i].energy,
sizeof(double), 1, fp);<br>
+<br>
+ // Write index data array (xs_ptrs array)<br>
+ fwrite(energy_grid[i].xs_ptrs, sizeof(int),
n_isotopes, fp);<br>
+ }<br>
+<br>
+ fclose(fp);<br>
+}<br>
+<br>
+void binary_read(long n_isotopes, long n_gridpoints,
NuclideGridPoint ** nuclide_grids, GridPoint * energy_grid)<br>
+{<br>
+ int stat;<br>
+ FILE * fp = fopen("XS_data.dat", "rb");<br>
+ // Read Nuclide Grid Data<br>
+ for( long i = 0; i < n_isotopes; i++ )<br>
+ stat = fread(nuclide_grids[i],
sizeof(NuclideGridPoint), n_gridpoints, fp);<br>
+ // Dump UEG Data<br>
+ for( long i = 0; i < n_isotopes * n_gridpoints;
i++ )<br>
+ {<br>
+ // Write energy level<br>
+ stat = fread(&energy_grid[i].energy,
sizeof(double), 1, fp);<br>
+<br>
+ // Write index data array (xs_ptrs array)<br>
+ stat = fread(energy_grid[i].xs_ptrs,
sizeof(int), n_isotopes, fp);<br>
+ }<br>
+<br>
+ fclose(fp);<br>
+<br>
+}<br>
<br>
Added: test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/glibc_compat_rand.c<br>
URL: <a moz-do-not-send="true"
href="http://llvm.org/viewvc/llvm-project/test-suite/trunk/MultiSource/Benchmarks/DOE-ProxyApps-C/XSBench/glibc_compat_rand.c?rev=289666&view=auto"
rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-<wbr>project/test-suite/trunk/<wbr>MultiSource/Benchmarks/DOE-<wbr>ProxyApps-C/XSBench/glibc_<wbr>compat_rand.c?rev=289666&view=<wbr>auto</a><br>
==============================<wbr>==============================<wbr>==================<br>
--- test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/glibc_compat_rand.c
(added)<br>
+++ test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/glibc_compat_rand.c
Wed Dec 14 10:42:31 2016<br>
@@ -0,0 +1,57 @@<br>
+/*===------------- glibc_compat_rand.h- glibc rand
emulation --------------===*\<br>
+|*<br>
+|* The LLVM Compiler Infrastructure<br>
+|*<br>
+|* This file is distributed under the University of
Illinois Open Source<br>
+|* License. See LICENSE.TXT for details.<br>
+|*<br>
+\*===------------------------<wbr>------------------------------<wbr>----------------===*/<br>
+<br>
+#include "glibc_compat_rand.h"<br>
+<br>
+/**<br>
+ * This rand implementation is designed to emulate the
implementation of<br>
+ * rand/srand in recent versions of glibc. This is used for
programs which<br>
+ * require this specific rand implementation in order to
pass verification<br>
+ * tests.<br>
+ */<br>
+<br>
+#define TABLE_SIZE 34<br>
+#define NUM_DISCARDED 344<br>
+static unsigned int table[TABLE_SIZE];<br>
+static int next;<br>
+<br>
+int glibc_compat_rand(void) {<br>
+ /* Calculate the indices i-3 and i-31 in the circular
vector. */<br>
+ int i3 = (next < 3) ? (TABLE_SIZE + next - 3) : (next
- 3);<br>
+ int i31 = (next < 31) ? (TABLE_SIZE + next - 31) :
(next - 31);<br>
+<br>
+ table[next] = table[i3] + table[i31];<br>
+ unsigned int r = table[next] >> 1;<br>
+<br>
+ ++next;<br>
+ if (next > TABLE_SIZE)<br>
+ next = 0;<br>
+<br>
+ return r;<br>
+}<br>
+<br>
+void glibc_compat_srand(unsigned int seed) {<br>
+ table[0] = seed;<br>
+ for (int i = 1; i < TABLE_SIZE - 3; ++i) {<br>
+ int r = 16807ll * ((long long) table[i - 1]) %
2147483647;<br>
+ if (r < 0)<br>
+ r += 2147483647;<br>
+<br>
+ table[i] = r;<br>
+ }<br>
+<br>
+ for (int i = TABLE_SIZE - 3; i < TABLE_SIZE; ++i)<br>
+ table[i] = table[i - 31];<br>
+<br>
+ next = 0;<br>
+<br>
+ for (int i = 0; i < NUM_DISCARDED; ++i)<br>
+ (void)glibc_compat_rand();<br>
+}<br>
+<br>
<br>
Added: test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/glibc_compat_rand.h<br>
URL: <a moz-do-not-send="true"
href="http://llvm.org/viewvc/llvm-project/test-suite/trunk/MultiSource/Benchmarks/DOE-ProxyApps-C/XSBench/glibc_compat_rand.h?rev=289666&view=auto"
rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-<wbr>project/test-suite/trunk/<wbr>MultiSource/Benchmarks/DOE-<wbr>ProxyApps-C/XSBench/glibc_<wbr>compat_rand.h?rev=289666&view=<wbr>auto</a><br>
==============================<wbr>==============================<wbr>==================<br>
--- test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/glibc_compat_rand.h
(added)<br>
+++ test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/glibc_compat_rand.h
Wed Dec 14 10:42:31 2016<br>
@@ -0,0 +1,17 @@<br>
+/*===------------- glibc_compat_rand.h- glibc rand
emulation --------------===*\<br>
+|*<br>
+|* The LLVM Compiler Infrastructure<br>
+|*<br>
+|* This file is distributed under the University of
Illinois Open Source<br>
+|* License. See LICENSE.TXT for details.<br>
+|*<br>
+\*===------------------------<wbr>------------------------------<wbr>----------------===*/<br>
+<br>
+#ifndef GLIBC_COMPAT_RAND_H<br>
+#define GLIBC_COMPAT_RAND_H<br>
+<br>
+int glibc_compat_rand(void);<br>
+void glibc_compat_srand(unsigned int seed);<br>
+<br>
+#endif /* GLIBC_COMPAT_RAND_H */<br>
+<br>
<br>
Added: test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/io.c<br>
URL: <a moz-do-not-send="true"
href="http://llvm.org/viewvc/llvm-project/test-suite/trunk/MultiSource/Benchmarks/DOE-ProxyApps-C/XSBench/io.c?rev=289666&view=auto"
rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-<wbr>project/test-suite/trunk/<wbr>MultiSource/Benchmarks/DOE-<wbr>ProxyApps-C/XSBench/io.c?rev=<wbr>289666&view=auto</a><br>
==============================<wbr>==============================<wbr>==================<br>
--- test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/io.c
(added)<br>
+++ test-suite/trunk/MultiSource/<wbr>Benchmarks/DOE-ProxyApps-C/<wbr>XSBench/io.c
Wed Dec 14 10:42:31 2016<br>
@@ -0,0 +1,278 @@<br>
+#include "XSbench_header.h"<br>
+<br>
+#ifdef MPI<br>
+#include<mpi.h><br>
+#endif<br>
+<br>
+// Prints program logo<br>
+void logo(int version)<br>
+{<br>
+ border_print();<br>
+ printf(<br>
+ " __ __ ___________
_ \n"<br>
+ " \\ \\ / // ___| ___ \\
| | \n"<br>
+ " \\ V / \\ `--.| |_/ / ___ _ __
___| |__ \n"<br>
+ " / \\ `--. \\ ___ \\/ _ \\ '_
\\ / __| '_ \\ \n"<br>
+ " / /^\\ \\/\\__/ / |_/ / __/ | |
| (__| | | | \n"<br>
+ " \\/ \\/\\____/\\____/ \\___|_|
|_|\\___|_| |_| \n\n"<br>
+ );<br>
+ border_print();<br>
+ center_print("Developed at Argonne National
Laboratory", 79);<br>
+ char v[100];<br>
+ sprintf(v, "Version: %d", version);<br>
+ center_print(v, 79);<br>
+ border_print();<br>
+}<br>
+<br>
+// Prints Section titles in center of 80 char terminal<br>
+void center_print(const char *s, int width)<br>
+{<br>
+ int length = strlen(s);<br>
+ int i;<br>
+ for (i=0; i<=(width-length)/2; i++) {<br>
+ fputs(" ", stdout);<br>
+ }<br>
+ fputs(s, stdout);<br>
+ fputs("\n", stdout);<br>
+}<br>
+<br>
+void print_results( Inputs in, int mype, double runtime,
int nprocs,<br>
+ unsigned long long vhash )<br>
+{<br>
+ // Calculate Lookups per sec<br>
+ int lookups_per_sec = (int) ((double) in.lookups /
runtime);<br>
+<br>
+ // If running in MPI, reduce timing statistics and
calculate average<br>
+ #ifdef MPI<br>
+ int total_lookups = 0;<br>
+ MPI_Barrier(MPI_COMM_WORLD);<br>
+ MPI_Reduce(&lookups_per_sec, &total_lookups,
1, MPI_INT,<br>
+ MPI_SUM, 0, MPI_COMM_WORLD);<br>
+ #endif<br>
+<br>
+ // Print output<br>
+ if( mype == 0 )<br>
+ {<br>
+ border_print();<br>
+ center_print("RESULTS", 79);<br>
+ border_print();<br>
+<br>
+ // Print the results<br>
+ printf("Threads: %d\n", in.nthreads);<br>
+ #ifdef MPI<br>
+ printf("MPI ranks: %d\n", nprocs);<br>
+ #endif<br>
+ #ifdef TIMING<br>
+ #ifdef MPI<br>
+ printf("Total Lookups/s: ");<br>
+ fancy_int(total_lookups);<br>
+ printf("Avg Lookups/s per MPI rank: ");<br>
+ fancy_int(total_lookups / nprocs);<br>
+ #else<br>
+ printf("Runtime: %.3lf seconds\n",
runtime);<br>
+ printf("Lookups: ");
fancy_int(in.lookups);<br>
+ printf("Lookups/s: ");<br>
+ fancy_int(lookups_per_sec);<br>
+ #endif<br>
+ #endif<br>
+ #ifdef VERIFICATION<br>
+ printf("Verification checksum: %llu\n",
vhash);<br>
+ #endif<br>
+ border_print();<br>
+<br>
+ // For bechmarking, output lookup/s data to
file<br>
+ if( SAVE )<br>
+ {<br>
+ FILE * out = fopen( "results.txt",
"a" );<br>
+ fprintf(out, "%d\t%d\n",
in.nthreads, lookups_per_sec);<br>
+ fclose(out);<br>
+ }<br>
+ }<br>
+}<br>
+<br>
+void print_inputs(Inputs in, int nprocs, int version )<br>
+{<br>
+ // Calculate Estimate of Memory Usage<br>
+ int mem_tot = estimate_mem_usage( in );<br>
+ logo(version);<br>
+ center_print("INPUT SUMMARY", 79);<br>
+ border_print();<br>
+ #ifdef VERIFICATION<br>
+ printf("Verification Mode: on\n");<br>
+ #endif<br>
+ printf("Materials: %d\n", 12);<br>
+ printf("H-M Benchmark Size: %s\n", in.HM);<br>
+ printf("Total Nuclides: %ld\n",
in.n_isotopes);<br>
+ printf("Gridpoints (per Nuclide): ");<br>
+ fancy_int(in.n_gridpoints);<br>
+ printf("Unionized Energy Gridpoints: ");<br>
+ fancy_int(in.n_isotopes*in.n_<wbr>gridpoints);<br>
+ printf("XS Lookups: ");
fancy_int(in.lookups);<br>
+ #ifdef MPI<br>
+ printf("MPI Ranks: %d\n",
nprocs);<br>
+ printf("OMP Threads per MPI Rank: %d\n",
in.nthreads);<br>
+ printf("Mem Usage per MPI Rank (MB): ");
fancy_int(mem_tot);<br>
+ #else<br>
+ printf("Threads: %d\n",
in.nthreads);<br>
+ printf("Est. Memory Usage (MB): ");
fancy_int(mem_tot);<br>
+ #endif<br>
+ border_print();<br>
+ center_print("INITIALIZATION", 79);<br>
+ border_print();<br>
+}<br>
+<br>
+void border_print(void)<br>
+{<br>
+ printf(<br>
+ "=============================<wbr>==============================<wbr>========"<br>
+ "=============\n");<br>
+}<br>
+<br>
+// Prints comma separated integers - for ease of reading<br>
+void fancy_int( long a )<br>
+{<br>
+ if( a < 1000 )<br>
+ printf("%ld\n",a);<br>
+<br>
+ else if( a >= 1000 && a < 1000000 )<br>
+ printf("%ld,%03ld\n", a / 1000, a % 1000);<br>
+<br>
+ else if( a >= 1000000 && a < 1000000000 )<br>
+ printf("%ld,%03ld,%03ld\n",a / 1000000,(a %
1000000) / 1000,a % 1000 );<br>
+<br>
+ else if( a >= 1000000000 )<br>
+ printf("%ld,%03ld,%03ld,%03ld\<wbr>n",<br>
+ a / 1000000000,<br>
+ (a % 1000000000) / 1000000,<br>
+ (a % 1000000) / 1000,<br>
+ a % 1000 );<br>
+ else<br>
+ printf("%ld\n",a);<br>
+}<br>
+<br>
+void print_CLI_error(void)<br>
+{<br>
+ printf("Usage: ./XSBench <options>\n");<br>
+ printf("Options include:\n");<br>
+ printf(" -t <threads> Number of OpenMP
threads to run\n");<br>
+ printf(" -s <size> Size of H-M
Benchmark to run (small, large, XL, XXL)\n");<br>
+ printf(" -g <gridpoints> Number of
gridpoints per nuclide (overrides -s defaults)\n");<br>
+ printf(" -l <lookups> Number of
Cross-section (XS) lookups\n");<br>
+ printf("Default is equivalent to: -s large -l
15000000\n");<br>
+ printf("See readme for full description of default
run values\n");<br>
+ exit(4);<br>
+}<br>
+<br>
+Inputs read_CLI( int argc, char * argv[] )<br>
+{<br>
+ Inputs input;<br>
+<br>
+ // defaults to max threads on the system<br>
+ #ifdef OPENMP<br>
+ input.nthreads = omp_get_num_procs();<br>
+ #else<br>
+ input.nthreads = 1;<br>
+ #endif<br>
+<br>
+ // defaults to 355 (corresponding to H-M Large
benchmark)<br>
+ input.n_isotopes = 355;<br>
+<br>
+ // defaults to 11303 (corresponding to H-M Large
benchmark)<br>
+ input.n_gridpoints = 11303;<br>
+<br>
+ // defaults to 15,000,000<br>
+ input.lookups = 15000000;<br>
+<br>
+ // defaults to H-M Large benchmark<br>
+ input.HM = (char *) malloc( 6 * sizeof(char) );<br>
+ input.HM[0] = 'l' ;<br>
+ input.HM[1] = 'a' ;<br>
+ input.HM[2] = 'r' ;<br>
+ input.HM[3] = 'g' ;<br>
+ input.HM[4] = 'e' ;<br>
+ input.HM[5] = '\0';<br>
+<br>
+ // Check if user sets these<br>
+ int user_g = 0;<br>
+<br>
+ // Collect Raw Input<br>
+ for( int i = 1; i < argc; i++ )<br>
+ {<br>
+ char * arg = argv[i];<br>
+<br>
+ // nthreads (-t)<br>
+ if( strcmp(arg, "-t") == 0 )<br>
+ {<br>
+ if( ++i < argc )<br>
+ input.nthreads =
atoi(argv[i]);<br>
+ else<br>
+ print_CLI_error();<br>
+ }<br>
+ // n_gridpoints (-g)<br>
+ else if( strcmp(arg, "-g") == 0 )<br>
+ {<br>
+ if( ++i < argc )<br>
+ {<br>
+ user_g = 1;<br>
+ input.n_gridpoints =
atol(argv[i]);<br>
+ }<br>
+ else<br>
+ print_CLI_error();<br>
+ }<br>
+ // lookups (-l)<br>
+ else if( strcmp(arg, "-l") == 0 )<br>
+ {<br>
+ if( ++i < argc )<br>
+ input.lookups =
atoi(argv[i]);<br>
+ else<br>
+ print_CLI_error();<br>
+ }<br>
+ // HM (-s)<br>
+ else if( strcmp(arg, "-s") == 0 )<br>
+ {<br>
+ if( ++i < argc )<br>
+ input.HM = argv[i];<br>
+ else<br>
+ print_CLI_error();<br>
+ }<br>
+ else<br>
+ print_CLI_error();<br>
+ }<br>
+<br>
+ // Validate Input<br>
+<br>
+ // Validate nthreads<br>
+ if( input.nthreads < 1 )<br>
+ print_CLI_error();<br>
+<br>
+ // Validate n_isotopes<br>
+ if( input.n_isotopes < 1 )<br>
+ print_CLI_error();<br>
+<br>
+ // Validate n_gridpoints<br>
+ if( input.n_gridpoints < 1 )<br>
+ print_CLI_error();<br>
+<br>
+ // Validate lookups<br>
+ if( input.lookups < 1 )<br>
+ print_CLI_error();<br>
+<br>
+ // Validate HM size<br>
+ if( strcasecmp(input.HM, "small") != 0 &&<br>
+ strcasecmp(input.HM, "large") != 0
&&<br>
+ strcasecmp(input.HM, "XL") != 0 &&<br>
+ strcasecmp(input.HM, "XXL") != 0 )<br>
+ print_CLI_error();<br>
+<br>
+ // Set HM size specific parameters<br>
+ // (defaults to large)<br>
+ if( strcasecmp(input.HM, "small") == 0 )<br>
+ input.n_isotopes = 68;<br>
+ else if( strcasecmp(input.HM, "XL") == 0 &&
user_g == 0 )<br>
+ input.n_gridpoints = 238847; // sized to
make 120 GB XS data<br>
+ else if( strcasecmp(input.HM, "XXL") == 0 &&
user_g == 0 )<br>
+ input.n_gridpoints = 238847 * 2.1; // 252 GB
XS data<br>
+<br>
+ // Return input struct<br>
+ return input;<br>
+}<br>
<br>
Modified: test-suite/trunk/MultiSource/<wbr>Benchmarks/Makefile<br>
URL: <a moz-do-not-send="true"
href="http://llvm.org/viewvc/llvm-project/test-suite/trunk/MultiSource/Benchmarks/Makefile?rev=289666&r1=289665&r2=289666&view=diff"
rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-<wbr>project/test-suite/trunk/<wbr>MultiSource/Benchmarks/<wbr>Makefile?rev=289666&r1=289665&<wbr>r2=289666&view=diff</a><br>
==============================<wbr>==============================<wbr>==================<br>
--- test-suite/trunk/MultiSource/<wbr>Benchmarks/Makefile
(original)<br>
+++ test-suite/trunk/MultiSource/<wbr>Benchmarks/Makefile
Wed Dec 14 10:42:31 2016<br>
@@ -9,7 +9,7 @@ PARALLEL_DIRS := Fhourstones Fhourstones<br>
McCat Olden Ptrdist llubenchmark \<br>
sim FreeBench MallocBench Prolangs-C
SciMark2-C mediabench\<br>
nbench ASCI_Purple MiBench Trimaran
VersaBench NPB-serial\<br>
- BitBench ASC_Sequoia TSVC<br>
+ BitBench ASC_Sequoia TSVC DOE-ProxyApps-C<br>
<br>
# Disable TSVC on Darwin until the tests support
SMALL_PROBLEM_SIZE=1.<br>
ifeq ($(TARGET_OS),Darwin)<br>
<br>
<br>
______________________________<wbr>_________________<br>
llvm-commits mailing list<br>
<a moz-do-not-send="true"
href="mailto:llvm-commits@lists.llvm.org">llvm-commits@lists.llvm.org</a><br>
<a moz-do-not-send="true"
href="http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-commits"
rel="noreferrer" target="_blank">http://lists.llvm.org/cgi-bin/<wbr>mailman/listinfo/llvm-commits</a><br>
</blockquote>
</div>
<br>
</div>
</blockquote>
<br>
<pre class="moz-signature" cols="72">--
Hal Finkel
Lead, Compiler Technology and Programming Languages
Leadership Computing Facility
Argonne National Laboratory</pre>
</body>
</html>