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 250 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
Jump to file
Failed to load files.
Loading
Diff view
Diff view
83 changes: 53 additions & 30 deletions .gitlab-ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -80,6 +80,7 @@ default:
myconfig: 'default'
with_coverage: 'true'
with_scafacos: 'true'
with_walberla: 'true'
with_stokesian_dynamics: 'true'
check_skip_long: 'true'
script:
Expand All @@ -106,6 +107,24 @@ maxset:
- docker
- linux

maxset-walberla:
<<: *global_job_definition
stage: build
variables:
with_cuda: 'false'
myconfig: 'maxset-walberla'
with_coverage: 'true'
with_walberla: 'true'
with_scafacos: 'false'
with_stokesian_dynamics: 'false'
check_skip_long: 'true'
check_procs: '4'
script:
- bash maintainer/CI/build_cmake.sh
tags:
- docker
- linux

no_rotation:
<<: *global_job_definition
stage: build
Expand Down Expand Up @@ -281,11 +300,12 @@ tutorials-samples-maxset:
variables:
CC: 'gcc-8'
CXX: 'g++-8'
myconfig: 'maxset'
myconfig: 'maxset-walberla'
with_cuda: 'true'
with_coverage: 'false'
with_coverage_python: 'true'
with_scafacos: 'true'
with_walberla: 'true'
make_check_unit_tests: 'false'
make_check_python: 'false'
make_check_tutorials: 'true'
Expand Down Expand Up @@ -429,28 +449,29 @@ empty:
- linux
- cuda-kepler

check_sphinx:
<<: *global_job_definition
stage: additional_checks
needs:
- cuda10-maxset
when: on_success
script:
- sed -i 's/ or "DISPLAY" in os.environ/ or True/' ${CI_PROJECT_DIR}/src/python/espressomd/visualization.pyx
- cd ${CI_PROJECT_DIR}/build
- make -t && rm src/python/espressomd/visualization.* && make sphinx
- make -j2 tutorials
- make check_utils
- bash ${CI_PROJECT_DIR}/maintainer/CI/doc_warnings.sh
- python3 ${CI_PROJECT_DIR}/maintainer/CI/jupyter_warnings.py
artifacts:
paths:
- build/doc/sphinx
expire_in: 1 week
tags:
- docker
- linux
- cuda-kepler
# WALBERLA TODO
#check_sphinx:
# <<: *global_job_definition
# stage: additional_checks
# needs:
# - cuda10-maxset
# when: on_success
# script:
# - sed -i 's/ or "DISPLAY" in os.environ/ or True/' ${CI_PROJECT_DIR}/src/python/espressomd/visualization.pyx
# - cd ${CI_PROJECT_DIR}/build
# - make -t && rm src/python/espressomd/visualization.* && make sphinx
# - make -j2 tutorials
# - make check_utils
# - bash ${CI_PROJECT_DIR}/maintainer/CI/doc_warnings.sh
# - python3 ${CI_PROJECT_DIR}/maintainer/CI/jupyter_warnings.py
# artifacts:
# paths:
# - build/doc/sphinx
# expire_in: 1 week
# tags:
# - docker
# - linux
# - cuda-kepler

run_tutorials:
<<: *global_job_definition
Expand Down Expand Up @@ -542,13 +563,15 @@ check_with_odd_no_of_processors:
- linux
- icp

deploy_sphinx_documentation:
extends: .deploy_base
dependencies:
- check_sphinx
script:
- cd ${CI_PROJECT_DIR}/build/doc/sphinx/html &&
rsync -avz --delete -e "ssh -i ${HOME}/.ssh/espresso_rsa" ./ [email protected]:/home/espresso/public_html/html/doc
# WALBERLA TODO
#deploy_sphinx_documentation:
# extends: .deploy_base
# dependencies:
# - check_sphinx
# script:
# - cd ${CI_PROJECT_DIR}/build/doc/sphinx/html &&
# rsync -avz --delete -e "ssh -i ${HOME}/.ssh/espresso_rsa" ./ [email protected]:/home/espresso/public_html/html/doc
#

deploy_doxygen_documentation:
extends: .deploy_base
Expand Down
1 change: 1 addition & 0 deletions .gitmodules
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
[submodule "libs/h5xx"]
path = libs/h5xx
url = https://github.com/h5md/h5xx.git

