40#ifndef MADNESS_CHEM_CALCULATIONPARAMETERS_H__INCLUDED
41#define MADNESS_CHEM_CALCULATIONPARAMETERS_H__INCLUDED
67 initialize<std::string> (
"hfexalg",
"multiworld",
"hf exchange algorithm: choose from multiworld (default), smallmem, largemem");
79 initialize<int> (
"nopen",0,
"number of unpaired electrons = nalpha-nbeta");
83 initialize<int> (
"plotlo",0,
"range of MOs to print (for both spins if polarized");
84 initialize<int> (
"plothi",-1,
"range of MOs to print (for both spins if polarized");
85 initialize<bool> (
"plotdens",
false,
"If true print the density at convergence");
86 initialize<bool> (
"plotcoul",
false,
"If true plot the total coulomb potential at convergence");
88 initialize<std::string> (
"pointgroup",
"c1",
"use point (sub) group symmetry if not localized",{
"c1",
"c2",
"ci",
"cs",
"c2v",
"c2h",
"d2",
"d2h"});
90 initialize<bool> (
"restartao",
false,
"if true restart from orbitals projected into AO basis (STO3G) on disk");
91 initialize<bool> (
"no_compute",
false,
"if true use orbitals on disk, set value to computed");
93 initialize<int> (
"maxsub",10,
"size of iterative subspace ... set to 0 or 1 to disable");
94 initialize<double> (
"orbitalshift",0.0,
"scf orbital shift: shift the occ orbitals to lower energies");
95 initialize<int> (
"npt_plot",101,
"no. of points to use in each dim for plots");
98 initialize<std::string> (
"aobasis",
"6-31g",
"AO basis used for initial guess (6-31gss, 6-31g, 3-21g, sto-6g, sto-3g)");
99 initialize<bool> (
"derivatives",
false,
"if true calculate nuclear derivatives");
101 initialize<bool> (
"conv_only_dens",
false,
"if true remove bsh_residual from convergence criteria (deprecated)");
102 initialize<bool> (
"psp_calc",
false,
"pseudopotential calculation for all atoms");
104 initialize<std::string> (
"ac_data",
"none",
"do a calculation with asymptotic correction (see ACParameters class in chem/AC.h for details)");
105 initialize<bool> (
"pure_ae",
true,
"pure all electron calculation with no pseudo-atoms");
106 initialize<int> (
"print_level",3,
"0: no output; 1: final energy; 2: iterations; 3: timings; 10: debug");
107 initialize<std::string> (
"molecular_structure",
"inputfile",
"where to read the molecule from: inputfile or name from the library");
112 initialize<int> (
"nmo_alpha",-1,
"number of alpha spin molecular orbitals");
113 initialize<int> (
"nmo_beta",-1,
"number of beta spin molecular orbitals");
125 initialize<bool> (
"ginitial_hessian",
false,
"compute inital hessian for optimization");
127 initialize<int> (
"nv_factor",1,
"factor to multiply number of virtual orbitals with when automatically decreasing nvirt");
128 initialize<int> (
"vnucextra",2,
"load balance parameter for nuclear pot");
132 initialize<std::string> (
"nwfile",
"none",
"Base name of nwchem output files (.out and .movecs extensions) to read from");
247 for (
size_t iatom = 0; iatom <
molecule.natom(); iatom++) {
248 if (
molecule.get_pseudo_atom(iatom)){
266 double z =
molecule.total_nuclear_charge();
308 error(
"\n\nsymmetry and localization cannot be used at the same time\n"
309 "switch from local to canonical orbitals (keyword canon)\n\n");
313 if (
get<bool>(
"gopt") &&
nwfile() !=
"none")
error(
"NWchem initialization only supports single point energy calculations.");
Contracted Gaussian basis.
Definition madness/chem/molecularbasis.h:465
Definition molecule.h:124
class for holding the parameters for calculation
Definition QCCalculationParametersBase.h:290
virtual void read_input_and_commandline_options(World &world, const commandlineparser &parser, const std::string tag)
Definition QCCalculationParametersBase.h:325
void set_user_defined_value(const std::string &key, const T &value)
Definition QCCalculationParametersBase.h:533
void set_derived_value(const std::string &key, const T &value)
Definition QCCalculationParametersBase.h:403
A tensor is a multidimensional array.
Definition tensor.h:317
A parallel world class.
Definition world.h:132
Namespace for all elements and tools of MADNESS.
Definition DFParameters.h:10
void error(const char *msg)
Definition world.cc:139
static XNonlinearSolver< std::vector< Function< T, NDIM > >, T, vector_function_allocator< T, NDIM > > nonlinear_vector_solver(World &world, const long nvec)
Definition nonlinsol.h:284
Definition CalculationParameters.h:51
double gval() const
Definition CalculationParameters.h:222
bool converge_each_energy() const
Definition CalculationParameters.h:156
std::vector< double > protocol() const
Definition CalculationParameters.h:202
double charge() const
Definition CalculationParameters.h:187
void set_derived_values(const Molecule &molecule, const AtomicBasisSet &aobasis, const commandlineparser &parser)
Definition CalculationParameters.h:242
CalculationParameters(const CalculationParameters &other)=default
bool converge_density() const
Definition CalculationParameters.h:144
virtual void read_input_and_commandline_options(World &world, const commandlineparser &parser, const std::string tag)
Definition QCCalculationParametersBase.h:325
int nv_factor() const
Definition CalculationParameters.h:167
bool do_symmetry() const
Definition CalculationParameters.h:186
bool localize_pm() const
Definition CalculationParameters.h:183
bool gopt() const
Definition CalculationParameters.h:218
int k() const
Definition CalculationParameters.h:179
bool converge_bsh_residual() const
Definition CalculationParameters.h:148
CalculationParameters()
ctor reading out the input file
Definition CalculationParameters.h:62
bool converge_total_energy() const
Definition CalculationParameters.h:152
Tensor< double > plot_cell() const
Definition CalculationParameters.h:228
std::string nwfile() const
Definition CalculationParameters.h:226
std::string prefix() const
Definition CalculationParameters.h:139
std::string ac_data() const
Definition CalculationParameters.h:196
int nmo_alpha() const
Definition CalculationParameters.h:169
int nopen() const
Definition CalculationParameters.h:161
bool dipole() const
Definition CalculationParameters.h:216
bool save() const
Definition CalculationParameters.h:203
double dconv() const
Definition CalculationParameters.h:142
std::string algopt() const
Definition CalculationParameters.h:219
double econv() const
Definition CalculationParameters.h:141
int nvalpha() const
Definition CalculationParameters.h:165
int vnucextra() const
Definition CalculationParameters.h:211
int print_level() const
Definition CalculationParameters.h:188
std::string deriv() const
Definition CalculationParameters.h:193
bool do_localize() const
Definition CalculationParameters.h:182
std::string hfexalg() const
Definition CalculationParameters.h:198
double L() const
Definition CalculationParameters.h:178
int gmaxiter() const
Definition CalculationParameters.h:220
std::string localize_method() const
Definition CalculationParameters.h:181
bool ginitial_hessian() const
Definition CalculationParameters.h:224
int loadbalparts() const
Definition CalculationParameters.h:212
std::string aobasis() const
Definition CalculationParameters.h:200
int nalpha() const
Definition CalculationParameters.h:162
std::string dft_deriv() const
Definition CalculationParameters.h:194
int maxsub() const
Definition CalculationParameters.h:208
int nvbeta() const
Definition CalculationParameters.h:166
double gprec() const
Definition CalculationParameters.h:223
bool derivatives() const
Definition CalculationParameters.h:215
int nbeta() const
Definition CalculationParameters.h:163
int nmo_beta() const
Definition CalculationParameters.h:170
double gtol() const
Definition CalculationParameters.h:221
bool have_beta() const
Definition CalculationParameters.h:172
bool no_compute() const
Definition CalculationParameters.h:175
bool spin_restricted() const
Definition CalculationParameters.h:174
int maxiter() const
Definition CalculationParameters.h:190
double orbitalshift() const
Definition CalculationParameters.h:191
double lo() const
Definition CalculationParameters.h:177
std::string pcm_data() const
Definition CalculationParameters.h:195
bool restart() const
Definition CalculationParameters.h:204
bool restart_cphf() const
Definition CalculationParameters.h:206
bool restartao() const
Definition CalculationParameters.h:205
std::string pointgroup() const
Definition CalculationParameters.h:185
double maxrotn() const
Definition CalculationParameters.h:209
std::string xc() const
Definition CalculationParameters.h:197
CalculationParameters(World &world, const commandlineparser &parser)
Definition CalculationParameters.h:55
very simple command line parser
Definition commandlineparser.h:15
std::string value(const std::string key) const
Definition commandlineparser.h:59
bool key_exists(std::string key) const
Definition commandlineparser.h:55
static std::string base_name(std::string const &path, std::string const &delims="/")
Definition commandlineparser.h:129
static std::string remove_extension(std::string const &filename)
Definition commandlineparser.h:134
void e()
Definition test_sig.cc:75
static Molecule molecule
Definition testperiodicdft.cc:39