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

Interface Walberla LB #2701

Closed
wants to merge 1,803 commits into from
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
1803 commits
Select commit Hold shift + click to select a range
6b6136e
CI: Small fix
jngrad Aug 2, 2022
528bb1e
walberla: Remove VTK code duplication
jngrad Aug 3, 2022
cc2b64b
walberla: Include what you use and fix Clang warnings
jngrad Aug 3, 2022
2e31fad
walberla: Fix destructor bugs in abstract classes
jngrad Aug 3, 2022
ba9690f
ekin: Add clear_*_boundary() methods and tests
jngrad Aug 3, 2022
b08cc55
walberla: Harmonize VTK and boundaries with ekin, add documentation
jngrad Aug 3, 2022
cfbc574
ekin: Remove unused code
jngrad Aug 3, 2022
6d23ad5
walberla: Move VTK to new LatticeModel base class
jngrad Aug 3, 2022
554e83e
walberla: Roll out get_lattice() method
jngrad Aug 3, 2022
247e76a
walberla: Declutter class definitions
jngrad Aug 3, 2022
201e62b
doc: Fix links
jngrad Aug 3, 2022
f02c236
ekin: Include what you use
jngrad Aug 3, 2022
e5db51e
ekin: Test runtime errors
jngrad Aug 3, 2022
deb4ea9
ekin: Remove unused code
jngrad Aug 3, 2022
4cc66ab
ekin: Formatting
jngrad Aug 3, 2022
7c9f7bc
CI: Small fixes
jngrad Aug 3, 2022
2ad0109
ekin: Test invalid combinations
jngrad Aug 3, 2022
76a5b1d
Formatting
jngrad Aug 4, 2022
c0a0ecc
ekin: Automatically generate switch statement
jngrad Aug 4, 2022
82632c3
Formatting
jngrad Aug 4, 2022
4075cb7
core: Fix regressions
jngrad Aug 4, 2022
cc49c68
walberla: Write common lattice node interface
jngrad Aug 4, 2022
238066f
walberla: Merge the LB and EK slice classes
jngrad Aug 4, 2022
b22c978
ekin: Naming convention for abstract classes
jngrad Aug 4, 2022
3ae4566
ekin: Remove unused code
jngrad Aug 4, 2022
0dd8972
ekin: Check node equality
jngrad Aug 4, 2022
7a4b6bc
walberla: Move set_boundary_from_shape() to free functions
jngrad Aug 5, 2022
2644b43
walberla: Use LB namespace
jngrad Aug 5, 2022
8360332
walberla: Fix regression
jngrad Aug 5, 2022
b36cd66
Merge branch 'python' into walberla
jngrad Aug 8, 2022
2dd1147
python: Fix merge regressions
jngrad Aug 8, 2022
afc81a0
Merge branch 'python' into walberla
jngrad Aug 15, 2022
0a5035c
CMake: Fix regressions
jngrad Aug 15, 2022
7282ab4
walberla: Unify thermalized and unthermalized kernels
jngrad Aug 15, 2022
1b2863d
Merge branch 'python' into walberla
jngrad Aug 18, 2022
65510f2
py: don't ignore Lees Edwards shift in system.distance_vec and system…
RudolfWeeber Aug 23, 2022
2ca84b7
pitchforkize walberla
christophlohrmann Aug 23, 2022
fdda32f
Complete remaining Pitchfork tasks, fix regressions
jngrad Aug 24, 2022
46585cd
walberla: Refactor reactions interface
jngrad Aug 24, 2022
d053b12
Merge branch 'python' into walberla
jngrad Aug 24, 2022
826be7f
Merge branch 'walberla' into walberla
jngrad Aug 24, 2022
452d17d
walberla: Disable failing test
jngrad Aug 24, 2022
02ef2fd
walberla: Fix more regressions
jngrad Aug 24, 2022
5719389
WIP: LE decrapification
RudolfWeeber Aug 24, 2022
5d1b76d
Revert "py: don't ignore Lees Edwards shift in system.distance_vec an…
RudolfWeeber Aug 25, 2022
df34e65
Core: Always fold share_plane_normal dir in Lees Edwards get_mi_vector
RudolfWeeber Aug 25, 2022
07084e2
Merge branch 'walberla' into le_decrapification
RudolfWeeber Aug 25, 2022
1eb204b
Revert "walberla: Disable failing test"
RudolfWeeber Aug 25, 2022
46a7105
Merge branch 'le_decrapification' into walberla
RudolfWeeber Aug 25, 2022
1570b47
WIP: LE
RudolfWeeber Aug 25, 2022
93f3880
WIP: Simplify VS_Relative, fix VS support for Lees Edwards
RudolfWeeber Sep 5, 2022
a565412
Merge branch 'vs_rel_simplification' into le_decrapification
RudolfWeeber Sep 5, 2022
ea828b1
Merge branch 'python' into walberla
jngrad Sep 13, 2022
c3f2f8a
script_interface: Make MPI communicator public
jngrad Sep 13, 2022
dfaeb20
script_interface: Make main analysis methods parallel
jngrad Sep 13, 2022
4b1d38f
script_interface: Remove dependency on core/communication.hpp
jngrad Sep 13, 2022
794341d
Fix various regressions found by Clang
jngrad Sep 13, 2022
eb3a3c4
Merge branch 'python' into walberla
jngrad Sep 20, 2022
a9d2473
python: Remove unused bindings
jngrad Oct 11, 2022
9073290
Fix regressions
jngrad Oct 12, 2022
5483521
CMake: Fix FetchContent regression
jngrad Oct 14, 2022
d94cde6
walberla: Make Ekin opt-in
jngrad Oct 14, 2022
590f7ab
Revert "walberla: Make Ekin opt-in"
jngrad Oct 16, 2022
54198a7
walberla: Make fft opt-in
jngrad Oct 16, 2022
8704213
CMake: Fix PNFFT dependency
jngrad Oct 18, 2022
60deb51
Fix issues revealed by Clang 14 and CMake 3.22
jngrad Oct 18, 2022
d088f2e
Merge branch 'python' into walberla
jngrad Oct 18, 2022
559708d
walberla: Re-enable LB sedimentation test
jngrad Oct 19, 2022
53ba66f
Merge branch 'walberla' of ssh://github.com/RudolfWeeber/espresso int…
RudolfWeeber Oct 21, 2022
070f97f
Merge branch 'le_decrapification' of ssh://github.com/RudolfWeeber/es…
RudolfWeeber Oct 21, 2022
8071163
walberla: Fix broken url
jngrad Oct 21, 2022
7f8f812
Merge commit 'refs/pull/4564/head' of ssh://github.com/espressomd/esp…
RudolfWeeber Oct 21, 2022
ec89b92
Merge branch 'walberla' of ssh://github.com/RudolfWeeber/espresso int…
RudolfWeeber Oct 21, 2022
921c5d4
core: Fix Clang-Tidy warnings
jngrad Oct 24, 2022
b783784
walberla: Regenerate kernels with latest pystencils
jngrad Oct 24, 2022
26edccc
walberla: Regenerate kernels with latest pystencils and lbmpy
jngrad Oct 25, 2022
36c5550
Merge branch 'python' into walberla
jngrad Oct 28, 2022
e98c060
Merge remote-tracking branch 'jngrad/devops' into walberla
jngrad Oct 28, 2022
212f266
WIP: investigate PNFFT MPI error
jngrad Oct 28, 2022
5ab3bd7
Revert "WIP: investigate PNFFT MPI error"
jngrad Oct 28, 2022
a232e7f
EK: fixed heap-use-after-free
reinaual Nov 8, 2022
a70ea8c
Merge branch 'python' into walberla
jngrad Nov 25, 2022
f5cf45c
Formatting
jngrad Nov 25, 2022
dc9d6e3
test: Reduce EK test runtime in UBSAN/ASAN builds
reinaual Dec 5, 2022
fd46c4b
ekin: Separation of concerns
jngrad Dec 6, 2022
d281db4
lb: Fix Clang-Tidy 14 diagnostics
jngrad Dec 6, 2022
c8eeb5f
CMake: Disable Clang-Tidy on FetchContent projects
jngrad Dec 6, 2022
24a28b1
tests: Fix UBSAN/ASAN errors
jngrad Dec 6, 2022
dcd0226
Merge branch 'python' into walberla
jngrad Dec 6, 2022
c83969b
Fix regressions
jngrad Dec 6, 2022
fba8be6
CMake: Bump CUDA standard
jngrad Dec 6, 2022
48a1ee4
CMake: Silence C++20 warning from Cython
jngrad Dec 6, 2022
724429f
python: Fix regression
jngrad Dec 6, 2022
079338c
CI: Remove redundant jobs
jngrad Dec 6, 2022
d3afb76
CI: Fix build script
jngrad Dec 6, 2022
b3855ff
CI: Fix CMake flags
jngrad Dec 6, 2022
d67961c
CMake: Fix regression
jngrad Dec 6, 2022
eb915ad
core: Rename back CMake option
jngrad Dec 7, 2022
1145bf9
Run waLBerla in Clang with GPU support
jngrad Dec 12, 2022
465379e
waLBerla+cuda
jngrad Dec 13, 2022
10798ee
Fix CMake
jngrad Dec 13, 2022
12cd6e7
Fix CMake
jngrad Dec 13, 2022
3ac42e7
Fix CMake
jngrad Dec 13, 2022
13f903b
CMake: Disable Clang-Tidy on FetchContent projects
jngrad Dec 26, 2022
ae09a15
Merge commit '13f903b8d782cba8' into walberla
jngrad Dec 27, 2022
fb9b92b
CMake: Remove experimental filesystem
jngrad Dec 27, 2022
f2bbc54
CMake: Remove property from header-only targets
jngrad Dec 27, 2022
5e0025a
script_interface: LatticeWalberla: exposed read-only shape
reinaual Dec 12, 2022
f165226
ek: added and exposed unit conversion for boundary handlings
reinaual Dec 12, 2022
feb51a7
ek: units: permittivity
reinaual Jan 10, 2023
bc958e9
ek: units: reactions
reinaual Dec 12, 2022
9eb0841
ek: EKReactant: make order read-only to prevent breaking unit-conversion
reinaual Jan 13, 2023
32c0188
Merge branch 'python' into walberla
jngrad Jan 16, 2023
b0047ed
Merge remote-tracking branch 'reinaual/walberla_ek_unit_conversion' i…
jngrad Jan 16, 2023
1468e7f
walberla: Re-enable Ekin checkpointing
jngrad Jan 16, 2023
7f8d082
ek: added checkpointing
reinaual Jan 31, 2023
fd64c92
walberla: Remove code duplication
jngrad Feb 1, 2023
599aeed
Merge branch 'python' into walberla
jngrad Feb 1, 2023
4392eb5
Fix testsuite
jngrad Feb 1, 2023
b834ab7
Revert "Bump NB convert toolchain and improve testing"
jngrad Feb 1, 2023
ab383ff
Revert "Revert "Bump NB convert toolchain and improve testing""
jngrad Feb 3, 2023
c8aabf9
Check combination ScaFaCoS + waLBerla on Ubuntu 22.04
jngrad Feb 3, 2023
136797b
Revert "Check combination ScaFaCoS + waLBerla on Ubuntu 22.04"
jngrad Feb 3, 2023
2cfba8e
Revert "Revert "Check combination ScaFaCoS + waLBerla on Ubuntu 22.04""
jngrad Feb 3, 2023
801f620
Sort out LB tests
jngrad Feb 3, 2023
edab653
Sort out Cartesian communicator and checkpointing
jngrad Feb 3, 2023
2c82b00
Update copyright headers
jngrad Feb 3, 2023
e7ead8a
Remove addressed TODOs
jngrad Feb 3, 2023
2f8b775
Merge branch 'python' into walberla
jngrad Feb 3, 2023
693fef8
doc: electrokinetics: adapted tutorial code
reinaual Feb 13, 2023
d6d3719
testsuite: ek: removed old testcases
reinaual Feb 13, 2023
b964b99
maintainer: ek: fixed thermalization codegen
reinaual Feb 13, 2023
d36ee77
CMake: Remove MPI linker commands
jngrad Feb 24, 2023
accaaa1
walberla: Document how to prototype new methods
jngrad Feb 24, 2023
bad53b7
Merge branch 'python' into walberla
jngrad Feb 24, 2023
d4b5622
walberla: Re-enable tests on 4 MPI ranks
jngrad Feb 25, 2023
edff007
CMake: Fix broken patch command
jngrad Mar 2, 2023
885cb8e
CMake: Move AVX2 logic to dedicated file
jngrad Mar 2, 2023
8f2fcc3
Merge branch 'python' into walberla
jngrad Mar 2, 2023
7e9333b
CMake: Add workaround for patch command
jngrad Mar 2, 2023
0716013
Fix merge conflicts
jngrad Mar 2, 2023
afc0388
tests: Workaround for an OSError on Fedora
jngrad Mar 2, 2023
c78f967
Merge 'reinaual/walberla_ek_tutorial' into walberla
jngrad Mar 7, 2023
ef700df
Fixup ToC
jngrad Mar 7, 2023
825684b
Bump waLBerla version
jngrad Mar 8, 2023
640e252
CMake: Add missing CUDA flags
jngrad Mar 8, 2023
5538a2f
core: Modernize
jngrad Mar 8, 2023
f1a3837
renaming the viscocity to kinematic viscocity
capomav Mar 10, 2023
2630ca7
walberla: Various improvements
jngrad Mar 11, 2023
bbe80ed
Merge remote-tracking branch 'capomav/rename_viscosity' into walberla
jngrad Mar 11, 2023
33be058
Finish renaming kinematic viscosity
jngrad Mar 11, 2023
849a8a0
Merge branch 'python' into walberla
jngrad Mar 11, 2023
37cffb1
walberla: Bump CMake requirements
jngrad Mar 11, 2023
39c1079
Fix Clang warning
jngrad Mar 11, 2023
bafec14
CMake: Fixup
jngrad Mar 11, 2023
a8989eb
walberla: GPU accessors (WIP)
RudolfWeeber Mar 3, 2023
ca2c70f
maintainer: Modernize codegen scripts
jngrad Mar 6, 2023
624b9e4
walberla: Completely rewrite macroscopic accessors
jngrad Mar 14, 2023
3e04494
walberla: Regenerate all kernels with lbmpy 1.1.1
jngrad Mar 14, 2023
ea73ea1
Formatting
jngrad Mar 14, 2023
6751d63
Remove duplicated code
jngrad Mar 21, 2023
09bd007
Formatting
jngrad Mar 21, 2023
ca6a242
Merge remote-tracking branch 'upstream/python' into walberla
jngrad Mar 30, 2023
0c9f6cf
tests: Fix numpy deprecation warning
jngrad Apr 5, 2023
81f7360
Re-order setters and getters
jngrad Apr 3, 2023
5b05d15
script_interface: Implement LB slice via ranges
jngrad Apr 3, 2023
3bb6fa9
maintainer: Update comments
jngrad Apr 5, 2023
5265630
walberla: Implement new setters
jngrad Apr 5, 2023
d78f6eb
script_interface: Fix regression
jngrad Apr 5, 2023
5f74ec8
walberla: Split interface into headers and implementations
jngrad Apr 5, 2023
5dc521c
walberla: Remove legacy error handling mechanism
jngrad Apr 6, 2023
d29e860
walberla: Refactoring
jngrad Apr 7, 2023
6ed6dfa
walberla: Fix VTK parser
jngrad Apr 7, 2023
82f9487
walberla: Design a multi-piece VTK parser
jngrad Apr 13, 2023
44aa35e
walberla: Introduce units conversion for LB VTK
jngrad Apr 13, 2023
8ea0958
Merge branch 'python' into walberla
jngrad Apr 18, 2023
6d383e9
python: Move utility functions to subfolder
jngrad Apr 18, 2023
5bfd69e
walberla: Implement EKSlice
jngrad Apr 18, 2023
850db2d
script_interface: Factor out code duplication
jngrad Apr 19, 2023
e0a4205
doc: Fixup Sphinx
jngrad Apr 20, 2023
60f157f
Merge branch 'python' into walberla
jngrad Apr 24, 2023
be28e6b
walberla: Simplify VTK classes
jngrad Apr 24, 2023
f07ac42
walberla: Introduce units conversion for EK VTK
jngrad Apr 24, 2023
3d7553f
walberla: Fix ADL rule
jngrad Apr 24, 2023
08ea53a
test: Check EK VTK in parallel
jngrad Apr 25, 2023
da4c90a
walberla: Implement CellInterval-based slice setters/getters
jngrad Apr 25, 2023
20c7a37
walberla: Add modifiers and documentation
jngrad Apr 25, 2023
587d887
walberla: Fix assertions
jngrad Apr 25, 2023
7b925df
walberla: Disable FFT by default
jngrad Apr 26, 2023
2ac9f92
walberla: Cleanup
jngrad Apr 26, 2023
ea7a8f3
walberla: Rename class
jngrad Apr 26, 2023
6ecdc33
walberla: Update copyright year
jngrad Apr 26, 2023
be6c733
walberla: Fix -Wconversion in generated kernels
jngrad Apr 25, 2023
e847d71
walberla: Fix -Wconversion in the bridge
jngrad Apr 25, 2023
f290fc9
Merge branch 'python' into walberla
jngrad Apr 28, 2023
7803614
walberla: Rename electrokinetics module
jngrad Apr 26, 2023
5a394d2
wablerla: Big cleanup and fix some TODOs
jngrad Apr 28, 2023
ab050e0
CMake: Remove obsolete linker flags
jngrad May 1, 2023
1eae245
walberla: Address TODOs
jngrad May 1, 2023
7a08b17
walberla: Formatting
jngrad May 1, 2023
7334051
walberla: Restore deleted content
jngrad May 1, 2023
d19e5d4
DevOps: Fix CI
jngrad May 2, 2023
0e079aa
walberla: Cleanup EK tests
jngrad May 2, 2023
260eedc
DevOps: Use new ScaFaCoS image
jngrad May 2, 2023
851e466
walberla: Re-enable tutorials
jngrad May 2, 2023
c42b0c5
walberla: Regenerate kernels for pystencils/lbmpy 1.2
jngrad May 3, 2023
7ac020c
CMake: Remove custom compiler flags
jngrad May 3, 2023
4d82794
walberla: Bugfixes and test cases
jngrad May 3, 2023
e505b8b
walberla: Rename classes for consistency
jngrad May 3, 2023
9f3ffb5
walberla: Update copyright headers
jngrad May 3, 2023
8c30f15
walberla: Rewrite exception mechanism
jngrad May 3, 2023
4d5d9b7
walberla: More cleanup
jngrad May 3, 2023
66b9c6a
lees_edwards: Type conversion
jngrad May 4, 2023
1a870b0
walberla: Remove code duplication in VTK
jngrad May 4, 2023
a0a84e7
tests: Factor out code duplication
jngrad May 4, 2023
85c2a51
Merge remote-tracking branch 'jngrad/maintenance' into walberla
jngrad May 4, 2023
4192e19
walberla: More simplifications
jngrad May 4, 2023
a5135de
python: Simplify VTK
jngrad May 4, 2023
1a4608a
CMake: Fix regression
jngrad May 4, 2023
875b5da
walberla: Write extra EK unit tests
jngrad May 4, 2023
6610932
walberla: Move templates
jngrad May 4, 2023
7e948c9
walberla: More cleanup, more unit testing
jngrad May 4, 2023
688d61e
walberla: Document codegen
jngrad May 4, 2023
416db5c
CMake: Remove obsolete patch
jngrad May 4, 2023
0abc836
tests: Cleanup
jngrad May 5, 2023
e12323b
tests: Re-organize tests
jngrad May 5, 2023
dd6dbdf
walberla: Apply SOLID principles
jngrad May 8, 2023
8e4ed18
tests: Merge EK and LB VTK tests
jngrad May 8, 2023
cce7a46
walberla: Fix more regressions
jngrad May 8, 2023
427fffd
walberla: Rename VTK fields
jngrad May 8, 2023
8bd7b89
walberla: Restore all LB samples
jngrad May 8, 2023
c1d874b
walberla: More refactoring
jngrad May 8, 2023
a15d5fa
script_interface: Rewrite ObjectList as AutoParameters
jngrad May 9, 2023
48cd88d
script_interface: Rewrite ObjectList as AutoParameters
jngrad May 9, 2023
23a8ae8
walberla: Fix EK checkpointing
jngrad May 9, 2023
4cd1ad0
walberla: Add EKPoissonSolver checks
jngrad May 9, 2023
40a4a56
walberla: Add optional parameters
jngrad May 9, 2023
2d594b4
walberla: Simplify boundaries interface
jngrad May 9, 2023
ed97498
walberla: Add checks for solver tau
jngrad May 9, 2023
5cef536
walberla: Fix regressions
jngrad May 9, 2023
4a1534d
walberla: Fix race condition in MPI communicators
jngrad May 10, 2023
376d80b
walberla: Cleanup
jngrad May 10, 2023
5ab7ac2
script_interface: Rewrite ObjectMap as AutoParameters
jngrad May 11, 2023
b7b9006
Merge remote-tracking branch 'jngrad/object-list' into walberla
jngrad May 11, 2023
711f9d6
python: Reduce diff
jngrad May 11, 2023
0e2e7e3
walberla: Remove unused kernels
jngrad May 11, 2023
10924b2
walberla: Bump version
jngrad May 11, 2023
ea66e95
walberla: Update docs
jngrad May 11, 2023
34bde22
walberla: Adjust single-precision test tolerances
jngrad May 12, 2023
a0492b0
walberla: Coding style
jngrad May 12, 2023
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
The table of contents is too big for display.
Diff view
Diff view
  •  
  •  
  •  