15 changes: 8 additions & 7 deletions .pre-commit-config.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -20,13 +20,14 @@ repos:
exclude: '\.pylintrc|.*.\.py\.in'
args: ["--ignore=E266,E701,W291,W293", "--in-place", "--aggressive"]

- id: cmake-format
name: cmake-format
entry: sh maintainer/format/cmake-format.sh
language: system
always_run: false
files: 'CMakeLists.txt'
args: ["-i"]
# TODO WALBERLA
# - id: cmake-format
# name: cmake-format
# entry: sh maintainer/format/cmake-format.sh
# language: system
# always_run: false
# files: 'CMakeLists.txt'
# args: ["-i"]

- id: ex-flags
name: executable flags
Expand Down
31 changes: 31 additions & 0 deletions CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -78,6 +78,7 @@ option_if_available(WITH_STOKESIAN_DYNAMICS "Build with Stokesian Dynamics" ON)
option(WITH_BENCHMARKS "Enable benchmarks" OFF)
option(WITH_VALGRIND_INSTRUMENTATION
"Build with valgrind instrumentation markers" OFF)
option(WITH_WALBERLA "Build with WALBERLA Lattice-Boltzmann support" OFF)
if(CMAKE_CXX_COMPILER_ID MATCHES "Clang")
option(WITH_CLANG_TIDY "Run Clang-Tidy during compilation" OFF)
endif()
Expand Down Expand Up @@ -490,6 +491,36 @@ if(WITH_BENCHMARKS)
add_subdirectory(maintainer/benchmarks)
endif(WITH_BENCHMARKS)


# Walberla
if (WITH_WALBERLA)
cmake_minimum_required(VERSION 3.11)
include(FetchContent)
FetchContent_Declare(
walberla
GIT_REPOSITORY https://i10git.cs.fau.de/walberla/walberla
GIT_TAG 64a4d68
PATCH_COMMAND patch -p0 --ignore-whitespace -i
${PROJECT_SOURCE_DIR}/cmake/waLBerlaFunctions.patch
)
FetchContent_Populate(walberla)
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(CMAKE_POSITION_INDEPENDENT_CODE on CACHE BOOL "")
add_subdirectory("${walberla_SOURCE_DIR}" "${walberla_BINARY_DIR}")
set(WALBERLA 1)
# TODO WALBERLA: remove -lmpi_cxx -lmpi (required to find symbol MPI::Datatype::Free() in VTK code) and -lstdc++fs
set(WALBERLA_LIBS walberla::core walberla::domain_decomposition walberla::blockforest walberla::boundary walberla::core walberla::domain_decomposition walberla::field walberla::lbm walberla::timeloop walberla::vtk)
if(NOT CMAKE_CXX_COMPILER_ID MATCHES "AppleClang")
set(WALBERLA_LIBS ${WALBERLA_LIBS} stdc++fs -lmpi_cxx -lmpi)
endif()
endif(WITH_WALBERLA)

#######################################################################
#
# Subdirectories
#
Expand Down
20 changes: 20 additions & 0 deletions cmake/FindwaLBerla.cmake
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
set( WALBERLA_FOUND OFF CACHE BOOL "waLBerla found" )
set( WALBERLA_DIR WALBERLA_DIR-NOTFOUND CACHE PATH "waLBerla path" )

