00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028 #ifndef _chemistry_qc_intv3_tbintv3_h
00029 #define _chemistry_qc_intv3_tbintv3_h
00030
00031 #include <chemistry/qc/basis/tbint.h>
00032 #include <chemistry/qc/intv3/int2e.h>
00033
00035 class TwoBodyIntV3 : public TwoBodyInt {
00036 protected:
00037 Ref<Int2eV3> int2ev3_;
00038
00039 public:
00040 TwoBodyIntV3(Integral*integral,
00041 const Ref<GaussianBasisSet>&b1,
00042 const Ref<GaussianBasisSet>&b2,
00043 const Ref<GaussianBasisSet>&b3,
00044 const Ref<GaussianBasisSet>&b4,
00045 int storage);
00046 ~TwoBodyIntV3();
00047
00048 int log2_shell_bound(int,int,int,int);
00049 void compute_shell(int,int,int,int);
00050
00051 int storage_used() { return int2ev3_->storage_used(); }
00052 void set_integral_storage(int storage);
00053 };
00054
00057 class TwoBodyDerivIntV3 : public TwoBodyDerivInt {
00058 protected:
00059 Ref<Int2eV3> int2ev3_;
00060
00061 public:
00062 TwoBodyDerivIntV3(Integral*integral,
00063 const Ref<GaussianBasisSet>&b1,
00064 const Ref<GaussianBasisSet>&b2,
00065 const Ref<GaussianBasisSet>&b3,
00066 const Ref<GaussianBasisSet>&b4,
00067 int storage);
00068 ~TwoBodyDerivIntV3();
00069
00070 int log2_shell_bound(int,int,int,int);
00071 void compute_shell(int,int,int,int,DerivCenters&);
00072
00073 int storage_used() { return int2ev3_->storage_used(); }
00074 };
00075
00076 #endif
00077
00078
00079
00080
00081