3 changes: 3 additions & 0 deletions .codecov.yml
Original file line number Diff line number Diff line change
Expand Up @@ -50,3 +50,6 @@ ignore:
- "doc/tutorials"
- "samples"
- "maintainer"
- "src/walberla_bridge/**/generated_kernels/*"
- "src/walberla_bridge/myintrin.h"
- "src/walberla_bridge/philox_rand.h"
22 changes: 19 additions & 3 deletions .gitlab-ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -68,7 +68,7 @@ style_doxygen:
- mkdir build
- cd build
- cp ../maintainer/configs/maxset.hpp myconfig.hpp
- cmake .. -D ESPRESSO_BUILD_WITH_CUDA=ON -D ESPRESSO_BUILD_WITH_GSL=ON -D ESPRESSO_BUILD_WITH_HDF5=ON -D ESPRESSO_BUILD_WITH_SCAFACOS=ON -D ESPRESSO_BUILD_WITH_STOKESIAN_DYNAMICS=ON
- cmake .. -D ESPRESSO_BUILD_WITH_CUDA=ON -D ESPRESSO_BUILD_WITH_GSL=ON -D ESPRESSO_BUILD_WITH_HDF5=ON -D ESPRESSO_BUILD_WITH_SCAFACOS=ON -D ESPRESSO_BUILD_WITH_WALBERLA=ON -D ESPRESSO_BUILD_WITH_WALBERLA_FFT=ON -D ESPRESSO_BUILD_WITH_STOKESIAN_DYNAMICS=ON
- sh ../maintainer/CI/dox_warnings.sh
tags:
- espresso
Expand All @@ -87,13 +87,15 @@ default:
myconfig: 'default'
with_coverage: 'true'
with_scafacos: 'true'
with_walberla: 'true'
with_stokesian_dynamics: 'true'
check_skip_long: 'true'
script:
- bash maintainer/CI/build_cmake.sh
tags:
- espresso
- no-cuda
- numa