if(EXISTS "${CMAKE_CURRENT_SOURCE_DIR}/walberla" )
# Subdirectory walberla exists
message( STATUS "Using walberla subfolder" )
add_subdirectory( walberla EXCLUDE_FROM_ALL )
waLBerla_import(NO_COMPILER_FLAGS)
set( WALBERLA_DIR "${CMAKE_CURRENT_SOURCE_DIR}/walberla" CACHE PATH "waLBerla path" FORCE )
set( WALBERLA_FOUND ON CACHE BOOL "waLBerla found" FORCE )
else()
# Search for a build directory elsewhere
find_package( waLBerla REQUIRED NO_MODULE )
message( STATUS "Found waLBerla source directory ${walberla_SOURCE_DIR}" )
message( STATUS "Found waLBerla binary directory ${walberla_BINARY_DIR}" )
add_subdirectory( ${walberla_SOURCE_DIR} ${walberla_BINARY_DIR} EXCLUDE_FROM_ALL )
waLBerla_import()
set( WALBERLA_DIR "${walberla_BINARY_DIR}" CACHE PATH "waLBerla path" FORCE )
set( WALBERLA_FOUND ON CACHE BOOL "waLBerla found" FORCE )
endif()
8 changes: 8 additions & 0 deletions cmake/waLBerlaFunctions.patch
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
--- cmake/waLBerlaFunctions.cmake
+++ cmake/waLBerlaFunctions.cmake
@@ -91,4 +91,5 @@ function ( waLBerla_add_module )
if ( hasSourceFiles )
add_library( ${moduleLibraryName} STATIC ${sourceFiles} ${otherFiles} )
+ add_library(walberla::${moduleLibraryName} ALIAS ${moduleLibraryName})
else( )
add_custom_target( ${moduleLibraryName} SOURCES ${sourceFiles} ${otherFiles} ) # dummy IDE target
33 changes: 1 addition & 32 deletions doc/sphinx/advanced_methods.rst
Original file line number Diff line number Diff line change
Expand Up @@ -523,7 +523,7 @@ or data files for further processing and analysis.
Visualization in ParaView
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

For visualization we suggest the free software ParaView. All .vtk
For visualization we suggest the free software ParaView [5]_. All .vtk
files (boundaries, fluid, objects at all time steps) can be loaded at
the same time. The loading is a two step process, because only after
pressing the Apply button, are the files actually imported. Using the
Expand Down Expand Up @@ -1422,35 +1422,6 @@ Checkpointing in the EK works quite similar to checkpointing in the LB, because
Output
~~~~~~

.. _Fields:

Fields
^^^^^^

::

ek.print_vtk_boundary(path)
ek.print_vtk_density(path)
ek.print_vtk_velocity(path)
ek.print_vtk_potential(path)

A property of the fluid field can be exported into a
file in one go. Currently supported
are: density, velocity, potential and boundary, which give the LB fluid density, the LB fluid velocity,
the electrostatic potential, and the location and type of the
boundaries, respectively. The boundaries can only be printed when the
``EK_BOUNDARIES`` is compiled in. The output is a vtk-file, which is readable by
visualization software such as ParaView [5]_ and Mayavi2 [6]_.

::

species.print_vtk_flux(path)
species.print_vtk_density(path)

These commands are similar to the above. They enable the
export of diffusive species properties, namely: ``density`` and ``flux``, which specify the
number density and flux of species ``species``, respectively.

.. _Local Quantities:

Local Quantities
Expand All @@ -1475,8 +1446,6 @@ The local ``density`` and ``flux`` of a species can be obtained in the same fash

.. [5]
https://www.paraview.org/
.. [6]
http://code.enthought.com/projects/mayavi/


.. _Particle polarizability with thermalized cold Drude oscillators:
Expand Down
51 changes: 21 additions & 30 deletions doc/sphinx/lb.rst
Original file line number Diff line number Diff line change
Expand Up @@ -216,41 +216,32 @@ drift. To remove the momentum in the fluid call::
Output for visualization
------------------------

|es| implements a number of commands to output fluid field data of the whole fluid into a file at once. ::

lb.print_vtk_velocity(path)
lb.print_vtk_boundary(path)
lb.print_velocity(path)
lb.print_boundary(path)

Currently supported fluid properties are the velocity, and boundary flag in ASCII VTK as well as Gnuplot compatible ASCII output.
|es| implements the :meth:`LBFluidWalberla.write_vtk()` command to output
one or multiple fluid field data into a single file::


vtk_obs = ['density', 'velocity_vector']
# create a VTK callback that automatically writes every 10 LB steps
lb_vtk = lbf.add_vtk_writer('vtk_automatic', vtk_obs, delta_N=10)
self.system.integrator.run(100)
# can be deactivated
lb_vtk.disable()
self.system.integrator.run(10)
lb_vtk.enable()
# create a VTK callback that writes on demand
lb_vtk = lbf.add_vtk_writer('vtk_now', vtk_obs)
lb_vtk.write()

Currently supported fluid properties are the density, velocity vector
and pressure tensor. By default, the properties of the current state
of the fluid are written to disk. To add a callback that writes to
disk continuously, use the optional argument ``delta_N`` to indicate
the level of subsampling. Such a callback can be deactivated.

