Computational Microfluidics
Mirheo is a GPU high-performance and high-throughput code aimed at simulation of flows at milli- and microscales. The code uses Dissipative Particle Dynamics method to describe the liquid and its interaction with cells and other bodies.
For more information, please refer to the online documentation: http://mirheo.readthedocs.io/
git clone --recursive https://github.com/cselab/Mirheo
cd Mirheo
make install
- add basic structure for the development documentation
- renamed most private variables: now should have a trailing
_
- enabled -Wshadow
- particle checker plugin dumps all particle fields when triggered
- bug fix: avoid avoid division by zero and nan in several places:
- SDPD kernel
- root finder (concerns bounce back)
- Do not create checkpoint folder when not needed
- bug fix restart for rigid object vector in multi-rank
- bug fix restart: initial processor assignment; shift relies on redistribution
- bug fix repulsive LJ: missing factor; add an additional check so the force is continuous at rc
- internal changes
- state is private
- add -Wconversion for
.cpp
files (not.cu
for now because of thrust)
- bug fix: pass substep with random fluctuations had bias rng
- prepend macros with
MIRHEO_
- interface changes:
- average flow plugins: does not need type
- changed channel names to a more consistent version
- add list of reserved channel names into docs
- internal changes:
- more modern CMakeLists
- remove unneeded includes
- reduce compilation time: do not include
std::chrono
- reduce compilation time: do not bind all plugin classes
- interface changes
- substep integrator now takes a list of interactions
- ObjStats plugin dumps additional type id field if activated
- dump particles plugin does not need type infos
- dump particles plugin supports object and rod data
- remove dump particles rod plugin as it would now be redundant
- add membrane with type id IC
- add filtered membrane forces, which can be used in coordination with the type ids field
- make Mirheo more usable as a library:
- changed the directory structure
- added namespace
mirheo
-
Add double precision support can be compiled with
CMAKE_FLAGS="-DDOUBLE_PRECISION=ON" mir.make
-
bug fixes:
- fixed cell lists sizes with domain sizes not multiple of rc
- fix in reverse force exchanger
- objectBelonging: split all persistent channels instead of positions and velocities only
-
add
PlaneOutletPlugin
for removing particles that cross a given plane -
add
ParticlePortal
plugin that transfers standalone particles from one Mirheo instance to another -
add
ObjectDeleter
helper class for removing marked objects
Work in progress:
- adding
ObjectPortal
plugin that transfers objects from one Mirheo instance to another - adding
ObjectsToParticles
plugin that destroys objects and transforms them into standalone particles once a condition is met
-
support for different bounce kinds: every bouncer can be used with:
- bounce back
- bounce maxwell
-
Interface changes:
- need bounce kernel parameter for every bouncer
-
Interface changes:
- add function to log compile time options; this can be useful to make sure what was run exactly
- generic Pairwise forces; removed all old pairwise classes from the interface
- use
kBT
everywhere instead ofkbt
- use
number_density
instead ofdensity
- rename
mirheo
class coordinator toMirheo
-
internal changes
- refactored pairwise interaction drivers
- more consistent naming
- internal changes:
- enable and fix warnings
- fix initialization bugs
- use forked cselab/cuda_variant
- refactor interaction manager: one for each interaction stage
- interface changes: new field
requireShift
in restart files. Newer versions will not be able to read older restart files. - add unit tests for restart
- internal changes:
- refactored restart for particle vectors
- fix: test for ROV
- fix: correctly assigns and shift data during restart IC
- interface changes:
- no checkpointEvery in registerParticleVector or belongingChercker
- internal changes:
- refactoring of packers
- add persistent channels support for rod bisegment data
- allow silent log
- pack arguments: logInfo and checkpointInfo for better readability
- add unit tests for packers:
- redistribute (particles, objects, rods)
- exchange (particles, objects)
- test for bounce back reverse exchange:
- rigid
- membrane mesh
- rigid mesh
- rename to Mirheo
- add spin based state update for rods with polymorphic states (not validated yet)
- fix was a possible deadlock for many nodes / many objects suspensions; see commit 4b65e00eba8cf163db3e99e1730e6f16c12fcd26
- add Capsule Rigid Vectors together with bonce back and belonging checkers
- tests: renaming, semantic
- add CylinderRigidObjectVectors (CROVs)
- add bounce back on rods and CROVs
- add belonging checker for rods and CROVs
- tests belonging checkers
- internal changes:
- do not rely on hash for mpi tags in plugins
- generic kernels in belonging and bounce for RigidObjectVectors with analytical shapes
- fix MPI cleanup
- fix restart in pvs now supports extra data
- fix checkpoint in pvs also shifts the extra data
- fix dump plugins for xyz, ply and grid h5 timestamp based on simulation time (hence continues after restart)
- fix float4 data is correctly dumped in checkpoint
- minor fix stats plugin works for 0 particles
- interface changes anchor particle plugin accepts multiple anchors
- add pin rod extremity plugin
- fix cleanup streams
- fix more robust filename creation
- fix more robust parameter passing to rod forces factory
- interace chanes rod forces:
- change
omega0
tokappa0
- remove
k_visc
- split
k_bounds
intok_s_center
andk_s_frame
- can optionally save energies and polymorphic states
- change
- extend rod IC
- implement polymorphic states
- add interaction rod-rigid
- fix free communicator in plugins
- add
particleChecker
plugin - interface changes: average flow plugin does not support float8 entries anymore due to internal changes; use float4 instead
- internal changes
- particles are now separated into 2 arrays: positions and velocities; this will simplify packing/unpacking kernels
- positions and velocities are stored as other quantities in dataManagers
- old particles are only positions
- vertices are only positions
- output change
- restart time-stamps are now continuing from the previous simulation
- output dump files start at t=0
- fix in TextIO::reader
- internal changes:
- currentStep is long long -> allow longer simulations
- forces are stored as generic arrays -> simplifies a bit cell lists
- interface change pass rod width to rod ic
- add bound viscous forces to rod
- fix issues #38 and #54
- safe check: cannot register or set objects to coordinator after setup
- interface changes Integrator: SubStepMembrane -> SubStep
- SubStep integrator supports rods
- add anchor_particle plugin
- internal changes:
- ids are stored in 64 bits integers
- Add "rod aware" LJ repulsion interactions
- interface change DPD, MDPD and LJ interactions have only one constructor each
- Safer parameters in interaction factory: treat unread parameters
- Add elastic rod interactions: bounds, bending and torsion
- Add corresponding unit test
- Add corresponding regression tests
- Add particle drap plugin
- fix (minor) dependencies for tools installation
- compilation changes require
c++ 14
andcuda 9.2
- additional extern code include
src/extern/mpark
- interface change linear EOS in SDPD needs an extra parameter
rho_0
- fix SDPD: correct use of mass density
- checkpoint and restart interaction random state
- internal changes:
- cleanup some implementations from interfaces
- adding rod vectors
- remove xmacros for channel types
- use mpark::variant for membrane interaction
- interface changes
- use checkpoint instead of restart in Ymero coordinator constructor
- add checkpoint_mode parameter to Ymero coordinator constructor
- checkpoint/restart mechanism is more uniform
- densities computed from pairwise interactions are now mass density
- internal changes:
- add fetcher with mass
- add type trait for self interacting pairwise kernels
- add support of SDPD/MDPD for objects
- fix belonging checkers for halo objects: needed rigid motions
- fix reverse exchanger data taken from halo for the extra data
- fix
mirheo.restart()
will now indeed restart the simulation - interface change Renamed and moved parameter for MPI communicator in the mirheo constructor
- interface change Density interaction needs a density kernel
- add SDPD interactions
- add more density kernels
- docs: add tutorials
- docs: minor fixes
- internal:
- tests are more robust to DPD noise
- proper rng per time step in DPD/MDPD
- add density outlet plugin
- add rate outlet plugin
- add experimental version of density control plugin
- support for RDMA communication
- membrane fluctuation forces: use uniform distribution instead of gaussian so that it is bounded
- membrane forces: more robust computation of Lim forces
- internal changes:
- simplify interface of interaction manager
- pairwise forces can contain only host memory variable and pass a separate handle to gpu
- pairwise interaction: compiled separately when template instances are created
- fix Lim shear forces bug: triangle invariant
- fix reset accumulated quantities in Juelicher ADE model
- fix check MPI send requests
- fix Juelicher bending forces sign
- fix Lim shear forces sign
- add possibility to compute membrane forces in double perecision
- fix wall thickness is larger when using MDPD
- internal changes:
- cell lists do not know about special channels
- add interaction manager to manage interaction channels
- fix bounce back on multiple nodes for objects
- minor fixes in documentation
- add Lim model for shear forces on membranes
- add corresponding tests
- interface change membrane interactions take only one constructor (see docs)
- fix warp reductions: all threads participate
- internal changes:
- cosmetic changes: more consistent namespace style
- membrane interaction takes a functor for dihedral computations
- refactor membrane interactions: take functors for shear and bending forces
- Internal change: add before cell list plugin task
- fix: pvs exchanger plugin: new particles are now correctly redistributed
- fix: velocity inlet plugin: new particles are now correctly redistributed
- fix: communication of persistent data to empty pvs
- fix: average plugin asynchronous message to postprocessing
- add displacement plugin
- add radial velocity control plugin
- fix reordering of extra data in celllists
- fix pvsExchanger plugin also copies persistent channels
- add test for pvsExchanger
- add test for displacement plugin
- internal changes:
- packers can copy to another packer
- defaultStream in
core/utils/cuda_common.h
- add velocity inlet plugin
- add very simple CPU marching cubes implementation in core
- clean up units
- add wall force collector plugin
- automated support of multiple GPUs on single nodes
- fix in bounce
- remove deprecate warings for python 3.7
- Adds support for different stress free shape than original mesh
- add plugin to save a channel of extra particle data (useful for intermediate quantities such as densities in MDPD)
- fix reordering of persistent extra channels in primary cell lists
- fix use local cell lists instead of primary ones in halo exchanger
- Add MDPD interaction (walls and solvent fully supported only)
- internal changes:
- generic pairwise interaction fetching
- 2-steps interaction support: extended task dependency graph
- cell lists are aware of which channels to clear, accumulate and reorder
- wip: more general object reverse exchangers
- interface change: make frozen walls takes a list of interactions
- interface change: make frozen rigid takes a list of interactions
- support for VOLTA architecture
- internal changes
- generic pairwise interaction output: accumulators
- generic pairwise_interaction: pass views
- cell lists produce views; cellinfos don not know about particles and forces
- less magic numbers
- fix: LJ potential had swapped epsilon and sigma
- separate sdf grid implementation into more general core/field
- field can be initialized from std::function
- pressure plugin uses region
- fix: stress free state can be used when the cell is grown
- fix: MembraneMesh wrapper needs GPU
- fix: the stress entries are now cleared before forces; could be cleared more by other interaction handlers
- use mirheo state inside the simulation objects; do not have current time, step and dt separate in simulation
- add filtered initial conditions: allows custom regions in space to initialise uniform density particles
- add sphere initial condition
- add plugin to compute total virial pressure from stresses per particle for a given pv
- Add common YmrState object.
- interface change:
- the time step is now passed to the coordinator constructor
- the time step is not passed to any other object
- add checkpoint for permanent channels
- extra data managers are aware of the type
- add permanent channels in extra data manager
- reorganise membrane interaction kernels:
- bending force kernels now separated from other
- 2 parameter strctures
- add Juelicher bending model
- add force saver plugin to save forces in channels
- rename uDeviceX to Ymero
- synchronzation bug fix
- add plugin for magnetic orientation of rigid bodies
- make the stress channel name customizable
- add stress computation + tests
- perf improvement in sdf
- minor perf improvement in pairwise kernels
- compile some units
- use gtest
- interface change: wall oscillation: period is in dpd units now
- add hdf5 support for mesh dump
- allow for extra channels to be dumped together with the mesh
- add compile time switch for CUDA>9 support
- add extra force plugin
- proper MPI init and finalize
- communicator can be passed from python
- add tools python submodule
- add checkpoint/restart support for object vectors
- dumped in xdmf+hdf5 format: restart files can be viewed
- add bounce tests
- wip: xdmf support for restart
- bug fix: bounce back with substep integration
- xdmf reader
- dump walls in xdmf format
- add tests for bounce back on mesh + rigid ellipsoids
- sdf fix: merged sdf before splittinf frozen particles
- set up versioning