maxset:
<<: *global_job_definition
Expand All @@ -107,6 +109,7 @@ maxset:
myconfig: 'maxset'
with_coverage: 'true'
with_scafacos: 'true'
with_walberla: 'true'
with_stokesian_dynamics: 'true'
check_skip_long: 'true'
cmake_params: '-D ESPRESSO_TEST_NP=8'
Expand All @@ -116,6 +119,7 @@ maxset:
- espresso
- no-cuda
- numa
- avx2

no_rotation:
<<: *global_job_definition
Expand Down Expand Up @@ -169,6 +173,7 @@ clang-sanitizer:
with_asan: 'true'
with_ubsan: 'true'
with_scafacos: 'true'
with_walberla: 'true'
with_stokesian_dynamics: 'true'
script:
- bash maintainer/CI/build_cmake.sh
Expand Down Expand Up @@ -210,6 +215,7 @@ cuda11-coverage:
with_coverage: 'true'
check_skip_long: 'true'
with_scafacos: 'true'
with_walberla: 'true'
with_stokesian_dynamics: 'true'
script:
- bash maintainer/CI/build_cmake.sh
Expand All @@ -232,6 +238,8 @@ cuda11-maxset:
test_timeout: '900'
srcdir: '${CI_PROJECT_DIR}'
with_scafacos: 'true'
with_walberla: 'true'
with_walberla_avx: 'true'
with_stokesian_dynamics: 'true'
script:
- bash maintainer/CI/build_cmake.sh
Expand All @@ -256,6 +264,8 @@ tutorials-samples-maxset:
with_coverage: 'false'
with_coverage_python: 'true'
with_scafacos: 'true'
with_walberla: 'true'
with_walberla_avx: 'true'
with_stokesian_dynamics: 'true'
make_check_unit_tests: 'false'
make_check_python: 'false'
Expand All @@ -281,6 +291,8 @@ tutorials-samples-default:
with_cuda: 'true'
with_coverage: 'false'
with_scafacos: 'true'
with_walberla: 'true'
with_walberla_avx: 'true'
make_check_unit_tests: 'false'
make_check_python: 'false'
make_check_tutorials: 'true'
Expand All @@ -306,14 +318,14 @@ tutorials-samples-empty:
myconfig: 'empty'
with_cuda: 'true'
with_coverage: 'false'
with_scafacos: 'true'
with_scafacos: 'false'
with_walberla: 'false'
make_check_unit_tests: 'false'
make_check_python: 'false'
make_check_tutorials: 'true'
make_check_samples: 'true'
make_check_benchmarks: 'true'
test_timeout: '1200'
with_scafacos: 'false'
script:
- bash maintainer/CI/build_cmake.sh
tags:
Expand All @@ -334,6 +346,8 @@ tutorials-samples-no-gpu:
with_cuda: 'true'
with_coverage: 'false'
with_scafacos: 'true'
with_walberla: 'true'
with_walberla_avx: 'true'
make_check_unit_tests: 'false'
make_check_python: 'false'
make_check_tutorials: 'true'
Expand Down Expand Up @@ -362,6 +376,7 @@ installation:
make_check_unit_tests: 'false'
make_check_python: 'false'
with_scafacos: 'true'
with_walberla: 'true'
with_stokesian_dynamics: 'true'
srcdir: '${CI_PROJECT_DIR}'
build_type: 'Release'
Expand Down Expand Up @@ -396,6 +411,7 @@ empty:
with_cuda: 'true'
with_static_analysis: 'true'
with_scafacos: 'false'
with_walberla: 'false'
with_stokesian_dynamics: 'false'
with_coverage: 'false'
with_coverage_python: 'true'
Expand Down
4 changes: 2 additions & 2 deletions .pre-commit-config.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -8,8 +8,8 @@ repos:
entry: sh maintainer/format/clang-format.sh
language: system
always_run: false
files: '.*\.(cpp|hpp|cu|cuh)'
exclude: '^libs/'
files: '.*\.(cpp|hpp|h|cu|cuh)'
exclude: '^libs/|^src/walberla_bridge/src/.*/generated_kernels/.*\.(cpp|cu)|^maintainer/walberla_kernels/templates/.*\.tmpl\.(cpp|hpp|h|cu|cuh)'
args: ["-i", "-style=file"]

