summaryrefslogtreecommitdiff
path: root/var/spack/repos/builtin/packages/talass/package.py
blob: 7a0f60fb37c8e0f60b16d71bc6852f16adc13024 (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
50
51
52
53
54
55
56
57
58
59
# Copyright 2013-2022 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 Talass(CMakePackage):
    """TALASS: Topological Analysis of Large-Scale Simulations
    This package compiles the talass tool chain thar implements
    various topological algorithms to analyze large scale data.
    The package is organized hierarchical FileFormat < Statistics
    < StreamingTopology and any of the subsets can be build stand-
    alone."""

    homepage = "http://www.cedmav.org/research/project/16-talass.html"
    git      = "ssh://git@bitbucket.org/cedmav/talass.git"

    version('2018-10-29', commit='5d459c0dd89e733fa301391908a5b79fe2850ad7')

    # The default precision and index space sizes
    variant('precision', default='32', values=('32', '64'),
            description='Precision of the function values')
    variant('global', default='32', values=('16', '32', '64'),
            description='Number of bits used for the global index space')
    variant('local', default='32', values=('16', '32', '64'),
            description='Number of bits used for the local index space')

    root_cmakelists_dir = 'StreamingTopology'

    def cmake_args(self):
        variants = self.spec.variants

        args = []

        if int(variants['local'].value) > int(variants['global'].value):
            msg = ('The global index space (%d bits) must be at least as '
                   'large as the local index space (% bits)')
            raise InstallError(
                msg % (variants['global'].value, variants['local'].value))

        if variants['precision'].value == '32':
            args.append('-DFUNCTION_TYPE=float')
        elif variants['precision'].value == '64':
            args.append('-DFUNCTION_TYPE=double')

        # Set global index space
        args.append('-DGLOBAL_INDEX_TYPE=uint{0}_t'.format(
            variants['global'].value))

        # Set local index space
        args.append('-DLOCAL_INDEX_TYPE=uint{0}_t'.format(
            variants['local'].value))

        # Deal with the PROJECT_INSTALL_PREFIX to enable Talass super builds
        args.append('-DPROJECT_INSTALL_PREFIX=%s' % self.prefix)

        return args