MPQC  3.0.0-alpha

RefWavefunction specialization for a single-determinant wave function. More...

#include <chemistry/qc/nbody/ref.h>

Inheritance diagram for sc::SD_RefWavefunction:
sc::RefWavefunction sc::SavableState sc::DescribedClass sc::RefCount

Public Member Functions

 SD_RefWavefunction (const Ref< KeyVal > &kv)
 A KeyVal constructor is used to generate a SD_RefWavefunction object from a KeyVal object. More...
 
 SD_RefWavefunction (const Ref< WavefunctionWorld > &world, const Ref< OneBodyWavefunction > &obwfn, bool spin_restricted=true, unsigned int nfzc=0, unsigned int nfzv=0, Ref< OrbitalSpace > vir_space=0, std::string occ_orbs=std::string("canonical"))
 construct from a OneBodyWavefunction object More...
 
 SD_RefWavefunction (StateIn &)
 
void save_data_state (StateOut &)
 Save the base classes (with save_data_state) and the members in the same order that the StateIn CTOR initializes them. More...
 
void print (std::ostream &os=ExEnv::out0()) const
 Print the object.
 
void purge ()
 purges the data from this object More...
 
bool sdref () const
 is this a single-determinantal reference?
 
const Ref< OneBodyWavefunction > & obwfn () const
 
const Ref< OrbitalSpace > & vir_space () const
 
const Ref< GaussianBasisSet > & uocc_basis () const
 returns the basis supporting unoccupied orbitals. The defauls is same as returned by basis().
 
double energy ()
 
double actual_value_accuracy () const
 Return the accuracy with which the value has been computed. More...
 
double desired_value_accuracy () const
 
bool desired_value_accuracy_set_to_default () const
 
int nelectron () const
 
double magnetic_moment () const
 
bool spin_restricted () const
 
int dk () const
 
Ref< GaussianBasisSetmomentum_basis () const
 
RefSymmSCMatrix core_hamiltonian_for_basis (const Ref< GaussianBasisSet > &basis, const Ref< GaussianBasisSet > &p_basis)
 Returns the SO core Hamiltonian in the given basis and momentum basis. More...
 
unsigned int nfzc () const
 
unsigned int nfzv () const
 
RefSymmSCMatrix ordm (SpinCase1 spin) const
 return the AO basis density
 
Ref< DensityFittingInfodfinfo () const
 which DensityFittingRuntime used to compute this reference wave function
 
const std::string & occ_orbitals () const
 
- Public Member Functions inherited from sc::RefWavefunction
virtual void obsolete ()
 obsoletes this object More...
 
const Ref< WavefunctionWorld > & world () const
 
const Ref< GaussianBasisSet > & basis () const
 
const Ref< Integral > & integral () const
 
const Ref< OrbitalSpace > & valence_orbs () const
 This OrbitalSpace defines valence orbitals. More...
 
void set_desired_value_accuracy (double)
 Set the accuracy to which the value is to be computed. More...
 
bool spin_polarized () const
 
virtual RefSymmSCMatrix ordm_orbs_sb (SpinCase1 spin) const
 return the density in the orbs_sb() space
 
virtual RefSymmSCMatrix ordm_occ_sb (SpinCase1 spin) const
 return the density in the occ_sb() space
 
const Ref< OrbitalSpace > & oso_space () const
 Returns the space of symmetry-blocked orthogonal SOs (spans the entire space of the basis)
 
const Ref< OrbitalSpace > & orbs_sb (SpinCase1 spin=AnySpinCase1) const
 Return the space of symmetry-blocked MOs of the given spin.
 
const Ref< OrbitalSpace > & orbs (SpinCase1 spin=AnySpinCase1) const
 Return the space of energy-sorted MOs of the given spin.
 
const Ref< OrbitalSpace > & occ_sb (SpinCase1 spin=AnySpinCase1) const
 Return the space of symmery-blocked occupied MOs of the given spin.
 
const Ref< OrbitalSpace > & occ_act_sb (SpinCase1 spin=AnySpinCase1) const
 Return the space of symmery-blocked active occupied MOs of the given spin.
 
const Ref< OrbitalSpace > & occ_frz_sb (SpinCase1 spin=AnySpinCase1) const
 Return the space of symmery-blocked frozen occupied MOs of the given spin.
 
const Ref< OrbitalSpace > & occ (SpinCase1 spin=AnySpinCase1) const
 Return the space of occupied MOs of the given spin.
 
const Ref< OrbitalSpace > & occ_act (SpinCase1 spin=AnySpinCase1) const
 Return the space of active occupied MOs of the given spin.
 
const Ref< OrbitalSpace > & occ_frz (SpinCase1 spin=AnySpinCase1) const
 Return the space of frozen occupied MOs of the given spin.
 