- id: autopep8
Expand Down
84 changes: 84 additions & 0 deletions CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -57,6 +57,7 @@ include(FeatureSummary)
project(ESPResSo)
include(GNUInstallDirs)
include(espresso_option_enum)
include(espresso_enable_avx2_support)
if(POLICY CMP0074)
# make find_package() use <PackageName>_ROOT variables
cmake_policy(SET CMP0074 NEW)
Expand Down Expand Up @@ -92,6 +93,11 @@ option(ESPRESSO_BUILD_TESTS "Enable tests" ON)
option(ESPRESSO_BUILD_WITH_SCAFACOS "Build with ScaFaCoS support" OFF)
option(ESPRESSO_BUILD_WITH_STOKESIAN_DYNAMICS "Build with Stokesian Dynamics"
OFF)
option(ESPRESSO_BUILD_WITH_WALBERLA
"Build with waLBerla lattice-Boltzmann support" OFF)
option(ESPRESSO_BUILD_WITH_WALBERLA_AVX
"Build waLBerla lattice-Boltzmann with AVX vectorization" OFF)
option(ESPRESSO_BUILD_WITH_WALBERLA_FFT "Build waLBerla with FFT support" OFF)
option(ESPRESSO_BUILD_BENCHMARKS "Enable benchmarks" OFF)
option(ESPRESSO_BUILD_WITH_VALGRIND_MARKERS
"Build with valgrind instrumentation markers" OFF)
Expand Down Expand Up @@ -171,6 +177,15 @@ foreach(func_name __PRETTY_FUNCTION__ __FUNCSIG__ __FUNCTION__)
endif(result${func_name})
endforeach()

