Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add HyTeG Project #841

Merged
merged 17 commits into from
Oct 23, 2023
Merged
1 change: 1 addition & 0 deletions varats-core/varats/project/project_domain.py
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ class ProjectDomains(Enum):
EDITOR = "Editor"
FILE_FORMAT = "File format"
HW_EMULATOR = "Hardware emulator"
HPC = "High Performance Applications"
PARSER = "Parser"
PLANNING = "Planning"
PROG_LANG = "Programming language"
Expand Down
110 changes: 110 additions & 0 deletions varats/varats/projects/cpp_projects/hyteg.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,110 @@
"""Adds the HyTeg framework as a project to VaRA-TS."""
import typing as tp

import benchbuild as bb
from benchbuild.command import WorkloadSet, Command, SourceRoot

Check warning on line 5 in varats/varats/projects/cpp_projects/hyteg.py

View workflow job for this annotation

GitHub Actions / pylint

[pylint] varats/varats/projects/cpp_projects/hyteg.py#L5 <611>

Unused Command imported from benchbuild.command (unused-import)
Raw output
varats/varats/projects/cpp_projects/hyteg.py:5:0: W0611: Unused Command imported from benchbuild.command (unused-import)
vulder marked this conversation as resolved.
Show resolved Hide resolved
from benchbuild.utils.cmd import make, cmake, mkdir
from benchbuild.utils.revision_ranges import SingleRevision
from benchbuild.utils.settings import get_number_of_jobs
from plumbum import local

from varats.experiment.workload_util import WorkloadCategory, RSBinary
from varats.paper.paper_config import PaperConfigSpecificGit
from varats.project.project_domain import ProjectDomains
from varats.project.project_util import (
get_local_project_git_path,
BinaryType,
ProjectBinaryWrapper,
)
from varats.project.sources import FeatureSource
from varats.project.varats_command import VCommand
from varats.project.varats_project import VProject
from varats.utils.git_util import ShortCommitHash, RevisionBinaryMap
from varats.utils.settings import bb_cfg


class HyTeg(VProject):
"""
C++ framework for large scale high performance finite element simulations
based on (but not limited to) matrix-free geometric multigrid.

Note:
Currently HyTeg CANNOT be compiled with the Phasar passes activated
in vara.
Trying to do so will crash the compiler

If you use Dune with an experiment that uses the vara compiler,
add `-mllvm --vara-disable-phasar` to the projects `cflags` to
disable phasar passes.
This will still allow to analyse compile-time variability.
"""
NAME = 'HyTeg'
GROUP = 'cpp_projects'
DOMAIN = ProjectDomains.HPC

SOURCE = [
PaperConfigSpecificGit(
project_name="HyTeg",
remote="https://github.com/se-sic/hyteg-VaRA.git",
local="HyTeg",
refspec="origin/HEAD",
limit=None,
shallow=False
),
FeatureSource()
]

WORKLOADS = {
WorkloadSet(WorkloadCategory.EXAMPLE): [
VCommand(
SourceRoot("HyTeg") / "build" / "apps" / "profiling" /
RSBinary('ProfilingApp'),
label='ProfilingApp'
)
]
}

@staticmethod
def binaries_for_revision(
revision: ShortCommitHash
) -> tp.List['ProjectBinaryWrapper']:
binaries = RevisionBinaryMap(get_local_project_git_path(HyTeg.NAME))

binaries.specify_binary(
"ProfilingApp",
BinaryType.EXECUTABLE,
only_valid_in=SingleRevision(
"f4711dadc3f61386e6ccdc704baa783253332db2"
)
)

return binaries[revision]

def compile(self) -> None:
"""Compile HyTeg with irrelevant settings disabled."""
hyteg_source = local.path(self.source_of(self.primary_source))

mkdir("-p", hyteg_source / "build")

cc_compiler = bb.compiler.cc(self)
cxx_compiler = bb.compiler.cxx(self)

with local.cwd(hyteg_source / "build"):
with local.env(CC=str(cc_compiler), CXX=str(cxx_compiler)):
bb.watch(cmake)(
"..", "-DWALBERLA_BUILD_WITH_MPI=OFF",
"-DHYTEG_BUILD_DOC=OFF"
)

with local.cwd(hyteg_source / "build" / "apps" / "profiling"):
bb.watch(make)("-j", get_number_of_jobs(bb_cfg()))

def recompile(self) -> None:
"""Recompiles HyTeg e.g. after a patch has been applied."""
hyteg_source = local.path(self.source_of(self.primary_source))

with local.cwd(hyteg_source / "build" / "apps" / "profiling"):
bb.watch(make)("-j", get_number_of_jobs(bb_cfg()))

def run_tests(self) -> None:
pass
1 change: 1 addition & 0 deletions varats/varats/tools/bb_config.py
Original file line number Diff line number Diff line change
Expand Up @@ -75,6 +75,7 @@ def update_projects(
'varats.projects.cpp_projects.z3',
'varats.projects.cpp_projects.ect',
'varats.projects.cpp_projects.lepton',
'varats.projects.cpp_projects.hyteg',
'varats.projects.cpp_projects.dune'
]
projects_conf.value[:] += [
Expand Down
Loading