96 lines
3.9 KiB
Python
96 lines
3.9 KiB
Python
##############################################################################
|
|
# Copyright (c) 2013-2017, Lawrence Livermore National Security, LLC.
|
|
# Produced at the Lawrence Livermore National Laboratory.
|
|
#
|
|
# This file is part of Spack.
|
|
# Created by Todd Gamblin, tgamblin@llnl.gov, All rights reserved.
|
|
# LLNL-CODE-647188
|
|
#
|
|
# For details, see https://github.com/spack/spack
|
|
# Please also see the LICENSE file for our notice and the LGPL.
|
|
#
|
|
# This program is free software; you can redistribute it and/or modify
|
|
# it under the terms of the GNU Lesser General Public License (as
|
|
# published by the Free Software Foundation) version 2.1, February 1999.
|
|
#
|
|
# This program is distributed in the hope that it will be useful, but
|
|
# WITHOUT ANY WARRANTY; without even the IMPLIED WARRANTY OF
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the terms and
|
|
# conditions of the GNU Lesser General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU Lesser General Public
|
|
# License along with this program; if not, write to the Free Software
|
|
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
##############################################################################
|
|
from spack import *
|
|
import glob
|
|
|
|
|
|
class AmrExpParabolic(MakefilePackage):
|
|
"""Simplified block-structured adaptive mesh refinement algorithm
|
|
in two and three dimensions with subcycling in time.
|
|
The algorithm solves a linear advection diffusion equation
|
|
with a simple numerical method. This proxy app is intended to
|
|
capture the communication pattern of an explicit AMR algorithm
|
|
but does not represent an accurate characterization of
|
|
floating point effort or
|
|
relative costs of communication to computation."""
|
|
|
|
homepage = "https://ccse.lbl.gov/ExaCT/index.html"
|
|
url = "https://ccse.lbl.gov/ExaCT/AMR_Exp_Parabolic.tgz"
|
|
tags = ['proxy-app']
|
|
|
|
version(
|
|
'release', '330604d9cc755dad8a2cdfaa7ff8f6a4',
|
|
url='https://ccse.lbl.gov/ExaCT/AMR_Exp_Parabolic.tgz')
|
|
|
|
variant(
|
|
'debug', default=False, description='Turn on debugging')
|
|
variant(
|
|
'mpi', default=True, description='Build with MPI support')
|
|
variant(
|
|
'openmp', default=False,
|
|
description='Build with OpenMP support')
|
|
variant(
|
|
'prof', default=False, description='Use profiler')
|
|
|
|
depends_on('mpi', when='+mpi')
|
|
depends_on('gmake', type='build')
|
|
|
|
build_directory = 'MiniApps/AMR_Adv_Diff_F90'
|
|
|
|
def edit(self, spec, prefix):
|
|
def_file = FileFilter('Tools/F_mk/GMakedefs.mak')
|
|
def_file.filter('tdir = t/.*', 'tdir := t/$(suf)')
|
|
def_file.filter('hdir = t/.*', 'hdir := t/html')
|
|
def_file.filter('include $(BOXLIB_HOME)/Tools/F_mk/GMakeMPI.mak', '#')
|
|
|
|
if '+mpi' in spec:
|
|
def_file.filter('FC.*:=.*', 'FC = {0}'.format(spec['mpi'].mpifc))
|
|
def_file.filter('F90.*:=.*', 'F90 = {0}'.format(spec['mpi'].mpifc))
|
|
def_file.filter(
|
|
'mpi_include_dir =.*',
|
|
'mpi_include_dir = {0}'.format(spec['mpi'].prefix.include))
|
|
def_file.filter(
|
|
'mpi_lib_dir =.*',
|
|
'mpi_lib_dir = {0}'.format(spec['mpi'].prefix.lib))
|
|
|
|
with working_dir(self.build_directory):
|
|
makefile = FileFilter('GNUmakefile')
|
|
if '+debug' in spec:
|
|
makefile.filter('NDEBUG.*:= t', '#')
|
|
if '~mpi' in spec:
|
|
makefile.filter('MPI.*:= t', '#')
|
|
if '+openmp' in spec:
|
|
makefile.filter('OMP.*:=', 'OMP := t')
|
|
if '+prof' in spec:
|
|
makefile.filter('PROF.*:=', 'PROF := t')
|
|
|
|
def install(self, spec, prefix):
|
|
mkdirp(prefix.bin)
|
|
files = glob.glob(join_path(self.build_directory, '*.exe'))
|
|
for f in files:
|
|
install(f, prefix.bin)
|
|
install('README.txt', prefix)
|
|
install('license.txt', prefix)
|