#
# AVX2 support
#

include(CheckCXXCompilerFlag)

add_library(espresso_avx_flags INTERFACE)
add_library(espresso::avx_flags ALIAS espresso_avx_flags)

#
# Interface libraries
#
Expand Down Expand Up @@ -573,6 +588,75 @@ if(ESPRESSO_BUILD_BENCHMARKS)
add_subdirectory(maintainer/benchmarks)
endif()

#
# waLBerla
#

if(ESPRESSO_BUILD_WITH_WALBERLA)
# cmake-format: off
include(FetchContent)
FetchContent_Declare(
walberla
GIT_REPOSITORY https://i10git.cs.fau.de/walberla/walberla.git
GIT_TAG 065ce5f311850371a97ac4766f47dbb5ca8424ba
)
# workaround for https://gitlab.kitware.com/cmake/cmake/-/issues/21146
if(NOT DEFINED walberla_SOURCE_DIR OR NOT EXISTS "${walberla_SOURCE_DIR}")
FetchContent_Populate(walberla)
endif()
# cmake-format: on
string(REGEX REPLACE "([/\\]walberla)-src$" "\\1-build" walberla_BINARY_DIR
"${walberla_SOURCE_DIR}")
set(WALBERLA_BUILD_TESTS off CACHE BOOL "")
set(WALBERLA_BUILD_BENCHMARKS off CACHE BOOL "")
set(WALBERLA_BUILD_TOOLS off CACHE BOOL "")
set(WALBERLA_BUILD_TUTORIALS off CACHE BOOL "")
set(WALBERLA_BUILD_SHOWCASES off CACHE BOOL "")
set(WALBERLA_BUILD_DOC off CACHE BOOL "")
set(WALBERLA_LOGLEVEL "WARNING" CACHE STRING "")
set(CMAKE_POSITION_INDEPENDENT_CODE on CACHE BOOL "")
if(ESPRESSO_BUILD_WITH_CUDA)
set(WALBERLA_BUILD_WITH_CUDA "on" CACHE BOOL "")
if(CMAKE_VERSION VERSION_LESS 3.25 OR NOT ESPRESSO_CUDA_COMPILER STREQUAL
"clang")
if(NOT DEFINED CMAKE_CUDA_ARCHITECTURES)
set(CMAKE_CUDA_ARCHITECTURES 75)
endif()
endif()
endif()
if(ESPRESSO_BUILD_WITH_WALBERLA_FFT)
set(ESPRESSO_USE_WALBERLA_FFT 1)
set(WALBERLA_BUILD_WITH_FFTW on CACHE BOOL "")
else()
set(WALBERLA_BUILD_WITH_FFTW off CACHE BOOL "")
endif()
set(WALBERLA_BUILD_WITH_FASTMATH off CACHE BOOL "")
add_subdirectory("${walberla_SOURCE_DIR}" "${walberla_BINARY_DIR}")
set(WALBERLA_LIBS
walberla::core walberla::domain_decomposition walberla::blockforest
walberla::boundary walberla::field walberla::lbm walberla::timeloop
walberla::vtk)
if(ESPRESSO_BUILD_WITH_WALBERLA_FFT)
set(WALBERLA_LIBS ${WALBERLA_LIBS} walberla::fft)
endif()
if(ESPRESSO_BUILD_WITH_CUDA AND WALBERLA_BUILD_WITH_CUDA)
set(WALBERLA_LIBS ${WALBERLA_LIBS} walberla::cuda)
endif()
# workaround for https://gitlab.kitware.com/cmake/cmake/-/issues/21283
foreach(target_w_namespace IN LISTS WALBERLA_LIBS)
string(REPLACE "walberla::" "" target_wo_namespace ${target_w_namespace})
add_library(${target_w_namespace} ALIAS ${target_wo_namespace})
endforeach()
if(ESPRESSO_BUILD_WITH_WALBERLA_AVX)
function(espresso_avx_flags_callback COMPILER_AVX2_FLAG)
target_compile_options(
espresso_avx_flags INTERFACE "${COMPILER_AVX2_FLAG}"
"-DESPRESSO_BUILD_WITH_AVX_KERNELS")
endfunction()
espresso_enable_avx2_support(espresso_avx_flags_callback)
endif()
endif()

