forked from sanshar/Block
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathfciqmchelper.h
67 lines (50 loc) · 1.82 KB
/
fciqmchelper.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
#ifndef FCIQMC_HELPER_HEADER_H
#define FCIQMC_HELPER_HEADER_H
#include "global.h"
#include <vector>
#include "boost/shared_ptr.hpp"
#include "StateInfo.h"
#include "StackOperators.h"
#include "Stackwavefunction.h"
#include "ObjectMatrix.h"
namespace SpinAdapted{
//the MPS is stored in the left canonical form
//LLLLL..LC
class MPS{
private:
friend class boost::serialization::access;
template<class Archive>
void serialize(Archive & ar, const unsigned int version)
{
ar & SiteTensors \
& w ;
}
std::vector< std::vector<Matrix> > SiteTensors; //these are the L matrices
StackWavefunction w; //the last wavefunction
void Init(std::vector<bool>& occ);
public:
static int sweepIters;
static bool spinAdapted;
static std::vector<StackSpinBlock> siteBlocks;
static std::vector<StackSpinBlock> siteBlocks_noDES;
MPS() {};
MPS(int stateindex);
MPS(std::vector<bool>& occ);
MPS(ulong* occnum, int length);
//void buildMPSrep();
std::vector<Matrix>& getSiteTensors(int i) {return SiteTensors[i];}
const std::vector<Matrix>& getSiteTensors(int i) const {return SiteTensors[i];}
const StackWavefunction& getw() const {return w;}
void scale(double r) {Scale(r, w);}
void normalize() {int success; w.Normalise(&success);}
double get_coefficient(const vector<bool>& occ_strings);
void writeToDiskForDMRG(int state, bool writeStateAverage=false);
};
//statea is multiplied with Operator O|Mpsa> and then we compress it to get stateb
//void compressOperatorTimesMPS(const MPS& statea, MPS& stateb);
//calculate overlap between a and b <Mpsa|Mpsb>
//double calculateOverlap (const MPS& a, const MPS& b);
//calculate hamiltonian matrix between a and b <Mpsa|H|Mpsb>
void calcHamiltonianAndOverlap(int statea, int stateb, double& h, double& o, bool sameStates=false, int integralIndex=0) ;
}
#endif