added a package butterflypack (#12222)
* added a package butterflypack * remove one line in the python script
This commit is contained in:
parent
45d852b87d
commit
474bf18853
59
var/spack/repos/builtin/packages/butterflypack/package.py
Normal file
59
var/spack/repos/builtin/packages/butterflypack/package.py
Normal file
@ -0,0 +1,59 @@
|
|||||||
|
# Copyright 2013-2019 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 Butterflypack(CMakePackage):
|
||||||
|
"""ButterflyPACK is a mathematical software for rapidly solving
|
||||||
|
large-scale dense linear systems that exhibit off-diagonal rank-deficiency.
|
||||||
|
These systems arise frequently from boundary element methods, or
|
||||||
|
factorization phases in finite-difference/finite-element methods.
|
||||||
|
ButterflyPACK relies on low-rank or butterfly formats under Hierarchical
|
||||||
|
matrix, HODLR or other hierarchically nested frameworks to compress,
|
||||||
|
factor and solve the linear system in quasi-linear time. The
|
||||||
|
computationally most intensive phase, factorization, is accelerated via
|
||||||
|
randomized linear algebras. The butterfly format, originally inspired by
|
||||||
|
the butterfly data flow in fast Fourier Transform, is a linear algebra tool
|
||||||
|
well-suited for compressing matrices arising from high-frequency wave
|
||||||
|
equations or highly oscillatory integral operators."""
|
||||||
|
|
||||||
|
homepage = "https://github.com/liuyangzhuan/ButterflyPACK"
|
||||||
|
git = "https://github.com/liuyangzhuan/ButterflyPACK.git"
|
||||||
|
|
||||||
|
maintainers = ['liuyangzhuan']
|
||||||
|
|
||||||
|
version('master', branch='master')
|
||||||
|
|
||||||
|
variant('shared', default=True, description='Build shared libraries')
|
||||||
|
|
||||||
|
depends_on('mpi')
|
||||||
|
depends_on('blas')
|
||||||
|
depends_on('lapack')
|
||||||
|
depends_on('scalapack')
|
||||||
|
depends_on('arpack-ng')
|
||||||
|
|
||||||
|
def cmake_args(self):
|
||||||
|
spec = self.spec
|
||||||
|
|
||||||
|
def on_off(varstr):
|
||||||
|
return 'ON' if varstr in spec else 'OFF'
|
||||||
|
|
||||||
|
args = [
|
||||||
|
'-DCMAKE_C_COMPILER=%s' % spec['mpi'].mpicc,
|
||||||
|
'-DCMAKE_Fortran_COMPILER=%s' % spec['mpi'].mpifc,
|
||||||
|
'-DCMAKE_CXX_COMPILER=%s' % spec['mpi'].mpicxx,
|
||||||
|
'-DTPL_BLAS_LIBRARIES=%s' % spec['blas'].libs.joined(";"),
|
||||||
|
'-DTPL_LAPACK_LIBRARIES=%s' % spec['lapack'].libs.joined(";"),
|
||||||
|
'-DTPL_SCALAPACK_LIBRARIES=%s' % spec['scalapack'].
|
||||||
|
libs.joined(";"),
|
||||||
|
'-DTPL_ARPACK_LIBRARIES=%s' % spec['arpack-ng'].libs.joined(";"),
|
||||||
|
]
|
||||||
|
|
||||||
|
args.extend([
|
||||||
|
'-DBUILD_SHARED_LIBS=%s' % on_off('+shared')
|
||||||
|
])
|
||||||
|
|
||||||
|
return args
|
Loading…
Reference in New Issue
Block a user