#
# Subdirectories
#
Expand Down
9 changes: 8 additions & 1 deletion cmake/FindFFTW3.cmake
Original file line number Diff line number Diff line change
Expand Up @@ -32,14 +32,21 @@ endif(FFTW3_INCLUDE_DIR)

find_path(FFTW3_INCLUDE_DIR fftw3.h)
find_library(FFTW3_LIBRARIES NAMES fftw3)
find_path(FFTW3_MPI_INCLUDE_DIR fftw3-mpi.h)
find_library(FFTW3_MPI_LIBRARIES NAMES fftw3_mpi)

# handle the QUIETLY and REQUIRED arguments and set FFTW3_FOUND to TRUE if all
# listed variables are TRUE
include(FindPackageHandleStandardArgs)
find_package_handle_standard_args(FFTW3 DEFAULT_MSG FFTW3_LIBRARIES
FFTW3_INCLUDE_DIR)
set(FPHSA_NAME_MISMATCHED 1)
find_package_handle_standard_args(FFTW3_MPI DEFAULT_MSG FFTW3_MPI_LIBRARIES
FFTW3_MPI_INCLUDE_DIR)
unset(FPHSA_NAME_MISMATCHED)

mark_as_advanced(FFTW3_LIBRARIES FFTW3_INCLUDE_DIR FFTW3_MPI_LIBRARIES FFTW3_MPI_INCLUDE_DIR)

