MPQC  3.0.0-alpha
sc::PsiRASCI_RefWavefunction Class Reference

RefWavefunction specialization for a general restricted-active-space multiconfiguration wave function. More...

#include <chemistry/qc/psi/psiref.h>

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

Public Member Functions

 PsiRASCI_RefWavefunction (const Ref< WavefunctionWorld > &world, const Ref< PsiRASCI > &wfn, bool spin_restricted=true, unsigned int nfzc=0, unsigned int nfzv=0, bool omit_uocc=false)
 construct from a PsiRASCI object More...
 
 PsiRASCI_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...
 
const Ref< PsiRASCI > & wfn () const
 
void print (std::ostream &os=ExEnv::out0()) const
 Print the object.
 
bool sdref () const
 is this a single-determinantal reference?
 
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
 
bool omit_uocc () const
 
RefSymmSCMatrix ordm (SpinCase1 spin) const
 return the AO basis density
 
Ref< DensityFittingInfodfinfo () const
 which DensityFittingRuntime used to compute this reference wave function
 
- Public Member Functions inherited from sc::RefWavefunction
virtual void obsolete ()
 obsoletes this object More...
 
virtual void purge ()
 purges the data from this object More...
 
const Ref< WavefunctionWorld > & world () const
 
const Ref< GaussianBasisSet > & basis () const
 
const Ref< Integral > & integral () const
 
virtual const Ref< GaussianBasisSet > & uocc_basis () const
 returns the basis supporting unoccupied orbitals. The defauls is same as returned by basis().
 
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 general restricted-active-space multiconfiguration wave function.

Constructor & Destructor Documentation

◆ PsiRASCI_RefWavefunction()

sc::PsiRASCI_RefWavefunction::PsiRASCI_RefWavefunction ( const Ref< WavefunctionWorld > &  world,
const Ref< PsiRASCI > &  wfn,
bool  spin_restricted = true,
unsigned int  nfzc = 0,
unsigned int  nfzv = 0,
bool  omit_uocc = false 
)

construct from a PsiRASCI object

Parameters
worldThe WavefunctionWorld in which this objects lives.
wfnThe PsiRASCI object that specifies the general CI wavefunction
spin_restrictedIf false and wfn is an open-shell wavefunction (wfn->spin_polarized() == true), will use semicanonical orbitals. The value of this parameter will be ignored for closed-shell wfn.
nfzcThe number of lowest-energy occupied orbitals to be kept inactive
nfzvThe number of highest-energy unoccupied orbitals to be kept inactive
omit_uoccIf true, omit all unoccupied orbitals (i.e. make the unoccupied space empty). N.B. This is not the same as "freezing" the unoccupieds.

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

Member Function Documentation

◆ actual_value_accuracy()

double sc::PsiRASCI_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::PsiRASCI_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::PsiRASCI_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::PsiRASCI_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::PsiRASCI_RefWavefunction::dk ( ) const
inlinevirtual

◆ energy()

double sc::PsiRASCI_RefWavefunction::energy ( )
inlinevirtual

◆ magnetic_moment()

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

◆ momentum_basis()

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

◆ nelectron()

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

◆ save_data_state()

void sc::PsiRASCI_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:09 for MPQC 3.0.0-alpha using the documentation package Doxygen 1.8.16.