The VTK format is readable by visualization software such as ParaView [1]_
or Mayavi2 [2]_. If you plan to use ParaView for visualization, note that also the particle
positions can be exported using the VTK format (see :meth:`~espressomd.particle_data.ParticleList.writevtk`).

The variant

::

lb.print_vtk_velocity(path, bb1, bb2)

allows you to only output part of the flow field by specifying an axis aligned
bounding box through the coordinates ``bb1`` and ``bb1`` (lists of three ints) of two of its corners. This
bounding box can be used to output a slice of the flow field. As an
example, executing

::

lb.print_vtk_velocity(path, [0, 0, 5], [10, 10, 5])

will output the cross-section of the velocity field in a plane
perpendicular to the :math:`z`-axis at :math:`z = 5` (assuming the box
size is 10 in the :math:`x`- and :math:`y`-direction).

.. If the bicomponent fluid is used, two filenames have to be supplied when exporting the density field, to save both components.


.. _Choosing between the GPU and CPU implementations:

Choosing between the GPU and CPU implementations
Expand Down
22 changes: 9 additions & 13 deletions doc/tutorials/active_matter/active_matter.ipynb
Original file line number Diff line number Diff line change
Expand Up @@ -218,7 +218,7 @@
"by invoking\n",
"\n",
"```python\n",
"lbf = espressomd.lb.LBFluidGPU(agrid=1, dens=1.0, visc=1.0, tau=0.01)\n",
"lbf = espressomd.lb.LBFluidWalberla(agrid=1, dens=1.0, visc=1.0, tau=0.01)\n",
"system.actors.add(lbf)\n",
"system.thermostat.set_lb(LB_fluid=lbf, gamma=20.0, seed=42)\n",
"```\n",
Expand Down Expand Up @@ -529,15 +529,15 @@
"The first block of the script sets up the basic simulation parameters, with\n",
"which you should be familiar – if you are struggling with this part, please\n",
"consult the previous tutorials. The second block sets up the boundaries using\n",
"instances of <tt>LBBoundary</tt>, as was introduced in the LB tutorial.\n",
"Finally, in the third block the\n",
"code\n",
"instances of <tt>LBBoundary</tt>, as was introduced in the LB tutorial, and\n",
"fills the cavity with a fluid. Finally, in the third block, the code\n",
"\n",
"```python\n",
"lbf.print_vtk_boundary(\"{}/boundary.vtk\".format(outdir))\n",
"lb_vtk = lbf.add_vtk_writer(\"shape\", \"density\")\n",
"lb_vtk.write()\n",
"```\n",
"\n",
"ensures that the boundary data is exported to a <tt>.vtk</tt> file. This file\n",
"ensures that the fluid data is exported to a <tt>.vtu</tt> file. This file\n",
"can be read in and visualized using the program ParaView, which should\n",
"have been introduced in the LB and Electrostatics tutorials. Here, we briefly\n",
"comment on how the geometry can be visualized. In the command prompt type\n",
Expand All @@ -546,13 +546,9 @@
"paraview &\n",
"```\n",
"\n",
"to open ParaView. Open the relevant <tt>.vtk</tt> file (in our\n",
"case <tt>boundary.vtk</tt>). Click the green `Apply` button. Now add a\n",
"`Clip` from the ribbon just above the Pipeline Browser to the\n",
"highlighted <tt>boundary.vtk</tt> entry. Within the `Clip Properties` tab, select\n",
"`Scalar` in the `Clip Type` drop-down tab. Then set the value of the\n",
"scalar to 0.1 with the slide (or by typing in the field) and tick the\n",
"`Inside Out` box. Click `Apply`. Next do `Filter/Alphabetical/Extract Surface`\n",
"to open ParaView. Open the relevant <tt>.vtu</tt> file (in our\n",
"case <tt>vtk_out/shape/simulation_step_0.vtu</tt>). Click the green `Apply` button.\n",
"Next do `Filter/Alphabetical/Extract Surface` and click the green `Apply` button\n",
"to create a surface mesh, then do `Filter/Alphabetical/Smooth` with 1000 in the\n",
"`Number of iterations` field. Click `Apply`, then set the `Opacity` slide to\n",
"0.25 to visualize the inside of the geometry that you have created. The result\n",
Expand Down
Loading