Add S(q,t) executable for Heis
This commit is contained in:
parent
8793035aa1
commit
aec7c206da
3
Makefile
3
Makefile
|
@ -25,7 +25,7 @@ BINDIR = $(BASEDIR)bin/
|
||||||
# Set the compiler choice
|
# Set the compiler choice
|
||||||
#CXX = g++
|
#CXX = g++
|
||||||
#CXX = /usr/local/bin/g++
|
#CXX = /usr/local/bin/g++
|
||||||
CXX = /usr/local/Cellar/gcc@7/7.4.0/bin/g++-7
|
CXX = /usr/local/Cellar/gcc@7/7.5.0/bin/g++-7
|
||||||
# On OS X, using a separate installation of llvm tools:
|
# On OS X, using a separate installation of llvm tools:
|
||||||
# CXX = /usr/local/opt/llvm/bin/clang++ -Xpreprocessor -fopenmp -lomp -L/usr/local/opt/llvm/lib:lib/ -I/usr/local/opt/llvm/include
|
# CXX = /usr/local/opt/llvm/bin/clang++ -Xpreprocessor -fopenmp -lomp -L/usr/local/opt/llvm/lib:lib/ -I/usr/local/opt/llvm/include
|
||||||
# CXX = clang++ -Weverything -ferror-limit=1
|
# CXX = clang++ -Weverything -ferror-limit=1
|
||||||
|
@ -143,6 +143,7 @@ lib$(VERSION).a : $(Objects_ALL)
|
||||||
$(COMPILE) $(EXECSDIR)Heis_DSF.cc -o $(BINDIR)Heis_DSF -l$(VERSION)
|
$(COMPILE) $(EXECSDIR)Heis_DSF.cc -o $(BINDIR)Heis_DSF -l$(VERSION)
|
||||||
$(COMPILE) $(EXECSDIR)Heis_DSF_GeneralState.cc -o $(BINDIR)Heis_DSF_GeneralState -l$(VERSION)
|
$(COMPILE) $(EXECSDIR)Heis_DSF_GeneralState.cc -o $(BINDIR)Heis_DSF_GeneralState -l$(VERSION)
|
||||||
$(COMPILE) $(EXECSDIR)Smoothen_Heis_DSF.cc -o $(BINDIR)Smoothen_Heis_DSF -l$(VERSION)
|
$(COMPILE) $(EXECSDIR)Smoothen_Heis_DSF.cc -o $(BINDIR)Smoothen_Heis_DSF -l$(VERSION)
|
||||||
|
$(COMPILE) $(EXECSDIR)Heis_Fourier_to_Sqt.cc -o $(BINDIR)Heis_Fourier_to_Sqt -l$(VERSION)
|
||||||
$(COMPILE) $(EXECSDIR)XXZ_gpd_StagSz_h0.cc -o $(BINDIR)XXZ_gpd_StagSz_h0 -l$(VERSION)
|
$(COMPILE) $(EXECSDIR)XXZ_gpd_StagSz_h0.cc -o $(BINDIR)XXZ_gpd_StagSz_h0 -l$(VERSION)
|
||||||
# $(COMPILE) $(EXECSDIR)ODSLF_DSF.cc -o $(BINDIR)ODSLF_DSF -l$(VERSION)
|
# $(COMPILE) $(EXECSDIR)ODSLF_DSF.cc -o $(BINDIR)ODSLF_DSF -l$(VERSION)
|
||||||
# $(COMPILE) $(EXECSDIR)Smoothen_ODSLF_DSF.cc -o $(BINDIR)Smoothen_ODSLF_DSF -l$(VERSION)
|
# $(COMPILE) $(EXECSDIR)Smoothen_ODSLF_DSF.cc -o $(BINDIR)Smoothen_ODSLF_DSF -l$(VERSION)
|
||||||
|
|
|
@ -156,6 +156,7 @@ namespace ABACUS {
|
||||||
DP ommin, DP ommax, int Nom, DP gwidth, DP normalization, DP denom_sum_K);
|
DP ommin, DP ommax, int Nom, DP gwidth, DP normalization, DP denom_sum_K);
|
||||||
void Write_K_File (DP Length, int iKmin, int iKmax);
|
void Write_K_File (DP Length, int iKmin, int iKmax);
|
||||||
void Write_Omega_File (int Nout_omega, DP omegamin, DP omegamax);
|
void Write_Omega_File (int Nout_omega, DP omegamin, DP omegamax);
|
||||||
|
void Write_Time_File (int Nt, DP tmin, DP tmax);
|
||||||
// Smoothen with gaussian width scaled with two-particle bandwidth
|
// Smoothen with gaussian width scaled with two-particle bandwidth
|
||||||
DP Smoothen_RAW_into_SF_LiebLin_Scaled (std::string prefix, DP L, int N, int iKmin, int iKmax, int DiK, DP ommin, DP ommax, int Nom, DP width, DP normalization);
|
DP Smoothen_RAW_into_SF_LiebLin_Scaled (std::string prefix, DP L, int N, int iKmin, int iKmax, int DiK, DP ommin, DP ommax, int Nom, DP width, DP normalization);
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,116 @@
|
||||||
|
/**********************************************************
|
||||||
|
|
||||||
|
This software is part of J.-S. Caux's ABACUS library.
|
||||||
|
|
||||||
|
Copyright (c) J.-S. Caux.
|
||||||
|
|
||||||
|
-----------------------------------------------------------
|
||||||
|
|
||||||
|
File: Heis_Fourier_to_Sqt.cc
|
||||||
|
|
||||||
|
Purpose: Fourier transform to q and t-dependent correlator for Heis
|
||||||
|
|
||||||
|
***********************************************************/
|
||||||
|
|
||||||
|
#include "ABACUS.h"
|
||||||
|
|
||||||
|
using namespace std;
|
||||||
|
using namespace ABACUS;
|
||||||
|
|
||||||
|
int main(int argc, char* argv[])
|
||||||
|
{
|
||||||
|
if (argc != 10) { // Print out instructions
|
||||||
|
cout << "Usage of Heis_Fourier_to_Sqt executable: " << endl << endl;
|
||||||
|
cout << "Provide arguments using one of the following options:" << endl << endl;
|
||||||
|
cout << "whichDSF Delta N M iKmin iKmax devmax Npts_t tmax" << endl << endl;
|
||||||
|
}
|
||||||
|
|
||||||
|
else {
|
||||||
|
int index = 1;
|
||||||
|
char whichDSF = *argv[index++];
|
||||||
|
DP Delta = atof(argv[index++]);
|
||||||
|
int N = atoi(argv[index++]);
|
||||||
|
int M = atoi(argv[index++]);
|
||||||
|
int iKmin = atoi(argv[index++]);
|
||||||
|
int iKmax = atoi(argv[index++]);
|
||||||
|
DP devmax = atof(argv[index++]);
|
||||||
|
int Npts_t = atoi(argv[index++]);
|
||||||
|
DP tmax = atof(argv[index++]);
|
||||||
|
|
||||||
|
stringstream filenameprefix;
|
||||||
|
Data_File_Name (filenameprefix, whichDSF, Delta, N, M, iKmin, iKmax, 0.0, 0, "");
|
||||||
|
string prefix = filenameprefix.str();
|
||||||
|
|
||||||
|
stringstream RAW_stringstream; string RAW_string;
|
||||||
|
RAW_stringstream << prefix << ".raw";
|
||||||
|
RAW_string = RAW_stringstream.str(); const char* RAW_Cstr = RAW_string.c_str();
|
||||||
|
|
||||||
|
ifstream RAW_infile;
|
||||||
|
RAW_infile.open(RAW_Cstr);
|
||||||
|
if (RAW_infile.fail()) {
|
||||||
|
cout << RAW_Cstr << endl;
|
||||||
|
ABACUSerror("Could not open RAW_infile... ");
|
||||||
|
}
|
||||||
|
|
||||||
|
RecMat<complex<DP> > FT(Npts_t + 1, iKmax - iKmin + 1);
|
||||||
|
|
||||||
|
DP omega;
|
||||||
|
int iK;
|
||||||
|
DP FF;
|
||||||
|
DP dev;
|
||||||
|
string label;
|
||||||
|
|
||||||
|
// Now define time coordinates: between 0 and tmax
|
||||||
|
Vect_DP tlattice(Npts_t + 1);
|
||||||
|
for (int i = 0; i <= Npts_t; ++i) tlattice[i] = i * tmax/Npts_t;
|
||||||
|
|
||||||
|
while (RAW_infile.peek() != EOF) {
|
||||||
|
RAW_infile >> omega >> iK >> FF >> dev >> label;
|
||||||
|
for (int it = 0; it < Npts_t; ++it)
|
||||||
|
FT[it][iK] += FF * FF * exp(II * omega * tlattice[it]);
|
||||||
|
}
|
||||||
|
RAW_infile.close();
|
||||||
|
|
||||||
|
|
||||||
|
// Output to files:
|
||||||
|
|
||||||
|
Write_K_File (N, iKmin, iKmax);
|
||||||
|
Write_Time_File (Npts_t + 1, 0.0, tmax);
|
||||||
|
|
||||||
|
stringstream FTre_stringstream; string FTre_string;
|
||||||
|
FTre_stringstream << prefix << "_Sqt_tmin_" << 0 << "_tmax_" << tmax << "_Nt_" << Npts_t << ".dat_re";
|
||||||
|
FTre_string = FTre_stringstream.str(); const char* FTre_Cstr = FTre_string.c_str();
|
||||||
|
ofstream FTre_outfile;
|
||||||
|
FTre_outfile.open(FTre_Cstr);
|
||||||
|
if (FTre_outfile.fail()) ABACUSerror("Could not open FTre_outfile... ");
|
||||||
|
|
||||||
|
stringstream FTim_stringstream; string FTim_string;
|
||||||
|
FTim_stringstream << prefix << "_Sqt_tmin_" << 0 << "_tmax_" << tmax << "_Nt_" << Npts_t << ".dat_im";
|
||||||
|
FTim_string = FTim_stringstream.str(); const char* FTim_Cstr = FTim_string.c_str();
|
||||||
|
ofstream FTim_outfile;
|
||||||
|
FTim_outfile.open(FTim_Cstr);
|
||||||
|
if (FTim_outfile.fail()) ABACUSerror("Could not open FTim_outfile... ");
|
||||||
|
|
||||||
|
|
||||||
|
for (int iK = iKmin; iK <= iKmax; ++iK) {
|
||||||
|
FTre_outfile << setprecision(16);
|
||||||
|
FTim_outfile << setprecision(16);
|
||||||
|
if (iK > iKmin) {
|
||||||
|
FTre_outfile << endl;
|
||||||
|
FTim_outfile << endl;
|
||||||
|
}
|
||||||
|
FTre_outfile << real(FT[0][iK]);
|
||||||
|
FTim_outfile << real(FT[0][iK]);
|
||||||
|
for (int it = 1; it <= Npts_t; ++it) {
|
||||||
|
FTre_outfile << "\t" << real(FT[it][iK]);
|
||||||
|
FTim_outfile << "\t" << imag(FT[it][iK]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
FTre_outfile.close();
|
||||||
|
FTim_outfile.close();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
return(0);
|
||||||
|
}
|
|
@ -65,4 +65,27 @@ namespace ABACUS {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Write_Time_File (int Nt, DP tmin, DP tmax)
|
||||||
|
{
|
||||||
|
stringstream t_file;
|
||||||
|
string t_file_string;
|
||||||
|
t_file << "t_tmin_" << tmin << "_tmax_" << tmax << "_Nt_" << Nt << ".dat";
|
||||||
|
t_file_string = t_file.str();
|
||||||
|
const char* t_file_Cstr = t_file_string.c_str();
|
||||||
|
|
||||||
|
ofstream outfile_t;
|
||||||
|
|
||||||
|
outfile_t.open(t_file_Cstr);
|
||||||
|
|
||||||
|
outfile_t.setf(ios::fixed);
|
||||||
|
outfile_t.setf(ios::showpoint);
|
||||||
|
outfile_t.precision(16);
|
||||||
|
|
||||||
|
for (int it = 0; it <= Nt; ++it) outfile_t << tmin + it * (tmax - tmin)/Nt << endl;
|
||||||
|
|
||||||
|
outfile_t.close();
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace ABACUS
|
} // namespace ABACUS
|
||||||
|
|
Loading…
Reference in New Issue