29#include "accumulators/AutoUpdateAccumulators.hpp"
35#include "collision_detection/CollisionDetection.hpp"
36#include "communication.hpp"
45#include "thermostat.hpp"
52#include <boost/mpi/collectives/all_reduce.hpp>
67 auto handle = std::make_shared<System>(Private());
73 box_geo = std::make_shared<BoxGeometry>();
74 local_geo = std::make_shared<LocalBox>();
75 cell_structure = std::make_shared<CellStructure>(*box_geo);
76#ifdef ESPRESSO_SHARED_MEMORY_PARALLELISM
80 gpu = std::make_shared<GpuParticleData>();
82 propagation = std::make_shared<Propagation>();
83 bonded_ias = std::make_shared<BondedInteractionsMap>();
84 thermostat = std::make_shared<Thermostat::Thermostat>();
85 nonbonded_ias = std::make_shared<InteractionsNonBonded>();
86 comfixed = std::make_shared<ComFixed>();
87 galilei = std::make_shared<Galilei>();
88 oif_global = std::make_shared<OifGlobal>();
89 immersed_boundaries = std::make_shared<ImmersedBoundaries>();
90#ifdef ESPRESSO_COLLISION_DETECTION
92 std::make_shared<CollisionDetection::CollisionDetection>();
94 bond_breakage = std::make_shared<BondBreakage::BondBreakage>();
95 lees_edwards = std::make_shared<LeesEdwards::LeesEdwards>();
96 auto_update_accumulators =
97 std::make_shared<Accumulators::AutoUpdateAccumulators>();
98 constraints = std::make_shared<Constraints::Constraints>();
99 steepest_descent = std::make_shared<SteepestDescent>();
100#ifdef ESPRESSO_STOKESIAN_DYNAMICS
101 stokesian_dynamics = std::make_shared<StokesianDynamics>();
104 nptiso = std::make_shared<NptIsoParameters>();
105 npt_inst_pressure = std::make_shared<InstantaneousPressure>();
107 reinit_thermo =
true;
114void System::initialize() {
116 cell_structure->bind_system(
handle);
117 lees_edwards->bind_system(
handle);
118 bonded_ias->bind_system(
handle);
119 thermostat->bind_system(
handle);
120 nonbonded_ias->bind_system(
handle);
121 oif_global->bind_system(
handle);
122 immersed_boundaries->bind_system(
handle);
123#ifdef ESPRESSO_COLLISION_DETECTION
124 collision_detection->bind_system(
handle);
126 auto_update_accumulators->bind_system(
handle);
127 constraints->bind_system(
handle);
146 throw std::domain_error(
"time_step must be > 0.");
147 if (lb.is_solver_set()) {
148 lb.veto_time_step(value);
150 if (ek.is_solver_set()) {
151 ek.veto_time_step(value);
154 on_timestep_change();
158 if (lb.is_solver_set()) {
161 if (ek.is_solver_set()) {
168 propagation->recalc_forces =
true;
172 min_global_cut = value;
173 on_verlet_skin_change();
182 std::as_const(*cell_structure).decomposition());
183 cell_structure->set_regular_decomposition(
184 get_interaction_range(),
187 cell_structure->set_regular_decomposition(get_interaction_range(), {});
190 cell_structure->set_atom_decomposition();
195 std::as_const(*cell_structure).decomposition());
196 cell_structure->set_hybrid_decomposition(
203 set_cell_structure_topology(cell_structure->decomposition_type());
208 rebuild_cell_structure();
214#ifdef ESPRESSO_ELECTROSTATICS
215 coulomb.on_boxl_change();
217#ifdef ESPRESSO_DIPOLES
218 dipoles.on_boxl_change();
221 constraints->on_boxl_change();
226 auto const n_part = boost::mpi::all_reduce(
227 ::comm_cart, cell_structure->local_particles().size(), std::plus<>());
229 throw std::runtime_error(
230 "Cannot reset the box length when particles are present");
233 constraints->veto_boxl_change();
234 lb.veto_boxl_change();
235 ek.veto_boxl_change();
240 lb.on_node_grid_change();
241 ek.on_node_grid_change();
242#ifdef ESPRESSO_ELECTROSTATICS
243 coulomb.on_node_grid_change();
245#ifdef ESPRESSO_DIPOLES
246 dipoles.on_node_grid_change();
248 rebuild_cell_structure();
252#ifdef ESPRESSO_ELECTROSTATICS
253 coulomb.on_periodicity_change();
256#ifdef ESPRESSO_DIPOLES
257 dipoles.on_periodicity_change();
260#ifdef ESPRESSO_STOKESIAN_DYNAMICS
262 if (box_geo->periodic(0
u)
or box_geo->periodic(1u)
or box_geo->periodic(2u))
264 <<
"(False, False, False)\n";
267 on_verlet_skin_change();
272 lb.on_cell_structure_change();
273 ek.on_cell_structure_change();
274#ifdef ESPRESSO_ELECTROSTATICS
275 coulomb.on_cell_structure_change();
277#ifdef ESPRESSO_DIPOLES
278 dipoles.on_cell_structure_change();
285 rebuild_cell_structure();
286#ifdef ESPRESSO_ELECTROSTATICS
287 coulomb.on_coulomb_change();
289#ifdef ESPRESSO_DIPOLES
290 dipoles.on_dipoles_change();
292 on_short_range_ia_change();
296 lb.on_temperature_change();
297 ek.on_temperature_change();
301 lb.on_timestep_change();
302 ek.on_timestep_change();
303 on_thermostat_param_change();
307 rebuild_cell_structure();
308 propagation->recalc_forces =
true;
312 nonbonded_ias->recalc_maximal_cutoffs();
313 rebuild_cell_structure();
314 on_thermostat_param_change();
315 propagation->recalc_forces =
true;
319#ifdef ESPRESSO_ELECTROSTATICS
320 coulomb.on_coulomb_change();
322 on_short_range_ia_change();
326#ifdef ESPRESSO_DIPOLES
327 dipoles.on_dipoles_change();
329 on_short_range_ia_change();
335 propagation->recalc_forces =
true;
339 cell_structure->update_ghosts_and_resort_particle(get_global_ghost_flags());
340 propagation->recalc_forces =
true;
341 propagation->recalc_used_propagations =
true;
350#ifdef ESPRESSO_ELECTROSTATICS
351 coulomb.on_particle_change();
353#ifdef ESPRESSO_DIPOLES
354 dipoles.on_particle_change();
356 propagation->recalc_forces =
true;
357 propagation->recalc_used_propagations =
true;
361#ifdef ESPRESSO_SHARED_MEMORY_PARALLELISM
362 cell_structure->clear_local_properties();
367#ifdef ESPRESSO_ELECTROSTATICS
368 coulomb.on_particle_change();
373#ifdef ESPRESSO_VIRTUAL_SITES
374 if (propagation->recalc_used_propagations) {
375 update_used_propagations();
377#ifdef ESPRESSO_VIRTUAL_SITES_RELATIVE
378 if (propagation->used_propagations &
384#ifdef ESPRESSO_VIRTUAL_SITES_CENTER_OF_MASS
385 if (propagation->used_propagations &
390 cell_structure->update_ghosts_and_resort_particle(get_global_ghost_flags());
393#ifdef ESPRESSO_ELECTROSTATICS
394 if (has_icc_enabled()) {
395#ifdef ESPRESSO_SHARED_MEMORY_PARALLELISM
398 update_icc_particles();
405 immersed_boundaries->init_volume_conservation(*cell_structure);
411 cell_structure->update_ghosts_and_resort_particle(get_global_ghost_flags());
412 update_dependent_particles();
414#ifdef ESPRESSO_ELECTROSTATICS
415 coulomb.on_observable_calc();
418#ifdef ESPRESSO_DIPOLES
419 dipoles.on_observable_calc();
423#ifdef ESPRESSO_SHARED_MEMORY_PARALLELISM
428#ifdef ESPRESSO_SHARED_MEMORY_PARALLELISM
430#ifdef ESPRESSO_COLLISION_DETECTION
437 cell_structure->get_verlet_skin(),
438 get_interaction_range(),
444 get_interaction_range(), propagation->integ_switch);
458 max_cut = std::max(max_cut, get_min_global_cut());
459 max_cut = std::max(max_cut, coulomb.cutoff());
460 max_cut = std::max(max_cut, dipoles.cutoff());
464 max_cut = std::max(max_cut, bonded_ias->maximal_cutoff());
466 max_cut = std::max(max_cut, nonbonded_ias->maximal_cutoff());
468#ifdef ESPRESSO_COLLISION_DETECTION
469 max_cut = std::max(max_cut, collision_detection->cutoff());
476#ifdef ESPRESSO_ELECTROSTATICS
477 coulomb.sanity_checks();
479#ifdef ESPRESSO_DIPOLES
480 dipoles.sanity_checks();
482 }
catch (std::runtime_error
const &
err) {
490 auto const max_cut = maximal_cutoff();
491 auto const verlet_skin = cell_structure->get_verlet_skin();
497 box_geo->set_length(
box_l);
503 integrator_sanity_checks();
504 long_range_interactions_sanity_checks();
511 npt_ensemble_init(propagation->recalc_forces);
517 thermostat->recalc_prefactors(time_step);
518 reinit_thermo =
false;
519 propagation->recalc_forces =
true;
523#ifdef ESPRESSO_SHARED_MEMORY_PARALLELISM
524 cell_structure->clear_local_properties();
527#ifdef ESPRESSO_ADDITIONAL_CHECKS
531#ifdef ESPRESSO_ELECTROSTATICS
533 auto const &actor = coulomb.impl->solver;
539#ifdef ESPRESSO_DIPOLES
541 auto const &actor = dipoles.impl->solver;
549 on_observable_calc();
561 if (lb.is_solver_set())
572#ifdef ESPRESSO_COLLISION_DETECTION
573 if (
not collision_detection->is_off()) {
590 if (has_npt_enabled()) {
591 return &npt_inst_pressure->p_vir;
597#ifdef ESPRESSO_COLLISION_DETECTION
599 return not collision_detection->is_off();
CellStructureType
Cell structure topology.
@ NSQUARE
Atom decomposition (N-square).
@ HYBRID
Hybrid decomposition.
@ REGULAR
Regular decomposition.
@ INTEG_METHOD_NPT_ISO_AND
@ INTEG_METHOD_NPT_ISO_MTK
Vector implementation and trait types for boost qvm interoperability.
Data structures for bonded interactions.
Hybrid decomposition cell system.
static LocalBox make_regular_decomposition(Utils::Vector3d const &box_l, Utils::Vector3i const &node_index, Utils::Vector3i const &node_grid)
void on_periodicity_change()
double get_interaction_range() const
Get the interaction range.
double maximal_cutoff() const
Calculate the maximal cutoff of all interactions.
void on_constraint_change()
Called every time a constraint is changed.
void on_cell_structure_change()
unsigned get_global_ghost_flags() const
Returns the ghost flags required for running pair kernels for the global state, e....
void on_boxl_change(bool skip_method_adaption=false)
Called when the box length has changed.
void set_box_l(Utils::Vector3d const &box_l)
Change the box dimensions.
void on_temperature_change()
void on_thermostat_param_change()
void on_lees_edwards_change()
void on_integration_start()
void set_force_cap(double value)
Set force_cap.
void on_non_bonded_ia_change()
void on_verlet_skin_change()
void update_dependent_particles()
Update particles with properties depending on other particles, namely virtual sites and ICC charges.
void on_lb_boundary_conditions_change()
Called when the LB boundary conditions change (geometry, slip velocity, or both).
void veto_boxl_change(bool skip_particle_checks=false) const
void set_time_step(double value)
Set time_step.
void on_particle_change()
Called every time a particle property changes.
bool long_range_interactions_sanity_checks() const
Check electrostatic and magnetostatic methods are properly initialized.
void on_node_grid_change()
void on_particle_charge_change()
Called every time a particle charge changes.
void on_particle_local_change()
Called every time a particle local property changes.
void on_observable_calc()
called before calculating observables, i.e.
void on_timestep_change()
void check_kT(double value) const
Veto temperature change.
static std::shared_ptr< System > create()
Utils::Vector3d * get_npt_virial() const
void set_min_global_cut(double value)
Set min_global_cut.
bool has_npt_enabled() const
void set_cell_structure_topology(CellStructureType topology)
Change cell structure topology.
void on_short_range_ia_change()
void rebuild_cell_structure()
Rebuild cell lists.
bool has_collision_detection_enabled() const
Returns true if the particles are to be considered for short range interactions.
void vs_com_update_particles(CellStructure &cell_structure, BoxGeometry const &box_geo)
cudaStream_t stream[1]
CUDA streams for parallel computing on CPU and GPU.
std::shared_ptr< KokkosHandle > kokkos_handle
Communicator communicator
boost::mpi::communicator comm_cart
The communicator.
constexpr double inactive_cutoff
Special cutoff value for an inactive interaction.
This file contains the errorhandling code for severe errors, like a broken bond or illegal parameter ...
#define runtimeErrorMsg()
ICC is a method that allows to take into account the influence of arbitrarily shaped dielectric inter...
@ DATA_PART_MOMENTUM
Particle::m.
@ DATA_PART_PROPERTIES
Particle::p.
@ DATA_PART_BONDS
Particle::bonds.
@ DATA_PART_POSITION
Particle::r.
@ TRANS_VS_CENTER_OF_MASS
static std::shared_ptr< System > instance
void set_system(std::shared_ptr< System > new_instance)
bool all_compare(boost::mpi::communicator const &comm, T const &value)
Compare values on all nodes.
Exports for the NpT code.
void invalidate_fetch_cache()
Invalidate the fetch cache for get_particle_data.
void clear_particle_node()
Invalidate particle_node.
Particles creation and deletion.
void vs_relative_update_particles(CellStructure &cell_structure, BoxGeometry const &box_geo)
See for the Stokesian dynamics method used here.
ESPRESSO_ATTR_ALWAYS_INLINE void update_cabana_state(CellStructure &cell_structure, auto const &verlet_criterion, double const pair_cutoff, auto const integ_switch)
Utils::Vector3i calc_node_index() const
Calculate the node index in the Cartesian topology.
Utils::Vector3i node_grid
Regular decomposition cell system.
Routines to thermalize the center of mass and distance of a particle pair.