1 #ifndef MCMD_MD_EWALD_POTENTIAL_H 2 #define MCMD_MD_EWALD_POTENTIAL_H 11 #include <mcMd/potentials/coulomb/MdCoulombPotential.h> 12 #include <mcMd/potentials/coulomb/EwaldRSpaceAccumulator.h> 13 #include <mcMd/chemistry/AtomType.h> 15 #include <simp/interaction/coulomb/EwaldInteraction.h> 16 #include <simp/boundary/Boundary.h> 18 #include <util/space/IntVector.h> 19 #include <util/space/Vector.h> 20 #include <util/space/Tensor.h> 21 #include <util/containers/Pair.h> 22 #include <util/containers/GArray.h> 23 #include <util/misc/Setable.h> 24 #include <util/containers/Array.h> 34 typedef std::complex<double> DCMPLX;
72 virtual void readParameters(std::istream& in);
98 void set(std::string name,
double value);
105 double get(std::string name)
const;
114 virtual void makeWaves();
124 virtual void addForces();
129 virtual void computeEnergy();
134 virtual void computeStress();
141 {
return rSpaceAccumulator_; }
144 {
return ewaldInteraction_; }
166 double base0_, base1_, base2_;
167 double upper0_, upper1_, upper2_;
188 double kSpaceCutoff_;
193 void computeKSpaceCharge();
Coulomb potential for an Md simulation.
An orthorhombic periodic unit cell.
A set of interacting Molecules enclosed by a Boundary.
Array container class template.
Classes used by all simpatico molecular simulations.
The main object in a simulation, which coordinates others.
Saving / output archive for binary ostream.
Implementation of r-space and k-space Ewald Coulomb interactions.
Utility classes for scientific computation.
Utility class to store r-space Coulomb energy and stress.
Saving archive for binary istream.
Single-processor Monte Carlo (MC) and molecular dynamics (MD).
Ewald Coulomb potential class for MD simulations.