1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
|
# Copyright 2013-2020 Lawrence Livermore National Security, LLC and other
# Spack Project Developers. See the top-level COPYRIGHT file for details.
#
# SPDX-License-Identifier: (Apache-2.0 OR MIT)
from spack import *
class Ebms(MakefilePackage):
"""This is a miniapp for the Energy Banding Monte Carlo (EBMC)
neutron transportation simulation code. It is adapted from a
similar miniapp provided by Andrew Siegel, whose algorithm is
described in [1], where only one process in a compute node
is used, and the compute nodes are divided into memory nodes
and tracking nodes. Memory nodes do not participate in particle
tracking. Obviously, there is a lot of resource waste in this design.
"""
homepage = "https://github.com/ANL-CESAR/EBMS"
git = "https://github.com/ANL-CESAR/EBMS.git"
version('develop')
variant('mpi', default=True, description='Build with MPI support')
depends_on('mpi@2:', when='+mpi')
tags = ['proxy-app']
@property
def build_targets(self):
targets = []
cflags = '-g -O3 -std=gnu99'
if '+mpi' in self.spec:
targets.append('CC={0}'.format(self.spec['mpi'].mpicc))
targets.append('CFLAGS={0}'.format(cflags))
return targets
def install(self, spec, prefix):
mkdir(prefix.bin)
install('ebmc-iallgather', prefix.bin)
install('ebmc-rget', prefix.bin)
install_tree('run', join_path(prefix, 'run'))
install_tree('inputs', join_path(prefix, 'inputs'))
|