blob: f70029ff30b6f327931857e46688594f9091cee5 (
plain) (
blame)
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
|
# Copyright 2013-2023 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.package 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"
license("MIT")
version("develop")
depends_on("mpi@2:")
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"))
|