From a8a6812756cd4cdb229451de01e14cd7ed7e05b9 Mon Sep 17 00:00:00 2001 From: RuQing Xu Date: Sun, 19 Aug 2018 17:48:20 +0900 Subject: [PATCH 01/10] 1-Step Lanczos Estimation of Operators Uses Q|CACAQ Decomposition Further optimisation needed. --- src/mVMC/calgrn.c | 7 +++- src/mVMC/include/global.h | 1 + src/mVMC/setmemory.c | 3 +- src/mVMC/vmccal.c | 84 +++++++++++++++++++++++++++++++++++++-- 4 files changed, 89 insertions(+), 6 deletions(-) diff --git a/src/mVMC/calgrn.c b/src/mVMC/calgrn.c index 8d13215b..16fc3864 100644 --- a/src/mVMC/calgrn.c +++ b/src/mVMC/calgrn.c @@ -81,7 +81,7 @@ void CalculateGreenFunc(const double w, const double complex ip, int *eleIdx, in tmp = GreenFunc2(ri,rj,rk,rl,s,t,ip,myEleIdx,eleCfg,myEleNum,eleProjCnt, myProjCntNew,myBuffer); - PhysCisAjsCktAltDC[idx] += w*tmp; + LocalCisAjsCktAltDC[idx] = tmp; } #pragma omp master @@ -92,6 +92,11 @@ void CalculateGreenFunc(const double w, const double complex ip, int *eleIdx, in PhysCisAjs[idx] += w*LocalCisAjs[idx]; } + #pragma omp for private(idx) nowait + for (idx=0;idx, */ diff --git a/src/mVMC/setmemory.c b/src/mVMC/setmemory.c index 38a66524..5166eb1d 100644 --- a/src/mVMC/setmemory.c +++ b/src/mVMC/setmemory.c @@ -365,10 +365,11 @@ void SetMemory() { /***** Physical Quantity *****/ if(NVMCCalMode==1){ PhysCisAjs = (double complex*)malloc(sizeof(double complex) - *(NCisAjs+NCisAjsCktAlt+NCisAjsCktAltDC+NCisAjs)); + *(NCisAjs+NCisAjsCktAlt+NCisAjsCktAltDC+NCisAjs+NCisAjsCktAltDC)); PhysCisAjsCktAlt = PhysCisAjs + NCisAjs; PhysCisAjsCktAltDC = PhysCisAjsCktAlt + NCisAjsCktAlt; LocalCisAjs = PhysCisAjsCktAltDC + NCisAjsCktAltDC; + LocalCisAjsCktAltDC = LocalCisAjs + NCisAjs; if(NLanczosMode>0){ QQQQ = (double complex*)malloc(sizeof(double complex) diff --git a/src/mVMC/vmccal.c b/src/mVMC/vmccal.c index 85698c08..f886f5fd 100644 --- a/src/mVMC/vmccal.c +++ b/src/mVMC/vmccal.c @@ -68,6 +68,16 @@ void calculateQCACAQ_real(double *qcacaq, const double *lslca, const double w, const int nLSHam, const int nCA, const int nCACA, int **cacaIdx); +void calculateQCACAQ_real_alt(double *qcacaq, const double *lslq, const double w, + const int nLSHam, const int nCA, const int nCACA, + const double h1, const double ip, + int *eleIdx, int *eleCfg, int *eleNum, int *eleProjCnt); + +void calculateQCACAQ_alt(double complex *qcacaq, const double complex *lslq, const double w, + const int nLSHam, const int nCA, const int nCACA, + const double complex h1, const double complex ip, + int *eleIdx, int *eleCfg, int *eleNum, int *eleProjCnt); + void VMCMainCal(MPI_Comm comm) { int *eleIdx,*eleCfg,*eleNum,*eleProjCnt; double complex e,ip; @@ -266,15 +276,19 @@ void VMCMainCal(MPI_Comm comm) { LSLocalCisAjs_real(creal(e),creal(ip),eleIdx,eleCfg,eleNum,eleProjCnt); calculateQCAQ_real(QCisAjsQ_real,LSLCisAjs_real,LSLQ_real,w,NLSHam,NCisAjs); - calculateQCACAQ_real(QCisAjsCktAltQ_real,LSLCisAjs_real,w,NLSHam,NCisAjs, - NCisAjsCktAltDC, CisAjsCktAltLzIdx); + //calculateQCACAQ_real(QCisAjsCktAltQ_real,LSLCisAjs_real,w,NLSHam,NCisAjs, + // NCisAjsCktAltDC, CisAjsCktAltLzIdx); + calculateQCACAQ_real_alt(QCisAjsCktAltQ_real,LSLQ_real,w,NLSHam,NCisAjs, + NCisAjsCktAltDC,creal(e),creal(ip),eleIdx,eleCfg,eleNum,eleProjCnt); } else{ LSLocalCisAjs(e,ip,eleIdx,eleCfg,eleNum,eleProjCnt); calculateQCAQ(QCisAjsQ,LSLCisAjs,LSLQ,w,NLSHam,NCisAjs); - calculateQCACAQ(QCisAjsCktAltQ,LSLCisAjs,w,NLSHam,NCisAjs, - NCisAjsCktAltDC,CisAjsCktAltLzIdx); + //calculateQCACAQ(QCisAjsCktAltQ,LSLCisAjs,w,NLSHam,NCisAjs, + // NCisAjsCktAltDC,CisAjsCktAltLzIdx); + calculateQCACAQ_alt(QCisAjsCktAltQ,LSLQ,w,NLSHam,NCisAjs, + NCisAjsCktAltDC,e,ip,eleIdx,eleCfg,eleNum,eleProjCnt); } StopTimer(44); } @@ -919,4 +933,66 @@ void calculateQCACAQ_real(double *qcacaq, const double *lslca, const double w, return; } + +void calculateQCACAQ_real_alt(double *qcacaq, const double *lslq, const double w, + const int nLSHam, const int nCA, const int nCACA, + const double h1, const double ip, + int *eleIdx, int *eleCfg, int *eleNum, int *eleProjCnt) { + const int n=nLSHam*nLSHam*nCACA; + int rq,rp,ri,rj,rk,rl,s,t,idx; + int i,tmp; + +# pragma omp for private(i,tmp,idx,rp,rq,ri,rj,rk,rl,s,t) + for(i=0;i Date: Sat, 20 Jul 2019 11:41:15 +0800 Subject: [PATCH 02/10] Changed Lanczos Green Function Fix to an Appropirate Name --- src/mVMC/vmccal.c | 40 ++++++++++++++++++++-------------------- 1 file changed, 20 insertions(+), 20 deletions(-) diff --git a/src/mVMC/vmccal.c b/src/mVMC/vmccal.c index f886f5fd..24010fcb 100644 --- a/src/mVMC/vmccal.c +++ b/src/mVMC/vmccal.c @@ -68,15 +68,15 @@ void calculateQCACAQ_real(double *qcacaq, const double *lslca, const double w, const int nLSHam, const int nCA, const int nCACA, int **cacaIdx); -void calculateQCACAQ_real_alt(double *qcacaq, const double *lslq, const double w, - const int nLSHam, const int nCA, const int nCACA, - const double h1, const double ip, - int *eleIdx, int *eleCfg, int *eleNum, int *eleProjCnt); +void calculateQCACAQDC_real(double *qcacaq, const double *lslq, const double w, + const int nLSHam, const int nCA, const int nCACA, + int *eleIdx, int *eleCfg, int *eleNum, int *eleProjCnt, + const double h1, const double ip); -void calculateQCACAQ_alt(double complex *qcacaq, const double complex *lslq, const double w, - const int nLSHam, const int nCA, const int nCACA, - const double complex h1, const double complex ip, - int *eleIdx, int *eleCfg, int *eleNum, int *eleProjCnt); +void calculateQCACAQDC(double complex *qcacaq, const double complex *lslq, const double w, + const int nLSHam, const int nCA, const int nCACA, + int *eleIdx, int *eleCfg, int *eleNum, int *eleProjCnt, + const double complex h1, const double complex ip); void VMCMainCal(MPI_Comm comm) { int *eleIdx,*eleCfg,*eleNum,*eleProjCnt; @@ -278,8 +278,8 @@ void VMCMainCal(MPI_Comm comm) { calculateQCAQ_real(QCisAjsQ_real,LSLCisAjs_real,LSLQ_real,w,NLSHam,NCisAjs); //calculateQCACAQ_real(QCisAjsCktAltQ_real,LSLCisAjs_real,w,NLSHam,NCisAjs, // NCisAjsCktAltDC, CisAjsCktAltLzIdx); - calculateQCACAQ_real_alt(QCisAjsCktAltQ_real,LSLQ_real,w,NLSHam,NCisAjs, - NCisAjsCktAltDC,creal(e),creal(ip),eleIdx,eleCfg,eleNum,eleProjCnt); + calculateQCACAQDC_real(QCisAjsCktAltQ_real,LSLQ_real,w,NLSHam,NCisAjs, + NCisAjsCktAltDC,eleIdx,eleCfg,eleNum,eleProjCnt,creal(e),creal(ip)); } else{ @@ -287,8 +287,8 @@ void VMCMainCal(MPI_Comm comm) { calculateQCAQ(QCisAjsQ,LSLCisAjs,LSLQ,w,NLSHam,NCisAjs); //calculateQCACAQ(QCisAjsCktAltQ,LSLCisAjs,w,NLSHam,NCisAjs, // NCisAjsCktAltDC,CisAjsCktAltLzIdx); - calculateQCACAQ_alt(QCisAjsCktAltQ,LSLQ,w,NLSHam,NCisAjs, - NCisAjsCktAltDC,e,ip,eleIdx,eleCfg,eleNum,eleProjCnt); + calculateQCACAQDC(QCisAjsCktAltQ,LSLQ,w,NLSHam,NCisAjs, + NCisAjsCktAltDC,eleIdx,eleCfg,eleNum,eleProjCnt,e,ip); } StopTimer(44); } @@ -934,10 +934,10 @@ void calculateQCACAQ_real(double *qcacaq, const double *lslca, const double w, } -void calculateQCACAQ_real_alt(double *qcacaq, const double *lslq, const double w, - const int nLSHam, const int nCA, const int nCACA, - const double h1, const double ip, - int *eleIdx, int *eleCfg, int *eleNum, int *eleProjCnt) { +void calculateQCACAQ_real(double *qcacaq, const double *lslq, const double w, + const int nLSHam, const int nCA, const int nCACA, + int *eleIdx, int *eleCfg, int *eleNum, int *eleProjCnt, + const double h1, const double ip) { const int n=nLSHam*nLSHam*nCACA; int rq,rp,ri,rj,rk,rl,s,t,idx; int i,tmp; @@ -965,10 +965,10 @@ void calculateQCACAQ_real_alt(double *qcacaq, const double *lslq, const double w return; } -void calculateQCACAQ_alt(double complex *qcacaq, const double complex *lslq, const double w, - const int nLSHam, const int nCA, const int nCACA, - const double complex h1, const double complex ip, - int *eleIdx, int *eleCfg, int *eleNum, int *eleProjCnt) { +void calculateQCACAQ(double complex *qcacaq, const double complex *lslq, const double w, + const int nLSHam, const int nCA, const int nCACA, + int *eleIdx, int *eleCfg, int *eleNum, int *eleProjCnt, + const double complex h1, const double complex ip) { const int n=nLSHam*nLSHam*nCACA; int rq,rp,ri,rj,rk,rl,s,t,idx; int i,tmp; From d70bd0498f7df02a8ee24fcf046cdfb31572e4d7 Mon Sep 17 00:00:00 2001 From: RuQing Xu Date: Sat, 27 Jul 2019 19:29:36 +0800 Subject: [PATCH 03/10] Fixed a Miss in Changing Routine Name Change 59fe4ec --- src/mVMC/vmccal.c | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) diff --git a/src/mVMC/vmccal.c b/src/mVMC/vmccal.c index 24010fcb..46350bb4 100644 --- a/src/mVMC/vmccal.c +++ b/src/mVMC/vmccal.c @@ -934,10 +934,10 @@ void calculateQCACAQ_real(double *qcacaq, const double *lslca, const double w, } -void calculateQCACAQ_real(double *qcacaq, const double *lslq, const double w, - const int nLSHam, const int nCA, const int nCACA, - int *eleIdx, int *eleCfg, int *eleNum, int *eleProjCnt, - const double h1, const double ip) { +void calculateQCACAQDC_real(double *qcacaq, const double *lslq, const double w, + const int nLSHam, const int nCA, const int nCACA, + int *eleIdx, int *eleCfg, int *eleNum, int *eleProjCnt, + const double h1, const double ip) { const int n=nLSHam*nLSHam*nCACA; int rq,rp,ri,rj,rk,rl,s,t,idx; int i,tmp; @@ -965,10 +965,10 @@ void calculateQCACAQ_real(double *qcacaq, const double *lslq, const double w, return; } -void calculateQCACAQ(double complex *qcacaq, const double complex *lslq, const double w, - const int nLSHam, const int nCA, const int nCACA, - int *eleIdx, int *eleCfg, int *eleNum, int *eleProjCnt, - const double complex h1, const double complex ip) { +void calculateQCACAQCDC(double complex *qcacaq, const double complex *lslq, const double w, + const int nLSHam, const int nCA, const int nCACA, + int *eleIdx, int *eleCfg, int *eleNum, int *eleProjCnt, + const double complex h1, const double complex ip) { const int n=nLSHam*nLSHam*nCACA; int rq,rp,ri,rj,rk,rl,s,t,idx; int i,tmp; From a1c6d431112410b4a1ff48f62aa870ec519c60f7 Mon Sep 17 00:00:00 2001 From: RuQing Xu Date: Sat, 27 Jul 2019 19:31:33 +0800 Subject: [PATCH 04/10] Fixed a Typo in Changing Routine Name 59fe4ec --- src/mVMC/vmccal.c | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/src/mVMC/vmccal.c b/src/mVMC/vmccal.c index 46350bb4..3fcd762d 100644 --- a/src/mVMC/vmccal.c +++ b/src/mVMC/vmccal.c @@ -965,10 +965,10 @@ void calculateQCACAQDC_real(double *qcacaq, const double *lslq, const double w, return; } -void calculateQCACAQCDC(double complex *qcacaq, const double complex *lslq, const double w, - const int nLSHam, const int nCA, const int nCACA, - int *eleIdx, int *eleCfg, int *eleNum, int *eleProjCnt, - const double complex h1, const double complex ip) { +void calculateQCACAQDC(double complex *qcacaq, const double complex *lslq, const double w, + const int nLSHam, const int nCA, const int nCACA, + int *eleIdx, int *eleCfg, int *eleNum, int *eleProjCnt, + const double complex h1, const double complex ip) { const int n=nLSHam*nLSHam*nCACA; int rq,rp,ri,rj,rk,rl,s,t,idx; int i,tmp; From 94ad10d6a75d9f5d310d89a409895247df313ac3 Mon Sep 17 00:00:00 2001 From: RuQing Xu Date: Sat, 27 Jul 2019 19:30:19 +0800 Subject: [PATCH 05/10] Fixed Parallel Level in QCACAQDC Calculation --- src/mVMC/vmccal.c | 2 -- 1 file changed, 2 deletions(-) diff --git a/src/mVMC/vmccal.c b/src/mVMC/vmccal.c index 3fcd762d..834d122c 100644 --- a/src/mVMC/vmccal.c +++ b/src/mVMC/vmccal.c @@ -942,7 +942,6 @@ void calculateQCACAQDC_real(double *qcacaq, const double *lslq, const double w, int rq,rp,ri,rj,rk,rl,s,t,idx; int i,tmp; -# pragma omp for private(i,tmp,idx,rp,rq,ri,rj,rk,rl,s,t) for(i=0;i Date: Tue, 30 Jul 2019 18:11:28 +0800 Subject: [PATCH 06/10] Fixed Indirect GreenTwo & Separated Direct/Indirect LSGreenTwo Indirect: TwoBodyGEx Direct: TwoBodyG --- src/mVMC/average.c | 2 +- src/mVMC/include/global.h | 10 +- src/mVMC/include/physcal_lanczos.h | 14 ++- src/mVMC/initfile.c | 9 +- src/mVMC/physcal_lanczos.c | 59 ++++++++--- src/mVMC/readdef.c | 153 ++++++++++++++--------------- src/mVMC/setmemory.c | 29 +++--- src/mVMC/vmccal.c | 20 ++-- src/mVMC/vmcmain.c | 39 +++----- 9 files changed, 182 insertions(+), 153 deletions(-) diff --git a/src/mVMC/average.c b/src/mVMC/average.c index c6bbc7a4..a9ffde52 100644 --- a/src/mVMC/average.c +++ b/src/mVMC/average.c @@ -229,7 +229,7 @@ void WeightAverageGreenFunc(MPI_Comm comm) { } if(NLanczosMode>1){ /* QCisAjsQ and QCisAjsCktAltQ */ - n = NLSHam*NLSHam*NCisAjs + NLSHam*NLSHam*NCisAjsCktAltDC; + n = NLSHam*NLSHam*NCisAjs + NLSHam*NLSHam*(NCisAjsCktAltDC+NCisAjsCktAlt); if(AllComplexFlag==0){ vec_real=QCisAjsQ_real; weightAverageReduce_real(n,vec_real,comm); diff --git a/src/mVMC/include/global.h b/src/mVMC/include/global.h index 2d2d7631..e3add70a 100644 --- a/src/mVMC/include/global.h +++ b/src/mVMC/include/global.h @@ -141,10 +141,9 @@ double *ParaQPOptTrans; /* for Green functions */ int NCisAjs, **CisAjsIdx; /* [NCisAjs][3] */ -int NCisAjsCktAlt, **CisAjsCktAltIdx; /* [NCisAjsCktAlt][8] */ +int NCisAjsCktAlt, **CisAjsCktAltIdx; /* [NCisAjsCktAlt][2] */ int NCisAjsCktAltDC, **CisAjsCktAltDCIdx; /* [NCisAjsCktAltDC][6] */ -int NCisAjsLz, **CisAjsLzIdx, **iOneBodyGIdx; /* For Lanczos method only for rank 0*/ -int NCisAjsCktAltLz, **CisAjsCktAltLzIdx; +int **iOneBodyGIdx; /* For GF2 indirect measurement */ /* Optimization flag */ int *OptFlag; /* [NPara] 1: optimized, 0 or 2: fixed */ @@ -286,10 +285,13 @@ double *LSLQ_real; /* [NLSHam][NLSHam]*/ //TBC double complex *QCisAjsQ; /* QCisAjsQ[NLSHam][NLSHam][NCisAjs]*/ //TBC double complex *QCisAjsCktAltQ; /* QCisAjsCktAltQ[NLSHam][NLSHam][NCisAjsCktAlt]*/ //TBC +double complex *QCisAjsCktAltQDC; /* QCisAjsCktAltQ[NLSHam][NLSHam][NCisAjsCktAlt] + DC Lanczos Calculation */ double complex *LSLCisAjs; /* [NLSHam][NCisAjs]*/ //TBC double *QCisAjsQ_real; /* QCisAjsQ[NLSHam][NLSHam][NCisAjs]*/ //TBC double *QCisAjsCktAltQ_real; /* QCisAjsCktAltQ[NLSHam][NLSHam][NCisAjsCktAlt]*/ //TBC +double *QCisAjsCktAltQDC_real; /* QCisAjsCktAltQ[NLSHam][NLSHam][NCisAjsCktAlt]*/ double *LSLCisAjs_real; /* [NLSHam][NCisAjs]*/ //TBC /***** Output File *****/ @@ -305,8 +307,10 @@ FILE *FileLS; FILE *FileLSQQQQ; FILE *FileLSQCisAjsQ; FILE *FileLSQCisAjsCktAltQ; +FILE *FileLSQCisAjsCktAltQ; FILE *FileLSCisAjs; FILE *FileLSCisAjsCktAlt; +FILE *FileLSCisAjsCktAltDC; /* FILE *FileTimerList; */ diff --git a/src/mVMC/include/physcal_lanczos.h b/src/mVMC/include/physcal_lanczos.h index 9dd02cce..27dbf7ff 100644 --- a/src/mVMC/include/physcal_lanczos.h +++ b/src/mVMC/include/physcal_lanczos.h @@ -7,6 +7,7 @@ int PhysCalLanczos_real( double *_QQQQ_real, double *_QCisAjsQ_real, double *_QCisAjsCktAltQ_real, + double *_QCisAjsCktAltQDC_real, const int _nLSHam, const int _Ns, const int _nCisAjs, @@ -14,20 +15,23 @@ int PhysCalLanczos_real( int **_iOneBodyGIdx, int **_CisAjsLzIdx, const int _nCisAjsCktAlt, - int **_CisAjsCktAlt, + const int _nCisAjsCktAltDC, + int **_CisAjsCktAltDC, const int _NLanczosmode, FILE *_FileLS, FILE *_FileLSQQQQ, FILE *_FileLSQCisAjsQ, FILE *_FileLSQCisAjsCktAltQ, FILE *_FileLSCisAjs, - FILE *_FileLSCisAjsCktAlt + FILE *_FileLSCisAjsCktAlt, + FILE *_FileLSCisAjsCktAltDC ); int PhysCalLanczos_fcmp( double complex* _QQQQ, double complex* _QCisAjsQ, double complex* _QCisAjsCktAltQ, + double complex* _QCisAjsCktAltQDC, const int _nLSHam, const int _Ns, const int _nCisAjs, @@ -35,14 +39,16 @@ int PhysCalLanczos_fcmp( int **_iOneBodyGIdx, int **_CisAjsLzIdx, const int _nCisAjsCktAlt, - int **_CisAjsCktAlt, + const int _nCisAjsCktAltDC, + int **_CisAjsCktAltDC, const int _NLanczosmode, FILE *_FileLS, FILE *_FileLSQQQQ, FILE *_FileLSQCisAjsQ, FILE *_FileLSQCisAjsCktAltQ, FILE *_FileLSCisAjs, - FILE *_FileLSCisAjsCktAlt + FILE *_FileLSCisAjsCktAlt, + FILE *_FileLSCisAjsCktAltDC ); #endif diff --git a/src/mVMC/initfile.c b/src/mVMC/initfile.c index 815f971f..80a04f38 100644 --- a/src/mVMC/initfile.c +++ b/src/mVMC/initfile.c @@ -126,9 +126,15 @@ void InitFilePhysCal(int i, int rank) { CDataFileHead, idx); FileLSCisAjs = fopen(fileName, "w"); - sprintf(fileName, "%s_ls_cisajscktalt_%03d.dat", + // CACA + sprintf(fileName, "%s_ls_cisajscktaltex_%03d.dat", CDataFileHead, idx); FileLSCisAjsCktAlt = fopen(fileName, "w"); + + // CACADC + sprintf(fileName, "%s_ls_cisajscktalt_%03d.dat", + CDataFileHead, idx); + FileLSCisAjsCktAltDC = fopen(fileName, "w"); } } @@ -176,6 +182,7 @@ void CloseFilePhysCal(int rank) { #endif fclose(FileLSCisAjs); fclose(FileLSCisAjsCktAlt); + fclose(FileLSCisAjsCktAltDC); } } diff --git a/src/mVMC/physcal_lanczos.c b/src/mVMC/physcal_lanczos.c index 26b9782a..7eb6891a 100644 --- a/src/mVMC/physcal_lanczos.c +++ b/src/mVMC/physcal_lanczos.c @@ -29,6 +29,7 @@ int PhysCalLanczos_real double *_QQQQ_real, double *_QCisAjsQ_real, double *_QCisAjsCktAltQ_real, + double *_QCisAjsCktAltQDC_real, const int _nLSHam, const int _Ns, const int _nCisAjs, @@ -36,14 +37,16 @@ int PhysCalLanczos_real int **_iOneBodyGIdx, int **_CisAjsLzIdx, const int _nCisAjsCktAlt, - int **_CisAjsCktAlt, + const int _nCisAjsCktAltDC, + int **_CisAjsCktAltDC, const int _NLanczosmode, FILE *_FileLS, FILE *_FileLSQQQQ, FILE *_FileLSQCisAjsQ, FILE *_FileLSQCisAjsCktAltQ, FILE *_FileLSCisAjs, - FILE *_FileLSCisAjsCktAlt + FILE *_FileLSCisAjsCktAlt, + FILE *_FileLSCisAjsCktAltDC ) { int i=0; @@ -53,8 +56,10 @@ int PhysCalLanczos_real double alpha_m, ene_m, ene_vm; double *LS_CisAjs_real; double *LS_CisAjsCktAlt_real; + double *LS_CisAjsCktAltDC_real; LS_CisAjs_real = (double*)malloc(sizeof(double)*_nCisAjs); LS_CisAjsCktAlt_real = (double*)malloc(sizeof(double)*_nCisAjsCktAlt); + LS_CisAjsCktAltDC_real = (double*)malloc(sizeof(double)*_nCisAjsCktAltDC); CalculateEne(_QQQQ_real[2], _QQQQ_real[3], _QQQQ_real[10], _QQQQ_real[11], _QQQQ_real[15], &alpha_p, &ene_p, &ene_vp, &alpha_m, &ene_m, &ene_vm); @@ -114,21 +119,30 @@ int PhysCalLanczos_real fprintf(_FileLSQCisAjsCktAltQ, "\n"); #endif + CalculatePhysVal_real(_QQQQ_real[2], _QQQQ_real[3], + alpha, _QCisAjsCktAltQDC_real, _nCisAjsCktAltDC, + _nLSHam, LS_CisAjsCktAltDC_real); + /* zvo_ls_cisajscktalt.dat */ + for (i = 0; i < _nCisAjsCktAltDC; i++) { + fprintf(_FileLSCisAjsCktAltDC, "%d %d %d %d %d %d %d %d % .18e 0.0\n", + _CisAjsCktAltDC[i][0], _CisAjsCktAltDC[i][1], _CisAjsCktAltDC[i][2], _CisAjsCktAltDC[i][3], + _CisAjsCktAltDC[i][4], _CisAjsCktAltDC[i][5], _CisAjsCktAltDC[i][6], _CisAjsCktAltDC[i][7], + LS_CisAjsCktAltDC_real[i]); + } + fprintf(_FileLSCisAjsCktAltDC, "\n"); + CalculatePhysVal_real(_QQQQ_real[2], _QQQQ_real[3], alpha, _QCisAjsCktAltQ_real, _nCisAjsCktAlt, _nLSHam, LS_CisAjsCktAlt_real); - /* zvo_ls_cisajscktalt.dat */ + /* zvo_ls_cisajscktaltex.dat */ for (i = 0; i < _nCisAjsCktAlt; i++) { - fprintf(_FileLSCisAjsCktAlt, "%d %d %d %d %d %d %d %d % .18e 0.0\n", - _CisAjsCktAlt[i][0], _CisAjsCktAlt[i][1], _CisAjsCktAlt[i][2], _CisAjsCktAlt[i][3], - _CisAjsCktAlt[i][4], _CisAjsCktAlt[i][5], _CisAjsCktAlt[i][6], _CisAjsCktAlt[i][7], - LS_CisAjsCktAlt_real[i]); - + fprintf(_FileLSCisAjsCktAlt, "% .18e 0.0 ", LS_CisAjsCktAlt_real[i]); // LS_CisAjsCktAlt_real } fprintf(_FileLSCisAjsCktAlt, "\n"); } free(LS_CisAjs_real); free(LS_CisAjsCktAlt_real); + free(LS_CisAjsCktAltDC_real); return 0; } @@ -136,6 +150,7 @@ int PhysCalLanczos_fcmp( double complex* _QQQQ, double complex* _QCisAjsQ, double complex* _QCisAjsCktAltQ, + double complex* _QCisAjsCktAltQDC, const int _nLSHam, const int _Ns, const int _nCisAjs, @@ -143,14 +158,16 @@ int PhysCalLanczos_fcmp( int **_iOneBodyGIdx, int **_CisAjsLzIdx, const int _nCisAjsCktAlt, - int **_CisAjsCktAlt, + const int _nCisAjsCktAltDC, + int **_CisAjsCktAltDC, const int _NLanczosmode, FILE *_FileLS, FILE *_FileLSQQQQ, FILE *_FileLSQCisAjsQ, FILE *_FileLSQCisAjsCktAltQ, FILE *_FileLSCisAjs, - FILE *_FileLSCisAjsCktAlt + FILE *_FileLSCisAjsCktAlt, + FILE *_FileLSCisAjsCktAltDC ) { int i=0; @@ -160,8 +177,10 @@ int PhysCalLanczos_fcmp( double alpha_m, ene_m, ene_vm; double complex*LS_CisAjs; double complex*LS_CisAjsCktAlt; + double complex*LS_CisAjsCktAltDC; LS_CisAjs = (double complex*)malloc(sizeof(double complex)*_nCisAjs); LS_CisAjsCktAlt = (double complex*)malloc(sizeof(double complex)*_nCisAjsCktAlt); + LS_CisAjsCktAltDC = (double complex*)malloc(sizeof(double complex)*_nCisAjsCktAltDC); /* zvo_ls.dat */ if(!CalculateEne(creal(_QQQQ[2]),creal(_QQQQ[3]), @@ -222,19 +241,29 @@ int PhysCalLanczos_fcmp( fprintf(_FileLSQCisAjsCktAltQ, "\n"); #endif CalculatePhysVal_fcmp(_QQQQ[2], _QQQQ[3], + alpha, _QCisAjsCktAltQDC, _nCisAjsCktAltDC, + _nLSHam, LS_CisAjsCktAltDC); + /* zvo_ls_cisajscktalt.dat */ + for (i = 0; i < _nCisAjsCktAltDC; i++) { + fprintf(_FileLSCisAjsCktAltDC, "%d %d %d %d %d %d %d %d % .18e % .18e\n", + _CisAjsCktAltDC[i][0], _CisAjsCktAltDC[i][1], _CisAjsCktAltDC[i][2], _CisAjsCktAltDC[i][3], + _CisAjsCktAltDC[i][4], _CisAjsCktAltDC[i][5], _CisAjsCktAltDC[i][6], _CisAjsCktAltDC[i][7], + creal(LS_CisAjsCktAltDC[i]), cimag(LS_CisAjsCktAltDC[i])); + } + fprintf(_FileLSCisAjsCktAltDC, "\n"); + + CalculatePhysVal_real(_QQQQ[2], _QQQQ[3], alpha, _QCisAjsCktAltQ, _nCisAjsCktAlt, _nLSHam, LS_CisAjsCktAlt); - /* zvo_ls_cisajs.dat */ + /* zvo_ls_cisajscktaltex.dat */ for (i = 0; i < _nCisAjsCktAlt; i++) { - fprintf(_FileLSCisAjsCktAlt, "%d %d %d %d %d %d %d %d % .18e % .18e\n", - _CisAjsCktAlt[i][0], _CisAjsCktAlt[i][1], _CisAjsCktAlt[i][2], _CisAjsCktAlt[i][3], - _CisAjsCktAlt[i][4], _CisAjsCktAlt[i][5], _CisAjsCktAlt[i][6], _CisAjsCktAlt[i][7], - creal(LS_CisAjsCktAlt[i]), cimag(LS_CisAjsCktAlt[i])); + fprintf(_FileLSCisAjsCktAlt, "% .18e % .18e ", creal(LS_CisAjsCktAlt[i]), cimag(LS_CisAjsCktAlt[i])); // LS_CisAjsCktAlt_real } fprintf(_FileLSCisAjsCktAlt, "\n"); } free(LS_CisAjs); free(LS_CisAjsCktAlt); + free(LS_CisAjsCktAltDC); return 0; } diff --git a/src/mVMC/readdef.c b/src/mVMC/readdef.c index bd0c555a..c26bd4fb 100644 --- a/src/mVMC/readdef.c +++ b/src/mVMC/readdef.c @@ -89,10 +89,10 @@ int GetInfoInterAll(FILE *fp, int **ArrayIdx, double complex *ArrayValue, int GetInfoOptTrans(FILE *fp, int **Array, double *ArrayPara, int *ArrayOpt, int **ArraySgn, int _iFlagOptTrans, int *iOptCount, int _fidx, int _APFlag, int Nsite, int NArray, char *defname); -int GetInfoTwoBodyG(FILE *fp, int **ArrayIdx, int **ArrayIdxTwoBodyGLz, int **ArrayToIdx, int **ArrayIdxOneBodyG, - int _NLanczosMode, int Nsite, int NArray, char *defname); +int GetInfoTwoBodyG(FILE *fp, int **ArrayIdx, int Nsite, int NArray, char *defname); -int GetInfoTwoBodyGEx(FILE *fp, int **ArrayIdx, int Nsite, int NArray, char *defname); +int GetInfoTwoBodyGEx(FILE *fp, int **ArrayIdx, int **ArrayToIdx, int **ArrayIdxOneBodyG, + int Nsite, int NArray, char *defname); int GetInfoOrbitalGeneral(FILE *fp, int **Array, int *ArrayOpt, int **ArraySgn, int *iOptCount, int _fidx, int _iComplexFlag, int _iFlagOrbitalGeneral, int _APFlag, int Nsite, int NArray, @@ -181,7 +181,7 @@ int JudgeOrbitalMode(int *_iFlgOrbitalGeneral, const int _iFlgOrbitalAP, const i return iret; } -int ReadGreen(char *xNameListFile, int Nca, int **caIdx, int Ncacadc, int **cacaDCIdx, int Ns) { +int ReadGreen(char *xNameListFile, int Nca, int **caIdx, int Ncacadc, int **cacaIdx, int Ns) { FILE *fp; char defname[D_FileNameMax]; char ctmp[D_FileNameMax]; @@ -217,9 +217,10 @@ int ReadGreen(char *xNameListFile, int Nca, int **caIdx, int Ncacadc, int **caca /*cisajs.def----------------------------------------*/ if (GetInfoOneBodyG(fp, caIdx, iOneBodyGIdx, 0, Ns, Nca, defname) != 0) return (-1); break; - case KWTwoBodyG: - /*cisajscktaltdc.def--------------------------------*/ - if (GetInfoTwoBodyG(fp, cacaDCIdx, cacaDCIdx, iOneBodyGIdx, caIdx, 0, Ns, Ncacadc, defname) != 0) return (-1); + case KWTwoBodyGEx: + /*cisajscktalt.def----------------------------------*/ + /*load as if it's DC for index rearranging----------*/ + if (GetInfoTwoBodyG(fp, cacaIdx, Ns, Ncacadc, defname) != 0) return (-1); break; default: break; @@ -235,27 +236,34 @@ int ReadGreen(char *xNameListFile, int Nca, int **caIdx, int Ncacadc, int **caca /// \param Ncacadc Number of CisAjsCktAltDC /// \param Ns Number of sites /// \return Number of calculation target -int CountOneBodyGForLanczos(char *xNameListFile, int Nca, int Ncacadc, int Ns, int **caIdx, int **iFlgOneBodyG) { +int CountOneBodyGForLanczos(char *xNameListFile, int Nca, int Ncacadc, int Ns, int **iFlgOneBodyG) { int info = 0; int i, j, isite1, isite2; int icount = 0; - int **cacaDCIdx; + int **cacaIdx; + int **caIdx; - cacaDCIdx = malloc(sizeof(int *) * Ncacadc); - //pInt=cacaDCIdx[0]; - for (i = 0; i < Ncacadc; i++) { - cacaDCIdx[i] = malloc(sizeof(int) * 8); - } + cacaIdx = malloc(sizeof(int *) * Ncacadc); + for (i = 0; i < Ncacadc; i++) + cacaIdx[i] = malloc(sizeof(int) * 8); + caIdx = malloc(sizeof(int *) * Nca); + for (i = 0; i < Nca; i++) + caIdx[i] = malloc(sizeof(int) * 4); for (i = 0; i < 2 * Ns; i++) { for (j = 0; j < 2 * Ns; j++) { iFlgOneBodyG[i][j] = -1; } } - info = ReadGreen(xNameListFile, Nca, caIdx, Ncacadc, cacaDCIdx, Ns); + info = ReadGreen(xNameListFile, Nca, caIdx, Ncacadc, cacaIdx, Ns); if (info != 0) { - free(cacaDCIdx); + for (i = 0; i < Ncacadc; i++) + free(cacaIdx[i]); + free(cacaIdx); + for (i = 0; i < Nca; i++) + free(caIdx[i]); + free(caIdx); return (info); } @@ -269,20 +277,25 @@ int CountOneBodyGForLanczos(char *xNameListFile, int Nca, int Ncacadc, int Ns, i } //cisajscktalt -> cisajs, cktalt for (i = 0; i < Ncacadc; i++) { - isite1 = cacaDCIdx[i][0] + cacaDCIdx[i][1] * Ns; - isite2 = cacaDCIdx[i][2] + cacaDCIdx[i][3] * Ns; + isite1 = cacaIdx[i][0] + cacaIdx[i][1] * Ns; + isite2 = cacaIdx[i][2] + cacaIdx[i][3] * Ns; if (iFlgOneBodyG[isite1][isite2] == -1) { iFlgOneBodyG[isite1][isite2] = icount; icount++; } - isite1 = cacaDCIdx[i][4] + cacaDCIdx[i][5] * Ns; - isite2 = cacaDCIdx[i][6] + cacaDCIdx[i][7] * Ns; + isite1 = cacaIdx[i][4] + cacaIdx[i][5] * Ns; + isite2 = cacaIdx[i][6] + cacaIdx[i][7] * Ns; if (iFlgOneBodyG[isite1][isite2] == -1) { iFlgOneBodyG[isite1][isite2] = icount; icount++; } } - free(cacaDCIdx); + for (i = 0; i < Ncacadc; i++) + free(cacaIdx[i]); + free(cacaIdx); + for (i = 0; i < Nca; i++) + free(caIdx[i]); + free(caIdx); return icount; } @@ -487,23 +500,17 @@ int ReadDefFileNInt(char *xNameListFile, MPI_Comm comm) { //TODO: LanczosMode is not supported for Sz not conserved mode. - //For Lanczos mode: Calculation of Green's function - if (bufInt[IdxLanczosMode] > 1) { - //Get info of CisAjs and CisAjsCktAltDC + //For indirect calculation of Green's function + if (bufInt[IdxNTwoBodyGEx] > 0 || bufInt[IdxLanczosMode] > 1) { + //Get info of CisAjs and CisAjsCktAlt(GreenTwoEx as if it's DC) int i; - NCisAjsLz = bufInt[IdxNOneBodyG]; - //bufInt[IdxNTwoBodyGEx] = bufInt[IdxNTwoBodyG]; - CisAjsLzIdx = malloc(sizeof(int *) * NCisAjsLz); - for (i = 0; i < NCisAjsLz; i++) { - CisAjsLzIdx[i] = malloc(sizeof(int) * 4); - } iOneBodyGIdx = malloc(sizeof(int *) * (2 * bufInt[IdxNsite])); //For spin - //pInt=iFlgOneBodyG[0]; for (i = 0; i < 2 * bufInt[IdxNsite]; i++) { iOneBodyGIdx[i] = malloc(sizeof(int) * (2 * bufInt[IdxNsite])); } - bufInt[IdxNOneBodyG] = CountOneBodyGForLanczos(xNameListFile, NCisAjsLz, bufInt[IdxNTwoBodyG], - bufInt[IdxNsite], CisAjsLzIdx, iOneBodyGIdx); + bufInt[IdxNOneBodyG] = CountOneBodyGForLanczos(xNameListFile, + bufInt[IdxNOneBodyG], bufInt[IdxNTwoBodyGEx], + bufInt[IdxNsite], iOneBodyGIdx); } //CalcNCond @@ -690,7 +697,7 @@ int ReadDefFileNInt(char *xNameListFile, MPI_Comm comm) { + Nsite * NQPTrans /* QPTransInv */ + Nsite * NQPTrans /* QPTransSgn */ + 4 * NCisAjs /* CisAjs */ - + 8 * NCisAjsCktAlt /* CisAjsCktAlt */ + + 2 * NCisAjsCktAlt /* CisAjsCktAlt */ + 8 * NCisAjsCktAltDC /* CisAjsCktAltDC */ + 8 * NInterAll /* InterAll */ + Nsite * NQPOptTrans /* QPOptTrans */ @@ -735,8 +742,6 @@ int ReadDefFileIdxPara(char *xNameListFile, MPI_Comm comm) { int x0, x1; int rank; - int iNOneBodyG; - MPI_Comm_rank(comm, &rank); if (rank == 0) { @@ -849,19 +854,17 @@ int ReadDefFileIdxPara(char *xNameListFile, MPI_Comm comm) { case KWOneBodyG: /*cisajs.def----------------------------------------*/ - iNOneBodyG = (NLanczosMode < 2) ? NCisAjs : NCisAjsLz; - if (GetInfoOneBodyG(fp, CisAjsIdx, iOneBodyGIdx, NLanczosMode, Nsite, iNOneBodyG, defname) != 0) info = 1; + if (GetInfoOneBodyG(fp, CisAjsIdx, iOneBodyGIdx, NCisAjsCktAlt>0, Nsite, NCisAjs, defname) != 0) info = 1; break; case KWTwoBodyGEx: /*cisajscktalt.def----------------------------------*/ - if (GetInfoTwoBodyGEx(fp, CisAjsCktAltIdx, Nsite, NCisAjsCktAlt, defname) != 0) info = 1; + if (GetInfoTwoBodyGEx(fp, CisAjsCktAltIdx, iOneBodyGIdx, CisAjsIdx, Nsite, NCisAjsCktAlt, defname) != 0) info = 1; break; case KWTwoBodyG: /*cisajscktaltdc.def--------------------------------*/ - if (GetInfoTwoBodyG(fp, CisAjsCktAltDCIdx, CisAjsCktAltLzIdx, iOneBodyGIdx, CisAjsIdx, NLanczosMode, Nsite, - NCisAjsCktAltDC, defname) != 0) + if (GetInfoTwoBodyG(fp, CisAjsCktAltDCIdx, Nsite, NCisAjsCktAltDC, defname) != 0) info = 1; break; @@ -968,9 +971,6 @@ int ReadDefFileIdxPara(char *xNameListFile, MPI_Comm comm) { */ #ifdef _mpi_use SafeMpiBcastInt(LocSpn, NTotalDefInt, comm); - if (NLanczosMode > 1) { - SafeMpiBcastInt(CisAjsCktAltLzIdx[0], NCisAjsCktAltDC * 2, comm); - } SafeMpiBcast_fcmp(ParaTransfer, NTransfer + NInterAll, comm); SafeMpiBcast(ParaCoulombIntra, NTotalDefDouble, comm); SafeMpiBcast_fcmp(ParaQPTrans, NQPTrans, comm); @@ -1915,7 +1915,7 @@ int GetInfoTransSym(FILE *fp, int **Array, int **ArraySgn, int **ArrayInv, doubl } int -GetInfoOneBodyG(FILE *fp, int **ArrayIdx, int **ArrayToIdx, int _NLanczosMode, int Nsite, int NArray, char *defname) { +GetInfoOneBodyG(FILE *fp, int **ArrayIdx, int **ArrayToIdx, int IndirectGFOn, int Nsite, int NArray, char *defname) { char ctmp2[256]; int idx = 0, info = 0; int x0 = 0, x1 = 0, x2 = 0, x3 = 0; @@ -1924,12 +1924,12 @@ GetInfoOneBodyG(FILE *fp, int **ArrayIdx, int **ArrayToIdx, int _NLanczosMode, i if (NArray == 0) return 0; while (fgets(ctmp2, sizeof(ctmp2) / sizeof(char), fp) != NULL) { sscanf(ctmp2, "%d %d %d %d\n", &x0, &x1, &x2, &x3); - if (_NLanczosMode < 2) { // Normal + if (!IndirectGFOn) { // Normal ArrayIdx[idx][0] = x0; ArrayIdx[idx][1] = x1; ArrayIdx[idx][2] = x2; ArrayIdx[idx][3] = x3; - } else { //For Calc Green func by Lanczos mode + } else { //For Calc Green func indirectly isite1 = x0 + x1 * Nsite; isite2 = x2 + x3 * Nsite; idxLanczos = ArrayToIdx[isite1][isite2]; @@ -1946,27 +1946,41 @@ GetInfoOneBodyG(FILE *fp, int **ArrayIdx, int **ArrayToIdx, int _NLanczosMode, i idx++; } - if (idx != NArray) info = ReadDefFileError(defname); + if (!IndirectGFOn && idx != NArray) + info = ReadDefFileError(defname); return info; } -int GetInfoTwoBodyGEx(FILE *fp, int **ArrayIdx, int Nsite, int NArray, char *defname) { +// Formerly CisAjsCktAlt +int GetInfoTwoBodyGEx(FILE *fp, int **ArrayIdx, int **ArrayToIdx, int **ArrayIdxOneBodyG, + int Nsite, int NArray, char *defname) { char ctmp2[256]; int idx = 0, info = 0; int x0 = 0, x1 = 0, x2 = 0, x3 = 0; int x4 = 0, x5 = 0, x6 = 0, x7 = 0; + int isite1 = 0, isite2 = 0; + int idxLanczos = 0; + if (NArray == 0) return 0; while (fgets(ctmp2, sizeof(ctmp2) / sizeof(char), fp) != NULL) { sscanf(ctmp2, "%d %d %d %d %d %d %d %d\n", &x0, &x1, &x2, &x3, &x4, &x5, &x6, &x7); - ArrayIdx[idx][0] = x0; - ArrayIdx[idx][1] = x1; - ArrayIdx[idx][2] = x2; - ArrayIdx[idx][3] = x3; - ArrayIdx[idx][4] = x4; - ArrayIdx[idx][5] = x5; - ArrayIdx[idx][6] = x6; - ArrayIdx[idx][7] = x7; - if (CheckQuadSite(x2, x3, x5, x6, Nsite) != 0) { + isite1 = x0 + x1 * Nsite; + isite2 = x2 + x3 * Nsite; + idxLanczos = ArrayToIdx[isite1][isite2]; + ArrayIdxOneBodyG[idxLanczos][0] = x0; + ArrayIdxOneBodyG[idxLanczos][1] = x1; + ArrayIdxOneBodyG[idxLanczos][2] = x2; + ArrayIdxOneBodyG[idxLanczos][3] = x3; + ArrayIdx[idx][0] = idxLanczos; + isite1 = x4 + x5 * Nsite; + isite2 = x6 + x7 * Nsite; + idxLanczos = ArrayToIdx[isite1][isite2]; + ArrayIdxOneBodyG[idxLanczos][0] = x4; + ArrayIdxOneBodyG[idxLanczos][1] = x5; + ArrayIdxOneBodyG[idxLanczos][2] = x6; + ArrayIdxOneBodyG[idxLanczos][3] = x7; + ArrayIdx[idx][1] = idxLanczos; + if (CheckQuadSite(x0, x2, x4, x6, Nsite) != 0) { fprintf(stderr, "Error: Site index is incorrect. \n"); info = 1; break; @@ -1977,8 +1991,8 @@ int GetInfoTwoBodyGEx(FILE *fp, int **ArrayIdx, int Nsite, int NArray, char *def return info; } -int GetInfoTwoBodyG(FILE *fp, int **ArrayIdx, int **ArrayIdxTwoBodyGLz, int **ArrayToIdx, int **ArrayIdxOneBodyG, - int _NLanczosMode, int Nsite, int NArray, char *defname) { +// Formerly CisAjsCktAltDC +int GetInfoTwoBodyG(FILE *fp, int **ArrayIdx, int Nsite, int NArray, char *defname) { char ctmp2[256]; int idx = 0, info = 0; int x0 = 0, x1 = 0, x2 = 0, x3 = 0; @@ -2003,25 +2017,6 @@ int GetInfoTwoBodyG(FILE *fp, int **ArrayIdx, int **ArrayIdxTwoBodyGLz, int **Ar break; } - if (_NLanczosMode > 1) { //Calc TwoBodyG by Lanczos method - isite1 = x0 + x1 * Nsite; - isite2 = x2 + x3 * Nsite; - idxLanczos = ArrayToIdx[isite1][isite2]; - ArrayIdxOneBodyG[idxLanczos][0] = x0; - ArrayIdxOneBodyG[idxLanczos][1] = x1; - ArrayIdxOneBodyG[idxLanczos][2] = x2; - ArrayIdxOneBodyG[idxLanczos][3] = x3; - ArrayIdxTwoBodyGLz[idx][0] = idxLanczos; - - isite1 = x4 + x5 * Nsite; - isite2 = x6 + x7 * Nsite; - idxLanczos = ArrayToIdx[isite1][isite2]; - ArrayIdxOneBodyG[idxLanczos][0] = x4; - ArrayIdxOneBodyG[idxLanczos][1] = x5; - ArrayIdxOneBodyG[idxLanczos][2] = x6; - ArrayIdxOneBodyG[idxLanczos][3] = x7; - ArrayIdxTwoBodyGLz[idx][1] = idxLanczos; - } idx++; } if (idx != NArray) info = ReadDefFileError(defname); diff --git a/src/mVMC/setmemory.c b/src/mVMC/setmemory.c index 5166eb1d..2f199c89 100644 --- a/src/mVMC/setmemory.c +++ b/src/mVMC/setmemory.c @@ -163,7 +163,7 @@ void SetMemoryDef() { CisAjsCktAltIdx = (int**)malloc(sizeof(int*)*NCisAjsCktAlt); for(i=0;i1){ - CisAjsCktAltLzIdx = malloc(sizeof(int*)*NCisAjsCktAltDC); - for(i=0;i0) { + for(i=0;i<2*Nsite;i++) + free(iOneBodyGIdx[i]); + free(iOneBodyGIdx); + } free(QPOptTransSgn); free(QPOptTrans); @@ -243,6 +241,7 @@ void FreeMemoryDef() { free(DoublonHolon4siteIdx); free(DoublonHolon2siteIdx); free(JastrowIdx); + free(ParaTransfer); free(ExchangeCoupling); free(PairHopping); free(HundCoupling); @@ -382,14 +381,16 @@ void SetMemory() { if(NLanczosMode>1){ QCisAjsQ = (double complex*)malloc(sizeof(double complex) - *(NLSHam*NLSHam*NCisAjs + NLSHam*NLSHam*NCisAjsCktAltDC + NLSHam*NCisAjs) ); + *(NLSHam*NLSHam*NCisAjs + NLSHam*NLSHam*(NCisAjsCktAltDC+NCisAjsCktAlt) + NLSHam*NCisAjs) ); QCisAjsCktAltQ = QCisAjsQ + NLSHam*NLSHam*NCisAjs; - LSLCisAjs = QCisAjsCktAltQ + NLSHam*NLSHam*NCisAjsCktAltDC; + QCisAjsCktAltQDC = QCisAjsCktAltQ + NLSHam*NLSHam*NCisAjsCktAlt; + LSLCisAjs = QCisAjsCktAltQDC + NLSHam*NLSHam*NCisAjsCktAltDC; //for real QCisAjsQ_real = (double *)malloc(sizeof(double ) - *(NLSHam*NLSHam*NCisAjs + NLSHam*NLSHam*NCisAjsCktAltDC + NLSHam*NCisAjs) ); + *(NLSHam*NLSHam*NCisAjs + NLSHam*NLSHam*(NCisAjsCktAltDC+NCisAjsCktAlt) + NLSHam*NCisAjs) ); QCisAjsCktAltQ_real = QCisAjsQ_real + NLSHam*NLSHam*NCisAjs; - LSLCisAjs_real = QCisAjsCktAltQ_real + NLSHam*NLSHam*NCisAjsCktAltDC; + QCisAjsCktAltQDC_real = QCisAjsCktAltQ_real + NLSHam*NLSHam*NCisAjsCktAlt; + LSLCisAjs_real = QCisAjsCktAltQDC_real + NLSHam*NLSHam*NCisAjsCktAltDC; } } diff --git a/src/mVMC/vmccal.c b/src/mVMC/vmccal.c index 834d122c..e400819d 100644 --- a/src/mVMC/vmccal.c +++ b/src/mVMC/vmccal.c @@ -276,18 +276,18 @@ void VMCMainCal(MPI_Comm comm) { LSLocalCisAjs_real(creal(e),creal(ip),eleIdx,eleCfg,eleNum,eleProjCnt); calculateQCAQ_real(QCisAjsQ_real,LSLCisAjs_real,LSLQ_real,w,NLSHam,NCisAjs); - //calculateQCACAQ_real(QCisAjsCktAltQ_real,LSLCisAjs_real,w,NLSHam,NCisAjs, - // NCisAjsCktAltDC, CisAjsCktAltLzIdx); - calculateQCACAQDC_real(QCisAjsCktAltQ_real,LSLQ_real,w,NLSHam,NCisAjs, + calculateQCACAQ_real(QCisAjsCktAltQ_real,LSLCisAjs_real,w,NLSHam,NCisAjs, + NCisAjsCktAlt, CisAjsCktAltIdx); + calculateQCACAQDC_real(QCisAjsCktAltQDC_real,LSLQ_real,w,NLSHam,NCisAjs, NCisAjsCktAltDC,eleIdx,eleCfg,eleNum,eleProjCnt,creal(e),creal(ip)); } else{ LSLocalCisAjs(e,ip,eleIdx,eleCfg,eleNum,eleProjCnt); calculateQCAQ(QCisAjsQ,LSLCisAjs,LSLQ,w,NLSHam,NCisAjs); - //calculateQCACAQ(QCisAjsCktAltQ,LSLCisAjs,w,NLSHam,NCisAjs, - // NCisAjsCktAltDC,CisAjsCktAltLzIdx); - calculateQCACAQDC(QCisAjsCktAltQ,LSLQ,w,NLSHam,NCisAjs, + calculateQCACAQ(QCisAjsCktAltQ,LSLCisAjs,w,NLSHam,NCisAjs, + NCisAjsCktAlt,CisAjsCktAltIdx); + calculateQCACAQDC(QCisAjsCktAltQDC,LSLQ,w,NLSHam,NCisAjs, NCisAjsCktAltDC,eleIdx,eleCfg,eleNum,eleProjCnt,e,ip); } StopTimer(44); @@ -521,12 +521,12 @@ for(i=0;i1) { /* QCisAjsQ, QCisAjsCktAltQ, LSLCisAjs */ //[TODO]: Check the value n - n = NLSHam*NLSHam*NCisAjs + NLSHam*NLSHam*NCisAjsCktAltDC + n = NLSHam*NLSHam*NCisAjs + NLSHam*NLSHam*(NCisAjsCktAltDC+NCisAjsCktAlt) + NLSHam*NCisAjs; vec = QCisAjsQ; #pragma omp parallel for default(shared) private(i) for(i=0;i 0) { - if(NLanczosMode <2) { - for (i = 0; i < NCisAjs; i++) { - fprintf(FileCisAjs, "%d %d %d %d % .18e % .18e \n", CisAjsIdx[i][0], CisAjsIdx[i][1], CisAjsIdx[i][2], - CisAjsIdx[i][3], creal(PhysCisAjs[i]), cimag(PhysCisAjs[i])); - } - } - else{ - int idx=0; - for (i = 0; i < NCisAjsLz; i++) { - idx = iOneBodyGIdx[CisAjsLzIdx[i][0] + CisAjsLzIdx[i][1] * Nsite][CisAjsLzIdx[i][2] + - CisAjsLzIdx[i][3] * Nsite]; - //fprintf(stdout, "Debug: idx= %d value= % .18e % .18e\n", idx, creal(PhysCisAjs[idx]), cimag(PhysCisAjs[idx])); - fprintf(FileCisAjs, "%d %d %d %d % .18e % .18e \n", CisAjsLzIdx[idx][0], CisAjsLzIdx[idx][1], - CisAjsLzIdx[idx][2], CisAjsLzIdx[idx][3], creal(PhysCisAjs[idx]), cimag(PhysCisAjs[idx])); - } - } + for (i = 0; i < NCisAjs; i++) + fprintf(FileCisAjs, "%d %d %d %d % .18e % .18e \n", CisAjsIdx[i][0], CisAjsIdx[i][1], CisAjsIdx[i][2], + CisAjsIdx[i][3], creal(PhysCisAjs[i]), cimag(PhysCisAjs[i])); fprintf(FileCisAjs, "\n"); } - /* zvo_cisajscktalt.dat */ + /* zvo_cisajscktaltex.dat */ if (NCisAjsCktAlt > 0) { for (i = 0; i < NCisAjsCktAlt; i++) fprintf(FileCisAjsCktAlt, "% .18e % .18e ", creal(PhysCisAjsCktAlt[i]), cimag(PhysCisAjsCktAlt[i])); fprintf(FileCisAjsCktAlt, "\n"); } - /* zvo_cisajscktaltdc.dat */ + /* zvo_cisajscktalt.dat */ if (NCisAjsCktAltDC > 0) { for (i = 0; i < NCisAjsCktAltDC; i++) { fprintf(FileCisAjsCktAltDC, "%d %d %d %d %d %d %d %d % .18e % .18e\n", @@ -694,16 +681,16 @@ void outputData() { if (NLanczosMode > 0) { if (AllComplexFlag == 0) { //real PhysCalLanczos_real( - QQQQ_real, QCisAjsQ_real, QCisAjsCktAltQ_real, - NLSHam, Nsite, NCisAjs, NCisAjsLz, iOneBodyGIdx, CisAjsLzIdx, NCisAjsCktAltDC, CisAjsCktAltDCIdx, NLanczosMode, - FileLS, FileLSQQQQ, FileLSQCisAjsQ, FileLSQCisAjsCktAltQ, - FileLSCisAjs, FileLSCisAjsCktAlt); + QQQQ_real, QCisAjsQ_real, QCisAjsCktAltQ_real, QCisAjsCktAltQDC_real, + NLSHam, Nsite, NCisAjs, NCisAjs, iOneBodyGIdx, CisAjsIdx, NCisAjsCktAlt, NCisAjsCktAltDC, CisAjsCktAltDCIdx, + NLanczosMode, FileLS, FileLSQQQQ, FileLSQCisAjsQ, FileLSQCisAjsCktAltQ, + FileLSCisAjs, FileLSCisAjsCktAlt, FileLSCisAjsCktAltDC); }else { //complex PhysCalLanczos_fcmp( - QQQQ, QCisAjsQ, QCisAjsCktAltQ, - NLSHam, Nsite, NCisAjs, NCisAjsLz, iOneBodyGIdx, CisAjsLzIdx, NCisAjsCktAltDC, CisAjsCktAltDCIdx, NLanczosMode, - FileLS, FileLSQQQQ, FileLSQCisAjsQ, FileLSQCisAjsCktAltQ, - FileLSCisAjs, FileLSCisAjsCktAlt); + QQQQ, QCisAjsQ, QCisAjsCktAltQ, QCisAjsCktAltQDC, + NLSHam, Nsite, NCisAjs, NCisAjs, iOneBodyGIdx, CisAjsIdx, NCisAjsCktAlt, NCisAjsCktAltDC, CisAjsCktAltDCIdx, + NLanczosMode, FileLS, FileLSQQQQ, FileLSQCisAjsQ, FileLSQCisAjsCktAltQ, + FileLSCisAjs, FileLSCisAjsCktAlt, FileLSCisAjsCktAltDC); } } } From c88c6bcbc05a1db7ceb4bb3ad958e805593c5507 Mon Sep 17 00:00:00 2001 From: RuQing Xu Date: Tue, 30 Jul 2019 23:39:54 +0800 Subject: [PATCH 07/10] Fix a Typo In Printing Indirect GF2 --- src/mVMC/physcal_lanczos.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/mVMC/physcal_lanczos.c b/src/mVMC/physcal_lanczos.c index 7eb6891a..13640256 100644 --- a/src/mVMC/physcal_lanczos.c +++ b/src/mVMC/physcal_lanczos.c @@ -252,7 +252,7 @@ int PhysCalLanczos_fcmp( } fprintf(_FileLSCisAjsCktAltDC, "\n"); - CalculatePhysVal_real(_QQQQ[2], _QQQQ[3], + CalculatePhysVal_fcmp(_QQQQ[2], _QQQQ[3], alpha, _QCisAjsCktAltQ, _nCisAjsCktAlt, _nLSHam, LS_CisAjsCktAlt); /* zvo_ls_cisajscktaltex.dat */ From 5474dd4f9d5eaac6775186f4021e56b81b900df0 Mon Sep 17 00:00:00 2001 From: Takahiro Misawa Date: Tue, 1 Oct 2024 15:23:17 +0900 Subject: [PATCH 08/10] Revert "Rebased "Separating Direct and Indirect Measurement of Two Body Green Function"" --- src/mVMC/average.c | 2 +- src/mVMC/calgrn.c | 7 +- src/mVMC/include/global.h | 11 +- src/mVMC/include/physcal_lanczos.h | 14 +-- src/mVMC/initfile.c | 9 +- src/mVMC/physcal_lanczos.c | 59 +++------- src/mVMC/readdef.c | 182 ++++++++++++++++------------- src/mVMC/setmemory.c | 32 +++-- src/mVMC/vmccal.c | 86 +------------- src/mVMC/vmcmain.c | 39 ++++--- 10 files changed, 171 insertions(+), 270 deletions(-) diff --git a/src/mVMC/average.c b/src/mVMC/average.c index f4954818..4cb0749e 100644 --- a/src/mVMC/average.c +++ b/src/mVMC/average.c @@ -230,7 +230,7 @@ void WeightAverageGreenFunc(MPI_Comm comm) { } if(NLanczosMode>1){ /* QCisAjsQ and QCisAjsCktAltQ */ - n = NLSHam*NLSHam*NCisAjs + NLSHam*NLSHam*(NCisAjsCktAltDC+NCisAjsCktAlt); + n = NLSHam*NLSHam*NCisAjs + NLSHam*NLSHam*NCisAjsCktAltDC; if(AllComplexFlag==0){ vec_real=QCisAjsQ_real; weightAverageReduce_real(n,vec_real,comm); diff --git a/src/mVMC/calgrn.c b/src/mVMC/calgrn.c index 16fc3864..8d13215b 100644 --- a/src/mVMC/calgrn.c +++ b/src/mVMC/calgrn.c @@ -81,7 +81,7 @@ void CalculateGreenFunc(const double w, const double complex ip, int *eleIdx, in tmp = GreenFunc2(ri,rj,rk,rl,s,t,ip,myEleIdx,eleCfg,myEleNum,eleProjCnt, myProjCntNew,myBuffer); - LocalCisAjsCktAltDC[idx] = tmp; + PhysCisAjsCktAltDC[idx] += w*tmp; } #pragma omp master @@ -92,11 +92,6 @@ void CalculateGreenFunc(const double w, const double complex ip, int *eleIdx, in PhysCisAjs[idx] += w*LocalCisAjs[idx]; } - #pragma omp for private(idx) nowait - for (idx=0;idx, */ @@ -286,13 +286,10 @@ double *LSLQ_real; /* [NLSHam][NLSHam]*/ //TBC double complex *QCisAjsQ; /* QCisAjsQ[NLSHam][NLSHam][NCisAjs]*/ //TBC double complex *QCisAjsCktAltQ; /* QCisAjsCktAltQ[NLSHam][NLSHam][NCisAjsCktAlt]*/ //TBC -double complex *QCisAjsCktAltQDC; /* QCisAjsCktAltQ[NLSHam][NLSHam][NCisAjsCktAlt] - DC Lanczos Calculation */ double complex *LSLCisAjs; /* [NLSHam][NCisAjs]*/ //TBC double *QCisAjsQ_real; /* QCisAjsQ[NLSHam][NLSHam][NCisAjs]*/ //TBC double *QCisAjsCktAltQ_real; /* QCisAjsCktAltQ[NLSHam][NLSHam][NCisAjsCktAlt]*/ //TBC -double *QCisAjsCktAltQDC_real; /* QCisAjsCktAltQ[NLSHam][NLSHam][NCisAjsCktAlt]*/ double *LSLCisAjs_real; /* [NLSHam][NCisAjs]*/ //TBC /***** Output File *****/ @@ -308,10 +305,8 @@ FILE *FileLS; FILE *FileLSQQQQ; FILE *FileLSQCisAjsQ; FILE *FileLSQCisAjsCktAltQ; -FILE *FileLSQCisAjsCktAltQ; FILE *FileLSCisAjs; FILE *FileLSCisAjsCktAlt; -FILE *FileLSCisAjsCktAltDC; /* FILE *FileTimerList; */ diff --git a/src/mVMC/include/physcal_lanczos.h b/src/mVMC/include/physcal_lanczos.h index 27dbf7ff..9dd02cce 100644 --- a/src/mVMC/include/physcal_lanczos.h +++ b/src/mVMC/include/physcal_lanczos.h @@ -7,7 +7,6 @@ int PhysCalLanczos_real( double *_QQQQ_real, double *_QCisAjsQ_real, double *_QCisAjsCktAltQ_real, - double *_QCisAjsCktAltQDC_real, const int _nLSHam, const int _Ns, const int _nCisAjs, @@ -15,23 +14,20 @@ int PhysCalLanczos_real( int **_iOneBodyGIdx, int **_CisAjsLzIdx, const int _nCisAjsCktAlt, - const int _nCisAjsCktAltDC, - int **_CisAjsCktAltDC, + int **_CisAjsCktAlt, const int _NLanczosmode, FILE *_FileLS, FILE *_FileLSQQQQ, FILE *_FileLSQCisAjsQ, FILE *_FileLSQCisAjsCktAltQ, FILE *_FileLSCisAjs, - FILE *_FileLSCisAjsCktAlt, - FILE *_FileLSCisAjsCktAltDC + FILE *_FileLSCisAjsCktAlt ); int PhysCalLanczos_fcmp( double complex* _QQQQ, double complex* _QCisAjsQ, double complex* _QCisAjsCktAltQ, - double complex* _QCisAjsCktAltQDC, const int _nLSHam, const int _Ns, const int _nCisAjs, @@ -39,16 +35,14 @@ int PhysCalLanczos_fcmp( int **_iOneBodyGIdx, int **_CisAjsLzIdx, const int _nCisAjsCktAlt, - const int _nCisAjsCktAltDC, - int **_CisAjsCktAltDC, + int **_CisAjsCktAlt, const int _NLanczosmode, FILE *_FileLS, FILE *_FileLSQQQQ, FILE *_FileLSQCisAjsQ, FILE *_FileLSQCisAjsCktAltQ, FILE *_FileLSCisAjs, - FILE *_FileLSCisAjsCktAlt, - FILE *_FileLSCisAjsCktAltDC + FILE *_FileLSCisAjsCktAlt ); #endif diff --git a/src/mVMC/initfile.c b/src/mVMC/initfile.c index 80a04f38..815f971f 100644 --- a/src/mVMC/initfile.c +++ b/src/mVMC/initfile.c @@ -126,15 +126,9 @@ void InitFilePhysCal(int i, int rank) { CDataFileHead, idx); FileLSCisAjs = fopen(fileName, "w"); - // CACA - sprintf(fileName, "%s_ls_cisajscktaltex_%03d.dat", - CDataFileHead, idx); - FileLSCisAjsCktAlt = fopen(fileName, "w"); - - // CACADC sprintf(fileName, "%s_ls_cisajscktalt_%03d.dat", CDataFileHead, idx); - FileLSCisAjsCktAltDC = fopen(fileName, "w"); + FileLSCisAjsCktAlt = fopen(fileName, "w"); } } @@ -182,7 +176,6 @@ void CloseFilePhysCal(int rank) { #endif fclose(FileLSCisAjs); fclose(FileLSCisAjsCktAlt); - fclose(FileLSCisAjsCktAltDC); } } diff --git a/src/mVMC/physcal_lanczos.c b/src/mVMC/physcal_lanczos.c index 13640256..26b9782a 100644 --- a/src/mVMC/physcal_lanczos.c +++ b/src/mVMC/physcal_lanczos.c @@ -29,7 +29,6 @@ int PhysCalLanczos_real double *_QQQQ_real, double *_QCisAjsQ_real, double *_QCisAjsCktAltQ_real, - double *_QCisAjsCktAltQDC_real, const int _nLSHam, const int _Ns, const int _nCisAjs, @@ -37,16 +36,14 @@ int PhysCalLanczos_real int **_iOneBodyGIdx, int **_CisAjsLzIdx, const int _nCisAjsCktAlt, - const int _nCisAjsCktAltDC, - int **_CisAjsCktAltDC, + int **_CisAjsCktAlt, const int _NLanczosmode, FILE *_FileLS, FILE *_FileLSQQQQ, FILE *_FileLSQCisAjsQ, FILE *_FileLSQCisAjsCktAltQ, FILE *_FileLSCisAjs, - FILE *_FileLSCisAjsCktAlt, - FILE *_FileLSCisAjsCktAltDC + FILE *_FileLSCisAjsCktAlt ) { int i=0; @@ -56,10 +53,8 @@ int PhysCalLanczos_real double alpha_m, ene_m, ene_vm; double *LS_CisAjs_real; double *LS_CisAjsCktAlt_real; - double *LS_CisAjsCktAltDC_real; LS_CisAjs_real = (double*)malloc(sizeof(double)*_nCisAjs); LS_CisAjsCktAlt_real = (double*)malloc(sizeof(double)*_nCisAjsCktAlt); - LS_CisAjsCktAltDC_real = (double*)malloc(sizeof(double)*_nCisAjsCktAltDC); CalculateEne(_QQQQ_real[2], _QQQQ_real[3], _QQQQ_real[10], _QQQQ_real[11], _QQQQ_real[15], &alpha_p, &ene_p, &ene_vp, &alpha_m, &ene_m, &ene_vm); @@ -119,30 +114,21 @@ int PhysCalLanczos_real fprintf(_FileLSQCisAjsCktAltQ, "\n"); #endif - CalculatePhysVal_real(_QQQQ_real[2], _QQQQ_real[3], - alpha, _QCisAjsCktAltQDC_real, _nCisAjsCktAltDC, - _nLSHam, LS_CisAjsCktAltDC_real); - /* zvo_ls_cisajscktalt.dat */ - for (i = 0; i < _nCisAjsCktAltDC; i++) { - fprintf(_FileLSCisAjsCktAltDC, "%d %d %d %d %d %d %d %d % .18e 0.0\n", - _CisAjsCktAltDC[i][0], _CisAjsCktAltDC[i][1], _CisAjsCktAltDC[i][2], _CisAjsCktAltDC[i][3], - _CisAjsCktAltDC[i][4], _CisAjsCktAltDC[i][5], _CisAjsCktAltDC[i][6], _CisAjsCktAltDC[i][7], - LS_CisAjsCktAltDC_real[i]); - } - fprintf(_FileLSCisAjsCktAltDC, "\n"); - CalculatePhysVal_real(_QQQQ_real[2], _QQQQ_real[3], alpha, _QCisAjsCktAltQ_real, _nCisAjsCktAlt, _nLSHam, LS_CisAjsCktAlt_real); - /* zvo_ls_cisajscktaltex.dat */ + /* zvo_ls_cisajscktalt.dat */ for (i = 0; i < _nCisAjsCktAlt; i++) { - fprintf(_FileLSCisAjsCktAlt, "% .18e 0.0 ", LS_CisAjsCktAlt_real[i]); // LS_CisAjsCktAlt_real + fprintf(_FileLSCisAjsCktAlt, "%d %d %d %d %d %d %d %d % .18e 0.0\n", + _CisAjsCktAlt[i][0], _CisAjsCktAlt[i][1], _CisAjsCktAlt[i][2], _CisAjsCktAlt[i][3], + _CisAjsCktAlt[i][4], _CisAjsCktAlt[i][5], _CisAjsCktAlt[i][6], _CisAjsCktAlt[i][7], + LS_CisAjsCktAlt_real[i]); + } fprintf(_FileLSCisAjsCktAlt, "\n"); } free(LS_CisAjs_real); free(LS_CisAjsCktAlt_real); - free(LS_CisAjsCktAltDC_real); return 0; } @@ -150,7 +136,6 @@ int PhysCalLanczos_fcmp( double complex* _QQQQ, double complex* _QCisAjsQ, double complex* _QCisAjsCktAltQ, - double complex* _QCisAjsCktAltQDC, const int _nLSHam, const int _Ns, const int _nCisAjs, @@ -158,16 +143,14 @@ int PhysCalLanczos_fcmp( int **_iOneBodyGIdx, int **_CisAjsLzIdx, const int _nCisAjsCktAlt, - const int _nCisAjsCktAltDC, - int **_CisAjsCktAltDC, + int **_CisAjsCktAlt, const int _NLanczosmode, FILE *_FileLS, FILE *_FileLSQQQQ, FILE *_FileLSQCisAjsQ, FILE *_FileLSQCisAjsCktAltQ, FILE *_FileLSCisAjs, - FILE *_FileLSCisAjsCktAlt, - FILE *_FileLSCisAjsCktAltDC + FILE *_FileLSCisAjsCktAlt ) { int i=0; @@ -177,10 +160,8 @@ int PhysCalLanczos_fcmp( double alpha_m, ene_m, ene_vm; double complex*LS_CisAjs; double complex*LS_CisAjsCktAlt; - double complex*LS_CisAjsCktAltDC; LS_CisAjs = (double complex*)malloc(sizeof(double complex)*_nCisAjs); LS_CisAjsCktAlt = (double complex*)malloc(sizeof(double complex)*_nCisAjsCktAlt); - LS_CisAjsCktAltDC = (double complex*)malloc(sizeof(double complex)*_nCisAjsCktAltDC); /* zvo_ls.dat */ if(!CalculateEne(creal(_QQQQ[2]),creal(_QQQQ[3]), @@ -240,30 +221,20 @@ int PhysCalLanczos_fcmp( } fprintf(_FileLSQCisAjsCktAltQ, "\n"); #endif - CalculatePhysVal_fcmp(_QQQQ[2], _QQQQ[3], - alpha, _QCisAjsCktAltQDC, _nCisAjsCktAltDC, - _nLSHam, LS_CisAjsCktAltDC); - /* zvo_ls_cisajscktalt.dat */ - for (i = 0; i < _nCisAjsCktAltDC; i++) { - fprintf(_FileLSCisAjsCktAltDC, "%d %d %d %d %d %d %d %d % .18e % .18e\n", - _CisAjsCktAltDC[i][0], _CisAjsCktAltDC[i][1], _CisAjsCktAltDC[i][2], _CisAjsCktAltDC[i][3], - _CisAjsCktAltDC[i][4], _CisAjsCktAltDC[i][5], _CisAjsCktAltDC[i][6], _CisAjsCktAltDC[i][7], - creal(LS_CisAjsCktAltDC[i]), cimag(LS_CisAjsCktAltDC[i])); - } - fprintf(_FileLSCisAjsCktAltDC, "\n"); - CalculatePhysVal_fcmp(_QQQQ[2], _QQQQ[3], alpha, _QCisAjsCktAltQ, _nCisAjsCktAlt, _nLSHam, LS_CisAjsCktAlt); - /* zvo_ls_cisajscktaltex.dat */ + /* zvo_ls_cisajs.dat */ for (i = 0; i < _nCisAjsCktAlt; i++) { - fprintf(_FileLSCisAjsCktAlt, "% .18e % .18e ", creal(LS_CisAjsCktAlt[i]), cimag(LS_CisAjsCktAlt[i])); // LS_CisAjsCktAlt_real + fprintf(_FileLSCisAjsCktAlt, "%d %d %d %d %d %d %d %d % .18e % .18e\n", + _CisAjsCktAlt[i][0], _CisAjsCktAlt[i][1], _CisAjsCktAlt[i][2], _CisAjsCktAlt[i][3], + _CisAjsCktAlt[i][4], _CisAjsCktAlt[i][5], _CisAjsCktAlt[i][6], _CisAjsCktAlt[i][7], + creal(LS_CisAjsCktAlt[i]), cimag(LS_CisAjsCktAlt[i])); } fprintf(_FileLSCisAjsCktAlt, "\n"); } free(LS_CisAjs); free(LS_CisAjsCktAlt); - free(LS_CisAjsCktAltDC); return 0; } diff --git a/src/mVMC/readdef.c b/src/mVMC/readdef.c index 36ac357f..5b51600b 100644 --- a/src/mVMC/readdef.c +++ b/src/mVMC/readdef.c @@ -89,10 +89,10 @@ int GetInfoInterAll(FILE *fp, int **ArrayIdx, double complex *ArrayValue, int GetInfoOptTrans(FILE *fp, int **Array, double *ArrayPara, int *ArrayOpt, int **ArraySgn, int _iFlagOptTrans, int *iOptCount, int _fidx, int _APFlag, int Nsite, int NArray, char *defname); -int GetInfoTwoBodyG(FILE *fp, int **ArrayIdx, int Nsite, int NArray, char *defname); +int GetInfoTwoBodyG(FILE *fp, int **ArrayIdx, int **ArrayIdxTwoBodyGLz, int **ArrayToIdx, int **ArrayIdxOneBodyG, + int _NLanczosMode, int Nsite, int NArray, char *defname); -int GetInfoTwoBodyGEx(FILE *fp, int **ArrayIdx, int **ArrayToIdx, int **ArrayIdxOneBodyG, - int Nsite, int NArray, char *defname); +int GetInfoTwoBodyGEx(FILE *fp, int **ArrayIdx, int Nsite, int NArray, char *defname); int GetInfoOrbitalGeneral(FILE *fp, int **Array, int *ArrayOpt, int **ArraySgn, int *iOptCount, int _fidx, int _iComplexFlag, int _iFlagOrbitalGeneral, int _APFlag, int Nsite, int NArray, @@ -181,7 +181,7 @@ int JudgeOrbitalMode(int *_iFlgOrbitalGeneral, const int _iFlgOrbitalAP, const i return iret; } -int ReadGreen(char *xNameListFile, int Nca, int **caIdx, int Ncacadc, int **cacaIdx, int Ns) { +int ReadGreen(char *xNameListFile, int Nca, int **caIdx, int Ncacadc, int **cacaDCIdx, int Ns) { FILE *fp; char defname[D_FileNameMax]; char ctmp[D_FileNameMax]; @@ -217,10 +217,9 @@ int ReadGreen(char *xNameListFile, int Nca, int **caIdx, int Ncacadc, int **caca /*cisajs.def----------------------------------------*/ if (GetInfoOneBodyG(fp, caIdx, iOneBodyGIdx, 0, Ns, Nca, defname) != 0) return (-1); break; - case KWTwoBodyGEx: - /*cisajscktalt.def----------------------------------*/ - /*load as if it's DC for index rearranging----------*/ - if (GetInfoTwoBodyG(fp, cacaIdx, Ns, Ncacadc, defname) != 0) return (-1); + case KWTwoBodyG: + /*cisajscktaltdc.def--------------------------------*/ + if (GetInfoTwoBodyG(fp, cacaDCIdx, cacaDCIdx, iOneBodyGIdx, caIdx, 0, Ns, Ncacadc, defname) != 0) return (-1); break; default: break; @@ -236,34 +235,27 @@ int ReadGreen(char *xNameListFile, int Nca, int **caIdx, int Ncacadc, int **caca /// \param Ncacadc Number of CisAjsCktAltDC /// \param Ns Number of sites /// \return Number of calculation target -int CountOneBodyGForLanczos(char *xNameListFile, int Nca, int Ncacadc, int Ns, int **iFlgOneBodyG) { +int CountOneBodyGForLanczos(char *xNameListFile, int Nca, int Ncacadc, int Ns, int **caIdx, int **iFlgOneBodyG) { int info = 0; int i, j, isite1, isite2; int icount = 0; - int **cacaIdx; - int **caIdx; + int **cacaDCIdx; - cacaIdx = malloc(sizeof(int *) * Ncacadc); - for (i = 0; i < Ncacadc; i++) - cacaIdx[i] = malloc(sizeof(int) * 8); - caIdx = malloc(sizeof(int *) * Nca); - for (i = 0; i < Nca; i++) - caIdx[i] = malloc(sizeof(int) * 4); + cacaDCIdx = malloc(sizeof(int *) * Ncacadc); + //pInt=cacaDCIdx[0]; + for (i = 0; i < Ncacadc; i++) { + cacaDCIdx[i] = malloc(sizeof(int) * 8); + } for (i = 0; i < 2 * Ns; i++) { for (j = 0; j < 2 * Ns; j++) { iFlgOneBodyG[i][j] = -1; } } - info = ReadGreen(xNameListFile, Nca, caIdx, Ncacadc, cacaIdx, Ns); + info = ReadGreen(xNameListFile, Nca, caIdx, Ncacadc, cacaDCIdx, Ns); if (info != 0) { - for (i = 0; i < Ncacadc; i++) - free(cacaIdx[i]); - free(cacaIdx); - for (i = 0; i < Nca; i++) - free(caIdx[i]); - free(caIdx); + free(cacaDCIdx); return (info); } @@ -277,8 +269,8 @@ int CountOneBodyGForLanczos(char *xNameListFile, int Nca, int Ncacadc, int Ns, i } //cisajscktalt -> cisajs, cltakt (Note: indecies of the latter Green's function are modified) for (i = 0; i < Ncacadc; i++) { - isite1 = cacaIdx[i][0] + cacaIdx[i][1] * Ns; - isite2 = cacaIdx[i][2] + cacaIdx[i][3] * Ns; + isite1 = cacaDCIdx[i][0] + cacaDCIdx[i][1] * Ns; + isite2 = cacaDCIdx[i][2] + cacaDCIdx[i][3] * Ns; if (iFlgOneBodyG[isite1][isite2] == -1) { iFlgOneBodyG[isite1][isite2] = icount; icount++; @@ -288,20 +280,15 @@ int CountOneBodyGForLanczos(char *xNameListFile, int Nca, int Ncacadc, int Ns, i isite1 = cacaDCIdx[i][4] + cacaDCIdx[i][5] * Ns; isite2 = cacaDCIdx[i][6] + cacaDCIdx[i][7] * Ns; */ - isite1 = cacaIdx[i][6] + cacaIdx[i][7] * Ns; - isite2 = cacaIdx[i][4] + cacaIdx[i][5] * Ns; + isite1 = cacaDCIdx[i][6] + cacaDCIdx[i][7] * Ns; + isite2 = cacaDCIdx[i][4] + cacaDCIdx[i][5] * Ns; if (iFlgOneBodyG[isite1][isite2] == -1) { iFlgOneBodyG[isite1][isite2] = icount; icount++; } } - for (i = 0; i < Ncacadc; i++) - free(cacaIdx[i]); - free(cacaIdx); - for (i = 0; i < Nca; i++) - free(caIdx[i]); - free(caIdx); + free(cacaDCIdx); return icount; } @@ -509,17 +496,23 @@ int ReadDefFileNInt(char *xNameListFile, MPI_Comm comm) { //TODO: LanczosMode is not supported for Sz not conserved mode. - //For indirect calculation of Green's function - if (bufInt[IdxNTwoBodyGEx] > 0 || bufInt[IdxLanczosMode] > 1) { - //Get info of CisAjs and CisAjsCktAlt(GreenTwoEx as if it's DC) + //For Lanczos mode: Calculation of Green's function + if (bufInt[IdxLanczosMode] > 1) { + //Get info of CisAjs and CisAjsCktAltDC int i; + NCisAjsLz = bufInt[IdxNOneBodyG]; + //bufInt[IdxNTwoBodyGEx] = bufInt[IdxNTwoBodyG]; + CisAjsLzIdx = malloc(sizeof(int *) * NCisAjsLz); + for (i = 0; i < NCisAjsLz; i++) { + CisAjsLzIdx[i] = malloc(sizeof(int) * 4); + } iOneBodyGIdx = malloc(sizeof(int *) * (2 * bufInt[IdxNsite])); //For spin + //pInt=iFlgOneBodyG[0]; for (i = 0; i < 2 * bufInt[IdxNsite]; i++) { iOneBodyGIdx[i] = malloc(sizeof(int) * (2 * bufInt[IdxNsite])); } - bufInt[IdxNOneBodyG] = CountOneBodyGForLanczos(xNameListFile, - bufInt[IdxNOneBodyG], bufInt[IdxNTwoBodyGEx], - bufInt[IdxNsite], iOneBodyGIdx); + bufInt[IdxNOneBodyG] = CountOneBodyGForLanczos(xNameListFile, NCisAjsLz, bufInt[IdxNTwoBodyG], + bufInt[IdxNsite], CisAjsLzIdx, iOneBodyGIdx); } //CalcNCond @@ -710,7 +703,7 @@ int ReadDefFileNInt(char *xNameListFile, MPI_Comm comm) { + Nsite * NQPTrans /* QPTransInv */ + Nsite * NQPTrans /* QPTransSgn */ + 4 * NCisAjs /* CisAjs */ - + 2 * NCisAjsCktAlt /* CisAjsCktAlt */ + + 8 * NCisAjsCktAlt /* CisAjsCktAlt */ + 8 * NCisAjsCktAltDC /* CisAjsCktAltDC */ + 8 * NInterAll /* InterAll */ + Nsite * NQPOptTrans /* QPOptTrans */ @@ -755,6 +748,8 @@ int ReadDefFileIdxPara(char *xNameListFile, MPI_Comm comm) { int x0, x1; int rank; + int iNOneBodyG; + MPI_Comm_rank(comm, &rank); if (rank == 0) { @@ -867,17 +862,19 @@ int ReadDefFileIdxPara(char *xNameListFile, MPI_Comm comm) { case KWOneBodyG: /*cisajs.def----------------------------------------*/ - if (GetInfoOneBodyG(fp, CisAjsIdx, iOneBodyGIdx, NCisAjsCktAlt>0, Nsite, NCisAjs, defname) != 0) info = 1; + iNOneBodyG = (NLanczosMode < 2) ? NCisAjs : NCisAjsLz; + if (GetInfoOneBodyG(fp, CisAjsIdx, iOneBodyGIdx, NLanczosMode, Nsite, iNOneBodyG, defname) != 0) info = 1; break; case KWTwoBodyGEx: /*cisajscktalt.def----------------------------------*/ - if (GetInfoTwoBodyGEx(fp, CisAjsCktAltIdx, iOneBodyGIdx, CisAjsIdx, Nsite, NCisAjsCktAlt, defname) != 0) info = 1; + if (GetInfoTwoBodyGEx(fp, CisAjsCktAltIdx, Nsite, NCisAjsCktAlt, defname) != 0) info = 1; break; case KWTwoBodyG: /*cisajscktaltdc.def--------------------------------*/ - if (GetInfoTwoBodyG(fp, CisAjsCktAltDCIdx, Nsite, NCisAjsCktAltDC, defname) != 0) + if (GetInfoTwoBodyG(fp, CisAjsCktAltDCIdx, CisAjsCktAltLzIdx, iOneBodyGIdx, CisAjsIdx, NLanczosMode, Nsite, + NCisAjsCktAltDC, defname) != 0) info = 1; break; @@ -984,6 +981,9 @@ int ReadDefFileIdxPara(char *xNameListFile, MPI_Comm comm) { */ #ifdef _mpi_use SafeMpiBcastInt(LocSpn, NTotalDefInt, comm); + if (NLanczosMode > 1) { + SafeMpiBcastInt(CisAjsCktAltLzIdx[0], NCisAjsCktAltDC * 2, comm); + } SafeMpiBcast_fcmp(ParaTransfer, NTransfer + NInterAll, comm); SafeMpiBcast(ParaCoulombIntra, NTotalDefDouble, comm); SafeMpiBcast_fcmp(ParaQPTrans, NQPTrans, comm); @@ -1928,7 +1928,7 @@ int GetInfoTransSym(FILE *fp, int **Array, int **ArraySgn, int **ArrayInv, doubl } int -GetInfoOneBodyG(FILE *fp, int **ArrayIdx, int **ArrayToIdx, int IndirectGFOn, int Nsite, int NArray, char *defname) { +GetInfoOneBodyG(FILE *fp, int **ArrayIdx, int **ArrayToIdx, int _NLanczosMode, int Nsite, int NArray, char *defname) { char ctmp2[256]; int idx = 0, info = 0; int x0 = 0, x1 = 0, x2 = 0, x3 = 0; @@ -1937,12 +1937,12 @@ GetInfoOneBodyG(FILE *fp, int **ArrayIdx, int **ArrayToIdx, int IndirectGFOn, in if (NArray == 0) return 0; while (fgets(ctmp2, sizeof(ctmp2) / sizeof(char), fp) != NULL) { sscanf(ctmp2, "%d %d %d %d\n", &x0, &x1, &x2, &x3); - if (!IndirectGFOn) { // Normal + if (_NLanczosMode < 2) { // Normal ArrayIdx[idx][0] = x0; ArrayIdx[idx][1] = x1; ArrayIdx[idx][2] = x2; ArrayIdx[idx][3] = x3; - } else { //For Calc Green func indirectly + } else { //For Calc Green func by Lanczos mode isite1 = x0 + x1 * Nsite; isite2 = x2 + x3 * Nsite; idxLanczos = ArrayToIdx[isite1][isite2]; @@ -1959,50 +1959,28 @@ GetInfoOneBodyG(FILE *fp, int **ArrayIdx, int **ArrayToIdx, int IndirectGFOn, in idx++; } - if (!IndirectGFOn && idx != NArray) - info = ReadDefFileError(defname); + if (idx != NArray) info = ReadDefFileError(defname); return info; } -// Formerly CisAjsCktAlt -int GetInfoTwoBodyGEx(FILE *fp, int **ArrayIdx, int **ArrayToIdx, int **ArrayIdxOneBodyG, - int Nsite, int NArray, char *defname) { +int GetInfoTwoBodyGEx(FILE *fp, int **ArrayIdx, int Nsite, int NArray, char *defname) { char ctmp2[256]; int idx = 0, info = 0; int x0 = 0, x1 = 0, x2 = 0, x3 = 0; int x4 = 0, x5 = 0, x6 = 0, x7 = 0; - int isite1 = 0, isite2 = 0; - int idxLanczos = 0; - + //Debug if (NArray == 0) return 0; while (fgets(ctmp2, sizeof(ctmp2) / sizeof(char), fp) != NULL) { sscanf(ctmp2, "%d %d %d %d %d %d %d %d\n", &x0, &x1, &x2, &x3, &x4, &x5, &x6, &x7); - - isite1 = x0 + x1 * Nsite; - isite2 = x2 + x3 * Nsite; - idxLanczos = ArrayToIdx[isite1][isite2]; - ArrayIdxOneBodyG[idxLanczos][0] = x0; - ArrayIdxOneBodyG[idxLanczos][1] = x1; - ArrayIdxOneBodyG[idxLanczos][2] = x2; - ArrayIdxOneBodyG[idxLanczos][3] = x3; - ArrayIdx[idx][0] = idxLanczos; - - isite1 = x6 + x7 * Nsite; - isite2 = x4 + x5 * Nsite; - idxLanczos = ArrayToIdx[isite1][isite2]; - /* - ArrayIdxOneBodyG[idxLanczos][0] = x4; - ArrayIdxOneBodyG[idxLanczos][1] = x5; - ArrayIdxOneBodyG[idxLanczos][2] = x6; - ArrayIdxOneBodyG[idxLanczos][3] = x7; - */ - ArrayIdxOneBodyG[idxLanczos][0] = x6; - ArrayIdxOneBodyG[idxLanczos][1] = x7; - ArrayIdxOneBodyG[idxLanczos][2] = x4; - ArrayIdxOneBodyG[idxLanczos][3] = x5; - ArrayIdx[idx][1] = idxLanczos; - - if (CheckQuadSite(x0, x2, x4, x6, Nsite) != 0) { + ArrayIdx[idx][0] = x0; // Index to OneBodyG1 + ArrayIdx[idx][1] = x1; // Index to OneBodyG2 + ArrayIdx[idx][2] = x2; // G1:site i + ArrayIdx[idx][3] = x3; // G1:site j + ArrayIdx[idx][4] = x4; // G1:sigma1 + ArrayIdx[idx][5] = x5; // G2:site l + ArrayIdx[idx][6] = x6; // G2:site k + ArrayIdx[idx][7] = x7; // G2:sigma2 + if (CheckQuadSite(x2, x3, x5, x6, Nsite) != 0) { fprintf(stderr, "Error: Site index is incorrect. \n"); info = 1; break; @@ -2013,8 +1991,8 @@ int GetInfoTwoBodyGEx(FILE *fp, int **ArrayIdx, int **ArrayToIdx, int **ArrayIdx return info; } -// Formerly CisAjsCktAltDC -int GetInfoTwoBodyG(FILE *fp, int **ArrayIdx, int Nsite, int NArray, char *defname) { +int GetInfoTwoBodyG(FILE *fp, int **ArrayIdx, int **ArrayIdxTwoBodyGLz, int **ArrayToIdx, int **ArrayIdxOneBodyG, + int _NLanczosMode, int Nsite, int NArray, char *defname) { char ctmp2[256]; int idx = 0, info = 0; int x0 = 0, x1 = 0, x2 = 0, x3 = 0; @@ -2039,6 +2017,44 @@ int GetInfoTwoBodyG(FILE *fp, int **ArrayIdx, int Nsite, int NArray, char *defna break; } + if (_NLanczosMode > 1) { //Calc TwoBodyG by Lanczos method + + isite1 = x0 + x1 * Nsite; + isite2 = x2 + x3 * Nsite; + idxLanczos = ArrayToIdx[isite1][isite2]; + + ArrayIdxOneBodyG[idxLanczos][0] = x0; + ArrayIdxOneBodyG[idxLanczos][1] = x1; + ArrayIdxOneBodyG[idxLanczos][2] = x2; + ArrayIdxOneBodyG[idxLanczos][3] = x3; + /* + ArrayIdxOneBodyG[idxLanczos][0] = x2; + ArrayIdxOneBodyG[idxLanczos][1] = x3; + ArrayIdxOneBodyG[idxLanczos][2] = x0; + ArrayIdxOneBodyG[idxLanczos][3] = x1; + */ + ArrayIdxTwoBodyGLz[idx][0] = idxLanczos; + + /* + isite1 = x4 + x5 * Nsite; + isite2 = x6 + x7 * Nsite; + */ + isite1 = x6 + x7 * Nsite; + isite2 = x4 + x5 * Nsite; + idxLanczos = ArrayToIdx[isite1][isite2]; + ArrayIdxOneBodyG[idxLanczos][0] = x6; + ArrayIdxOneBodyG[idxLanczos][1] = x7; + ArrayIdxOneBodyG[idxLanczos][2] = x4; + ArrayIdxOneBodyG[idxLanczos][3] = x5; + + /* + ArrayIdxOneBodyG[idxLanczos][0] = x4; + ArrayIdxOneBodyG[idxLanczos][1] = x5; + ArrayIdxOneBodyG[idxLanczos][2] = x6; + ArrayIdxOneBodyG[idxLanczos][3] = x7; + */ + ArrayIdxTwoBodyGLz[idx][1] = idxLanczos; + } idx++; } if (idx != NArray) info = ReadDefFileError(defname); diff --git a/src/mVMC/setmemory.c b/src/mVMC/setmemory.c index 4ae2e252..8422397f 100644 --- a/src/mVMC/setmemory.c +++ b/src/mVMC/setmemory.c @@ -163,7 +163,7 @@ void SetMemoryDef() { CisAjsCktAltIdx = (int**)malloc(sizeof(int*)*NCisAjsCktAlt); for(i=0;i1){ + CisAjsCktAltLzIdx = malloc(sizeof(int*)*NCisAjsCktAltDC); + for(i=0;i0) { - for(i=0;i<2*Nsite;i++) - free(iOneBodyGIdx[i]); - free(iOneBodyGIdx); - } + free(ParaTransfer); free(QPOptTransSgn); free(QPOptTrans); @@ -241,7 +243,6 @@ void FreeMemoryDef() { free(DoublonHolon4siteIdx); free(DoublonHolon2siteIdx); free(JastrowIdx); - free(ParaTransfer); free(ExchangeCoupling); free(PairHopping); free(HundCoupling); @@ -368,11 +369,10 @@ void SetMemory() { /***** Physical Quantity *****/ if(NVMCCalMode==1){ PhysCisAjs = (double complex*)malloc(sizeof(double complex) - *(NCisAjs+NCisAjsCktAlt+NCisAjsCktAltDC+NCisAjs+NCisAjsCktAltDC)); + *(NCisAjs+NCisAjsCktAlt+NCisAjsCktAltDC+NCisAjs)); PhysCisAjsCktAlt = PhysCisAjs + NCisAjs; PhysCisAjsCktAltDC = PhysCisAjsCktAlt + NCisAjsCktAlt; LocalCisAjs = PhysCisAjsCktAltDC + NCisAjsCktAltDC; - LocalCisAjsCktAltDC = LocalCisAjs + NCisAjs; if(NLanczosMode>0){ QQQQ = (double complex*)malloc(sizeof(double complex) @@ -385,16 +385,14 @@ void SetMemory() { if(NLanczosMode>1){ QCisAjsQ = (double complex*)malloc(sizeof(double complex) - *(NLSHam*NLSHam*NCisAjs + NLSHam*NLSHam*(NCisAjsCktAltDC+NCisAjsCktAlt) + NLSHam*NCisAjs) ); + *(NLSHam*NLSHam*NCisAjs + NLSHam*NLSHam*NCisAjsCktAltDC + NLSHam*NCisAjs) ); QCisAjsCktAltQ = QCisAjsQ + NLSHam*NLSHam*NCisAjs; - QCisAjsCktAltQDC = QCisAjsCktAltQ + NLSHam*NLSHam*NCisAjsCktAlt; - LSLCisAjs = QCisAjsCktAltQDC + NLSHam*NLSHam*NCisAjsCktAltDC; + LSLCisAjs = QCisAjsCktAltQ + NLSHam*NLSHam*NCisAjsCktAltDC; //for real QCisAjsQ_real = (double *)malloc(sizeof(double ) - *(NLSHam*NLSHam*NCisAjs + NLSHam*NLSHam*(NCisAjsCktAltDC+NCisAjsCktAlt) + NLSHam*NCisAjs) ); + *(NLSHam*NLSHam*NCisAjs + NLSHam*NLSHam*NCisAjsCktAltDC + NLSHam*NCisAjs) ); QCisAjsCktAltQ_real = QCisAjsQ_real + NLSHam*NLSHam*NCisAjs; - QCisAjsCktAltQDC_real = QCisAjsCktAltQ_real + NLSHam*NLSHam*NCisAjsCktAlt; - LSLCisAjs_real = QCisAjsCktAltQDC_real + NLSHam*NLSHam*NCisAjsCktAltDC; + LSLCisAjs_real = QCisAjsCktAltQ_real + NLSHam*NLSHam*NCisAjsCktAltDC; } } diff --git a/src/mVMC/vmccal.c b/src/mVMC/vmccal.c index e400819d..85698c08 100644 --- a/src/mVMC/vmccal.c +++ b/src/mVMC/vmccal.c @@ -68,16 +68,6 @@ void calculateQCACAQ_real(double *qcacaq, const double *lslca, const double w, const int nLSHam, const int nCA, const int nCACA, int **cacaIdx); -void calculateQCACAQDC_real(double *qcacaq, const double *lslq, const double w, - const int nLSHam, const int nCA, const int nCACA, - int *eleIdx, int *eleCfg, int *eleNum, int *eleProjCnt, - const double h1, const double ip); - -void calculateQCACAQDC(double complex *qcacaq, const double complex *lslq, const double w, - const int nLSHam, const int nCA, const int nCACA, - int *eleIdx, int *eleCfg, int *eleNum, int *eleProjCnt, - const double complex h1, const double complex ip); - void VMCMainCal(MPI_Comm comm) { int *eleIdx,*eleCfg,*eleNum,*eleProjCnt; double complex e,ip; @@ -277,18 +267,14 @@ void VMCMainCal(MPI_Comm comm) { LSLocalCisAjs_real(creal(e),creal(ip),eleIdx,eleCfg,eleNum,eleProjCnt); calculateQCAQ_real(QCisAjsQ_real,LSLCisAjs_real,LSLQ_real,w,NLSHam,NCisAjs); calculateQCACAQ_real(QCisAjsCktAltQ_real,LSLCisAjs_real,w,NLSHam,NCisAjs, - NCisAjsCktAlt, CisAjsCktAltIdx); - calculateQCACAQDC_real(QCisAjsCktAltQDC_real,LSLQ_real,w,NLSHam,NCisAjs, - NCisAjsCktAltDC,eleIdx,eleCfg,eleNum,eleProjCnt,creal(e),creal(ip)); + NCisAjsCktAltDC, CisAjsCktAltLzIdx); } else{ LSLocalCisAjs(e,ip,eleIdx,eleCfg,eleNum,eleProjCnt); calculateQCAQ(QCisAjsQ,LSLCisAjs,LSLQ,w,NLSHam,NCisAjs); calculateQCACAQ(QCisAjsCktAltQ,LSLCisAjs,w,NLSHam,NCisAjs, - NCisAjsCktAlt,CisAjsCktAltIdx); - calculateQCACAQDC(QCisAjsCktAltQDC,LSLQ,w,NLSHam,NCisAjs, - NCisAjsCktAltDC,eleIdx,eleCfg,eleNum,eleProjCnt,e,ip); + NCisAjsCktAltDC,CisAjsCktAltLzIdx); } StopTimer(44); } @@ -521,12 +507,12 @@ for(i=0;i1) { /* QCisAjsQ, QCisAjsCktAltQ, LSLCisAjs */ //[TODO]: Check the value n - n = NLSHam*NLSHam*NCisAjs + NLSHam*NLSHam*(NCisAjsCktAltDC+NCisAjsCktAlt) + n = NLSHam*NLSHam*NCisAjs + NLSHam*NLSHam*NCisAjsCktAltDC + NLSHam*NCisAjs; vec = QCisAjsQ; #pragma omp parallel for default(shared) private(i) for(i=0;i 0) { - for (i = 0; i < NCisAjs; i++) - fprintf(FileCisAjs, "%d %d %d %d % .18e % .18e \n", CisAjsIdx[i][0], CisAjsIdx[i][1], CisAjsIdx[i][2], - CisAjsIdx[i][3], creal(PhysCisAjs[i]), cimag(PhysCisAjs[i])); + if(NLanczosMode <2) { + for (i = 0; i < NCisAjs; i++) { + fprintf(FileCisAjs, "%d %d %d %d % .18e % .18e \n", CisAjsIdx[i][0], CisAjsIdx[i][1], CisAjsIdx[i][2], + CisAjsIdx[i][3], creal(PhysCisAjs[i]), cimag(PhysCisAjs[i])); + } + } + else{ + int idx=0; + for (i = 0; i < NCisAjsLz; i++) { + idx = iOneBodyGIdx[CisAjsLzIdx[i][0] + CisAjsLzIdx[i][1] * Nsite][CisAjsLzIdx[i][2] + + CisAjsLzIdx[i][3] * Nsite]; + //fprintf(stdout, "Debug: idx= %d value= % .18e % .18e\n", idx, creal(PhysCisAjs[idx]), cimag(PhysCisAjs[idx])); + fprintf(FileCisAjs, "%d %d %d %d % .18e % .18e \n", CisAjsLzIdx[idx][0], CisAjsLzIdx[idx][1], + CisAjsLzIdx[idx][2], CisAjsLzIdx[idx][3], creal(PhysCisAjs[idx]), cimag(PhysCisAjs[idx])); + } + } fprintf(FileCisAjs, "\n"); } - /* zvo_cisajscktaltex.dat */ + /* zvo_cisajscktalt.dat */ if (NCisAjsCktAlt > 0) { for (i = 0; i < NCisAjsCktAlt; i++) fprintf(FileCisAjsCktAlt, "% .18e % .18e ", creal(PhysCisAjsCktAlt[i]), cimag(PhysCisAjsCktAlt[i])); fprintf(FileCisAjsCktAlt, "\n"); } - /* zvo_cisajscktalt.dat */ + /* zvo_cisajscktaltdc.dat */ if (NCisAjsCktAltDC > 0) { for (i = 0; i < NCisAjsCktAltDC; i++) { fprintf(FileCisAjsCktAltDC, "%d %d %d %d %d %d %d %d % .18e % .18e\n", @@ -689,16 +702,16 @@ void outputData() { if (NLanczosMode > 0) { if (AllComplexFlag == 0) { //real PhysCalLanczos_real( - QQQQ_real, QCisAjsQ_real, QCisAjsCktAltQ_real, QCisAjsCktAltQDC_real, - NLSHam, Nsite, NCisAjs, NCisAjs, iOneBodyGIdx, CisAjsIdx, NCisAjsCktAlt, NCisAjsCktAltDC, CisAjsCktAltDCIdx, - NLanczosMode, FileLS, FileLSQQQQ, FileLSQCisAjsQ, FileLSQCisAjsCktAltQ, - FileLSCisAjs, FileLSCisAjsCktAlt, FileLSCisAjsCktAltDC); + QQQQ_real, QCisAjsQ_real, QCisAjsCktAltQ_real, + NLSHam, Nsite, NCisAjs, NCisAjsLz, iOneBodyGIdx, CisAjsLzIdx, NCisAjsCktAltDC, CisAjsCktAltDCIdx, NLanczosMode, + FileLS, FileLSQQQQ, FileLSQCisAjsQ, FileLSQCisAjsCktAltQ, + FileLSCisAjs, FileLSCisAjsCktAlt); }else { //complex PhysCalLanczos_fcmp( - QQQQ, QCisAjsQ, QCisAjsCktAltQ, QCisAjsCktAltQDC, - NLSHam, Nsite, NCisAjs, NCisAjs, iOneBodyGIdx, CisAjsIdx, NCisAjsCktAlt, NCisAjsCktAltDC, CisAjsCktAltDCIdx, - NLanczosMode, FileLS, FileLSQQQQ, FileLSQCisAjsQ, FileLSQCisAjsCktAltQ, - FileLSCisAjs, FileLSCisAjsCktAlt, FileLSCisAjsCktAltDC); + QQQQ, QCisAjsQ, QCisAjsCktAltQ, + NLSHam, Nsite, NCisAjs, NCisAjsLz, iOneBodyGIdx, CisAjsLzIdx, NCisAjsCktAltDC, CisAjsCktAltDCIdx, NLanczosMode, + FileLS, FileLSQQQQ, FileLSQCisAjsQ, FileLSQCisAjsCktAltQ, + FileLSCisAjs, FileLSCisAjsCktAlt); } } } From ca0a4acc8eb4cf5e7904d564dcec0d4aebf2f512 Mon Sep 17 00:00:00 2001 From: Takahiro Misawa Date: Tue, 1 Oct 2024 15:33:12 +0900 Subject: [PATCH 09/10] Revert "Revert "Rebased "Separating Direct and Indirect Measurement of Two Body Green Function""" --- src/mVMC/average.c | 2 +- src/mVMC/calgrn.c | 7 +- src/mVMC/include/global.h | 11 +- src/mVMC/include/physcal_lanczos.h | 14 ++- src/mVMC/initfile.c | 9 +- src/mVMC/physcal_lanczos.c | 59 +++++++--- src/mVMC/readdef.c | 182 +++++++++++++---------------- src/mVMC/setmemory.c | 32 ++--- src/mVMC/vmccal.c | 86 +++++++++++++- src/mVMC/vmcmain.c | 39 +++---- 10 files changed, 270 insertions(+), 171 deletions(-) diff --git a/src/mVMC/average.c b/src/mVMC/average.c index 4cb0749e..f4954818 100644 --- a/src/mVMC/average.c +++ b/src/mVMC/average.c @@ -230,7 +230,7 @@ void WeightAverageGreenFunc(MPI_Comm comm) { } if(NLanczosMode>1){ /* QCisAjsQ and QCisAjsCktAltQ */ - n = NLSHam*NLSHam*NCisAjs + NLSHam*NLSHam*NCisAjsCktAltDC; + n = NLSHam*NLSHam*NCisAjs + NLSHam*NLSHam*(NCisAjsCktAltDC+NCisAjsCktAlt); if(AllComplexFlag==0){ vec_real=QCisAjsQ_real; weightAverageReduce_real(n,vec_real,comm); diff --git a/src/mVMC/calgrn.c b/src/mVMC/calgrn.c index 8d13215b..16fc3864 100644 --- a/src/mVMC/calgrn.c +++ b/src/mVMC/calgrn.c @@ -81,7 +81,7 @@ void CalculateGreenFunc(const double w, const double complex ip, int *eleIdx, in tmp = GreenFunc2(ri,rj,rk,rl,s,t,ip,myEleIdx,eleCfg,myEleNum,eleProjCnt, myProjCntNew,myBuffer); - PhysCisAjsCktAltDC[idx] += w*tmp; + LocalCisAjsCktAltDC[idx] = tmp; } #pragma omp master @@ -92,6 +92,11 @@ void CalculateGreenFunc(const double w, const double complex ip, int *eleIdx, in PhysCisAjs[idx] += w*LocalCisAjs[idx]; } + #pragma omp for private(idx) nowait + for (idx=0;idx, */ @@ -286,10 +286,13 @@ double *LSLQ_real; /* [NLSHam][NLSHam]*/ //TBC double complex *QCisAjsQ; /* QCisAjsQ[NLSHam][NLSHam][NCisAjs]*/ //TBC double complex *QCisAjsCktAltQ; /* QCisAjsCktAltQ[NLSHam][NLSHam][NCisAjsCktAlt]*/ //TBC +double complex *QCisAjsCktAltQDC; /* QCisAjsCktAltQ[NLSHam][NLSHam][NCisAjsCktAlt] + DC Lanczos Calculation */ double complex *LSLCisAjs; /* [NLSHam][NCisAjs]*/ //TBC double *QCisAjsQ_real; /* QCisAjsQ[NLSHam][NLSHam][NCisAjs]*/ //TBC double *QCisAjsCktAltQ_real; /* QCisAjsCktAltQ[NLSHam][NLSHam][NCisAjsCktAlt]*/ //TBC +double *QCisAjsCktAltQDC_real; /* QCisAjsCktAltQ[NLSHam][NLSHam][NCisAjsCktAlt]*/ double *LSLCisAjs_real; /* [NLSHam][NCisAjs]*/ //TBC /***** Output File *****/ @@ -305,8 +308,10 @@ FILE *FileLS; FILE *FileLSQQQQ; FILE *FileLSQCisAjsQ; FILE *FileLSQCisAjsCktAltQ; +FILE *FileLSQCisAjsCktAltQ; FILE *FileLSCisAjs; FILE *FileLSCisAjsCktAlt; +FILE *FileLSCisAjsCktAltDC; /* FILE *FileTimerList; */ diff --git a/src/mVMC/include/physcal_lanczos.h b/src/mVMC/include/physcal_lanczos.h index 9dd02cce..27dbf7ff 100644 --- a/src/mVMC/include/physcal_lanczos.h +++ b/src/mVMC/include/physcal_lanczos.h @@ -7,6 +7,7 @@ int PhysCalLanczos_real( double *_QQQQ_real, double *_QCisAjsQ_real, double *_QCisAjsCktAltQ_real, + double *_QCisAjsCktAltQDC_real, const int _nLSHam, const int _Ns, const int _nCisAjs, @@ -14,20 +15,23 @@ int PhysCalLanczos_real( int **_iOneBodyGIdx, int **_CisAjsLzIdx, const int _nCisAjsCktAlt, - int **_CisAjsCktAlt, + const int _nCisAjsCktAltDC, + int **_CisAjsCktAltDC, const int _NLanczosmode, FILE *_FileLS, FILE *_FileLSQQQQ, FILE *_FileLSQCisAjsQ, FILE *_FileLSQCisAjsCktAltQ, FILE *_FileLSCisAjs, - FILE *_FileLSCisAjsCktAlt + FILE *_FileLSCisAjsCktAlt, + FILE *_FileLSCisAjsCktAltDC ); int PhysCalLanczos_fcmp( double complex* _QQQQ, double complex* _QCisAjsQ, double complex* _QCisAjsCktAltQ, + double complex* _QCisAjsCktAltQDC, const int _nLSHam, const int _Ns, const int _nCisAjs, @@ -35,14 +39,16 @@ int PhysCalLanczos_fcmp( int **_iOneBodyGIdx, int **_CisAjsLzIdx, const int _nCisAjsCktAlt, - int **_CisAjsCktAlt, + const int _nCisAjsCktAltDC, + int **_CisAjsCktAltDC, const int _NLanczosmode, FILE *_FileLS, FILE *_FileLSQQQQ, FILE *_FileLSQCisAjsQ, FILE *_FileLSQCisAjsCktAltQ, FILE *_FileLSCisAjs, - FILE *_FileLSCisAjsCktAlt + FILE *_FileLSCisAjsCktAlt, + FILE *_FileLSCisAjsCktAltDC ); #endif diff --git a/src/mVMC/initfile.c b/src/mVMC/initfile.c index 815f971f..80a04f38 100644 --- a/src/mVMC/initfile.c +++ b/src/mVMC/initfile.c @@ -126,9 +126,15 @@ void InitFilePhysCal(int i, int rank) { CDataFileHead, idx); FileLSCisAjs = fopen(fileName, "w"); - sprintf(fileName, "%s_ls_cisajscktalt_%03d.dat", + // CACA + sprintf(fileName, "%s_ls_cisajscktaltex_%03d.dat", CDataFileHead, idx); FileLSCisAjsCktAlt = fopen(fileName, "w"); + + // CACADC + sprintf(fileName, "%s_ls_cisajscktalt_%03d.dat", + CDataFileHead, idx); + FileLSCisAjsCktAltDC = fopen(fileName, "w"); } } @@ -176,6 +182,7 @@ void CloseFilePhysCal(int rank) { #endif fclose(FileLSCisAjs); fclose(FileLSCisAjsCktAlt); + fclose(FileLSCisAjsCktAltDC); } } diff --git a/src/mVMC/physcal_lanczos.c b/src/mVMC/physcal_lanczos.c index 26b9782a..13640256 100644 --- a/src/mVMC/physcal_lanczos.c +++ b/src/mVMC/physcal_lanczos.c @@ -29,6 +29,7 @@ int PhysCalLanczos_real double *_QQQQ_real, double *_QCisAjsQ_real, double *_QCisAjsCktAltQ_real, + double *_QCisAjsCktAltQDC_real, const int _nLSHam, const int _Ns, const int _nCisAjs, @@ -36,14 +37,16 @@ int PhysCalLanczos_real int **_iOneBodyGIdx, int **_CisAjsLzIdx, const int _nCisAjsCktAlt, - int **_CisAjsCktAlt, + const int _nCisAjsCktAltDC, + int **_CisAjsCktAltDC, const int _NLanczosmode, FILE *_FileLS, FILE *_FileLSQQQQ, FILE *_FileLSQCisAjsQ, FILE *_FileLSQCisAjsCktAltQ, FILE *_FileLSCisAjs, - FILE *_FileLSCisAjsCktAlt + FILE *_FileLSCisAjsCktAlt, + FILE *_FileLSCisAjsCktAltDC ) { int i=0; @@ -53,8 +56,10 @@ int PhysCalLanczos_real double alpha_m, ene_m, ene_vm; double *LS_CisAjs_real; double *LS_CisAjsCktAlt_real; + double *LS_CisAjsCktAltDC_real; LS_CisAjs_real = (double*)malloc(sizeof(double)*_nCisAjs); LS_CisAjsCktAlt_real = (double*)malloc(sizeof(double)*_nCisAjsCktAlt); + LS_CisAjsCktAltDC_real = (double*)malloc(sizeof(double)*_nCisAjsCktAltDC); CalculateEne(_QQQQ_real[2], _QQQQ_real[3], _QQQQ_real[10], _QQQQ_real[11], _QQQQ_real[15], &alpha_p, &ene_p, &ene_vp, &alpha_m, &ene_m, &ene_vm); @@ -114,21 +119,30 @@ int PhysCalLanczos_real fprintf(_FileLSQCisAjsCktAltQ, "\n"); #endif + CalculatePhysVal_real(_QQQQ_real[2], _QQQQ_real[3], + alpha, _QCisAjsCktAltQDC_real, _nCisAjsCktAltDC, + _nLSHam, LS_CisAjsCktAltDC_real); + /* zvo_ls_cisajscktalt.dat */ + for (i = 0; i < _nCisAjsCktAltDC; i++) { + fprintf(_FileLSCisAjsCktAltDC, "%d %d %d %d %d %d %d %d % .18e 0.0\n", + _CisAjsCktAltDC[i][0], _CisAjsCktAltDC[i][1], _CisAjsCktAltDC[i][2], _CisAjsCktAltDC[i][3], + _CisAjsCktAltDC[i][4], _CisAjsCktAltDC[i][5], _CisAjsCktAltDC[i][6], _CisAjsCktAltDC[i][7], + LS_CisAjsCktAltDC_real[i]); + } + fprintf(_FileLSCisAjsCktAltDC, "\n"); + CalculatePhysVal_real(_QQQQ_real[2], _QQQQ_real[3], alpha, _QCisAjsCktAltQ_real, _nCisAjsCktAlt, _nLSHam, LS_CisAjsCktAlt_real); - /* zvo_ls_cisajscktalt.dat */ + /* zvo_ls_cisajscktaltex.dat */ for (i = 0; i < _nCisAjsCktAlt; i++) { - fprintf(_FileLSCisAjsCktAlt, "%d %d %d %d %d %d %d %d % .18e 0.0\n", - _CisAjsCktAlt[i][0], _CisAjsCktAlt[i][1], _CisAjsCktAlt[i][2], _CisAjsCktAlt[i][3], - _CisAjsCktAlt[i][4], _CisAjsCktAlt[i][5], _CisAjsCktAlt[i][6], _CisAjsCktAlt[i][7], - LS_CisAjsCktAlt_real[i]); - + fprintf(_FileLSCisAjsCktAlt, "% .18e 0.0 ", LS_CisAjsCktAlt_real[i]); // LS_CisAjsCktAlt_real } fprintf(_FileLSCisAjsCktAlt, "\n"); } free(LS_CisAjs_real); free(LS_CisAjsCktAlt_real); + free(LS_CisAjsCktAltDC_real); return 0; } @@ -136,6 +150,7 @@ int PhysCalLanczos_fcmp( double complex* _QQQQ, double complex* _QCisAjsQ, double complex* _QCisAjsCktAltQ, + double complex* _QCisAjsCktAltQDC, const int _nLSHam, const int _Ns, const int _nCisAjs, @@ -143,14 +158,16 @@ int PhysCalLanczos_fcmp( int **_iOneBodyGIdx, int **_CisAjsLzIdx, const int _nCisAjsCktAlt, - int **_CisAjsCktAlt, + const int _nCisAjsCktAltDC, + int **_CisAjsCktAltDC, const int _NLanczosmode, FILE *_FileLS, FILE *_FileLSQQQQ, FILE *_FileLSQCisAjsQ, FILE *_FileLSQCisAjsCktAltQ, FILE *_FileLSCisAjs, - FILE *_FileLSCisAjsCktAlt + FILE *_FileLSCisAjsCktAlt, + FILE *_FileLSCisAjsCktAltDC ) { int i=0; @@ -160,8 +177,10 @@ int PhysCalLanczos_fcmp( double alpha_m, ene_m, ene_vm; double complex*LS_CisAjs; double complex*LS_CisAjsCktAlt; + double complex*LS_CisAjsCktAltDC; LS_CisAjs = (double complex*)malloc(sizeof(double complex)*_nCisAjs); LS_CisAjsCktAlt = (double complex*)malloc(sizeof(double complex)*_nCisAjsCktAlt); + LS_CisAjsCktAltDC = (double complex*)malloc(sizeof(double complex)*_nCisAjsCktAltDC); /* zvo_ls.dat */ if(!CalculateEne(creal(_QQQQ[2]),creal(_QQQQ[3]), @@ -221,20 +240,30 @@ int PhysCalLanczos_fcmp( } fprintf(_FileLSQCisAjsCktAltQ, "\n"); #endif + CalculatePhysVal_fcmp(_QQQQ[2], _QQQQ[3], + alpha, _QCisAjsCktAltQDC, _nCisAjsCktAltDC, + _nLSHam, LS_CisAjsCktAltDC); + /* zvo_ls_cisajscktalt.dat */ + for (i = 0; i < _nCisAjsCktAltDC; i++) { + fprintf(_FileLSCisAjsCktAltDC, "%d %d %d %d %d %d %d %d % .18e % .18e\n", + _CisAjsCktAltDC[i][0], _CisAjsCktAltDC[i][1], _CisAjsCktAltDC[i][2], _CisAjsCktAltDC[i][3], + _CisAjsCktAltDC[i][4], _CisAjsCktAltDC[i][5], _CisAjsCktAltDC[i][6], _CisAjsCktAltDC[i][7], + creal(LS_CisAjsCktAltDC[i]), cimag(LS_CisAjsCktAltDC[i])); + } + fprintf(_FileLSCisAjsCktAltDC, "\n"); + CalculatePhysVal_fcmp(_QQQQ[2], _QQQQ[3], alpha, _QCisAjsCktAltQ, _nCisAjsCktAlt, _nLSHam, LS_CisAjsCktAlt); - /* zvo_ls_cisajs.dat */ + /* zvo_ls_cisajscktaltex.dat */ for (i = 0; i < _nCisAjsCktAlt; i++) { - fprintf(_FileLSCisAjsCktAlt, "%d %d %d %d %d %d %d %d % .18e % .18e\n", - _CisAjsCktAlt[i][0], _CisAjsCktAlt[i][1], _CisAjsCktAlt[i][2], _CisAjsCktAlt[i][3], - _CisAjsCktAlt[i][4], _CisAjsCktAlt[i][5], _CisAjsCktAlt[i][6], _CisAjsCktAlt[i][7], - creal(LS_CisAjsCktAlt[i]), cimag(LS_CisAjsCktAlt[i])); + fprintf(_FileLSCisAjsCktAlt, "% .18e % .18e ", creal(LS_CisAjsCktAlt[i]), cimag(LS_CisAjsCktAlt[i])); // LS_CisAjsCktAlt_real } fprintf(_FileLSCisAjsCktAlt, "\n"); } free(LS_CisAjs); free(LS_CisAjsCktAlt); + free(LS_CisAjsCktAltDC); return 0; } diff --git a/src/mVMC/readdef.c b/src/mVMC/readdef.c index 5b51600b..36ac357f 100644 --- a/src/mVMC/readdef.c +++ b/src/mVMC/readdef.c @@ -89,10 +89,10 @@ int GetInfoInterAll(FILE *fp, int **ArrayIdx, double complex *ArrayValue, int GetInfoOptTrans(FILE *fp, int **Array, double *ArrayPara, int *ArrayOpt, int **ArraySgn, int _iFlagOptTrans, int *iOptCount, int _fidx, int _APFlag, int Nsite, int NArray, char *defname); -int GetInfoTwoBodyG(FILE *fp, int **ArrayIdx, int **ArrayIdxTwoBodyGLz, int **ArrayToIdx, int **ArrayIdxOneBodyG, - int _NLanczosMode, int Nsite, int NArray, char *defname); +int GetInfoTwoBodyG(FILE *fp, int **ArrayIdx, int Nsite, int NArray, char *defname); -int GetInfoTwoBodyGEx(FILE *fp, int **ArrayIdx, int Nsite, int NArray, char *defname); +int GetInfoTwoBodyGEx(FILE *fp, int **ArrayIdx, int **ArrayToIdx, int **ArrayIdxOneBodyG, + int Nsite, int NArray, char *defname); int GetInfoOrbitalGeneral(FILE *fp, int **Array, int *ArrayOpt, int **ArraySgn, int *iOptCount, int _fidx, int _iComplexFlag, int _iFlagOrbitalGeneral, int _APFlag, int Nsite, int NArray, @@ -181,7 +181,7 @@ int JudgeOrbitalMode(int *_iFlgOrbitalGeneral, const int _iFlgOrbitalAP, const i return iret; } -int ReadGreen(char *xNameListFile, int Nca, int **caIdx, int Ncacadc, int **cacaDCIdx, int Ns) { +int ReadGreen(char *xNameListFile, int Nca, int **caIdx, int Ncacadc, int **cacaIdx, int Ns) { FILE *fp; char defname[D_FileNameMax]; char ctmp[D_FileNameMax]; @@ -217,9 +217,10 @@ int ReadGreen(char *xNameListFile, int Nca, int **caIdx, int Ncacadc, int **caca /*cisajs.def----------------------------------------*/ if (GetInfoOneBodyG(fp, caIdx, iOneBodyGIdx, 0, Ns, Nca, defname) != 0) return (-1); break; - case KWTwoBodyG: - /*cisajscktaltdc.def--------------------------------*/ - if (GetInfoTwoBodyG(fp, cacaDCIdx, cacaDCIdx, iOneBodyGIdx, caIdx, 0, Ns, Ncacadc, defname) != 0) return (-1); + case KWTwoBodyGEx: + /*cisajscktalt.def----------------------------------*/ + /*load as if it's DC for index rearranging----------*/ + if (GetInfoTwoBodyG(fp, cacaIdx, Ns, Ncacadc, defname) != 0) return (-1); break; default: break; @@ -235,27 +236,34 @@ int ReadGreen(char *xNameListFile, int Nca, int **caIdx, int Ncacadc, int **caca /// \param Ncacadc Number of CisAjsCktAltDC /// \param Ns Number of sites /// \return Number of calculation target -int CountOneBodyGForLanczos(char *xNameListFile, int Nca, int Ncacadc, int Ns, int **caIdx, int **iFlgOneBodyG) { +int CountOneBodyGForLanczos(char *xNameListFile, int Nca, int Ncacadc, int Ns, int **iFlgOneBodyG) { int info = 0; int i, j, isite1, isite2; int icount = 0; - int **cacaDCIdx; + int **cacaIdx; + int **caIdx; - cacaDCIdx = malloc(sizeof(int *) * Ncacadc); - //pInt=cacaDCIdx[0]; - for (i = 0; i < Ncacadc; i++) { - cacaDCIdx[i] = malloc(sizeof(int) * 8); - } + cacaIdx = malloc(sizeof(int *) * Ncacadc); + for (i = 0; i < Ncacadc; i++) + cacaIdx[i] = malloc(sizeof(int) * 8); + caIdx = malloc(sizeof(int *) * Nca); + for (i = 0; i < Nca; i++) + caIdx[i] = malloc(sizeof(int) * 4); for (i = 0; i < 2 * Ns; i++) { for (j = 0; j < 2 * Ns; j++) { iFlgOneBodyG[i][j] = -1; } } - info = ReadGreen(xNameListFile, Nca, caIdx, Ncacadc, cacaDCIdx, Ns); + info = ReadGreen(xNameListFile, Nca, caIdx, Ncacadc, cacaIdx, Ns); if (info != 0) { - free(cacaDCIdx); + for (i = 0; i < Ncacadc; i++) + free(cacaIdx[i]); + free(cacaIdx); + for (i = 0; i < Nca; i++) + free(caIdx[i]); + free(caIdx); return (info); } @@ -269,8 +277,8 @@ int CountOneBodyGForLanczos(char *xNameListFile, int Nca, int Ncacadc, int Ns, i } //cisajscktalt -> cisajs, cltakt (Note: indecies of the latter Green's function are modified) for (i = 0; i < Ncacadc; i++) { - isite1 = cacaDCIdx[i][0] + cacaDCIdx[i][1] * Ns; - isite2 = cacaDCIdx[i][2] + cacaDCIdx[i][3] * Ns; + isite1 = cacaIdx[i][0] + cacaIdx[i][1] * Ns; + isite2 = cacaIdx[i][2] + cacaIdx[i][3] * Ns; if (iFlgOneBodyG[isite1][isite2] == -1) { iFlgOneBodyG[isite1][isite2] = icount; icount++; @@ -280,15 +288,20 @@ int CountOneBodyGForLanczos(char *xNameListFile, int Nca, int Ncacadc, int Ns, i isite1 = cacaDCIdx[i][4] + cacaDCIdx[i][5] * Ns; isite2 = cacaDCIdx[i][6] + cacaDCIdx[i][7] * Ns; */ - isite1 = cacaDCIdx[i][6] + cacaDCIdx[i][7] * Ns; - isite2 = cacaDCIdx[i][4] + cacaDCIdx[i][5] * Ns; + isite1 = cacaIdx[i][6] + cacaIdx[i][7] * Ns; + isite2 = cacaIdx[i][4] + cacaIdx[i][5] * Ns; if (iFlgOneBodyG[isite1][isite2] == -1) { iFlgOneBodyG[isite1][isite2] = icount; icount++; } } - free(cacaDCIdx); + for (i = 0; i < Ncacadc; i++) + free(cacaIdx[i]); + free(cacaIdx); + for (i = 0; i < Nca; i++) + free(caIdx[i]); + free(caIdx); return icount; } @@ -496,23 +509,17 @@ int ReadDefFileNInt(char *xNameListFile, MPI_Comm comm) { //TODO: LanczosMode is not supported for Sz not conserved mode. - //For Lanczos mode: Calculation of Green's function - if (bufInt[IdxLanczosMode] > 1) { - //Get info of CisAjs and CisAjsCktAltDC + //For indirect calculation of Green's function + if (bufInt[IdxNTwoBodyGEx] > 0 || bufInt[IdxLanczosMode] > 1) { + //Get info of CisAjs and CisAjsCktAlt(GreenTwoEx as if it's DC) int i; - NCisAjsLz = bufInt[IdxNOneBodyG]; - //bufInt[IdxNTwoBodyGEx] = bufInt[IdxNTwoBodyG]; - CisAjsLzIdx = malloc(sizeof(int *) * NCisAjsLz); - for (i = 0; i < NCisAjsLz; i++) { - CisAjsLzIdx[i] = malloc(sizeof(int) * 4); - } iOneBodyGIdx = malloc(sizeof(int *) * (2 * bufInt[IdxNsite])); //For spin - //pInt=iFlgOneBodyG[0]; for (i = 0; i < 2 * bufInt[IdxNsite]; i++) { iOneBodyGIdx[i] = malloc(sizeof(int) * (2 * bufInt[IdxNsite])); } - bufInt[IdxNOneBodyG] = CountOneBodyGForLanczos(xNameListFile, NCisAjsLz, bufInt[IdxNTwoBodyG], - bufInt[IdxNsite], CisAjsLzIdx, iOneBodyGIdx); + bufInt[IdxNOneBodyG] = CountOneBodyGForLanczos(xNameListFile, + bufInt[IdxNOneBodyG], bufInt[IdxNTwoBodyGEx], + bufInt[IdxNsite], iOneBodyGIdx); } //CalcNCond @@ -703,7 +710,7 @@ int ReadDefFileNInt(char *xNameListFile, MPI_Comm comm) { + Nsite * NQPTrans /* QPTransInv */ + Nsite * NQPTrans /* QPTransSgn */ + 4 * NCisAjs /* CisAjs */ - + 8 * NCisAjsCktAlt /* CisAjsCktAlt */ + + 2 * NCisAjsCktAlt /* CisAjsCktAlt */ + 8 * NCisAjsCktAltDC /* CisAjsCktAltDC */ + 8 * NInterAll /* InterAll */ + Nsite * NQPOptTrans /* QPOptTrans */ @@ -748,8 +755,6 @@ int ReadDefFileIdxPara(char *xNameListFile, MPI_Comm comm) { int x0, x1; int rank; - int iNOneBodyG; - MPI_Comm_rank(comm, &rank); if (rank == 0) { @@ -862,19 +867,17 @@ int ReadDefFileIdxPara(char *xNameListFile, MPI_Comm comm) { case KWOneBodyG: /*cisajs.def----------------------------------------*/ - iNOneBodyG = (NLanczosMode < 2) ? NCisAjs : NCisAjsLz; - if (GetInfoOneBodyG(fp, CisAjsIdx, iOneBodyGIdx, NLanczosMode, Nsite, iNOneBodyG, defname) != 0) info = 1; + if (GetInfoOneBodyG(fp, CisAjsIdx, iOneBodyGIdx, NCisAjsCktAlt>0, Nsite, NCisAjs, defname) != 0) info = 1; break; case KWTwoBodyGEx: /*cisajscktalt.def----------------------------------*/ - if (GetInfoTwoBodyGEx(fp, CisAjsCktAltIdx, Nsite, NCisAjsCktAlt, defname) != 0) info = 1; + if (GetInfoTwoBodyGEx(fp, CisAjsCktAltIdx, iOneBodyGIdx, CisAjsIdx, Nsite, NCisAjsCktAlt, defname) != 0) info = 1; break; case KWTwoBodyG: /*cisajscktaltdc.def--------------------------------*/ - if (GetInfoTwoBodyG(fp, CisAjsCktAltDCIdx, CisAjsCktAltLzIdx, iOneBodyGIdx, CisAjsIdx, NLanczosMode, Nsite, - NCisAjsCktAltDC, defname) != 0) + if (GetInfoTwoBodyG(fp, CisAjsCktAltDCIdx, Nsite, NCisAjsCktAltDC, defname) != 0) info = 1; break; @@ -981,9 +984,6 @@ int ReadDefFileIdxPara(char *xNameListFile, MPI_Comm comm) { */ #ifdef _mpi_use SafeMpiBcastInt(LocSpn, NTotalDefInt, comm); - if (NLanczosMode > 1) { - SafeMpiBcastInt(CisAjsCktAltLzIdx[0], NCisAjsCktAltDC * 2, comm); - } SafeMpiBcast_fcmp(ParaTransfer, NTransfer + NInterAll, comm); SafeMpiBcast(ParaCoulombIntra, NTotalDefDouble, comm); SafeMpiBcast_fcmp(ParaQPTrans, NQPTrans, comm); @@ -1928,7 +1928,7 @@ int GetInfoTransSym(FILE *fp, int **Array, int **ArraySgn, int **ArrayInv, doubl } int -GetInfoOneBodyG(FILE *fp, int **ArrayIdx, int **ArrayToIdx, int _NLanczosMode, int Nsite, int NArray, char *defname) { +GetInfoOneBodyG(FILE *fp, int **ArrayIdx, int **ArrayToIdx, int IndirectGFOn, int Nsite, int NArray, char *defname) { char ctmp2[256]; int idx = 0, info = 0; int x0 = 0, x1 = 0, x2 = 0, x3 = 0; @@ -1937,12 +1937,12 @@ GetInfoOneBodyG(FILE *fp, int **ArrayIdx, int **ArrayToIdx, int _NLanczosMode, i if (NArray == 0) return 0; while (fgets(ctmp2, sizeof(ctmp2) / sizeof(char), fp) != NULL) { sscanf(ctmp2, "%d %d %d %d\n", &x0, &x1, &x2, &x3); - if (_NLanczosMode < 2) { // Normal + if (!IndirectGFOn) { // Normal ArrayIdx[idx][0] = x0; ArrayIdx[idx][1] = x1; ArrayIdx[idx][2] = x2; ArrayIdx[idx][3] = x3; - } else { //For Calc Green func by Lanczos mode + } else { //For Calc Green func indirectly isite1 = x0 + x1 * Nsite; isite2 = x2 + x3 * Nsite; idxLanczos = ArrayToIdx[isite1][isite2]; @@ -1959,28 +1959,50 @@ GetInfoOneBodyG(FILE *fp, int **ArrayIdx, int **ArrayToIdx, int _NLanczosMode, i idx++; } - if (idx != NArray) info = ReadDefFileError(defname); + if (!IndirectGFOn && idx != NArray) + info = ReadDefFileError(defname); return info; } -int GetInfoTwoBodyGEx(FILE *fp, int **ArrayIdx, int Nsite, int NArray, char *defname) { +// Formerly CisAjsCktAlt +int GetInfoTwoBodyGEx(FILE *fp, int **ArrayIdx, int **ArrayToIdx, int **ArrayIdxOneBodyG, + int Nsite, int NArray, char *defname) { char ctmp2[256]; int idx = 0, info = 0; int x0 = 0, x1 = 0, x2 = 0, x3 = 0; int x4 = 0, x5 = 0, x6 = 0, x7 = 0; - //Debug + int isite1 = 0, isite2 = 0; + int idxLanczos = 0; + if (NArray == 0) return 0; while (fgets(ctmp2, sizeof(ctmp2) / sizeof(char), fp) != NULL) { sscanf(ctmp2, "%d %d %d %d %d %d %d %d\n", &x0, &x1, &x2, &x3, &x4, &x5, &x6, &x7); - ArrayIdx[idx][0] = x0; // Index to OneBodyG1 - ArrayIdx[idx][1] = x1; // Index to OneBodyG2 - ArrayIdx[idx][2] = x2; // G1:site i - ArrayIdx[idx][3] = x3; // G1:site j - ArrayIdx[idx][4] = x4; // G1:sigma1 - ArrayIdx[idx][5] = x5; // G2:site l - ArrayIdx[idx][6] = x6; // G2:site k - ArrayIdx[idx][7] = x7; // G2:sigma2 - if (CheckQuadSite(x2, x3, x5, x6, Nsite) != 0) { + + isite1 = x0 + x1 * Nsite; + isite2 = x2 + x3 * Nsite; + idxLanczos = ArrayToIdx[isite1][isite2]; + ArrayIdxOneBodyG[idxLanczos][0] = x0; + ArrayIdxOneBodyG[idxLanczos][1] = x1; + ArrayIdxOneBodyG[idxLanczos][2] = x2; + ArrayIdxOneBodyG[idxLanczos][3] = x3; + ArrayIdx[idx][0] = idxLanczos; + + isite1 = x6 + x7 * Nsite; + isite2 = x4 + x5 * Nsite; + idxLanczos = ArrayToIdx[isite1][isite2]; + /* + ArrayIdxOneBodyG[idxLanczos][0] = x4; + ArrayIdxOneBodyG[idxLanczos][1] = x5; + ArrayIdxOneBodyG[idxLanczos][2] = x6; + ArrayIdxOneBodyG[idxLanczos][3] = x7; + */ + ArrayIdxOneBodyG[idxLanczos][0] = x6; + ArrayIdxOneBodyG[idxLanczos][1] = x7; + ArrayIdxOneBodyG[idxLanczos][2] = x4; + ArrayIdxOneBodyG[idxLanczos][3] = x5; + ArrayIdx[idx][1] = idxLanczos; + + if (CheckQuadSite(x0, x2, x4, x6, Nsite) != 0) { fprintf(stderr, "Error: Site index is incorrect. \n"); info = 1; break; @@ -1991,8 +2013,8 @@ int GetInfoTwoBodyGEx(FILE *fp, int **ArrayIdx, int Nsite, int NArray, char *def return info; } -int GetInfoTwoBodyG(FILE *fp, int **ArrayIdx, int **ArrayIdxTwoBodyGLz, int **ArrayToIdx, int **ArrayIdxOneBodyG, - int _NLanczosMode, int Nsite, int NArray, char *defname) { +// Formerly CisAjsCktAltDC +int GetInfoTwoBodyG(FILE *fp, int **ArrayIdx, int Nsite, int NArray, char *defname) { char ctmp2[256]; int idx = 0, info = 0; int x0 = 0, x1 = 0, x2 = 0, x3 = 0; @@ -2017,44 +2039,6 @@ int GetInfoTwoBodyG(FILE *fp, int **ArrayIdx, int **ArrayIdxTwoBodyGLz, int **Ar break; } - if (_NLanczosMode > 1) { //Calc TwoBodyG by Lanczos method - - isite1 = x0 + x1 * Nsite; - isite2 = x2 + x3 * Nsite; - idxLanczos = ArrayToIdx[isite1][isite2]; - - ArrayIdxOneBodyG[idxLanczos][0] = x0; - ArrayIdxOneBodyG[idxLanczos][1] = x1; - ArrayIdxOneBodyG[idxLanczos][2] = x2; - ArrayIdxOneBodyG[idxLanczos][3] = x3; - /* - ArrayIdxOneBodyG[idxLanczos][0] = x2; - ArrayIdxOneBodyG[idxLanczos][1] = x3; - ArrayIdxOneBodyG[idxLanczos][2] = x0; - ArrayIdxOneBodyG[idxLanczos][3] = x1; - */ - ArrayIdxTwoBodyGLz[idx][0] = idxLanczos; - - /* - isite1 = x4 + x5 * Nsite; - isite2 = x6 + x7 * Nsite; - */ - isite1 = x6 + x7 * Nsite; - isite2 = x4 + x5 * Nsite; - idxLanczos = ArrayToIdx[isite1][isite2]; - ArrayIdxOneBodyG[idxLanczos][0] = x6; - ArrayIdxOneBodyG[idxLanczos][1] = x7; - ArrayIdxOneBodyG[idxLanczos][2] = x4; - ArrayIdxOneBodyG[idxLanczos][3] = x5; - - /* - ArrayIdxOneBodyG[idxLanczos][0] = x4; - ArrayIdxOneBodyG[idxLanczos][1] = x5; - ArrayIdxOneBodyG[idxLanczos][2] = x6; - ArrayIdxOneBodyG[idxLanczos][3] = x7; - */ - ArrayIdxTwoBodyGLz[idx][1] = idxLanczos; - } idx++; } if (idx != NArray) info = ReadDefFileError(defname); diff --git a/src/mVMC/setmemory.c b/src/mVMC/setmemory.c index 8422397f..4ae2e252 100644 --- a/src/mVMC/setmemory.c +++ b/src/mVMC/setmemory.c @@ -163,7 +163,7 @@ void SetMemoryDef() { CisAjsCktAltIdx = (int**)malloc(sizeof(int*)*NCisAjsCktAlt); for(i=0;i1){ - CisAjsCktAltLzIdx = malloc(sizeof(int*)*NCisAjsCktAltDC); - for(i=0;i0) { + for(i=0;i<2*Nsite;i++) + free(iOneBodyGIdx[i]); + free(iOneBodyGIdx); + } free(QPOptTransSgn); free(QPOptTrans); @@ -243,6 +241,7 @@ void FreeMemoryDef() { free(DoublonHolon4siteIdx); free(DoublonHolon2siteIdx); free(JastrowIdx); + free(ParaTransfer); free(ExchangeCoupling); free(PairHopping); free(HundCoupling); @@ -369,10 +368,11 @@ void SetMemory() { /***** Physical Quantity *****/ if(NVMCCalMode==1){ PhysCisAjs = (double complex*)malloc(sizeof(double complex) - *(NCisAjs+NCisAjsCktAlt+NCisAjsCktAltDC+NCisAjs)); + *(NCisAjs+NCisAjsCktAlt+NCisAjsCktAltDC+NCisAjs+NCisAjsCktAltDC)); PhysCisAjsCktAlt = PhysCisAjs + NCisAjs; PhysCisAjsCktAltDC = PhysCisAjsCktAlt + NCisAjsCktAlt; LocalCisAjs = PhysCisAjsCktAltDC + NCisAjsCktAltDC; + LocalCisAjsCktAltDC = LocalCisAjs + NCisAjs; if(NLanczosMode>0){ QQQQ = (double complex*)malloc(sizeof(double complex) @@ -385,14 +385,16 @@ void SetMemory() { if(NLanczosMode>1){ QCisAjsQ = (double complex*)malloc(sizeof(double complex) - *(NLSHam*NLSHam*NCisAjs + NLSHam*NLSHam*NCisAjsCktAltDC + NLSHam*NCisAjs) ); + *(NLSHam*NLSHam*NCisAjs + NLSHam*NLSHam*(NCisAjsCktAltDC+NCisAjsCktAlt) + NLSHam*NCisAjs) ); QCisAjsCktAltQ = QCisAjsQ + NLSHam*NLSHam*NCisAjs; - LSLCisAjs = QCisAjsCktAltQ + NLSHam*NLSHam*NCisAjsCktAltDC; + QCisAjsCktAltQDC = QCisAjsCktAltQ + NLSHam*NLSHam*NCisAjsCktAlt; + LSLCisAjs = QCisAjsCktAltQDC + NLSHam*NLSHam*NCisAjsCktAltDC; //for real QCisAjsQ_real = (double *)malloc(sizeof(double ) - *(NLSHam*NLSHam*NCisAjs + NLSHam*NLSHam*NCisAjsCktAltDC + NLSHam*NCisAjs) ); + *(NLSHam*NLSHam*NCisAjs + NLSHam*NLSHam*(NCisAjsCktAltDC+NCisAjsCktAlt) + NLSHam*NCisAjs) ); QCisAjsCktAltQ_real = QCisAjsQ_real + NLSHam*NLSHam*NCisAjs; - LSLCisAjs_real = QCisAjsCktAltQ_real + NLSHam*NLSHam*NCisAjsCktAltDC; + QCisAjsCktAltQDC_real = QCisAjsCktAltQ_real + NLSHam*NLSHam*NCisAjsCktAlt; + LSLCisAjs_real = QCisAjsCktAltQDC_real + NLSHam*NLSHam*NCisAjsCktAltDC; } } diff --git a/src/mVMC/vmccal.c b/src/mVMC/vmccal.c index 85698c08..e400819d 100644 --- a/src/mVMC/vmccal.c +++ b/src/mVMC/vmccal.c @@ -68,6 +68,16 @@ void calculateQCACAQ_real(double *qcacaq, const double *lslca, const double w, const int nLSHam, const int nCA, const int nCACA, int **cacaIdx); +void calculateQCACAQDC_real(double *qcacaq, const double *lslq, const double w, + const int nLSHam, const int nCA, const int nCACA, + int *eleIdx, int *eleCfg, int *eleNum, int *eleProjCnt, + const double h1, const double ip); + +void calculateQCACAQDC(double complex *qcacaq, const double complex *lslq, const double w, + const int nLSHam, const int nCA, const int nCACA, + int *eleIdx, int *eleCfg, int *eleNum, int *eleProjCnt, + const double complex h1, const double complex ip); + void VMCMainCal(MPI_Comm comm) { int *eleIdx,*eleCfg,*eleNum,*eleProjCnt; double complex e,ip; @@ -267,14 +277,18 @@ void VMCMainCal(MPI_Comm comm) { LSLocalCisAjs_real(creal(e),creal(ip),eleIdx,eleCfg,eleNum,eleProjCnt); calculateQCAQ_real(QCisAjsQ_real,LSLCisAjs_real,LSLQ_real,w,NLSHam,NCisAjs); calculateQCACAQ_real(QCisAjsCktAltQ_real,LSLCisAjs_real,w,NLSHam,NCisAjs, - NCisAjsCktAltDC, CisAjsCktAltLzIdx); + NCisAjsCktAlt, CisAjsCktAltIdx); + calculateQCACAQDC_real(QCisAjsCktAltQDC_real,LSLQ_real,w,NLSHam,NCisAjs, + NCisAjsCktAltDC,eleIdx,eleCfg,eleNum,eleProjCnt,creal(e),creal(ip)); } else{ LSLocalCisAjs(e,ip,eleIdx,eleCfg,eleNum,eleProjCnt); calculateQCAQ(QCisAjsQ,LSLCisAjs,LSLQ,w,NLSHam,NCisAjs); calculateQCACAQ(QCisAjsCktAltQ,LSLCisAjs,w,NLSHam,NCisAjs, - NCisAjsCktAltDC,CisAjsCktAltLzIdx); + NCisAjsCktAlt,CisAjsCktAltIdx); + calculateQCACAQDC(QCisAjsCktAltQDC,LSLQ,w,NLSHam,NCisAjs, + NCisAjsCktAltDC,eleIdx,eleCfg,eleNum,eleProjCnt,e,ip); } StopTimer(44); } @@ -507,12 +521,12 @@ for(i=0;i1) { /* QCisAjsQ, QCisAjsCktAltQ, LSLCisAjs */ //[TODO]: Check the value n - n = NLSHam*NLSHam*NCisAjs + NLSHam*NLSHam*NCisAjsCktAltDC + n = NLSHam*NLSHam*NCisAjs + NLSHam*NLSHam*(NCisAjsCktAltDC+NCisAjsCktAlt) + NLSHam*NCisAjs; vec = QCisAjsQ; #pragma omp parallel for default(shared) private(i) for(i=0;i 0) { - if(NLanczosMode <2) { - for (i = 0; i < NCisAjs; i++) { - fprintf(FileCisAjs, "%d %d %d %d % .18e % .18e \n", CisAjsIdx[i][0], CisAjsIdx[i][1], CisAjsIdx[i][2], - CisAjsIdx[i][3], creal(PhysCisAjs[i]), cimag(PhysCisAjs[i])); - } - } - else{ - int idx=0; - for (i = 0; i < NCisAjsLz; i++) { - idx = iOneBodyGIdx[CisAjsLzIdx[i][0] + CisAjsLzIdx[i][1] * Nsite][CisAjsLzIdx[i][2] + - CisAjsLzIdx[i][3] * Nsite]; - //fprintf(stdout, "Debug: idx= %d value= % .18e % .18e\n", idx, creal(PhysCisAjs[idx]), cimag(PhysCisAjs[idx])); - fprintf(FileCisAjs, "%d %d %d %d % .18e % .18e \n", CisAjsLzIdx[idx][0], CisAjsLzIdx[idx][1], - CisAjsLzIdx[idx][2], CisAjsLzIdx[idx][3], creal(PhysCisAjs[idx]), cimag(PhysCisAjs[idx])); - } - } + for (i = 0; i < NCisAjs; i++) + fprintf(FileCisAjs, "%d %d %d %d % .18e % .18e \n", CisAjsIdx[i][0], CisAjsIdx[i][1], CisAjsIdx[i][2], + CisAjsIdx[i][3], creal(PhysCisAjs[i]), cimag(PhysCisAjs[i])); fprintf(FileCisAjs, "\n"); } - /* zvo_cisajscktalt.dat */ + /* zvo_cisajscktaltex.dat */ if (NCisAjsCktAlt > 0) { for (i = 0; i < NCisAjsCktAlt; i++) fprintf(FileCisAjsCktAlt, "% .18e % .18e ", creal(PhysCisAjsCktAlt[i]), cimag(PhysCisAjsCktAlt[i])); fprintf(FileCisAjsCktAlt, "\n"); } - /* zvo_cisajscktaltdc.dat */ + /* zvo_cisajscktalt.dat */ if (NCisAjsCktAltDC > 0) { for (i = 0; i < NCisAjsCktAltDC; i++) { fprintf(FileCisAjsCktAltDC, "%d %d %d %d %d %d %d %d % .18e % .18e\n", @@ -702,16 +689,16 @@ void outputData() { if (NLanczosMode > 0) { if (AllComplexFlag == 0) { //real PhysCalLanczos_real( - QQQQ_real, QCisAjsQ_real, QCisAjsCktAltQ_real, - NLSHam, Nsite, NCisAjs, NCisAjsLz, iOneBodyGIdx, CisAjsLzIdx, NCisAjsCktAltDC, CisAjsCktAltDCIdx, NLanczosMode, - FileLS, FileLSQQQQ, FileLSQCisAjsQ, FileLSQCisAjsCktAltQ, - FileLSCisAjs, FileLSCisAjsCktAlt); + QQQQ_real, QCisAjsQ_real, QCisAjsCktAltQ_real, QCisAjsCktAltQDC_real, + NLSHam, Nsite, NCisAjs, NCisAjs, iOneBodyGIdx, CisAjsIdx, NCisAjsCktAlt, NCisAjsCktAltDC, CisAjsCktAltDCIdx, + NLanczosMode, FileLS, FileLSQQQQ, FileLSQCisAjsQ, FileLSQCisAjsCktAltQ, + FileLSCisAjs, FileLSCisAjsCktAlt, FileLSCisAjsCktAltDC); }else { //complex PhysCalLanczos_fcmp( - QQQQ, QCisAjsQ, QCisAjsCktAltQ, - NLSHam, Nsite, NCisAjs, NCisAjsLz, iOneBodyGIdx, CisAjsLzIdx, NCisAjsCktAltDC, CisAjsCktAltDCIdx, NLanczosMode, - FileLS, FileLSQQQQ, FileLSQCisAjsQ, FileLSQCisAjsCktAltQ, - FileLSCisAjs, FileLSCisAjsCktAlt); + QQQQ, QCisAjsQ, QCisAjsCktAltQ, QCisAjsCktAltQDC, + NLSHam, Nsite, NCisAjs, NCisAjs, iOneBodyGIdx, CisAjsIdx, NCisAjsCktAlt, NCisAjsCktAltDC, CisAjsCktAltDCIdx, + NLanczosMode, FileLS, FileLSQQQQ, FileLSQCisAjsQ, FileLSQCisAjsCktAltQ, + FileLSCisAjs, FileLSCisAjsCktAlt, FileLSCisAjsCktAltDC); } } } From 832230e3cb5f0ecc0138c2557e5b75e4163f7bc3 Mon Sep 17 00:00:00 2001 From: tmisawa Date: Tue, 1 Oct 2024 15:59:21 +0900 Subject: [PATCH 10/10] mod --- src/mVMC/vmccal.c | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/src/mVMC/vmccal.c b/src/mVMC/vmccal.c index e264c4f0..50a3fb39 100644 --- a/src/mVMC/vmccal.c +++ b/src/mVMC/vmccal.c @@ -77,7 +77,7 @@ void calculateQCACAQDC_real(double *qcacaq, const double *lslq, const double w, void calculateQCACAQDC(double complex *qcacaq, const double complex *lslq, const double w, const int nLSHam, const int nCA, const int nCACA, int *eleIdx, int *eleCfg, int *eleNum, int *eleProjCnt, - const double complex h1, const double complex ip); + const double complex h1, const double complex ip,double complex *rbmCnt); void VMCMainCal(MPI_Comm comm) { int *eleIdx,*eleCfg,*eleNum,*eleProjCnt; @@ -297,7 +297,7 @@ void VMCMainCal(MPI_Comm comm) { calculateQCACAQ(QCisAjsCktAltQ,LSLCisAjs,w,NLSHam,NCisAjs, NCisAjsCktAlt,CisAjsCktAltIdx); calculateQCACAQDC(QCisAjsCktAltQDC,LSLQ,w,NLSHam,NCisAjs, - NCisAjsCktAltDC,eleIdx,eleCfg,eleNum,eleProjCnt,e,ip); + NCisAjsCktAltDC,eleIdx,eleCfg,eleNum,eleProjCnt,e,ip,rbmCnt); } StopTimer(44); } @@ -977,7 +977,7 @@ void calculateQCACAQDC_real(double *qcacaq, const double *lslq, const double w, void calculateQCACAQDC(double complex *qcacaq, const double complex *lslq, const double w, const int nLSHam, const int nCA, const int nCACA, int *eleIdx, int *eleCfg, int *eleNum, int *eleProjCnt, - const double complex h1, const double complex ip) { + const double complex h1, const double complex ip,double complex *rbmCnt) { const int n=nLSHam*nLSHam*nCACA; int rq,rp,ri,rj,rk,rl,s,t,idx; int i,tmp; @@ -996,7 +996,7 @@ void calculateQCACAQDC(double complex *qcacaq, const double complex *lslq, const rl = CisAjsCktAltDCIdx[idx][6]; t = CisAjsCktAltDCIdx[idx][5]; qcacaq[i] += w * lslq[rp*nLSHam] * calHCACA(ri,rj,rk,rl,s,t,h1,ip, - eleIdx,eleCfg,eleNum,eleProjCnt); + eleIdx,eleCfg,eleNum,eleProjCnt,rbmCnt); } else qcacaq[i] += w * lslq[rp*nLSHam] * LocalCisAjsCktAltDC[idx]; }