85class System :
public std::enable_shared_from_this<System> {
93 static std::shared_ptr<System> create();
96 std::shared_ptr<GpuParticleData>
gpu;
104 void set_time_step(
double value);
110 void set_sim_time(
double value);
116 void set_force_cap(
double value);
122 void set_min_global_cut(
double value);
139 void rebuild_cell_structure();
140#ifdef ESPRESSO_SHARED_MEMORY_PARALLELISM
141 void rebuild_aosoa();
145 double maximal_cutoff()
const;
148 double get_interaction_range()
const;
150 unsigned get_global_ghost_flags()
const;
155 bool long_range_interactions_sanity_checks()
const;
158 std::shared_ptr<Observable_stat> calculate_energy();
161 std::shared_ptr<Observable_stat> calculate_pressure();
171 void synchronize_npt_state();
173 void npt_ensemble_init(
bool recalc_forces);
174 void npt_add_virial_contribution(
double energy);
175 bool has_npt_enabled()
const;
180 void calculate_forces();
182#ifdef ESPRESSO_DIPOLE_FIELD_TRACKING
187#ifdef ESPRESSO_COLLISION_DETECTION
188 bool has_collision_detection_enabled()
const;
200 double particle_short_range_energy_contribution(
int pid);
215 std::optional<double> particle_bond_energy(
int pid,
int bond_id,
256 void lb_couple_particles();
272 void on_node_grid_change();
273 void on_periodicity_change();
274 void on_cell_structure_change();
275 void on_thermostat_param_change();
276 void on_temperature_change();
277 void on_verlet_skin_change();
278 void on_timestep_change();
279 void on_integration_start();
280 void on_short_range_ia_change();
281 void on_non_bonded_ia_change();
282 void on_coulomb_change();
283 void on_dipoles_change();
285 void on_constraint_change();
289 void on_lb_boundary_conditions_change();
291 void on_particle_local_change();
293 void on_particle_change();
295 void on_particle_charge_change();
300 void on_observable_calc();
301 void on_lees_edwards_change();
309 void update_dependent_particles();
313 void update_used_propagations();
317 void check_kT(
double value)
const;
334#ifdef ESPRESSO_COLLISION_DETECTION
339 std::shared_ptr<Accumulators::AutoUpdateAccumulators>
343#ifdef ESPRESSO_STOKESIAN_DYNAMICS
347 std::shared_ptr<NptIsoParameters>
nptiso;
368 void update_local_geo();
369#ifdef ESPRESSO_ELECTROSTATICS
370 void update_icc_particles();
371 bool has_icc_enabled()
const;
373#ifdef ESPRESSO_THERMAL_STONER_WOHLFARTH
374 void integrate_magnetodynamics();
382 void integrator_sanity_checks()
const;
Particle data communication manager for the GPU.