MPQC  3.0.0-alpha
hsosks.h
1 //
2 // hsosks.h --- definition of the restricted open shell Kohn-Sham SCF class
3 // derived from clks.h
4 //
5 // Copyright (C) 1997 Limit Point Systems, Inc.
6 //
7 // Author: Edward Seidl <seidl@janed.com>
8 // Maintainer: LPS
9 //
10 // This file is part of the SC Toolkit.
11 //
12 // The SC Toolkit is free software; you can redistribute it and/or modify
13 // it under the terms of the GNU Library General Public License as published by
14 // the Free Software Foundation; either version 2, or (at your option)
15 // any later version.
16 //
17 // The SC Toolkit is distributed in the hope that it will be useful,
18 // but WITHOUT ANY WARRANTY; without even the implied warranty of
19 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
20 // GNU Library General Public License for more details.
21 //
22 // You should have received a copy of the GNU Library General Public License
23 // along with the SC Toolkit; see the file COPYING.LIB. If not, write to
24 // the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
25 //
26 // The U.S. Government is granted a limited license as per AL 91-7.
27 //
28 
29 #ifndef _chemistry_qc_dft_hsosks_h
30 #define _chemistry_qc_dft_hsosks_h
31 
32 #include <chemistry/qc/scf/hsosscf.h>
33 #include <chemistry/qc/dft/integrator.h>
34 #include <chemistry/qc/dft/functional.h>
35 
36 namespace sc {
37 
38 // //////////////////////////////////////////////////////////////////////////
39 
44 class HSOSKS: public HSOSSCF {
45  protected:
46  Ref<DenIntegrator> integrator_;
47  Ref<DenFunctional> functional_;
48  RefSymmSCMatrix vxc_a_;
49  RefSymmSCMatrix vxc_b_;
50 
51  RefSymmSCMatrix cl_vxc();
52  RefSymmSCMatrix op_vxc();
53 
54  public:
55  HSOSKS(StateIn&);
70  HSOSKS(const Ref<KeyVal>&);
71  ~HSOSKS();
72 
74 
75  void print(std::ostream&o=ExEnv::out0()) const;
76 
77  void two_body_energy(double &ec, double &ex);
78 
79  int value_implemented() const;
80 
81  protected:
82  void ao_fock(double accuracy);
83  double exc_;
84  double scf_energy();
85  Ref<SCExtrapData> extrap_data();
86  RefSymmSCMatrix effective_fock();
87 
88  void init_vector();
89  void done_vector();
90 
91  void two_body_deriv(double*);
92 
93  RefSymmSCMatrix lagrangian();
94 
95  // overload of HSOSSCF::semicanonical
96  void semicanonical();
97 
98  bool analytic_gradient_implemented() const;
99 };
100 
101 }
102 
103 #endif
104 
105 // Local Variables:
106 // mode: c++
107 // c-file-style: "ETS"
108 // End:
sc::RefSymmSCMatrix
The RefSymmSCMatrix class is a smart pointer to an SCSymmSCMatrix specialization.
Definition: matrix.h:265
sc::Ref
A template class that maintains references counts.
Definition: ref.h:361
sc::HSOSKS::print
void print(std::ostream &o=ExEnv::out0()) const
Print information about the object.
sc::StateIn
Definition: statein.h:79
sc::HSOSKS::save_data_state
void save_data_state(StateOut &)
Save the base classes (with save_data_state) and the members in the same order that the StateIn CTOR ...
sc::HSOSKS::value_implemented
int value_implemented() const
sc::HSOSSCF
The HSOSSCF class is a base for classes implementing a self-consistent procedure for high-spin open-s...
Definition: hsosscf.h:39
sc::StateOut
Definition: stateout.h:71
sc::HSOSKS::analytic_gradient_implemented
bool analytic_gradient_implemented() const
must overload this in a derived class if analytic gradient can be computed
sc::HSOSKS
This provides a Kohn-Sham implementation for restricted-orbital high-spin open-shell systems.
Definition: hsosks.h:44
sc::ExEnv::out0
static std::ostream & out0()
Return an ostream that writes from node 0.
sc
Contains all MPQC code up to version 3.
Definition: mpqcin.h:14

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