const Ref< OrbitalSpace > & uocc_sb (SpinCase1 spin=AnySpinCase1) const
 Return the space of symmetry-blocked unoccupied (virtual) MOs of the given spin.
 
const Ref< OrbitalSpace > & uocc_act_sb (SpinCase1 spin=AnySpinCase1) const
 Return the space of symmetry-blocked active unoccupied (virtual) MOs of the given spin.
 
const Ref< OrbitalSpace > & uocc (SpinCase1 spin=AnySpinCase1) const
 Return the space of unoccupied (virtual) MOs of the given spin.
 
const Ref< OrbitalSpace > & uocc_act (SpinCase1 spin=AnySpinCase1) const
 Return the space of active unoccupied (virtual) MOs of the given spin.
 
- Public Member Functions inherited from sc::SavableState
SavableStateoperator= (const SavableState &)
 
void save_state (StateOut &)
 Save the state of the object as specified by the StateOut object. More...
 
void save_object_state (StateOut &)
 This can be used for saving state when the exact type of the object is known for both the save and the restore. More...
 
virtual void save_vbase_state (StateOut &)
 Save the virtual bases for the object. More...
 
- Public Member Functions inherited from sc::DescribedClass
 DescribedClass (const DescribedClass &)
 
DescribedClassoperator= (const DescribedClass &)
 
ClassDescclass_desc () const MPQC__NOEXCEPT
 This returns the unique pointer to the ClassDesc corresponding to the given type_info object. More...
 
const char * class_name () const
 Return the name of the object's exact type.
 
int class_version () const
 Return the version of the class.
 
Ref< DescribedClassref ()
 Return this object wrapped up in a Ref smart pointer. More...
 
- Public Member Functions inherited from sc::RefCount
size_t identifier () const
 Return the unique identifier for this object that can be compared for different objects of different types. More...
 
int lock_ptr () const
 Lock this object.
 
int unlock_ptr () const
 Unlock this object.
 
void use_locks (bool inVal)
 start and stop using locks on this object
 
refcount_t nreference () const
 Return the reference count.
 
refcount_t reference ()
 Increment the reference count and return the new count.
 
refcount_t dereference ()
 Decrement the reference count and return the new count.
 
int managed () const
 
void unmanage ()
 Turn off the reference counting mechanism for this object. More...
 

Additional Inherited Members

- Static Public Member Functions inherited from sc::SavableState
static void save_state (SavableState *s, StateOut &)
 
static SavableStaterestore_state (StateIn &si)
 Restores objects saved with save_state. More...
 
static SavableStatekey_restore_state (StateIn &si, const char *keyword)
 Like restore_state, but keyword is used to override values while restoring.
 
static SavableStatedir_restore_state (StateIn &si, const char *objectname, const char *keyword=0)
 
- Protected Member Functions inherited from sc::RefWavefunction
bool use_world_dfinfo () const
 if true, override density fitting settings of RefWavefunction objects with those of WavefunctionWorld in which they live. More...
 
 RefWavefunction (const Ref< KeyVal > &kv)
 A KeyVal constructor is used to generate a RefWavefunction object from a KeyVal object. More...
 
 RefWavefunction (StateIn &)
 
 RefWavefunction (const Ref< WavefunctionWorld > &world, const Ref< GaussianBasisSet > &basis, const Ref< Integral > &integral, bool use_world_df=false)
 
void init () const
 initializes the object
 
virtual void reset ()
 calling this will cause the object to be re-initialized next time it is used
 
- Protected Member Functions inherited from sc::SavableState
 SavableState (const SavableState &)
 
 SavableState (StateIn &)
 Each derived class StateIn CTOR handles the restore corresponding to calling save_object_state, save_vbase_state, and save_data_state listed above. More...
 
- Protected Member Functions inherited from sc::RefCount
 RefCount (const RefCount &)
 
RefCountoperator= (const RefCount &)
 
- Protected Attributes inherited from sc::RefWavefunction
Ref< PopulatedOrbitalSpacespinspaces_ [NSpinCases1]
 
bool force_average_AB_rdm1_
 For spin-free algorithms, if this is true, we would set both alpha/beta 1-rdm to the average of them; defaults to false.
 

Detailed Description

RefWavefunction specialization for a single-determinant wave function.

Constructor & Destructor Documentation

◆ SD_RefWavefunction() [1/2]

sc::SD_RefWavefunction::SD_RefWavefunction ( const Ref< KeyVal > &  kv)

A KeyVal constructor is used to generate a SD_RefWavefunction object from a KeyVal object.

This constructor accepts all keywords of the KeyVal constructor of the RefWavefunction class, plus the additional keywords listed below.

KeywordTypeDefault

Description

obwfnOneBodyWavefunctionnone

the OneBodyWavefunction object adapted by this wave function. There is no default.