mark_as_advanced(FFTW3_LIBRARIES FFTW3_INCLUDE_DIR)

if(FFTW3_FOUND AND NOT TARGET FFTW3::FFTW3)
add_library(FFTW3::FFTW3 INTERFACE IMPORTED)
Expand Down
4 changes: 4 additions & 0 deletions cmake/espresso_cmake_config.cmakein
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,10 @@

#cmakedefine ESPRESSO_BUILD_WITH_STOKESIAN_DYNAMICS

#cmakedefine ESPRESSO_BUILD_WITH_WALBERLA

#cmakedefine ESPRESSO_BUILD_WITH_WALBERLA_FFT

#cmakedefine ESPRESSO_BUILD_WITH_VALGRIND_MARKERS

#define PACKAGE_NAME "${PROJECT_NAME}"
Expand Down
67 changes: 67 additions & 0 deletions cmake/espresso_enable_avx2_support.cmake
Original file line number Diff line number Diff line change
@@ -0,0 +1,67 @@
#
# Copyright (C) 2022-2023 The ESPResSo project
#
# This file is part of ESPResSo.
#
# ESPResSo is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# ESPResSo 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
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
#

function(espresso_enable_avx2_support callback)
set(COMPILER_AVX2_FLAG "")
foreach(FLAG_NAME "-mavx2" "/arch:AVX2")
string(REGEX REPLACE "[^0-9A-Za-z_]" "_" FLAG_VARIABLE "${FLAG_NAME}")
check_cxx_compiler_flag("${flag_name}"
COMPILER_HAS_${FLAG_VARIABLE}_FLAG_RESULT)
if(COMPILER_HAS_${FLAG_VARIABLE}_FLAG_RESULT)
set(COMPILER_AVX2_FLAG "${FLAG_NAME}")
cmake_language(CALL ${callback} "${COMPILER_AVX2_FLAG}")
break()
endif()
endforeach()
if(COMPILER_AVX2_FLAG STREQUAL "")
message(
FATAL_ERROR
"${CMAKE_CXX_COMPILER_ID} ${CMAKE_CXX_COMPILER_VERSION} doesn't support AVX2-specific compiler flags."
)
endif()
if(NOT COMPILER_AVX2_FLAG STREQUAL "/arch:AVX2")
execute_process(
COMMAND ${CMAKE_CXX_COMPILER} -march=native -E -v - INPUT_FILE /dev/null
OUTPUT_VARIABLE MARCH_NATIVE_OUTPUT_STRING
ERROR_VARIABLE MARCH_NATIVE_OUTPUT_STRING)
if(NOT "${MARCH_NATIVE_OUTPUT_STRING}" MATCHES "[ \n](\\+avx2|-mavx2|-D__AVX2__)[ \n]")
message(
FATAL_ERROR
"AVX2 not supported on this CPU architecture according to ${CMAKE_CXX_COMPILER_ID} ${CMAKE_CXX_COMPILER_VERSION}. While ESPResSo will still compile, you will trigger SIGILL when calling AVX functions."
)
endif()
endif()
set(CMAKE_REQUIRED_FLAGS_BACKUP "${CMAKE_REQUIRED_FLAGS}")
set(CMAKE_REQUIRED_FLAGS "${CMAKE_REQUIRED_FLAGS} ${COMPILER_AVX2_FLAG}")
check_cxx_source_compiles(
"#include <immintrin.h>
__m256i xi_i = _mm256_set_epi32(1, 2, 3, 4, 5, 6, 7, 8);
__m256 xi_s = _mm256_set_ps(0.f, 1.f, 2.f, 3.f, 4.f, 5.f, 6.f, 7.f);
__m256d xi_d = _mm256_set_pd(0.0, 1.0, 2.0, 3.0);
int main() {}
" COMPILER_HAS_AVX2_SUPPORT)
set(CMAKE_REQUIRED_FLAGS "${CMAKE_REQUIRED_FLAGS_BACKUP}")
if(NOT COMPILER_HAS_AVX2_SUPPORT)
message(
FATAL_ERROR
"Cannot execute a simple AVX2 program compiled by ${CMAKE_CXX_COMPILER_ID} ${CMAKE_CXX_COMPILER_VERSION}."
)
endif()
endfunction()

Loading