-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathrpa_test.cpp
89 lines (71 loc) · 2.93 KB
/
rpa_test.cpp
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
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
#include "rpa.hpp"
#include <cstring>
#include <chrono>
#include <cstdlib>
double t=1;
double U_prime=2;
int L=4;
MatrixXcd U;
using namespace std::chrono;
void greens_sigma_generate(MatrixXi& suggested_sigma, int lattice_index, long & idum)
{
if(ran0(&idum)<=0.5) suggested_sigma(lattice_index,2) *= -1;
}
VectorXd inttobin(int theValue)
{
VectorXd v(L);
for (int i = 0; i < L; ++i) v(i) = theValue & (1 << i) ? 1 : 0;
return v;
}
VectorXd get_field(int i)
{
VectorXd raw = inttobin(i);
for(int i=0; i<raw.size(); i++) raw(i) = (raw(i)==0)?-1:1;
return raw;
}
int main(int argc, char* argv[])
{
if(argc!=4) {cerr << "Enter (1) lattice size, (2) U and (3) temperature.\n"; exit(1);}
L = atoi(argv[1]);
U_prime = atof(argv[2]);
// double temperature = atof(argv[3]);
MatrixXd sigma = MatrixXd::Zero(L,3);
sigma.col(2) = VectorXd::Constant(L,-1);
// for(int i=0; i<L; i++) sigma(i,2) = pow(-1,i);// greens_sigma_generate(sigma, i, idum);
MatrixXcd H0 = construct_h0();
MatrixXcd H_spa = H0 - U_prime/2*matrixelement_sigmaz(sigma);
pair<MatrixXcd,VectorXd> spa_spectrum = Eigenspectrum(H_spa);
// double free_energy = rpa_free_energy(spa_spectrum.second, spa_spectrum.first, temperature);
// cout << free_energy/L << " " << " " << endl;
cout << setw(10) << "RPA_num" << " " << setw(10) << "RPA_denom" << " " << setw(10) << "SPA " << setw(10) << "Final FE " << setw(10) << "S_pi " << endl;
int i_min = 0, i_max = 0;
for(int it=0; it < L; it++) i_max += pow(2,it);
ofstream dataout("totFE.dat");
for(int j=1; j>=-3; j--)
{
for(double i=10; i>=2; i-=1)
{
double temperature = i*pow(10,j);
double total_rpa_FE = 0.0, total_spa_FE = 0.0;
for(int it= i_min; it<= i_max; it++)
{
sigma.col(2) = get_field(it);
MatrixXcd H_spa = H0 - U_prime/2*matrixelement_sigmaz(sigma);
pair<MatrixXcd,VectorXd> spa_spectrum = Eigenspectrum(H_spa);
total_rpa_FE += rpa_free_energy(spa_spectrum.second, spa_spectrum.first, temperature);
total_spa_FE += spa_free_energy(spa_spectrum.second, temperature);
}
dataout << temperature << " " << total_spa_FE/(double(i_max-i_min)) << " " << total_rpa_FE/(double(i_max-i_min)) << endl;
}
}
// MatrixXcd H_rpa = construct_RPA(spa_spectrum.second, spa_spectrum.first, temperature);
// cout.precision(3);
// // for(int i=0; i<N*N/4; i++) cout << "(" <<
// cout << endl << H_rpa.unaryExpr(&filter).real() << endl << endl;
// MatrixXcd A = H_rpa.block(0, 0, H_rpa.rows()/2, H_rpa.cols()/2);
// MatrixXcd B = H_rpa.block(0, H_rpa.cols()/2, H_rpa.rows()/2, H_rpa.cols()/2);
// MatrixXcd D = (A+B)*(A-B);
// cout << Eigenvalues(D).unaryExpr(&squareroot).transpose() << endl << endl;
// cout << Eigenvalues(H_rpa, &zgeev_cpp).transpose() << endl << endl;
}
// cout << setw(10) << free_energy/L << " " << setw(10) << get_spi(sigma) << " " << get_field(it).transpose() << " " << endl;