32#ifndef MADNESS_CHEM_MOLECULE_H__INCLUDED
33#define MADNESS_CHEM_MOLECULE_H__INCLUDED
99 return ((err<
thresh) &&
q == other.
q &&
111 template <
typename Archive>
132 static constexpr char const *
tag =
"molecule";
149 }
catch (std::exception &
e) {
164 initialize<std::string>(
"source_type",
"inputfile",
"where to get the coordinates from", {
"inputfile",
"xyz",
"library"});
165 initialize<std::string>(
"source_name",
"TBD",
"name of the geometry from the library or the input file");
166 initialize<double>(
"eprec", 1.e-4,
"smoothing for the nuclear potential");
167 initialize<std::string>(
"units",
"atomic",
"coordinate units", {
"atomic",
"angstrom",
"bohr",
"au"});
168 initialize<std::vector<double>>(
"field", {0.0, 0.0, 0.0},
"external electric field");
169 initialize<bool>(
"no_orient",
false,
170 "if true the molecule coordinates will not be "
171 "reoriented and/or symmetrized");
172 initialize<double>(
"symtol", -1.e-2,
173 "distance threshold for determining the "
174 "symmetry-equivalent atoms; negative: old algorithm");
176 initialize<std::string>(
"core_type",
"none",
"core potential type", {
"none",
"mcp"});
177 initialize<bool>(
"psp_calc",
false,
"pseudopotential calculation for all atoms");
178 initialize<bool>(
"pure_ae",
true,
"pure all electron calculation with no pseudo-atoms");
190 parser.
value(
"input"));
198 bool found_geometry_file =
f.good();
202 bool geometry_found_in_library =
true;
207 geometry_found_in_library =
false;
210 if (found_geometry_file and geometry_found_in_library) {
213 "geometry specification ambiguous: found geometry in "
214 "the structure library and in a file\n");
218 "\nPlease specify the location of your geometry input "
219 "by one of the two lines:\n");
250 std::string
source_type()
const {
return get<std::string>(
"source_type"); }
251 std::string
source_name()
const {
return get<std::string>(
"source_name"); }
252 std::vector<double>
field()
const {
return get<std::vector<double>>(
"field"); }
253 double eprec()
const {
return get<double>(
"eprec"); }
254 std::string
units()
const {
return get<std::string>(
"units"); }
255 std::string
core_type()
const {
return get<std::string>(
"core_type"); }
256 bool psp_calc()
const {
return get<bool>(
"psp_calc"); }
257 bool pure_ae()
const {
return get<bool>(
"pure_ae"); }
258 bool no_orient()
const {
return get<bool>(
"no_orient"); }
259 double symtol()
const {
return get<double>(
"symtol"); }
262 if (
name == parser.
value(
"input"))
return "inputfile";
263 std::size_t pos =
name.find(
".xyz");
264 if (pos != std::string::npos)
return "xyz";
290 template <
typename opT>
293 template <
typename opT>
296 template <
typename opT>
299 bool test_for_c2(
double xaxis,
double yaxis,
double zaxis,
const double symtol)
const;
301 bool test_for_sigma(
double xaxis,
double yaxis,
double zaxis,
const double symtol)
const;
369 std::vector<std::string>
cubefile_header(
const Vector<double, 3>
offset = Vector<double, 3>(0.0))
const;
375 void read(std::istream &
f);
398 double core_eval(
int atom,
unsigned int core,
int m,
double x,
double y,
double z)
const;
400 double core_derivative(
int atom,
int axis,
unsigned int core,
int m,
double x,
double y,
double z)
const;
406 void add_atom(
double x,
double y,
double z,
double q,
int atn);
408 void add_atom(
double x,
double y,
double z,
double q,
int atn,
bool psat);
519 for (
size_t i = 0; i <
natom(); i++) {
520 const double sqrtmass = 1.0 / sqrt(
get_atom(i).get_mass_in_au());
521 M(3 * i, 3 * i) = sqrtmass;
522 M(3 * i + 1, 3 * i + 1) = sqrtmass;
523 M(3 * i + 2, 3 * i + 2) = sqrtmass;
530 void orient(
bool verbose =
false);
550 for (
size_t i = 0; i <
atoms.size(); ++i) {
551 if (not (
atoms[i] == other.
atoms[i]))
return false;
553 for (
size_t i = 0; i <
rcut.size(); ++i) {
554 if (
rcut[i] != other.
rcut[i])
return false;
560 template <
typename Archive>
double q(double t)
Definition DKops.h:18
Declaration of utility class and functions for atom.
Atom(double x, double y, double z, double q, unsigned int atomic_number)
Definition molecule.h:78
double y
Definition molecule.h:62
unsigned int atomic_number
Atomic number.
Definition molecule.h:63
int get_atomic_number() const
Definition molecule.h:104
Atom(double x, double y, double z, double q, unsigned int atomic_number, bool pseudo_atom)
Definition molecule.h:67
double x
Definition molecule.h:62
double z
Definition molecule.h:62
Atom(const Atom &a)
Definition molecule.h:90
bool operator==(const Atom &other) const
Definition molecule.h:95
madness::Vector< double, 3 > get_coords() const
Definition molecule.h:106
Atom()
Default construct makes a zero charge ghost atom at origin.
Definition molecule.h:93
double mass
Mass.
Definition molecule.h:64
double q
Coordinates and charge in atomic units.
Definition molecule.h:62
void serialize(Archive &ar)
Definition molecule.h:112
double get_mass_in_au() const
return the mass in atomic units (electron mass = 1 a.u.)
Definition molecule.h:109
hashT hash() const
Definition molecule.h:115
bool pseudo_atom
Indicates if this atom uses a pseudopotential.
Definition molecule.h:65
Definition corepotential.h:148
unsigned int n_core_orb_base(const unsigned int atn) const
Definition corepotential.h:173
std::string guess_file() const
Definition corepotential.h:177
bool is_defined(const unsigned int atn) const
Definition corepotential.h:165
unsigned int get_core_l(unsigned int atn, unsigned int core) const
Definition corepotential.h:187
void set_eprec(double value)
Definition corepotential.cc:369
void set_rcut(double value)
Definition corepotential.cc:379
double get_core_bc(unsigned int atn, unsigned int core) const
Definition corepotential.h:191
Definition molecule.h:129
void read_structure_from_library(const std::string &name)
Definition molecule.cc:228
std::vector< madness::Vector< double, 3 > > get_all_coords_vec() const
Definition molecule.cc:413
static std::string get_structure_library_path()
Definition molecule.cc:201
std::vector< double > get_rcut() const
Definition molecule.h:436
void read_core_file(const std::string &filename)
Definition molecule.cc:1194
double bounding_cube() const
Returns the half width of the bounding cube.
Definition molecule.cc:999
std::vector< double > atomic_radii
Definition molecule.h:428
void symmetrize_for_op(opT op, const double symtol)
Definition molecule.cc:739
void update_rcut_with_eprec(double value)
updates rcuts with given eprec
Definition molecule.cc:434
Tensor< double > nuclear_dipole_derivative(const int atom, const int axis) const
compute the derivative of the nuclear dipole wrt a nuclear displacement
Definition molecule.cc:579
void set_all_coords(const madness::Tensor< double > &newcoords)
Definition molecule.cc:424
std::string guess_file() const
Definition molecule.h:383
double smallest_length_scale() const
Definition molecule.cc:679
double get_core_bc(unsigned int atn, unsigned int c) const
Definition molecule.h:396
double atomic_attraction_potential(int iatom, double x, double y, double z) const
nuclear attraction potential for a specific atom in the molecule
Definition molecule.cc:1041
double total_nuclear_charge() const
Definition molecule.cc:1009
double nuclear_dipole(int axis) const
compute the dipole moment of the nuclei
Definition molecule.cc:558
const std::vector< Atom > & get_atoms() const
Definition molecule.h:448
std::vector< Atom > atoms
Definition molecule.h:271
void translate(const Tensor< double > &translation)
translate the molecule
Definition molecule.cc:708
void center()
Moves the center of nuclear charge to the origin.
Definition molecule.cc:689
const Atom & get_atom(unsigned int i) const
Definition molecule.cc:452
bool operator==(const Molecule &other) const
Definition molecule.h:548
madness::Tensor< double > get_all_coords() const
Definition molecule.cc:402
void orient(bool verbose=false)
Centers and orients the molecule in a standard manner.
Definition molecule.cc:907
unsigned int get_atom_charge(unsigned int i) const
Definition molecule.cc:375
double core_derivative(int atom, int axis, unsigned int core, int m, double x, double y, double z) const
Definition molecule.cc:1151
int find_symmetry_equivalent_atom(int iatom, opT op, const double symtol) const
Definition molecule.cc:728
double molecular_core_potential(double x, double y, double z) const
Definition molecule.cc:1164
std::vector< std::string > cubefile_header(const Vector< double, 3 > offset=Vector< double, 3 >(0.0)) const
print out a Gaussian cubefile header
Definition molecule.cc:241
std::string get_pointgroup() const
Definition molecule.h:285
bool get_pseudo_atom(unsigned int i) const
Definition molecule.cc:390
double nuclear_attraction_potential(double x, double y, double z) const
nuclear attraction potential for the whole molecule
Definition molecule.cc:1017
std::string symmetrize_and_identify_point_group(const double symtol)
Definition molecule.cc:795
void read_file(const std::string &filename)
Definition molecule.cc:256
Tensor< double > center_of_mass() const
compute the center of mass
Definition molecule.cc:877
std::string pointgroup_
Definition molecule.h:278
hashT hash() const
Definition molecule.h:565
void fix_phase()
rotates the molecule and the external field
Definition molecule.cc:953
static std::istream & position_stream_in_library(std::ifstream &f, const std::string &name)
Definition molecule.cc:207
void set_atom_coords(unsigned int i, double x, double y, double z)
Definition molecule.cc:395
json to_json_if_precedence(std::string const &precedence) const
Definition molecule.h:133
double inter_atomic_distance(unsigned int i, unsigned int j) const
Definition molecule.cc:530
bool test_for_inverse(const double symtol) const
Definition molecule.cc:778
size_t natom() const
Definition molecule.h:410
double core_eval(int atom, unsigned int core, int m, double x, double y, double z) const
Definition molecule.cc:1142
void print() const
Definition molecule.cc:510
double nuclear_repulsion_derivative(size_t iatom, int axis) const
Definition molecule.cc:586
std::vector< double > rcut
Definition molecule.h:272
void set_rcut(double value)
Definition molecule.cc:446
void set_core_rcut(double value)
Definition molecule.h:440
void set_core_eprec(double value)
Definition molecule.h:438
bool is_potential_defined(unsigned int atn) const
Definition molecule.h:402
double nuclear_attraction_potential_second_derivative(int atom, int iaxis, int jaxis, double x, double y, double z) const
the second derivative of the (smoothed) nuclear potential Z/r
Definition molecule.cc:1085
void serialize(Archive &ar)
Definition molecule.h:561
double nuclear_repulsion_energy() const
Definition molecule.cc:537
unsigned int get_atomic_number(unsigned int i) const
Definition molecule.cc:380
void swapaxes(int ix, int iy)
Definition molecule.cc:782
static constexpr char const * tag
Definition molecule.h:132
static void print_parameters()
Definition molecule.cc:115
json to_json() const
Definition molecule.cc:462
unsigned int get_core_l(unsigned int atn, unsigned int c) const
Definition molecule.h:394
Tensor< double > nuclear_repulsion_hessian() const
return the hessian matrix of the second derivatives d^2/dxdy V
Definition molecule.cc:606
void add_atom(double x, double y, double z, double q, int atn)
Definition molecule.cc:351
Tensor< double > moment_of_inertia() const
Definition molecule.cc:893
Molecule()
Makes a molecule with zero atoms.
Definition molecule.h:350
double nuclear_charge_density(double x, double y, double z, double rscale=1.) const
Definition molecule.cc:1113
void set_atom_charge(unsigned int i, double zeff)
Definition molecule.cc:370
double get_eprec() const
Definition molecule.h:442
double nuclear_repulsion_second_derivative(int iatom, int jatom, int iaxis, int jaxis) const
compute the nuclear-nuclear contribution to the second derivatives
Definition molecule.cc:630
GeometryParameters parameters
Definition molecule.h:281
void from_json(const json &mol_json)
Definition molecule.cc:483
unsigned int n_core_orb(unsigned int atn) const
Definition molecule.h:387
madness::Tensor< double > field
Definition molecule.h:274
unsigned int n_core_orb_all() const
Definition molecule.cc:1130
void set_pseudo_atom(unsigned int i, bool psat)
Definition molecule.cc:385
void insert_symbols_and_geometry(json &mol_json) const
Definition molecule.cc:473
CorePotentialManager core_pot
Definition molecule.h:273
Tensor< double > massweights() const
compute the mass-weighting matrix for the hessian
Definition molecule.h:517
void get_structure()
Definition molecule.cc:134
bool test_for_c2(double xaxis, double yaxis, double zaxis, const double symtol) const
Definition molecule.cc:770
double core_potential_derivative(int atom, int axis, double x, double y, double z) const
Definition molecule.cc:1179
void read_xyz(const std::string filename)
Definition molecule.cc:306
bool test_for_op(opT op, const double symtol) const
Definition molecule.cc:718
double nuclear_attraction_potential_derivative(int atom, int axis, double x, double y, double z) const
Definition molecule.cc:1054
bool is_potential_defined_atom(int i) const
Definition molecule.h:404
void read(std::istream &f)
Definition molecule.cc:265
bool test_for_sigma(double xaxis, double yaxis, double zaxis, const double symtol) const
Definition molecule.cc:774
void rotate(const Tensor< double > &D)
Definition molecule.cc:982
class for holding the parameters for calculation
Definition QCCalculationParametersBase.h:294
virtual void read_input_and_commandline_options(World &world, const commandlineparser &parser, const std::string tag)
Definition QCCalculationParametersBase.h:328
bool throw_if_datagroup_not_found
Definition QCCalculationParametersBase.h:365
void set_user_defined_value(const std::string &key, const T &value)
Definition QCCalculationParametersBase.h:524
bool ignore_unknown_keys
Definition QCCalculationParametersBase.h:363
bool ignore_unknown_keys_silently
Definition QCCalculationParametersBase.h:364
bool is_user_defined(std::string key) const
Definition QCCalculationParametersBase.h:311
json to_json_if_precedence(const std::string &precedence) const
convert all parameters to a json object, but only those with a given precedence
Definition QCCalculationParametersBase.h:507
void set_derived_value(const std::string &key, const T &value)
Definition QCCalculationParametersBase.h:406
A tensor is a multidimensional array.
Definition tensor.h:317
A simple, fixed dimension vector.
Definition vector.h:64
A parallel world class.
Definition world.h:132
Declaration of core potential related class.
static const double eprec
Definition hatom_sf_dirac.cc:18
Tensor< double > op(const Tensor< double > &x)
Definition kain.cc:508
#define MADNESS_EXCEPTION(msg, value)
Macro for throwing a MADNESS exception.
Definition madness_exception.h:119
Header to declare stuff which has not yet found a home.
constexpr double atomic_mass_in_au
Atomic mass in atomic units.
Definition constants.h:270
Namespace for all elements and tools of MADNESS.
Definition DFParameters.h:10
std::ostream & operator<<(std::ostream &os, const particle< PDIM > &p)
Definition lowrankfunction.h:397
void hash_range(hashT &seed, It first, It last)
Definition worldhash.h:280
static const char * filename
Definition legendre.cc:96
nlohmann::json json
Definition QCCalculationParametersBase.h:28
void hash_combine(hashT &seed, const T &v)
Combine hash values.
Definition worldhash.h:260
Key< NDIM > displacement(const Key< NDIM > &source, const Key< NDIM > &target)
given a source and a target, return the displacement in translation
Definition key.h:451
const AtomicData & get_atomic_data(unsigned int atomic_number)
Definition atomutil.cc:167
void print(const T &t, const Ts &... ts)
Print items to std::cout (items separated by spaces) and terminate with a new line.
Definition print.h:225
NDIM & f
Definition mra.h:2481
std::size_t hashT
The hash value type.
Definition worldhash.h:145
std::string name(const FuncType &type, const int ex=-1)
Definition ccpairfunction.h:28
madness::hashT hash_value(const std::array< T, N > &a)
Hash std::array with madness hash.
Definition array_addons.h:78
static const double a
Definition nonlinschro.cc:118
static const double c
Definition relops.cc:10
static const double m
Definition relops.cc:9
static const double thresh
Definition rk.cc:45
Definition test_ar.cc:204
const double mass
the atomic mass
Definition atomutil.h:64
Definition molecule.h:140
bool psp_calc() const
Definition molecule.h:256
std::string source_name() const
Definition molecule.h:251
std::string core_type() const
Definition molecule.h:255
void set_global_convenience_options(const commandlineparser &parser)
Definition molecule.h:181
double symtol() const
Definition molecule.h:259
bool no_orient() const
Definition molecule.h:258
static std::string derive_source_type_from_name(const std::string name, const commandlineparser &parser)
Definition molecule.h:261
bool pure_ae() const
Definition molecule.h:257
GeometryParameters(const GeometryParameters &other)=default
GeometryParameters()
Definition molecule.h:156
GeometryParameters(World &world, const commandlineparser &parser)
Definition molecule.h:143
std::string units() const
Definition molecule.h:254
std::vector< double > field() const
Definition molecule.h:252
double eprec() const
Definition molecule.h:253
std::string source_type() const
Definition molecule.h:250
void set_derived_values(const commandlineparser &parser)
Definition molecule.h:187
Definition molecule.h:307
double yaxis
Definition molecule.h:308
void operator()(double &x, double &y, double &z) const
Definition molecule.h:310
double xaxis
Definition molecule.h:308
apply_c2(double xaxis, double yaxis, double zaxis)
Definition molecule.h:309
double zaxis
Definition molecule.h:308
Definition molecule.h:338
double yaxis
Definition molecule.h:339
void operator()(double &x, double &y, double &z) const
Definition molecule.h:341
double zaxis
Definition molecule.h:339
apply_inverse(double xaxis, double yaxis, double zaxis)
Definition molecule.h:340
double xaxis
Definition molecule.h:339
Definition molecule.h:323
void operator()(double &x, double &y, double &z) const
Definition molecule.h:326
apply_sigma(double xaxis, double yaxis, double zaxis)
Definition molecule.h:325
double xaxis
Definition molecule.h:324
double yaxis
Definition molecule.h:324
double zaxis
Definition molecule.h:324
very simple command line parser
Definition commandlineparser.h:15
std::string value(const std::string key) const
Definition commandlineparser.h:62
bool key_exists(std::string key) const
Definition commandlineparser.h:58
Defines and implements most of Tensor.
void e()
Definition test_sig.cc:75
const double offset
Definition testfuns.cc:143
double h(const coord_1d &r)
Definition testgconv.cc:175
std::size_t axis
Definition testpdiff.cc:59
Implement the madness:Vector class, an extension of std::array that supports some mathematical operat...