spin_restrictedbooleantrueIf false and obwfn is an open-shell spin-restricted OneBodyWavefunction (
See also
HSOSSCF), will use semicanonical orbitals. The value of this parameter will be ignored for closed-shell and spin-unrestricted open-shell references.
nfzcint0

specifies the total number of doubly-occupied orbitals that will be kept "frozen" in correlated calculations; this keyword is ignored if frozen_docc is given. The orbitals to be kept frozen will be those of the lowest energy in reference object.

nfzvint0

specifies the total number of non-occupied orbitals that will be kept "frozen" in correlated calculations; this keyword is ignored if frozen_uocc is given. The orbitals to be kept frozen will be those of the highest energy in reference object.

vir_basisGaussianBasisSetsee notes

The basis set that supports the unoccupied orbitals used for expressing the correlated wave function. The default is to use the basis used by obwfn.

occ_orbitalsstringcanonical

The method used to provide the occupied orbitals. This can be pipek-mezey or canonical (the default). This is to be used by experts only.

◆ SD_RefWavefunction() [2/2]

sc::SD_RefWavefunction::SD_RefWavefunction ( const Ref< WavefunctionWorld > &  world,
const Ref< OneBodyWavefunction > &  obwfn,
bool  spin_restricted = true,
unsigned int  nfzc = 0,
unsigned int  nfzv = 0,
Ref< OrbitalSpace vir_space = 0,
std::string  occ_orbs = std::string("canonical") 
)

construct from a OneBodyWavefunction object

Parameters
worldThe WavefunctionWorld in which this objects lives.
obwfnThe OneBodyWavefunction object that specifies the orbitals
spin_restrictedIf false and obwfn is an open-shell spin-restricted OneBodyWavefunction, will use semicanonical orbitals. The value of this parameter will be ignored for closed-shell and spin-unrestricted open-shell references.
nfzcThe number of lowest-energy occupied orbitals to be kept inactive
nfzvThe number of highest-energy unoccupied orbitals to be kept inactive
vir_spaceThe space describing the unoccupied orbitals. Default is 0, which means use unoccupied orbitals from obwfn.
occ_orbsThe method used to provide the occupied orbitals. This can be "pipek-mezey or "canonical".

N.B. This will feed the FockBuildRuntime in world with the density matrices from obwfn!

Member Function Documentation

◆ actual_value_accuracy()

double sc::SD_RefWavefunction::actual_value_accuracy ( ) const
inlinevirtual

Return the accuracy with which the value has been computed.

See also
Function::actual_value_accuracy()

Implements sc::RefWavefunction.

◆ core_hamiltonian_for_basis()

RefSymmSCMatrix sc::SD_RefWavefunction::core_hamiltonian_for_basis ( const Ref< GaussianBasisSet > &  basis,
const Ref< GaussianBasisSet > &  p_basis 
)
virtual

Returns the SO core Hamiltonian in the given basis and momentum basis.

The momentum basis is not needed if no Douglas-Kroll correction is being performed.

See also
Wavefunction::core_hamiltonian_for_basis()

Implements sc::RefWavefunction.

◆ desired_value_accuracy()

double sc::SD_RefWavefunction::desired_value_accuracy ( ) const
inlinevirtual
See also
Return the accuracy with which the value is to be computed.
Function::desired_value_accuracy()

Implements sc::RefWavefunction.

◆ desired_value_accuracy_set_to_default()

bool sc::SD_RefWavefunction::desired_value_accuracy_set_to_default ( ) const
inlinevirtual
See also
Return true if the accuracy was set to default.
Function::desired_value_accuracy_set_to_default()

Reimplemented from sc::RefWavefunction.

◆ dk()

int sc::SD_RefWavefunction::dk ( ) const
inlinevirtual

◆ energy()

double sc::SD_RefWavefunction::energy ( )
inlinevirtual

◆ magnetic_moment()

double sc::SD_RefWavefunction::magnetic_moment ( ) const
inlinevirtual

◆ momentum_basis()

Ref<GaussianBasisSet> sc::SD_RefWavefunction::momentum_basis ( ) const
inlinevirtual

◆ nelectron()

int sc::SD_RefWavefunction::nelectron ( ) const
inlinevirtual

◆ purge()

void sc::SD_RefWavefunction::purge ( )
virtual

purges the data from this object

See also
MolecularEnergy::purge()

Reimplemented from sc::RefWavefunction.

◆ save_data_state()

void sc::SD_RefWavefunction::save_data_state ( StateOut )
virtual

Save the base classes (with save_data_state) and the members in the same order that the StateIn CTOR initializes them.

This must be implemented by the derived class if the class has data.

Reimplemented from sc::RefWavefunction.


The documentation for this class was generated from the following file:

Generated at Sun Jan 26 2020 23:24:12 for MPQC 3.0.0-alpha using the documentation package Doxygen 1.8.16.