ergo
|
Representation of a molecule as a set of nuclei and total charge. More...
#include <molecule.h>
Public Member Functions | |
Molecule () | |
void | addAtom (ergo_real c, ergo_real x, ergo_real y, ergo_real z) |
void | clear () |
void | setNetCharge (ergo_real netCharge_) |
void | replaceAtom (int i, const Atom &atom) |
void | setAtomList (const std::vector< Atom > atomList) |
const Atom * | getAtomListPtr () const |
const Atom & | getAtom (int i) const |
int | getNoOfAtoms () const |
ergo_real | getNetCharge () const |
void | getExtremeInternuclearDistances (ergo_real &minDist, ergo_real &maxDist) const |
Compute smallest and largest internuclear distances. More... | |
ergo_real | getNuclearRepulsionEnergy () const |
Compute nuclear repulsion energy. More... | |
ergo_real | getNuclearElectricFieldEnergy (const Vector3D &electricField) const |
Compute nuclear energy in given electric field. More... | |
int | getNumberOfElectrons () const |
Compute total number of electrons. More... | |
int | setFromMoleculeFile (const char *fileName, int netCharge, char **basissetFile) |
Loads molecule from a given file name, assuming given net charge. More... | |
Private Attributes | |
std::vector< Atom > | atoms |
ergo_real | netCharge |
int | noOfAtoms |
Representation of a molecule as a set of nuclei and total charge.
It provides I/O methods and basic manipulation routines.
|
inline |
References noOfAtoms.
Referenced by es_add_atom(), main(), readMoleculeFileInMolFormat(), readMoleculeFileInXyzFormat(), and test_small().
|
inline |
Referenced by es_mol_begin().
|
inline |
Referenced by compute_dipole_moment_onecoord(), SCF_restricted::compute_gradient_fixeddens(), compute_h_core_matrix_sparse(), compute_V_linear(), compute_V_sparse(), SCF_restricted::create_gabedit_file(), do_density_images(), do_mulliken_atomic_charges(), SCF_unrestricted::do_spin_flip(), do_tdhf_dynamics(), es_run(), get_mulliken_charges(), ErgoMolInfo::getAtom(), ErgoMolInfo::getExps(), getSafeMaxDistance(), main(), and write_gcube_file_header().
|
inline |
Compute smallest and largest internuclear distances.
References A, atoms, B, get_distance_between_atoms(), and noOfAtoms.
Referenced by SCF_general::SCF_general().
|
inline |
References noOfAtoms.
Referenced by BasisInfoStruct::addBasisfuncsForMolecule(), compute_dipole_moment_onecoord(), SCF_restricted::compute_gradient_fixeddens(), compute_h_core_matrix_simple_dense(), compute_h_core_matrix_sparse(), compute_V_linear(), compute_V_sparse(), SCF_restricted::create_gabedit_file(), do_density_images(), do_mulliken_atomic_charges(), do_mulliken_spin_densities(), SCF_unrestricted::do_spin_flip(), do_tdhf_dynamics(), es_mol_commit(), es_run(), get_mulliken_charges(), ErgoMolInfo::getExps(), getSafeMaxDistance(), main(), readMoleculeFileInMolFormat(), readMoleculeFileInXyzFormat(), savePotential(), SCF_general::SCF_general(), and write_gcube_file_header().
Compute nuclear energy in given electric field.
References A, atoms, Atom::charge, Atom::coords, do_output(), LOG_AREA_MAIN, LOG_CAT_INFO, noOfAtoms, and Vector3D::v.
Referenced by SCF_general::do_SCF_iterations().
ergo_real Molecule::getNuclearRepulsionEnergy | ( | ) | const |
Compute nuclear repulsion energy.
References A, atoms, B, Atom::charge, do_output(), get_distance_between_atoms(), LOG_AREA_MAIN, LOG_CAT_INFO, and noOfAtoms.
Referenced by SCF_general::do_SCF_iterations(), and get_nucl_energy_for_given_mol_and_dens().
int Molecule::getNumberOfElectrons | ( | ) | const |
Compute total number of electrons.
The result is sum of atomic charges plus netCharge.
References atoms, charge, netCharge, and noOfAtoms.
Referenced by calculation_shared(), dft_get_uxc_mt(), dft_get_xc(), dft_get_xc_mt(), dft_lin_resp_mt(), dft_lin_respao(), es_get_polarisability(), es_getexc(), es_run(), SCF_general::SCF_general(), and test_mol().
|
inline |
Referenced by SCF_restricted::compute_gradient_fixeddens(), and es_run().
|
inline |
int Molecule::setFromMoleculeFile | ( | const char * | fileName, |
int | netCharge, | ||
char ** | basissetFile | ||
) |
Loads molecule from a given file name, assuming given net charge.
basissetFile will be set if the file contains basis set and basissetFile is NULL.
References readMoleculeFileInMolFormat(), and readMoleculeFileInXyzFormat().
Referenced by es_mol_read_molecule(), main(), mol_calculation(), and test_mol().
|
inline |
Referenced by es_run(), readMoleculeFileInMolFormat(), and readMoleculeFileInXyzFormat().
|
private |
|
private |
Referenced by getNetCharge(), and getNumberOfElectrons().
|
private |