diff --git a/ABACUS.org b/ABACUS.org new file mode 100644 index 0000000..1c212ea --- /dev/null +++ b/ABACUS.org @@ -0,0 +1,69 @@ +#+TODO: TODO(t@) | DONE(d@) +#+TODO: BUGREPORT(b@) CRITICAL(#@) | SOLVED(s@) +#+TODO: CONCEPT(c@) UPDATED(u@) | REJECTED(r@) +#+TODO: PICKEDUP(p@) | ABANDONED(k@) IMPLEMENTED(i@) + + +* Templates + :PROPERTIES: + :CUSTOM_ID: Templates + :END: +** Project +*** dev-unit +**** Description +Type your description here +**** Tasks +***** Task1example (needs a TODO state) + + + +* Bugs :ABACUS:Dev:Bugs: + :PROPERTIES: + :ARCHIVE: %s_archive::* Bugs + :CUSTOM_ID: Bugs + :END: + + +* Priority :ABACUS:Dev:Priority: + :PROPERTIES: + :ARCHIVE: %s_archive::* Priority + :CUSTOM_ID: Priority + :END: + + +* Implementation queue :ABACUS:Dev:ImpQueue: + :PROPERTIES: + :ARCHIVE: %s_archive::* Implementation queue + :CUSTOM_ID: ImplementationQueue + :END: + + +** CONCEPT Complex integration + - State "CONCEPT" from "" [2018-02-10 Sat 06:28] +*** Complete implementation of Integral_result_CX +**** Description +The `Integral_result_CX Integrate_optimal_using_table` functions are not yet implemented. +**** Tasks +***** Implement `Integral_result_CX Integrate_optimal_using_table` + + + + +** CONCEPT Rewrite ODSLF to use `State_Label` + - State "CONCEPT" from "" [2018-02-10 Sat 06:49] + + + +* Planning (short term) :ABACUS:Dev:PlanningST: + :PROPERTIES: + :ARCHIVE: %s_archive::* Planning (short term) + :CUSTOM_ID: PlanningShortTerm + :END: + + + +* Planning (long term) :ABACUS:Dev:PlanningLT: + :PROPERTIES: + :ARCHIVE: %s_archive::* Planning (long term) + :CUSTOM_ID: PlanningLongTerm + :END: diff --git a/Makefile b/Makefile index b634f10..ef78b9b 100644 --- a/Makefile +++ b/Makefile @@ -37,12 +37,12 @@ COMPILE = $(CXX) -I$(BASEDIR)include/ -L$(LIBDIR) -O3 -w -fopenmp COMPILE_MPI = mpicxx -I$(BASEDIR)include/ -L$(LIBDIR) -O3 -w -fopenmp #COMPILE_OMP = g++ -I$(BASEDIR)include/ -L$(LIBDIR) -O3 -w -fopenmp -VPATH = $(SRCDIR)BETHE:$(SRCDIR)LIEBLIN:$(SRCDIR)COMBI:$(SRCDIR)EXECS:$(SRCDIR)FITTING:$(SRCDIR)HEIS:$(SRCDIR)INTEG:$(SRCDIR)MATRIX:$(SRCDIR)NRG:$(SRCDIR)ODSLF:$(SRCDIR)SCAN:$(SRCDIR)TBA:$(SRCDIR)UTILS:$(SRCDIR)XXX_h0:$(SRCDIR)XXZ_h0:$(SRCDIR)YOUNG +VPATH = $(SRCDIR)BETHE:$(SRCDIR)LIEBLIN:$(SRCDIR)COMBI:$(SRCDIR)EXECS:$(SRCDIR)FITTING:$(SRCDIR)HEIS:$(SRCDIR)INTEG:$(SRCDIR)MATRIX:$(SRCDIR)NRG:$(SRCDIR)ODSLF:$(SRCDIR)SCAN:$(SRCDIR)TBA:$(SRCDIR)UTILS:$(SRCDIR)XXX_VOA:$(SRCDIR)XXZ_VOA:$(SRCDIR)YOUNG vpath %.h $(HEADDIR) -Headers_JSC = JSC.h JSC_util.h JSC_Combi.h JSC_Integ.h JSC_Matrix.h JSC_NRG.h JSC_Spec_Fns.h JSC_Vect.h JSC_Young.h -Headers_all = $(Headers_JSC) JSC_LiebLin.h JSC_Heis.h JSC_Scan.h JSC_State_Ensemble.h JSC_XXX_h0.h JSC_XXZ_h0.h +Headers_ABACUS = ABACUS.h ABACUS_Utils.h ABACUS_Combi.h ABACUS_Integ.h ABACUS_Matrix.h ABACUS_NRG.h ABACUS_Spec_Fns.h ABACUS_Vect.h ABACUS_Young.h +Headers_all = $(Headers_ABACUS) ABACUS_LiebLin.h ABACUS_Heis.h ABACUS_Scan.h ABACUS_State_Ensemble.h ABACUS_XXX_VOA.h ABACUS_XXZ_VOA.h Objects_LIEBLIN = $(OBJDIR)LiebLin_Bethe_State.o $(OBJDIR)LiebLin_Chem_Pot.o \ $(OBJDIR)LiebLin_Matrix_Element_Contrib.o $(OBJDIR)LiebLin_ln_Overlap.o \ @@ -84,15 +84,15 @@ Objects_TBA = $(OBJDIR)Root_Density.o $(OBJDIR)TBA_LiebLin.o $(OBJDIR)TBA_XXZ.o Objects_UTILS = $(OBJDIR)Data_File_Name.o $(OBJDIR)K_and_Omega_Files.o $(OBJDIR)Smoothen_RAW_into_SF.o \ $(OBJDIR)Smoothen_RAW_into_SF_LiebLin_Scaled.o $(OBJDIR)Sort_RAW_File.o $(OBJDIR)State_Label.o -Objects_XXX_h0 = $(OBJDIR)XXX_h0.o +Objects_XXX_VOA = $(OBJDIR)XXX_VOA.o -Objects_XXZ_h0 = $(OBJDIR)XXZ_h0.o +Objects_XXZ_VOA = $(OBJDIR)XXZ_VOA.o Objects_YOUNG = $(OBJDIR)Young_Tableau.o Objects_ALL = $(Objects_LIEBLIN) $(Objects_HEIS) $(Objects_COMBI) $(Objects_FITTING) \ $(Objects_INTEG) $(Objects_MATRIX) $(Objects_NRG) $(Objects_SCAN) $(Objects_TBA) \ - $(Objects_UTILS) $(Objects_XXX_h0) $(Objects_XXZ_h0) $(Objects_YOUNG) + $(Objects_UTILS) $(Objects_XXX_VOA) $(Objects_XXZ_VOA) $(Objects_YOUNG) EXECS = $(BINDIR)LiebLin_DSF $(BINDIR)LiebLin_Data_Daemon $(BINDIR)LiebLin_RAW_File_Stats \ $(BINDIR)LiebLin_DSF_tester $(BINDIR)LiebLin_DSF_tester_Ix2 $(BINDIR)LiebLin_DSF_MosesState \ @@ -144,218 +144,218 @@ lib$(VERSION).a : $(Objects_ALL) ########################################### # Interacting LiebLin gas -$(OBJDIR)LiebLin_Bethe_State.o : LiebLin_Bethe_State.cc $(Headers_JSC) JSC_LiebLin.h +$(OBJDIR)LiebLin_Bethe_State.o : LiebLin_Bethe_State.cc $(Headers_ABACUS) ABACUS_LiebLin.h $(COMPILE) -c $< -o $@ -$(OBJDIR)LiebLin_Chem_Pot.o : LiebLin_Chem_Pot.cc $(Headers_JSC) JSC_LiebLin.h +$(OBJDIR)LiebLin_Chem_Pot.o : LiebLin_Chem_Pot.cc $(Headers_ABACUS) ABACUS_LiebLin.h $(COMPILE) -c $< -o $@ -$(OBJDIR)LiebLin_Matrix_Element_Contrib.o : LiebLin_Matrix_Element_Contrib.cc $(Headers_JSC) JSC_LiebLin.h +$(OBJDIR)LiebLin_Matrix_Element_Contrib.o : LiebLin_Matrix_Element_Contrib.cc $(Headers_ABACUS) ABACUS_LiebLin.h $(COMPILE) -c $< -o $@ -$(OBJDIR)LiebLin_ln_Overlap.o : LiebLin_ln_Overlap.cc $(Headers_JSC) JSC_LiebLin.h +$(OBJDIR)LiebLin_ln_Overlap.o : LiebLin_ln_Overlap.cc $(Headers_ABACUS) ABACUS_LiebLin.h $(COMPILE) -c $< -o $@ -$(OBJDIR)LiebLin_Sumrules.o : LiebLin_Sumrules.cc $(Headers_JSC) JSC_LiebLin.h +$(OBJDIR)LiebLin_Sumrules.o : LiebLin_Sumrules.cc $(Headers_ABACUS) ABACUS_LiebLin.h $(COMPILE) -c $< -o $@ -$(OBJDIR)LiebLin_State_Ensemble.o : LiebLin_State_Ensemble.cc $(Headers_JSC) JSC_LiebLin.h +$(OBJDIR)LiebLin_State_Ensemble.o : LiebLin_State_Ensemble.cc $(Headers_ABACUS) ABACUS_LiebLin.h $(COMPILE) -c $< -o $@ -$(OBJDIR)LiebLin_Tgt0.o : LiebLin_Tgt0.cc $(Headers_JSC) JSC_LiebLin.h +$(OBJDIR)LiebLin_Tgt0.o : LiebLin_Tgt0.cc $(Headers_ABACUS) ABACUS_LiebLin.h $(COMPILE) -c $< -o $@ -$(OBJDIR)LiebLin_Twisted_lnnorm.o : LiebLin_Twisted_lnnorm.cc $(Headers_JSC) JSC_LiebLin.h +$(OBJDIR)LiebLin_Twisted_lnnorm.o : LiebLin_Twisted_lnnorm.cc $(Headers_ABACUS) ABACUS_LiebLin.h $(COMPILE) -c $< -o $@ -$(OBJDIR)LiebLin_Utils.o : LiebLin_Utils.cc $(Headers_JSC) JSC_LiebLin.h +$(OBJDIR)LiebLin_Utils.o : LiebLin_Utils.cc $(Headers_ABACUS) ABACUS_LiebLin.h $(COMPILE) -c $< -o $@ -$(OBJDIR)ln_Density_ME.o : ln_Density_ME.cc $(Headers_JSC) JSC_LiebLin.h +$(OBJDIR)ln_Density_ME.o : ln_Density_ME.cc $(Headers_ABACUS) ABACUS_LiebLin.h $(COMPILE) -c $< -o $@ -$(OBJDIR)LiebLin_Twisted_ln_Overlap.o : LiebLin_Twisted_ln_Overlap.cc $(Headers_JSC) JSC_LiebLin.h +$(OBJDIR)LiebLin_Twisted_ln_Overlap.o : LiebLin_Twisted_ln_Overlap.cc $(Headers_ABACUS) ABACUS_LiebLin.h $(COMPILE) -c $< -o $@ -$(OBJDIR)ln_Psi_ME.o : ln_Psi_ME.cc $(Headers_JSC) JSC_LiebLin.h +$(OBJDIR)ln_Psi_ME.o : ln_Psi_ME.cc $(Headers_ABACUS) ABACUS_LiebLin.h $(COMPILE) -c $< -o $@ -$(OBJDIR)ln_g2_ME.o : ln_g2_ME.cc $(Headers_JSC) JSC_LiebLin.h +$(OBJDIR)ln_g2_ME.o : ln_g2_ME.cc $(Headers_ABACUS) ABACUS_LiebLin.h $(COMPILE) -c $< -o $@ ########################################### # Heisenberg chains -$(OBJDIR)Heis.o : Heis.cc $(Headers_JSC) JSC_Heis.h +$(OBJDIR)Heis.o : Heis.cc $(Headers_ABACUS) ABACUS_Heis.h $(COMPILE) -c $< -o $@ -$(OBJDIR)Heis_Chem_Pot.o : Heis_Chem_Pot.cc $(Headers_JSC) JSC_Heis.h +$(OBJDIR)Heis_Chem_Pot.o : Heis_Chem_Pot.cc $(Headers_ABACUS) ABACUS_Heis.h $(COMPILE) -c $< -o $@ -$(OBJDIR)Heis_Sumrules.o : Heis_Sumrules.cc $(Headers_JSC) JSC_Heis.h +$(OBJDIR)Heis_Sumrules.o : Heis_Sumrules.cc $(Headers_ABACUS) ABACUS_Heis.h $(COMPILE) -c $< -o $@ -$(OBJDIR)Heis_Matrix_Element_Contrib.o : Heis_Matrix_Element_Contrib.cc $(Headers_JSC) JSC_Heis.h +$(OBJDIR)Heis_Matrix_Element_Contrib.o : Heis_Matrix_Element_Contrib.cc $(Headers_ABACUS) ABACUS_Heis.h $(COMPILE) -c $< -o $@ -$(OBJDIR)ln_Overlap_XXX.o : ln_Overlap_XXX.cc $(Headers_JSC) JSC_Heis.h +$(OBJDIR)ln_Overlap_XXX.o : ln_Overlap_XXX.cc $(Headers_ABACUS) ABACUS_Heis.h $(COMPILE) -c $< -o $@ -$(OBJDIR)ln_Sz_ME_XXX.o : ln_Sz_ME_XXX.cc $(Headers_JSC) JSC_Heis.h +$(OBJDIR)ln_Sz_ME_XXX.o : ln_Sz_ME_XXX.cc $(Headers_ABACUS) ABACUS_Heis.h $(COMPILE) -c $< -o $@ -$(OBJDIR)ln_Szz_ME_XXX.o : ln_Szz_ME_XXX.cc $(Headers_JSC) JSC_Heis.h +$(OBJDIR)ln_Szz_ME_XXX.o : ln_Szz_ME_XXX.cc $(Headers_ABACUS) ABACUS_Heis.h $(COMPILE) -c $< -o $@ -$(OBJDIR)ln_Smm_ME_XXX.o : ln_Smm_ME_XXX.cc $(Headers_JSC) JSC_Heis.h +$(OBJDIR)ln_Smm_ME_XXX.o : ln_Smm_ME_XXX.cc $(Headers_ABACUS) ABACUS_Heis.h $(COMPILE) -c $< -o $@ -$(OBJDIR)ln_Szm_p_Smz_ME_XXX.o : ln_Szm_p_Smz_ME_XXX.cc $(Headers_JSC) JSC_Heis.h +$(OBJDIR)ln_Szm_p_Smz_ME_XXX.o : ln_Szm_p_Smz_ME_XXX.cc $(Headers_ABACUS) ABACUS_Heis.h $(COMPILE) -c $< -o $@ -$(OBJDIR)ln_Sz_ME_XXZ.o : ln_Sz_ME_XXZ.cc $(Headers_JSC) JSC_Heis.h +$(OBJDIR)ln_Sz_ME_XXZ.o : ln_Sz_ME_XXZ.cc $(Headers_ABACUS) ABACUS_Heis.h $(COMPILE) -c $< -o $@ -$(OBJDIR)ln_Sz_ME_XXZ_gpd.o : ln_Sz_ME_XXZ_gpd.cc $(Headers_JSC) JSC_Heis.h +$(OBJDIR)ln_Sz_ME_XXZ_gpd.o : ln_Sz_ME_XXZ_gpd.cc $(Headers_ABACUS) ABACUS_Heis.h $(COMPILE) -c $< -o $@ -$(OBJDIR)ln_Smin_ME_XXX.o : ln_Smin_ME_XXX.cc $(Headers_JSC) JSC_Heis.h +$(OBJDIR)ln_Smin_ME_XXX.o : ln_Smin_ME_XXX.cc $(Headers_ABACUS) ABACUS_Heis.h $(COMPILE) -c $< -o $@ -$(OBJDIR)ln_Smin_ME_XXZ.o : ln_Smin_ME_XXZ.cc $(Headers_JSC) JSC_Heis.h +$(OBJDIR)ln_Smin_ME_XXZ.o : ln_Smin_ME_XXZ.cc $(Headers_ABACUS) ABACUS_Heis.h $(COMPILE) -c $< -o $@ -$(OBJDIR)ln_Smin_ME_XXZ_gpd.o : ln_Smin_ME_XXZ_gpd.cc $(Headers_JSC) JSC_Heis.h +$(OBJDIR)ln_Smin_ME_XXZ_gpd.o : ln_Smin_ME_XXZ_gpd.cc $(Headers_ABACUS) ABACUS_Heis.h $(COMPILE) -c $< -o $@ -$(OBJDIR)M_vs_H.o : M_vs_H.cc $(Headers_JSC) JSC_Heis.h +$(OBJDIR)M_vs_H.o : M_vs_H.cc $(Headers_ABACUS) ABACUS_Heis.h $(COMPILE) -c $< -o $@ -$(OBJDIR)XXX_Bethe_State.o : XXX_Bethe_State.cc $(Headers_JSC) JSC_Heis.h +$(OBJDIR)XXX_Bethe_State.o : XXX_Bethe_State.cc $(Headers_ABACUS) ABACUS_Heis.h $(COMPILE) -c $< -o $@ -$(OBJDIR)XXZ_Bethe_State.o : XXZ_Bethe_State.cc $(Headers_JSC) JSC_Heis.h +$(OBJDIR)XXZ_Bethe_State.o : XXZ_Bethe_State.cc $(Headers_ABACUS) ABACUS_Heis.h $(COMPILE) -c $< -o $@ -$(OBJDIR)XXZ_gpd_Bethe_State.o : XXZ_gpd_Bethe_State.cc $(Headers_JSC) JSC_Heis.h +$(OBJDIR)XXZ_gpd_Bethe_State.o : XXZ_gpd_Bethe_State.cc $(Headers_ABACUS) ABACUS_Heis.h $(COMPILE) -c $< -o $@ ########################################### # One-d spinless fermions -$(OBJDIR)ODSLF.o : ODSLF.cc $(Headers_JSC) JSC_Heis.h JSC_ODSLF.h +$(OBJDIR)ODSLF.o : ODSLF.cc $(Headers_ABACUS) ABACUS_Heis.h ABACUS_ODSLF.h $(COMPILE) -c $< -o $@ -$(OBJDIR)ODSLF_Chem_Pot.o : ODSLF_Chem_Pot.cc $(Headers_JSC) JSC_ODSLF.h +$(OBJDIR)ODSLF_Chem_Pot.o : ODSLF_Chem_Pot.cc $(Headers_ABACUS) ABACUS_ODSLF.h $(COMPILE) -c $< -o $@ -$(OBJDIR)ODSLF_Sumrules.o : ODSLF_Sumrules.cc $(Headers_JSC) JSC_ODSLF.h +$(OBJDIR)ODSLF_Sumrules.o : ODSLF_Sumrules.cc $(Headers_ABACUS) ABACUS_ODSLF.h $(COMPILE) -c $< -o $@ -$(OBJDIR)ODSLF_XXZ_Bethe_State.o : ODSLF_XXZ_Bethe_State.cc $(Headers_JSC) JSC_Heis.h JSC_ODSLF.h +$(OBJDIR)ODSLF_XXZ_Bethe_State.o : ODSLF_XXZ_Bethe_State.cc $(Headers_ABACUS) ABACUS_Heis.h ABACUS_ODSLF.h $(COMPILE) -c $< -o $@ -$(OBJDIR)ln_Smin_ME_ODSLF_XXZ.o : ln_Smin_ME_ODSLF_XXZ.cc $(Headers_JSC) JSC_ODSLF.h +$(OBJDIR)ln_Smin_ME_ODSLF_XXZ.o : ln_Smin_ME_ODSLF_XXZ.cc $(Headers_ABACUS) ABACUS_ODSLF.h $(COMPILE) -c $< -o $@ -$(OBJDIR)ln_Sz_ME_ODSLF_XXZ.o : ln_Sz_ME_ODSLF_XXZ.cc $(Headers_JSC) JSC_ODSLF.h +$(OBJDIR)ln_Sz_ME_ODSLF_XXZ.o : ln_Sz_ME_ODSLF_XXZ.cc $(Headers_ABACUS) ABACUS_ODSLF.h $(COMPILE) -c $< -o $@ -$(OBJDIR)ODSLF_Matrix_Element_Contrib.o : ODSLF_Matrix_Element_Contrib.cc $(Headers_JSC) JSC_ODSLF.h +$(OBJDIR)ODSLF_Matrix_Element_Contrib.o : ODSLF_Matrix_Element_Contrib.cc $(Headers_ABACUS) ABACUS_ODSLF.h $(COMPILE) -c $< -o $@ ########################################### # Combinatorics functions -$(OBJDIR)Combinatorics.o : Combinatorics.cc $(Headers_JSC) +$(OBJDIR)Combinatorics.o : Combinatorics.cc $(Headers_ABACUS) $(COMPILE) -c $< -o $@ ########################################### # Integ functions -$(OBJDIR)Integration.o : Integration.cc $(Headers_JSC) +$(OBJDIR)Integration.o : Integration.cc $(Headers_ABACUS) $(COMPILE) -c $< -o $@ ########################################### # Fitting functions -$(OBJDIR)covsrt.o : covsrt.cc $(Headers_JSC) +$(OBJDIR)covsrt.o : covsrt.cc $(Headers_ABACUS) $(COMPILE) -c $< -o $@ -$(OBJDIR)lin_reg.o : lin_reg.cc $(Headers_JSC) +$(OBJDIR)lin_reg.o : lin_reg.cc $(Headers_ABACUS) $(COMPILE) -c $< -o $@ -$(OBJDIR)mrq.o : mrq.cc $(Headers_JSC) +$(OBJDIR)mrq.o : mrq.cc $(Headers_ABACUS) $(COMPILE) -c $< -o $@ -$(OBJDIR)polint.o : polint.cc $(Headers_JSC) +$(OBJDIR)polint.o : polint.cc $(Headers_ABACUS) $(COMPILE) -c $< -o $@ -$(OBJDIR)polint_cx.o : polint_cx.cc $(Headers_JSC) +$(OBJDIR)polint_cx.o : polint_cx.cc $(Headers_ABACUS) $(COMPILE) -c $< -o $@ ########################################### # Matrix functions -$(OBJDIR)balanc.o : balanc.cc $(Headers_JSC) +$(OBJDIR)balanc.o : balanc.cc $(Headers_ABACUS) $(COMPILE) -c $< -o $@ -$(OBJDIR)det_LU.o : det_LU.cc $(Headers_JSC) +$(OBJDIR)det_LU.o : det_LU.cc $(Headers_ABACUS) $(COMPILE) -c $< -o $@ -$(OBJDIR)det_LU_CX.o : det_LU_CX.cc $(Headers_JSC) +$(OBJDIR)det_LU_CX.o : det_LU_CX.cc $(Headers_ABACUS) $(COMPILE) -c $< -o $@ -$(OBJDIR)eigsrt.o : eigsrt.cc $(Headers_JSC) +$(OBJDIR)eigsrt.o : eigsrt.cc $(Headers_ABACUS) $(COMPILE) -c $< -o $@ -$(OBJDIR)elmhes.o : elmhes.cc $(Headers_JSC) +$(OBJDIR)elmhes.o : elmhes.cc $(Headers_ABACUS) $(COMPILE) -c $< -o $@ -$(OBJDIR)gaussj.o : gaussj.cc $(Headers_JSC) +$(OBJDIR)gaussj.o : gaussj.cc $(Headers_ABACUS) $(COMPILE) -c $< -o $@ -$(OBJDIR)hqr.o : hqr.cc $(Headers_JSC) +$(OBJDIR)hqr.o : hqr.cc $(Headers_ABACUS) $(COMPILE) -c $< -o $@ -$(OBJDIR)jacobi.o : jacobi.cc $(Headers_JSC) +$(OBJDIR)jacobi.o : jacobi.cc $(Headers_ABACUS) $(COMPILE) -c $< -o $@ -$(OBJDIR)lndet_LU.o : lndet_LU.cc $(Headers_JSC) +$(OBJDIR)lndet_LU.o : lndet_LU.cc $(Headers_ABACUS) $(COMPILE) -c $< -o $@ -$(OBJDIR)lndet_LU_CX.o : lndet_LU_CX.cc $(Headers_JSC) +$(OBJDIR)lndet_LU_CX.o : lndet_LU_CX.cc $(Headers_ABACUS) $(COMPILE) -c $< -o $@ -$(OBJDIR)lndet_LU_dstry.o : lndet_LU_dstry.cc $(Headers_JSC) +$(OBJDIR)lndet_LU_dstry.o : lndet_LU_dstry.cc $(Headers_ABACUS) $(COMPILE) -c $< -o $@ -$(OBJDIR)lndet_LU_CX_dstry.o : lndet_LU_CX_dstry.cc $(Headers_JSC) +$(OBJDIR)lndet_LU_CX_dstry.o : lndet_LU_CX_dstry.cc $(Headers_ABACUS) $(COMPILE) -c $< -o $@ -$(OBJDIR)lubksb.o : lubksb.cc $(Headers_JSC) +$(OBJDIR)lubksb.o : lubksb.cc $(Headers_ABACUS) $(COMPILE) -c $< -o $@ -$(OBJDIR)lubksb_CX.o : lubksb_CX.cc $(Headers_JSC) +$(OBJDIR)lubksb_CX.o : lubksb_CX.cc $(Headers_ABACUS) $(COMPILE) -c $< -o $@ -$(OBJDIR)ludcmp.o : ludcmp.cc $(Headers_JSC) +$(OBJDIR)ludcmp.o : ludcmp.cc $(Headers_ABACUS) $(COMPILE) -c $< -o $@ -$(OBJDIR)ludcmp_CX.o : ludcmp_CX.cc $(Headers_JSC) +$(OBJDIR)ludcmp_CX.o : ludcmp_CX.cc $(Headers_ABACUS) $(COMPILE) -c $< -o $@ -$(OBJDIR)pythag.o : pythag.cc $(Headers_JSC) +$(OBJDIR)pythag.o : pythag.cc $(Headers_ABACUS) $(COMPILE) -c $< -o $@ -$(OBJDIR)tqli.o : tqli.cc $(Headers_JSC) +$(OBJDIR)tqli.o : tqli.cc $(Headers_ABACUS) $(COMPILE) -c $< -o $@ -$(OBJDIR)tred2.o : tred2.cc $(Headers_JSC) +$(OBJDIR)tred2.o : tred2.cc $(Headers_ABACUS) $(COMPILE) -c $< -o $@ @@ -399,16 +399,16 @@ $(OBJDIR)Scan_Thread_Data.o : Scan_Thread_Data.cc $(Headers_all) ########################################### # Thermodynamic Bethe Ansatz -$(OBJDIR)Root_Density.o : Root_Density.cc $(Headers_JSC) JSC_TBA.h +$(OBJDIR)Root_Density.o : Root_Density.cc $(Headers_ABACUS) ABACUS_TBA.h $(COMPILE) -c $< -o $@ -$(OBJDIR)TBA_LiebLin.o : TBA_LiebLin.cc $(Headers_JSC) JSC_TBA.h +$(OBJDIR)TBA_LiebLin.o : TBA_LiebLin.cc $(Headers_ABACUS) ABACUS_TBA.h $(COMPILE) -c $< -o $@ -$(OBJDIR)TBA_XXZ.o : TBA_XXZ.cc $(Headers_JSC) JSC_TBA.h +$(OBJDIR)TBA_XXZ.o : TBA_XXZ.cc $(Headers_ABACUS) ABACUS_TBA.h $(COMPILE) -c $< -o $@ -$(OBJDIR)TBA_2CBG.o : TBA_2CBG.cc $(Headers_JSC) JSC_TBA.h +$(OBJDIR)TBA_2CBG.o : TBA_2CBG.cc $(Headers_ABACUS) ABACUS_TBA.h $(COMPILE) -c $< -o $@ ########################################### @@ -433,15 +433,15 @@ $(OBJDIR)State_Label.o : State_Label.cc $(Headers_all) $(COMPILE) -c $< -o $@ ########################################### -# XXX_h0 +# XXX_VOA -$(OBJDIR)XXX_h0.o : XXX_h0.cc $(Headers_all) JSC_XXX_h0.h +$(OBJDIR)XXX_VOA.o : XXX_VOA.cc $(Headers_all) ABACUS_XXX_VOA.h $(COMPILE) -c $< -o $@ ########################################### -# XXZ_h0 +# XXZ_VOA -$(OBJDIR)XXZ_h0.o : XXZ_h0.cc $(Headers_all) JSC_XXZ_h0.h +$(OBJDIR)XXZ_VOA.o : XXZ_VOA.cc $(Headers_all) ABACUS_XXZ_VOA.h $(COMPILE) -c $< -o $@ ########################################### diff --git a/README.md b/README.md index 5e6cac8..fab35d9 100644 --- a/README.md +++ b/README.md @@ -26,7 +26,13 @@ $ make This will produce all executables, together with a library `ABACUS_[vn]` where vn is of the form [digit][character]. ---- +## Acknowledgements +__Antoine Klauser__ provided functions for computing neighbour-operator-product matrix elements in XXX: `ln_Szz_ME`, `ln_Szm_p_Smz_ME` and `ln_Smm_ME`. + +__Jacopo De Nardis__ provided the code for the `ln_g2_ME` function for Lieb-Liniger. + +__Teun Zwart__ has given much useful advice concerning C++ code organization. + Previous versions ================= diff --git a/include/JSC.h b/include/ABACUS.h similarity index 60% rename from include/JSC.h rename to include/ABACUS.h index b0def99..3b23635 100644 --- a/include/JSC.h +++ b/include/ABACUS.h @@ -2,31 +2,30 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- -File: JSC.h +File: ABACUS.h Purpose: Core header file, includes all descendents. - ***********************************************************/ -#ifndef _JSC_H_ -#define _JSC_H_ +#ifndef ABACUS_H +#define ABACUS_H // This core header file includes all the others -const char JSC_VERSION[20] = "ABACUS++G_8"; +const char ABACUS_VERSION[20] = "ABACUS++G_8"; // Standard includes -#include +#include #include // for complex number algebra #include #include -#include +#include #include #include // for exit(), ... @@ -46,77 +45,64 @@ const char JSC_VERSION[20] = "ABACUS++G_8"; #include /* signal name macros, and the signal() prototype */ // My own math functions and shortcuts -#include "JSC_util.h" +#include "ABACUS_Utils.h" // Vectors and matrices -#include "JSC_Vect.h" // My vector class definitions -#include "JSC_Matrix.h" // My matrix class definitions +#include "ABACUS_Vect.h" // My vector class definitions +#include "ABACUS_Matrix.h" // My matrix class definitions // Choose_Table -#include "JSC_Combi.h" +#include "ABACUS_Combi.h" // Fitting, interpolating -#include "JSC_Fitting.h" +#include "ABACUS_Fitting.h" // Young tableaux -#include "JSC_Young.h" +#include "ABACUS_Young.h" // Integration -#include "JSC_Integ.h" +#include "ABACUS_Integ.h" // Special functions: -#include "JSC_Spec_Fns.h" +#include "ABACUS_Spec_Fns.h" //*** Integrable models: // Heisenberg spin-1/2 antiferromagnet -#include "JSC_Heis.h" +#include "ABACUS_Heis.h" // Lieb-Liniger -#include "JSC_LiebLin.h" +#include "ABACUS_LiebLin.h" // One-d spinless fermions: -#include "JSC_ODSLF.h" +#include "ABACUS_ODSLF.h" // General: -//#include "JSC_Bethe.h" +//#include "ABACUS_Bethe.h" // IN DEVELOPMENT // Thermodynamic Bethe Ansatz utilities -#include "JSC_TBA.h" +#include "ABACUS_TBA.h" // State ensembles -#include "JSC_State_Ensemble.h" +#include "ABACUS_State_Ensemble.h" -// XXX in zero field: Uq(sl(2)) stuff -#include "JSC_XXX_h0.h" +// XXX in zero field: Vertex Operator Approach +#include "ABACUS_XXX_VOA.h" -// XXZ in zero field: quantum groups -#include "JSC_XXZ_h0.h" +// XXZ in zero field: Vertex Operator Approach +#include "ABACUS_XXZ_VOA.h" -// Two-component Bose gas -//#include "2CBG.h" - -// Richardson -//#include "Richardson.h" // *** Correlation functions: // New scanning protocols for ABACUS++ -#include "JSC_Scan.h" - -// Functions for everybody -//#include "JSC_fns.h" // KEEP THIS INCLUDE LAST, SINCE IT USES PREVIOUS DECLARATIONS +#include "ABACUS_Scan.h" // Numerical RG: -#include "JSC_NRG.h" - -// OpenMP -#include +#include "ABACUS_NRG.h" // Typedefs: typedef double DP; -#endif // _JSC_H_ - - +#endif // ABACUS_H diff --git a/include/JSC_Bethe.h b/include/ABACUS_Bethe.h similarity index 80% rename from include/JSC_Bethe.h rename to include/ABACUS_Bethe.h index dcc1bce..1698ba4 100644 --- a/include/JSC_Bethe.h +++ b/include/ABACUS_Bethe.h @@ -2,36 +2,24 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- -File: JSC_Bethe.h +File: ABACUS_Bethe.h Purpose: Declares Bethe state-related classes and functions. +Status: IN DEVELOPMENT + ***********************************************************/ -#ifndef _BETHE_ -#define _BETHE_ +#ifndef ABACUS_BETHE_H +#define ABACUS_BETHE_H -#include "JSC.h" +#include "ABACUS.h" -namespace JSC { - - /* - class Model { - - protected: - string Name; // LiebLin, XXZ, XXX, XXZ_gpd - int Nsites; // - int L; - DP interaction; - - public: - Model (string Name_ref, - }; - */ +namespace ABACUS { class Base { @@ -41,7 +29,7 @@ namespace JSC { Vect Nrap; // Nrap[i] contains the number of rapidities of type i, i = 0, ..., Nstrings - 1. int Nraptot; // total number of strings in this state Vect Ix2_infty; // Ix2_infty[i] contains the max of BAE function for the (half-)integer I[i], i = 0, Nstrings - 1. - Vect Ix2_min; + Vect Ix2_min; Vect Ix2_max; // Ix2_max[i] contains the integer part of 2*I_infty, with correct parity for base. string baselabel; @@ -51,20 +39,19 @@ namespace JSC { public: // LiebLin constructors Base (int N); // Constructor for repulsive LiebLin gas case: one type of particle - + public: // HEIS constructors - //Base (const Heis_Chain& RefChain, int M); // constructs configuration with all Mdown in one-string of +1 parity // DEPRECATED Base (const Heis_Chain& RefChain, const Vect& Nrapidities); // sets to Nrapidities vector, and checks consistency Base (const Heis_Chain& RefChain, string baselabel_ref); - - public: // operators + + public: // operators Base& operator= (const Base& RefBase); bool operator== (const Base& RefBase); bool operator!= (const Base& RefBase); public: // member functions - void Compute_Ix2_limits(const Heis_Chain& RefChain); // computes the Ix2_infty and Ix2_max - }; + void Compute_Ix2_limits(const Heis_Chain& RefChain); // computes the Ix2_infty and Ix2_max + }; //**************************************************************************** @@ -83,7 +70,7 @@ namespace JSC { int iK; DP K; DP lnnorm; - + public: // identification string label; // this is the relative label by default Vect > OriginIx2; // to define the relative label @@ -94,16 +81,14 @@ namespace JSC { int iter; int iter_Newton; - //public: // for descendents, etc - public: // constructors Bethe_State(); Bethe_State (const Bethe_State& RefState); // copy constructor - Bethe_State (const Bethe_State& OriginState, string label_ref); + Bethe_State (const Bethe_State& OriginState, string label_ref); LiebLin_Bethe_State& operator= (const LiebLin_Bethe_State& RefState); -} // namespace JSC +} // namespace ABACUS #endif diff --git a/include/JSC_Combi.h b/include/ABACUS_Combi.h similarity index 80% rename from include/JSC_Combi.h rename to include/ABACUS_Combi.h index d7eb31e..5a2637e 100644 --- a/include/JSC_Combi.h +++ b/include/ABACUS_Combi.h @@ -1,25 +1,23 @@ /********************************************************** -This software is part of J.-S. Caux's ABACUS++ library. +This software is part of J.-S. Caux's ABACUS library. -Copyright (c) 2006-9. +Copyright (c) J.-S. Caux. ----------------------------------------------------------- -File: JSC_Combi.h +File: ABACUS_Combi.h Purpose: Declares combinatorics-related classes and functions. -Last modified: 08/10/2009 - ***********************************************************/ -#ifndef _COMBI_ -#define _COMBI_ +#ifndef ABACUS_COMBI_H +#define ABACUS_COMBI_H -#include "JSC.h" +#include "ABACUS.h" -namespace JSC { +namespace ABACUS { //*********************************************************************** @@ -46,6 +44,6 @@ namespace JSC { std::ostream& operator<< (std::ostream& s, Choose_Table& Ref_table); -} // namespace JSC +} // namespace ABACUS #endif diff --git a/include/JSC_Fitting.h b/include/ABACUS_Fitting.h similarity index 75% rename from include/JSC_Fitting.h rename to include/ABACUS_Fitting.h index a10b38f..7df7224 100644 --- a/include/JSC_Fitting.h +++ b/include/ABACUS_Fitting.h @@ -2,26 +2,26 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- -File: JSC.h +File: ABACUS_Fitting.h -Purpose: Core header file, includes all descendents. +Purpose: Defines functions for fitting: linear regression etc. ***********************************************************/ -#ifndef _FITTING_ -#define _FITTING_ +#ifndef ABACUS_FITTING_H +#define ABACUS_FITTING_H -namespace JSC { +namespace ABACUS { // Functions in src/FITTING directory void covsrt (SQMat_DP& covar, Vect& ia, const int mfit); void lin_reg (Vect_DP x, Vect_DP y, Vect_DP sigma, DP& a, DP& b, DP& chisq); void lin_reg (Vect_DP x, Vect_DP y, DP& a, DP& b, DP& chisq); - void mrqmin (Vect_DP& x, Vect_DP& y, Vect_DP& sig, Vect_DP& a, + void mrqmin (Vect_DP& x, Vect_DP& y, Vect_DP& sig, Vect_DP& a, Vect& ia, SQMat_DP& covar, SQMat_DP& alpha, DP& chisq, void funcs(const DP, Vect_DP&, DP&, Vect_DP&), DP& alambda); void mrqcof (Vect_DP& x, Vect_DP& y, Vect_DP& sig, Vect_DP& a, @@ -30,8 +30,8 @@ namespace JSC { // For interpolating: void polint(Vect_DP& xa, Vect_DP& ya, const DP x, DP& y, DP& dy); - void polint(Vect_CX& xa, Vect_CX& ya, const complex x, complex& y, complex& dy); + void polint(Vect_CX& xa, Vect_CX& ya, const std::complex x, std::complex& y, std::complex& dy); -} // namespace JSC +} // namespace ABACUS #endif diff --git a/include/ABACUS_Heis.h b/include/ABACUS_Heis.h new file mode 100644 index 0000000..8a7d187 --- /dev/null +++ b/include/ABACUS_Heis.h @@ -0,0 +1,428 @@ +/********************************************************** + +This software is part of J.-S. Caux's ABACUS library. + +Copyright (c) J.-S. Caux. + +----------------------------------------------------------- + +File: ABACUS_Heis.h + +Purpose: Declares Heisenberg chain classes and functions. + +***********************************************************/ + +#ifndef ABACUS_HEIS_H +#define ABACUS_HEIS_H + +#include "ABACUS.h" + +namespace ABACUS { + + // First, some global constants... + + const long long int ID_UPPER_LIMIT = 10000000LL; // max size of vectors we can define without seg fault + const int INTERVALS_SIZE = 100000; // size of Scan_Intervals arrays + const int NBASESMAX = 1000; // max number of bases kept + + const DP ITER_REQ_PREC = 100.0 * MACHINE_EPS_SQ; + + // Cutoffs on particle numbers + const int MAXSTRINGS = 20; // maximal number of particle types we allow in bases + + const int NEXC_MAX_HEIS = 16; // maximal number of excitations (string binding/unbinding, particle-hole) considered + + + //*********************************************************************** + + class Heis_Chain { + + public: + DP J; + DP Delta; + DP anis; // acos(Delta) if Delta < 1.0, 0 if Delta == 1.0, acosh(Delta) if Delta > 1.0 + DP hz; + int Nsites; + int Nstrings; // how many possible strings. The following two arrays have Nstrings nonzero elements. + int* Str_L; // vector (length M) containing the allowed string lengths. Elements that are 0 have no meaning. + int* par; // vector (length M) containing the parities of the strings. Elements that are 0 have no meaning. + // Parities are all +1 except for gapless XXZ subcases + DP* si_n_anis_over_2; // for optimization: sin for XXZ, sinh for XXZ_gpd + DP* co_n_anis_over_2; // for optimization + DP* ta_n_anis_over_2; // for optimization + DP prec; // precision required for computations, always put to ITER_REQ_PREC + + public: + Heis_Chain (); + Heis_Chain (DP JJ, DP DD, DP hh, int NN); // contructor: simply initializes + Heis_Chain (const Heis_Chain& RefChain); // copy constructor; + Heis_Chain& operator= (const Heis_Chain& RefChain); + bool operator== (const Heis_Chain& RefChain); + bool operator!= (const Heis_Chain& RefChain); + ~Heis_Chain(); // destructor + + }; + + + //**************************************************************************** + + // Objects in class Heis_Base are a checked vector containing the number of rapidities of allowable types for a given state + + class Heis_Base { + + public: + int Mdown; // total number of down spins + Vect Nrap; // Nrap[i] contains the number of rapidities of type i, i = 0, Nstrings - 1. + int Nraptot; // total number of strings in this state + Vect Ix2_infty; // Ix2_infty[i] contains the max of BAE function for the (half-)integer I[i], i = 0, Nstrings - 1. + Vect Ix2_min; + Vect Ix2_max; // Ix2_max[i] contains the integer part of 2*I_infty, with correct parity for base. + double dimH; // dimension of sub Hilbert space associated to this base; use double to avoid max int problems. + std::string baselabel; // base label + + public: + Heis_Base (); + Heis_Base (const Heis_Base& RefBase); // copy constructor + Heis_Base (const Heis_Chain& RefChain, int M); // constructs configuration with all Mdown in one-string of +1 parity + Heis_Base (const Heis_Chain& RefChain, const Vect& Nrapidities); // sets to Nrapidities vector, and checks consistency + Heis_Base (const Heis_Chain& RefChain, std::string baselabel_ref); + inline int& operator[] (const int i); + inline const int& operator[] (const int i) const; + Heis_Base& operator= (const Heis_Base& RefBase); + bool operator== (const Heis_Base& RefBase); + bool operator!= (const Heis_Base& RefBase); + + void Compute_Ix2_limits(const Heis_Chain& RefChain); // computes the Ix2_infty and Ix2_max + + }; + + inline int& Heis_Base::operator[] (const int i) + { + return Nrap[i]; + } + + inline const int& Heis_Base::operator[] (const int i) const + { + return Nrap[i]; + } + + + //**************************************************************************** + + // Objects in class Lambda carry all rapidities of a state + + class Lambda { + + private: + int Nstrings; + Vect Nrap; + int Nraptot; + DP** lambda; + + public: + Lambda (); + Lambda (const Heis_Chain& RefChain, int M); // constructor, puts all lambda's to zero + Lambda (const Heis_Chain& RefChain, const Heis_Base& base); // constructor, putting I's to lowest-energy config + // consistent with Heis_Base configuration for chain RefChain + Lambda& operator= (const Lambda& RefConfig); + inline DP* operator[] (const int i); + inline const DP* operator[] (const int i) const; + ~Lambda(); + + }; + + inline DP* Lambda::operator[] (const int i) + { + return lambda[i]; + } + + inline const DP* Lambda::operator[] (const int i) const + { + return lambda[i]; + } + + + //**************************************************************************** + + // Objects in class Heis_Bethe_State carry all information about an eigenstate + + // Derived classes include XXZ_Bethe_State, XXX_Bethe_State, XXZ_gpd_Bethe_State + // These contain subclass-specific functions and data. + + class Heis_Bethe_State { + + public: + Heis_Chain chain; + Heis_Base base; + Vect > Ix2; + Lambda lambda; + Lambda deviation; // string deviations + Lambda BE; // Bethe equation for relevant rapidity, in the form BE = theta - (1/N)\sum ... - \pi I/N = 0 + DP diffsq; // sum of squares of rapidity differences in last iteration + int conv; // convergence status + DP dev; // sum of absolute values of string deviations + int iter; // number of iterations necessary for convergence + int iter_Newton; // number of iterations necessary for convergence (Newton method) + DP E; // total energy + int iK; // K = 2.0*PI * iK/Nsites + DP K; // total momentum + DP lnnorm; // ln of norm of reduced Gaudin matrix + std::string label; + + public: + Heis_Bethe_State (); + Heis_Bethe_State (const Heis_Bethe_State& RefState); // copy constructor + Heis_Bethe_State (const Heis_Chain& RefChain, int M); // constructor to ground-state configuration + Heis_Bethe_State (const Heis_Chain& RefChain, const Heis_Base& base); // constructor to lowest-energy config with base + virtual ~Heis_Bethe_State () {}; + + public: + int Charge () { return(base.Mdown); }; + void Set_to_Label (std::string label_ref, const Vect >& OriginIx2); + void Set_Label_from_Ix2 (const Vect >& OriginIx2); + bool Check_Symmetry (); // checks whether the I's are symmetrically distributed + void Compute_diffsq (); // \sum BE[j][alpha]^2 + void Find_Rapidities (bool reset_rapidities); // Finds the rapidities + void Find_Rapidities_Twisted (bool reset_rapidities, DP twist); // Finds the rapidities with twist added to RHS of logBE + void Solve_BAE_bisect (int j, int alpha, DP req_prec, int itermax); + void Iterate_BAE (DP iter_factor); // Finds new set of lambda[j][alpha] from previous one by simple iteration + void Solve_BAE_straight_iter (DP straight_prec, int max_iter_interp, DP iter_factor); + void Solve_BAE_extrap (DP extrap_prec, int max_iter_extrap, DP iter_factor); + void Iterate_BAE_Newton (); // Finds new set of lambda[j][alpha] from previous one by a Newton step + void Solve_BAE_Newton (DP Newton_prec, int max_iter_Newton); + void Solve_BAE_with_silk_gloves (DP silk_prec, int max_iter_silk, DP iter_factor); + void Compute_lnnorm (); + void Compute_Momentum (); + void Compute_All (bool reset_rapidities); // solves BAE, computes E, K and lnnorm + + inline bool Set_to_Inner_Skeleton (int iKneeded, const Vect >& OriginStateIx2) + { + Ix2[0][0] = Ix2[0][1] - 2; + Ix2[0][base.Nrap[0] - 1] = Ix2[0][base.Nrap[0] - 2] + 2; + (*this).Compute_Momentum(); + if (base.Nrap[0] == 0) return(false); + if (iKneeded >= iK) Ix2[0][base.Nrap[0]-1] += 2*(iKneeded - iK); + else Ix2[0][0] += 2*(iKneeded - iK); + if (Ix2[0][0] < base.Ix2_min[0] || Ix2[0][base.Nrap[0]-1] > base.Ix2_max[0]) return(false); + (*this).Set_Label_from_Ix2 (OriginStateIx2); + return(true); + } + void Set_to_Outer_Skeleton (const Vect >& OriginStateIx2) { + Ix2[0][0] = base.Ix2_min[0] - 4; + Ix2[0][base.Nrap[0]-1] = base.Ix2_max[0] + 4; + (*this).Set_Label_from_Ix2 (OriginStateIx2); + }; + + void Set_to_Closest_Matching_Ix2_fixed_Base (const Heis_Bethe_State& StateToMatch); // defined in Heis.cc + + + // Virtual functions, all defined in the derived classes + + public: + virtual void Set_Free_lambdas() { ABACUSerror("Heis_Bethe_State::..."); } // sets the rapidities to solutions of BAEs without scattering terms + virtual bool Check_Admissibility(char option) { ABACUSerror("Heis_Bethe_State::..."); return(false); } + // verifies that we don't have a symmetrical Ix2 config with a Ix2 == 0 for a string of even length >= 2. + virtual void Compute_BE (int j, int alpha) { ABACUSerror("Heis_Bethe_State::..."); } + virtual void Compute_BE () { ABACUSerror("Heis_Bethe_State::..."); } + virtual DP Iterate_BAE(int i, int alpha) { ABACUSerror("Heis_Bethe_State::..."); return(0.0);} + virtual bool Check_Rapidities() { ABACUSerror("Heis_Bethe_State::..."); return(false); } + virtual DP String_delta () { ABACUSerror("Heis_Bethe_State::..."); return(0.0); } + virtual void Compute_Energy () { ABACUSerror("Heis_Bethe_State::..."); } + virtual void Build_Reduced_Gaudin_Matrix (SQMat >& Gaudin_Red) { ABACUSerror("Heis_Bethe_State::..."); } + }; + + inline bool Is_Inner_Skeleton (Heis_Bethe_State& State) { + return (State.base.Nrap[0] >= 2 && (State.Ix2[0][0] == State.Ix2[0][1] - 2 || State.Ix2[0][State.base.Nrap[0]-1] == State.Ix2[0][State.base.Nrap[0]-2] + 2)); + }; + inline bool Is_Outer_Skeleton (Heis_Bethe_State& State) { + return (State.Ix2[0][0] == State.base.Ix2_min[0] - 4 && State.Ix2[0][State.base.Nrap[0]-1] == State.base.Ix2_max[0] + 4); + }; + + inline bool Force_Descent (char whichDSF, Heis_Bethe_State& ScanState, Heis_Bethe_State& RefState, int desc_type_required, int iKmod, DP Chem_Pot) + { + bool force_descent = false; + + // Force descent for all DSFs if we're at K = 0 or PI and not conserving momentum upon descent: + if (desc_type_required > 8 && (2*(ScanState.iK - RefState.iK) % iKmod == 0)) force_descent = true; // type_req > 8 means that we don't conserve momentum + + return(force_descent); + } + + + std::ostream& operator<< (std::ostream& s, const Heis_Bethe_State& state); + + + //**************************************************************************** + + // Objects in class XXZ_Bethe_State carry all extra information pertaining to XXZ gapless + + class XXZ_Bethe_State : public Heis_Bethe_State { + + public: + Lambda sinhlambda; + Lambda coshlambda; + Lambda tanhlambda; + + public: + XXZ_Bethe_State (); + XXZ_Bethe_State (const XXZ_Bethe_State& RefState); // copy constructor + XXZ_Bethe_State (const Heis_Chain& RefChain, int M); // constructor to ground-state configuration + XXZ_Bethe_State (const Heis_Chain& RefChain, const Heis_Base& base); // constructor to lowest-energy config with base + + public: + XXZ_Bethe_State& operator= (const XXZ_Bethe_State& RefState); + + public: + void Set_Free_lambdas(); // sets the rapidities to solutions of BAEs without scattering terms + void Compute_sinhlambda(); + void Compute_coshlambda(); + void Compute_tanhlambda(); + bool Check_Admissibility(char option); // verifies that we don't have a symmetrical Ix2 config with a Ix2 == 0 for a string of even length >= 2. + void Compute_BE (int j, int alpha); + void Compute_BE (); + DP Iterate_BAE(int i, int j); + bool Check_Rapidities(); // checks that all rapidities are not nan + DP String_delta (); + void Compute_Energy (); + void Build_Reduced_Gaudin_Matrix (SQMat >& Gaudin_Red); + + // XXZ specific functions: + public: + + }; + + XXZ_Bethe_State Add_Particle_at_Center (const XXZ_Bethe_State& RefState); + XXZ_Bethe_State Remove_Particle_at_Center (const XXZ_Bethe_State& RefState); + + + //**************************************************************************** + + // Objects in class XXX_Bethe_State carry all extra information pertaining to XXX antiferromagnet + + class XXX_Bethe_State : public Heis_Bethe_State { + + public: + XXX_Bethe_State (); + XXX_Bethe_State (const XXX_Bethe_State& RefState); // copy constructor + XXX_Bethe_State (const Heis_Chain& RefChain, int M); // constructor to ground-state configuration + XXX_Bethe_State (const Heis_Chain& RefChain, const Heis_Base& base); // constructor to lowest-energy config with base + + public: + XXX_Bethe_State& operator= (const XXX_Bethe_State& RefState); + + public: + void Set_Free_lambdas(); // sets the rapidities to solutions of BAEs without scattering terms + bool Check_Admissibility(char option); // verifies that we don't have a symmetrical Ix2 config with a Ix2 == 0 for a string of even length >= 2. + void Compute_BE (int j, int alpha); + void Compute_BE (); + DP Iterate_BAE(int i, int j); + bool Check_Rapidities(); // checks that all rapidities are not nan + DP String_delta (); + void Compute_Energy (); + void Build_Reduced_Gaudin_Matrix (SQMat >& Gaudin_Red); + + // XXX specific functions + public: + bool Check_Finite_rap (); + + }; + + XXX_Bethe_State Add_Particle_at_Center (const XXX_Bethe_State& RefState); + XXX_Bethe_State Remove_Particle_at_Center (const XXX_Bethe_State& RefState); + + //**************************************************************************** + + // Objects in class XXZ_gpd_Bethe_State carry all extra information pertaining to XXZ gapped antiferromagnets + + class XXZ_gpd_Bethe_State : public Heis_Bethe_State { + + public: + Lambda sinlambda; + Lambda coslambda; + Lambda tanlambda; + + public: + XXZ_gpd_Bethe_State (); + XXZ_gpd_Bethe_State (const XXZ_gpd_Bethe_State& RefState); // copy constructor + XXZ_gpd_Bethe_State (const Heis_Chain& RefChain, int M); // constructor to ground-state configuration + XXZ_gpd_Bethe_State (const Heis_Chain& RefChain, const Heis_Base& base); // constructor to lowest-energy config with base + + public: + XXZ_gpd_Bethe_State& operator= (const XXZ_gpd_Bethe_State& RefState); + + public: + void Set_Free_lambdas(); // sets the rapidities to solutions of BAEs without scattering terms + void Compute_sinlambda(); + void Compute_coslambda(); + void Compute_tanlambda(); + int Weight(); // weight function for contributions cutoff + bool Check_Admissibility(char option); // verifies that we don't have a symmetrical Ix2 config with a Ix2 == 0 for a string of even length >= 2. + void Compute_BE (int j, int alpha); + void Compute_BE (); + DP Iterate_BAE(int i, int j); + void Iterate_BAE_Newton(); + bool Check_Rapidities(); // checks that all rapidities are not nan and are in interval ]-PI/2, PI/2] + DP String_delta (); + void Compute_Energy (); + void Build_Reduced_Gaudin_Matrix (SQMat >& Gaudin_Red); + + // XXZ_gpd specific functions + public: + + }; + + XXZ_gpd_Bethe_State Add_Particle_at_Center (const XXZ_gpd_Bethe_State& RefState); + XXZ_gpd_Bethe_State Remove_Particle_at_Center (const XXZ_gpd_Bethe_State& RefState); + + + //*********************************************** + + // Function declarations + + // in M_vs_H.cc + DP Ezero (DP Delta, int N, int M); + DP H_vs_M (DP Delta, int N, int M); + DP HZmin (DP Delta, int N, int M, Vect_DP& Ezero_ref); + int M_vs_H (DP Delta, int N, DP HZ); + + DP X_avg (char xyorz, DP Delta, int N, int M); + + DP Chemical_Potential (const Heis_Bethe_State& RefState); + DP Particle_Hole_Excitation_Cost (char whichDSF, Heis_Bethe_State& AveragingState); + + //DP Sumrule_Factor (char whichDSF, Heis_Bethe_State& RefState, DP Chem_Pot, bool fixed_iK, int iKneeded); + DP Sumrule_Factor (char whichDSF, Heis_Bethe_State& RefState, DP Chem_Pot, int iKmin, int iKmax); + void Evaluate_F_Sumrule (std::string prefix, char whichDSF, const Heis_Bethe_State& RefState, DP Chem_Pot, int iKmin, int iKmax); + + std::complex ln_Sz_ME (XXZ_Bethe_State& A, XXZ_Bethe_State& B); + std::complex ln_Smin_ME (XXZ_Bethe_State& A, XXZ_Bethe_State& B); + + std::complex ln_Sz_ME (XXX_Bethe_State& A, XXX_Bethe_State& B); + std::complex ln_Smin_ME (XXX_Bethe_State& A, XXX_Bethe_State& B); + + // From Antoine Klauser: + std::complex ln_Szz_ME (XXX_Bethe_State& A, XXX_Bethe_State& B); + std::complex ln_Szm_p_Smz_ME (XXX_Bethe_State& A, XXX_Bethe_State& B); + std::complex ln_Smm_ME (XXX_Bethe_State& A, XXX_Bethe_State& B); + + std::complex ln_Sz_ME (XXZ_gpd_Bethe_State& A, XXZ_gpd_Bethe_State& B); + std::complex ln_Smin_ME (XXZ_gpd_Bethe_State& A, XXZ_gpd_Bethe_State& B); + + + DP Compute_Matrix_Element_Contrib (char whichDSF, int iKmin, int iKmax, XXZ_Bethe_State& LeftState, + XXZ_Bethe_State& RefState, DP Chem_Pot, std::stringstream& DAT_outfile); + DP Compute_Matrix_Element_Contrib (char whichDSF, int iKmin, int iKmax, XXX_Bethe_State& LeftState, + XXX_Bethe_State& RefState, DP Chem_Pot, std::stringstream& DAT_outfile); + DP Compute_Matrix_Element_Contrib (char whichDSF, int iKmin, int iKmax, XXZ_gpd_Bethe_State& LeftState, + XXZ_gpd_Bethe_State& RefState, DP Chem_Pot, std::stringstream& DAT_outfile); + + // For geometric quench: + std::complex ln_Overlap (XXX_Bethe_State& A, XXX_Bethe_State& B); + + void Scan_Heis_Geometric_Quench (DP Delta, int N_1, int M, long long int base_id_1, long long int type_id_1, long long int id_1, + int N_2, int iKmin, int iKmax, int Max_Secs, bool refine); + + +} // namespace ABACUS + +#endif diff --git a/include/JSC_Integ.h b/include/ABACUS_Integ.h similarity index 69% rename from include/JSC_Integ.h rename to include/ABACUS_Integ.h index a3affe7..97f7f09 100644 --- a/include/JSC_Integ.h +++ b/include/ABACUS_Integ.h @@ -1,31 +1,30 @@ /********************************************************** -This software is part of J.-S. Caux's ABACUS++ library. +This software is part of J.-S. Caux's ABACUS library. -Copyright (c) +Copyright (c) J.-S. Caux. ----------------------------------------------------------- -File: JSC_Integ.h +File: ABACUS_Integ.h Purpose: Declares combinatorics-related classes and functions. - ***********************************************************/ -#ifndef _INTEG_ -#define _INTEG_ +#ifndef ABACUS_INTEG_H +#define ABACUS_INTEG_H -#include "JSC.h" +#include "ABACUS.h" -namespace JSC { +namespace ABACUS { //********************** Class Domain ************************ template class Domain { - + private: Vect bdry; @@ -35,41 +34,41 @@ namespace JSC { bdry[0] = T(0); bdry[1] = T(0); } - + public: Domain (T xmin_ref, T xmax_ref) : bdry(Vect(2)) { - if (xmax_ref < xmin_ref) JSCerror("Use xmax > xmin in Domain."); - + if (xmax_ref < xmin_ref) ABACUSerror("Use xmax > xmin in Domain."); + bdry[0] = xmin_ref; bdry[1] = xmax_ref; } - + public: inline T xmin (int i) - { - if (i > bdry.size()/2) JSCerror("i index too high in Domain::xmin."); - - return(bdry[2*i]); - } - + { + if (i > bdry.size()/2) ABACUSerror("i index too high in Domain::xmin."); + + return(bdry[2*i]); + } + public: inline T xmax (int i) - { - if (i > bdry.size()/2) JSCerror("i index too high in Domain::xmax."); - - return(bdry[2*i + 1]); - } - + { + if (i > bdry.size()/2) ABACUSerror("i index too high in Domain::xmax."); + + return(bdry[2*i + 1]); + } + public: inline int Ndomains () - { - return(bdry.size()/2); - } + { + return(bdry.size()/2); + } public: void Include (T xmin_ref, T xmax_ref) { - + // Determine the indices of xmin_ref & xmax_ref int xmin_reg = -1; int xmax_reg = -1; @@ -79,15 +78,13 @@ namespace JSC { if ((i+1) % 2 && bdry[i] <= xmax_ref) xmax_reg++; if (i % 2 && bdry[i] < xmax_ref) xmax_reg++; } - - //cout << "Include: xmin_reg = " << xmin_reg << "\txmax_reg = " << xmax_reg << endl; - + Vect new_bdry(bdry.size() + 2 * ((xmin_reg % 2 && xmax_reg % 2) - (xmax_reg - xmin_reg)/2)); - + int ishift = 0; for (int i = 0; i <= xmin_reg; ++i) new_bdry[i] = bdry[i]; if (xmin_reg % 2) { - new_bdry[xmin_reg + 1] = xmin_ref; + new_bdry[xmin_reg + 1] = xmin_ref; ishift++; if (xmax_reg % 2) { new_bdry[xmin_reg + 2] = xmax_ref; @@ -100,15 +97,15 @@ namespace JSC { } for (int i = xmin_reg + ishift + 1; i < new_bdry.size(); ++i) new_bdry[i] = bdry[xmax_reg - xmin_reg - ishift + i]; - + bdry = new_bdry; - + return; } - + public: void Exclude (T xmin_ref, T xmax_ref) { - + // Determine the indices of xmin_ref & xmax_ref int xmin_reg = -1; int xmax_reg = -1; @@ -118,15 +115,13 @@ namespace JSC { if ((i+1) % 2 && bdry[i] <= xmax_ref) xmax_reg++; if (i % 2 && bdry[i] < xmax_ref) xmax_reg++; } - - //cout << "Exclude: xmin_reg = " << xmin_reg << "\txmax_reg = " << xmax_reg << endl; - + Vect new_bdry(bdry.size() + 2 * (((xmin_reg + 1) % 2 && (xmax_reg + 1) % 2) - (xmax_reg - xmin_reg)/2)); - + int ishift = 0; for (int i = 0; i <= xmin_reg; ++i) new_bdry[i] = bdry[i]; if ((xmin_reg + 1) % 2) { - new_bdry[xmin_reg + 1] = xmin_ref; + new_bdry[xmin_reg + 1] = xmin_ref; ishift++; if ((xmax_reg + 1) % 2) { new_bdry[xmin_reg + 2] = xmax_ref; @@ -139,24 +134,25 @@ namespace JSC { } for (int i = xmin_reg + ishift + 1; i < new_bdry.size(); ++i) new_bdry[i] = bdry[xmax_reg - xmin_reg - ishift + i]; - + bdry = new_bdry; - + return; } - + }; template std::ostream& operator<< (std::ostream& s, Domain dom) { for (int i = 0; i < dom.Ndomains(); ++i) { - if (i > 0) s << endl; + if (i > 0) s << std::endl; s << dom.xmin(i) << "\t" << dom.xmax(i); } return(s); } + // ********************************* struct I_table ************************ struct I_table { @@ -168,11 +164,9 @@ namespace JSC { DP alpha; DP logalpha; DP prec; - //Vect_DP rho_tbl; - //Vect_DP I_tbl; DP* rho_tbl; DP* I_tbl; - + I_table (DP (*function) (DP, DP), DP rhomin_ref, DP rhomax_ref, int Nvals_ref, DP req_prec); DP Return_val (DP req_rho); void Save (); @@ -195,8 +189,9 @@ namespace JSC { int maxnrpts; DP* rho_tbl; DP* I_tbl; - - Integral_table (DP (*function) (DP, DP, int), const char* filenameprefix_ref, DP rhomin_ref, DP rhomax_ref, int Nvals_ref, DP req_prec, int max_nr_pts); + + Integral_table (DP (*function) (DP, DP, int), const char* filenameprefix_ref, DP rhomin_ref, + DP rhomax_ref, int Nvals_ref, DP req_prec, int max_nr_pts); DP Return_val (DP req_rho); void Save (const char* filenameprefix); bool Load (const char* filenameprefix, DP rhomin_ref, DP rhomax_ref, int Nvals_ref, DP req_prec, int max_nr_pts); @@ -207,16 +202,17 @@ namespace JSC { // ******************************** Recursive integration functions ****************************** DP Integrate_Riemann (DP (*function) (Vect_DP), Vect_DP& args, int arg_to_integ, DP xmin, DP xmax, int Npts); - DP Integrate_Riemann_using_table (DP (*function) (Vect_DP, I_table), Vect_DP& args, int arg_to_integ, I_table Itable, + DP Integrate_Riemann_using_table (DP (*function) (Vect_DP, I_table), Vect_DP& args, int arg_to_integ, I_table Itable, DP xmin, DP xmax, int Npts); DP Integrate_rec (DP (*function) (Vect_DP), Vect_DP& args, int arg_to_integ, DP xmin, DP xmax, DP req_prec, int max_rec_level); - DP Integrate_rec_using_table (DP (*function) (Vect_DP, I_table), Vect_DP& args, int arg_to_integ, I_table Itable, + DP Integrate_rec_using_table (DP (*function) (Vect_DP, I_table), Vect_DP& args, int arg_to_integ, I_table Itable, DP xmin, DP xmax, DP req_prec, int max_rec_level); - DP Integrate_rec_using_table (DP (*function) (Vect_DP, I_table), Vect_DP& args, int arg_to_integ, I_table Itable, - DP xmin, DP xmax, DP req_prec, int max_rec_level, ofstream& outfile); - DP Integrate_rec_using_table_and_file (DP (*function) (Vect_DP, I_table, ofstream&), Vect_DP& args, int arg_to_integ, I_table Itable, - DP xmin, DP xmax, DP req_prec, int max_rec_level, ofstream& outfile); + DP Integrate_rec_using_table (DP (*function) (Vect_DP, I_table), Vect_DP& args, int arg_to_integ, I_table Itable, + DP xmin, DP xmax, DP req_prec, int max_rec_level, std::ofstream& outfile); + DP Integrate_rec_using_table_and_file (DP (*function) (Vect_DP, I_table, std::ofstream&), Vect_DP& args, + int arg_to_integ, I_table Itable, + DP xmin, DP xmax, DP req_prec, int max_rec_level, std::ofstream& outfile); @@ -240,12 +236,11 @@ namespace JSC { class Integral_data { private: - data_pt* data; + data_pt* data; DP* abs_d2f_dx; // second derivative * dx - DP max_abs_d2f_dx; // + DP max_abs_d2f_dx; // public: - //int n_vals; Integral_result integ_res; public: @@ -254,37 +249,44 @@ namespace JSC { public: Integral_data (DP (*function_ref) (Vect_DP), Vect_DP& args, int arg_to_integ_ref, DP xmin_ref, DP xmax_ref); - Integral_data (DP (*function_ref) (Vect_DP, I_table), Vect_DP& args, int arg_to_integ_ref, I_table Itable, DP xmin_ref, DP xmax_ref); - Integral_data (DP (*function_ref) (Vect_DP, Integral_table), Vect_DP& args, int arg_to_integ_ref, Integral_table Itable, DP xmin_ref, DP xmax_ref); - void Save (ofstream& outfile); + Integral_data (DP (*function_ref) (Vect_DP, I_table), Vect_DP& args, int arg_to_integ_ref, + I_table Itable, DP xmin_ref, DP xmax_ref); + Integral_data (DP (*function_ref) (Vect_DP, Integral_table), Vect_DP& args, int arg_to_integ_ref, + Integral_table Itable, DP xmin_ref, DP xmax_ref); + void Save (std::ofstream& outfile); void Improve_estimate (DP (*function) (Vect_DP), Vect_DP& args, int arg_to_integ, int Npts_max); void Improve_estimate (DP (*function) (Vect_DP, I_table), Vect_DP& args, int arg_to_integ, I_table Itable, int Npts_max); - void Improve_estimate (DP (*function) (Vect_DP, Integral_table), Vect_DP& args, int arg_to_integ, Integral_table Itable, int Npts_max); + void Improve_estimate (DP (*function) (Vect_DP, Integral_table), Vect_DP& args, int arg_to_integ, + Integral_table Itable, int Npts_max); ~Integral_data (); }; - Integral_result Integrate_optimal (DP (*function) (Vect_DP), Vect_DP& args, int arg_to_integ, DP xmin, DP xmax, DP req_rel_prec, DP req_abs_prec, int max_nr_pts); - Integral_result Integrate_optimal_using_table (DP (*function) (Vect_DP, I_table Itable), Vect_DP& args, int arg_to_integ, + Integral_result Integrate_optimal (DP (*function) (Vect_DP), Vect_DP& args, + int arg_to_integ, DP xmin, DP xmax, DP req_rel_prec, DP req_abs_prec, int max_nr_pts); + Integral_result Integrate_optimal_using_table (DP (*function) (Vect_DP, I_table Itable), Vect_DP& args, int arg_to_integ, I_table Itable, DP xmin, DP xmax, DP req_rel_prec, DP req_abs_prec, int max_nr_pts); - Integral_result Integrate_optimal_using_table (DP (*function) (Vect_DP, Integral_table Itable), Vect_DP& args, int arg_to_integ, - Integral_table Itable, DP xmin, DP xmax, DP req_rel_prec, DP req_abs_prec, int max_nr_pts); + Integral_result Integrate_optimal_using_table (DP (*function) (Vect_DP, Integral_table Itable), Vect_DP& args, int arg_to_integ, + Integral_table Itable, DP xmin, DP xmax, DP req_rel_prec, + DP req_abs_prec, int max_nr_pts); + + Integral_result Integrate_optimal_using_table (DP (*function) (Vect_DP, I_table Itable), Vect_DP& args, int arg_to_integ, + I_table Itable, DP xmin, DP xmax, DP req_rel_prec, + DP req_abs_prec, int max_nr_pts, std::ofstream& outfile); - Integral_result Integrate_optimal_using_table (DP (*function) (Vect_DP, I_table Itable), Vect_DP& args, int arg_to_integ, - I_table Itable, DP xmin, DP xmax, DP req_rel_prec, DP req_abs_prec, int max_nr_pts, ofstream& outfile); // ******************************** Recursive version: optimal, complex implementation ****************************** - // NB: function returns complex values but takes real arguments + // NB: function returns complex values but takes real arguments struct data_pt_CX { DP x; - complex f; + std::complex f; DP dx; }; struct Integral_result_CX { - complex integ_est; + std::complex integ_est; DP abs_prec; DP rel_prec; int n_vals; @@ -293,12 +295,11 @@ namespace JSC { class Integral_data_CX { private: - data_pt_CX* data; + data_pt_CX* data; DP* abs_d2f_dx; // second derivative * dx - DP max_abs_d2f_dx; // + DP max_abs_d2f_dx; // public: - //int n_vals; Integral_result_CX integ_res; public: @@ -306,26 +307,24 @@ namespace JSC { DP xmax; public: - Integral_data_CX (complex (*function_ref) (Vect_DP), Vect_DP& args, int arg_to_integ_ref, DP xmin_ref, DP xmax_ref); - //Integral_data_CX (complex (*function_ref) (Vect_DP, I_table), Vect_DP& args, int arg_to_integ_ref, I_table Itable, DP xmin_ref, DP xmax_ref); - void Save (ofstream& outfile); - void Improve_estimate (complex (*function) (Vect_DP), Vect_DP& args, int arg_to_integ, int Npts_max); - //void Improve_estimate (complex (*function) (Vect_DP, I_table), Vect_DP& args, int arg_to_integ, I_table Itable, int Npts_max); + Integral_data_CX (std::complex (*function_ref) (Vect_DP), Vect_DP& args, int arg_to_integ_ref, DP xmin_ref, DP xmax_ref); + void Save (std::ofstream& outfile); + void Improve_estimate (std::complex (*function) (Vect_DP), Vect_DP& args, int arg_to_integ, int Npts_max); ~Integral_data_CX (); }; - Integral_result_CX Integrate_optimal (complex (*function) (Vect_DP), Vect_DP& args, int arg_to_integ, DP xmin, DP xmax, + Integral_result_CX Integrate_optimal (std::complex (*function) (Vect_DP), Vect_DP& args, int arg_to_integ, DP xmin, DP xmax, DP req_rel_prec, DP req_abs_prec, int max_nr_pts); - //Integral_result_CX Integrate_optimal_using_table (DP (*function) (Vect_DP, I_table Itable), Vect_DP& args, int arg_to_integ, + //Integral_result_CX Integrate_optimal_using_table (DP (*function) (Vect_DP, I_table Itable), Vect_DP& args, int arg_to_integ, // I_table Itable, DP xmin, DP xmax, DP req_rel_prec, DP req_abs_prec, int max_nr_pts); - //Integral_result Integrate_optimal_using_table (DP (*function) (Vect_DP, I_table Itable), Vect_DP& args, int arg_to_integ, - // I_table Itable, DP xmin, DP xmax, DP req_rel_prec, DP req_abs_prec, int max_nr_pts, ofstream& outfile); + //Integral_result_CX Integrate_optimal_using_table (DP (*function) (Vect_DP, I_table Itable), Vect_DP& args, int arg_to_integ, + // I_table Itable, DP xmin, DP xmax, DP req_rel_prec, DP req_abs_prec, int max_nr_pts, std::ofstream& outfile); -} // namespace JSC +} // namespace ABACUS #endif diff --git a/include/JSC_LiebLin.h b/include/ABACUS_LiebLin.h similarity index 61% rename from include/JSC_LiebLin.h rename to include/ABACUS_LiebLin.h index e138afa..349f8bc 100644 --- a/include/JSC_LiebLin.h +++ b/include/ABACUS_LiebLin.h @@ -2,49 +2,46 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- -File: JSC_LiebLin.h +File: ABACUS_LiebLin.h Purpose: Declares LiebLin gas-related classes and functions. ***********************************************************/ -#ifndef _LIEBLIN_ -#define _LIEBLIN_ +#ifndef ABACUS_LIEBLIN_H +#define ABACUS_LIEBLIN_H -#include "JSC.h" +#include "ABACUS.h" -namespace JSC { +namespace ABACUS { // First, some global constants... - //const DP ITER_REQ_PREC_LIEBLIN = 1.0e+6 * MACHINE_EPS_SQ; const DP ITER_REQ_PREC_LIEBLIN = 1.0e+4 * MACHINE_EPS_SQ; const int LIEBLIN_Ix2_MIN = -1000000; // Like a UV cutoff. Assumption: never reached in scanning. const int LIEBLIN_Ix2_MAX = -LIEBLIN_Ix2_MIN; + //*********************************************************************** - //class LiebLin_Bethe_State : public Bethe_State { class LiebLin_Bethe_State { public: DP c_int; // interaction parameter - DP L; + DP L; DP cxL; int N; - string label; - //Vect OriginStateIx2; // quantum numbers of state on which excitations are built; always ordered + std::string label; Vect Ix2_available; // quantum numbers which are allowable but not occupied Vect index_first_hole_to_right; Vect displacement; Vect Ix2; Vect lambdaoc; - //Vect BE; Vect S; // scattering sum Vect dSdlambdaoc; // its derivative DP diffsq; @@ -62,9 +59,9 @@ namespace JSC { LiebLin_Bethe_State& operator= (const LiebLin_Bethe_State& RefState); public: - int Charge () { return(N); }; - void Set_to_Label (string label_ref, const Vect& OriginStateIx2); - void Set_to_Label (string label_ref); // assumes OriginState == GroundState + int Charge () { return(N); }; + void Set_to_Label (std::string label_ref, const Vect& OriginStateIx2); + void Set_to_Label (std::string label_ref); // assumes OriginState == GroundState void Set_Label_from_Ix2 (const Vect& OriginStateIx2); void Set_Label_Internals_from_Ix2 (const Vect& OriginStateIx2); bool Check_Admissibility(char whichDSF); // always returns true @@ -88,7 +85,7 @@ namespace JSC { void Parity_Flip (); // takes all lambdaoc to -lambdaoc inline bool Set_to_Inner_Skeleton (int iKneeded, const Vect& OriginIx2) { - if (N < 3) JSCerror("N<3 incompatible with fixed momentum scanning"); + if (N < 3) ABACUSerror("N<3 incompatible with fixed momentum scanning"); Ix2[0] = Ix2[1] - 2; Ix2[N-1] = Ix2[N-2] + 2; (*this).Compute_Momentum(); @@ -98,27 +95,28 @@ namespace JSC { (*this).Set_Label_from_Ix2 (OriginIx2); return(true); } - void Set_to_Outer_Skeleton (const Vect& OriginIx2) - { - Ix2[0] = LIEBLIN_Ix2_MIN + (N % 2) + 1; - Ix2[N-1] = LIEBLIN_Ix2_MAX - (N % 2) - 1; + void Set_to_Outer_Skeleton (const Vect& OriginIx2) + { + Ix2[0] = LIEBLIN_Ix2_MIN + (N % 2) + 1; + Ix2[N-1] = LIEBLIN_Ix2_MAX - (N % 2) - 1; (*this).Set_Label_from_Ix2 (OriginIx2); - //cout << "Set state to outer skeleton: Ix2 " << (*this).Ix2 << endl; - //cout << "label " << (*this).label << endl; }; }; - inline bool Is_Inner_Skeleton (LiebLin_Bethe_State& State) { - return (State.N >= 2 && (State.Ix2[0] == State.Ix2[1] - 2 || State.Ix2[State.N-1] == State.Ix2[State.N-2] + 2)); - }; - inline bool Is_Outer_Skeleton (LiebLin_Bethe_State& State) { - return (State.N >= 2 && State.Ix2[0] == LIEBLIN_Ix2_MIN + (State.N % 2) + 1 && State.Ix2[State.N-1] == LIEBLIN_Ix2_MAX - (State.N % 2) - 1); - }; - inline bool Is_Outer_Skeleton (const LiebLin_Bethe_State& State) { - return (State.N >= 2 && State.Ix2[0] == LIEBLIN_Ix2_MIN + (State.N % 2) + 1 && State.Ix2[State.N-1] == LIEBLIN_Ix2_MAX - (State.N % 2) - 1); - }; + inline bool Is_Inner_Skeleton (LiebLin_Bethe_State& State) { + return (State.N >= 2 && (State.Ix2[0] == State.Ix2[1] - 2 || State.Ix2[State.N-1] == State.Ix2[State.N-2] + 2)); + }; + inline bool Is_Outer_Skeleton (LiebLin_Bethe_State& State) { + return (State.N >= 2 && State.Ix2[0] == LIEBLIN_Ix2_MIN + (State.N % 2) + 1 + && State.Ix2[State.N-1] == LIEBLIN_Ix2_MAX - (State.N % 2) - 1); + }; + inline bool Is_Outer_Skeleton (const LiebLin_Bethe_State& State) { + return (State.N >= 2 && State.Ix2[0] == LIEBLIN_Ix2_MIN + (State.N % 2) + 1 + && State.Ix2[State.N-1] == LIEBLIN_Ix2_MAX - (State.N % 2) - 1); + }; - inline bool Force_Descent (char whichDSF, LiebLin_Bethe_State& ScanState, LiebLin_Bethe_State& RefState, int desc_type_required, int iKmod, DP Chem_Pot) + inline bool Force_Descent (char whichDSF, LiebLin_Bethe_State& ScanState, LiebLin_Bethe_State& RefState, + int desc_type_required, int iKmod, DP Chem_Pot) { bool forcedesc = false; @@ -138,9 +136,12 @@ namespace JSC { DP Chemical_Potential (LiebLin_Bethe_State& RefState); DP Sumrule_Factor (char whichDSF, LiebLin_Bethe_State& RefState, DP Chem_Pot, int iKmin, int iKmax); - void Evaluate_F_Sumrule (char whichDSF, const LiebLin_Bethe_State& RefState, DP Chem_Pot, int iKmin, int iKmax, const char* RAW_Cstr, const char* FSR_Cstr); - void Evaluate_F_Sumrule (string prefix, char whichDSF, const LiebLin_Bethe_State& RefState, DP Chem_Pot, int iKmin, int iKmax); - void Evaluate_F_Sumrule (char whichDSF, DP c_int, DP L, int N, DP kBT, int nstates_req, DP Chem_Pot, int iKmin, int iKmax, const char* FSR_Cstr); + void Evaluate_F_Sumrule (char whichDSF, const LiebLin_Bethe_State& RefState, DP Chem_Pot, + int iKmin, int iKmax, const char* RAW_Cstr, const char* FSR_Cstr); + void Evaluate_F_Sumrule (std::string prefix, char whichDSF, const LiebLin_Bethe_State& RefState, + DP Chem_Pot, int iKmin, int iKmax); + void Evaluate_F_Sumrule (char whichDSF, DP c_int, DP L, int N, DP kBT, int nstates_req, + DP Chem_Pot, int iKmin, int iKmax, const char* FSR_Cstr); // in LiebLin_Utils.cc DP LiebLin_dE0_dc (DP c_int, DP L, int N); @@ -152,32 +153,22 @@ namespace JSC { DP Particle_Hole_Excitation_Cost (char whichDSF, LiebLin_Bethe_State& AveragingState); - complex ln_Density_ME (LiebLin_Bethe_State& lstate, LiebLin_Bethe_State& rstate); - complex ln_Psi_ME (LiebLin_Bethe_State& lstate, LiebLin_Bethe_State& rstate); - complex ln_g2_ME (LiebLin_Bethe_State& mu, LiebLin_Bethe_State& lambda); + std::complex ln_Density_ME (LiebLin_Bethe_State& lstate, LiebLin_Bethe_State& rstate); + std::complex ln_Psi_ME (LiebLin_Bethe_State& lstate, LiebLin_Bethe_State& rstate); + std::complex ln_g2_ME (LiebLin_Bethe_State& mu, LiebLin_Bethe_State& lambda); - //DP Compute_Matrix_Element_Contrib (char whichDSF, int iKmin, int iKmax, LiebLin_Bethe_State& LeftState, - // LiebLin_Bethe_State& RefState, DP Chem_Pot, fstream& DAT_outfile); - DP Compute_Matrix_Element_Contrib (char whichDSF, int iKmin, int iKmax, LiebLin_Bethe_State& LeftState, - LiebLin_Bethe_State& RefState, DP Chem_Pot, stringstream& DAT_outfile); + DP Compute_Matrix_Element_Contrib (char whichDSF, int iKmin, int iKmax, LiebLin_Bethe_State& LeftState, + LiebLin_Bethe_State& RefState, DP Chem_Pot, std::stringstream& DAT_outfile); - DP LiebLin_Twisted_lnnorm (Vect >& lambdaoc, double cxL); - complex LiebLin_Twisted_ln_Overlap (DP expbeta, Vect lstate_lambdaoc, DP lstate_lnnorm, LiebLin_Bethe_State& rstate); - complex LiebLin_Twisted_ln_Overlap (complex expbeta, Vect > lstate_lambdaoc, DP lstate_lnnorm, LiebLin_Bethe_State& rstate); - complex LiebLin_ln_Overlap (Vect lstate_lambdaoc, DP lstate_lnnorm, LiebLin_Bethe_State& rstate); - complex LiebLin_ln_Overlap (Vect > lstate_lambdaoc, DP lstate_lnnorm, LiebLin_Bethe_State& rstate); + DP LiebLin_Twisted_lnnorm (Vect >& lambdaoc, double cxL); + std::complex LiebLin_Twisted_ln_Overlap (DP expbeta, Vect lstate_lambdaoc, DP lstate_lnnorm, LiebLin_Bethe_State& rstate); + std::complex LiebLin_Twisted_ln_Overlap (std::complex expbeta, Vect > lstate_lambdaoc, DP lstate_lnnorm, LiebLin_Bethe_State& rstate); + std::complex LiebLin_ln_Overlap (Vect lstate_lambdaoc, DP lstate_lnnorm, LiebLin_Bethe_State& rstate); + std::complex LiebLin_ln_Overlap (Vect > lstate_lambdaoc, DP lstate_lnnorm, LiebLin_Bethe_State& rstate); // In src/LiebLin_Tgt0.cc: - //DP Entropy_rho (LiebLin_Bethe_State& RefState, int Delta); - //DP Entropy_Fixed_Delta (LiebLin_Bethe_State& RefState, int Delta); - //DP Entropy (LiebLin_Bethe_State& RefState, int Delta); DP Entropy (LiebLin_Bethe_State& RefState); - //DP Canonical_Free_Energy (LiebLin_Bethe_State& RefState, DP kBT, int Delta); DP Canonical_Free_Energy (LiebLin_Bethe_State& RefState, DP kBT); - //DP Entropy (LiebLin_Bethe_State& RefState, DP epsilon); - //DP Canonical_Free_Energy (LiebLin_Bethe_State& RefState, DP kBT, DP epsilon); - //LiebLin_Bethe_State Canonical_Saddle_Point_State (DP c_int, DP L, int N, DP kBT, int Delta); - //LiebLin_Bethe_State Canonical_Saddle_Point_State (DP c_int, DP L, int N, DP kBT, DP epsilon); LiebLin_Bethe_State Canonical_Saddle_Point_State (DP c_int, DP L, int N, DP kBT); LiebLin_Bethe_State Add_Particle_at_Center (const LiebLin_Bethe_State& RefState); LiebLin_Bethe_State Remove_Particle_at_Center (const LiebLin_Bethe_State& RefState); @@ -185,6 +176,6 @@ namespace JSC { DP rho_of_lambdaoc_2 (LiebLin_Bethe_State& RefState, DP lambdaoc, DP delta); -} // namespace JSC +} // namespace ABACUS #endif diff --git a/include/ABACUS_Matrix.h b/include/ABACUS_Matrix.h new file mode 100644 index 0000000..194ce8d --- /dev/null +++ b/include/ABACUS_Matrix.h @@ -0,0 +1,440 @@ +/********************************************************** + +This software is part of J.-S. Caux's ABACUS library. + +Copyright (c) J.-S. Caux. + +----------------------------------------------------------- + +File: ABACUS_Matrix.h + +Purpose: Declares square matrix class. + +***********************************************************/ + +#ifndef ABACUS_MATRIX_H +#define ABACUS_MATRIX_H + +namespace ABACUS { + + + // CLASS DEFINITIONS + + template + class SQMat { + + private: + int dim; + T** M; + + public: + SQMat (int N); // initializes all elements of this n by n matrix to zero + SQMat (const SQMat& rhs); // copy constructor + SQMat (const T& a, int N); // initialize to diagonal matrix with value a (NOT like in NR !!!) + SQMat (const SQMat& a, const SQMat& b); // initialize to tensor product of a and b + SQMat (const SQMat& a, int row_id, int col_id); // init by cutting row row_id and col col_id + void Print (); + SQMat& operator= (const SQMat& rhs); // assignment + SQMat& operator= (const T& a); // assign 1 to diagonal elements (NOT like in NR !!!) + inline T* operator[] (const int i); // subscripting: pointer to row i + inline const T* operator[] (const int i) const; + SQMat& operator+= (const T& a); + SQMat& operator+= (const SQMat& a); + SQMat& operator-= (const T& a); + SQMat& operator-= (const SQMat& a); + SQMat& operator*= (const T& a); + SQMat& operator*= (const SQMat& a); + inline int size() const; + ~SQMat(); + + }; + + template + SQMat::SQMat (int N) : dim(N) , M(new T*[N]) + { + M[0] = new T[N*N]; + for (int i = 1; i < N; i++) M[i] = M[i-1] + N; + } + + template + SQMat::SQMat (const SQMat& rhs) : dim(rhs.dim) , M(new T*[dim]) + { + int i,j; + M[0] = new T[dim*dim]; + for (i = 1; i < dim; i++) M[i] = M[i-1] + dim; + for (i = 0; i < dim; i++) + for (j = 0; j < dim; j++) M[i][j] = rhs[i][j]; + } + + template + SQMat::SQMat (const T& a, int N) : dim(N) , M(new T*[dim]) + { + int i, j; + M[0] = new T[dim*dim]; + for (i = 1; i < dim; i++) M[i] = M[i-1] + dim; + for (i = 0; i < dim; i++) { + for (j = 0; j < dim; j++) M[i][j] = T(0); + M[i][i] = a; + } + } + + template + SQMat::SQMat (const SQMat& a, const SQMat& b) : dim (a.dim * b.dim) , M(new T*[a.dim * b.dim]) + { + M[0] = new T[a.dim * b.dim * a.dim * b.dim]; + + for (int i = 1; i < a.dim * b.dim; ++i) M[i] = M[i-1] + a.dim * b.dim; + + for (int i1 = 0; i1 < a.dim; ++i1) { + + for (int i2 = 0; i2 < a.dim; ++i2) { + + for (int j1 = 0; j1 < b.dim; ++j1) { + + for (int j2 = 0; j2 < b.dim; ++j2) { + + M[i1 * (b.dim) + j1][i2 * (b.dim) + j2] = a[i1][i2] * b[j1][j2]; + } + } + } + } + } + + template + SQMat::SQMat (const SQMat&a, int row_id, int col_id) : dim (a.dim - 1) , M(new T*[dim]) + { + if (dim == 0) { + ABACUSerror("Error: chopping a row and col from size one matrix."); + exit(1); + } + + M[0] = new T[dim * dim]; + + for (int i = 1; i < dim; ++i) M[i] = M[i-1] + dim; + + for (int i = 0; i < row_id; ++i) + for (int j = 0; j < col_id; ++j) M[i][j] = a[i][j]; + for (int i = row_id; i < dim; ++i) + for (int j = 0; j < col_id; ++j) M[i][j] = a[i+1][j]; + for (int i = 0; i < row_id; ++i) + for (int j = col_id; j < dim; ++j) M[i][j] = a[i][j+1]; + for (int i = row_id; i < dim; ++i) + for (int j = col_id; j < dim; ++j) M[i][j] = a[i+1][j+1]; + + } + + // operators + template + void SQMat::Print () + { + std::cout << std::endl; + for (int i = 0; i < dim; ++i) { + for (int j = 0; j < dim; ++j) std::cout << M[i][j] << " "; + std::cout << std::endl; + } + std::cout << std::endl; + } + + template + SQMat& SQMat::operator= (const SQMat& rhs) + { + if (this != &rhs) { + if (dim != rhs.dim) { + ABACUSerror("Assignment between matrices of different dimensions. Bailing out."); + exit(1); + } + + for (int i = 0; i < dim; ++i) + for (int j = 0; j < dim; ++j) M[i][j] = rhs[i][j]; + } + return *this; + } + + template + SQMat& SQMat::operator= (const T& a) + { + for (int i = 0; i < dim; ++i) { + for (int j = 0; j < dim; ++j) + M[i][j] = T(0); + M[i][i] = a; + } + return *this; + } + + template + inline T* SQMat::operator[] (const int i) + { + return M[i]; + } + + template + inline const T* SQMat::operator[] (const int i) const + { + return M[i]; + } + + template + SQMat& SQMat::operator+= (const T& a) + { + + for (int i = 0; i < dim; ++i) M[i][i] += a; + + return *this; + } + + template + SQMat& SQMat::operator+= (const SQMat& a) + { + if (dim != a.dim) { + ABACUSerror("Incompatible matrix sizes in matrix operator +."); + exit(1); + } + for (int i = 0; i < dim; ++i) { + for (int j = 0; j < dim; ++j) { + M[i][j] += a[i][j]; + } + } + return *this; + } + + template + SQMat& SQMat::operator-= (const T& a) + { + + for (int i = 0; i < dim; ++i) M[i][i] -= a; + + return *this; + } + + template + SQMat& SQMat::operator-= (const SQMat& a) + { + if (dim != a.dim) { + ABACUSerror("Incompatible matrix sizes in matrix operator +."); + exit(1); + } + for (int i = 0; i < dim; ++i) { + for (int j = 0; j < dim; ++j) { + M[i][j] -= a[i][j]; + } + } + return *this; + } + + template + SQMat& SQMat::operator*= (const T& a) + { + + for (int i = 0; i < dim; ++i) for (int j = 0; j < dim; ++j) M[i][j] *= a; + + return *this; + } + + template + SQMat& SQMat::operator*= (const SQMat& a) + { + + if (dim != a.dim) { + ABACUSerror("Incompatible matrix sizes in matrix operator *."); + exit(1); + } + + SQMat leftarg(*this); // use copy constructor. + + for (int i = 0; i < dim; ++i) { + + for (int j = 0; j < dim; ++j) { + + M[i][j] = 0.0; + + for (int k = 0; k < dim; ++k) { + + M[i][j] += leftarg[i][k] * a[k][j]; + } + } + } + + return *this; + } + + template + inline int SQMat::size() const + { + return dim; + } + + template + SQMat::~SQMat() + { + if (M != 0) { + delete[] (M[0]); + delete[] (M); + } + } + + + //***************************** + + template + class RecMat { + + private: + int nrows; + int ncols; + T** M; + + public: + RecMat (int Nrows, int Ncols); // initializes all elements of this n by n matrix to zero + RecMat (const T& a, int Nrows, int Ncols); + RecMat (const RecMat& rhs); // copy constructor + void Print (); + RecMat& operator= (const RecMat& rhs); // assignment + inline T* operator[] (const int i); // subscripting: pointer to row i + inline const T* operator[] (const int i) const; + inline int nr_rows() const; + inline int nr_cols() const; + ~RecMat(); + + }; + + template + RecMat::RecMat (int Nrows, int Ncols) : nrows(Nrows), ncols(Ncols), M(new T*[Nrows]) + { + M[0] = new T[Nrows*Ncols]; + for (int i = 1; i < Nrows; i++) M[i] = M[i-1] + Ncols; + + for (int i = 0; i < Nrows; i++) for (int j = 0; j < Ncols; j++) M[i][j] = T(0); + } + + template + RecMat::RecMat (const T& a, int Nrows, int Ncols) : nrows(Nrows), ncols(Ncols), M(new T*[Nrows]) + { + M[0] = new T[Nrows*Ncols]; + for (int i = 1; i < Nrows; i++) M[i] = M[i-1] + Ncols; + + for (int i = 0; i < Nrows; i++) for (int j = 0; j < Ncols; j++) { + if (i == j) M[i][i] = a; + else M[i][j] = T(0); + } + } + + template + RecMat::RecMat (const RecMat& rhs) : nrows(rhs.nrows), ncols(rhs.ncols), M(new T*[nrows]) + { + int i,j; + M[0] = new T[nrows*ncols]; + for (i = 1; i < nrows; i++) M[i] = M[i-1] + ncols; + for (i = 0; i < nrows; i++) + for (j = 0; j < ncols; j++) M[i][j] = rhs[i][j]; + } + + // operators + template + void RecMat::Print () + { + std::cout << std::endl; + for (int i = 0; i < nrows; ++i) { + for (int j = 0; j < ncols; ++j) std::cout << M[i][j] << " "; + std::cout << std::endl; + } + std::cout << std::endl; + } + + template + RecMat& RecMat::operator= (const RecMat& rhs) + { + if (this != &rhs) { + if (nrows != rhs.nrows || ncols != rhs.ncols) { + if (M != 0) { + delete[] (M[0]); + delete[] (M); + } + nrows = rhs.nrows; + ncols = rhs.ncols; + M = new T*[nrows]; + M[0] = new T[nrows * ncols]; + } + + for (int i = 0; i < nrows; ++i) + for (int j = 0; j < ncols; ++j) M[i][j] = rhs[i][j]; + } + return *this; + } + + template + inline T* RecMat::operator[] (const int i) + { + return M[i]; + } + + template + inline const T* RecMat::operator[] (const int i) const + { + return M[i]; + } + + template + inline int RecMat::nr_rows() const + { + return nrows; + } + + template + inline int RecMat::nr_cols() const + { + return ncols; + } + + template + inline std::ostream& operator<< (std::ostream& s, const RecMat& matrix) + { + for (int i = 0; i < matrix.nr_rows(); ++i) { + for (int j = 0; j < matrix.nr_cols(); ++j) s << matrix[i][j] << " "; + s << std::endl; + } + + return (s); + } + + template + RecMat::~RecMat() + { + if (M != 0) { + delete[] (M[0]); + delete[] (M); + } + } + + // TYPEDEFS: + + typedef ABACUS::SQMat SQMat_DP; + typedef ABACUS::SQMat > SQMat_CX; + + + // FUNCTION DEFINITIONS + + // Functions in src/MATRIX directory + + DP det_LU (SQMat_DP a); + DP lndet_LU (SQMat_DP a); + std::complex lndet_LU_dstry (SQMat_DP& a); + std::complex det_LU_CX (SQMat_CX a); + std::complex lndet_LU_CX (SQMat_CX a); + std::complex lndet_LU_CX_dstry (SQMat_CX& a); + void eigsrt (Vect_DP& d, SQMat_DP& v); + void balanc (SQMat_DP& a); + void elmhes (SQMat_DP& a); + void gaussj (SQMat_DP& a, SQMat_DP& b); + void hqr (SQMat_DP& a, Vect_CX& wri); + void jacobi (SQMat_DP& a, Vect_DP& d, SQMat_DP& v, int& nrot); + void lubksb (SQMat_DP& a, Vect_INT& indx, Vect_DP& b); + void lubksb_CX (SQMat_CX& a, Vect_INT& indx, Vect_CX& b); + void ludcmp (SQMat_DP& a, Vect_INT& indx, DP& d); + void ludcmp_CX (SQMat_CX& a, Vect_INT& indx, DP& d); + DP pythag(DP a, DP b); + void tqli(Vect_DP& d, Vect_DP& e, SQMat_DP& z); + void tred2 (SQMat_DP& a, Vect_DP& d, Vect_DP& e); + +} // namespace ABACUS + +#endif diff --git a/include/ABACUS_NRG.h b/include/ABACUS_NRG.h new file mode 100644 index 0000000..10ad90d --- /dev/null +++ b/include/ABACUS_NRG.h @@ -0,0 +1,35 @@ +/********************************************************** + +This software is part of J.-S. Caux's ABACUS library. + +Copyright (c) J.-S. Caux. + +----------------------------------------------------------- + +File: ABACUS_NRG.h + +Purpose: Declares NRG-related classes and functions. + +***********************************************************/ + +#ifndef ABACUS_NRG_H +#define ABACUS_NRG_H + +#include "ABACUS.h" + +namespace ABACUS { + + DP K_Weight_integrand (Vect_DP args); // weighing function for state selection + + void Select_States_for_NRG (DP c_int, DP L, int N, int iKmin, int iKmax, int Nstates_required, + bool symmetric_states, int iKmod, + int weighing_option, Vect >& FT_of_potential); + + void Build_DFF_Matrix_Block_for_NRG (DP c_int, DP L, int N, int iKmin, int iKmax, int Nstates_required, + bool symmetric_states, int iKmod, int weighing_option, + int label_left_begin, int label_left_end, int label_right_begin, int label_right_end, + int block_option, DP* DFF_block_1, DP* DFF_block_2, Vect_DP Kweight); + +} + +#endif diff --git a/include/JSC_ODSLF.h b/include/ABACUS_ODSLF.h similarity index 62% rename from include/JSC_ODSLF.h rename to include/ABACUS_ODSLF.h index 76d6350..de4878d 100644 --- a/include/JSC_ODSLF.h +++ b/include/ABACUS_ODSLF.h @@ -2,22 +2,22 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- -File: Heis.h +File: ABACUS_ODSLF.h Purpose: Declares lattice spinless fermion classes and functions. ***********************************************************/ -#ifndef _ODSLF_ -#define _ODSLF_ +#ifndef ABACUS_ODSLF_H +#define ABACUS_ODSLF_H -#include "JSC.h" +#include "ABACUS.h" -namespace JSC { +namespace ABACUS { //**************************************************************************** @@ -40,12 +40,12 @@ namespace JSC { ODSLF_Base (const Heis_Chain& RefChain, const Vect& Nrapidities); // sets to Nrapidities vector, and checks consistency ODSLF_Base (const Heis_Chain& RefChain, long long int id_ref); inline int& operator[] (const int i); - inline const int& operator[] (const int i) const; + inline const int& operator[] (const int i) const; ODSLF_Base& operator= (const ODSLF_Base& RefBase); bool operator== (const ODSLF_Base& RefBase); bool operator!= (const ODSLF_Base& RefBase); - void Compute_Ix2_limits(const Heis_Chain& RefChain); // computes the Ix2_infty and Ix2_max + void Compute_Ix2_limits(const Heis_Chain& RefChain); // computes the Ix2_infty and Ix2_max void Scan_for_Possible_Types (Vect& possible_type_id, int& nfound, int base_level, Vect& Nexcitations); Vect Possible_Types (); // returns a vector of possible types @@ -56,19 +56,19 @@ namespace JSC { { return Nrap[i]; } - + inline const int& ODSLF_Base::operator[] (const int i) const { return Nrap[i]; } + //**************************************************************************** // Objects in class ODSLF_Ix2_Config carry all the I's of a given state class ODSLF_Ix2_Config { - //private: public: int Nstrings; Vect Nrap; @@ -76,73 +76,63 @@ namespace JSC { int** Ix2; - //Vect > Ix2; - public: ODSLF_Ix2_Config (); ODSLF_Ix2_Config (const Heis_Chain& RefChain, int M); // constructor, puts I's to ground state - ODSLF_Ix2_Config (const Heis_Chain& RefChain, const ODSLF_Base& base); // constructor, putting I's to lowest-energy config - // consistent with Heis_Base configuration for chain RefChain + ODSLF_Ix2_Config (const Heis_Chain& RefChain, const ODSLF_Base& base); // constructor, putting I's to lowest-energy config + // consistent with Heis_Base configuration for chain RefChain ODSLF_Ix2_Config& operator= (const ODSLF_Ix2_Config& RefConfig); inline int* operator[] (const int i); - //inline Vect operator[] (const int i); inline const int* operator[] (const int i) const; - //inline const Vect operator[] (const int i) const; ~ODSLF_Ix2_Config(); }; inline int* ODSLF_Ix2_Config::operator[] (const int i) - //inline Vect Ix2_Config::operator[] (const int i) - { - return Ix2[i]; - } - + { + return Ix2[i]; + } + inline const int* ODSLF_Ix2_Config::operator[] (const int i) const - //inline const Vect Ix2_Config::operator[] (const int i) const { return Ix2[i]; } std::ostream& operator<< (std::ostream& s, const ODSLF_Ix2_Config& RefConfig); + //**************************************************************************** // Objects in class ODSLF_Lambda carry all rapidities of a state class ODSLF_Lambda { - + private: int Nstrings; Vect Nrap; int Nraptot; DP** lambda; - //Vect > lambda; - + public: ODSLF_Lambda (); ODSLF_Lambda (const Heis_Chain& RefChain, int M); // constructor, puts all lambda's to zero - ODSLF_Lambda (const Heis_Chain& RefChain, const ODSLF_Base& base); // constructor, putting I's to lowest-energy config + ODSLF_Lambda (const Heis_Chain& RefChain, const ODSLF_Base& base); // constructor, putting I's to lowest-energy config // consistent with Heis_Base configuration for chain RefChain ODSLF_Lambda& operator= (const ODSLF_Lambda& RefConfig); inline DP* operator[] (const int i); - //inline Vect operator[] (const int i); inline const DP* operator[] (const int i) const; - //inline const Vect operator[] (const int i) const; ~ODSLF_Lambda(); }; inline DP* ODSLF_Lambda::operator[] (const int i) - //inline Vect Lambda::operator[] (const int i) - { - return lambda[i]; - } - + { + return lambda[i]; + } + inline const DP* ODSLF_Lambda::operator[] (const int i) const - //inline const Vect Lambda::operator[] (const int i) const - { - return lambda[i]; - } + { + return lambda[i]; + } //**************************************************************************** @@ -168,7 +158,7 @@ namespace JSC { bool operator>= (const ODSLF_Ix2_Offsets& RefOffsets); public: - void Set_to_id (long long int idnr); + void Set_to_id (long long int idnr); void Compute_id (); void Compute_type_id (); @@ -178,14 +168,15 @@ namespace JSC { }; inline long long int ODSLF_Ix2_Offsets_type_id (Vect& nparticles) - { - long long int type_id_here = 0ULL; + { + long long int type_id_here = 0ULL; - for (int i = 0; i < nparticles.size(); ++i) - type_id_here += nparticles[i] * pow_ulli(10ULL, i); + for (int i = 0; i < nparticles.size(); ++i) + type_id_here += nparticles[i] * pow_ulli(10ULL, i); + + return(type_id_here); + } - return(type_id_here); - } //**************************************************************************** // Objects in class ODSLF_Ix2_Offsets_List carry a vector of used Ix2_Offsets @@ -211,7 +202,7 @@ namespace JSC { // These contain subclass-specific functions and data. class ODSLF_Bethe_State { - + public: Heis_Chain chain; ODSLF_Base base; @@ -219,7 +210,7 @@ namespace JSC { ODSLF_Ix2_Config Ix2; ODSLF_Lambda lambda; ODSLF_Lambda BE; // Bethe equation for relevant rapidity, in the form BE = theta - (1/N)\sum ... - \pi I/N = 0 - DP diffsq; // sum of squares of rapidity differences in last iteration + DP diffsq; // sum of squares of rapidity differences in last iteration int conv; // convergence status int iter; // number of iterations necessary for convergence int iter_Newton; // number of iterations necessary for convergence (Newton method) @@ -227,8 +218,6 @@ namespace JSC { int iK; // K = 2.0*PI * iK/Nsites DP K; // total momentum DP lnnorm; // ln of norm of reduced Gaudin matrix - //long long int id; - //long long int maxid; long long int base_id; long long int type_id; long long int id; @@ -236,17 +225,16 @@ namespace JSC { int nparticles; public: - ODSLF_Bethe_State (); + ODSLF_Bethe_State (); ODSLF_Bethe_State (const ODSLF_Bethe_State& RefState); // copy constructor ODSLF_Bethe_State (const ODSLF_Bethe_State& RefState, long long int type_id_ref); // new state with requested type_id ODSLF_Bethe_State (const Heis_Chain& RefChain, int M); // constructor to ground-state configuration ODSLF_Bethe_State (const Heis_Chain& RefChain, const ODSLF_Base& base); // constructor to lowest-energy config with base - ODSLF_Bethe_State (const Heis_Chain& RefChain, long long int base_id_ref, long long int type_id_ref); + ODSLF_Bethe_State (const Heis_Chain& RefChain, long long int base_id_ref, long long int type_id_ref); virtual ~ODSLF_Bethe_State () {}; public: - int Charge () { return(base.Mdown); }; - //void Set_I_Offset (const I_Offset& RefOffset); // sets the Ix2 to given offsets + int Charge () { return(base.Mdown); }; void Set_Ix2_Offsets (const ODSLF_Ix2_Offsets& RefOffset); // sets the Ix2 to given offsets void Set_to_id (long long int id_ref); void Set_to_id (long long int id_ref, ODSLF_Bethe_State& RefState); @@ -271,65 +259,45 @@ namespace JSC { // Virtual functions, all defined in the derived classes public: - virtual void Set_Free_lambdas() { JSCerror("ODSLF_Bethe_State::..."); } // sets the rapidities to solutions of BAEs without scattering terms - virtual bool Check_Admissibility(char option) { JSCerror("ODSLF_Bethe_State::..."); return(false); } + virtual void Set_Free_lambdas() { ABACUSerror("ODSLF_Bethe_State::..."); } // sets the rapidities to solutions of BAEs without scattering terms + virtual bool Check_Admissibility(char option) { ABACUSerror("ODSLF_Bethe_State::..."); return(false); } // verifies that we don't have a symmetrical Ix2 config with a Ix2 == 0 for a string of even length >= 2. - virtual void Compute_BE (int j, int alpha) { JSCerror("ODSLF_Bethe_State::..."); } - virtual void Compute_BE () { JSCerror("ODSLF_Bethe_State::..."); } - virtual DP Iterate_BAE(int i, int alpha) { JSCerror("ODSLF_Bethe_State::..."); return(0.0);} - virtual bool Check_Rapidities() { JSCerror("ODSLF_Bethe_State::..."); return(false); } - virtual void Compute_Energy () { JSCerror("ODSLF_Bethe_State::..."); } - virtual void Build_Reduced_Gaudin_Matrix (SQMat >& Gaudin_Red) { JSCerror("ODSLF_Bethe_State::..."); } + virtual void Compute_BE (int j, int alpha) { ABACUSerror("ODSLF_Bethe_State::..."); } + virtual void Compute_BE () { ABACUSerror("ODSLF_Bethe_State::..."); } + virtual DP Iterate_BAE(int i, int alpha) { ABACUSerror("ODSLF_Bethe_State::..."); return(0.0);} + virtual bool Check_Rapidities() { ABACUSerror("ODSLF_Bethe_State::..."); return(false); } + virtual void Compute_Energy () { ABACUSerror("ODSLF_Bethe_State::..."); } + virtual void Build_Reduced_Gaudin_Matrix (SQMat >& Gaudin_Red) { ABACUSerror("ODSLF_Bethe_State::..."); } }; inline bool Force_Descent (char whichDSF, ODSLF_Bethe_State& ScanState, ODSLF_Bethe_State& RefState, int desc_type_required, int iKmod, DP Chem_Pot) { - JSCerror("Need to implement Force_Descent properly for ODSLF."); + ABACUSerror("Need to implement Force_Descent properly for ODSLF."); bool force_descent = false; - // Force descent if energy of ScanState is lower than that of RefState - if (ScanState.E - RefState.E - (ScanState.base.Mdown - RefState.base.Mdown) < 0.0) return(true); - /* - // We force descent if - // 1) - there exists a higher string whose quantum number is still on 0 - // AND - there is at most a single particle-hole in the 0 base level - // AND - either the particle or the hole hasn't yet moved. - if (RefState.base_id/100000LL > 0) { // there is a higher string - int type0 = RefState.type_id % 10000; - if (type0 == 0 - || type0 == 101 && RefState.offsets.Tableau[0].id * RefState.offsets.Tableau[2].id == 0LL - || type0 == 110 && RefState.offsets.Tableau[1].id * RefState.offsets.Tableau[2].id == 0LL - || type0 == 1001 && RefState.offsets.Tableau[0].id * RefState.offsets.Tableau[3].id == 0LL - || type0 == 1010 && RefState.offsets.Tableau[1].id * RefState.offsets.Tableau[3].id == 0LL) // single p-h pair in base level 0 - for (int j = 1; j < RefState.chain.Nstrings; ++j) { - if (RefState.base[j] == 1 && RefState.Ix2[j][0] == 0) { - force_descent = true; - } - } - } - */ // Force descent if quantum nr distribution is symmetric: if (RefState.Check_Symmetry()) force_descent = true; - + return(force_descent); } std::ostream& operator<< (std::ostream& s, const ODSLF_Bethe_State& state); + //**************************************************************************** // Objects in class XXZ_Bethe_State carry all extra information pertaining to XXZ gapless class ODSLF_XXZ_Bethe_State : public ODSLF_Bethe_State { - - public: - ODSLF_Lambda sinhlambda; - ODSLF_Lambda coshlambda; - ODSLF_Lambda tanhlambda; public: - ODSLF_XXZ_Bethe_State (); + ODSLF_Lambda sinhlambda; + ODSLF_Lambda coshlambda; + ODSLF_Lambda tanhlambda; + + public: + ODSLF_XXZ_Bethe_State (); ODSLF_XXZ_Bethe_State (const ODSLF_XXZ_Bethe_State& RefState); // copy constructor ODSLF_XXZ_Bethe_State (const Heis_Chain& RefChain, int M); // constructor to ground-state configuration ODSLF_XXZ_Bethe_State (const Heis_Chain& RefChain, const ODSLF_Base& base); // constructor to lowest-energy config with base @@ -337,7 +305,7 @@ namespace JSC { public: ODSLF_XXZ_Bethe_State& operator= (const ODSLF_XXZ_Bethe_State& RefState); - + public: void Set_Free_lambdas(); // sets the rapidities to solutions of BAEs without scattering terms void Compute_sinhlambda(); @@ -349,14 +317,14 @@ namespace JSC { DP Iterate_BAE(int i, int j); bool Check_Rapidities(); // checks that all rapidities are not nan void Compute_Energy (); - //void Compute_Momentum (); - void Build_Reduced_Gaudin_Matrix (SQMat >& Gaudin_Red); + void Build_Reduced_Gaudin_Matrix (SQMat >& Gaudin_Red); // XXZ specific functions: public: }; + //**************************************************************************** /* // Objects in class ODSLF_XXX_Bethe_State carry all extra information pertaining to XXX antiferromagnet @@ -364,29 +332,29 @@ namespace JSC { class ODSLF_XXX_Bethe_State : public ODSLF_Bethe_State { public: - ODSLF_XXX_Bethe_State (); - ODSLF_XXX_Bethe_State (const ODSLF_XXX_Bethe_State& RefState); // copy constructor - ODSLF_XXX_Bethe_State (const Heis_Chain& RefChain, int M); // constructor to ground-state configuration - ODSLF_XXX_Bethe_State (const Heis_Chain& RefChain, const ODSLF__Base& base); // constructor to lowest-energy config with base - ODSLF_XXX_Bethe_State (const Heis_Chain& RefChain, long long int base_id_ref, long long int type_id_ref); // constructor to lowest-energy config with base + ODSLF_XXX_Bethe_State (); + ODSLF_XXX_Bethe_State (const ODSLF_XXX_Bethe_State& RefState); // copy constructor + ODSLF_XXX_Bethe_State (const Heis_Chain& RefChain, int M); // constructor to ground-state configuration + ODSLF_XXX_Bethe_State (const Heis_Chain& RefChain, const ODSLF__Base& base); // constructor to lowest-energy config with base + ODSLF_XXX_Bethe_State (const Heis_Chain& RefChain, long long int base_id_ref, long long int type_id_ref); // constructor to lowest-energy config with base public: - ODSLF_XXX_Bethe_State& operator= (const ODSLF_XXX_Bethe_State& RefState); + ODSLF_XXX_Bethe_State& operator= (const ODSLF_XXX_Bethe_State& RefState); public: - void Set_Free_lambdas(); // sets the rapidities to solutions of BAEs without scattering terms - bool Check_Admissibility(char option); // verifies that we don't have a symmetrical Ix2 config with a Ix2 == 0 for a string of even length >= 2. - void Compute_BE (int j, int alpha); - void Compute_BE (); - DP Iterate_BAE(int i, int j); - bool Check_Rapidities(); // checks that all rapidities are not nan - void Compute_Energy (); - //void Compute_Momentum (); - void Build_Reduced_Gaudin_Matrix (SQMat >& Gaudin_Red); + void Set_Free_lambdas(); // sets the rapidities to solutions of BAEs without scattering terms + bool Check_Admissibility(char option); // verifies that we don't have a symmetrical Ix2 config with a Ix2 == 0 for a string of even length >= 2. + void Compute_BE (int j, int alpha); + void Compute_BE (); + DP Iterate_BAE(int i, int j); + bool Check_Rapidities(); // checks that all rapidities are not nan + void Compute_Energy (); + //void Compute_Momentum (); + void Build_Reduced_Gaudin_Matrix (SQMat >& Gaudin_Red); - // XXX specific functions + // XXX specific functions public: - bool Check_Finite_rap (); + bool Check_Finite_rap (); }; */ @@ -395,45 +363,45 @@ namespace JSC { // Objects in class ODSLF_XXZ_gpd_Bethe_State carry all extra information pertaining to XXZ gapped antiferromagnets class ODSLF_XXZ_gpd_Bethe_State : public ODSLF__Bethe_State { - - public: - Lambda sinlambda; - Lambda coslambda; - Lambda tanlambda; public: - ODSLF_XXZ_gpd_Bethe_State (); - ODSLF_XXZ_gpd_Bethe_State (const ODSLF_XXZ_gpd_Bethe_State& RefState); // copy constructor - ODSLF_XXZ_gpd_Bethe_State (const Heis_Chain& RefChain, int M); // constructor to ground-state configuration - ODSLF_XXZ_gpd_Bethe_State (const Heis_Chain& RefChain, const ODSLF_Base& base); // constructor to lowest-energy config with base - ODSLF_XXZ_gpd_Bethe_State (const Heis_Chain& RefChain, long long int base_id_ref, long long int type_id_ref); // constructor to lowest-energy config with base + Lambda sinlambda; + Lambda coslambda; + Lambda tanlambda; public: - ODSLF_XXZ_gpd_Bethe_State& operator= (const ODSLF_XXZ_gpd_Bethe_State& RefState); + ODSLF_XXZ_gpd_Bethe_State (); + ODSLF_XXZ_gpd_Bethe_State (const ODSLF_XXZ_gpd_Bethe_State& RefState); // copy constructor + ODSLF_XXZ_gpd_Bethe_State (const Heis_Chain& RefChain, int M); // constructor to ground-state configuration + ODSLF_XXZ_gpd_Bethe_State (const Heis_Chain& RefChain, const ODSLF_Base& base); // constructor to lowest-energy config with base + ODSLF_XXZ_gpd_Bethe_State (const Heis_Chain& RefChain, long long int base_id_ref, long long int type_id_ref); // constructor to lowest-energy config with base public: - void Set_Free_lambdas(); // sets the rapidities to solutions of BAEs without scattering terms - void Compute_sinlambda(); - void Compute_coslambda(); - void Compute_tanlambda(); - int Weight(); // weight function for contributions cutoff - bool Check_Admissibility(char option); // verifies that we don't have a symmetrical Ix2 config with a Ix2 == 0 for a string of even length >= 2. - void Compute_BE (int j, int alpha); - void Compute_BE (); - DP Iterate_BAE(int i, int j); - void Iterate_BAE_Newton(); - bool Check_Rapidities(); // checks that all rapidities are not nan and are in interval ]-PI/2, PI/2] - void Compute_Energy (); - //void Compute_Momentum (); - void Build_Reduced_Gaudin_Matrix (SQMat >& Gaudin_Red); + ODSLF_XXZ_gpd_Bethe_State& operator= (const ODSLF_XXZ_gpd_Bethe_State& RefState); - // XXZ_gpd specific functions + public: + void Set_Free_lambdas(); // sets the rapidities to solutions of BAEs without scattering terms + void Compute_sinlambda(); + void Compute_coslambda(); + void Compute_tanlambda(); + int Weight(); // weight function for contributions cutoff + bool Check_Admissibility(char option); // verifies that we don't have a symmetrical Ix2 config with a Ix2 == 0 for a string of even length >= 2. + void Compute_BE (int j, int alpha); + void Compute_BE (); + DP Iterate_BAE(int i, int j); + void Iterate_BAE_Newton(); + bool Check_Rapidities(); // checks that all rapidities are not nan and are in interval ]-PI/2, PI/2] + void Compute_Energy (); + //void Compute_Momentum (); + void Build_Reduced_Gaudin_Matrix (SQMat >& Gaudin_Red); + + // XXZ_gpd specific functions public: }; */ //*********************************************** - + // Function declarations /* // in M_vs_H.cc @@ -445,19 +413,16 @@ namespace JSC { DP X_avg (char xyorz, DP Delta, int N, int M); */ DP Chemical_Potential (const ODSLF_Bethe_State& RefState); - //DP Sumrule_Factor (char whichDSF, Heis_Bethe_State& RefState, DP Chem_Pot, bool fixed_iK, int iKneeded); DP Sumrule_Factor (char whichDSF, ODSLF_Bethe_State& RefState, DP Chem_Pot, int iKmin, int iKmax); - void Evaluate_F_Sumrule (string prefix, char whichDSF, const ODSLF_Bethe_State& RefState, DP Chem_Pot, int iKmin, int iKmax); + void Evaluate_F_Sumrule (std::string prefix, char whichDSF, const ODSLF_Bethe_State& RefState, DP Chem_Pot, int iKmin, int iKmax); - complex ln_Sz_ME (ODSLF_XXZ_Bethe_State& A, ODSLF_XXZ_Bethe_State& B); - complex ln_Smin_ME (ODSLF_XXZ_Bethe_State& A, ODSLF_XXZ_Bethe_State& B); + std::complex ln_Sz_ME (ODSLF_XXZ_Bethe_State& A, ODSLF_XXZ_Bethe_State& B); + std::complex ln_Smin_ME (ODSLF_XXZ_Bethe_State& A, ODSLF_XXZ_Bethe_State& B); - //DP Compute_Matrix_Element_Contrib (char whichDSF, int iKmin, int iKmax, ODSLF_XXZ_Bethe_State& LeftState, - // ODSLF_XXZ_Bethe_State& RefState, DP Chem_Pot, fstream& DAT_outfile); - DP Compute_Matrix_Element_Contrib (char whichDSF, int iKmin, int iKmax, ODSLF_XXZ_Bethe_State& LeftState, - ODSLF_XXZ_Bethe_State& RefState, DP Chem_Pot, stringstream& DAT_outfile); + DP Compute_Matrix_Element_Contrib (char whichDSF, int iKmin, int iKmax, ODSLF_XXZ_Bethe_State& LeftState, + ODSLF_XXZ_Bethe_State& RefState, DP Chem_Pot, std::stringstream& DAT_outfile); -} // namespace JSC +} // namespace ABACUS #endif diff --git a/include/ABACUS_Scan.h b/include/ABACUS_Scan.h new file mode 100644 index 0000000..ddd7587 --- /dev/null +++ b/include/ABACUS_Scan.h @@ -0,0 +1,828 @@ +/********************************************************** + +This software is part of J.-S. Caux's ABACUS library. + +Copyright (c) J.-S. Caux. + +----------------------------------------------------------- + +File: ABACUS_Scan.h + +Purpose: Declares all classes and functions used in the + ABACUS logic of scanning with threads. + +***********************************************************/ + +#ifndef ABACUS_SCAN_H +#define ABACUS_SCAN_H + +#include "ABACUS.h" + +namespace ABACUS { + + const int MAX_STATE_LIST_SIZE = 10000; + + // Functions in src/UTILS/Data_File_Name.cc: + void Data_File_Name (std::stringstream& name, char whichDSF, DP c_int, DP L, int N, + int iKmin, int iKmax, DP kBT, DP L2, std::string defaultname); + void Data_File_Name (std::stringstream& name, char whichDSF, int iKmin, int iKmax, DP kBT, + LiebLin_Bethe_State& State, LiebLin_Bethe_State& RefScanState, std::string defaultname); + void Data_File_Name (std::stringstream& name, char whichDSF, DP Delta, int N, int M, int iKmin, int iKmax, + DP kBT, int N2, std::string defaultname); + void Data_File_Name (std::stringstream& name, char whichDSF, int iKmin, int iKmax, DP kBT, + Heis_Bethe_State& State, Heis_Bethe_State& RefScanState, std::string defaultname); + void ODSLF_Data_File_Name (std::stringstream& name, char whichDSF, DP Delta, int N, int M, + int iKmin, int iKmax, DP kBT, int N2, std::string defaultname); + void Data_File_Name (std::stringstream& name, char whichDSF, int iKmin, int iKmax, DP kBT, + ODSLF_Bethe_State& State, ODSLF_Bethe_State& RefScanState, std::string defaultname); + + // Coding to convert ints to strings: for application in reduced labels + //const int ABACUScodingsize = 64; // use a multiple of 2 to accelerate divisions in labeling. + //const char ABACUScoding[] = {'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z', 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', '!', '?'}; + + // From ABACUS++T_8 onwards: forbid special characters as |, :, !, ? and all capital letters in labels. + // This is due to the dumb capitalization-preserving but capitalization-insensitive HFS+ filesystem on Mac OS X. + const int ABACUScodingsize = 32; + const char ABACUScoding[] = {'0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v'}; + const char LABELSEP = '_'; // was _ + const char TYPESEP = 'x'; // was | + const char EXCSEP = 'y'; // was : + const char INEXCSEP = 'z'; // was @ + + struct State_Label_Data { + + Vect type; // integer type labels of the types present + Vect M; // how many particles of each type + Vect nexc; // how many excitations as compared to the reference state used + Vect > Ix2old; // which Ix2 will be excited + Vect > Ix2exc; // which Ix2 the excitation has shifted to + + State_Label_Data (const Vect& type_ref, const Vect& M_ref, + const Vect& nexc_ref, const Vect >& Ix2old_ref, const Vect >& Ix2exc_ref) + { + type = type_ref; M = M_ref; nexc = nexc_ref; Ix2old = Ix2old_ref; Ix2exc = Ix2exc_ref; + } + + }; + + std::string Extract_Base_Label (std::string label); // works for labels and complabels + std::string Extract_nexc_Label (std::string label); + + // For compressed labels: conversions between integers and char/strings. + std::string Convert_POSINT_to_STR (int int_to_convert); + int Convert_CHAR_to_POSINT (char char_to_convert); + int Convert_STR_to_POSINT (std::string str_to_convert); + + State_Label_Data Read_Base_Label (std::string label); + State_Label_Data Read_State_Label (std::string label, const Vect >& OriginIx2); + State_Label_Data Read_State_Label (std::string label, const Vect& OriginIx2); // if there is only one type + std::string Return_State_Label (State_Label_Data data, const Vect >& OriginIx2); + std::string Return_State_Label (State_Label_Data data, const Vect& OriginIx2); // if there is only one type + std::string Return_State_Label (const Vect >& ScanIx2, const Vect >& OriginIx2); + std::string Return_State_Label (const Vect& ScanIx2, const Vect& OriginIx2); // if there is only one type + Vect > Return_Ix2_from_Label (std::string label_ref, const Vect >& OriginIx2); + Vect Return_Ix2_from_Label (std::string label_ref, const Vect& OriginIx2); // specialization to Lieb-Liniger + + // Functions for descending states: in SCAN/Descendents.cc + Vect Descendent_States_with_iK_Stepped_Up (std::string ScanIx2_label, const LiebLin_Bethe_State& OriginState, bool disperse_only_current_exc, bool preserve_nexc); + Vect Descendent_States_with_iK_Stepped_Down (std::string ScanIx2_label, const LiebLin_Bethe_State& OriginState, bool disperse_only_current_exc, bool preserve_nexc); + Vect Descendent_States_with_iK_Preserved (std::string ScanIx2_label, const LiebLin_Bethe_State& OriginState, bool disperse_only_current_exc_up, bool preserve_nexc_up, bool disperse_only_current_exc_down, bool preserve_nexc_down); + Vect Descendent_States_with_iK_Stepped_Up (std::string ScanIx2_label, const Heis_Bethe_State& OriginState, bool disperse_only_current_exc, bool preserve_nexc); + Vect Descendent_States_with_iK_Stepped_Down (std::string ScanIx2_label, const Heis_Bethe_State& OriginState, bool disperse_only_current_exc, bool preserve_nexc); + Vect Descendent_States_with_iK_Preserved (std::string ScanIx2_label, const Heis_Bethe_State& OriginState, bool disperse_only_current_exc_up, bool preserve_nexc_up, bool disperse_only_current_exc_down, bool preserve_nexc_down); + + // For symmetric state scanning: + Vect Descendent_States_with_iK_Stepped_Up_rightIx2only + (std::string ScanIx2_label, const LiebLin_Bethe_State& OriginState, bool disperse_only_current_exc, bool preserve_nexc); + Vect Descendent_States_with_iK_Stepped_Down_rightIx2only + (std::string ScanIx2_label, const LiebLin_Bethe_State& OriginState, bool disperse_only_current_exc, bool preserve_nexc); + Vect Descendent_States_with_iK_Stepped_Up_rightIx2only + (std::string ScanIx2_label, const Heis_Bethe_State& OriginState, bool disperse_only_current_exc, bool preserve_nexc); + Vect Descendent_States_with_iK_Stepped_Down_rightIx2only + (std::string ScanIx2_label, const Heis_Bethe_State& OriginState, bool disperse_only_current_exc, bool preserve_nexc); + + // Functions in src/SCAN/General_Scan.cc: + void Scan_LiebLin (char whichDSF, DP c_int, DP L, int N, int iKmin, int iKmax, DP kBT, + int Max_Secs, DP target_sumrule, bool refine, int paralevel, Vect rank, Vect nr_processors); + void Scan_LiebLin (char whichDSF, DP c_int, DP L, int N, int iKmin, int iKmax, DP kBT, + int Max_Secs, DP target_sumrule, bool refine); + void Scan_LiebLin (char whichDSF, LiebLin_Bethe_State AveragingState, std::string defaultScanStatename, int iKmin, int iKmax, + int Max_Secs, DP target_sumrule, bool refine, int paralevel, Vect rank, Vect nr_processors); + void Scan_LiebLin (char whichDSF, LiebLin_Bethe_State AveragingState, std::string defaultname, int iKmin, int iKmax, + int Max_Secs, DP target_sumrule, bool refine); + void Scan_LiebLin_Geometric_Quench (DP c_int, DP L_1, int type_id_1, long long int id_1, DP L_2, int N, + int iK_UL, int Max_Secs, DP target_sumrule, bool refine); + + void Scan_Heis (char whichDSF, DP Delta, int N, int M, int iKmin, int iKmax, + int Max_Secs, DP target_sumrule, bool refine, int paralevel, Vect rank, Vect nr_processors); + void Scan_Heis (char whichDSF, DP Delta, int N, int M, int iKmin, int iKmax, + int Max_Secs, DP target_sumrule, bool refine); + void Scan_Heis (char whichDSF, XXZ_Bethe_State& AveragingState, std::string defaultScanStatename, int iKmin, int iKmax, + int Max_Secs, DP target_sumrule, bool refine, int paralevel, Vect rank, Vect nr_processors); + void Scan_Heis (char whichDSF, XXX_Bethe_State& AveragingState, std::string defaultScanStatename, int iKmin, int iKmax, + int Max_Secs, DP target_sumrule, bool refine, int paralevel, Vect rank, Vect nr_processors); + void Scan_Heis (char whichDSF, XXZ_gpd_Bethe_State& AveragingState, std::string defaultScanStatename, int iKmin, int iKmax, + int Max_Secs, DP target_sumrule, bool refine, int paralevel, Vect rank, Vect nr_processors); + + void Scan_ODSLF (char whichDSF, DP Delta, int N, int M, int iKmin, int iKmax, + int Max_Secs, DP target_sumrule, bool refine, int rank, int nr_processors); + void Scan_ODSLF (char whichDSF, DP Delta, int N, int M, int iKmin, int iKmax, int Max_Secs, bool refine); + void Scan_ODSLF (char whichDSF, DP Delta, int N, int M, int iKneeded, int Max_Secs, bool refine); + void Scan_ODSLF (char whichDSF, DP Delta, int N, int M, int Max_Secs, bool refine); + + // Functions to prepare and wrapup parallel scans: + void Prepare_Parallel_Scan_LiebLin (char whichDSF, DP c_int, DP L, int N, int iKmin, int iKmax, DP kBT, + std::string defaultname, int paralevel, Vect rank_lower_paralevels, + Vect nr_processors_lower_paralevels, int nr_processors_at_newlevel); + void Wrapup_Parallel_Scan_LiebLin (char whichDSF, DP c_int, DP L, int N, int iKmin, int iKmax, DP kBT, + std::string defaultname, int paralevel, Vect rank_lower_paralevels, + Vect nr_processors_lower_paralevels, int nr_processors_at_newlevel); + + void Prepare_Parallel_Scan_Heis (char whichDSF, DP Delta, int N, int M, int iKmin, int iKmax, + int paralevel, Vect rank_lower_paralevels, + Vect nr_processors_lower_paralevels, int nr_processors_at_newlevel); + void Wrapup_Parallel_Scan_Heis (char whichDSF, DP Delta, int N, int M, int iKmin, int iKmax, + int paralevel, Vect rank_lower_paralevels, + Vect nr_processors_lower_paralevels, int nr_processors_at_newlevel); + + + void Sort_RAW_File (const char ffsq_file[], char optionchar); + void Sort_RAW_File (const char ffsq_file[], char optionchar, char whichDSF); + + // Functions for data interpretation: + DP Smoothen_RAW_into_SF (std::string prefix, int iKmin, int iKmax, int DiK, + DP ommin, DP ommax, int Nom, DP gwidth, DP normalization, DP denom_sum_K); + DP Smoothen_RAW_into_SF (std::string prefix, Vect rawfilename, Vect weight, int iKmin, int iKmax, int DiK, + DP ommin, DP ommax, int Nom, DP gwidth, DP normalization, DP denom_sum_K); + void Write_K_File (DP Length, int iKmin, int iKmax); + void Write_Omega_File (int Nout_omega, DP omegamin, DP omegamax); + // Smoothen with gaussian width scaled with two-particle bandwidth + DP Smoothen_RAW_into_SF_LiebLin_Scaled (std::string prefix, DP L, int N, int iKmin, int iKmax, int DiK, DP ommin, DP ommax, int Nom, DP width, DP normalization); + + + //**************************************************************************** + + struct Scan_Info { + + DP sumrule_obtained; + DP Nfull; // dimensionality of (sub)Hilbert space considered + long long int Ninadm; + long long int Ndata; + long long int Ndata_conv; + long long int Ndata_conv0; + double TT; // total computation time in seconds + + public: + Scan_Info(); // constructor, puts everything to zero + Scan_Info (DP sr, DP Nf, long long int Ni, long long int Nd, long long int Ndc, long long int Ndc0, double t); + + void Save (const char* outfile_Cstr); + void Load (const char* infile_Cstr); + + inline Scan_Info& operator = (const Scan_Info& ref_info) + { + sumrule_obtained = ref_info.sumrule_obtained; + Nfull = ref_info.Nfull; + Ninadm = ref_info.Ninadm; + Ndata = ref_info.Ndata; + Ndata_conv = ref_info.Ndata_conv; + Ndata_conv0 = ref_info.Ndata_conv0; + TT = ref_info.TT; + + return(*this); + } + + inline Scan_Info& operator+= (const Scan_Info& ref_info) + { + if (this != &ref_info) { + sumrule_obtained += ref_info.sumrule_obtained; + Nfull += ref_info.Nfull; + Ninadm += ref_info.Ninadm; + Ndata += ref_info.Ndata; + Ndata_conv += ref_info.Ndata_conv; + Ndata_conv0 += ref_info.Ndata_conv0; + TT += ref_info.TT; + } + + return(*this); + } + + inline Scan_Info& operator-= (const Scan_Info& ref_info) + { + if (this != &ref_info) { + sumrule_obtained -= ref_info.sumrule_obtained; + Nfull -= ref_info.Nfull; + Ninadm -= ref_info.Ninadm; + Ndata -= ref_info.Ndata; + Ndata_conv -= ref_info.Ndata_conv; + Ndata_conv0 -= ref_info.Ndata_conv0; + TT -= ref_info.TT; + } + + return(*this); + } + + }; + + std::ostream& operator<< (std::ostream& s, const Scan_Info& info); + + template + Scan_Info General_Scan (char whichDSF, int iKmin, int iKmax, int iKmod, DP kBT, Tstate& AveragingState, Tstate& SeedScanState, + std::string defaultScanStatename, int Max_Secs, DP target_sumrule, bool refine, int paralevel, Vect rank, Vect nr_processors); + + + //**************************************************************************** + + // Functions in src/SCAN/Descendents.cc: + Vect Descendents (const LiebLin_Bethe_State& ScanState, const LiebLin_Bethe_State& OriginState, int type_required); + Vect Descendents (const Heis_Bethe_State& ScanState, const Heis_Bethe_State& OriginState, int type_required); + + + struct Scan_Thread { + + std::string label; + int type; + + Scan_Thread (); + Scan_Thread (std::string label_ref, int type_ref) { + label = label_ref; + type = type_ref; + } + + Scan_Thread& operator= (const Scan_Thread& RefThread); + }; + + + struct Scan_Thread_Data { + + // By convention, a Scan_Thread_Data object handles a list of threads which are yet to be descended. + // Improvement on Scan_Thread_Set used up to ABACUS++G_7, saving data to disk instead of holding it in memory. + + int nlists = 6400; // number of threads lists, fixed to this number by convention. + DP logscale = (1.0/64) * log(2.0); // each separate list contains threads differing by a scale factor of 2^{1/64} \approx 1.01. + + std::string thrdir_name; // directory in which threads files are saved. + + Vect nthreads_total; + + Vect nthreads_on_disk; + int lowest_il_with_nthreads_neq_0; + + // In-memory storage, for adding threads efficiently without constantly writing to disk + // These objects are saved to disk when Next_Scan_Threads are called. + Vect dim; + Vect nthreads_in_memory; + Vect > label; + Vect > type; // which type of descendent is needed + + Vect filename; + + Scan_Thread_Data (); + Scan_Thread_Data (std::string thrdir_name_ref, bool refine); + ~Scan_Thread_Data (); + + bool Increase_Memory_Size (int il, int nr_to_add); + void Include_Thread (DP abs_data_value_ref, std::string label_ref, int type_ref); + void Include_Thread (int il, std::string label_ref, int type_ref); + + Vect Extract_Next_Scan_Threads (); // returns a vector of the threads that are next in line. By defn, all threads with index il == lowest_il_with_nthreads_neq_0. These are removed from the object. + Vect Extract_Next_Scan_Threads (int min_nr); // as above, but returns a minimum of min_nr threads. + + + void Flush_to_Disk (int il); + void Save (); + void Load (); + }; + + + + //**************************************************************************** + + // To populate a list of states for scanning: + + inline void Scan_for_Possible_Bases (const Vect SeedNrap, const Vect Str_L, + int Mdown_remaining, Vect& possible_base_label, int& nfound, int nexc_max_used, + int base_level_to_scan, Vect& Nrapidities) + { + if (Mdown_remaining < 0) { ABACUSerror("Scan_for_Possible_Bases: shouldn't be here..."); } // reached inconsistent point + + if (base_level_to_scan == 0) { + if (Str_L[0] != 1) ABACUSerror("Str_L[0] != 1 in ABACUS_Scan.h Scan_for_Possible_Bases."); + Nrapidities[0] = Mdown_remaining; + + // Set label: + std::stringstream M0out; + M0out << Nrapidities[0]; + possible_base_label[nfound] = M0out.str(); + for (int itype = 1; itype < Nrapidities.size(); ++itype) + if (Nrapidities[itype] > 0) { + possible_base_label[nfound] += TYPESEP; + std::stringstream typeout; + typeout << itype; + possible_base_label[nfound] += typeout.str(); + possible_base_label[nfound] += EXCSEP; + std::stringstream Mout; + Mout << Nrapidities[itype]; + possible_base_label[nfound] += Mout.str(); + } + nfound++; + } + + else { + // Preserve the number of strings at this level as compared to SeedState: + Nrapidities[base_level_to_scan] = SeedNrap[base_level_to_scan]; + if (Mdown_remaining - Str_L[base_level_to_scan] * Nrapidities[base_level_to_scan] >= 0) + Scan_for_Possible_Bases (SeedNrap, Str_L, Mdown_remaining - Str_L[base_level_to_scan] * Nrapidities[base_level_to_scan], + possible_base_label, nfound, nexc_max_used, base_level_to_scan - 1, Nrapidities); + + // Reduce number of strings at this level as compared to SeedState: + for (int i = 1; i <= ABACUS::min(SeedNrap[base_level_to_scan], nexc_max_used/Str_L[base_level_to_scan]); ++i) { + Nrapidities[base_level_to_scan] = SeedNrap[base_level_to_scan] - i; + if (Mdown_remaining - Str_L[base_level_to_scan] * Nrapidities[base_level_to_scan] >= 0) + Scan_for_Possible_Bases (SeedNrap, Str_L, Mdown_remaining - Str_L[base_level_to_scan] * Nrapidities[base_level_to_scan], + possible_base_label, nfound, nexc_max_used - i*Str_L[base_level_to_scan], base_level_to_scan - 1, Nrapidities); + } + // Increase the number of strings at this level as compared to SeedState: + for (int i = 1; i <= ABACUS::min(Mdown_remaining/Str_L[base_level_to_scan], nexc_max_used/Str_L[base_level_to_scan]); ++i) { + Nrapidities[base_level_to_scan] = SeedNrap[base_level_to_scan] + i; + if (Mdown_remaining - Str_L[base_level_to_scan] * Nrapidities[base_level_to_scan] >= 0) + Scan_for_Possible_Bases (SeedNrap, Str_L, Mdown_remaining - Str_L[base_level_to_scan] * Nrapidities[base_level_to_scan], + possible_base_label, nfound, nexc_max_used - i*Str_L[base_level_to_scan], base_level_to_scan - 1, Nrapidities); + } + } + } + + + inline Vect Possible_Bases (const Vect SeedNrap, const Vect Str_L, int Mdown)//const Heis_Bethe_State& SeedState) + { + int nexc_max_used = NEXC_MAX_HEIS; + + Vect possible_base_label (1000); + int nfound = 0; + Vect Nrapidities = SeedNrap; + int Mdown_remaining = Mdown; + + Scan_for_Possible_Bases (SeedNrap, Str_L, Mdown_remaining, possible_base_label, nfound, nexc_max_used, SeedNrap.size() - 1, Nrapidities); + + // Copy results into a clean vector: + Vect possible_base_label_found (nfound); + for (int i = 0; i < nfound; ++i) possible_base_label_found[i] = possible_base_label[i]; + + return(possible_base_label_found); + } + + + + //**************************************************************************** + + template + class Scan_State_List { + + public: + int ndef; + Vect State; + Vect base_label; + Vect info; // info for base and type of State[n] + Vect flag_for_scan; // set to true, next round of scanning will use this base/type + Vect scan_attempted; // whether this has already been attempted + + public: + inline Scan_State_List (char whichDSF, const Tstate& SeedScanState); + + public: + inline Tstate& Return_State (std::string base_label_ref); // returns a state corresponding to same base and type + inline void Populate_List (char whichDSF, const Tstate& SeedScanState); // creates all types of states containing up to nexc_max excitations + inline void Include_Info (Scan_Info& info_to_add, std::string base_label_ref); + inline void Raise_Scanning_Flags (DP threshold); // checks whether base/type should be scanned based on simpler base/type combinations + + inline void Order_in_SRC (); + inline void Save_Info (const char* sumfile_Cstr); + inline void Load_Info (const char* sumfile_Cstr); + }; + + // Do the explicit class specializations: + + template<> + inline Scan_State_List::Scan_State_List (char whichDSF, const LiebLin_Bethe_State& SeedScanState) + : ndef(0), State(Vect(MAX_STATE_LIST_SIZE)), base_label(Vect(MAX_STATE_LIST_SIZE)), + info(Vect(MAX_STATE_LIST_SIZE)), flag_for_scan(Vect(false, MAX_STATE_LIST_SIZE)), + scan_attempted(Vect(false, MAX_STATE_LIST_SIZE)) + { + State[0] = SeedScanState; + } + + template<> + inline Scan_State_List::Scan_State_List (char whichDSF, const XXZ_Bethe_State& SeedScanState) + : ndef(0), State(Vect(MAX_STATE_LIST_SIZE)), base_label(Vect(MAX_STATE_LIST_SIZE)), + info(Vect(MAX_STATE_LIST_SIZE)), flag_for_scan(Vect(false, MAX_STATE_LIST_SIZE)), + scan_attempted(Vect(false, MAX_STATE_LIST_SIZE)) + { + State[0] = SeedScanState; + } + + template<> + inline Scan_State_List::Scan_State_List (char whichDSF, const XXX_Bethe_State& SeedScanState) + : ndef(0), State(Vect(MAX_STATE_LIST_SIZE)), base_label(Vect(MAX_STATE_LIST_SIZE)), + info(Vect(MAX_STATE_LIST_SIZE)), flag_for_scan(Vect(false, MAX_STATE_LIST_SIZE)), + scan_attempted(Vect(false, MAX_STATE_LIST_SIZE)) + { + State[0] = SeedScanState; + } + + template<> + inline Scan_State_List::Scan_State_List (char whichDSF, const XXZ_gpd_Bethe_State& SeedScanState) + : ndef(0), State(Vect(MAX_STATE_LIST_SIZE)), base_label(Vect(MAX_STATE_LIST_SIZE)), + info(Vect(MAX_STATE_LIST_SIZE)), flag_for_scan(Vect(false, MAX_STATE_LIST_SIZE)), + scan_attempted(Vect(false, MAX_STATE_LIST_SIZE)) + { + State[0] = SeedScanState; + } + + /* IN_DEVELOPMENT + template<> + inline Scan_State_List::Scan_State_List (char whichDSF, const ODSLF_XXZ_Bethe_State& RefState) + : ndef(0), State(Vect(MAX_STATE_LIST_SIZE)), base_label(Vect(MAX_STATE_LIST_SIZE)), + info(Vect(MAX_STATE_LIST_SIZE)), flag_for_scan(Vect(false, MAX_STATE_LIST_SIZE)), + scan_attempted(Vect(false, MAX_STATE_LIST_SIZE)) + { + if (whichDSF == 'Z' || whichDSF == 'z') State[0] = ODSLF_XXZ_Bethe_State(RefState.chain, RefState.base.Mdown); + else if (whichDSF == 'm') State[0] = ODSLF_XXZ_Bethe_State(RefState.chain, RefState.base.Mdown - 1); + else if (whichDSF == 'p') State[0] = ODSLF_XXZ_Bethe_State(RefState.chain, RefState.base.Mdown + 1); + else ABACUSerror("Unknown whichDSF in Scan_State_List + inline LiebLin_Bethe_State& Scan_State_List::Return_State (std::string base_label_ref) + { + int n = 0; + while (n < ndef && base_label_ref.compare(base_label[n]) != 0) n++; + + if (n == ndef) { + State[n] = State[0]; + base_label[n] = base_label_ref; + info[n].Nfull = 1LL; // Nfull not definable for LiebLin + ndef++; + } + + return(State[n]); + } + + template<> + inline XXZ_Bethe_State& Scan_State_List::Return_State (std::string base_label_ref) + { + int n = 0; + while (n < ndef && base_label_ref.compare(base_label[n]) != 0) n++; + + if (n == ndef) { + Heis_Base checkbase (State[0].chain, base_label_ref); + State[n] = XXZ_Bethe_State (State[0].chain, checkbase); + info[n].Nfull = checkbase.dimH; + ndef++; + } + + return(State[n]); + } + + template<> + inline XXX_Bethe_State& Scan_State_List::Return_State (std::string base_label_ref) + { + int n = 0; + while (n < ndef && base_label_ref.compare(base_label[n]) != 0) n++; + + if (n == ndef) { + Heis_Base checkbase (State[0].chain, base_label_ref); + State[n] = XXX_Bethe_State (State[0].chain, checkbase); + info[n].Nfull = checkbase.dimH; + ndef++; + } + + return(State[n]); + } + + template<> + inline XXZ_gpd_Bethe_State& Scan_State_List::Return_State (std::string base_label_ref) + { + int n = 0; + while (n < ndef && base_label_ref.compare(base_label[n]) != 0) n++; + + if (n == ndef) { + Heis_Base checkbase (State[0].chain, base_label_ref); + State[n] = XXZ_gpd_Bethe_State (State[0].chain, checkbase); + info[n].Nfull = checkbase.dimH; + ndef++; + } + + return(State[n]); + } + + /* IN DEVELOPMENT + template<> + inline ODSLF_XXZ_Bethe_State& Scan_State_List::Return_State (long long int base_id_ref, long long int type_id_ref) + { + int n = 0; + while (n < ndef && !(base_id_ref == State[n].base_id && type_id_ref == State[n].type_id)) n++; + + if (n == ndef) { + State[n] = ODSLF_XXZ_Bethe_State (State[0].chain, base_id_ref, type_id_ref); + info[n].Nfull = State[n].maxid + 1LL; + ndef++; + } + + return(State[n]); + } + */ + + template<> + inline void Scan_State_List::Populate_List (char whichDSF, const LiebLin_Bethe_State& SeedScanState) + { + // For LiebLin_Bethe_State: only one base is used, so there is only one state here. + + if (ndef != 0) ABACUSerror("Please only populate a virgin Scan_State_List."); + + std::stringstream baselabel; + baselabel << State[0].N; + base_label[0] = baselabel.str(); + std::stringstream label0; + label0 << State[0].N << LABELSEP << ABACUScoding[0] << LABELSEP;//"_0_"; + State[0].Set_to_Label (label0.str(), SeedScanState.Ix2); + info[0].Nfull = 1LL; // Nfull not definable for LiebLin + ndef = 1; + } + + template<> + inline void Scan_State_List::Populate_List (char whichDSF, const XXZ_Bethe_State& SeedScanState) + { + // creates all types of states containing up to nexc_max excitations + + if (ndef != 0) ABACUSerror("Please only populate a virgin Scan_State_List."); + + // We assume that SeedScanState has quantum numbers which are set according to the relevant AveragingState. + + // This function creates a list of states with other bases in the vicinity of that of SeedScanState, + // matching the quantum numbers as closely as possible. + + Vect Str_L(SeedScanState.chain.Nstrings); + for (int i = 0; i < SeedScanState.chain.Nstrings; ++i) Str_L[i] = SeedScanState.chain.Str_L[i]; + + // First of all, we create a list of the possible bases themselves. + Vect bases_label = Possible_Bases (SeedScanState.base.Nrap, Str_L, SeedScanState.base.Mdown); // returns a vector of possible bases + + for (int ib = 0; ib < bases_label.size(); ++ib) { + + Heis_Base checkbase (State[0].chain, bases_label[ib]); + + State[ndef] = XXZ_Bethe_State (State[0].chain, checkbase); + State[ndef].Set_to_Closest_Matching_Ix2_fixed_Base (SeedScanState); + State[ndef].Set_Label_from_Ix2 (State[ndef].Ix2); // sets to trivial label for this base + base_label[ndef] = bases_label[ib]; + info[ndef].Nfull = State[ndef].base.dimH; + ndef++; + if (ndef >= MAX_STATE_LIST_SIZE) ABACUSerror("Increase number of elements in ScanStateList."); + } + } + + template<> + inline void Scan_State_List::Populate_List (char whichDSF, const XXX_Bethe_State& SeedScanState) + { + // creates all types of states containing up to nexc_max excitations + + if (ndef != 0) ABACUSerror("Please only populate a virgin Scan_State_List."); + + // We assume that SeedScanState has quantum numbers which are set according to the relevant AveragingState. + + // This function creates a list of states with other bases in the vicinity of that of SeedScanState, + // matching the quantum numbers as closely as possible. + + Vect Str_L(SeedScanState.chain.Nstrings); + for (int i = 0; i < SeedScanState.chain.Nstrings; ++i) Str_L[i] = SeedScanState.chain.Str_L[i]; + + // To take infinite rapidities into account, we use intermediate states with up to 2 less finite rapidities (1 for Szz, 2 for Spm) + int nrinfrapmax = 0; + if (whichDSF == 'z') nrinfrapmax = 1; + else if (whichDSF == 'p') nrinfrapmax = ABACUS::min(2, SeedScanState.base.Mdown); + + Vect Nrapmod = SeedScanState.base.Nrap; + + for (int nrinfrap = 0; nrinfrap <= nrinfrapmax; ++nrinfrap) { + + Nrapmod[0] = SeedScanState.base.Nrap[0] - nrinfrap; + if (Nrapmod[0] < 0) ABACUSerror("Putting too many rapidities at infinity in ABACUS_Scan.h: Possible_Bases."); + + Vect bases_label = Possible_Bases (Nrapmod, Str_L, SeedScanState.base.Mdown-nrinfrap); // returns a vector of possible bases + + for (int ib = 0; ib < bases_label.size(); ++ib) { + + Heis_Base checkbase (State[0].chain, bases_label[ib]); + + State[ndef] = XXX_Bethe_State (State[0].chain, checkbase); + State[ndef].Set_to_Closest_Matching_Ix2_fixed_Base (SeedScanState); + base_label[ndef] = bases_label[ib]; + info[ndef].Nfull = State[ndef].base.dimH; + ndef++; + if (ndef >= MAX_STATE_LIST_SIZE) ABACUSerror("Increase number of elements in ScanStateList."); + } + } // for nrinfrap + } + + template<> + inline void Scan_State_List::Populate_List (char whichDSF, const XXZ_gpd_Bethe_State& SeedScanState) + { + // creates all types of states containing up to nexc_max excitations + + if (ndef != 0) ABACUSerror("Please only populate a virgin Scan_State_List."); + + // We assume that SeedScanState has quantum numbers which are set according to the relevant AveragingState. + + // This function creates a list of states with other bases in the vicinity of that of SeedScanState, + // matching the quantum numbers as closely as possible. + + Vect Str_L(SeedScanState.chain.Nstrings); + for (int i = 0; i < SeedScanState.chain.Nstrings; ++i) Str_L[i] = SeedScanState.chain.Str_L[i]; + + // First of all, we create a list of the possible bases themselves. + Vect bases_label = Possible_Bases (SeedScanState.base.Nrap, Str_L, SeedScanState.base.Mdown); // returns a vector of possible bases + + for (int ib = 0; ib < bases_label.size(); ++ib) { + + Heis_Base checkbase (State[0].chain, bases_label[ib]); + + State[ndef] = XXZ_gpd_Bethe_State (State[0].chain, checkbase); + State[ndef].Set_to_Closest_Matching_Ix2_fixed_Base (SeedScanState); + base_label[ndef] = bases_label[ib]; + info[ndef].Nfull = State[ndef].base.dimH; + ndef++; + if (ndef >= MAX_STATE_LIST_SIZE) ABACUSerror("Increase number of elements in ScanStateList."); + } + } + + + /* IN DEVELOPMENT + template<> + inline void Scan_State_List::Populate_List () + { + // creates all types of states containing up to nexc_max excitations + + if (ndef != 0) ABACUSerror("Please only populate a virgin Scan_State_List."); + + //std::cout << "In Populate_List: " << State[0] << std::endl; + + Vect bases_id = State[0].chain.Possible_Bases (State[0].base.Mdown); // returns a vector of possible bases + + //std::cout << "Mdown = " << State[0].base.Mdown << "\tPossible bases size: " << bases_id.size() << "\tPossible bases: " << bases_id << std::endl; + + for (int ib = 0; ib < bases_id.size(); ++ib) { + ODSLF_Base checkbase (State[0].chain, bases_id[ib]); + + Vect types_id = checkbase.Possible_Types (); // returns a vector of possible types + + //std::cout << "For base_id " << bases_id[ib] << "\t found types " << types_id << std::endl; + + for (int it = 0; it < types_id.size(); ++it) { + + if (bases_id[ib] < 1000000) { // FUDGE: consider only one-strings + //std::cout << "Populate list: constructing state: " << bases_id[ib] << "\t" << types_id[it] << std::endl; + State[ndef] = ODSLF_XXZ_Bethe_State (State[0].chain, bases_id[ib], types_id[it]); + //std::cout << "Populate list: before setting id: " << std::endl << State[ndef] << std::endl; + State[ndef].Set_to_id(0LL); + //std::cout << "Populate list: after setting id: " << std::endl << State[ndef] << std::endl; + info[ndef].Nfull = State[ndef].maxid + 1LL; + ndef++; + if (ndef >= MAX_STATE_LIST_SIZE) ABACUSerror("Increase number of elements in ScanStateList."); + } + } + + } + } + + */ + + + + template + inline void Scan_State_List::Include_Info (Scan_Info& info_to_add, std::string base_label_ref) + { + + int n = 0; + while (n < ndef && base_label_ref.compare(base_label[n]) != 0) n++; + + if (n == ndef) { + std::cout << "ndef = " << ndef << std::endl; + for (int i = 0; i < ndef; ++i) std::cout << base_label[i] << "\t"; + std::cout << std::endl; + std::cout << "base_label_ref " << base_label_ref << std::endl; + ABACUSerror("Did not find base_label_ref in Scan_State_List::Include_Info."); + } + + info[n] += info_to_add; + return; + } + + + template + inline void Scan_State_List::Raise_Scanning_Flags (DP threshold) + { + flag_for_scan = true; + } + + template + inline void Scan_State_List::Order_in_SRC () + { + if (ndef > 0) { + + Vect_INT index(ndef); + for (int i = 0; i < ndef; ++i) index[i] = i; + + Vect sr (ndef); + for (int i = 0; i < ndef; ++i) sr[i] = info[i].sumrule_obtained; + + sr.QuickSort(index, 0, ndef - 1); + + Vect State_ordered(ndef); + Vect base_label_ordered(ndef); + Vect info_ordered(ndef); + Vect flag_for_scan_ordered(ndef); + + // Put data in proper order + for (int i = 0; i < ndef; ++i) { + State_ordered[i] = State[index[ndef - 1 - i] ]; + base_label_ordered[i] = base_label[index[ndef - 1 - i] ]; + info_ordered[i] = info[index[ndef - 1 - i] ]; + flag_for_scan_ordered[i] = flag_for_scan[index[ndef - 1 - i] ]; + } + + // Put back in *this object: + for (int i = 0; i < ndef; ++i) { + State[i] = State_ordered[i]; + base_label[i] = base_label_ordered[i]; + info[i] = info_ordered[i]; + flag_for_scan[i] = flag_for_scan_ordered[i]; + } // The rest are all simply 0. + } + } + + template + inline void Scan_State_List::Save_Info (const char* sumfile_Cstr) + { + std::ofstream outfile; + + outfile.open(sumfile_Cstr); + if (outfile.fail()) ABACUSerror("Could not open outfile... "); + + outfile.setf(std::ios::fixed); + outfile.precision(16); + + outfile << std::setw(20) << "base" << std::setw(25) << "sumrule_obtained" << std::setw(25) << "Nfull" << std::setw(10) << "Ninadm" << std::setw(10) << "Ndata" << std::setw(10) << "conv" << std::setw(10) << "conv0" << std::setw(10) << "TT."; + + for (int i = 0; i < ndef; ++i) + if (info[i].Nfull > 0.0) { + int TT_hr = int(info[i].TT/3600); + int TT_min = int((info[i].TT - 3600.0*TT_hr)/60); + outfile << std::endl << std::setw(20) << base_label[i] << std::setw(25) << std::fixed << std::setprecision(20) << info[i].sumrule_obtained; + if (info[i].Nfull < 1.0e+10) outfile << std::setw(25) << std::fixed << std::setprecision(0) << info[i].Nfull; + else outfile << std::setw(25) << std::scientific << std::setprecision(16) << info[i].Nfull; + outfile << std::setw(10) << info[i].Ninadm << std::setw(10) << info[i].Ndata << std::setw(10) << info[i].Ndata_conv << std::setw(10) << info[i].Ndata_conv0 << std::setw(10) << TT_hr << " h " << TT_min << " m " << std::fixed << std::showpoint << std::setprecision(3) << info[i].TT - 3600.0*TT_hr - 60.0*TT_min << " s"; + } + outfile.close(); + } + + template + inline void Scan_State_List::Load_Info (const char* sumfile_Cstr) + { + std::ifstream infile; + infile.open(sumfile_Cstr); + if(infile.fail()) { + std::cout << std::endl << sumfile_Cstr << std::endl; + ABACUSerror("Could not open input file in Scan_State_List::Load_Info."); + } + + // Load first line, containing informative text: + char junk[256]; + infile.getline(junk, 256); + + // Now load the previous info's: + std::string base_label_ref; + DP sr_ref; + DP Nfull_ref; + long long int Ninadm_ref, Ndata_ref, conv_ref, conv0_ref; + DP TT_ref; + int TT_hr, TT_min; + DP TT_sec; + char a; + + while (infile.peek() != EOF) { + infile >> base_label_ref >> sr_ref >> Nfull_ref >> Ninadm_ref >> Ndata_ref >> conv_ref >> conv0_ref >> TT_hr >> a >> TT_min >> a >> TT_sec >> a; + TT_ref = 3600.0 * TT_hr + 60.0* TT_min + TT_sec; + Scan_Info info_ref (sr_ref, Nfull_ref, Ninadm_ref, Ndata_ref, conv_ref, conv0_ref, TT_ref); + (*this).Include_Info (info_ref, base_label_ref); + } + + infile.close(); + + return; + } + + +} // namespace ABACUS + +#endif diff --git a/include/JSC_Spec_Fns.h b/include/ABACUS_Spec_Fns.h similarity index 65% rename from include/JSC_Spec_Fns.h rename to include/ABACUS_Spec_Fns.h index 2770d50..69397e3 100644 --- a/include/JSC_Spec_Fns.h +++ b/include/ABACUS_Spec_Fns.h @@ -2,24 +2,22 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- -File: JSC_Spec_Fns.h +File: ABACUS_Spec_Fns.h Purpose: Defines special math functions. ***********************************************************/ -#ifndef _JSC_SPEC_FNS_H_ -#define _JSC_SPEC_FNS_H_ +#ifndef ABACUS_SPEC_FNS_H +#define ABACUS_SPEC_FNS_H -#include "JSC.h" +#include "ABACUS.h" -using namespace std; - -namespace JSC { +namespace ABACUS { inline DP Cosine_Integral (DP x) { @@ -28,8 +26,8 @@ namespace JSC { // Refer to GR[6] 8.23 if (x <= 0.0) { - cout << "Cosine_Integral called with real argument " << x << " <= 0, which is ill-defined because of the branch cut." << endl; - JSCerror(""); + std::cout << "Cosine_Integral called with real argument " << x << " <= 0, which is ill-defined because of the branch cut." << std::endl; + ABACUSerror(""); } else if (x < 15.0) { // Use power series expansion @@ -45,7 +43,7 @@ namespace JSC { DP series = minonetothen * exp(logxtothetwon - log(2.0 * n) - logtwonfact); DP term_n; - do { + do { n += 1; minonetothen *= -1.0; logxtothetwon += twologx; @@ -55,34 +53,6 @@ namespace JSC { } while (fabs(term_n) > 1.0e-16); - - - - /* - // For improved convergence we pair terms up, DOESN'T WORK WELL - - // Ci (x) = gamma + \ln x - \sum{n = 1, 3, 5, ...} \frac{x^{2n}}{2n (2n)!} ( 1 - \frac{n}{n+1} \frac{x^2}{(2n+1)(2n+2)} ) - - int n = 1; - DP logxtothetwon = 2.0 * log(x); - DP logtwon = log(2.0); - DP logtwonfact = log(2.0); - DP xsq = x*x; - - DP series = exp(logxtothetwon - logtwon - logtwonfact) * (1 - xsq/((2.0 * n + 1.0) * (2.0 * n + 2.0) * (1.0 + 1.0/n))); - DP term_n; - DP twologx = 2.0 * log(x); - - do { - n += 2; - logxtothetwon += twologx; - logtwonfact += log((2.0 * n - 1.0) * 2.0 * n); - term_n = exp(logxtothetwon - log(2.0 * n) - logtwonfact) * (1 - xsq/((2.0 * n + 1.0) * (2.0 * n + 2.0) * (1.0 + 1.0/n)));; - series += term_n; - - } while (fabs(term_n) > 1.0e-16); - */ - return(Euler_Mascheroni + log(x) + series); } @@ -102,7 +72,7 @@ namespace JSC { DP series1 = minonetothen * exp(logtwonfact - logxtothetwon); DP series2 = minonetothen * exp(logtwonplus1fact - logxtothetwonplus1); - do { + do { n += 1; minonetothen *= -1.0; logxtothetwon += twologx; @@ -133,11 +103,11 @@ namespace JSC { // in which q is the nome. (GR 8.180.1) // We always evaluate to numerical accuracy. - if (q >= 1.0) JSCerror("Jacobi_Theta_1_q function called with q > 1."); + if (q >= 1.0) ABACUSerror("Jacobi_Theta_1_q function called with q > 1."); DP answer = 0.0; - DP contrib = 0.0; + DP contrib = 0.0; DP qtonminhalfsq = pow(q, 0.25); // this will be q^{(n-1/2)^2} DP qtotwon = pow(q, 2.0); // this will be q^{2n} DP qsq = q*q; @@ -149,26 +119,24 @@ namespace JSC { qtonminhalfsq *= qtotwon; qtotwon *= qsq; n++; - //cout << "\t\tn = " << n << "\tanswer = " << answer << "\tcontrib = " << contrib << "\tqtonminhalfsq = " << qtonminhalfsq << "\tqtotwon = " << qtotwon << endl; } while (fabs(contrib/answer) > MACHINE_EPS); - //cout << "\t\tJacobi_Theta_1: used " << n << " iterations." << "\tanswer = " << answer << "\tcontrib = " << contrib << "\tqtonminhalfsq = " << qtonminhalfsq << "\tqtotwon = " << qtotwon << endl; return(answer); } - inline complex ln_Jacobi_Theta_1_q (complex u, complex q) { + inline std::complex ln_Jacobi_Theta_1_q (std::complex u, std::complex q) { // This uses the product representation // \theta_1 (x) = 2 q^{1/4} \sin{u} \prod_{n=1}^\infty (1 - 2 q^{2n} \cos 2u + q^{4n}) (1 - q^{2n}) // (GR 8.181.2) - complex contrib = 0.0; - complex qtotwon = q*q; // this will be q^{2n} - complex qsq = q*q; - complex twocos2u = 2.0 * cos(2.0*u); + std::complex contrib = 0.0; + std::complex qtotwon = q*q; // this will be q^{2n} + std::complex qsq = q*q; + std::complex twocos2u = 2.0 * cos(2.0*u); int n = 1; - complex answer = log(2.0 * sin(u)) + 0.25 * log(q); - + std::complex answer = log(2.0 * sin(u)) + 0.25 * log(q); + do { contrib = log((1.0 - twocos2u * qtotwon + qtotwon * qtotwon) * (1.0 - qtotwon)); answer += contrib; @@ -184,7 +152,7 @@ namespace JSC { inline DP ln_Gamma_for_Barnes_G_RE (Vect_DP args) { - return(real(ln_Gamma(complex(args[0])))); + return(real(ln_Gamma(std::complex(args[0])))); } inline DP ln_Barnes_G_RE (DP z) @@ -199,9 +167,9 @@ namespace JSC { int max_nr_pts = 10000; Integral_result integ_ln_Gamma = Integrate_optimal (ln_Gamma_for_Barnes_G_RE, args, 0, 0.0, z - 1.0, req_rel_prec, req_abs_prec, max_nr_pts); - return(0.5 * (z - 1.0) * (2.0 - z + logtwoPI) + (z - 1.0) * real(ln_Gamma(complex(z - 1.0))) - integ_ln_Gamma.integ_est); + return(0.5 * (z - 1.0) * (2.0 - z + logtwoPI) + (z - 1.0) * real(ln_Gamma(std::complex(z - 1.0))) - integ_ln_Gamma.integ_est); } -} // namespace JSC +} // namespace ABACUS -#endif // _JS_SPEC_FNS_H_ +#endif diff --git a/include/JSC_State_Ensemble.h b/include/ABACUS_State_Ensemble.h similarity index 66% rename from include/JSC_State_Ensemble.h rename to include/ABACUS_State_Ensemble.h index fd25f04..110a73f 100644 --- a/include/JSC_State_Ensemble.h +++ b/include/ABACUS_State_Ensemble.h @@ -2,23 +2,22 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- -File: JSC_State_Ensemble.h +File: ABACUS_State_Ensemble.h Purpose: Define state ensembles. - ***********************************************************/ -#ifndef _ENS_ -#define _ENS_ +#ifndef ABACUS_STATE_ENSEMBLE_H +#define ABACUS_STATE_ENSEMBLE_H -#include "JSC.h" +#include "ABACUS.h" -namespace JSC { +namespace ABACUS { struct LiebLin_Diagonal_State_Ensemble { @@ -29,8 +28,6 @@ namespace JSC { LiebLin_Diagonal_State_Ensemble (); LiebLin_Diagonal_State_Ensemble (const LiebLin_Bethe_State& RefState, int nstates_req); - //LiebLin_Diagonal_State_Ensemble (const LiebLin_Bethe_State& RefState, int nstates_req, const Vect& weight_ref); - //LiebLin_Diagonal_State_Ensemble (DP c_int, DP L, int N, const Root_Density& rho, int nstates_req); LiebLin_Diagonal_State_Ensemble (DP c_int, DP L, int N, const Root_Density& rho); LiebLin_Diagonal_State_Ensemble& operator= (const LiebLin_Diagonal_State_Ensemble& rhs); @@ -38,10 +35,9 @@ namespace JSC { void Save (const char* ensfile_Cstr); }; - //LiebLin_Diagonal_State_Ensemble LiebLin_Thermal_Saddle_Point_Ensemble (DP c_int, DP L, int N, DP kBT, int nstates_req); LiebLin_Diagonal_State_Ensemble LiebLin_Thermal_Saddle_Point_Ensemble (DP c_int, DP L, int N, DP kBT); -} // namespace JSC +} // namespace ABACUS #endif diff --git a/include/JSC_TBA.h b/include/ABACUS_TBA.h similarity index 93% rename from include/JSC_TBA.h rename to include/ABACUS_TBA.h index 43f0f53..3f7ac7c 100644 --- a/include/JSC_TBA.h +++ b/include/ABACUS_TBA.h @@ -2,26 +2,25 @@ This software is part of J.-S. Caux's ABACUS. library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- -File: JSC_TBA.h +File: ABACUS_TBA.h Purpose: Thermodynamic Bethe Ansatz general functions - ***********************************************************/ -#ifndef _TBA_ -#define _TBA_ +#ifndef ABACUS_TBA_H +#define ABACUS_TBA_H -#include "JSC.h" +#include "ABACUS.h" -namespace JSC { +namespace ABACUS { struct Root_Density { - + int Npts; // how many points are used to describe each function DP lambdamax; // what the largest rapidity is Vect_DP lambda; // rapidity vector @@ -31,42 +30,42 @@ namespace JSC { DP diff; // relative differences with previous iteration bool value_infty_set; // boolean, true if asymptotic value set DP value_infty; // asymptotic value, computed analytically - + Root_Density (); Root_Density (int Npts_ref, DP lambdamax_ref); - + Root_Density& operator= (const Root_Density& RefDensity); - + void Save (const char* outfile_Cstr); DP Return_Value (DP lambda_ref); // evaluates the function for any argument using linear interpolation void Set_Asymptotics (DP value_infty_ref); // sets value for lambda >= lambdamax - + Root_Density Compress_and_Match_Densities (DP comp_factor); // returns a Root_Density with fewer points }; struct Root_Density_Set { - + int ntypes; Vect epsilon; int Npts_total; // sum of all Npts of epsilon's DP diff; // sum of diff's of the epsilon's - + Root_Density_Set (); Root_Density_Set (int ntypes_ref, int Npts_ref, DP lambdamax_ref); Root_Density_Set (int ntypes_ref, Vect_INT Npts_ref, Vect_DP lambdamax_ref); - + Root_Density_Set& operator= (const Root_Density_Set& RefSet); - + void Insert_new_function (DP asymptotic_value); void Extend_limits (Vect need_to_extend_limit); void Insert_new_points (Vect > need_new_point_around); - + DP Return_Value (int n_ref, DP lambda_ref); // returns a value, no matter what. - + Root_Density_Set Return_Compressed_and_Matched_Set (DP comp_factor); void Match_Densities (Root_Density_Set& RefSet); - + void Save (const char* outfile_Cstr); }; @@ -100,13 +99,13 @@ namespace JSC { Root_Density LiebLin_rho_TBA (DP kBT, const Root_Density& epsilon, const Root_Density& depsilon_dmu); Root_Density LiebLin_rhoh_TBA (DP kBT, const Root_Density& epsilon, const Root_Density& depsilon_dmu); DP LiebLin_nbar_TBA (const Root_Density& rho); - DP LiebLin_ebar_TBA (const Root_Density& rho); - DP LiebLin_sbar_TBA (const Root_Density& rho, const Root_Density& rhoh); + DP LiebLin_ebar_TBA (const Root_Density& rho); + DP LiebLin_sbar_TBA (const Root_Density& rho, const Root_Density& rhoh); LiebLin_TBA_Solution LiebLin_TBA_Solution_fixed_nbar (DP c_int, DP nbar_required, DP kBT, DP req_diff, int Max_Secs); LiebLin_TBA_Solution LiebLin_TBA_Solution_fixed_nbar_ebar (DP c_int, DP nbar_required, DP ebar_required, DP req_diff, int Max_Secs); LiebLin_Bethe_State Discretized_LiebLin_Bethe_State (DP c_int, DP L, int N, const Root_Density& rho); - // Functions defined in TBA_XXZ.cc + // Functions defined in TBA_XXZ.cc DP XXZ_phi1_kernel (DP zeta, DP lambda); DP XXZ_phi2_kernel (DP zeta, DP lambda); DP XXZ_a1_kernel (DP sinzeta, DP coszeta, DP lambda); @@ -121,7 +120,6 @@ namespace JSC { Root_Density XXZ_Kbackflow_GS (DP Delta, DP B, DP lambdamax, DP lambda_p, DP lambda_h, int Npts, DP req_prec); Root_Density XXZ_Fbackflow_GS (DP Delta, DP B, DP lambdamax, DP lambda_p, DP lambda_h, int Npts, DP req_prec); Root_Density XXZ_Z_GS (DP Delta, DP B, DP lambdamax, int Npts, DP req_prec); - //void XXZ_Compare_Lattice_and_Continuum_Backflows_base_1010 (DP Delta, int N, int M, long long int id); // Defined in TBA_2CBG.cc: struct TBA_Data_2CBG { @@ -141,7 +139,7 @@ namespace JSC { void Scan_2CBG_TBAE (DP c_int, DP mu_min, DP mu_max, int Nmu, DP Omega_min, DP Omega_max, int NOmega, DP kBT_min, DP kBT_max, int NkBT, int Max_Secs); - -} // namespace JSC + +} // namespace ABACUS #endif diff --git a/include/ABACUS_Utils.h b/include/ABACUS_Utils.h new file mode 100644 index 0000000..4965e2d --- /dev/null +++ b/include/ABACUS_Utils.h @@ -0,0 +1,438 @@ +/********************************************************** + +This software is part of J.-S. Caux's ABACUS library. + +Copyright (c) J.-S. Caux. + +----------------------------------------------------------- + +File: ABACUS_util.h + +Purpose: Defines basic math functions. + +***********************************************************/ + +#ifndef ABACUS_UTIL_H +#define ABACUS_UTIL_H + +#include "ABACUS.h" + + +typedef double DP; + +// Global constants + +const double PI = 3.141592653589793238462643; +const double sqrtPI = sqrt(PI); +const double twoPI = 2.0*PI; +const double logtwoPI = log(twoPI); +const double Euler_Mascheroni = 0.577215664901532860606; +const double Gamma_min_0p5 = -2.0 * sqrt(PI); +const std::complex II(0.0,1.0); // Shorthand for i + +const DP MACHINE_EPS = std::numeric_limits::epsilon(); +const DP MACHINE_EPS_SQ = pow(MACHINE_EPS, 2.0); + +// Now for some basic math utilities: + +namespace ABACUS { + + // File checks: + + inline bool file_exists (const char* filename) + { + std::fstream file; + file.open(filename); + bool exists = !file.fail(); + file.close(); + + return(exists); + } + + // Error handler: + + inline void ABACUSerror (const std::string error_text) + // my error handler + { + std::cerr << "Run-time error... " << std::endl; + std::cerr << error_text << std::endl; + std::cerr << "Exiting to system..." << std::endl; + exit(1); + } + + struct Divide_by_zero {}; + + + // Basics: min, max, fabs + + template + inline const T max (const T& a, const T& b) { return a > b ? (a) : (b); } + + template + inline const T min (const T& a, const T& b) { return a > b ? (b) : (a); } + + template + inline const T fabs (const T& a) { return a >= 0 ? (a) : (-a); } + + inline long long int pow_lli (const long long int& base, const int& exp) + { + long long int answer = base; + if (exp == 0) answer = 1LL; + else for (int i = 1; i < exp; ++i) answer *= base; + return(answer); + } + + inline unsigned long long int pow_ulli (const unsigned long long int& base, const int& exp) + { + unsigned long long int answer = base; + if (exp == 0) answer = 1ULL; + for (int i = 1; i < exp; ++i) answer *= base; + return(answer); + } + + inline int fact (const int& N) + { + int ans = 0; + + if (N < 0) { + std::cerr << "Error: factorial of negative number. Exited." << std::endl; + exit(1); + } + else if ( N == 1 || N == 0) ans = 1; + else ans = N * fact(N-1); + + return(ans); + } + + inline DP ln_fact (const int& N) + { + DP ans = 0.0; + + if (N < 0) { + std::cerr << "Error: factorial of negative number. Exited." << std::endl; + exit(1); + } + else if ( N == 1 || N == 0) ans = 0.0; + else ans = log(DP(N)) + ln_fact(N-1); + + return(ans); + } + + inline long long int fact_lli (const int& N) + { + long long int ans = 0; + + if (N < 0) { + std::cerr << "Error: factorial of negative number. Exited." << std::endl; + exit(1); + } + else if ( N == 1 || N == 0) ans = 1; + else ans = fact_lli(N-1) * N; + + return(ans); + } + + inline long long int fact_ulli (const int& N) + { + unsigned long long int ans = 0; + + if (N < 0) { + std::cerr << "Error: factorial of negative number. Exited." << std::endl; + exit(1); + } + else if ( N == 1 || N == 0) ans = 1; + else ans = fact_ulli(N-1) * N; + + return(ans); + } + + inline int choose (const int& N1, const int& N2) + { + // returns N1 choose N2 + + int ans = 0; + if (N1 < N2) { + std::cout << "Error: N1 smaller than N2 in choose. Exited." << std::endl; + exit(1); + } + else if (N1 == N2) ans = 1; + else if (N1 < 12) ans = fact(N1)/(fact(N2) * fact(N1 - N2)); + else { + ans = 1; + int mult = N1; + while (mult > max(N2, N1 - N2)) ans *= mult--; + ans /= fact(min(N2, N1 - N2)); + } + + return(ans); + } + + inline DP ln_choose (const int& N1, const int& N2) + { + // returns the log of N1 choose N2 + + DP ans = 0.0; + if (N1 < N2) { + std::cout << "Error: N1 smaller than N2 in choose. Exited." << std::endl; + exit(1); + } + else if (N1 == N2) ans = 0.0; + else ans = ln_fact(N1) - ln_fact(N2) - ln_fact(N1 - N2); + + return(ans); + } + + + inline long long int choose_lli (const int& N1, const int& N2) + { + // returns N1 choose N2 + + long long int ans = 0; + if (N1 < N2) { + std::cout << "Error: N1 smaller than N2 in choose. Exited." << std::endl; + exit(1); + } + else if (N1 == N2) ans = 1; + else if (N1 < 12) ans = fact_lli(N1)/(fact_lli(N2) * fact_lli(N1 - N2)); + else { + // Make sure that N2 is less than or equal to N1/2; if not, just switch... + int N2_min = min(N2, N1 - N2); + + ans = 1; + for (int i = 0; i < N2_min; ++i) { + ans *= (N1 - i); + ans /= i + 1; + } + } + + return(ans); + } + + inline unsigned long long int choose_ulli (const int& N1, const int& N2) + { + // returns N1 choose N2 + + unsigned long long int ans = 0; + if (N1 < N2) { + std::cout << "Error: N1 smaller than N2 in choose. Exited." << std::endl; + exit(1); + } + else if (N1 == N2) ans = 1; + else if (N1 < 12) ans = fact_ulli(N1)/(fact_ulli(N2) * fact_ulli(N1 - N2)); + else { + // Make sure that N2 is less than or equal to N1/2; if not, just switch... + int N2_min = min(N2, N1 - N2); + + ans = 1; + for (int i = 0; i < N2_min; ++i) { + ans *= (N1 - i); + ans /= i + 1; + } + } + + return(ans); + } + + inline DP SIGN (const DP &a, const DP &b) + { + return b >= 0 ? (a >= 0 ? a : -a) : (a >= 0 ? -a : a); + } + + inline DP sign_of (const DP& a) + { + return (a >= 0.0 ? 1.0 : -1.0); + } + + inline int sgn_int (const int& a) + { + return (a >= 0) ? 1 : -1; + } + + inline int sgn_DP (const DP& a) + { + return (a >= 0) ? 1 : -1; + } + + template + inline void SWAP (T& a, T& b) {T dum = a; a = b; b = dum;} + + inline int kronecker (int a, int b) + { + return a == b ? 1 : 0; + } + + template + inline bool is_nan (const T& a) + { + return(!((a < T(0.0)) || (a >= T(0.0)))); + } + + inline std::complex atan_cx(const std::complex& x) + { + return(-0.5 * II * log((1.0 + II* x)/(1.0 - II* x))); + } + + /**************** Gamma function *******************/ + + inline std::complex ln_Gamma (std::complex z) + { + // Implementation of Lanczos method with g = 9. + // Coefficients from Godfrey 2001. + + if (real(z) < 0.5) return(log(PI/(sin(PI*z))) - ln_Gamma(1.0 - z)); + + else { + + std::complex series = 1.000000000000000174663 + + 5716.400188274341379136/z + - 14815.30426768413909044/(z + 1.0) + + 14291.49277657478554025/(z + 2.0) + - 6348.160217641458813289/(z + 3.0) + + 1301.608286058321874105/(z + 4.0) + - 108.1767053514369634679/(z + 5.0) + + 2.605696505611755827729/(z + 6.0) + - 0.7423452510201416151527e-2 / (z + 7.0) + + 0.5384136432509564062961e-7 / (z + 8.0) + - 0.4023533141268236372067e-8 / (z + 9.0); + + return(0.5 * logtwoPI + (z - 0.5) * log(z + 8.5) - (z + 8.5) + log(series)); + } + + return(log(0.0)); // never called + } + + inline std::complex ln_Gamma_old (std::complex z) + { + // Implementation of Lanczos method with g = 9. + // Coefficients from Godfrey 2001. + + if (real(z) < 0.5) return(log(PI/(sin(PI*z))) - ln_Gamma(1.0 - z)); + + else { + + int g = 9; + + double p[11] = { 1.000000000000000174663, + 5716.400188274341379136, + -14815.30426768413909044, + 14291.49277657478554025, + -6348.160217641458813289, + 1301.608286058321874105, + -108.1767053514369634679, + 2.605696505611755827729, + -0.7423452510201416151527e-2, + 0.5384136432509564062961e-7, + -0.4023533141268236372067e-8 }; + + std::complex z_min_1 = z - 1.0; + std::complex series = p[0]; + for (int i = 1; i < g+2; ++i) + series += p[i]/(z_min_1 + std::complex(i)); + + return(0.5 * logtwoPI + (z_min_1 + 0.5) * log(z_min_1 + std::complex(g) + 0.5) + - (z_min_1 + std::complex(g) + 0.5) + log(series)); + } + + return(log(0.0)); // never called + } + + inline std::complex ln_Gamma_2 (std::complex z) + { + // Implementation of Lanczos method with g = 7. + + if (real(z) < 0.5) return(log(PI/(sin(PI*z)) - ln_Gamma(1.0 - z))); + + else { + + int g = 7; + + double p[9] = { 0.99999999999980993, 676.5203681218851, -1259.1392167224028, + 771.32342877765313, -176.61502916214059, 12.507343278686905, + -0.13857109526572012, 9.9843695780195716e-6, 1.5056327351493116e-7}; + + std::complex z_min_1 = z - 1.0; + std::complex series = p[0]; + for (int i = 1; i < g+2; ++i) + series += p[i]/(z_min_1 + std::complex(i)); + + return(0.5 * logtwoPI + (z_min_1 + 0.5) * log(z_min_1 + std::complex(g) + 0.5) + - (z_min_1 + std::complex(g) + 0.5) + log(series)); + } + + return(log(0.0)); // never called + } + + /********** Partition numbers **********/ + + inline long long int Partition_Function (int n) + { + // Returns the value of the partition function p(n), giving the number of partitions of n into integers. + + if (n < 0) ABACUSerror("Calling Partition_Function for n < 0."); + else if (n == 0 || n == 1) return(1LL); + else if (n == 2) return(2LL); + else if (n == 3) return(3LL); + + else { // do recursion using pentagonal numbers + long long int pn = 0LL; + int pentnrplus, pentnrmin; // pentagonal numbers + for (int i = 1; true; ++i) { + pentnrplus = (i * (3*i - 1))/2; + pentnrmin = (i * (3*i + 1))/2; + if (n - pentnrplus >= 0) pn += (i % 2 ? 1LL : -1LL) * Partition_Function (n - pentnrplus); + if (n - pentnrmin >= 0) pn += (i % 2 ? 1LL : -1LL) * Partition_Function (n - pentnrmin); + else break; + } + return(pn); + } + return(-1LL); // never called + } + + + /********** Sorting **********/ + + template + void QuickSort (T* V, int l, int r) + { + int i = l, j = r; + T pivot = V[l + (r-l)/2]; + + while (i <= j) { + while (V[i] < pivot) i++; + while (V[j] > pivot) j--; + if (i <= j) { + std::swap(V[i],V[j]); + i++; + j--; + } + }; + + if (l < j) QuickSort(V, l, j); + if (i < r) QuickSort(V, i, r); + } + + template + void QuickSort (T* V, int* index, int l, int r) + { + int i = l, j = r; + T pivot = V[l + (r-l)/2]; + + while (i <= j) { + while (V[i] < pivot) i++; + while (V[j] > pivot) j--; + if (i <= j) { + std::swap(V[i],V[j]); + std::swap(index[i],index[j]); + i++; + j--; + } + }; + + if (l < j) QuickSort(V, index, l, j); + if (i < r) QuickSort(V, index, i, r); + } + + +} // namespace ABACUS + +#endif diff --git a/include/JSC_Vect.h b/include/ABACUS_Vect.h similarity index 66% rename from include/JSC_Vect.h rename to include/ABACUS_Vect.h index 10feb46..0dcca73 100644 --- a/include/JSC_Vect.h +++ b/include/ABACUS_Vect.h @@ -2,20 +2,20 @@ This software is part of J.-S. Caux's ABACUS++ library. -Copyright (c) +Copyright (c) J.-S. Caux. ----------------------------------------------------------- -File: JSC_Vect.h +File: ABACUS_Vect.h Purpose: Declares vector class. ***********************************************************/ -#ifndef _JSC_VECT_ -#define _JSC_VECT_ +#ifndef ABACUS_VECT_H +#define ABACUS_VECT_H -namespace JSC { +namespace ABACUS { template class Vect { @@ -32,7 +32,7 @@ namespace JSC { Vect& operator= (const T& a); // assign a to all elements inline T& operator[] (const int i); inline const T& operator[] (const int i) const; - Vect& operator+= (const Vect& rhs); + Vect& operator+= (const Vect& rhs); Vect& operator-= (const Vect& rhs); bool operator== (const Vect& rhs); // checks equality of size and of all elements bool operator!= (const Vect& rhs); // checks inequality @@ -52,31 +52,31 @@ namespace JSC { void QuickSort (Vect& index); ~Vect(); }; - + template Vect::Vect() : dim(0), V(0) {} - + template Vect::Vect (int N) : dim(N), V(new T[N]) {} - + template Vect::Vect (const T& a, int N) : dim(N), V(new T[N]) - { - for (int i = 0; i < N; ++i) V[i] = a; - } - + { + for (int i = 0; i < N; ++i) V[i] = a; + } + template Vect::Vect (const T* a, int N) : dim(N), V(new T[N]) - { - for (int i = 0; i < N; ++i) V[i] = *a++; - } - + { + for (int i = 0; i < N; ++i) V[i] = *a++; + } + template Vect::Vect (const Vect& rhs) : dim(rhs.dim), V(new T[dim]) - { - for (int i = 0; i < dim; ++i) V[i] = rhs[i]; - } - + { + for (int i = 0; i < dim; ++i) V[i] = rhs[i]; + } + template Vect& Vect::operator= (const Vect& rhs) { @@ -90,7 +90,7 @@ namespace JSC { } return *this; } - + template Vect& Vect::operator= (const T& a) { @@ -100,15 +100,15 @@ namespace JSC { template inline T& Vect::operator[] (const int i) - { - return V[i]; - } - + { + return V[i]; + } + template inline const T& Vect::operator[] (const int i) const - { - return V[i]; - } + { + return V[i]; + } template Vect& Vect::operator+= (const Vect& rhs) @@ -116,7 +116,7 @@ namespace JSC { for (int i = 0; i < dim; ++i) V[i] += rhs[i]; return *this; } - + template Vect& Vect::operator-= (const Vect& rhs) { @@ -138,7 +138,7 @@ namespace JSC { bool Vect::operator!= (const Vect& rhs) { return(!((*this) == rhs)); - } + } template bool Vect::Append (const Vect& rhs) // appends rhs to the vector @@ -180,7 +180,7 @@ namespace JSC { int resized_dim = dim + nr_to_add; T* resized_vect = new T[resized_dim]; - for (int i = 0; i < dim; ++i) resized_vect[i] = V[i]; + for (int i = 0; i < dim; ++i) resized_vect[i] = V[i]; for (int i = dim; i < resized_dim; ++i) resized_vect[i] = T(0); dim = resized_dim; @@ -199,7 +199,7 @@ namespace JSC { int resized_dim = dim + nr_to_add; T* resized_vect = new T[resized_dim]; - for (int i = 0; i < dim; ++i) resized_vect[i] = V[i]; + for (int i = 0; i < dim; ++i) resized_vect[i] = V[i]; for (int i = dim; i < resized_dim; ++i) resized_vect[i] = setval; dim = resized_dim; @@ -215,12 +215,12 @@ namespace JSC { template inline int Vect::size() const - { - return dim; - } + { + return dim; + } template - inline double Vect::norm () const + inline double Vect::norm () const { double normsq = 0.0; for (int i = 0; i < dim; ++i) normsq += abs(V[i]) * abs(V[i]); @@ -228,7 +228,7 @@ namespace JSC { } template <> - inline double Vect::norm () const + inline double Vect::norm () const { double normsq = 0.0; for (int i = 0; i < dim; ++i) normsq += V[i] * V[i]; @@ -236,7 +236,7 @@ namespace JSC { } template <> - inline double Vect >::norm () const + inline double Vect >::norm () const { double normsq = 0.0; for (int i = 0; i < dim; ++i) normsq += std::norm(V[i]); @@ -262,7 +262,7 @@ namespace JSC { template inline T Vect::sum() const { - T total = T(0); + T total = T(0); for (int i = 0; i < dim; ++i) total += V[i]; return total; } @@ -275,69 +275,13 @@ namespace JSC { return(index < dim); } - /* - template - void Vect::QuickSort (int l, int r) - { - //cout << "QuickSort called for l = " << l << "\t r = " << r << endl; - //cout << (*this) << endl; - //for (int ih = l; ih <= r; ++ih) cout << setprecision(16) << "ih = " << ih << "\tV[ih] = " << V[ih] << endl; - - static T m; - static int j; - int i; - - if (r > l) { - m = V[r]; i = l-1; j = r; - - for (;;) { - while (V[++i] < m); - while (V[--j] > m); - if (i >= j) break; - std::swap(V[i], V[j]); - } - std::swap(V[i], V[r]); - - (*this).QuickSort(l, i-1); - (*this).QuickSort(i+1, r); - } - } - */ - /* - template - void Vect::QuickSort (int l, int r) - { - // My own version of QuickSort: add sentinels on left and right - if (r > l) { - int s = l + (r-l)/2; // central element index - // Rearrange so that V[l] <= V[s] <= V[r] (sentinels on left and right) - if (V[l] > V[r]) std::swap(V[l],V[r]); - if (V[s] > V[r]) std::swap(V[s],V[r]); - if (V[l] > V[s]) std::swap(V[l],V[s]); - m = V[s]; i = l-1; j = r; - //m = V[r]; i = l-1; j = r; - - for (;;) { - while (V[i] < m) i++; - while (V[j] > m) j--; - if (i >= j) break; - std::swap(V[i], V[j]); // restart from indices i and j just used, in case one is pivot - } - //std::swap(V[i], V[r]); - - (*this).QuickSort(l, i-1); - (*this).QuickSort(i+1, r); - } - - } - */ template void Vect::QuickSort (int l, int r) { int i = l, j = r; T pivot = V[l + (r-l)/2]; - + while (i <= j) { while (V[i] < pivot) i++; while (V[j] > pivot) j--; @@ -347,7 +291,7 @@ namespace JSC { j--; } }; - + if (l < j) (*this).QuickSort(l, j); if (i < r) (*this).QuickSort(i, r); } @@ -358,71 +302,12 @@ namespace JSC { if ((*this).size() > 1) (*this).QuickSort (0, (*this).size() - 1); } - /* - template - void Vect::QuickSort (Vect& index, int l, int r) - { - if (index.size() != (*this).size()) { - cout << (*this).size() << "\t" << index.size() << endl; - JSCerror("Wrong dim for index in Vect QuickSort."); - } - - static T m; - static int j; - int i; - - if (r > l) { - m = V[r]; i = l-1; j = r; - - for (;;) { - while (V[++i] < m); - while (V[--j] > m); - if (i >= j) break; - std::swap(V[i], V[j]); - std::swap(index[i], index[j]); - } - std::swap(V[i], V[r]); - std::swap(index[i], index[r]); - - (*this).QuickSort(index, l, i-1); - (*this).QuickSort(index, i+1, r); - } - } - */ - /* - template - void Vect::QuickSort (Vect& index, int l, int r) - { - // My own version of QuickSort: - if (r > l) { - int s = l + (r-l)/2; // central element index - // Rearrange so that V[l] <= V[s] <= V[r] (sentinels on left and right) - if (V[l] > V[r]) std::swap(V[l],V[r]); - if (V[s] > V[r]) std::swap(V[s],V[r]); - if (V[l] > V[s]) std::swap(V[l],V[s]); - m = V[s]; i = l-1; j = r+1; - - for (;;) { - while (V[++i] < m); - while (V[--j] > m); - if (i >= j) break; - std::swap(index[i], index[j]); - std::swap(V[i--], V[j++]); // restart from indices i and j just used, in case one is pivot - } - - (*this).QuickSort(index, l, i-1); - (*this).QuickSort(index, i+1, r); - } - - } - */ - template void Vect::QuickSort (Vect& index, int l, int r) { int i = l, j = r; T pivot = V[l + (r-l)/2]; - + while (i <= j) { while (V[i] < pivot) i++; while (V[j] > pivot) j--; @@ -433,7 +318,7 @@ namespace JSC { j--; } }; - + if (l < j) (*this).QuickSort(index, l, j); if (i < r) (*this).QuickSort(index, i, r); } @@ -441,32 +326,32 @@ namespace JSC { template void Vect::QuickSort (Vect& index) { - if (index.size() != (*this).size()) JSCerror("Wrong dim for index in Vect QuickSort."); + if (index.size() != (*this).size()) ABACUSerror("Wrong dim for index in Vect QuickSort."); (*this).QuickSort (index, 0, (*this).size() - 1); } template - inline std::ostream& operator<< (std::ostream& s, const Vect& vector) - { - for (int i = 0; i < vector.size() - 1; ++i) s << vector[i] << " "; - if (vector.size() >= 1) s << vector[vector.size() - 1]; + inline std::ostream& operator<< (std::ostream& s, const Vect& vector) + { + for (int i = 0; i < vector.size() - 1; ++i) s << vector[i] << " "; + if (vector.size() >= 1) s << vector[vector.size() - 1]; - return (s); - } + return (s); + } template Vect::~Vect() - { - if (V != 0) delete[] V; - } + { + if (V != 0) delete[] V; + } - // TYPEDEFS - typedef JSC::Vect Vect_INT; - typedef JSC::Vect Vect_DP; - typedef JSC::Vect > Vect_CX; + // TYPEDEFS + typedef ABACUS::Vect Vect_INT; + typedef ABACUS::Vect Vect_DP; + typedef ABACUS::Vect > Vect_CX; - -} // namespace JSC + +} // namespace ABACUS #endif diff --git a/include/JSC_XXX_h0.h b/include/ABACUS_XXX_VOA.h similarity index 73% rename from include/JSC_XXX_h0.h rename to include/ABACUS_XXX_VOA.h index 020dd88..34cc304 100644 --- a/include/JSC_XXX_h0.h +++ b/include/ABACUS_XXX_VOA.h @@ -2,56 +2,58 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- -File: JSC_XXX_h0.h - -Purpose: Declares classes for XXX in zero field: Uq(sl(2)) stuff. +File: ABACUS_XXX_VOA.h +Purpose: Declares classes for XXX in zero field: Vertex Operator Approach ***********************************************************/ -#ifndef _XXX_h0_ -#define _XXX_h0_ +#ifndef ABACUS_XXX_VOA_H +#define ABACUS_XXX_VOA_H -#include "JSC.h" +#include "ABACUS.h" const DP default_req_prec = 1.0e-14; const int default_max_rec = 10; -namespace JSC { +namespace ABACUS { inline DP Integrand_11 (Vect_DP args) - { - // args[0] corresponds to t, args[1] to rho - return((exp(args[0]) * sinh(args[0]) * cos(4.0 * args[0] * args[1])/(2.0 * pow(cosh(args[0]), 2.0)) + 2.0 * pow(sin(2.0 * args[0] * args[1]), 2.0))/args[0]); - } - + { + // args[0] corresponds to t, args[1] to rho + return((exp(args[0]) * sinh(args[0]) * cos(4.0 * args[0] * args[1]) + /(2.0 * pow(cosh(args[0]), 2.0)) + 2.0 * pow(sin(2.0 * args[0] * args[1]), 2.0))/args[0]); + } + inline DP Integrand_12 (Vect_DP args) - { - DP expm2t = exp(-2.0*args[0]); - return(cos(4.0 * args[0] * args[1]) * expm2t * (3.0 + expm2t)/ (args[0] * (1.0 + expm2t) * (1.0 + expm2t))); - } - + { + DP expm2t = exp(-2.0*args[0]); + return(cos(4.0 * args[0] * args[1]) * expm2t * (3.0 + expm2t)/ (args[0] * (1.0 + expm2t) * (1.0 + expm2t))); + } + inline DP Integrand_2 (Vect_DP args) - { - DP answer = 0.0; - if (args[0] < 1.0) answer = exp(args[0]) * pow(sin(2.0 * args[0] * args[1]), 2.0)/(args[0] * sinh(args[0]) * pow(cosh(args[0]), 2.0)); - else if (args[0] >= 1.0) { - DP expm2t = exp(-2.0 * args[0]); - answer = 8.0 * expm2t * pow(sin(2.0 * args[0] * args[1]), 2.0)/(args[0] * (1.0 - expm2t) * (1.0 + expm2t) * (1.0 + expm2t)); - } - return(answer); + { + DP answer = 0.0; + if (args[0] < 1.0) answer = exp(args[0]) * pow(sin(2.0 * args[0] * args[1]), 2.0) + /(args[0] * sinh(args[0]) * pow(cosh(args[0]), 2.0)); + else if (args[0] >= 1.0) { + DP expm2t = exp(-2.0 * args[0]); + answer = 8.0 * expm2t * pow(sin(2.0 * args[0] * args[1]), 2.0) + /(args[0] * (1.0 - expm2t) * (1.0 + expm2t) * (1.0 + expm2t)); } - + return(answer); + } + inline DP Integrand_A (Vect_DP args) - { - // This kernel is for -ln | A_-(i\pi/2) | function - return(exp(args[0]) * pow(sinh(args[0]/2.0), 2.0)/(args[0] * sinh(2.0*args[0]) * cosh(args[0]))); - } - + { + // This kernel is for -ln | A_-(i\pi/2) | function + return(exp(args[0]) * pow(sinh(args[0]/2.0), 2.0)/(args[0] * sinh(2.0*args[0]) * cosh(args[0]))); + } + DP I_integral (DP rho, DP req_prec); @@ -73,32 +75,32 @@ namespace JSC { DP SF_2p_check_fixed_k_sumrule_opt (DP k, DP req_prec, int Npts, I_table Itable); -/********************** FOUR SPINONS **********************/ + /********************** FOUR SPINONS **********************/ DP Sum_norm_gl (Vect_DP rho, DP req_prec); DP Compute_C4 (DP req_prec); DP SF_contrib (Vect_DP p, DP req_prec, I_table Itable); DP J_fn (Vect_DP p, DP req_prec, I_table Itable); inline DP Jacobian_p3p4_KW (DP k, DP w, DP K, DP W) - { - return(1.0/sqrt(pow(twoPI * sin(0.5 * (k - K)), 2.0) - (w-W)*(w-W))); - } + { + return(1.0/sqrt(pow(twoPI * sin(0.5 * (k - K)), 2.0) - (w-W)*(w-W))); + } bool Set_p_given_kwKW (DP k, DP w, DP K, DP W, Vect_DP& p); inline DP wmin_4p (DP k) { return(PI * fabs(sin(k))); - } + } inline DP wmax_4p (DP k) { return(2.0 * PI * sqrt(2.0 * (1.0 + fabs(cos(0.5*k))))); } inline DP Wmin (DP k, DP w, DP K) { - return(JSC::max(1.0e-15, JSC::max(fabs(PI * sin(K)), w - twoPI * sin(0.5 * (fabs(k-K)))))); + return(ABACUS::max(1.0e-15, ABACUS::max(fabs(PI * sin(K)), w - twoPI * sin(0.5 * (fabs(k-K)))))); } inline DP Wmax (DP k, DP w, DP K) { - return(JSC::min(twoPI * sin(0.5 * K), w - fabs(PI * sin(k - K)))); + return(ABACUS::min(twoPI * sin(0.5 * K), w - fabs(PI * sin(k - K)))); } DP G_fn (Vect_DP args_to_G, I_table Itable); DP G1_fn (Vect_DP args_to_G, I_table Itable); @@ -134,6 +136,6 @@ namespace JSC { DP Direct_J_integral_bin (int Npts_p, int Npts_o, DP req_prec, I_table Itable); void Smoothen_raw_SF_4p (int Npts_p, int Npts_o, DP req_prec, DP width); -} // namespace JSC +} // namespace ABACUS #endif diff --git a/include/ABACUS_XXZ_VOA.h b/include/ABACUS_XXZ_VOA.h new file mode 100644 index 0000000..c708d5e --- /dev/null +++ b/include/ABACUS_XXZ_VOA.h @@ -0,0 +1,47 @@ +/********************************************************** + +This software is part of J.-S. Caux's ABACUS library. + +Copyright (c) J.-S. Caux. + +----------------------------------------------------------- + +File: ABACUS_XXZ_VOA.h + +Purpose: Declares classes for XXZ in zero field: Vertex Operator Approach + +***********************************************************/ + +#ifndef ABACUS_XXZ_VOA_H +#define ABACUS_XXZ_VOA_H + +#include "ABACUS.h" + + +namespace ABACUS { + + DP I_xi_integral (DP xi, DP rho, DP req_prec, int max_nr_pts); + + /********************* TWO SPINONS ********************/ + DP Szz_XXZ_h0_2spinons (DP k, DP omega, Integral_table Itable); + DP Szz_XXZ_h0_2spinons (Vect_DP args, Integral_table Itable); + DP Szz_XXZ_h0_2spinons_alt (Vect_DP args, Integral_table Itable); + DP Szz_XXZ_h0_2spinons_omega (Vect_DP args, Integral_table Itable); + DP Szz_XXZ_h0_2spinons_omega_alt (Vect_DP args, Integral_table Itable); + DP Szz_XXZ_h0_2spinons_intomega (Vect_DP args, Integral_table Itable); + DP Szz_XXZ_h0_2spinons_intomega_alt (Vect_DP args, Integral_table Itable); + DP Szz_XXZ_h0_2spinons_check_sumrule (DP Delta, DP req_prec, int max_nr_pts, Integral_table Itable); + DP Szz_XXZ_h0_2spinons_check_sumrule_alt (DP Delta, DP req_prec, int max_nr_pts, Integral_table Itable); + DP Fixed_k_sumrule_omega_Szz_XXZ_h0_N (DP Delta, DP k); + DP GSE_XXZ_h0 (DP Delta, DP req_prec, int max_nr_pts); + DP Fixed_k_sumrule_omega_Szz_XXZ_h0 (DP Delta, DP k, DP req_prec, int max_nr_pts); + DP Szz_XXZ_h0_2spinons_check_fixed_k_Szz_sumrule (DP Delta, DP k, DP req_prec, int max_nr_pts, Integral_table Itable); + DP Szz_XXZ_h0_2spinons_check_fixed_k_Szz_sumrule_alt (DP Delta, DP k, DP req_prec, int max_nr_pts, Integral_table Itable); + + //******************************** Functions to produce files similar to ABACUS ********************************** + void Produce_Szz_XXZ_h0_2spinons_file (DP Delta, int N, int Nomega, DP omegamax, Integral_table Itable); + void Produce_Szz_XXZ_h0_2spinons_fixed_K_file (DP Delta, DP Kover2PI, int Nomega, Integral_table Itable); + +} // namespace ABACUS + +#endif diff --git a/include/JSC_Young.h b/include/ABACUS_Young.h similarity index 93% rename from include/JSC_Young.h rename to include/ABACUS_Young.h index e50abf8..be7d1b0 100644 --- a/include/JSC_Young.h +++ b/include/ABACUS_Young.h @@ -2,22 +2,22 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- -File: JSC_Young.h +File: ABACUS_Young.h Purpose: Declares Young tableau class. ***********************************************************/ -#ifndef _YOUNG_ -#define _YOUNG_ +#ifndef ABACUS_YOUNG_H +#define ABACUS_YOUNG_H -#include "JSC_Vect.h" +#include "ABACUS_Vect.h" -namespace JSC { +namespace ABACUS { const int YOUNG_TABLEAU_ID_OPTION = 0; const long long int TABLEAU_ID_UPPER_LIMIT = 10000000LL; @@ -32,7 +32,7 @@ namespace JSC { int* Row_L; int* Col_L; long long int id; // identification number - long long int maxid; + long long int maxid; long long int* map; bool map_computed; long long int idnr_reached; @@ -59,11 +59,11 @@ namespace JSC { Young_Tableau& Set_Row_L (Vect& Row_Lengths); // set row lengths Young_Tableau& Set_Col_L_given_Row_L (); // sets the Col_L array self-consistently Young_Tableau& Set_Row_L_given_Col_L (); // sets the Col_L array self-consistently - long long int Compute_Descendent_id (int option, Vect& Desc_Row_L, int Nrows_Desc, int Ncols_Desc, + long long int Compute_Descendent_id (int option, Vect& Desc_Row_L, int Nrows_Desc, int Ncols_Desc, const Young_Tableau& RefTableau); Young_Tableau& Compute_id(); // computes the id number of tableau Young_Tableau& Compute_id(int option); // computes the id number of tableau according to rule option - Young_Tableau& Print(); // couts the tableau + Young_Tableau& Print(); // couts the tableau bool Lower_Row (int i); bool Raise_Row (int i); @@ -104,15 +104,15 @@ namespace JSC { Vect map; long long int idnr_reached; int nboxes_reached; - + public: Tableau_Map (int Nrows, int Ncols); void Distribute_id (int nboxes_to_dist, int level, Young_Tableau& RefTableau); - + }; -} // namespace JSC +} // namespace ABACUS #endif diff --git a/include/JSC_Heis.h b/include/JSC_Heis.h deleted file mode 100644 index 15c604f..0000000 --- a/include/JSC_Heis.h +++ /dev/null @@ -1,777 +0,0 @@ -/********************************************************** - -This software is part of J.-S. Caux's ABACUS++ library. - -Copyright (c) - ------------------------------------------------------------ - -File: Heis.h - -Purpose: Declares Heisenberg chain classes and functions. - - - -***********************************************************/ - -#ifndef _HEIS_ -#define _HEIS_ - -#include "JSC.h" - -namespace JSC { - - // First, some global constants... - - const long long int ID_UPPER_LIMIT = 10000000LL; // max size of vectors we can define without seg fault - const int INTERVALS_SIZE = 100000; // size of Scan_Intervals arrays - const int NBASESMAX = 1000; // max number of bases kept - - const DP ITER_REQ_PREC = 100.0 * MACHINE_EPS_SQ; - //const DP ITER_REQ_PREC = MACHINE_EPS_SQ; - - // Cutoffs on particle numbers - //const int NPARTICLES_MAX = 24; - //const int NHOLES_MAX = NPARTICLES_MAX/2; - //const int MAX_RAPS_ABOVE_ZERO = 10; // max nr of rapidities above lowest type - //const int NPARTICLES_MAX = 2; - //const int NHOLES_MAX = 1; - //const int MAX_TYPES_IN_BASE = 4; // maximal number of particle types we allow in bases - const int MAXSTRINGS = 20; // maximal number of particle types we allow in bases - //const int MAXSTRINGS = 2; // maximal number of particle types we allow in bases - //const DP HEIS_deltaprec = 1.0e-6;//1.0e-4; // maximal string deviation allowed // DEPRECATED in ++T_9 - - const int NEXC_MAX_HEIS = 16; // maximal number of excitations (string binding/unbinding, particle-hole) considered - - //*********************************************************************** - - class Heis_Chain { - - public: - DP J; - DP Delta; - DP anis; // acos(Delta) if Delta < 1.0, 0 if Delta == 1.0, acosh(Delta) if Delta > 1.0 - DP hz; - int Nsites; - int Nstrings; // how many possible strings. The following two arrays have Nstrings nonzero elements. - int* Str_L; // vector (length M) containing the allowed string lengths. Elements that are 0 have no meaning. - int* par; // vector (length M) containing the parities of the strings. Elements that are 0 have no meaning. - // Parities are all +1 except for gapless XXZ subcases - DP* si_n_anis_over_2; // for optimization: sin for XXZ, sinh for XXZ_gpd - DP* co_n_anis_over_2; // for optimization - DP* ta_n_anis_over_2; // for optimization - DP prec; // precision required for computations, always put to ITER_REQ_PREC - - public: - Heis_Chain (); - Heis_Chain (DP JJ, DP DD, DP hh, int NN); // contructor: simply initializes - Heis_Chain (const Heis_Chain& RefChain); // copy constructor; - Heis_Chain& operator= (const Heis_Chain& RefChain); - bool operator== (const Heis_Chain& RefChain); - bool operator!= (const Heis_Chain& RefChain); - ~Heis_Chain(); // destructor - - public: - //void Scan_for_Possible_Bases (int Mdown, Vect& possible_base_id, int& nfound, int nexc_max_used, - // int base_level_to_scan, Vect& Nrapidities); - //Vect Possible_Bases (int Mdown); // returns a vector of possible bases - /* Deactivated in ++G_8 - void Scan_for_Possible_Bases (int Mdown, Vect& possible_base_label, int& nfound, int nexc_max_used, - int base_level_to_scan, Vect& Nrapidities); - Vect Possible_Bases (int Mdown); // returns a vector of possible bases - */ - }; - - //**************************************************************************** - - // Objects in class Heis_Base are a checked vector containing the number of rapidities of allowable types for a given state - - class Heis_Base { - - public: - int Mdown; // total number of down spins - Vect Nrap; // Nrap[i] contains the number of rapidities of type i, i = 0, Nstrings - 1. - int Nraptot; // total number of strings in this state - Vect Ix2_infty; // Ix2_infty[i] contains the max of BAE function for the (half-)integer I[i], i = 0, Nstrings - 1. - Vect Ix2_min; - Vect Ix2_max; // Ix2_max[i] contains the integer part of 2*I_infty, with correct parity for base. - //long long int id; // identification number - double dimH; // dimension of sub Hilbert space associated to this base; use double to avoid max int problems. - string baselabel; // base label - - public: - Heis_Base (); - Heis_Base (const Heis_Base& RefBase); // copy constructor - Heis_Base (const Heis_Chain& RefChain, int M); // constructs configuration with all Mdown in one-string of +1 parity - Heis_Base (const Heis_Chain& RefChain, const Vect& Nrapidities); // sets to Nrapidities vector, and checks consistency - //Heis_Base (const Heis_Chain& RefChain, long long int id_ref); - Heis_Base (const Heis_Chain& RefChain, string baselabel_ref); - inline int& operator[] (const int i); - inline const int& operator[] (const int i) const; - Heis_Base& operator= (const Heis_Base& RefBase); - bool operator== (const Heis_Base& RefBase); - bool operator!= (const Heis_Base& RefBase); - - void Compute_Ix2_limits(const Heis_Chain& RefChain); // computes the Ix2_infty and Ix2_max - - //void Scan_for_Possible_Types (Vect& possible_type_id, int& nfound, int base_level, Vect& Nexcitations); - //Vect Possible_Types (); // returns a vector of possible types - - }; - - inline int& Heis_Base::operator[] (const int i) - { - return Nrap[i]; - } - - inline const int& Heis_Base::operator[] (const int i) const - { - return Nrap[i]; - } - - //**************************************************************************** - /* - // Objects in class Ix2_Config carry all the I's of a given state - - class Ix2_Config { - - //private: - public: - int Nstrings; - Vect Nrap; - int Nraptot; - - //int** Ix2; - Vect > Ix2; - - public: - Ix2_Config (); - Ix2_Config (const Heis_Chain& RefChain, int M); // constructor, puts I's to ground state - Ix2_Config (const Heis_Chain& RefChain, const Heis_Base& base); // constructor, putting I's to lowest-energy config - // consistent with Heis_Base configuration for chain RefChain - Ix2_Config& operator= (const Ix2_Config& RefConfig); - //inline int* operator[] (const int i); - inline Vect operator[] (const int i); - //inline const int* operator[] (const int i) const; - inline const Vect operator[] (const int i) const; - //~Ix2_Config(); // not needed, inherited from Vect - string Return_Label (const Ix2_Config& OriginIx2); - }; - - //inline int* Ix2_Config::operator[] (const int i) - inline Vect Ix2_Config::operator[] (const int i) - { - return Ix2[i]; - } - - //inline const int* Ix2_Config::operator[] (const int i) const - inline const Vect Ix2_Config::operator[] (const int i) const - { - return Ix2[i]; - } - - std::ostream& operator<< (std::ostream& s, const Ix2_Config& RefConfig); - */ - //**************************************************************************** - - // Objects in class Lambda carry all rapidities of a state - - class Lambda { - - private: - int Nstrings; - Vect Nrap; - int Nraptot; - DP** lambda; - //Vect > lambda; - - public: - Lambda (); - Lambda (const Heis_Chain& RefChain, int M); // constructor, puts all lambda's to zero - Lambda (const Heis_Chain& RefChain, const Heis_Base& base); // constructor, putting I's to lowest-energy config - // consistent with Heis_Base configuration for chain RefChain - Lambda& operator= (const Lambda& RefConfig); - inline DP* operator[] (const int i); - //inline Vect operator[] (const int i); - inline const DP* operator[] (const int i) const; - //inline const Vect operator[] (const int i) const; - ~Lambda(); - - }; - - inline DP* Lambda::operator[] (const int i) - //inline Vect Lambda::operator[] (const int i) - { - return lambda[i]; - } - - inline const DP* Lambda::operator[] (const int i) const - //inline const Vect Lambda::operator[] (const int i) const - { - return lambda[i]; - } - - - //**************************************************************************** - - // Objects in class Ix2_Offsets carry Young tableau representations of the Ix2 configurations - /* - class Ix2_Offsets { - - public: - Heis_Base base; - Vect Tableau; // vector of pointers to tableaux at each level - long long int type_id; - long long int id; // id number of offset - long long int maxid; // max id number allowable - - public: - Ix2_Offsets (); - Ix2_Offsets (const Ix2_Offsets& RefOffset); // copy constructor - Ix2_Offsets (const Heis_Base& RefBase, long long int req_type_id); - Ix2_Offsets (const Heis_Base& RefBase, Vect nparticles); // sets all tableaux to empty ones, with nparticles[] at each level - Ix2_Offsets& operator= (const Ix2_Offsets& RefOffset); - bool operator<= (const Ix2_Offsets& RefOffsets); - bool operator>= (const Ix2_Offsets& RefOffsets); - - public: - void Set_to_id (long long int idnr); - void Compute_id (); - void Compute_type_id (); - - public: - bool Add_Boxes_From_Lowest (int Nboxes, bool odd_sectors); // adds Nboxes in minimal energy config, all boxes in either even or odd sectors - - }; - - inline long long int Ix2_Offsets_type_id (Vect& nparticles) - { - long long int type_id_here = 0ULL; - - for (int i = 0; i < nparticles.size(); ++i) - type_id_here += nparticles[i] * pow_ulli(10ULL, i); - - return(type_id_here); - } - - long long int Find_idmin (Ix2_Offsets& scan_offsets, int particle_type, int tableau_level, int Row_L_min); - long long int Find_idmax (Ix2_Offsets& scan_offsets, int particle_type, int tableau_level); - */ - //**************************************************************************** - // Objects in class Ix2_Offsets_List carry a vector of used Ix2_Offsets - /* - class Ix2_Offsets_List { - - public: - int ndef; - Vect Offsets; - - public: - Ix2_Offsets_List (); - Ix2_Offsets& Return_Offsets (Heis_Base& RefBase, Vect nparticles); // returns the Ix2_Offsets corresponding to nparticles[]/base - Ix2_Offsets& Return_Offsets (Heis_Base& RefBase, long long int req_type_id); - }; - */ - //**************************************************************************** - - // Objects in class Heis_Bethe_State carry all information about an eigenstate - - // Derived classes include XXZ_Bethe_State, XXX_Bethe_State, XXZ_gpd_Bethe_State - // These contain subclass-specific functions and data. - - class Heis_Bethe_State { - - public: - Heis_Chain chain; - Heis_Base base; - //Ix2_Offsets offsets; - //Ix2_Config Ix2; - Vect > Ix2; - Lambda lambda; - Lambda deviation; // string deviations - Lambda BE; // Bethe equation for relevant rapidity, in the form BE = theta - (1/N)\sum ... - \pi I/N = 0 - DP diffsq; // sum of squares of rapidity differences in last iteration - int conv; // convergence status - DP dev; // sum of absolute values of string deviations - int iter; // number of iterations necessary for convergence - int iter_Newton; // number of iterations necessary for convergence (Newton method) - DP E; // total energy - int iK; // K = 2.0*PI * iK/Nsites - DP K; // total momentum - DP lnnorm; // ln of norm of reduced Gaudin matrix - //long long int base_id; - //long long int type_id; - //long long int id; - //long long int maxid; - //int nparticles; - string label; - - public: - Heis_Bethe_State (); - Heis_Bethe_State (const Heis_Bethe_State& RefState); // copy constructor - //Heis_Bethe_State (const Heis_Bethe_State& RefState, long long int type_id_ref); // new state with requested type_id - Heis_Bethe_State (const Heis_Chain& RefChain, int M); // constructor to ground-state configuration - Heis_Bethe_State (const Heis_Chain& RefChain, const Heis_Base& base); // constructor to lowest-energy config with base - //Heis_Bethe_State (const Heis_Chain& RefChain, long long int base_id_ref, long long int type_id_ref); - virtual ~Heis_Bethe_State () {}; - - public: - int Charge () { return(base.Mdown); }; - //void Set_Ix2_Offsets (const Ix2_Offsets& RefOffset); // sets the Ix2 to given offsets - //void Set_to_id (long long int id_ref); - //void Set_to_id (long long int id_ref, Heis_Bethe_State& RefState); - //int Nparticles (); // counts the number of particles in state once Ix2 offsets set (so type_id is correctly set) - //void Set_to_Label (string label_ref, const Ix2_Config& OriginIx2); - void Set_to_Label (string label_ref, const Vect >& OriginIx2); - void Set_Label_from_Ix2 (const Vect >& OriginIx2); - bool Check_Symmetry (); // checks whether the I's are symmetrically distributed - void Compute_diffsq (); // \sum BE[j][alpha]^2 - void Find_Rapidities (bool reset_rapidities); // Finds the rapidities - void Find_Rapidities_Twisted (bool reset_rapidities, DP twist); // Finds the rapidities with twist added to RHS of logBE - //void BAE_smackdown (DP max_allowed); - //void Solve_BAE_smackdown (DP max_allowed, int maxruns); - void Solve_BAE_bisect (int j, int alpha, DP req_prec, int itermax); - void Iterate_BAE (DP iter_factor); // Finds new set of lambda[j][alpha] from previous one by simple iteration - void Solve_BAE_straight_iter (DP straight_prec, int max_iter_interp, DP iter_factor); - void Solve_BAE_extrap (DP extrap_prec, int max_iter_extrap, DP iter_factor); - void Iterate_BAE_Newton (); // Finds new set of lambda[j][alpha] from previous one by a Newton step - void Solve_BAE_Newton (DP Newton_prec, int max_iter_Newton); - void Solve_BAE_with_silk_gloves (DP silk_prec, int max_iter_silk, DP iter_factor); - void Compute_lnnorm (); - void Compute_Momentum (); - void Compute_All (bool reset_rapidities); // solves BAE, computes E, K and lnnorm - - inline bool Set_to_Inner_Skeleton (int iKneeded, const Vect >& OriginStateIx2) - { - Ix2[0][0] = Ix2[0][1] - 2; - Ix2[0][base.Nrap[0] - 1] = Ix2[0][base.Nrap[0] - 2] + 2; - (*this).Compute_Momentum(); - if (base.Nrap[0] == 0) return(false); - if (iKneeded >= iK) Ix2[0][base.Nrap[0]-1] += 2*(iKneeded - iK); - else Ix2[0][0] += 2*(iKneeded - iK); - if (Ix2[0][0] < base.Ix2_min[0] || Ix2[0][base.Nrap[0]-1] > base.Ix2_max[0]) return(false); - (*this).Set_Label_from_Ix2 (OriginStateIx2); - return(true); - } - void Set_to_Outer_Skeleton (const Vect >& OriginStateIx2) { - Ix2[0][0] = base.Ix2_min[0] - 4; - Ix2[0][base.Nrap[0]-1] = base.Ix2_max[0] + 4; - (*this).Set_Label_from_Ix2 (OriginStateIx2); - }; - - void Set_to_Closest_Matching_Ix2_fixed_Base (const Heis_Bethe_State& StateToMatch); // defined in Heis.cc - - - // Virtual functions, all defined in the derived classes - - public: - virtual void Set_Free_lambdas() { JSCerror("Heis_Bethe_State::..."); } // sets the rapidities to solutions of BAEs without scattering terms - virtual bool Check_Admissibility(char option) { JSCerror("Heis_Bethe_State::..."); return(false); } - // verifies that we don't have a symmetrical Ix2 config with a Ix2 == 0 for a string of even length >= 2. - virtual void Compute_BE (int j, int alpha) { JSCerror("Heis_Bethe_State::..."); } - virtual void Compute_BE () { JSCerror("Heis_Bethe_State::..."); } - virtual DP Iterate_BAE(int i, int alpha) { JSCerror("Heis_Bethe_State::..."); return(0.0);} - virtual bool Check_Rapidities() { JSCerror("Heis_Bethe_State::..."); return(false); } - virtual DP String_delta () { JSCerror("Heis_Bethe_State::..."); return(0.0); } - virtual void Compute_Energy () { JSCerror("Heis_Bethe_State::..."); } - virtual void Build_Reduced_Gaudin_Matrix (SQMat >& Gaudin_Red) { JSCerror("Heis_Bethe_State::..."); } - }; - - inline bool Is_Inner_Skeleton (Heis_Bethe_State& State) { - return (State.base.Nrap[0] >= 2 && (State.Ix2[0][0] == State.Ix2[0][1] - 2 || State.Ix2[0][State.base.Nrap[0]-1] == State.Ix2[0][State.base.Nrap[0]-2] + 2)); - }; - inline bool Is_Outer_Skeleton (Heis_Bethe_State& State) { - return (State.Ix2[0][0] == State.base.Ix2_min[0] - 4 && State.Ix2[0][State.base.Nrap[0]-1] == State.base.Ix2_max[0] + 4); - }; - - inline bool Force_Descent (char whichDSF, Heis_Bethe_State& ScanState, Heis_Bethe_State& RefState, int desc_type_required, int iKmod, DP Chem_Pot) - { - bool force_descent = false; - - // Force descent if energy of ScanState is lower than that of RefState - //if (ScanState.E - RefState.E - (ScanState.base.Mdown - RefState.base.Mdown) < 0.0) return(true); - /* - // We force descent if - // 1) - there exists a higher string whose quantum number is still on 0 - // AND - there is at most a single particle-hole in the 0 base level - // AND - either the particle or the hole hasn't yet moved. - if (ScanState.base_id/100000LL > 0) { // there is a higher string - int type0 = ScanState.type_id % 10000; - if (type0 == 0 - || type0 == 101 && ScanState.offsets.Tableau[0].id * ScanState.offsets.Tableau[2].id == 0LL - || type0 == 110 && ScanState.offsets.Tableau[1].id * ScanState.offsets.Tableau[2].id == 0LL - || type0 == 1001 && ScanState.offsets.Tableau[0].id * ScanState.offsets.Tableau[3].id == 0LL - || type0 == 1010 && ScanState.offsets.Tableau[1].id * ScanState.offsets.Tableau[3].id == 0LL) // single p-h pair in base level 0 - for (int j = 1; j < ScanState.chain.Nstrings; ++j) { - if (ScanState.base[j] == 1 && ScanState.Ix2[j][0] == 0) { - force_descent = true; - } - } - } - */ - // Force descent if quantum nr distribution is symmetric: - //if (ScanState.Check_Symmetry()) force_descent = true; - //if (desc_type_required > 8 && ScanState.Check_Symmetry()) force_descent = true; - - // Force descent for longitudinal if we're at zero or pi momentum: - //ScanState.Compute_Momentum(); - //if (whichDSF == 'z' && (ScanState.iK - RefState.iK) % iKmod == 0) force_descent = true; - //if (desc_type_required > 8 && whichDSF == 'z' && (2*(ScanState.iK - RefState.iK) % iKmod == 0)) force_descent = true; // type_req > 8 means that we don't conserve momentum - // Force descent for all DSFs if we're at K = 0 or PI and not conserving momentum upon descent: - if (desc_type_required > 8 && (2*(ScanState.iK - RefState.iK) % iKmod == 0)) force_descent = true; // type_req > 8 means that we don't conserve momentum - - //if (force_descent) cout << "Forcing descent on state with label " << ScanState.label << endl; - - if (ScanState.chain.Delta > 1.0) { - /* - // Count the nr of holes in one-strings: - int nholes = 0; - for (int i = 0; i < ScanState.base.Nrap[0] - 1; ++i) if (ScanState.Ix2[0][i+1] - ScanState.Ix2[0][i] != 2) nholes++; - - if (nholes <= 2) { - if (ScanState.base.Nrap[0] == ScanState.base.Mdown - 2 && ScanState.base.Nrap[1] == 1) force_descent = true; - if (ScanState.base.Nrap[0] == ScanState.base.Mdown - 3 && ScanState.base.Nrap[2] == 1) force_descent = true; - if (ScanState.base.Nrap[0] == ScanState.base.Mdown - 4 && ScanState.base.Nrap[1] == 2) force_descent = true; - } - */ - - if (ScanState.label.compare(0, 10, "14x1y1_0x0") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "14x1y1_0x1") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "14x1y1_1x0") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "14x1y1_1x1") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "14x1y1_2x0") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "14x1y1_2x1") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "12x1y2_0x0") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "12x1y2_0x1") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "12x1y2_0x2") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "12x1y2_1x0") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "12x1y2_1x1") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "12x1y2_1x2") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "12x1y2_2x0") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "12x1y2_2x1") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "12x1y2_2x2") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "13x2y1_0x0") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "13x2y1_0x1") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "13x2y1_1x0") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "13x2y1_1x1") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "13x2y1_2x0") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "13x2y1_2x1") == 0) force_descent = true; - - if (ScanState.label.compare(0, 10, "30x1y1_0x0") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "30x1y1_0x1") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "30x1y1_1x0") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "30x1y1_1x1") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "30x1y1_2x0") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "30x1y1_2x1") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "28x1y2_0x0") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "28x1y2_0x1") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "28x1y2_0x2") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "28x1y2_1x0") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "28x1y2_1x1") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "28x1y2_1x2") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "28x1y2_2x0") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "28x1y2_2x1") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "28x1y2_2x2") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "29x2y1_0x0") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "29x2y1_0x1") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "29x2y1_1x0") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "29x2y1_1x1") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "29x2y1_2x0") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "29x2y1_2x1") == 0) force_descent = true; - - if (ScanState.label.compare(0, 10, "46x1y1_0x0") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "46x1y1_0x1") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "46x1y1_1x0") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "46x1y1_1x1") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "46x1y1_2x0") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "46x1y1_2x1") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "44x1y2_0x0") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "44x1y2_0x1") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "44x1y2_0x2") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "44x1y2_1x0") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "44x1y2_1x1") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "44x1y2_1x2") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "44x1y2_2x0") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "44x1y2_2x1") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "44x1y2_2x2") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "45x2y1_0x0") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "45x2y1_0x1") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "45x2y1_1x0") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "45x2y1_1x1") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "45x2y1_2x0") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "45x2y1_2x1") == 0) force_descent = true; - - - if (ScanState.label.compare(0, 10, "62x1y1_0x0") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "62x1y1_0x1") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "62x1y1_1x0") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "62x1y1_1x1") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "62x1y1_2x0") == 0) force_descent = true; - //if (ScanState.label.compare(0, 10, "62x1y1_2x1") == 0 && desc_type_required < 2) force_descent = true; - if (ScanState.label.compare(0, 10, "62x1y1_2x1") == 0 - && (desc_type_required == 14 || desc_type_required == 13 || desc_type_required == 11 || desc_type_required == 10)) force_descent = true; - /* - if (ScanState.label.compare(0, 10, "60x1y2_0x0") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "60x1y2_0x1") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "60x1y2_0x2") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "60x1y2_1x0") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "60x1y2_1x1") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "60x1y2_1x2") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "60x1y2_2x0") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "60x1y2_2x1") == 0 && desc_type_required < 2) force_descent = true; - if (ScanState.label.compare(0, 10, "60x1y2_2x2") == 0 && desc_type_required < 2) force_descent = true; - if (ScanState.label.compare(0, 10, "61x2y1_0x0") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "61x2y1_0x1") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "61x2y1_1x0") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "61x2y1_1x1") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "61x2y1_2x0") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "61x2y1_2x1") == 0 && desc_type_required < 2) force_descent = true; - */ - - if (ScanState.label.compare(0, 11, "126x1y1_0x0") == 0) force_descent = true; - if (ScanState.label.compare(0, 11, "126x1y1_0x1") == 0) force_descent = true; - if (ScanState.label.compare(0, 11, "126x1y1_1x0") == 0) force_descent = true; - if (ScanState.label.compare(0, 11, "126x1y1_1x1") == 0) force_descent = true; - if (ScanState.label.compare(0, 11, "126x1y1_2x0") == 0) force_descent = true; - //if (ScanState.label.compare(0, 11, "126x1y1_2x1") == 0 && desc_type_required < 2) force_descent = true; - if (ScanState.label.compare(0, 11, "126x1y1_2x1") == 0 - && (desc_type_required == 14 || desc_type_required == 13 || desc_type_required == 11 || desc_type_required == 10)) force_descent = true; - /* - if (ScanState.label.compare(0, 10, "124x1y2_0x0") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "124x1y2_0x1") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "124x1y2_0x2") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "124x1y2_1x0") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "124x1y2_1x1") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "124x1y2_1x2") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "124x1y2_2x0") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "124x1y2_2x1") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "124x1y2_2x2") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "125x2y1_0x0") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "125x2y1_0x1") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "125x2y1_1x0") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "125x2y1_1x1") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "125x2y1_2x0") == 0) force_descent = true; - if (ScanState.label.compare(0, 10, "125x2y1_2x1") == 0) force_descent = true; - */ - if (ScanState.label.compare(0, 11, "254x1y1_0x0") == 0) force_descent = true; - if (ScanState.label.compare(0, 11, "254x1y1_0x1") == 0) force_descent = true; - if (ScanState.label.compare(0, 11, "254x1y1_1x0") == 0) force_descent = true; - if (ScanState.label.compare(0, 11, "254x1y1_1x1") == 0) force_descent = true; - if (ScanState.label.compare(0, 11, "254x1y1_2x0") == 0) force_descent = true; - if (ScanState.label.compare(0, 11, "254x1y1_2x1") == 0 && desc_type_required < 2) force_descent = true; - - // Do not force descent a state with rapidities outside of fundamental interval: - /* - for (int j = 0; j < ScanState.chain.Nstrings; ++j) { - // Logic: allow rapidities -PI/2 <= lambda <= PI/2 (including boundaries) - if (ScanState.base.Nrap[j] > 0 && - (ScanState.lambda[j][0] < -PI/2 || ScanState.lambda[j][ScanState.base.Nrap[j] - 1] > PI/2)) - force_descent = false; - - // rapidities should also be ordered as the quantum numbers: - for (int alpha = 1; alpha < ScanState.base.Nrap[j]; ++alpha) - if (ScanState.lambda[j][alpha - 1] >= ScanState.lambda[j][alpha]) - force_descent = false; - } - */ - //if (force_descent) cout << "Forcing descent on state with label " << ScanState.label << endl; - } // if Delta > 1 - - //if (ScanState.base.Nrap[0] == ScanState.base.Mdown - 2 && ScanState.base.Nrap[1] == 1 && ScanState.Ix2[1][0] == 0) force_descent = true; - //if (ScanState.base.Nrap[0] == ScanState.base.Mdown - 3 && ScanState.base.Nrap[2] == 1 && ScanState.Ix2[2][0] == 0) force_descent = true; - //if (ScanState.base.Nrap[0] == ScanState.base.Mdown - 4 && ScanState.base.Nrap[1] == 2 && ScanState.Ix2[1][0] == -1 && ScanState.Ix2[1][1] == 1) force_descent = true; - - return(force_descent); - } - - std::ostream& operator<< (std::ostream& s, const Heis_Bethe_State& state); - - //**************************************************************************** - - // Objects in class XXZ_Bethe_State carry all extra information pertaining to XXZ gapless - - class XXZ_Bethe_State : public Heis_Bethe_State { - - public: - Lambda sinhlambda; - Lambda coshlambda; - Lambda tanhlambda; - - public: - XXZ_Bethe_State (); - XXZ_Bethe_State (const XXZ_Bethe_State& RefState); // copy constructor - XXZ_Bethe_State (const Heis_Chain& RefChain, int M); // constructor to ground-state configuration - XXZ_Bethe_State (const Heis_Chain& RefChain, const Heis_Base& base); // constructor to lowest-energy config with base - //XXZ_Bethe_State (const Heis_Chain& RefChain, long long int base_id_ref, long long int type_id_ref); // constructor to lowest-energy config with bas - - public: - XXZ_Bethe_State& operator= (const XXZ_Bethe_State& RefState); - - public: - void Set_Free_lambdas(); // sets the rapidities to solutions of BAEs without scattering terms - void Compute_sinhlambda(); - void Compute_coshlambda(); - void Compute_tanhlambda(); - bool Check_Admissibility(char option); // verifies that we don't have a symmetrical Ix2 config with a Ix2 == 0 for a string of even length >= 2. - void Compute_BE (int j, int alpha); - void Compute_BE (); - DP Iterate_BAE(int i, int j); - bool Check_Rapidities(); // checks that all rapidities are not nan - DP String_delta (); - void Compute_Energy (); - //void Compute_Momentum (); - void Build_Reduced_Gaudin_Matrix (SQMat >& Gaudin_Red); - - // XXZ specific functions: - public: - - }; - - XXZ_Bethe_State Add_Particle_at_Center (const XXZ_Bethe_State& RefState); - XXZ_Bethe_State Remove_Particle_at_Center (const XXZ_Bethe_State& RefState); - - //**************************************************************************** - - // Objects in class XXX_Bethe_State carry all extra information pertaining to XXX antiferromagnet - - class XXX_Bethe_State : public Heis_Bethe_State { - - public: - XXX_Bethe_State (); - XXX_Bethe_State (const XXX_Bethe_State& RefState); // copy constructor - XXX_Bethe_State (const Heis_Chain& RefChain, int M); // constructor to ground-state configuration - XXX_Bethe_State (const Heis_Chain& RefChain, const Heis_Base& base); // constructor to lowest-energy config with base - //XXX_Bethe_State (const Heis_Chain& RefChain, long long int base_id_ref, long long int type_id_ref); // constructor to lowest-energy config with base - - public: - XXX_Bethe_State& operator= (const XXX_Bethe_State& RefState); - - public: - void Set_Free_lambdas(); // sets the rapidities to solutions of BAEs without scattering terms - bool Check_Admissibility(char option); // verifies that we don't have a symmetrical Ix2 config with a Ix2 == 0 for a string of even length >= 2. - void Compute_BE (int j, int alpha); - void Compute_BE (); - DP Iterate_BAE(int i, int j); - bool Check_Rapidities(); // checks that all rapidities are not nan - DP String_delta (); - void Compute_Energy (); - //void Compute_Momentum (); - void Build_Reduced_Gaudin_Matrix (SQMat >& Gaudin_Red); - - // XXX specific functions - public: - bool Check_Finite_rap (); - - }; - - XXX_Bethe_State Add_Particle_at_Center (const XXX_Bethe_State& RefState); - XXX_Bethe_State Remove_Particle_at_Center (const XXX_Bethe_State& RefState); - - //**************************************************************************** - - // Objects in class XXZ_gpd_Bethe_State carry all extra information pertaining to XXZ gapped antiferromagnets - - class XXZ_gpd_Bethe_State : public Heis_Bethe_State { - - public: - Lambda sinlambda; - Lambda coslambda; - Lambda tanlambda; - - public: - XXZ_gpd_Bethe_State (); - XXZ_gpd_Bethe_State (const XXZ_gpd_Bethe_State& RefState); // copy constructor - XXZ_gpd_Bethe_State (const Heis_Chain& RefChain, int M); // constructor to ground-state configuration - XXZ_gpd_Bethe_State (const Heis_Chain& RefChain, const Heis_Base& base); // constructor to lowest-energy config with base - //XXZ_gpd_Bethe_State (const Heis_Chain& RefChain, long long int base_id_ref, long long int type_id_ref); // constructor to lowest-energy config with base - - public: - XXZ_gpd_Bethe_State& operator= (const XXZ_gpd_Bethe_State& RefState); - - public: - void Set_Free_lambdas(); // sets the rapidities to solutions of BAEs without scattering terms - void Compute_sinlambda(); - void Compute_coslambda(); - void Compute_tanlambda(); - int Weight(); // weight function for contributions cutoff - bool Check_Admissibility(char option); // verifies that we don't have a symmetrical Ix2 config with a Ix2 == 0 for a string of even length >= 2. - void Compute_BE (int j, int alpha); - void Compute_BE (); - DP Iterate_BAE(int i, int j); - void Iterate_BAE_Newton(); - bool Check_Rapidities(); // checks that all rapidities are not nan and are in interval ]-PI/2, PI/2] - DP String_delta (); - void Compute_Energy (); - //void Compute_Momentum (); - void Build_Reduced_Gaudin_Matrix (SQMat >& Gaudin_Red); - - // XXZ_gpd specific functions - public: - - }; - - XXZ_gpd_Bethe_State Add_Particle_at_Center (const XXZ_gpd_Bethe_State& RefState); - XXZ_gpd_Bethe_State Remove_Particle_at_Center (const XXZ_gpd_Bethe_State& RefState); - - //*********************************************** - - // Function declarations - - // in M_vs_H.cc - DP Ezero (DP Delta, int N, int M); - DP H_vs_M (DP Delta, int N, int M); - DP HZmin (DP Delta, int N, int M, Vect_DP& Ezero_ref); - int M_vs_H (DP Delta, int N, DP HZ); - - DP X_avg (char xyorz, DP Delta, int N, int M); - - DP Chemical_Potential (const Heis_Bethe_State& RefState); - DP Particle_Hole_Excitation_Cost (char whichDSF, Heis_Bethe_State& AveragingState); - - //DP Sumrule_Factor (char whichDSF, Heis_Bethe_State& RefState, DP Chem_Pot, bool fixed_iK, int iKneeded); - DP Sumrule_Factor (char whichDSF, Heis_Bethe_State& RefState, DP Chem_Pot, int iKmin, int iKmax); - void Evaluate_F_Sumrule (string prefix, char whichDSF, const Heis_Bethe_State& RefState, DP Chem_Pot, int iKmin, int iKmax); - - complex ln_Sz_ME (XXZ_Bethe_State& A, XXZ_Bethe_State& B); - complex ln_Smin_ME (XXZ_Bethe_State& A, XXZ_Bethe_State& B); - - complex ln_Sz_ME (XXX_Bethe_State& A, XXX_Bethe_State& B); - complex ln_Smin_ME (XXX_Bethe_State& A, XXX_Bethe_State& B); - - // From Antoine Klauser: - complex ln_Szz_ME (XXX_Bethe_State& A, XXX_Bethe_State& B); - complex ln_Szm_p_Smz_ME (XXX_Bethe_State& A, XXX_Bethe_State& B); - complex ln_Smm_ME (XXX_Bethe_State& A, XXX_Bethe_State& B); - - complex ln_Sz_ME (XXZ_gpd_Bethe_State& A, XXZ_gpd_Bethe_State& B); - complex ln_Smin_ME (XXZ_gpd_Bethe_State& A, XXZ_gpd_Bethe_State& B); - - // The following functions have become member functions. - //DP String_delta (XXZ_Bethe_State& state); - //DP String_delta (XXX_Bethe_State& state); - //DP String_delta (XXZ_gpd_Bethe_State& state); - - //DP Compute_Form_Factor_Entry (char whichDSF, Heis_Bethe_State& LeftState, Heis_Bethe_State& RefState, DP Chem_Pot, fstream& DAT_outfile); - //DP Compute_Matrix_Element_Contrib (char whichDSF, int iKmin, int iKmax, XXZ_Bethe_State& LeftState, - // XXZ_Bethe_State& RefState, DP Chem_Pot, fstream& DAT_outfile); - DP Compute_Matrix_Element_Contrib (char whichDSF, int iKmin, int iKmax, XXZ_Bethe_State& LeftState, - XXZ_Bethe_State& RefState, DP Chem_Pot, stringstream& DAT_outfile); - //DP Compute_Matrix_Element_Contrib (char whichDSF, int iKmin, int iKmax, XXX_Bethe_State& LeftState, - // XXX_Bethe_State& RefState, DP Chem_Pot, fstream& DAT_outfile); - DP Compute_Matrix_Element_Contrib (char whichDSF, int iKmin, int iKmax, XXX_Bethe_State& LeftState, - XXX_Bethe_State& RefState, DP Chem_Pot, stringstream& DAT_outfile); - //DP Compute_Matrix_Element_Contrib (char whichDSF, int iKmin, int iKmax, XXZ_gpd_Bethe_State& LeftState, - // XXZ_gpd_Bethe_State& RefState, DP Chem_Pot, fstream& DAT_outfile); - DP Compute_Matrix_Element_Contrib (char whichDSF, int iKmin, int iKmax, XXZ_gpd_Bethe_State& LeftState, - XXZ_gpd_Bethe_State& RefState, DP Chem_Pot, stringstream& DAT_outfile); - - // For geometric quench: - complex ln_Overlap (XXX_Bethe_State& A, XXX_Bethe_State& B); - - void Scan_Heis_Geometric_Quench (DP Delta, int N_1, int M, long long int base_id_1, long long int type_id_1, long long int id_1, - int N_2, int iKmin, int iKmax, int Max_Secs, bool refine); - - -} // namespace JSC - -#endif diff --git a/include/JSC_Infprec.h b/include/JSC_Infprec.h deleted file mode 100644 index e87136f..0000000 --- a/include/JSC_Infprec.h +++ /dev/null @@ -1,32 +0,0 @@ -/********************************************************** - -This software is part of J.-S. Caux's ABACUS library. - -Copyright (c). - ------------------------------------------------------------ - -File: JSC_Infprec.h - -Purpose: Declarations for infinite precision arithmetic classes. - -***********************************************************/ - - -#ifndef _JSC_INFPREC_ -#define _JSC_INFPREC_ - -namespace JSC { - - class infprec_int { - - private: - int nintrep; // number of integers used in representation - int baseint; // fundamental int - Vect xint; // extra integers - - } - -} // namespace JSC - -#endif diff --git a/include/JSC_Matrix.h b/include/JSC_Matrix.h deleted file mode 100644 index 3108637..0000000 --- a/include/JSC_Matrix.h +++ /dev/null @@ -1,440 +0,0 @@ -/********************************************************** - -This software is part of J.-S. Caux's ABACUS library. - -Copyright (c). - ------------------------------------------------------------ - -File: JSC_Matrix.h - -Purpose: Declares square matrix class. - -***********************************************************/ - -#ifndef _MATRIX_ -#define _MATRIX_ - -namespace JSC { - - - // CLASS DEFINITIONS - - template - class SQMat { - - private: - int dim; - T** M; - - public: - SQMat (int N); // initializes all elements of this n by n matrix to zero - SQMat (const SQMat& rhs); // copy constructor - SQMat (const T& a, int N); // initialize to diagonal matrix with value a (NOT like in NR !!!) - SQMat (const SQMat& a, const SQMat& b); // initialize to tensor product of a and b - SQMat (const SQMat& a, int row_id, int col_id); // init by cutting row row_id and col col_id - void Print (); - SQMat& operator= (const SQMat& rhs); // assignment - SQMat& operator= (const T& a); // assign 1 to diagonal elements (NOT like in NR !!!) - inline T* operator[] (const int i); // subscripting: pointer to row i - inline const T* operator[] (const int i) const; - SQMat& operator+= (const T& a); - SQMat& operator+= (const SQMat& a); - SQMat& operator-= (const T& a); - SQMat& operator-= (const SQMat& a); - SQMat& operator*= (const T& a); - SQMat& operator*= (const SQMat& a); - inline int size() const; - ~SQMat(); - - }; - - template - SQMat::SQMat (int N) : dim(N) , M(new T*[N]) - { - M[0] = new T[N*N]; - for (int i = 1; i < N; i++) M[i] = M[i-1] + N; - } - - template - SQMat::SQMat (const SQMat& rhs) : dim(rhs.dim) , M(new T*[dim]) - { - int i,j; - M[0] = new T[dim*dim]; - for (i = 1; i < dim; i++) M[i] = M[i-1] + dim; - for (i = 0; i < dim; i++) - for (j = 0; j < dim; j++) M[i][j] = rhs[i][j]; - } - - template - SQMat::SQMat (const T& a, int N) : dim(N) , M(new T*[dim]) - { - int i, j; - M[0] = new T[dim*dim]; - for (i = 1; i < dim; i++) M[i] = M[i-1] + dim; - for (i = 0; i < dim; i++) { - for (j = 0; j < dim; j++) M[i][j] = T(0); - M[i][i] = a; - } - } - - template - SQMat::SQMat (const SQMat& a, const SQMat& b) : dim (a.dim * b.dim) , M(new T*[a.dim * b.dim]) - { - M[0] = new T[a.dim * b.dim * a.dim * b.dim]; - - for (int i = 1; i < a.dim * b.dim; ++i) M[i] = M[i-1] + a.dim * b.dim; - - for (int i1 = 0; i1 < a.dim; ++i1) { - - for (int i2 = 0; i2 < a.dim; ++i2) { - - for (int j1 = 0; j1 < b.dim; ++j1) { - - for (int j2 = 0; j2 < b.dim; ++j2) { - - M[i1 * (b.dim) + j1][i2 * (b.dim) + j2] = a[i1][i2] * b[j1][j2]; - } - } - } - } - } - - template - SQMat::SQMat (const SQMat&a, int row_id, int col_id) : dim (a.dim - 1) , M(new T*[dim]) - { - if (dim == 0) { - JSCerror("Error: chopping a row and col from size one matrix."); - exit(1); - } - - M[0] = new T[dim * dim]; - - for (int i = 1; i < dim; ++i) M[i] = M[i-1] + dim; - - for (int i = 0; i < row_id; ++i) - for (int j = 0; j < col_id; ++j) M[i][j] = a[i][j]; - for (int i = row_id; i < dim; ++i) - for (int j = 0; j < col_id; ++j) M[i][j] = a[i+1][j]; - for (int i = 0; i < row_id; ++i) - for (int j = col_id; j < dim; ++j) M[i][j] = a[i][j+1]; - for (int i = row_id; i < dim; ++i) - for (int j = col_id; j < dim; ++j) M[i][j] = a[i+1][j+1]; - - } - - // operators - template - void SQMat::Print () - { - cout << endl; - for (int i = 0; i < dim; ++i) { - for (int j = 0; j < dim; ++j) cout << M[i][j] << " "; - cout << endl; - } - cout << endl; - } - - template - SQMat& SQMat::operator= (const SQMat& rhs) - { - if (this != &rhs) { - if (dim != rhs.dim) { - JSCerror("Assignment between matrices of different dimensions. Bailing out."); - exit(1); - } - - for (int i = 0; i < dim; ++i) - for (int j = 0; j < dim; ++j) M[i][j] = rhs[i][j]; - } - return *this; - } - - template - SQMat& SQMat::operator= (const T& a) - { - for (int i = 0; i < dim; ++i) { - for (int j = 0; j < dim; ++j) - M[i][j] = T(0); - M[i][i] = a; - } - return *this; - } - - template - inline T* SQMat::operator[] (const int i) - { - return M[i]; - } - - template - inline const T* SQMat::operator[] (const int i) const - { - return M[i]; - } - - template - SQMat& SQMat::operator+= (const T& a) - { - - for (int i = 0; i < dim; ++i) M[i][i] += a; - - return *this; - } - - template - SQMat& SQMat::operator+= (const SQMat& a) - { - if (dim != a.dim) { - JSCerror("Incompatible matrix sizes in matrix operator +."); - exit(1); - } - for (int i = 0; i < dim; ++i) { - for (int j = 0; j < dim; ++j) { - M[i][j] += a[i][j]; - } - } - return *this; - } - - template - SQMat& SQMat::operator-= (const T& a) - { - - for (int i = 0; i < dim; ++i) M[i][i] -= a; - - return *this; - } - - template - SQMat& SQMat::operator-= (const SQMat& a) - { - if (dim != a.dim) { - JSCerror("Incompatible matrix sizes in matrix operator +."); - exit(1); - } - for (int i = 0; i < dim; ++i) { - for (int j = 0; j < dim; ++j) { - M[i][j] -= a[i][j]; - } - } - return *this; - } - - template - SQMat& SQMat::operator*= (const T& a) - { - - for (int i = 0; i < dim; ++i) for (int j = 0; j < dim; ++j) M[i][j] *= a; - - return *this; - } - - template - SQMat& SQMat::operator*= (const SQMat& a) - { - - if (dim != a.dim) { - JSCerror("Incompatible matrix sizes in matrix operator *."); - exit(1); - } - - SQMat leftarg(*this); // use copy constructor. - - for (int i = 0; i < dim; ++i) { - - for (int j = 0; j < dim; ++j) { - - M[i][j] = 0.0; - - for (int k = 0; k < dim; ++k) { - - M[i][j] += leftarg[i][k] * a[k][j]; - } - } - } - - return *this; - } - - template - inline int SQMat::size() const - { - return dim; - } - - template - SQMat::~SQMat() - { - if (M != 0) { - delete[] (M[0]); - delete[] (M); - } - } - - - //***************************** - - template - class RecMat { - - private: - int nrows; - int ncols; - T** M; - - public: - RecMat (int Nrows, int Ncols); // initializes all elements of this n by n matrix to zero - RecMat (const T& a, int Nrows, int Ncols); - RecMat (const RecMat& rhs); // copy constructor - void Print (); - RecMat& operator= (const RecMat& rhs); // assignment - inline T* operator[] (const int i); // subscripting: pointer to row i - inline const T* operator[] (const int i) const; - inline int nr_rows() const; - inline int nr_cols() const; - ~RecMat(); - - }; - - template - RecMat::RecMat (int Nrows, int Ncols) : nrows(Nrows), ncols(Ncols), M(new T*[Nrows]) - { - M[0] = new T[Nrows*Ncols]; - for (int i = 1; i < Nrows; i++) M[i] = M[i-1] + Ncols; - - for (int i = 0; i < Nrows; i++) for (int j = 0; j < Ncols; j++) M[i][j] = T(0); - } - - template - RecMat::RecMat (const T& a, int Nrows, int Ncols) : nrows(Nrows), ncols(Ncols), M(new T*[Nrows]) - { - M[0] = new T[Nrows*Ncols]; - for (int i = 1; i < Nrows; i++) M[i] = M[i-1] + Ncols; - - for (int i = 0; i < Nrows; i++) for (int j = 0; j < Ncols; j++) { - if (i == j) M[i][i] = a; - else M[i][j] = T(0); - } - } - - template - RecMat::RecMat (const RecMat& rhs) : nrows(rhs.nrows), ncols(rhs.ncols), M(new T*[nrows]) - { - int i,j; - M[0] = new T[nrows*ncols]; - for (i = 1; i < nrows; i++) M[i] = M[i-1] + ncols; - for (i = 0; i < nrows; i++) - for (j = 0; j < ncols; j++) M[i][j] = rhs[i][j]; - } - - // operators - template - void RecMat::Print () - { - cout << endl; - for (int i = 0; i < nrows; ++i) { - for (int j = 0; j < ncols; ++j) cout << M[i][j] << " "; - cout << endl; - } - cout << endl; - } - - template - RecMat& RecMat::operator= (const RecMat& rhs) - { - if (this != &rhs) { - if (nrows != rhs.nrows || ncols != rhs.ncols) { - if (M != 0) { - delete[] (M[0]); - delete[] (M); - } - nrows = rhs.nrows; - ncols = rhs.ncols; - M = new T*[nrows]; - M[0] = new T[nrows * ncols]; - } - - for (int i = 0; i < nrows; ++i) - for (int j = 0; j < ncols; ++j) M[i][j] = rhs[i][j]; - } - return *this; - } - - template - inline T* RecMat::operator[] (const int i) - { - return M[i]; - } - - template - inline const T* RecMat::operator[] (const int i) const - { - return M[i]; - } - - template - inline int RecMat::nr_rows() const - { - return nrows; - } - - template - inline int RecMat::nr_cols() const - { - return ncols; - } - - template - inline std::ostream& operator<< (std::ostream& s, const RecMat& matrix) - { - for (int i = 0; i < matrix.nr_rows(); ++i) { - for (int j = 0; j < matrix.nr_cols(); ++j) s << matrix[i][j] << " "; - s << endl; - } - - return (s); - } - - template - RecMat::~RecMat() - { - if (M != 0) { - delete[] (M[0]); - delete[] (M); - } - } - - // TYPEDEFS: - - typedef JSC::SQMat SQMat_DP; - typedef JSC::SQMat > SQMat_CX; - - - // FUNCTION DEFINITIONS - - // Functions in src/MATRIX directory - - DP det_LU (SQMat_DP a); - DP lndet_LU (SQMat_DP a); - complex lndet_LU_dstry (SQMat_DP& a); - complex det_LU_CX (SQMat_CX a); - complex lndet_LU_CX (SQMat_CX a); - complex lndet_LU_CX_dstry (SQMat_CX& a); - void eigsrt (Vect_DP& d, SQMat_DP& v); - void balanc (SQMat_DP& a); - void elmhes (SQMat_DP& a); - void gaussj (SQMat_DP& a, SQMat_DP& b); - void hqr (SQMat_DP& a, Vect_CX& wri); - void jacobi (SQMat_DP& a, Vect_DP& d, SQMat_DP& v, int& nrot); - void lubksb (SQMat_DP& a, Vect_INT& indx, Vect_DP& b); - void lubksb_CX (SQMat_CX& a, Vect_INT& indx, Vect_CX& b); - void ludcmp (SQMat_DP& a, Vect_INT& indx, DP& d); - void ludcmp_CX (SQMat_CX& a, Vect_INT& indx, DP& d); - DP pythag(DP a, DP b); - void tqli(Vect_DP& d, Vect_DP& e, SQMat_DP& z); - void tred2 (SQMat_DP& a, Vect_DP& d, Vect_DP& e); - -} // namespace JSC - -#endif diff --git a/include/JSC_NRG.h b/include/JSC_NRG.h deleted file mode 100644 index 31776ff..0000000 --- a/include/JSC_NRG.h +++ /dev/null @@ -1,36 +0,0 @@ -/********************************************************** - -This software is part of J.-S. Caux's ABACUS library. - -Copyright (c). - ------------------------------------------------------------ - -File: JSC_NRG.h - -Purpose: Declares NRG-related classes and functions. - -***********************************************************/ - -#ifndef _NRG_ -#define _NRG_ - -#include "JSC.h" - -namespace JSC { - - DP K_Weight_integrand (Vect_DP args); // weighing function for state selection - - //void Select_States_for_NRG (DP c_int, DP L, int N, int iKmin, int iKmax, int Nstates_required, bool symmetric_states, int iKmod, - // int weighing_option, DP (*weight_integrand_fn) (Vect_DP), Vect_DP& args_to_weight_integrand); - void Select_States_for_NRG (DP c_int, DP L, int N, int iKmin, int iKmax, int Nstates_required, bool symmetric_states, int iKmod, - //int weighing_option, DP (*weight_integrand_fn) (Vect_DP), Vect_DP& args_to_weight_integrand) - int weighing_option, Vect >& FT_of_potential); - - void Build_DFF_Matrix_Block_for_NRG (DP c_int, DP L, int N, int iKmin, int iKmax, int Nstates_required, bool symmetric_states, int iKmod, - int weighing_option, int label_left_begin, int label_left_end, int label_right_begin, int label_right_end, - int block_option, DP* DFF_block_1, DP* DFF_block_2, Vect_DP Kweight); - -} - -#endif // _NRG_ diff --git a/include/JSC_Scan.h b/include/JSC_Scan.h deleted file mode 100644 index be98d79..0000000 --- a/include/JSC_Scan.h +++ /dev/null @@ -1,1263 +0,0 @@ -/********************************************************** - -This software is part of J.-S. Caux's ABACUS library. - -Copyright (c). - ------------------------------------------------------------ - -File: JSC_Scan.h - -Purpose: Declares all classes and functions used in the - ABACUS logic of scanning with threads. - - -***********************************************************/ - -#ifndef _SCAN_ -#define _SCAN_ - -#include "JSC.h" - -namespace JSC { - - const int MAX_STATE_LIST_SIZE = 10000; - - // Functions in src/UTILS/Data_File_Name.cc: - void Data_File_Name (stringstream& name, char whichDSF, DP c_int, DP L, int N, int iKmin, int iKmax, DP kBT, DP L2, string defaultname); - void Data_File_Name (stringstream& name, char whichDSF, int iKmin, int iKmax, DP kBT, LiebLin_Bethe_State& State, LiebLin_Bethe_State& RefScanState, string defaultname); - void Data_File_Name (stringstream& name, char whichDSF, DP Delta, int N, int M, int iKmin, int iKmax, DP kBT, int N2, string defaultname); - void Data_File_Name (stringstream& name, char whichDSF, int iKmin, int iKmax, DP kBT, Heis_Bethe_State& State, Heis_Bethe_State& RefScanState, string defaultname); - void ODSLF_Data_File_Name (stringstream& name, char whichDSF, DP Delta, int N, int M, int iKmin, int iKmax, DP kBT, int N2, string defaultname); - void Data_File_Name (stringstream& name, char whichDSF, int iKmin, int iKmax, DP kBT, ODSLF_Bethe_State& State, ODSLF_Bethe_State& RefScanState, string defaultname); - - // Coding to convert ints to strings: for application in reduced labels - //const int JSCcodingsize = 64; // use a multiple of 2 to accelerate divisions in labeling. - //const char JSCcoding[] = {'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z', 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', '!', '?'}; - - // From ABACUS++T_8 onwards: forbid special characters as |, :, !, ? and all capital letters in labels. - // This is due to the capitalization-preserving but capitalization-insensitive HFS+ filesystem on Mac OS X. - const int JSCcodingsize = 32; - const char JSCcoding[] = {'0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v'}; - const char LABELSEP = '_'; // was _ - const char TYPESEP = 'x'; // was | - const char EXCSEP = 'y'; // was : - const char INEXCSEP = 'z'; // was @ - - struct State_Label_Data { - - //int ntypes; // how many types of particles are present in the state - Vect type; // integer type labels of the types present - Vect M; // how many particles of each type - Vect nexc; // how many excitations as compared to the reference state used - Vect > Ix2old; // which Ix2 will be excited - Vect > Ix2exc; // which Ix2 the excitation has shifted to - - State_Label_Data (const Vect& type_ref, const Vect& M_ref, - const Vect& nexc_ref, const Vect >& Ix2old_ref, const Vect >& Ix2exc_ref) - { - type = type_ref; M = M_ref; nexc = nexc_ref; Ix2old = Ix2old_ref; Ix2exc = Ix2exc_ref; - } - - }; - - // DEPRECATED ++G_5 - //State_Label_Data Read_State_Ulabel (string ulabel); - //string Return_State_Ulabel (State_Label_Data data); - //string Return_State_Ulabel (const Vect >& ScanIx2, const Vect >& OriginIx2); - //string Return_State_Ulabel (const Vect& ScanIx2, const Vect& OriginIx2); // if there is only one type - - string Extract_Base_Label (string label); // works for labels and complabels - string Extract_nexc_Label (string label); - - // For compressed labels: conversions between integers and char/strings. - string Convert_POSINT_to_STR (int int_to_convert); - int Convert_CHAR_to_POSINT (char char_to_convert); - int Convert_STR_to_POSINT (string str_to_convert); - - State_Label_Data Read_Base_Label (string label); - State_Label_Data Read_State_Label (string label, const Vect >& OriginIx2); - State_Label_Data Read_State_Label (string label, const Vect& OriginIx2); // if there is only one type - string Return_State_Label (State_Label_Data data, const Vect >& OriginIx2); - string Return_State_Label (State_Label_Data data, const Vect& OriginIx2); // if there is only one type - string Return_State_Label (const Vect >& ScanIx2, const Vect >& OriginIx2); - string Return_State_Label (const Vect& ScanIx2, const Vect& OriginIx2); // if there is only one type - Vect > Return_Ix2_from_Label (string label_ref, const Vect >& OriginIx2); - Vect Return_Ix2_from_Label (string label_ref, const Vect& OriginIx2); // specialization to Lieb-Liniger - //bool Set_to_Label (string label_ref, Vect >& Ix2, const Vect >& OriginIx2); - - // Functions for descending states: in SCAN/Descendents.cc - //Vect Descendent_States_with_iK_Stepped_Up (string ScanIx2_label, const Vect >& OriginIx2, const Vect >& BaseScanIx2, const Vect& Ix2_min, const Vect& Ix2_max); - //Vect Descendent_States_with_iK_Stepped_Down (string ScanIx2_label, const Vect >& OriginIx2, const Vect >& BaseScanIx2, const Vect& Ix2_min, const Vect& Ix2_max); - //Vect Descendent_States_with_iK_Preserved (string ScanIx2_label, const Vect >& OriginIx2, const Vect >& BaseScanIx2, const Vect& Ix2_min, const Vect& Ix2_max); - // Specialization for Lieb-Liniger case: - // ++G_5 - //Vect Descendent_States_with_iK_Stepped_Up (string ScanIx2_label, const Vect& OriginIx2, const Vect& BaseScanIx2); - //Vect Descendent_States_with_iK_Stepped_Down (string ScanIx2_label, const Vect& OriginIx2, const Vect& BaseScanIx2); - //Vect Descendent_States_with_iK_Preserved (string ScanIx2_label, const Vect& OriginIx2, const Vect& BaseScanIx2); - //Vect Descendent_States_with_iK_Stepped_Up (string ScanIx2_label, const LiebLin_Bethe_State& OriginState); - //Vect Descendent_States_with_iK_Stepped_Down (string ScanIx2_label, const LiebLin_Bethe_State& OriginState); - //Vect Descendent_States_with_iK_Preserved (string ScanIx2_label, const LiebLin_Bethe_State& OriginState); - //Vect Descendent_States_with_iK_Stepped_Up (string ScanIx2_label, const Heis_Bethe_State& OriginState); - //Vect Descendent_States_with_iK_Stepped_Down (string ScanIx2_label, const Heis_Bethe_State& OriginState); - //Vect Descendent_States_with_iK_Preserved (string ScanIx2_label, const Heis_Bethe_State& OriginState); - // ++G_6.0 - //Vect Descendent_States_with_iK_Stepped_Up (string ScanIx2_label, const LiebLin_Bethe_State& OriginState, bool disperse_only_current_exc); - //Vect Descendent_States_with_iK_Stepped_Down (string ScanIx2_label, const LiebLin_Bethe_State& OriginState, bool disperse_only_current_exc); - //Vect Descendent_States_with_iK_Preserved (string ScanIx2_label, const LiebLin_Bethe_State& OriginState, bool disperse_only_current_exc_up, bool disperse_only_current_exc_down); - //Vect Descendent_States_with_iK_Stepped_Up (string ScanIx2_label, const Heis_Bethe_State& OriginState, bool disperse_only_current_exc); - //Vect Descendent_States_with_iK_Stepped_Down (string ScanIx2_label, const Heis_Bethe_State& OriginState, bool disperse_only_current_exc); - //Vect Descendent_States_with_iK_Preserved (string ScanIx2_label, const Heis_Bethe_State& OriginState, bool disperse_only_current_exc_up, bool disperse_only_current_exc_down); - // ++G_6.1 - Vect Descendent_States_with_iK_Stepped_Up (string ScanIx2_label, const LiebLin_Bethe_State& OriginState, bool disperse_only_current_exc, bool preserve_nexc); - Vect Descendent_States_with_iK_Stepped_Down (string ScanIx2_label, const LiebLin_Bethe_State& OriginState, bool disperse_only_current_exc, bool preserve_nexc); - Vect Descendent_States_with_iK_Preserved (string ScanIx2_label, const LiebLin_Bethe_State& OriginState, bool disperse_only_current_exc_up, bool preserve_nexc_up, bool disperse_only_current_exc_down, bool preserve_nexc_down); - Vect Descendent_States_with_iK_Stepped_Up (string ScanIx2_label, const Heis_Bethe_State& OriginState, bool disperse_only_current_exc, bool preserve_nexc); - Vect Descendent_States_with_iK_Stepped_Down (string ScanIx2_label, const Heis_Bethe_State& OriginState, bool disperse_only_current_exc, bool preserve_nexc); - Vect Descendent_States_with_iK_Preserved (string ScanIx2_label, const Heis_Bethe_State& OriginState, bool disperse_only_current_exc_up, bool preserve_nexc_up, bool disperse_only_current_exc_down, bool preserve_nexc_down); - - // For symmetric state scanning: - Vect Descendent_States_with_iK_Stepped_Up_rightIx2only - (string ScanIx2_label, const LiebLin_Bethe_State& OriginState, bool disperse_only_current_exc, bool preserve_nexc); - Vect Descendent_States_with_iK_Stepped_Down_rightIx2only - (string ScanIx2_label, const LiebLin_Bethe_State& OriginState, bool disperse_only_current_exc, bool preserve_nexc); - Vect Descendent_States_with_iK_Stepped_Up_rightIx2only - (string ScanIx2_label, const Heis_Bethe_State& OriginState, bool disperse_only_current_exc, bool preserve_nexc); - Vect Descendent_States_with_iK_Stepped_Down_rightIx2only - (string ScanIx2_label, const Heis_Bethe_State& OriginState, bool disperse_only_current_exc, bool preserve_nexc); - - - - // Conversion between labels and complabels: DEPRECATED ++G_5 - //string Compress_Ulabel (string ulabel_ref, const Vect >& OriginIx2); - //string Compress_Ulabel (string ulabel_ref, const Vect& OriginIx2); // if there is only one type - //string Uncompress_Label (string complabel_ref, const Vect >& OriginIx2); - //string Uncompress_Label (string complabel_ref, const Vect& OriginIx2); // if there is only one type - - // Functions in src/SCAN/General_Scan.cc: - //template - //void General_Scan (char whichDSF, Tstate& RefState, int Max_Secs, bool refine); - //void ScanLiebLin (char whichDSF, DP c_int, DP L, int N, int iKmin, int iKmax, - // int Max_Secs, DP target_sumrule, bool refine, int rank, int nr_processors); - //void Scan_LiebLin (char whichDSF, DP c_int, DP L, int N, int iKmin, int iKmax, int Max_Secs, bool refine); - //void Scan_LiebLin (char whichDSF, DP c_int, DP L, int N, int iKneeded, int Max_Secs, bool refine); - //void Scan_LiebLin (char whichDSF, DP c_int, DP L, int N, int iK_UL, int Max_Secs, bool refine); - // Finite temperature: - //void Scan_LiebLin (char whichDSF, DP c_int, DP L, int N, int iKmin, int iKmax, DP kBT, int Max_Secs, DP target_sumrule, bool refine, int rank, int nr_processors); - void Scan_LiebLin (char whichDSF, DP c_int, DP L, int N, int iKmin, int iKmax, DP kBT, - int Max_Secs, DP target_sumrule, bool refine, int paralevel, Vect rank, Vect nr_processors); - void Scan_LiebLin (char whichDSF, DP c_int, DP L, int N, int iKmin, int iKmax, DP kBT, - int Max_Secs, DP target_sumrule, bool refine); - // Over arbitrary excited state: - //void Scan_LiebLin (char whichDSF, LiebLin_Bethe_State AveragingState, string defaultname, int iKmin, int iKmax, int Max_Secs, DP target_sumrule, bool refine, int rank, int nr_processors); - void Scan_LiebLin (char whichDSF, LiebLin_Bethe_State AveragingState, string defaultScanStatename, int iKmin, int iKmax, - int Max_Secs, DP target_sumrule, bool refine, int paralevel, Vect rank, Vect nr_processors); - void Scan_LiebLin (char whichDSF, LiebLin_Bethe_State AveragingState, string defaultname, int iKmin, int iKmax, - int Max_Secs, DP target_sumrule, bool refine); - - //void Scan_Heis (char whichDSF, DP Delta, DP N, int M, bool fixed_iK, int iKneeded, int Max_Secs, bool refine, int rank, int nr_processors); - void Scan_Heis (char whichDSF, DP Delta, int N, int M, int iKmin, int iKmax, - int Max_Secs, DP target_sumrule, bool refine, int paralevel, Vect rank, Vect nr_processors); - void Scan_Heis (char whichDSF, DP Delta, int N, int M, int iKmin, int iKmax, - int Max_Secs, DP target_sumrule, bool refine); - //void Scan_Heis (char whichDSF, DP Delta, int N, int M, int iKmin, int iKmax, int Max_Secs, bool refine); - //void Scan_Heis (char whichDSF, DP Delta, int N, int M, int iKneeded, int Max_Secs, bool refine); - //void Scan_Heis (char whichDSF, DP Delta, int N, int M, int Max_Secs, bool refine); - - void Scan_Heis (char whichDSF, XXZ_Bethe_State& AveragingState, string defaultScanStatename, int iKmin, int iKmax, - int Max_Secs, DP target_sumrule, bool refine, int paralevel, Vect rank, Vect nr_processors); - void Scan_Heis (char whichDSF, XXX_Bethe_State& AveragingState, string defaultScanStatename, int iKmin, int iKmax, - int Max_Secs, DP target_sumrule, bool refine, int paralevel, Vect rank, Vect nr_processors); - void Scan_Heis (char whichDSF, XXZ_gpd_Bethe_State& AveragingState, string defaultScanStatename, int iKmin, int iKmax, - int Max_Secs, DP target_sumrule, bool refine, int paralevel, Vect rank, Vect nr_processors); - - //void Scan_LiebLin_Geometric_Quench (DP c_int, DP L_1, int type_id_1, long long int id_1, DP L_2, int N, int iK_UL, int Max_Secs, bool refine); - void Scan_LiebLin_Geometric_Quench (DP c_int, DP L_1, int type_id_1, long long int id_1, DP L_2, int N, - int iK_UL, int Max_Secs, DP target_sumrule, bool refine); - - //void Scan_ODSLF (char whichDSF, DP Delta, DP N, int M, bool fixed_iK, int iKneeded, int Max_Secs, bool refine, int rank, int nr_processors); - void Scan_ODSLF (char whichDSF, DP Delta, int N, int M, int iKmin, int iKmax, - int Max_Secs, DP target_sumrule, bool refine, int rank, int nr_processors); - void Scan_ODSLF (char whichDSF, DP Delta, int N, int M, int iKmin, int iKmax, int Max_Secs, bool refine); - void Scan_ODSLF (char whichDSF, DP Delta, int N, int M, int iKneeded, int Max_Secs, bool refine); - void Scan_ODSLF (char whichDSF, DP Delta, int N, int M, int Max_Secs, bool refine); - - // Functions to prepare and wrapup parallel scans: - //void Prepare_Parallel_Scan_LiebLin (char whichDSF, DP c_int, DP L, int N, int iK_UL, bool fixed_iK, int iKneeded, - void Prepare_Parallel_Scan_LiebLin (char whichDSF, DP c_int, DP L, int N, int iKmin, int iKmax, DP kBT, - string defaultname, int paralevel, Vect rank_lower_paralevels, Vect nr_processors_lower_paralevels, - int nr_processors_at_newlevel); - //void Wrapup_Parallel_Scan_LiebLin (char whichDSF, DP c_int, DP L, int N, int iK_UL, bool fixed_iK, int iKneeded, - void Wrapup_Parallel_Scan_LiebLin (char whichDSF, DP c_int, DP L, int N, int iKmin, int iKmax, DP kBT, - string defaultname, int paralevel, Vect rank_lower_paralevels, Vect nr_processors_lower_paralevels, - int nr_processors_at_newlevel); - - void Prepare_Parallel_Scan_Heis (char whichDSF, DP Delta, int N, int M, int iKmin, int iKmax, - int paralevel, Vect rank_lower_paralevels, Vect nr_processors_lower_paralevels, int nr_processors_at_newlevel); - void Wrapup_Parallel_Scan_Heis (char whichDSF, DP Delta, int N, int M, int iKmin, int iKmax, - int paralevel, Vect rank_lower_paralevels, Vect nr_processors_lower_paralevels, int nr_processors_at_newlevel); - - - void Sort_RAW_File (const char ffsq_file[], char optionchar); - void Sort_RAW_File (const char ffsq_file[], char optionchar, char whichDSF); - - // Functions for data interpretation: - DP Smoothen_RAW_into_SF (string prefix, int iKmin, int iKmax, int DiK, - DP ommin, DP ommax, int Nom, DP gwidth, DP normalization, DP denom_sum_K); - DP Smoothen_RAW_into_SF (string prefix, Vect rawfilename, Vect weight, int iKmin, int iKmax, int DiK, - DP ommin, DP ommax, int Nom, DP gwidth, DP normalization, DP denom_sum_K); - //DP Smoothen_RAW_into_ASF (string prefix, int iKmin, int iKmax, DP ommin, DP ommax, int Nom, DP gwidth, - // DP normalization, DP denom_sum_K); // for autocorrelation. Deprecated during ABACUS++T_8, now done automatically within Smoothen_RAW_into_ASF. - void Write_K_File (DP Length, int iKmin, int iKmax); - void Write_Omega_File (int Nout_omega, DP omegamin, DP omegamax); - // Smoothen with gaussian width scaled with two-particle bandwidth - DP Smoothen_RAW_into_SF_LiebLin_Scaled (string prefix, DP L, int N, int iKmin, int iKmax, int DiK, DP ommin, DP ommax, int Nom, DP width, DP normalization); - - //**************************************************************************** - - struct Scan_Info { - - DP sumrule_obtained; - //long long int Nfull; - DP Nfull; // dimensionality of (sub)Hilbert space considered - long long int Ninadm; - long long int Ndata; - long long int Ndata_conv; - long long int Ndata_conv0; - //long long int CPU_ticks; - //long long int CPU_ticks_TOT; // including refine runs - double TT; // total computation time in seconds - - public: - Scan_Info(); // constructor, puts everything to zero - //Scan_Info (DP sr, long long int Nf, long long int Ni, long long int Nd, long long int Ndc, long long int Ndc0, long long int t); - Scan_Info (DP sr, DP Nf, long long int Ni, long long int Nd, long long int Ndc, long long int Ndc0, double t); - - void Save (const char* outfile_Cstr); - void Load (const char* infile_Cstr); - - inline Scan_Info& operator = (const Scan_Info& ref_info) - { - sumrule_obtained = ref_info.sumrule_obtained; - Nfull = ref_info.Nfull; - Ninadm = ref_info.Ninadm; - Ndata = ref_info.Ndata; - Ndata_conv = ref_info.Ndata_conv; - Ndata_conv0 = ref_info.Ndata_conv0; - //CPU_ticks = ref_info.CPU_ticks; - //CPU_ticks_TOT = ref_info.CPU_ticks_TOT; - TT = ref_info.TT; - - return(*this); - } - - inline Scan_Info& operator+= (const Scan_Info& ref_info) - { - if (this != &ref_info) { - sumrule_obtained += ref_info.sumrule_obtained; - Nfull += ref_info.Nfull; - Ninadm += ref_info.Ninadm; - Ndata += ref_info.Ndata; - Ndata_conv += ref_info.Ndata_conv; - Ndata_conv0 += ref_info.Ndata_conv0; - //CPU_ticks += ref_info.CPU_ticks; - //CPU_ticks_TOT += ref_info.CPU_ticks_TOT; - TT += ref_info.TT; - } - - return(*this); - } - - inline Scan_Info& operator-= (const Scan_Info& ref_info) - { - if (this != &ref_info) { - sumrule_obtained -= ref_info.sumrule_obtained; - Nfull -= ref_info.Nfull; - Ninadm -= ref_info.Ninadm; - Ndata -= ref_info.Ndata; - Ndata_conv -= ref_info.Ndata_conv; - Ndata_conv0 -= ref_info.Ndata_conv0; - //CPU_ticks -= ref_info.CPU_ticks; - //CPU_ticks_TOT -= ref_info.CPU_ticks_TOT; - TT -= ref_info.TT; - } - - return(*this); - } - - }; - - std::ostream& operator<< (std::ostream& s, const Scan_Info& info); - - template - Scan_Info General_Scan (char whichDSF, int iKmin, int iKmax, int iKmod, DP kBT, Tstate& AveragingState, Tstate& SeedScanState, - string defaultScanStatename, int Max_Secs, DP target_sumrule, bool refine, int paralevel, Vect rank, Vect nr_processors); - - - //**************************************************************************** - - // Functions in src/SCAN/Descendents.cc: - /* - struct Descendent_Data { - - Vect label; - Vect type; - - Descendent_Data(); - - }; - */ - //Vect Descendents (const LiebLin_Bethe_State& ScanState, const LiebLin_Bethe_State& OriginState); - //Vect Descendents (const Heis_Bethe_State& ScanState, const Heis_Bethe_State& OriginState); - Vect Descendents (const LiebLin_Bethe_State& ScanState, const LiebLin_Bethe_State& OriginState, int type_required); - Vect Descendents (const Heis_Bethe_State& ScanState, const Heis_Bethe_State& OriginState, int type_required); - //Descendent_Data Descendents (const LiebLin_Bethe_State& ScanState, const LiebLin_Bethe_State& OriginState, int type_required); - //Descendent_Data Descendents (const Heis_Bethe_State& ScanState, const Heis_Bethe_State& OriginState, int type_required); - - //**************************************************************************** - /* DEPRECATED IN ABACUS++G_7 - struct Scan_Thread_List { - - int dim; // Dimension of vectors - int nthreads_tot; // Number of entries used; must be <= dim - int nthreads_done; // how many threads have already been processed - - ////Vect_DP omega; - //Vect omega; - //Vect_INT iK; - //Vect_DP abs_data_value; // Measure used to optimize scanning. This can be either the energy ('Z'), MEsq, omega * MEsq, ... - Vect abs_data_value; // Measure used to optimize scanning. This can be either the energy ('Z'), MEsq, omega * MEsq, ... - Vect label; - //Vect sector_lowest_raisable; - Vect type; // which type of descendent is needed: 0 == same nr of ph exc, 1 == one more ph exc. - Vect isdone; // whether the thread has been processed or not - - Scan_Thread_List (); // - Scan_Thread_List (int Nentries); - - bool Increase_Size (int nr_to_add); // resizes the vectors to accommodate up to nr_to_add additional entries - - //void Include_Thread (DP omega_ref, int iK_ref, DP abs_data_value_ref, string label_ref, int type_ref); - void Include_Thread (DP abs_data_value_ref, string label_ref, int type_ref); - void Order_in_abs_data_value (); // orders in decreasing abs_data_value, for correlation functions - //void Order_in_omega (); // orders in increasing omega, for partition function - //DP Highest_abs_data_value_ordered (DP omega_MIN, DP omega_MAX); // returns highest abs_data_value in window omega_MIN to omega_MAX, assuming list is ordered - //DP Highest_abs_data_value (DP omega_MIN, DP omega_MAX); // returns highest abs_data_value in window omega_MIN to omega_MAX - DP Highest_abs_data_value (); // returns highest abs_data_value - DP kth_highest_abs_data_value (int k); - bool Exists_data_value_greater_than (DP value); // whether at least one thread exceeds this value - //DP Lowest_omega (); // returns lowest omega - void Merge (const Scan_Thread_List& reflist); - //void Remove_Threads (int ithread_down, int ithread_up); // DEACTIVATED IN ABACUS++G_2 - //int Remove_Threads (const Vect& threads_done); // DEACTIVATED IN ABACUS++G_2 - void Remove_Done_Threads (); // removes done threads, replaces Remove_Threads (from ABACUS++G_2 onwards) - void Clear (); - void Save (const char* outfile_Cstr); - void Load (const char* thrfile_Cstr); - - inline Scan_Thread_List& operator = (const Scan_Thread_List& reflist) - { - dim = reflist.dim; - nthreads_tot = reflist.nthreads_tot; - nthreads_done = reflist.nthreads_done; - //omega = reflist.omega; - //iK = reflist.iK; - abs_data_value = reflist.abs_data_value; - label = reflist.label; - type = reflist.type; - isdone = reflist.isdone; - - return(*this); - } - - }; - */ - /* - struct Scan_Thread_Set { - - // By convention, a Scan_Thread_Set contains a list of threads which are yet to be descended. - - int nlists = 6400; // number of threads lists, fixed to this number by convention. - DP logscale = (1.0/64) * log(2.0); // each separate list contains threads differing by a scale factor of 2^{1/64} \approx 1.01. - // The number of lists thus covers abs_data_values from 1 down to about 10^-30. - // The list index of a thread is given by -log(data_value)/logscale, and forced between 0 and nlists -1. - Vect dim; - Vect nthreads_tot; - Vect nthreads_done; - - Vect > label; - Vect > type; // which type of descendent is needed - Vect > isdone; // whether the thread has been processed or not - - Scan_Thread_Set (); - - bool Increase_Size (int il, int nr_to_add); - void Include_Thread (DP abs_data_value_ref, string label_ref, int type_ref); - void Merge (const Scan_Thread_Set& refset); - void Remove_Done_Threads (int il); - void Remove_Done_Threads (); - void Clear (); - - void Save (const char* outfile_Cstr); - void Load (const char* thrfile_Cstr); - }; - */ - - - struct Scan_Thread { - - string label; - int type; - - Scan_Thread (); - Scan_Thread (string label_ref, int type_ref) { - label = label_ref; - type = type_ref; - } - - Scan_Thread& operator= (const Scan_Thread& RefThread); - }; - - - struct Scan_Thread_Data { - - // By convention, a Scan_Thread_Data object handles a list of threads which are yet to be descended. - // Improvement on Scan_Thread_Set used up to ABACUS++G_7, saving data to disk instead of holding it in memory. - - int nlists = 6400; // number of threads lists, fixed to this number by convention. - DP logscale = (1.0/64) * log(2.0); // each separate list contains threads differing by a scale factor of 2^{1/64} \approx 1.01. - //int nlists = 1600; // number of threads lists, fixed to this number by convention. - //DP logscale = (1.0/16) * log(2.0); // each separate list contains threads differing by a scale factor of 2^{1/64} \approx 1.01. - // The number of lists thus covers abs_data_values from 1 down to about 10^-30. - // The list index of a thread is given by -log(data_value)/logscale, and forced between 0 and nlists -1. - - string thrdir_name; // directory in which threads files are saved. - - Vect nthreads_total; - - Vect nthreads_on_disk; - int lowest_il_with_nthreads_neq_0; - - // In-memory storage, for adding threads efficiently without constantly writing to disk - // These objects are saved to disk when Next_Scan_Threads are called. - Vect dim; - Vect nthreads_in_memory; - Vect > label; - Vect > type; // which type of descendent is needed - - Vect filename; - //Vect file; - //Vect file_is_open; - - Scan_Thread_Data (); - Scan_Thread_Data (string thrdir_name_ref, bool refine); - ~Scan_Thread_Data (); - - bool Increase_Memory_Size (int il, int nr_to_add); - void Include_Thread (DP abs_data_value_ref, string label_ref, int type_ref); - void Include_Thread (int il, string label_ref, int type_ref); - - Vect Extract_Next_Scan_Threads (); // returns a vector of the threads that are next in line. By defn, all threads with index il == lowest_il_with_nthreads_neq_0. These are removed from the object. - Vect Extract_Next_Scan_Threads (int min_nr); // as above, but returns a minimum of min_nr threads. - - - void Flush_to_Disk (int il); - void Save (); - void Load (); - }; - - - - //**************************************************************************** - - // To populate a list of states for scanning: - - inline void Scan_for_Possible_Bases (const Vect SeedNrap, const Vect Str_L, - int Mdown_remaining, Vect& possible_base_label, int& nfound, int nexc_max_used, - int base_level_to_scan, Vect& Nrapidities) - { - if (Mdown_remaining < 0) { JSCerror("Scan_for_Possible_Bases: shouldn't be here..."); } // reached inconsistent point - - //cout << "Called Scan_for_Possible_Bases with Mdown_remaining = " << Mdown_remaining - //<< "\t" << possible_base_label << "\tnfound " << nfound << "\tnexc_max_used " << nexc_max_used - //<< "\tbase_level_to_scan " << base_level_to_scan << "\tNrap " << Nrapidities << endl; - - if (base_level_to_scan == 0) { - if (Str_L[0] != 1) JSCerror("Str_L[0] != 1 in JSC_Scan.h Scan_for_Possible_Bases."); - Nrapidities[0] = Mdown_remaining; - - // Set label: - stringstream M0out; - M0out << Nrapidities[0]; - possible_base_label[nfound] = M0out.str(); - for (int itype = 1; itype < Nrapidities.size(); ++itype) - if (Nrapidities[itype] > 0) { - possible_base_label[nfound] += TYPESEP; - stringstream typeout; - typeout << itype; - possible_base_label[nfound] += typeout.str(); - possible_base_label[nfound] += EXCSEP; - stringstream Mout; - Mout << Nrapidities[itype]; - possible_base_label[nfound] += Mout.str(); - } - nfound++; - } - - else { - // Preserve the number of strings at this level as compared to SeedState: - Nrapidities[base_level_to_scan] = SeedNrap[base_level_to_scan]; - if (Mdown_remaining - Str_L[base_level_to_scan] * Nrapidities[base_level_to_scan] >= 0) - Scan_for_Possible_Bases (SeedNrap, Str_L, Mdown_remaining - Str_L[base_level_to_scan] * Nrapidities[base_level_to_scan], - possible_base_label, nfound, nexc_max_used, base_level_to_scan - 1, Nrapidities); - - // Reduce number of strings at this level as compared to SeedState: - //for (int i = 1; i <= JSC::min(SeedNrap[base_level_to_scan], (Str_L[base_level_to_scan] == 0 ? 0 : nexc_max_used/Str_L[base_level_to_scan])); ++i) { - for (int i = 1; i <= JSC::min(SeedNrap[base_level_to_scan], nexc_max_used/Str_L[base_level_to_scan]); ++i) { - Nrapidities[base_level_to_scan] = SeedNrap[base_level_to_scan] - i; - if (Mdown_remaining - Str_L[base_level_to_scan] * Nrapidities[base_level_to_scan] >= 0) - Scan_for_Possible_Bases (SeedNrap, Str_L, Mdown_remaining - Str_L[base_level_to_scan] * Nrapidities[base_level_to_scan], - possible_base_label, nfound, nexc_max_used - i*Str_L[base_level_to_scan], base_level_to_scan - 1, Nrapidities); - } - // Increase the number of strings at this level as compared to SeedState: - for (int i = 1; i <= JSC::min(Mdown_remaining/Str_L[base_level_to_scan], nexc_max_used/Str_L[base_level_to_scan]); ++i) { - Nrapidities[base_level_to_scan] = SeedNrap[base_level_to_scan] + i; - if (Mdown_remaining - Str_L[base_level_to_scan] * Nrapidities[base_level_to_scan] >= 0) - Scan_for_Possible_Bases (SeedNrap, Str_L, Mdown_remaining - Str_L[base_level_to_scan] * Nrapidities[base_level_to_scan], - possible_base_label, nfound, nexc_max_used - i*Str_L[base_level_to_scan], base_level_to_scan - 1, Nrapidities); - } - } - } - - - inline Vect Possible_Bases (const Vect SeedNrap, const Vect Str_L, int Mdown)//const Heis_Bethe_State& SeedState) - { - //int nexc_max_used = JSC::min(NEXC_MAX_HEIS, 2*(Mdown/2)); // since each inner sector can contain at most N/2 holes. - int nexc_max_used = NEXC_MAX_HEIS; - - Vect possible_base_label (1000); - int nfound = 0; - Vect Nrapidities = SeedNrap; - int Mdown_remaining = Mdown; - - Scan_for_Possible_Bases (SeedNrap, Str_L, Mdown_remaining, possible_base_label, nfound, nexc_max_used, SeedNrap.size() - 1, Nrapidities); - - // Copy results into a clean vector: - Vect possible_base_label_found (nfound); - for (int i = 0; i < nfound; ++i) possible_base_label_found[i] = possible_base_label[i]; - - //cout << "In Possible_Bases: possible_base_label_found = " << possible_base_label_found << endl; - - return(possible_base_label_found); - } - - - - - - - - - //**************************************************************************** - - template - class Scan_State_List { - - public: - int ndef; - Vect State; - Vect base_label; - Vect info; // info for base and type of State[n] - //Vect descended; // true only if base has been descended - Vect flag_for_scan; // set to true, next round of scanning will use this base/type - Vect scan_attempted; // whether this has already been attempted - - public: - inline Scan_State_List (char whichDSF, const Tstate& SeedScanState); - - public: - inline Tstate& Return_State (string base_label_ref); // returns a state corresponding to same base and type - inline void Populate_List (char whichDSF, const Tstate& SeedScanState); // creates all types of states containing up to nexc_max excitations - inline void Include_Info (Scan_Info& info_to_add, string base_label_ref); - inline void Raise_Scanning_Flags (DP threshold); // checks whether base/type should be scanned based on simpler base/type combinations - - inline void Order_in_SRC (); - inline void Save_Info (const char* sumfile_Cstr); - inline void Load_Info (const char* sumfile_Cstr); - }; - - // Do the explicit class specializations: - - template<> - //inline Scan_State_List::Scan_State_List (char whichDSF, const LiebLin_Bethe_State& RefState) - inline Scan_State_List::Scan_State_List (char whichDSF, const LiebLin_Bethe_State& SeedScanState) - : ndef(0), State(Vect(MAX_STATE_LIST_SIZE)), base_label(Vect(MAX_STATE_LIST_SIZE)), - info(Vect(MAX_STATE_LIST_SIZE)), flag_for_scan(Vect(false, MAX_STATE_LIST_SIZE)), - scan_attempted(Vect(false, MAX_STATE_LIST_SIZE)) - { - //if (whichDSF == 'Z' || whichDSF == 'd' || whichDSF == 'q' || whichDSF == '1') - //State[0] = LiebLin_Bethe_State (RefState.c_int, RefState.L, RefState.N); - //else if (whichDSF == 'g') State[0] = LiebLin_Bethe_State (RefState.c_int, RefState.L, RefState.N + 1); - //else if (whichDSF == 'o') State[0] = LiebLin_Bethe_State (RefState.c_int, RefState.L, RefState.N - 1); - //else JSCerror("Unknown whichDSF in Scan_State_List - //inline Scan_State_List::Scan_State_List (char whichDSF, const XXZ_Bethe_State& RefState) - inline Scan_State_List::Scan_State_List (char whichDSF, const XXZ_Bethe_State& SeedScanState) - : ndef(0), State(Vect(MAX_STATE_LIST_SIZE)), base_label(Vect(MAX_STATE_LIST_SIZE)), - info(Vect(MAX_STATE_LIST_SIZE)), flag_for_scan(Vect(false, MAX_STATE_LIST_SIZE)), - scan_attempted(Vect(false, MAX_STATE_LIST_SIZE)) - { - //if (whichDSF == 'Z' || whichDSF == 'z') State[0] = XXZ_Bethe_State(RefState.chain, RefState.base.Mdown); - //else if (whichDSF == 'm') State[0] = XXZ_Bethe_State(RefState.chain, RefState.base.Mdown - 1); - //else if (whichDSF == 'p') State[0] = XXZ_Bethe_State(RefState.chain, RefState.base.Mdown + 1); - //else JSCerror("Unknown whichDSF in Scan_State_List - //inline Scan_State_List::Scan_State_List (char whichDSF, const XXX_Bethe_State& RefState) - inline Scan_State_List::Scan_State_List (char whichDSF, const XXX_Bethe_State& SeedScanState) - : ndef(0), State(Vect(MAX_STATE_LIST_SIZE)), base_label(Vect(MAX_STATE_LIST_SIZE)), - info(Vect(MAX_STATE_LIST_SIZE)), flag_for_scan(Vect(false, MAX_STATE_LIST_SIZE)), - scan_attempted(Vect(false, MAX_STATE_LIST_SIZE)) - { - //if (whichDSF == 'Z' || whichDSF == 'z' || whichDSF == 'a' || whichDSF == 'q') State[0] = XXX_Bethe_State(RefState.chain, RefState.base.Mdown); - //else if (whichDSF == 'm' || whichDSF == 'b') State[0] = XXX_Bethe_State(RefState.chain, RefState.base.Mdown - 1); - //else if (whichDSF == 'p') State[0] = XXX_Bethe_State(RefState.chain, RefState.base.Mdown + 1); - //else if (whichDSF == 'c') State[0] = XXX_Bethe_State(RefState.chain, RefState.base.Mdown - 2); - //else JSCerror("Unknown whichDSF in Scan_State_List - //inline Scan_State_List::Scan_State_List (char whichDSF, const XXZ_gpd_Bethe_State& RefState) - inline Scan_State_List::Scan_State_List (char whichDSF, const XXZ_gpd_Bethe_State& SeedScanState) - : ndef(0), State(Vect(MAX_STATE_LIST_SIZE)), base_label(Vect(MAX_STATE_LIST_SIZE)), - info(Vect(MAX_STATE_LIST_SIZE)), flag_for_scan(Vect(false, MAX_STATE_LIST_SIZE)), - scan_attempted(Vect(false, MAX_STATE_LIST_SIZE)) - { - //if (whichDSF == 'Z' || whichDSF == 'z') State[0] = XXZ_gpd_Bethe_State(RefState.chain, RefState.base.Mdown); - //else if (whichDSF == 'm') State[0] = XXZ_gpd_Bethe_State(RefState.chain, RefState.base.Mdown - 1); - //else if (whichDSF == 'p') State[0] = XXZ_gpd_Bethe_State(RefState.chain, RefState.base.Mdown + 1); - //else JSCerror("Unknown whichDSF in Scan_State_List - inline Scan_State_List::Scan_State_List (char whichDSF, const ODSLF_XXZ_Bethe_State& RefState) - : ndef(0), State(Vect(MAX_STATE_LIST_SIZE)), base_label(Vect(MAX_STATE_LIST_SIZE)), - info(Vect(MAX_STATE_LIST_SIZE)), flag_for_scan(Vect(false, MAX_STATE_LIST_SIZE)), - scan_attempted(Vect(false, MAX_STATE_LIST_SIZE)) - { - if (whichDSF == 'Z' || whichDSF == 'z') State[0] = ODSLF_XXZ_Bethe_State(RefState.chain, RefState.base.Mdown); - else if (whichDSF == 'm') State[0] = ODSLF_XXZ_Bethe_State(RefState.chain, RefState.base.Mdown - 1); - else if (whichDSF == 'p') State[0] = ODSLF_XXZ_Bethe_State(RefState.chain, RefState.base.Mdown + 1); - else JSCerror("Unknown whichDSF in Scan_State_List - inline LiebLin_Bethe_State& Scan_State_List::Return_State (string base_label_ref) - { - int n = 0; - while (n < ndef && base_label_ref.compare(base_label[n]) != 0) n++; - - if (n == ndef) { - State[n] = State[0]; - base_label[n] = base_label_ref; - info[n].Nfull = 1LL; // Nfull not definable for LiebLin - ndef++; - } - - return(State[n]); - } - - template<> - inline XXZ_Bethe_State& Scan_State_List::Return_State (string base_label_ref) - { - int n = 0; - while (n < ndef && base_label_ref.compare(base_label[n]) != 0) n++; - - if (n == ndef) { - Heis_Base checkbase (State[0].chain, base_label_ref); - State[n] = XXZ_Bethe_State (State[0].chain, checkbase); - info[n].Nfull = checkbase.dimH; - ndef++; - } - - return(State[n]); - } - - template<> - inline XXX_Bethe_State& Scan_State_List::Return_State (string base_label_ref) - { - int n = 0; - while (n < ndef && base_label_ref.compare(base_label[n]) != 0) n++; - - if (n == ndef) { - Heis_Base checkbase (State[0].chain, base_label_ref); - State[n] = XXX_Bethe_State (State[0].chain, checkbase); - info[n].Nfull = checkbase.dimH; - ndef++; - } - - return(State[n]); - } - - template<> - inline XXZ_gpd_Bethe_State& Scan_State_List::Return_State (string base_label_ref) - { - int n = 0; - while (n < ndef && base_label_ref.compare(base_label[n]) != 0) n++; - - if (n == ndef) { - Heis_Base checkbase (State[0].chain, base_label_ref); - State[n] = XXZ_gpd_Bethe_State (State[0].chain, checkbase); - info[n].Nfull = checkbase.dimH; - ndef++; - } - - return(State[n]); - } - - /* - template<> - inline ODSLF_XXZ_Bethe_State& Scan_State_List::Return_State (long long int base_id_ref, long long int type_id_ref) - { - int n = 0; - while (n < ndef && !(base_id_ref == State[n].base_id && type_id_ref == State[n].type_id)) n++; - - if (n == ndef) { - State[n] = ODSLF_XXZ_Bethe_State (State[0].chain, base_id_ref, type_id_ref); - info[n].Nfull = State[n].maxid + 1LL; - ndef++; - } - - return(State[n]); - } - */ - - template<> - //inline void Scan_State_List::Populate_List (char whichDSF, const LiebLin_Bethe_State& RefScanState) - inline void Scan_State_List::Populate_List (char whichDSF, const LiebLin_Bethe_State& SeedScanState) - { - // For LiebLin_Bethe_State: only one base is used, so there is only one state here. - - if (ndef != 0) JSCerror("Please only populate a virgin Scan_State_List."); - - stringstream baselabel; - baselabel << State[0].N; - base_label[0] = baselabel.str(); - stringstream label0; - label0 << State[0].N << LABELSEP << JSCcoding[0] << LABELSEP;//"_0_"; - //State[0].Set_to_Label (label0.str(), RefScanState.Ix2); - State[0].Set_to_Label (label0.str(), SeedScanState.Ix2); - info[0].Nfull = 1LL; // Nfull not definable for LiebLin - ndef = 1; - } - /* - template<> - //inline void Scan_State_List::Populate_List (char whichDSF, const XXZ_Bethe_State& RefScanState) - inline void Scan_State_List::Populate_List_pre_plusplusG_8 (char whichDSF, const XXZ_Bethe_State& SeedScanState) - { - // creates all types of states containing up to nexc_max excitations - - if (ndef != 0) JSCerror("Please only populate a virgin Scan_State_List."); - - //cout << "In Populate_List: " << State[0] << endl; - - //Vect bases_id = State[0].chain.Possible_Bases (State[0].base.Mdown); // returns a vector of possible bases - //cout << "Mdown = " << State[0].base.Mdown << "\tPossible bases size: " << bases_id.size() << "\tPossible bases: " << bases_id << endl; - Vect bases_label = State[0].chain.Possible_Bases (State[0].base.Mdown); // returns a vector of possible bases - //cout << "Mdown = " << State[0].base.Mdown << "\tPossible bases size: " << bases_label.size() << "\tPossible bases: " << bases_label << endl; - - - for (int ib = 0; ib < bases_label.size(); ++ib) { - - //cout << "ib = " << ib << "\tlabel " << bases_label[ib] << endl; - Heis_Base checkbase (State[0].chain, bases_label[ib]); - //cout << "Done building base for label " << bases_label[ib] << endl; - - State[ndef] = XXZ_Bethe_State (State[0].chain, checkbase); - base_label[ndef] = bases_label[ib]; - info[ndef].Nfull = 1LL; - ndef++; - if (ndef >= MAX_STATE_LIST_SIZE) JSCerror("Increase number of elements in ScanStateList."); - } - } - */ - - /* - // ++G_7 versions: - template<> - //inline void Scan_State_List::Populate_List (char whichDSF, const XXZ_Bethe_State& RefScanState) - inline void Scan_State_List::Populate_List (char whichDSF, const XXZ_Bethe_State& SeedScanState) - { - // creates all types of states containing up to nexc_max excitations - - if (ndef != 0) JSCerror("Please only populate a virgin Scan_State_List."); - - //cout << "In Populate_List: " << State[0] << endl; - - //Vect bases_id = State[0].chain.Possible_Bases (State[0].base.Mdown); // returns a vector of possible bases - //cout << "Mdown = " << State[0].base.Mdown << "\tPossible bases size: " << bases_id.size() << "\tPossible bases: " << bases_id << endl; - Vect bases_label = State[0].chain.Possible_Bases (State[0].base.Mdown); // returns a vector of possible bases - //cout << "Mdown = " << State[0].base.Mdown << "\tPossible bases size: " << bases_label.size() << "\tPossible bases: " << bases_label << endl; - - - for (int ib = 0; ib < bases_label.size(); ++ib) { - - //cout << "ib = " << ib << "\tlabel " << bases_label[ib] << endl; - Heis_Base checkbase (State[0].chain, bases_label[ib]); - //cout << "Done building base for label " << bases_label[ib] << endl; - - State[ndef] = XXZ_Bethe_State (State[0].chain, checkbase); - base_label[ndef] = bases_label[ib]; - info[ndef].Nfull = 1LL; - ndef++; - if (ndef >= MAX_STATE_LIST_SIZE) JSCerror("Increase number of elements in ScanStateList."); - } - } - - template<> - //inline void Scan_State_List::Populate_List (char whichDSF, const XXX_Bethe_State& RefScanState) - inline void Scan_State_List::Populate_List (char whichDSF, const XXX_Bethe_State& SeedScanState) - { - // creates all types of states containing up to nexc_max excitations - - if (ndef != 0) JSCerror("Please only populate a virgin Scan_State_List."); - - //cout << "In Populate_List: " << State[0] << endl; - - // To take infinite rapidities into account, we use intermediate states with up to 2 less finite rapidities (1 for Szz, 2 for Spm) - int nrinfrapmax = 0; - if (whichDSF == 'z') nrinfrapmax = 1; - else if (whichDSF == 'p') nrinfrapmax = JSC::min(2, SeedScanState.base.Mdown); - - //if (whichDSF == 'z' && RefScanState.chain.Nsites == 2*RefScanState.base.Mdown) - //if (whichDSF == 'z' && SeedScanState.chain.Nsites == 2*SeedScanState.base.Mdown) - //JSCerror("Szz at zero field for XXX is simply Smp/2. Compute the latter instead."); - //if (whichDSF == 'p' && RefScanState.chain.Nsites == 2*(RefScanState.base.Mdown + 1)) - //if (whichDSF == 'p' && SeedScanState.chain.Nsites/2 <= SeedScanState.base.Mdown) - //JSCerror("Spm for XXX at M >= N/2 is not implemented."); - - for (int nrinfrap = 0; nrinfrap <= nrinfrapmax; ++nrinfrap) { - - //Vect bases_id = State[0].chain.Possible_Bases (State[0].base.Mdown); // returns a vector of possible bases - Vect bases_label = State[0].chain.Possible_Bases (State[0].base.Mdown - nrinfrap); // returns a vector of possible bases - - //cout << "Mdown = " << State[0].base.Mdown << "\tPossible bases size: " << bases_id.size() << "\tPossible bases: " << bases_id << endl; - - for (int ib = 0; ib < bases_label.size(); ++ib) { - - Heis_Base checkbase (State[0].chain, bases_label[ib]); - - State[ndef] = XXX_Bethe_State (State[0].chain, checkbase); - base_label[ndef] = bases_label[ib]; - //cout << "nrinfrap = " << nrinfrap << "\tIncluding base " << base_label[ndef] << endl; - info[ndef].Nfull = 1LL; - ndef++; - if (ndef >= MAX_STATE_LIST_SIZE) JSCerror("Increase number of elements in ScanStateList."); - } - } // for nrinfrap - //cout << "Done populating." << endl; - } - - template<> - //inline void Scan_State_List::Populate_List (char whichDSF, const XXZ_gpd_Bethe_State& RefScanState) - inline void Scan_State_List::Populate_List (char whichDSF, const XXZ_gpd_Bethe_State& SeedScanState) - { - // creates all types of states containing up to nexc_max excitations - - if (ndef != 0) JSCerror("Please only populate a virgin Scan_State_List."); - - //cout << "In Populate_List: " << State[0] << endl; - - //Vect bases_id = State[0].chain.Possible_Bases (State[0].base.Mdown); // returns a vector of possible bases - Vect bases_label = State[0].chain.Possible_Bases (State[0].base.Mdown); // returns a vector of possible bases - - //cout << "Mdown = " << State[0].base.Mdown << "\tPossible bases size: " << bases_id.size() << "\tPossible bases: " << bases_id << endl; - - for (int ib = 0; ib < bases_label.size(); ++ib) { - - Heis_Base checkbase (State[0].chain, bases_label[ib]); - - State[ndef] = XXZ_gpd_Bethe_State (State[0].chain, checkbase); - base_label[ndef] = bases_label[ib]; - info[ndef].Nfull = 1LL; - ndef++; - if (ndef >= MAX_STATE_LIST_SIZE) JSCerror("Increase number of elements in ScanStateList."); - } - } - */ - - // ++G_8 versions: - template<> - //inline void Scan_State_List::Populate_List (char whichDSF, const XXZ_Bethe_State& RefScanState) - inline void Scan_State_List::Populate_List (char whichDSF, const XXZ_Bethe_State& SeedScanState) - { - // creates all types of states containing up to nexc_max excitations - - if (ndef != 0) JSCerror("Please only populate a virgin Scan_State_List."); - - // We assume that SeedScanState has quantum numbers which are set according to the relevant AveragingState. - - // This function creates a list of states with other bases in the vicinity of that of SeedScanState, - // matching the quantum numbers as closely as possible. - - Vect Str_L(SeedScanState.chain.Nstrings); - for (int i = 0; i < SeedScanState.chain.Nstrings; ++i) Str_L[i] = SeedScanState.chain.Str_L[i]; - - // First of all, we create a list of the possible bases themselves. - Vect bases_label = Possible_Bases (SeedScanState.base.Nrap, Str_L, SeedScanState.base.Mdown); // returns a vector of possible bases - - for (int ib = 0; ib < bases_label.size(); ++ib) { - - //cout << "ib = " << ib << "\tlabel " << bases_label[ib] << endl; - Heis_Base checkbase (State[0].chain, bases_label[ib]); - //cout << "Done building base for label " << bases_label[ib] << endl; - - State[ndef] = XXZ_Bethe_State (State[0].chain, checkbase); - State[ndef].Set_to_Closest_Matching_Ix2_fixed_Base (SeedScanState); - State[ndef].Set_Label_from_Ix2 (State[ndef].Ix2); // sets to trivial label for this base - //cout << "\tSet state label to " << State[ndef].label << endl; - //cout << "\tSet state to " << State[ndef] << endl; - base_label[ndef] = bases_label[ib]; - info[ndef].Nfull = State[ndef].base.dimH; - ndef++; - if (ndef >= MAX_STATE_LIST_SIZE) JSCerror("Increase number of elements in ScanStateList."); - } - } - - template<> - //inline void Scan_State_List::Populate_List (char whichDSF, const XXX_Bethe_State& RefScanState) - inline void Scan_State_List::Populate_List (char whichDSF, const XXX_Bethe_State& SeedScanState) - { - // creates all types of states containing up to nexc_max excitations - - if (ndef != 0) JSCerror("Please only populate a virgin Scan_State_List."); - - // We assume that SeedScanState has quantum numbers which are set according to the relevant AveragingState. - - // This function creates a list of states with other bases in the vicinity of that of SeedScanState, - // matching the quantum numbers as closely as possible. - - Vect Str_L(SeedScanState.chain.Nstrings); - for (int i = 0; i < SeedScanState.chain.Nstrings; ++i) Str_L[i] = SeedScanState.chain.Str_L[i]; - - // To take infinite rapidities into account, we use intermediate states with up to 2 less finite rapidities (1 for Szz, 2 for Spm) - int nrinfrapmax = 0; - if (whichDSF == 'z') nrinfrapmax = 1; - else if (whichDSF == 'p') nrinfrapmax = JSC::min(2, SeedScanState.base.Mdown); - - //if (whichDSF == 'z' && RefScanState.chain.Nsites == 2*RefScanState.base.Mdown) - //if (whichDSF == 'z' && SeedScanState.chain.Nsites == 2*SeedScanState.base.Mdown) - //JSCerror("Szz at zero field for XXX is simply Smp/2. Compute the latter instead."); - //if (whichDSF == 'p' && RefScanState.chain.Nsites == 2*(RefScanState.base.Mdown + 1)) - //if (whichDSF == 'p' && SeedScanState.chain.Nsites/2 <= SeedScanState.base.Mdown) - //JSCerror("Spm for XXX at M >= N/2 is not implemented."); - - Vect Nrapmod = SeedScanState.base.Nrap; - - for (int nrinfrap = 0; nrinfrap <= nrinfrapmax; ++nrinfrap) { - - Nrapmod[0] = SeedScanState.base.Nrap[0] - nrinfrap; - if (Nrapmod[0] < 0) JSCerror("Putting too many rapidities at infinity in JSC_Scan.h: Possible_Bases."); - - Vect bases_label = Possible_Bases (Nrapmod, Str_L, SeedScanState.base.Mdown-nrinfrap); // returns a vector of possible bases - - for (int ib = 0; ib < bases_label.size(); ++ib) { - - Heis_Base checkbase (State[0].chain, bases_label[ib]); - - State[ndef] = XXX_Bethe_State (State[0].chain, checkbase); - State[ndef].Set_to_Closest_Matching_Ix2_fixed_Base (SeedScanState); - //State[ndef].Set_Label_from_Ix2 (State[ndef].Ix2); // sets to trivial label for this base - base_label[ndef] = bases_label[ib]; - //cout << "nrinfrap = " << nrinfrap << "\tIncluding base " << base_label[ndef] << endl; - info[ndef].Nfull = State[ndef].base.dimH; - ndef++; - if (ndef >= MAX_STATE_LIST_SIZE) JSCerror("Increase number of elements in ScanStateList."); - } - } // for nrinfrap - //cout << "Done populating." << endl; - } - - template<> - //inline void Scan_State_List::Populate_List (char whichDSF, const XXZ_gpd_Bethe_State& RefScanState) - inline void Scan_State_List::Populate_List (char whichDSF, const XXZ_gpd_Bethe_State& SeedScanState) - { - // creates all types of states containing up to nexc_max excitations - - if (ndef != 0) JSCerror("Please only populate a virgin Scan_State_List."); - - // We assume that SeedScanState has quantum numbers which are set according to the relevant AveragingState. - - // This function creates a list of states with other bases in the vicinity of that of SeedScanState, - // matching the quantum numbers as closely as possible. - - Vect Str_L(SeedScanState.chain.Nstrings); - for (int i = 0; i < SeedScanState.chain.Nstrings; ++i) Str_L[i] = SeedScanState.chain.Str_L[i]; - - // First of all, we create a list of the possible bases themselves. - Vect bases_label = Possible_Bases (SeedScanState.base.Nrap, Str_L, SeedScanState.base.Mdown); // returns a vector of possible bases - - for (int ib = 0; ib < bases_label.size(); ++ib) { - - Heis_Base checkbase (State[0].chain, bases_label[ib]); - - State[ndef] = XXZ_gpd_Bethe_State (State[0].chain, checkbase); - State[ndef].Set_to_Closest_Matching_Ix2_fixed_Base (SeedScanState); - //State[ndef].Set_Label_from_Ix2 (State[ndef].Ix2); // sets to trivial label for this base - base_label[ndef] = bases_label[ib]; - info[ndef].Nfull = State[ndef].base.dimH; - ndef++; - if (ndef >= MAX_STATE_LIST_SIZE) JSCerror("Increase number of elements in ScanStateList."); - } - } - - - /* - template<> - inline void Scan_State_List::Populate_List () - { - // creates all types of states containing up to nexc_max excitations - - if (ndef != 0) JSCerror("Please only populate a virgin Scan_State_List."); - - //cout << "In Populate_List: " << State[0] << endl; - - Vect bases_id = State[0].chain.Possible_Bases (State[0].base.Mdown); // returns a vector of possible bases - - //cout << "Mdown = " << State[0].base.Mdown << "\tPossible bases size: " << bases_id.size() << "\tPossible bases: " << bases_id << endl; - - for (int ib = 0; ib < bases_id.size(); ++ib) { - ODSLF_Base checkbase (State[0].chain, bases_id[ib]); - - Vect types_id = checkbase.Possible_Types (); // returns a vector of possible types - - //cout << "For base_id " << bases_id[ib] << "\t found types " << types_id << endl; - - for (int it = 0; it < types_id.size(); ++it) { - - if (bases_id[ib] < 1000000) { // FUDGE: consider only one-strings - //cout << "Populate list: constructing state: " << bases_id[ib] << "\t" << types_id[it] << endl; - State[ndef] = ODSLF_XXZ_Bethe_State (State[0].chain, bases_id[ib], types_id[it]); - //cout << "Populate list: before setting id: " << endl << State[ndef] << endl; - State[ndef].Set_to_id(0LL); - //cout << "Populate list: after setting id: " << endl << State[ndef] << endl; - info[ndef].Nfull = State[ndef].maxid + 1LL; - ndef++; - if (ndef >= MAX_STATE_LIST_SIZE) JSCerror("Increase number of elements in ScanStateList."); - } - } - - } - } - - */ - - - - template - inline void Scan_State_List::Include_Info (Scan_Info& info_to_add, string base_label_ref) - { - - int n = 0; - while (n < ndef && base_label_ref.compare(base_label[n]) != 0) n++; - - if (n == ndef) { - cout << "ndef = " << ndef << endl; - for (int i = 0; i < ndef; ++i) cout << base_label[i] << "\t"; - cout << endl; - cout << "base_label_ref " << base_label_ref << endl; - JSCerror("Did not find base_label_ref in Scan_State_List::Include_Info."); - } - - info[n] += info_to_add; - return; - } - - - /* - inline int Base_Distance (string base_label_1, string base_label_2) - { - int dist = 0; - - State_Label_Data labeldata1 = Extract_base_label_data (base_label_1); - State_Label_Data labeldata2 = Extract_base_label_data (base_label_2); - - return(dist); - } - */ - /* - inline int Type_Nr_Excitations (string base_label) - { - State_Label_Data labeldata = Extract_base_label_data (base_label); - - return(labeldata.nexc[0]); - } - */ - template - inline void Scan_State_List::Raise_Scanning_Flags (DP threshold) - { - flag_for_scan = true; - } - /* - { - // Reset whole flags vector: - flag_for_scan = false; - - // We first flag all base/types having up to 1 higher string and up to 2 excitations in sectors 0-3 - - for (int n = 0; n < ndef; ++n) - //if (info[n].Nfull == 0LL && Base_Distance (State[n].base_id, 0LL) <= 1 - if (!scan_attempted[n] && Base_Distance (base_label[n], base_label[0]) <= 1 - && Type_Nr_Excitations(base_label[n]) <= 3) - flag_for_scan[n] = true; - - // Second, if one base/type combination has given good results, - // we flag as yet unopened but slightly more complex base/types: - - //cout << "Called Raise_Scanning_Flags: ndef = " << ndef << endl; - - for (int n = 0; n < ndef; ++n) { - //cout << "Base/type " << State[n].base_id << "\t" << State[n].type_id << "\t" << info[n].sumrule_obtained << "\t" << threshold << endl; - if (info[n].Nfull > 0LL && info[n].sumrule_obtained > threshold) { - //cout << "Base/type " << State[n].base_id << "\t" << State[n].type_id << "\tflagging descendents:" << endl; - for (int n2 = 0; n2 < ndef; ++n2) { - //cout << "\tBase/type " << State[n2].base_id << "\t" << State[n2].type_id - // << "\t" << !scan_attempted[n2] << "\t" << (Base_Distance (State[n].base_id, State[n2].base_id) <= 1) - // << "\t" << (Type_Distance (State[n].type_id, State[n2].type_id) <= 2) << endl; - //if (info[n2].Nfull == 0LL && Base_Distance (State[n].base_id, State[n2].base_id) <= 1 - if (!scan_attempted[n2] && Base_Distance (base_label[n], base_label[n2]) <= 1 - && Type_Distance (base_label[n], base_label[n2]) <= 2) { - flag_for_scan[n2] = true; - //cout << "Flagging base/type " << State[n2].base_id << "\t" << State[n2].type_id - // << "\tfrom " << State[n].base_id << "\t" << State[n].type_id - // << "\tBase_Distance " << Base_Distance (State[n].base_id, State[n2].base_id) << "\tType_Distance " << Type_Distance (State[n].type_id, State[n2].type_id) << endl; - } - } - } - } - } - */ - template - inline void Scan_State_List::Order_in_SRC () - { - if (ndef > 0) { - - Vect_INT index(ndef); - for (int i = 0; i < ndef; ++i) index[i] = i; - - Vect sr (ndef); - for (int i = 0; i < ndef; ++i) sr[i] = info[i].sumrule_obtained; - - sr.QuickSort(index, 0, ndef - 1); - - Vect State_ordered(ndef); - Vect base_label_ordered(ndef); - Vect info_ordered(ndef); - Vect flag_for_scan_ordered(ndef); - - // Put data in proper order - for (int i = 0; i < ndef; ++i) { - State_ordered[i] = State[index[ndef - 1 - i] ]; - base_label_ordered[i] = base_label[index[ndef - 1 - i] ]; - info_ordered[i] = info[index[ndef - 1 - i] ]; - flag_for_scan_ordered[i] = flag_for_scan[index[ndef - 1 - i] ]; - } - - // Put back in *this object: - for (int i = 0; i < ndef; ++i) { - State[i] = State_ordered[i]; - base_label[i] = base_label_ordered[i]; - info[i] = info_ordered[i]; - flag_for_scan[i] = flag_for_scan_ordered[i]; - } // The rest are all simply 0. - } - // Done ! - } - - template - inline void Scan_State_List::Save_Info (const char* sumfile_Cstr) - { - ofstream outfile; - - outfile.open(sumfile_Cstr); - if (outfile.fail()) JSCerror("Could not open outfile... "); - - outfile.setf(ios::fixed); - //outfile.setf(ios::showpoint); - outfile.precision(16); - - //outfile << "base\t\tsumrule_obtained\tNfull\tNinadm\tNdata\tconv\tconv0\tT\tTT."; - //outfile << setw(20) << "base" << setw(25) << "sumrule_obtained" << setw(25) << "Nfull" << setw(10) << "Ninadm" << setw(10) << "Ndata" << setw(10) << "conv" << setw(10) << "conv0" << setw(10) << "T" << setw(10) << "TT."; - outfile << setw(20) << "base" << setw(25) << "sumrule_obtained" << setw(25) << "Nfull" << setw(10) << "Ninadm" << setw(10) << "Ndata" << setw(10) << "conv" << setw(10) << "conv0" << setw(10) << "TT."; - - for (int i = 0; i < ndef; ++i) - if (info[i].Nfull > 0.0) { - int TT_hr = int(info[i].TT/3600); - int TT_min = int((info[i].TT - 3600.0*TT_hr)/60); - //outfile << endl << base_label[i] << "\t" << info[i].sumrule_obtained - // << "\t" << info[i].Nfull << "\t" << info[i].Ninadm << "\t" << info[i].Ndata << "\t" << info[i].Ndata_conv << "\t" - // << info[i].Ndata_conv0 << "\t" << info[i].CPU_ticks/CLOCKS_PER_SEC << "\t" << info[i].CPU_ticks_TOT/CLOCKS_PER_SEC; - outfile << endl << setw(20) << base_label[i] << setw(25) << std::fixed << setprecision(20) << info[i].sumrule_obtained; - if (info[i].Nfull < 1.0e+10) outfile << setw(25) << std::fixed << setprecision(0) << info[i].Nfull; - else outfile << setw(25) << std::scientific << setprecision(16) << info[i].Nfull; - //outfile << setw(10) << info[i].Ninadm << setw(10) << info[i].Ndata << setw(10) << info[i].Ndata_conv << setw(10) << info[i].Ndata_conv0 << setw(10) << info[i].CPU_ticks/CLOCKS_PER_SEC << setw(10) << info[i].CPU_ticks_TOT/CLOCKS_PER_SEC; - //outfile << setw(10) << info[i].Ninadm << setw(10) << info[i].Ndata << setw(10) << info[i].Ndata_conv << setw(10) << info[i].Ndata_conv0 << setw(16) << std::fixed << std::showpoint << setprecision(3) << info[i].TT; - outfile << setw(10) << info[i].Ninadm << setw(10) << info[i].Ndata << setw(10) << info[i].Ndata_conv << setw(10) << info[i].Ndata_conv0 << setw(10) << TT_hr << " h " << TT_min << " m " << std::fixed << std::showpoint << setprecision(3) << info[i].TT - 3600.0*TT_hr - 60.0*TT_min << " s"; - } - outfile.close(); - } - - template - inline void Scan_State_List::Load_Info (const char* sumfile_Cstr) - { - ifstream infile; - infile.open(sumfile_Cstr); - if(infile.fail()) { - cout << endl << sumfile_Cstr << endl; - JSCerror("Could not open input file in Scan_State_List::Load_Info."); - } - - // Load first line, containing informative text: - char junk[256]; - infile.getline(junk, 256); - - // Now load the previous info's: - string base_label_ref; - //DP sr_ref, CPU_ref, CPU_TOT_ref; - DP sr_ref; - //long long int Nfull_ref, Ninadm_ref, Ndata_ref, conv_ref, conv0_ref; - DP Nfull_ref; - long long int Ninadm_ref, Ndata_ref, conv_ref, conv0_ref; - DP TT_ref; - int TT_hr, TT_min; - DP TT_sec; - char a; - - while (infile.peek() != EOF) { - //infile >> base_label_ref >> sr_ref >> Nfull_ref >> Ninadm_ref >> Ndata_ref >> conv_ref >> conv0_ref >> CPU_ref >> CPU_TOT_ref; - //infile >> base_label_ref >> sr_ref >> Nfull_ref >> Ninadm_ref >> Ndata_ref >> conv_ref >> conv0_ref >> TT_ref; - infile >> base_label_ref >> sr_ref >> Nfull_ref >> Ninadm_ref >> Ndata_ref >> conv_ref >> conv0_ref >> TT_hr >> a >> TT_min >> a >> TT_sec >> a; - TT_ref = 3600.0 * TT_hr + 60.0* TT_min + TT_sec; - //Scan_Info info_ref (sr_ref, Nfull_ref, Ninadm_ref, Ndata_ref, conv_ref, conv0_ref, CPU_ref); - Scan_Info info_ref (sr_ref, Nfull_ref, Ninadm_ref, Ndata_ref, conv_ref, conv0_ref, TT_ref); - (*this).Include_Info (info_ref, base_label_ref); - } - - infile.close(); - - return; - } - - -} // namespace JSC - -#endif diff --git a/include/JSC_XXZ_h0.h b/include/JSC_XXZ_h0.h deleted file mode 100644 index cc5e378..0000000 --- a/include/JSC_XXZ_h0.h +++ /dev/null @@ -1,86 +0,0 @@ -/********************************************************** - -This software is part of J.-S. Caux's ABACUS library. - -Copyright (c). - ------------------------------------------------------------ - -File: JSC_XXZ_h0.h - -Purpose: Declares classes for XXZ in zero field: quantum group stuff. - - -***********************************************************/ - -#ifndef _XXZ_h0_ -#define _XXZ_h0_ - -#include "JSC.h" - -//const DP default_req_prec = 1.0e-14; -//const int default_max_rec = 10; - -namespace JSC { - - /* - inline DP Integrand_xi_11 (Vect_DP args) - { - // args[0] corresponds to t, args[1] to rho, args[2] to xi - //return((exp(args[0]) * sinh(args[0]) * cos(4.0 * args[0] * args[1])/(2.0 * pow(cosh(args[0]), 2.0)) + 2.0 * pow(sin(2.0 * args[0] * args[1]), 2.0))/args[0]); - return((sinh(args[0]*(1.0 + args[2])) * sinh(args[0]) * cos(4.0 * args[0] * args[1])/(2.0 * sinh(args[0] * args[2]) * pow(cosh(args[0]), 2.0)) - + 2.0 * pow(sin(2.0 * args[0] * args[1]), 2.0))/args[0]); - } - - inline DP Integrand_xi_12 (Vect_DP args) - { - DP expm2t = exp(-2.0*args[0]); - DP expm2txi = exp(-2.0*args[0]*args[2]); - //return(cos(4.0 * args[0] * args[1]) * expm2t * (3.0 + expm2t)/ (args[0] * (1.0 + expm2t) * (1.0 + expm2t))); - return(cos(4.0 * args[0] * args[1]) * (expm2t * (3.0 * (1.0 + expm2txi) + expm2t) + expm2txi) / (args[0] * (1.0 - expm2txi) * (1.0 + expm2t) * (1.0 + expm2t))); - } - */ - /* - inline DP Integrand_xi_2 (Vect_DP args) - { - DP answer = 0.0; - if (args[0] < 1.0) - //answer = exp(args[0]) * pow(sin(2.0 * args[0] * args[1]), 2.0)/(args[0] * sinh(args[0]) * pow(cosh(args[0]), 2.0)); - answer = sinh(args[0] * (args[2] + 1.0)) * pow(sin(2.0 * args[0] * args[1]), 2.0)/(args[0] * sinh(args[2] * args[0]) * sinh(args[0]) * pow(cosh(args[0]), 2.0)); - else if (args[0] >= 1.0) { - DP expm2t = exp(-2.0 * args[0]); - DP expm2txi = exp(-2.0*args[0]*args[2]); - //answer = 8.0 * expm2t * pow(sin(2.0 * args[0] * args[1]), 2.0)/(args[0] * (1.0 - expm2t) * (1.0 + expm2t) * (1.0 + expm2t)); - answer = 8.0 * ((1.0 - expm2t*expm2txi)/(1.0 - expm2t*expm2txi)) * expm2t * - pow(sin(2.0 * args[0] * args[1]), 2.0)/(args[0] * (1.0 - expm2t) * (1.0 + expm2t) * (1.0 + expm2t)); - } - return(answer); - } - */ - - DP I_xi_integral (DP xi, DP rho, DP req_prec, int max_nr_pts); - - - /********************* TWO SPINONS ********************/ - DP Szz_XXZ_h0_2spinons (DP k, DP omega, Integral_table Itable); - DP Szz_XXZ_h0_2spinons (Vect_DP args, Integral_table Itable); - DP Szz_XXZ_h0_2spinons_alt (Vect_DP args, Integral_table Itable); - DP Szz_XXZ_h0_2spinons_omega (Vect_DP args, Integral_table Itable); - DP Szz_XXZ_h0_2spinons_omega_alt (Vect_DP args, Integral_table Itable); - DP Szz_XXZ_h0_2spinons_intomega (Vect_DP args, Integral_table Itable); - DP Szz_XXZ_h0_2spinons_intomega_alt (Vect_DP args, Integral_table Itable); - DP Szz_XXZ_h0_2spinons_check_sumrule (DP Delta, DP req_prec, int max_nr_pts, Integral_table Itable); - DP Szz_XXZ_h0_2spinons_check_sumrule_alt (DP Delta, DP req_prec, int max_nr_pts, Integral_table Itable); - DP Fixed_k_sumrule_omega_Szz_XXZ_h0_N (DP Delta, DP k); - DP GSE_XXZ_h0 (DP Delta, DP req_prec, int max_nr_pts); - DP Fixed_k_sumrule_omega_Szz_XXZ_h0 (DP Delta, DP k, DP req_prec, int max_nr_pts); - DP Szz_XXZ_h0_2spinons_check_fixed_k_Szz_sumrule (DP Delta, DP k, DP req_prec, int max_nr_pts, Integral_table Itable); - DP Szz_XXZ_h0_2spinons_check_fixed_k_Szz_sumrule_alt (DP Delta, DP k, DP req_prec, int max_nr_pts, Integral_table Itable); - - //******************************** Functions to produce files similar to ABACUS ********************************** - void Produce_Szz_XXZ_h0_2spinons_file (DP Delta, int N, int Nomega, DP omegamax, Integral_table Itable); - void Produce_Szz_XXZ_h0_2spinons_fixed_K_file (DP Delta, DP Kover2PI, int Nomega, Integral_table Itable); - -} // namespace JSC - -#endif diff --git a/include/JSC_util.h b/include/JSC_util.h deleted file mode 100644 index b3f5f44..0000000 --- a/include/JSC_util.h +++ /dev/null @@ -1,485 +0,0 @@ -/********************************************************** - -This software is part of J.-S. Caux's ABACUS library. - -Copyright (c). - ------------------------------------------------------------ - -File: JSC_util.h - -Purpose: Defines basic math functions. - -***********************************************************/ - -#ifndef _JSC_UTIL_H_ -#define _JSC_UTIL_H_ - -#include "JSC.h" - -using namespace std; - -typedef double DP; - -// Global constants - -const double PI = 3.141592653589793238462643; -const double sqrtPI = sqrt(PI); -const double twoPI = 2.0*PI; -const double logtwoPI = log(twoPI); -const double Euler_Mascheroni = 0.577215664901532860606; -const double Gamma_min_0p5 = -2.0 * sqrt(PI); -const complex II(0.0,1.0); // Shorthand for i - -const DP MACHINE_EPS = numeric_limits::epsilon(); -const DP MACHINE_EPS_SQ = pow(MACHINE_EPS, 2.0); - -// Now for some basic math utilities: - -namespace JSC { - - // File checks: - - inline bool file_exists (const char* filename) - { - fstream file; - file.open(filename); - bool exists = !file.fail(); - file.close(); - - return(exists); - } - - // Error handler: - - inline void JSCerror (const string error_text) - // my error handler - { - cerr << "Run-time error... " << endl; - cerr << error_text << endl; - cerr << "Exiting to system..." << endl; - exit(1); - } - - struct Divide_by_zero {}; - - - // Basics: min, max, fabs - - template - inline const T max (const T& a, const T& b) { return a > b ? (a) : (b); } - - template - inline const T min (const T& a, const T& b) { return a > b ? (b) : (a); } - - template - inline const T fabs (const T& a) { return a >= 0 ? (a) : (-a); } - - inline long long int pow_lli (const long long int& base, const int& exp) - { - long long int answer = base; - if (exp == 0) answer = 1LL; - else for (int i = 1; i < exp; ++i) answer *= base; - return(answer); - } - - inline unsigned long long int pow_ulli (const unsigned long long int& base, const int& exp) - { - unsigned long long int answer = base; - if (exp == 0) answer = 1ULL; - for (int i = 1; i < exp; ++i) answer *= base; - return(answer); - } - - inline int fact (const int& N) - { - int ans = 0; - - if (N < 0) { - cerr << "Error: factorial of negative number. Exited." << endl; - exit(1); - } - else if ( N == 1 || N == 0) ans = 1; - else ans = N * fact(N-1); - - return(ans); - } - - inline DP ln_fact (const int& N) - { - DP ans = 0.0; - - if (N < 0) { - cerr << "Error: factorial of negative number. Exited." << endl; - exit(1); - } - else if ( N == 1 || N == 0) ans = 0.0; - else ans = log(DP(N)) + ln_fact(N-1); - - return(ans); - } - - inline long long int fact_lli (const int& N) - { - long long int ans = 0; - - if (N < 0) { - cerr << "Error: factorial of negative number. Exited." << endl; - exit(1); - } - else if ( N == 1 || N == 0) ans = 1; - else ans = fact_lli(N-1) * N; - - return(ans); - } - - inline long long int fact_ulli (const int& N) - { - unsigned long long int ans = 0; - - if (N < 0) { - cerr << "Error: factorial of negative number. Exited." << endl; - exit(1); - } - else if ( N == 1 || N == 0) ans = 1; - else ans = fact_ulli(N-1) * N; - - return(ans); - } - - inline int choose (const int& N1, const int& N2) - { - // returns N1 choose N2 - - int ans = 0; - if (N1 < N2) { - cout << "Error: N1 smaller than N2 in choose. Exited." << endl; - exit(1); - } - else if (N1 == N2) ans = 1; - else if (N1 < 12) ans = fact(N1)/(fact(N2) * fact(N1 - N2)); - else { - ans = 1; - int mult = N1; - while (mult > max(N2, N1 - N2)) ans *= mult--; - ans /= fact(min(N2, N1 - N2)); - } - - return(ans); - } - - inline DP ln_choose (const int& N1, const int& N2) - { - // returns the log of N1 choose N2 - - DP ans = 0.0; - if (N1 < N2) { - cout << "Error: N1 smaller than N2 in choose. Exited." << endl; - exit(1); - } - else if (N1 == N2) ans = 0.0; - else ans = ln_fact(N1) - ln_fact(N2) - ln_fact(N1 - N2); - - return(ans); - } - - - inline long long int choose_lli (const int& N1, const int& N2) - { - // returns N1 choose N2 - - long long int ans = 0; - if (N1 < N2) { - cout << "Error: N1 smaller than N2 in choose. Exited." << endl; - exit(1); - } - else if (N1 == N2) ans = 1; - else if (N1 < 12) ans = fact_lli(N1)/(fact_lli(N2) * fact_lli(N1 - N2)); - else { - // Make sure that N2 is less than or equal to N1/2; if not, just switch... - int N2_min = min(N2, N1 - N2); - - ans = 1; - for (int i = 0; i < N2_min; ++i) { - ans *= (N1 - i); - ans /= i + 1; - } - } - - return(ans); - } - - inline unsigned long long int choose_ulli (const int& N1, const int& N2) - { - // returns N1 choose N2 - - unsigned long long int ans = 0; - if (N1 < N2) { - cout << "Error: N1 smaller than N2 in choose. Exited." << endl; - exit(1); - } - else if (N1 == N2) ans = 1; - else if (N1 < 12) ans = fact_ulli(N1)/(fact_ulli(N2) * fact_ulli(N1 - N2)); - else { - // Make sure that N2 is less than or equal to N1/2; if not, just switch... - int N2_min = min(N2, N1 - N2); - - ans = 1; - for (int i = 0; i < N2_min; ++i) { - ans *= (N1 - i); - ans /= i + 1; - } - } - - return(ans); - } - - inline DP SIGN (const DP &a, const DP &b) - { - return b >= 0 ? (a >= 0 ? a : -a) : (a >= 0 ? -a : a); - } - - inline DP sign_of (const DP& a) - { - return (a >= 0.0 ? 1.0 : -1.0); - } - - inline int sgn_int (const int& a) - { - return (a >= 0) ? 1 : -1; - } - - inline int sgn_DP (const DP& a) - { - return (a >= 0) ? 1 : -1; - } - - template - inline void SWAP (T& a, T& b) {T dum = a; a = b; b = dum;} - - inline int kronecker (int a, int b) - { - return a == b ? 1 : 0; - } - - template - inline bool is_nan (const T& a) - { - return(!((a < T(0.0)) || (a >= T(0.0)))); - } - - inline complex atan_cx(const complex& x) - { - return(-0.5 * II * log((1.0 + II* x)/(1.0 - II* x))); - } - - /**************** Gamma function *******************/ - - inline complex ln_Gamma (complex z) - { - // Implementation of Lanczos method with g = 9. - // Coefficients from Godfrey 2001. - - if (real(z) < 0.5) return(log(PI/(sin(PI*z))) - ln_Gamma(1.0 - z)); - - else { - - complex series = 1.000000000000000174663 - + 5716.400188274341379136/z - - 14815.30426768413909044/(z + 1.0) - + 14291.49277657478554025/(z + 2.0) - - 6348.160217641458813289/(z + 3.0) - + 1301.608286058321874105/(z + 4.0) - - 108.1767053514369634679/(z + 5.0) - + 2.605696505611755827729/(z + 6.0) - - 0.7423452510201416151527e-2 / (z + 7.0) - + 0.5384136432509564062961e-7 / (z + 8.0) - - 0.4023533141268236372067e-8 / (z + 9.0); - - return(0.5 * logtwoPI + (z - 0.5) * log(z + 8.5) - (z + 8.5) + log(series)); - } - - return(log(0.0)); // never called - } - - inline complex ln_Gamma_old (complex z) - { - // Implementation of Lanczos method with g = 9. - // Coefficients from Godfrey 2001. - - if (real(z) < 0.5) return(log(PI/(sin(PI*z))) - ln_Gamma(1.0 - z)); - - else { - - int g = 9; - - double p[11] = { 1.000000000000000174663, - 5716.400188274341379136, - -14815.30426768413909044, - 14291.49277657478554025, - -6348.160217641458813289, - 1301.608286058321874105, - -108.1767053514369634679, - 2.605696505611755827729, - -0.7423452510201416151527e-2, - 0.5384136432509564062961e-7, - -0.4023533141268236372067e-8 }; - - complex z_min_1 = z - 1.0; - complex series = p[0]; - for (int i = 1; i < g+2; ++i) - series += p[i]/(z_min_1 + complex(i)); - - return(0.5 * logtwoPI + (z_min_1 + 0.5) * log(z_min_1 + complex(g) + 0.5) - (z_min_1 + complex(g) + 0.5) + log(series)); - } - - return(log(0.0)); // never called - } - - inline complex ln_Gamma_2 (complex z) - { - // Implementation of Lanczos method with g = 7. - - if (real(z) < 0.5) return(log(PI/(sin(PI*z)) - ln_Gamma(1.0 - z))); - - else { - - int g = 7; - - double p[9] = { 0.99999999999980993, 676.5203681218851, -1259.1392167224028, - 771.32342877765313, -176.61502916214059, 12.507343278686905, - -0.13857109526572012, 9.9843695780195716e-6, 1.5056327351493116e-7}; - - complex z_min_1 = z - 1.0; - complex series = p[0]; - for (int i = 1; i < g+2; ++i) - series += p[i]/(z_min_1 + complex(i)); - - return(0.5 * logtwoPI + (z_min_1 + 0.5) * log(z_min_1 + complex(g) + 0.5) - (z_min_1 + complex(g) + 0.5) + log(series)); - } - - return(log(0.0)); // never called - } - - /********** Partition numbers **********/ - - inline long long int Partition_Function (int n) - { - // Returns the value of the partition function p(n), giving the number of partitions of n into integers. - - if (n < 0) JSCerror("Calling Partition_Function for n < 0."); - else if (n == 0 || n == 1) return(1LL); - else if (n == 2) return(2LL); - else if (n == 3) return(3LL); - - else { // do recursion using pentagonal numbers - long long int pn = 0LL; - int pentnrplus, pentnrmin; // pentagonal numbers - for (int i = 1; true; ++i) { - pentnrplus = (i * (3*i - 1))/2; - pentnrmin = (i * (3*i + 1))/2; - //cout << "\ti = " << i << "pnrp = " << pentnrplus << "\tpnrm = " << pentnrmin << endl; - if (n - pentnrplus >= 0) pn += (i % 2 ? 1LL : -1LL) * Partition_Function (n - pentnrplus); - if (n - pentnrmin >= 0) pn += (i % 2 ? 1LL : -1LL) * Partition_Function (n - pentnrmin); - else break; - } - return(pn); - } - return(-1LL); // never called - } - - - /********** Sorting **********/ - - /* - template - void QuickSort (item_type* a, int l, int r) - { - static item_type m; - static int j; - int i; - - if (r > l) { - m = a[r]; i = l-1; j = r; - for (;;) { - while (a[++i] < m); - while (a[--j] > m); - if (i >= j) break; - std::swap(a[i], a[j]); - } - std::swap(a[i], a[r]); - QuickSort(a, l, i-1); - QuickSort(a, i+1, r); - } - } - */ - - template - void QuickSort (T* V, int l, int r) - { - int i = l, j = r; - T pivot = V[l + (r-l)/2]; - - while (i <= j) { - while (V[i] < pivot) i++; - while (V[j] > pivot) j--; - if (i <= j) { - std::swap(V[i],V[j]); - i++; - j--; - } - }; - - if (l < j) QuickSort(V, l, j); - if (i < r) QuickSort(V, i, r); - } - - /* - template - void QuickSort (item_type* a, int* idx, int l, int r) - { - static item_type m; - static int j; - int i; - - if (r > l) { - m = a[r]; i = l-1; j = r; - for (;;) { - while (a[++i] < m); - while (a[--j] > m); - if (i >= j) break; - std::swap(a[i], a[j]); - std::swap(idx[i], idx[j]); - } - std::swap(a[i], a[r]); - std::swap(idx[i], idx[r]); - QuickSort(a, idx, l, i-1); - QuickSort(a, idx, i+1, r); - } - } - */ - template - void QuickSort (T* V, int* index, int l, int r) - { - int i = l, j = r; - T pivot = V[l + (r-l)/2]; - - while (i <= j) { - while (V[i] < pivot) i++; - while (V[j] > pivot) j--; - if (i <= j) { - std::swap(V[i],V[j]); - std::swap(index[i],index[j]); - i++; - j--; - } - }; - - if (l < j) QuickSort(V, index, l, j); - if (i < r) QuickSort(V, index, i, r); - } - - -} // namespace JSC - -#endif // _JS_UTIL_H_ diff --git a/src/BETHE/Base.cc b/src/BETHE/Base.cc index db31676..3ce4016 100644 --- a/src/BETHE/Base.cc +++ b/src/BETHE/Base.cc @@ -1,6 +1,8 @@ /********************************************************** -This software is part of J.-S. Caux's ABACUS++ library. +This software is part of J.-S. Caux's ABACUS library. + +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -10,26 +12,25 @@ Purpose: defines functions in Base class, providing a unified base object for all Bethe Ansatz integrable models. - ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -namespace JSC { +namespace ABACUS { // Function definitions: class Base Base::Base () : Charge(0), Nrap(Vect()), Nraptot(0), Ix2_infty(Vect()), Ix2_max(Vect()), id(0LL) {} - + Base::Base (int N) : Charge(N), Nrap(Vect(N,1)), Nraptot(N), Ix2_infty(Vect(1.0e+100,1)), Ix2_max(Vect(LONG_LONG_MAX, 1)), id(N) {} Base::Base (const Base& RefBase) // copy constructor - : Charge(RefBase.Charge), Nrap(Vect(RefBase.Nrap.size())), Nraptot(RefBase.Nraptot), - Ix2_infty(Vect(RefBase.Ix2_infty.size())), Ix2_max(Vect(RefBase.Ix2_max.size())), id(RefBase.id) + : Charge(RefBase.Charge), Nrap(Vect(RefBase.Nrap.size())), Nraptot(RefBase.Nraptot), + Ix2_infty(Vect(RefBase.Ix2_infty.size())), Ix2_max(Vect(RefBase.Ix2_max.size())), id(RefBase.id) { for (int i = 0; i < Nrap.size(); ++i) { Nrap[i] = RefBase.Nrap[i]; @@ -40,7 +41,7 @@ namespace JSC { /* // DEPRECATED - Base::Base (const Heis_Chain& RefChain, int M) + Base::Base (const Heis_Chain& RefChain, int M) : Charge(M), Nrap(Vect(RefChain.Nstrings)), Nraptot(0), Ix2_infty(Vect(RefChain.Nstrings)), Ix2_max(Vect(RefChain.Nstrings)) { for (int i = 0; i < RefChain.Nstrings; ++i) Nrap[i] = 0; @@ -48,17 +49,17 @@ namespace JSC { Nraptot = 0; for (int i = 0; i < RefChain.Nstrings; ++i) Nraptot += Nrap[i]; - + // The id of this is zero by definition id = 0LL; // Now compute the Ix2_infty numbers - + (*this).Compute_Ix2_limits(RefChain); } */ - Base::Base (const Heis_Chain& RefChain, const Vect& Nrapidities) + Base::Base (const Heis_Chain& RefChain, const Vect& Nrapidities) : Charge(0), Nrap(Nrapidities), Nraptot(0), Ix2_infty(Vect(RefChain.Nstrings)), Ix2_max(Vect(RefChain.Nstrings)), id (0LL) { @@ -66,16 +67,16 @@ namespace JSC { // Check consistency of Nrapidities vector with RefChain //if (RefChain.Nstrings != Nrapidities.size()) cout << "error: Nstrings = " << RefChain.Nstrings << "\tNrap.size = " << Nrapidities.size() << endl; - - if (RefChain.Nstrings != Nrapidities.size()) JSCerror("Incompatible Nrapidities vector used in Base constructor."); - + + if (RefChain.Nstrings != Nrapidities.size()) ABACUSerror("Incompatible Nrapidities vector used in Base constructor."); + int Mcheck = 0; for (int i = 0; i < RefChain.Nstrings; ++i) Mcheck += RefChain.Str_L[i] * Nrap[i]; Charge = Mcheck; - + Nraptot = 0; for (int i = 0; i < RefChain.Nstrings; ++i) Nraptot += Nrap[i]; - + // Compute id id += Nrapidities[0]; long long int factor = 100000LL; @@ -87,10 +88,10 @@ namespace JSC { // Now compute the Ix2_infty numbers (*this).Compute_Ix2_limits(RefChain); - + } - Base::Base (const Heis_Chain& RefChain, long long int id_ref) + Base::Base (const Heis_Chain& RefChain, long long int id_ref) : Charge(0), Nrap(Vect(RefChain.Nstrings)), Nraptot(0), Ix2_infty(Vect(RefChain.Nstrings)), Ix2_max(Vect(RefChain.Nstrings)), id (id_ref) { @@ -108,18 +109,18 @@ namespace JSC { //id = id_ref; //cout << "In Base constructor: id_ref = " << id_ref << " and Nrapidities = " << Nrap << endl; - + // Check consistency of Nrapidities vector with RefChain - //if (RefChain.Nstrings != Nrap.size()) JSCerror("Incompatible Nrapidities vector used in Base constructor."); - + //if (RefChain.Nstrings != Nrap.size()) ABACUSerror("Incompatible Nrapidities vector used in Base constructor."); + int Mcheck = 0; for (int i = 0; i < RefChain.Nstrings; ++i) Mcheck += RefChain.Str_L[i] * Nrap[i]; Charge = Mcheck; - + Nraptot = 0; for (int i = 0; i < RefChain.Nstrings; ++i) Nraptot += Nrap[i]; - + // Now compute the Ix2_infty numbers (*this).Compute_Ix2_limits(RefChain); @@ -138,7 +139,7 @@ namespace JSC { } return(*this); } - + bool Base::operator== (const Base& RefBase) { bool answer = (Nrap == RefBase.Nrap); @@ -159,39 +160,39 @@ namespace JSC { if ((RefChain.Delta > 0.0) && (RefChain.Delta < 1.0)) { // Compute the Ix2_infty numbers - + DP sum1 = 0.0; DP sum2 = 0.0; - + for (int j = 0; j < RefChain.Nstrings; ++j) { - + sum1 = 0.0; - + for (int k = 0; k < RefChain.Nstrings; ++k) { - + sum2 = 0.0; - - sum2 += (RefChain.Str_L[j] == RefChain.Str_L[k]) ? 0.0 : 2.0 * atan(tan(0.25 * PI * (1.0 + RefChain.par[j] * RefChain.par[k]) + + sum2 += (RefChain.Str_L[j] == RefChain.Str_L[k]) ? 0.0 : 2.0 * atan(tan(0.25 * PI * (1.0 + RefChain.par[j] * RefChain.par[k]) - 0.5 * fabs(RefChain.Str_L[j] - RefChain.Str_L[k]) * RefChain.anis)); - sum2 += 2.0 * atan(tan(0.25 * PI * (1.0 + RefChain.par[j] * RefChain.par[k]) + sum2 += 2.0 * atan(tan(0.25 * PI * (1.0 + RefChain.par[j] * RefChain.par[k]) - 0.5 * (RefChain.Str_L[j] + RefChain.Str_L[k]) * RefChain.anis)); - - for (int a = 1; a < JSC::min(RefChain.Str_L[j], RefChain.Str_L[k]); ++a) - sum2 += 2.0 * 2.0 * atan(tan(0.25 * PI * (1.0 + RefChain.par[j] * RefChain.par[k]) + + for (int a = 1; a < ABACUS::min(RefChain.Str_L[j], RefChain.Str_L[k]); ++a) + sum2 += 2.0 * 2.0 * atan(tan(0.25 * PI * (1.0 + RefChain.par[j] * RefChain.par[k]) - 0.5 * (fabs(RefChain.Str_L[j] - RefChain.Str_L[k]) + 2.0*a) * RefChain.anis)); - + sum1 += (Nrap[k] - ((j == k) ? 1 : 0)) * sum2; } - - Ix2_infty[j] = (1.0/PI) * fabs(RefChain.Nsites * 2.0 * atan(tan(0.25 * PI * (1.0 + RefChain.par[j]) + + Ix2_infty[j] = (1.0/PI) * fabs(RefChain.Nsites * 2.0 * atan(tan(0.25 * PI * (1.0 + RefChain.par[j]) - 0.5 * RefChain.Str_L[j] * RefChain.anis)) - sum1); - + } // The Ix2_infty are now set. // Now compute the Ix2_max limits - + for (int j = 0; j < RefChain.Nstrings; ++j) { - + Ix2_max[j] = int(floor(Ix2_infty[j])); // sets basic integer // Reject formally infinite rapidities (i.e. if Delta is root of unity) @@ -205,7 +206,7 @@ namespace JSC { if (!((Nrap[j] + Ix2_max[j]) % 2)) Ix2_max[j] -= 1; while (Ix2_max[j] > RefChain.Nsites) { - Ix2_max[j] -= 2; + Ix2_max[j] -= 2; } } } // if XXZ gapless @@ -213,41 +214,41 @@ namespace JSC { else if (RefChain.Delta == 1.0) { // Compute the Ix2_infty numbers - + int sum1 = 0; - + for (int j = 0; j < RefChain.Nstrings; ++j) { - + sum1 = 0; - + for (int k = 0; k < RefChain.Nstrings; ++k) { - - sum1 += Nrap[k] * (2 * JSC::min(RefChain.Str_L[j], RefChain.Str_L[k]) - ((j == k) ? 1 : 0)); + + sum1 += Nrap[k] * (2 * ABACUS::min(RefChain.Str_L[j], RefChain.Str_L[k]) - ((j == k) ? 1 : 0)); } - + //Ix2_infty[j] = (RefChain.Nsites - 1.0 + 2.0 * RefChain.Str_L[j] - sum1); Ix2_infty[j] = (RefChain.Nsites + 1.0 - sum1); // to get counting right... - + } // The Ix2_infty are now set. - + // Now compute the Ix2_max limits - + for (int j = 0; j < RefChain.Nstrings; ++j) { Ix2_max[j] = int(floor(Ix2_infty[j])); // sets basic integer // Give the correct parity to Ix2_max - + // If Nrap is even, Ix2_max must be odd. If odd, then even. if (!((Nrap[j] + Ix2_max[j]) % 2)) Ix2_max[j] -= 1; // If Ix2_max equals Ix2_infty, we reduce it by 2: - + if (Ix2_max[j] == int(Ix2_infty[j])) Ix2_max[j] -= 2; - + while (Ix2_max[j] > RefChain.Nsites) { - Ix2_max[j] -= 2; + Ix2_max[j] -= 2; } } @@ -256,40 +257,40 @@ namespace JSC { else if (RefChain.Delta > 1.0) { // Compute the Ix2_infty numbers - + int sum1 = 0; - + for (int j = 0; j < RefChain.Nstrings; ++j) { - + sum1 = 0; - + for (int k = 0; k < RefChain.Nstrings; ++k) { - - sum1 += Nrap[k] * (2 * JSC::min(RefChain.Str_L[j], RefChain.Str_L[k]) - ((j == k) ? 1 : 0)); + + sum1 += Nrap[k] * (2 * ABACUS::min(RefChain.Str_L[j], RefChain.Str_L[k]) - ((j == k) ? 1 : 0)); } - + Ix2_infty[j] = (RefChain.Nsites - 1 + 2 * RefChain.Str_L[j] - sum1); - + } // The Ix2_infty are now set. - + // Now compute the Ix2_max limits - + for (int j = 0; j < RefChain.Nstrings; ++j) { - + Ix2_max[j] = int(floor(Ix2_infty[j])); // sets basic integer // Give the correct parity to Ix2_max - + // If Nrap is even, Ix2_max must be odd. If odd, then even. if (!((Nrap[j] + Ix2_max[j]) % 2)) Ix2_max[j] -= 1; - + // If Ix2_max equals Ix2_infty, we reduce it by 2: //if (Ix2_max[j] == Ix2_infty[j]) Ix2_max[j] -= 2; while (Ix2_max[j] > RefChain.Nsites) { - Ix2_max[j] -= 2; + Ix2_max[j] -= 2; } // Fudge, for strings: @@ -304,4 +305,4 @@ namespace JSC { -} // namespace JSC +} // namespace ABACUS diff --git a/src/BETHE/Bethe_State.cc b/src/BETHE/Bethe_State.cc index c0846d4..4367fc7 100644 --- a/src/BETHE/Bethe_State.cc +++ b/src/BETHE/Bethe_State.cc @@ -1,8 +1,8 @@ /********************************************************** -This software is part of J.-S. Caux's ABACUS++ library. +This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -12,18 +12,17 @@ Purpose: defines functions in Bethe_State class, providing a unified object for eigenstates of all Bethe Ansatz integrable models. - - +IN DEVELOPMENT ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -namespace JSC { +namespace ABACUS { Bethe_State::Bethe_State (long long int base_id_ref, long long int type_id_ref, long long int id_ref, long long int maxid_ref) : base_id(base_id_ref), type_id(type_id_ref), id(id_ref), maxid(maxid_ref) {} -} // namespace JSC +} // namespace ABACUS diff --git a/src/BETHE/Offsets.cc b/src/BETHE/Offsets.cc index beaf0b8..dcf44b5 100644 --- a/src/BETHE/Offsets.cc +++ b/src/BETHE/Offsets.cc @@ -1,25 +1,22 @@ /********************************************************** -This software is part of J.-S. Caux's ABACUS++ library. +This software is part of J.-S. Caux's ABACUS library. -Copyright (c) 2006-9. +Copyright (c) J.-S. Caux. ----------------------------------------------------------- File: src/BETHE/Offsets.cc Purpose: defines functions in Offsets class. - - -Last modified: 19/10/2009 ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -namespace JSC { +namespace ABACUS { // Function definitions: class Offsets @@ -31,7 +28,7 @@ namespace JSC { for (int i = 0; i < 2 * base.Nrap.size() + 2; ++i) Tableau[i] = RefOffset.Tableau[i]; } - Offsets::Offsets (const Heis_Base& RefBase, long long int req_type_id) + Offsets::Offsets (const Heis_Base& RefBase, long long int req_type_id) // sets all tableaux to empty ones, with nparticles(req_type_id) at each level { // Build nparticles vector from req_type_id @@ -47,9 +44,9 @@ namespace JSC { // Check if we've got the right vector... long long int idcheck = Offsets_type_id (nparticles); - if (idcheck != req_type_id) JSCerror("idcheck != req_type_id in Offsets constructor."); + if (idcheck != req_type_id) ABACUSerror("idcheck != req_type_id in Offsets constructor."); - (*this) = Offsets(RefBase, nparticles); + (*this) = Offsets(RefBase, nparticles); } Offsets::Offsets (const Heis_Base& RefBase, Vect nparticles) // sets all tableaux to empty ones, with nparticles at each level @@ -58,43 +55,43 @@ namespace JSC { // Checks on nparticles vector: - if (nparticles.size() != 2 * base.Nrap.size() + 2) JSCerror("Wrong nparticles.size in Offsets constructor."); - - //if (base.Nrap[0] != (nparticles[3] + nparticles[2] + base.Mdown - nparticles[0] - nparticles[1])) JSCerror("Wrong Nrap[0] in Offsets constructor."); + if (nparticles.size() != 2 * base.Nrap.size() + 2) ABACUSerror("Wrong nparticles.size in Offsets constructor."); + + //if (base.Nrap[0] != (nparticles[3] + nparticles[2] + base.Mdown - nparticles[0] - nparticles[1])) ABACUSerror("Wrong Nrap[0] in Offsets constructor."); if (nparticles[3] + nparticles[2] != nparticles[0] + nparticles[1]) { cout << nparticles[0] << "\t" << nparticles[1] << "\t" << nparticles[2] << "\t" << nparticles[3] << endl; - JSCerror("Wrong Npar[0-3] in Offsets constructor."); + ABACUSerror("Wrong Npar[0-3] in Offsets constructor."); } - for (int base_level = 1; base_level < base.Nrap.size(); ++ base_level) + for (int base_level = 1; base_level < base.Nrap.size(); ++ base_level) if (base.Nrap[base_level] != nparticles[2*base_level + 2] + nparticles[2*base_level + 3]) { cout << base_level << "\t" << base.Nrap[base_level] << "\t" << nparticles[2*base_level + 2] << "\t" << nparticles[2*base_level + 3] << endl; - JSCerror("Wrong Nrap[] in Offsets constructor."); + ABACUSerror("Wrong Nrap[] in Offsets constructor."); } // nparticles[0,1]: number of holes on R and L side in GS interval - if (nparticles[0] > (base.Nrap[0] + 1)/2) JSCerror("nparticles[0] too large in Offsets constructor."); - if (nparticles[1] > base.Nrap[0]/2) JSCerror("nparticles[1] too large in Offsets constructor."); + if (nparticles[0] > (base.Nrap[0] + 1)/2) ABACUSerror("nparticles[0] too large in Offsets constructor."); + if (nparticles[1] > base.Nrap[0]/2) ABACUSerror("nparticles[1] too large in Offsets constructor."); // nparticles[2,3]: number of particles of type 0 on R and L side out of GS interval - if (nparticles[2] > (base.Ix2_max[0] - base.Nrap[0] + 1)/2) JSCerror("nparticles[2] too large in Offsets constructor."); - if (nparticles[3] > (base.Ix2_max[0] - base.Nrap[0] + 1)/2) JSCerror("nparticles[3] too large in Offsets constructor."); + if (nparticles[2] > (base.Ix2_max[0] - base.Nrap[0] + 1)/2) ABACUSerror("nparticles[2] too large in Offsets constructor."); + if (nparticles[3] > (base.Ix2_max[0] - base.Nrap[0] + 1)/2) ABACUSerror("nparticles[3] too large in Offsets constructor."); for (int base_level = 1; base_level < base.Nrap.size(); ++ base_level) if ((nparticles[2*base_level + 2] > 0 && nparticles[2*base_level + 2] > (base.Ix2_max[base_level] - ((base.Nrap[base_level] + 1) % 2) + 2)/2) //|| (nparticles[2*base_level + 3] > 0 && nparticles[2*base_level + 3] > (base.Ix2_max[base_level] - (base.Nrap[base_level] % 2) - 1)/2)) { - || (nparticles[2*base_level + 3] > 0 + || (nparticles[2*base_level + 3] > 0 && nparticles[2*base_level + 3] > base.Ix2_max[base_level] + 1 - (base.Ix2_max[base_level] - ((base.Nrap[base_level] + 1) % 2) + 2)/2)) { cout << base_level << "\t" << nparticles[2*base_level + 2] << "\t" << (base.Ix2_max[base_level] - ((base.Nrap[base_level] + 1) % 2) + 2)/2 - << "\t" << nparticles[2*base_level + 3] << "\t" << (base.Ix2_max[base_level] - (base.Nrap[base_level] % 2) - 1)/2 + << "\t" << nparticles[2*base_level + 3] << "\t" << (base.Ix2_max[base_level] - (base.Nrap[base_level] % 2) - 1)/2 << "\t" << (nparticles[2*base_level + 2] > 0) << "\t" << (nparticles[2*base_level + 2] > (base.Ix2_max[base_level] - ((base.Nrap[base_level] + 1) % 2) + 2)/2) //<< "\t" << (nparticles[2*base_level + 3] > 0) << "\t" << (nparticles[2*base_level + 3] > (base.Ix2_max[base_level] - (base.Nrap[base_level] % 2) - 1)/2) - << "\t" << (nparticles[2*base_level + 3] > 0) << "\t" + << "\t" << (nparticles[2*base_level + 3] > 0) << "\t" << (nparticles[2*base_level + 3] > base.Ix2_max[base_level] + 1 - (base.Ix2_max[base_level] - ((base.Nrap[base_level] + 1) % 2) + 2)/2) << endl; - JSCerror("nparticles too large in Offsets constructor."); + ABACUSerror("nparticles too large in Offsets constructor."); } - + // Check sum of rapidities // Holes in GS interval @@ -104,14 +101,14 @@ namespace JSC { // Particles of type 0 out of GS interval Tableau[2] = Young_Tableau(nparticles[2], (base.Ix2_max[0] - base.Nrap[0] + 1)/2 - nparticles[2], Tableau[0]); Tableau[3] = Young_Tableau(nparticles[3], (base.Ix2_max[0] - base.Nrap[0] + 1)/2 - nparticles[3], Tableau[2]); - + // Tableaux of index i = 2,...: data about string type i/2-1. for (int base_level = 1; base_level < base.Nrap.size(); ++base_level) { - Tableau[2*base_level + 2] = Young_Tableau(nparticles[2*base_level + 2], + Tableau[2*base_level + 2] = Young_Tableau(nparticles[2*base_level + 2], //(base.Ix2_max[base_level] - ((base.Nrap[base_level]) % 2) + 2)/2 - nparticles[2*base_level + 2], Tableau[2]); //(base.Ix2_max[base_level] - base.Nrap[base_level] % 2 + 2)/2 - nparticles[2*base_level + 2], Tableau[2]); (base.Ix2_max[base_level] - ((base.Nrap[base_level] + 1) % 2))/2 + 1 - nparticles[2*base_level + 2], Tableau[2]); - Tableau[2*base_level + 3] = Young_Tableau(nparticles[2*base_level + 3], + Tableau[2*base_level + 3] = Young_Tableau(nparticles[2*base_level + 3], //(base.Ix2_max[base_level] - base.Nrap[base_level] % 2)/2 - nparticles[2*base_level + 3], Tableau[3]); (base.Ix2_max[base_level] - (base.Nrap[base_level] % 2) - 1)/2 + 1 - nparticles[2*base_level + 3], Tableau[3]); } @@ -147,11 +144,11 @@ namespace JSC { for (int level = 0; level < 4; ++level) { // check fundamental level only //for (int level = 0; level < 2 * base.Nrap.size() + 2; ++level) { // First check whether all rows which exist in both tableaux satisfy rule: - for (int tableau_level = 0; tableau_level < JSC::min(Tableau[level].Nrows, RefOffsets.Tableau[level].Nrows); ++tableau_level) - if (Tableau[level].Row_L[tableau_level] > RefOffsets.Tableau[level].Row_L[tableau_level]) + for (int tableau_level = 0; tableau_level < ABACUS::min(Tableau[level].Nrows, RefOffsets.Tableau[level].Nrows); ++tableau_level) + if (Tableau[level].Row_L[tableau_level] > RefOffsets.Tableau[level].Row_L[tableau_level]) answer = false; // Now check whether there exist extra rows violating rule: - for (int tableau_level = JSC::min(Tableau[level].Nrows, RefOffsets.Tableau[level].Nrows); tableau_level < Tableau[level].Nrows; ++tableau_level) + for (int tableau_level = ABACUS::min(Tableau[level].Nrows, RefOffsets.Tableau[level].Nrows); tableau_level < Tableau[level].Nrows; ++tableau_level) if (Tableau[level].Row_L[tableau_level] > 0) answer = false; } @@ -167,11 +164,11 @@ namespace JSC { for (int level = 0; level < 4; ++level) { // check fundamental level only //for (int level = 0; level < 2 * base.Nrap.size() + 2; ++level) { // First check whether all rows which exist in both tableaux satisfy rule: - for (int tableau_level = 0; tableau_level < JSC::min(Tableau[level].Nrows, RefOffsets.Tableau[level].Nrows); ++tableau_level) - if (Tableau[level].Row_L[tableau_level] < RefOffsets.Tableau[level].Row_L[tableau_level]) + for (int tableau_level = 0; tableau_level < ABACUS::min(Tableau[level].Nrows, RefOffsets.Tableau[level].Nrows); ++tableau_level) + if (Tableau[level].Row_L[tableau_level] < RefOffsets.Tableau[level].Row_L[tableau_level]) answer = false; // Now check whether there exist extra rows violating rule: - for (int tableau_level = JSC::min(Tableau[level].Nrows, RefOffsets.Tableau[level].Nrows); tableau_level < RefOffsets.Tableau[level].Nrows; ++tableau_level) + for (int tableau_level = ABACUS::min(Tableau[level].Nrows, RefOffsets.Tableau[level].Nrows); tableau_level < RefOffsets.Tableau[level].Nrows; ++tableau_level) if (RefOffsets.Tableau[level].Row_L[tableau_level] > 0) answer = false; } @@ -190,13 +187,13 @@ namespace JSC { void Offsets::Set_to_id (long long int idnr) { - // The idnr of the Offset is given by + // The idnr of the Offset is given by // sub_id[0] + (total number of tableaux of type 0) * (sub_id[1] + (total number of tableaux of type 1) * (sub_id[2] + ... // + total number of tableaux of type (2*base.Nrap.size()) * sub_id[2*base.Nrap.size() + 1] if (idnr > maxid) { cout << idnr << "\t" << maxid << endl; - JSCerror("idnr too large in offsets.Set_to_id."); + ABACUSerror("idnr too large in offsets.Set_to_id."); } id = idnr; @@ -223,7 +220,7 @@ namespace JSC { for (int i = 0; i <= 2*base.Nrap.size() + 1; ++i) { //cout << "level = " << i << " Tableau.id = " << sub_id[i] << endl; - if ((Tableau[i].Nrows * Tableau[i].Ncols == 0) && (sub_id[i] != 0)) JSCerror("index too large in offset.Set_to_id."); + if ((Tableau[i].Nrows * Tableau[i].Ncols == 0) && (sub_id[i] != 0)) ABACUSerror("index too large in offset.Set_to_id."); if (Tableau[i].id != sub_id[i]) Tableau[i].Set_to_id(sub_id[i]); } @@ -235,7 +232,7 @@ namespace JSC { void Offsets::Compute_id () { long long int prod_maxid = 1LL; - + id = 0LL; for (int i = 0; i < 2*base.Nrap.size() + 2; ++i) { @@ -251,14 +248,14 @@ namespace JSC { // this function provides the full set of descendents (either at the same momentum if // fixed_iK == true, or not) by returning a vector of all descendent id's (leaving the // base and type invariant), which can then be used for further calculations. - + // This set of descendents is meant to be used when calculating either partition functions // or zero-temperature correlation functions. - - // IMPORTANT ASSUMPTIONS: + + // IMPORTANT ASSUMPTIONS: // - all even sectors consistently increase/decrease momentum for increasing tableau row length // - all odd sectors consistently decrease/increase momentum for increasing tableau row length - + // FOR FIXED MOMENTUM: // all tableau levels `above' the lowest occupied one are descended as for fixed_iK == false, // and the lowest sector's highest tableau level's row length is modified (increased or decreased by one @@ -269,9 +266,9 @@ namespace JSC { Vect Tableau_ref = (*this).Tableau; Vect Tableau_desc = Tableau_ref; - + } -} // namespace JSC +} // namespace ABACUS diff --git a/src/COMBI/Combinatorics.cc b/src/COMBI/Combinatorics.cc index 6617a5b..bfd8f6e 100644 --- a/src/COMBI/Combinatorics.cc +++ b/src/COMBI/Combinatorics.cc @@ -2,7 +2,7 @@ This software is part of J.-S. Caux's C++ library. -Copyright (c) 2006. +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -10,15 +10,13 @@ Combinatorics.cc Defines all class related to combinatorics. -LAST MODIFIED: 04/09/06 - ******************************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -namespace JSC { +namespace ABACUS { Choose_Table::Choose_Table () : Npower(0ULL), Npowerp1(1ULL), table(new unsigned long long int[1]) @@ -33,7 +31,7 @@ namespace JSC { // We can only go up to ULL_MAX: if (log(DP(ULLONG_MAX)) < DP(Npowerp1) * log(2.0)) - JSCerror("Choose_Table: too large to contruct."); + ABACUSerror("Choose_Table: too large to contruct."); table = new unsigned long long int[dim]; @@ -62,8 +60,8 @@ namespace JSC { unsigned long long int Choose_Table::choose(int N, int M) { - if (N < 0 || N > Npower) JSCerror("N out of bounds in choose(N,M)."); - if (M < 0 || M > Npower) JSCerror("M out of bounds in choose(N,M)."); + if (N < 0 || N > Npower) ABACUSerror("N out of bounds in choose(N,M)."); + if (M < 0 || M > Npower) ABACUSerror("M out of bounds in choose(N,M)."); return(table[Npowerp1 * N + M]); } @@ -86,4 +84,4 @@ namespace JSC { } -} // namespace JSC +} // namespace ABACUS diff --git a/src/EXECS/2CBG_ThLim.cc b/src/EXECS/2CBG_ThLim.cc index 006b708..633dbed 100755 --- a/src/EXECS/2CBG_ThLim.cc +++ b/src/EXECS/2CBG_ThLim.cc @@ -2,7 +2,7 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -10,18 +10,17 @@ File: 2CBG_ThLim.cc Purpose: solves the TBA equations for the 2-component Bose gas - ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; int main(int argc, const char* argv[]) { - if (argc != 7) JSCerror("Wrong number of arguments to 2CBG_ThLim executable. Use c(best to set to 1), mu, Omega, kBT, TT(minutes), bool Save_data (0 == false)."); + if (argc != 7) ABACUSerror("Wrong number of arguments to 2CBG_ThLim executable. Use c(best to set to 1), mu, Omega, kBT, TT(minutes), bool Save_data (0 == false)."); DP c_int = atof(argv[1]); DP mu = atof(argv[2]); @@ -30,10 +29,10 @@ int main(int argc, const char* argv[]) int Max_Secs = 60 * atoi(argv[5]); bool Save_data = bool(atoi(argv[6])); - if (c_int <= 0.0) JSCerror("Give a strictly positive c."); - if (Omega <= 0.0) JSCerror("Give a strictly positive Omega, otherwise the algorithm cannot converge."); - if (kBT <= 0.0) JSCerror("Negative T ? You must be a string theorist."); - if (Max_Secs < 10) JSCerror("Give more time."); + if (c_int <= 0.0) ABACUSerror("Give a strictly positive c."); + if (Omega <= 0.0) ABACUSerror("Give a strictly positive Omega, otherwise the algorithm cannot converge."); + if (kBT <= 0.0) ABACUSerror("Negative T ? You must be a string theorist."); + if (Max_Secs < 10) ABACUSerror("Give more time."); //cout << "Read c_int = " << c_int << "\tmu = " << mu << "\tOmega = " << Omega << "\tkBT = " << kBT << "\tMax_Secs = " << Max_Secs << endl; diff --git a/src/EXECS/Analyze_RAW_File.cc b/src/EXECS/Analyze_RAW_File.cc index d8d6557..4b4e9ad 100644 --- a/src/EXECS/Analyze_RAW_File.cc +++ b/src/EXECS/Analyze_RAW_File.cc @@ -1,28 +1,28 @@ /********************************************************** -This software is part of J.-S. Caux's ABACUS++ library. +This software is part of J.-S. Caux's ABACUS library. -Copyright (c) +Copyright (c) J.-S. Caux. ----------------------------------------------------------- File: Analyze_RAW_File.cc Purpose: give some statistics for the matrix element distribution in a raw file. - + ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -int main(int argc, char* argv[]) +int main(int argc, char* argv[]) { - if (argc != 4) { + if (argc != 4) { cout << "Argument needed: rawfile, iKmin, iKmax." << endl; - JSCerror(""); + ABACUSerror(""); } const char* rawfilename = argv[1]; @@ -33,7 +33,7 @@ int main(int argc, char* argv[]) RAW_infile.open(rawfilename); if (RAW_infile.fail()) { cout << rawfilename << endl; - JSCerror("Could not open RAW_infile... "); + ABACUSerror("Could not open RAW_infile... "); } DP omega; @@ -72,7 +72,7 @@ int main(int argc, char* argv[]) RAW_infile.close(); - cout << "Inverse participation ratio: \t" << sumFF4/(sumFFsq*sumFFsq) << endl; + cout << "Inverse participation ratio: \t" << sumFF4/(sumFFsq*sumFFsq) << endl; // Entropy is -sum (FFsq/sumFFsq) * ln(FFsq/sumFFsq) = sum (FFsq lnFFsq - FFsq ln sumFFsq)/sumFFsq cout << "Entropy: \t" << -(sumFFsqlnFFsq - sumFFsq * log(sumFFsq))/sumFFsq << endl; diff --git a/src/EXECS/Check_RAW_File.cc b/src/EXECS/Check_RAW_File.cc index 62939b9..ca5bff3 100644 --- a/src/EXECS/Check_RAW_File.cc +++ b/src/EXECS/Check_RAW_File.cc @@ -2,24 +2,24 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- File: Check_RAW_File.cc -Purpose: from a .raw_srt file, check that nonzero momentum states +Purpose: from a .raw_srt file, check that nonzero momentum states appear (only) twice, and zero momentum ones (only) once. - + ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -int main(int argc, char* argv[]) +int main(int argc, char* argv[]) { if (argc != 7) { // print out some instructions cout << "Usage of Check_RAW_File executable: provide the following arguments:" << endl; @@ -29,7 +29,7 @@ int main(int argc, char* argv[]) char* rawfilename = argv[1]; int iKmin = atoi(argv[2]); - int iKmax = atoi(argv[3]); + int iKmax = atoi(argv[3]); int sympoint = atoi(argv[4]); DP FFmin = atof(argv[5]); int check_option = atoi(argv[6]); @@ -38,7 +38,7 @@ int main(int argc, char* argv[]) RAW_infile.open(rawfilename); if (RAW_infile.fail()) { cout << rawfilename << endl; - JSCerror("Could not open sorted RAW_infile... "); + ABACUSerror("Could not open sorted RAW_infile... "); } DP omega_next, omega, omega_prev; @@ -88,14 +88,14 @@ int main(int argc, char* argv[]) // << omega_next << "\t" << iK_next << "\t" << FF_next << "\t" << label_next << endl; line++; - if (label.compare(label_next) == 0) + if (label.compare(label_next) == 0) cout << "Identical labels around line " << line << ": " << endl << omega << "\t" << iK << "\t" << FF << "\t" << dev << "\t" << label << endl; - - if (check_option == 0 && iK != 0 && iK != sympoint && iK >= iKmin && iK <= iKmax + + if (check_option == 0 && iK != 0 && iK != sympoint && iK >= iKmin && iK <= iKmax && fabs((FF - FF_prev)/(FF + FF_prev)) > 1.0e-6 && fabs((FF - FF_next)/(FF + FF_next)) > 1.0e-6) { - - cout << "State missing around line " << line << ": " << endl + + cout << "State missing around line " << line << ": " << endl //<< omega_prev << "\t" << iK_prev << "\t" << FF_prev << "\t" << conv_prev << "\t" << label_prev << endl << omega_prev << "\t" << iK_prev << "\t" << FF_prev << "\t" << dev_prev << "\t" << label_prev << endl //<< omega << "\t" << iK << "\t" << FF << "\t" << conv << "\t" << label << endl @@ -119,10 +119,10 @@ int main(int argc, char* argv[]) cin >> a; } - if (check_option == 2 && iK != 0 && iK != sympoint && iK >= iKmin && iK <= iKmax + if (check_option == 2 && iK != 0 && iK != sympoint && iK >= iKmin && iK <= iKmax && fabs((omega - omega_prev)/(omega + omega_prev)) > 1.0e-6 && fabs((omega - omega_next)/(omega + omega_next)) > 1.0e-6) { - - cout << "State missing around line " << line << ": " << endl + + cout << "State missing around line " << line << ": " << endl << omega_prev << "\t" << iK_prev << "\t" << dev_prev << "\t" << label_prev << endl << omega << "\t" << iK << "\t" << dev << "\t" << label << endl << omega_next << "\t" << iK_next << "\t" << dev_next << "\t" << label_next << endl; @@ -144,4 +144,3 @@ int main(int argc, char* argv[]) return(0); } - diff --git a/src/EXECS/Heis_DSF.cc b/src/EXECS/Heis_DSF.cc index 04c4832..035c371 100644 --- a/src/EXECS/Heis_DSF.cc +++ b/src/EXECS/Heis_DSF.cc @@ -1,29 +1,29 @@ /********************************************************** -This software is part of J.-S. Caux's ABACUS++ library. +This software is part of J.-S. Caux's ABACUS library. -Copyright (c) +Copyright (c) J.-S. Caux ----------------------------------------------------------- File: Heis_DSF.cc -Purpose: main function for ABACUS++ for Heisenberg spin-1/2 chain +Purpose: main function for ABACUS for Heisenberg spin-1/2 chain ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -int main(int argc, char* argv[]) +int main(int argc, char* argv[]) { if (argc != 8) { // provide some info - cout << endl << "Welcome to ABACUS++\t(copyright J.-S. Caux)." << endl; + cout << endl << "Welcome to ABACUS\t(copyright J.-S. Caux)." << endl; cout << endl << "Usage of Heis_DSF executable: " << endl; cout << endl << "Provide the following arguments:" << endl << endl; cout << "char whichDSF \t\t Which structure factor should be calculated ? Options are: m for S- S+, z for Sz Sz, p for S+ S-." << endl; @@ -81,7 +81,7 @@ int main(int argc, char* argv[]) argsfile.open(argv[1]); if (argsfile.fail()) { cout << argv[1] << endl; - JSCerror("Could not open arguments file."); + ABACUSerror("Could not open arguments file."); } char junk[256]; @@ -134,9 +134,8 @@ int main(int argc, char* argv[]) Scan_Heis (whichDSF, Delta, N, M, iKmin, iKmax, Max_Secs, refine); } - else JSCerror("Wrong number of arguments to Heis_DSF executable."); + else ABACUSerror("Wrong number of arguments to Heis_DSF executable."); */ return(0); } - diff --git a/src/EXECS/Heis_DSF_GeneralState.cc b/src/EXECS/Heis_DSF_GeneralState.cc index c87667b..7617831 100644 --- a/src/EXECS/Heis_DSF_GeneralState.cc +++ b/src/EXECS/Heis_DSF_GeneralState.cc @@ -1,29 +1,29 @@ /********************************************************** -This software is part of J.-S. Caux's ABACUS++ library. +This software is part of J.-S. Caux's ABACUS library. -Copyright (c) +Copyright (c) J.-S. Caux. ----------------------------------------------------------- File: Heis_DSF_GeneralState.cc -Purpose: main function for ABACUS++ for Heisenberg spin-1/2 chain +Purpose: main function for ABACUS for Heisenberg spin-1/2 chain ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -int main(int argc, char* argv[]) +int main(int argc, char* argv[]) { if (argc != 9) { // provide some info - cout << endl << "Welcome to ABACUS++\t(copyright J.-S. Caux)." << endl; + cout << endl << "Welcome to ABACUS\t(copyright J.-S. Caux)." << endl; cout << endl << "Usage of Heis_DSF executable: " << endl; cout << endl << "Provide the following arguments:" << endl << endl; cout << "char whichDSF \t\t Which structure factor should be calculated ? Options are: m for S- S+, z for Sz Sz, p for S+ S-." << endl; @@ -68,7 +68,7 @@ int main(int argc, char* argv[]) Ix2_input_file.open(filename_Cstr); if (Ix2_input_file.fail()) { cout << filename_Cstr << endl; - JSCerror("Could not open Ix2 input file in Heis_DSF_GeneralState"); + ABACUSerror("Could not open Ix2 input file in Heis_DSF_GeneralState"); } Heis_Chain chain(1.0, Delta, 0.0, N); @@ -111,7 +111,7 @@ int main(int argc, char* argv[]) } AveragingState.Set_Label_from_Ix2(AveragingState.Ix2); AveragingState.Compute_All(true); - + // Perform the scan: Scan_Heis (whichDSF, AveragingState, defaultScanStatename, iKmin, iKmax, Max_Secs, target_sumrule, refine, paralevel, rank, nr_processors); } @@ -122,7 +122,7 @@ int main(int argc, char* argv[]) } AveragingState.Set_Label_from_Ix2(AveragingState.Ix2); AveragingState.Compute_All(true); - + // Perform the scan: Scan_Heis (whichDSF, AveragingState, defaultScanStatename, iKmin, iKmax, Max_Secs, target_sumrule, refine, paralevel, rank, nr_processors); } @@ -130,4 +130,3 @@ int main(int argc, char* argv[]) return(0); } - diff --git a/src/EXECS/Heis_DSF_par.cc b/src/EXECS/Heis_DSF_par.cc index fc82d9d..2d5c089 100644 --- a/src/EXECS/Heis_DSF_par.cc +++ b/src/EXECS/Heis_DSF_par.cc @@ -2,21 +2,20 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- File: Heis_DSF_par.cc -Purpose: Parallel version of ABACUS++ using MPICH. - +Purpose: Parallel version of ABACUS using MPICH. ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" #include "mpi.h" -using namespace JSC; +using namespace ABACUS; int main(int argc, char *argv[]) { @@ -28,9 +27,9 @@ int main(int argc, char *argv[]) if (argc != 8) { // provide some info - cout << endl << "Welcome to ABACUS++\t(copyright J.-S. Caux)." << endl; + cout << endl << "Welcome to ABACUS\t(copyright J.-S. Caux)." << endl; cout << endl << "Usage of Heis_DSF_par executable: " << endl; - cout << endl << "This function runs ABACUS++ in parallel mode, starting from a preexisting serial run (obtained using the Heis_DSF executable) using the same model parameters." << endl; + cout << endl << "This function runs ABACUS in parallel mode, starting from a preexisting serial run (obtained using the Heis_DSF executable) using the same model parameters." << endl; cout << endl << "Provide the following arguments:" << endl << endl; cout << "char whichDSF \t\t Which structure factor should be calculated ? Options are: m for S- S+, z for Sz Sz, p for S+ S-." << endl; cout << "DP Delta \t\t Value of the anisotropy: use positive real values only" << endl; @@ -56,21 +55,21 @@ int main(int argc, char *argv[]) DP supercycle_time = 600.0; // allotted time per supercycle - if (Max_Secs <= supercycle_time + 300) JSCerror("Please allow more time in Heis_DSF_par."); + if (Max_Secs <= supercycle_time + 300) ABACUSerror("Please allow more time in Heis_DSF_par."); MPI::Init(argc, argv); DP tstart = MPI::Wtime(); - + int rank = MPI::COMM_WORLD.Get_rank(); int nr_processors = MPI::COMM_WORLD.Get_size(); - if (nr_processors < 2) JSCerror("Give at least 2 processors to ABACUS++ parallel !"); + if (nr_processors < 2) ABACUSerror("Give at least 2 processors to ABACUS parallel !"); refine = true; // ASSUMPTION: preexisting files (raw, thr, ...) exist for the run. - + // IMPORTANT PRECONDITION: no flags are being raised in General_Scan in parallel mode, so // the preinitializing serial run must be extensive enough to have flagged all base/type s necessary. @@ -83,30 +82,30 @@ int main(int argc, char *argv[]) if (rank == 0) // Split up thread list into chunks, one per processor Prepare_Parallel_Scan_Heis (whichDSF, Delta, N, M, iKmin, iKmax, nr_processors); - + //cout << "rank " << rank << " done preparing, ready to scan." << endl; - // Barrier synchronization, to make sure other processes wait for process of rank 0 + // Barrier synchronization, to make sure other processes wait for process of rank 0 // to have finished splitting up the thr file into pieces before starting: MPI_Barrier (MPI::COMM_WORLD); - + // then everybody gets going on their own chunk ! Scan_Heis (whichDSF, Delta, N, M, iKmin, iKmax, supercycle_time, target_sumrule, refine, rank, nr_processors); //cout << "rank " << rank << " finished scanning, reached wrapup stage." << endl; - - // Another barrier synchronization + + // Another barrier synchronization MPI_Barrier (MPI::COMM_WORLD); - // Now that everybody is done, digest data into unique files - if (rank == 0) + // Now that everybody is done, digest data into unique files + if (rank == 0) Wrapup_Parallel_Scan_Heis (whichDSF, Delta, N, M, iKmin, iKmax, nr_processors); //cout << "rank " << rank << " passed wrapup stage." << endl; - // Another barrier synchronization - MPI_Barrier (MPI::COMM_WORLD); + // Another barrier synchronization + MPI_Barrier (MPI::COMM_WORLD); tnow = MPI::Wtime(); @@ -117,4 +116,3 @@ int main(int argc, char *argv[]) return(0); } - diff --git a/src/EXECS/Heis_DSF_par_Prepare.cc b/src/EXECS/Heis_DSF_par_Prepare.cc index 379d540..ee9c4fd 100644 --- a/src/EXECS/Heis_DSF_par_Prepare.cc +++ b/src/EXECS/Heis_DSF_par_Prepare.cc @@ -2,21 +2,20 @@ This software is part of J.-S. Caux's C++ library. -Copyright (c) +Copyright (c) J.-S. Caux. ----------------------------------------------------------- File: Heis_DSF_par_Prepare.cc -Purpose: Parallel version of ABACUS++ using MPICH. - +Purpose: Parallel version of ABACUS using MPICH. ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" //#include "mpi.h" // not needed for Prepare -using namespace JSC; +using namespace ABACUS; int main(int argc, char *argv[]) { @@ -28,9 +27,9 @@ int main(int argc, char *argv[]) if (argc < 9) { // provide some info - cout << endl << "Welcome to ABACUS++\t(copyright J.-S. Caux)." << endl; + cout << endl << "Welcome to ABACUS\t(copyright J.-S. Caux)." << endl; cout << endl << "Usage of Heis_DSF_par_Prepare executable: " << endl; - cout << endl << "This function prepares for ABACUS++G in parallel mode, starting from a preexisting serial run (obtained using the Heis_DSF executable) using the same model parameters." << endl; + cout << endl << "This function prepares for ABACUSG in parallel mode, starting from a preexisting serial run (obtained using the Heis_DSF executable) using the same model parameters." << endl; cout << endl << "Provide the following arguments:" << endl << endl; cout << "char whichDSF \t\t Which structure factor should be calculated ? Options are: m for S- S+, z for Sz Sz, p for S+ S-." << endl; cout << "DP Delta \t\t Value of the anisotropy: use positive real values only" << endl; @@ -53,7 +52,7 @@ int main(int argc, char *argv[]) iKmin = atoi(argv[n++]); iKmax = atoi(argv[n++]); paralevel = atoi(argv[n++]); // paralevel == 1 means that we have one layer of parallelization, so no previous rank and nr_processors to specify - if (argc != 9 + 2*(paralevel - 1)) JSCerror("Wrong nr of arguments in Heis_DSF_par_Prepare."); + if (argc != 9 + 2*(paralevel - 1)) ABACUSerror("Wrong nr of arguments in Heis_DSF_par_Prepare."); Vect rank_lower_paralevels(paralevel - 1); Vect nr_processors_lower_paralevels(paralevel - 1); @@ -64,12 +63,11 @@ int main(int argc, char *argv[]) nr_processors_at_newlevel = atoi(argv[n++]); string defaultScanStatename = ""; - + // Split up thread list into chunks, one per processor Prepare_Parallel_Scan_Heis (whichDSF, Delta, N, M, iKmin, iKmax, paralevel, rank_lower_paralevels, nr_processors_lower_paralevels, nr_processors_at_newlevel); - + } return(0); } - diff --git a/src/EXECS/Heis_DSF_par_Run.cc b/src/EXECS/Heis_DSF_par_Run.cc index 7c9fc53..aa87986 100644 --- a/src/EXECS/Heis_DSF_par_Run.cc +++ b/src/EXECS/Heis_DSF_par_Run.cc @@ -2,21 +2,20 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- File: Heis_DSF_par_Run.cc -Purpose: Parallel version of ABACUS++ using MPICH. - +Purpose: Parallel version of ABACUS using MPICH. ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" #include "mpi.h" -using namespace JSC; +using namespace ABACUS; int main(int argc, char *argv[]) { @@ -28,9 +27,9 @@ int main(int argc, char *argv[]) if (argc < 10) { // provide some info - cout << endl << "Welcome to ABACUS++\t(copyright J.-S. Caux)." << endl; + cout << endl << "Welcome to ABACUS\t(copyright J.-S. Caux)." << endl; cout << endl << "Usage of Heis_DSF_par_Run executable: " << endl; - cout << endl << "This function runs ABACUS++ in parallel mode, starting from a preexisting serial run (obtained using the Heis_DSF executable) using the same model parameters." << endl; + cout << endl << "This function runs ABACUS in parallel mode, starting from a preexisting serial run (obtained using the Heis_DSF executable) using the same model parameters." << endl; cout << endl << "Provide the following arguments:" << endl << endl; cout << "char whichDSF \t\t Which structure factor should be calculated ? Options are: m for S- S+, z for Sz Sz, p for S+ S-." << endl; cout << "DP Delta \t\t Value of the anisotropy: use positive real values only" << endl; @@ -56,7 +55,7 @@ int main(int argc, char *argv[]) iKmin = atoi(argv[n++]); iKmax = atoi(argv[n++]); paralevel = atoi(argv[n++]); // paralevel == 1 means that we have one layer of parallelization, so no previous rank and nr_processors to specify - if (argc != 10 + 2*(paralevel - 1)) JSCerror("Wrong nr of arguments in Heis_DSF_par_Run."); + if (argc != 10 + 2*(paralevel - 1)) ABACUSerror("Wrong nr of arguments in Heis_DSF_par_Run."); Vect rank_lower_paralevels(paralevel - 1); Vect nr_processors_lower_paralevels(paralevel - 1); for (int i = 0; i < paralevel - 1; ++i) { @@ -69,12 +68,12 @@ int main(int argc, char *argv[]) //DP supercycle_time = 600.0; // allotted time per supercycle - if (Max_Secs <= supercycle_time) JSCerror("Please allow more time in Heis_DSF_par_Run."); + if (Max_Secs <= supercycle_time) ABACUSerror("Please allow more time in Heis_DSF_par_Run."); MPI::Init(argc, argv); - + DP tstart = MPI::Wtime(); - + int rank_here = MPI::COMM_WORLD.Get_rank(); int nr_processors_here = MPI::COMM_WORLD.Get_size(); @@ -87,12 +86,12 @@ int main(int argc, char *argv[]) rank[paralevel-1] = rank_here; nr_processors[paralevel-1] = nr_processors_here; - if (nr_processors_here < 2) JSCerror("Give at least 2 processors to ABACUS++ parallel !"); + if (nr_processors_here < 2) ABACUSerror("Give at least 2 processors to ABACUS parallel !"); refine = true; // ASSUMPTION: preexisting files (raw, thr, ...) exist for the run. - + DP tnow = MPI::Wtime(); @@ -100,21 +99,21 @@ int main(int argc, char *argv[]) while (tnow - tstart < Max_Secs - supercycle_time - 120) { // space for one more supercycle, + 2 minutes safety - // Barrier synchronization, to make sure other processes wait for process of rank 0 + // Barrier synchronization, to make sure other processes wait for process of rank 0 // to have finished splitting up the thr file into pieces before starting: MPI_Barrier (MPI::COMM_WORLD); - + // then everybody gets going on their own chunk ! - Scan_Heis (whichDSF, Delta, N, M, iKmin, iKmax, + Scan_Heis (whichDSF, Delta, N, M, iKmin, iKmax, supercycle_time, target_sumrule, refine, paralevel, rank, nr_processors); - - // Another barrier synchronization + + // Another barrier synchronization MPI_Barrier (MPI::COMM_WORLD); - + // Now that everybody is done, digest data into unique files - - // Another barrier synchronization - MPI_Barrier (MPI::COMM_WORLD); + + // Another barrier synchronization + MPI_Barrier (MPI::COMM_WORLD); tnow = MPI::Wtime(); @@ -124,4 +123,3 @@ int main(int argc, char *argv[]) return(0); } - diff --git a/src/EXECS/Heis_DSF_par_Wrapup.cc b/src/EXECS/Heis_DSF_par_Wrapup.cc index d8013cc..12a3e6c 100644 --- a/src/EXECS/Heis_DSF_par_Wrapup.cc +++ b/src/EXECS/Heis_DSF_par_Wrapup.cc @@ -2,21 +2,20 @@ This software is part of J.-S. Caux's C++ library. -Copyright (c) +Copyright (c) J.-S. Caux. ----------------------------------------------------------- File: Heis_DSF_par_Prepare.cc -Purpose: Parallel version of ABACUS++ using MPICH. - +Purpose: Parallel version of ABACUS using MPICH. ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" //#include "mpi.h" // not needed for Prepare or Wrapup -using namespace JSC; +using namespace ABACUS; int main(int argc, char *argv[]) { @@ -28,9 +27,9 @@ int main(int argc, char *argv[]) if (argc < 9) { // provide some info - cout << endl << "Welcome to ABACUS++\t(copyright J.-S. Caux)." << endl; + cout << endl << "Welcome to ABACUS\t(copyright J.-S. Caux)." << endl; cout << endl << "Usage of Heis_DSF_par_Wrapup executable: " << endl; - cout << endl << "This function wraps up an ABACUS++G parallel mode run." << endl; + cout << endl << "This function wraps up an ABACUSG parallel mode run." << endl; cout << endl << "Provide the following arguments:" << endl << endl; cout << "char whichDSF \t\t Which structure factor should be calculated ? Options are: m for S- S+, z for Sz Sz, p for S+ S-." << endl; cout << "DP Delta \t\t Value of the anisotropy: use positive real values only" << endl; @@ -53,7 +52,7 @@ int main(int argc, char *argv[]) iKmin = atoi(argv[n++]); iKmax = atoi(argv[n++]); paralevel = atoi(argv[n++]); // paralevel == 1 means that we have one layer of parallelization, so no previous rank and nr_processors to specify - if (argc != 9 + 2*(paralevel - 1)) JSCerror("Wrong nr of arguments in Heis_DSF_par_Wrapup."); + if (argc != 9 + 2*(paralevel - 1)) ABACUSerror("Wrong nr of arguments in Heis_DSF_par_Wrapup."); Vect rank_lower_paralevels(paralevel - 1); Vect nr_processors_lower_paralevels(paralevel - 1); @@ -64,12 +63,11 @@ int main(int argc, char *argv[]) nr_processors_at_newlevel = atoi(argv[n++]); string defaultScanStatename = ""; - + // Split up thread list into chunks, one per processor Wrapup_Parallel_Scan_Heis (whichDSF, Delta, N, M, iKmin, iKmax, paralevel, rank_lower_paralevels, nr_processors_lower_paralevels, nr_processors_at_newlevel); - + } return(0); } - diff --git a/src/EXECS/LiebLin_Catalogue_Fixed_c_k_Nscaling.cc b/src/EXECS/LiebLin_Catalogue_Fixed_c_k_Nscaling.cc index 7295038..a162430 100644 --- a/src/EXECS/LiebLin_Catalogue_Fixed_c_k_Nscaling.cc +++ b/src/EXECS/LiebLin_Catalogue_Fixed_c_k_Nscaling.cc @@ -2,7 +2,7 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -12,13 +12,14 @@ Purpose: Produces sets of data files for correlations, increasing system size a ***********************************************************/ -#include "JSC.h" +#include +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -int main(int argc, char* argv[]) +int main(int argc, char* argv[]) { if (argc != 7) { // provide some info @@ -45,7 +46,7 @@ int main(int argc, char* argv[]) DP kBT = atof(argv[ia++]); DP target_sumrule = atof(argv[ia++]); int Max_Secs = atoi(argv[ia++]); - + //clock_t StartTime = clock(); double StartTime = omp_get_wtime(); @@ -76,9 +77,9 @@ int main(int argc, char* argv[]) Data_File_Name (SRC_stringstream, whichDSF, c_int, L, N, iKmin, iKmax, kBT, 0.0, ""); SRC_stringstream << ".src"; SRC_string = SRC_stringstream.str(); const char* SRC_Cstr = SRC_string.c_str(); - + fstream srcfile; - srcfile.open(SRC_Cstr, fstream::in); + srcfile.open(SRC_Cstr, fstream::in); if (srcfile.fail()) { srsat = 0.0; refine = false; @@ -92,7 +93,7 @@ int main(int argc, char* argv[]) ActualTime = omp_get_wtime(); Secs_left = int(Max_Secs - (ActualTime - StartTime)); - if (srsat < target_sumrule && Secs_left > Max_Secs/2) + if (srsat < target_sumrule && Secs_left > Max_Secs/2) // Improve the icmin calculation by one chunk: Scan_LiebLin (whichDSF, c_int, L, N, iKmin, iKmax, kBT, Secs_left, target_sumrule, refine); @@ -107,10 +108,9 @@ int main(int argc, char* argv[]) break; } - } // while there is time + } // while there is time } // else if arguments given OK return(0); } - diff --git a/src/EXECS/LiebLin_DSF.cc b/src/EXECS/LiebLin_DSF.cc index a6f1ddd..aad4227 100644 --- a/src/EXECS/LiebLin_DSF.cc +++ b/src/EXECS/LiebLin_DSF.cc @@ -2,28 +2,28 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- File: LiebLin_DSF.cc -Purpose: main function for ABACUS++ for LiebLin gas +Purpose: main function for ABACUS for LiebLin gas ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -int main(int argc, char* argv[]) +int main(int argc, char* argv[]) { if (argc != 11) { // provide some info - cout << endl << "Welcome to ABACUS++\t(copyright J.-S. Caux)." << endl; + cout << endl << "Welcome to ABACUS\t(copyright J.-S. Caux)." << endl; cout << endl << "Usage of LiebLin_DSF_Tgt0 executable: " << endl; cout << endl << "Provide the following arguments:" << endl << endl; cout << "char whichDSF \t\t Which structure factor should be calculated ? Options are: d for rho rho, g for psi psi{dagger}, o for psi{dagger} psi" << endl; @@ -59,4 +59,3 @@ int main(int argc, char* argv[]) return(0); } - diff --git a/src/EXECS/LiebLin_DSF_GeneralState.cc b/src/EXECS/LiebLin_DSF_GeneralState.cc index 037abdc..fff586a 100644 --- a/src/EXECS/LiebLin_DSF_GeneralState.cc +++ b/src/EXECS/LiebLin_DSF_GeneralState.cc @@ -2,28 +2,28 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- File: LiebLin_DSF_GeneralState.cc -Purpose: function for ABACUS++ for LiebLin gas, on general states +Purpose: function for ABACUS for LiebLin gas, on general states ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -int main(int argc, char* argv[]) +int main(int argc, char* argv[]) { if (argc != 11) { // provide some info - cout << endl << "Welcome to ABACUS++\t(copyright J.-S. Caux)." << endl; + cout << endl << "Welcome to ABACUS\t(copyright J.-S. Caux)." << endl; cout << endl << "Usage of LiebLin_DSF_Tgt0 executable: " << endl; cout << endl << "Provide the following arguments:" << endl << endl; cout << "char whichDSF \t\t Which structure factor should be calculated ? Options are: d for rho rho, g for psi psi{dagger}, o for psi{dagger} psi" << endl; @@ -66,7 +66,7 @@ int main(int argc, char* argv[]) Ix2_input_file.open(filename_Cstr); if (Ix2_input_file.fail()) { cout << filename_Cstr << endl; - JSCerror("Could not open Ix2 input file in LiebLin_DSF_GeneralState"); + ABACUSerror("Could not open Ix2 input file in LiebLin_DSF_GeneralState"); } for (int i = 0; i < N; ++i) { Ix2_input_file >> Ix2_input[i]; @@ -83,10 +83,10 @@ int main(int argc, char* argv[]) //Scan_LiebLin (whichDSF, c_int, L, N, iKmin, iKmax, kBT, Max_Secs, target_sumrule, refine, 0, 1); //Scan_LiebLin (whichDSF, c_int, L, N, iKmin, iKmax, kBT, Max_Secs, target_sumrule, refine); - //void Scan_LiebLin (char whichDSF, LiebLin_Bethe_State AveragingState, string defaultScanStatename, int iKmin, int iKmax, + //void Scan_LiebLin (char whichDSF, LiebLin_Bethe_State AveragingState, string defaultScanStatename, int iKmin, int iKmax, // int Max_Secs, DP target_sumrule, bool refine, int paralevel, Vect rank, Vect nr_processors) // Simplified function call of the above: - //void Scan_LiebLin (char whichDSF, LiebLin_Bethe_State AveragingState, string defaultScanStatename, int iKmin, int iKmax, + //void Scan_LiebLin (char whichDSF, LiebLin_Bethe_State AveragingState, string defaultScanStatename, int iKmin, int iKmax, // int Max_Secs, DP target_sumrule, bool refine) Scan_LiebLin (whichDSF, AveragingState, defaultScanStatename, iKmin, iKmax, Max_Secs, target_sumrule, refine); @@ -94,4 +94,3 @@ int main(int argc, char* argv[]) return(0); } - diff --git a/src/EXECS/LiebLin_DSF_GeneralState_par_Prepare.cc b/src/EXECS/LiebLin_DSF_GeneralState_par_Prepare.cc index 6f79294..5ae0f47 100644 --- a/src/EXECS/LiebLin_DSF_GeneralState_par_Prepare.cc +++ b/src/EXECS/LiebLin_DSF_GeneralState_par_Prepare.cc @@ -2,21 +2,20 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- File: LiebLin_DSF_GeneralState_par_Prepare.cc -Purpose: Parallel version of ABACUS++ using MPICH. - +Purpose: Parallel version of ABACUS using MPICH. ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" //#include "mpi.h" // not needed for Prepare -using namespace JSC; +using namespace ABACUS; int main(int argc, char *argv[]) { @@ -29,9 +28,9 @@ int main(int argc, char *argv[]) if (argc < 10) { // provide some info - cout << endl << "Welcome to ABACUS++\t(copyright J.-S. Caux)." << endl; + cout << endl << "Welcome to ABACUS\t(copyright J.-S. Caux)." << endl; cout << endl << "Usage of LiebLin_DSF_par_Prepare executable: " << endl; - cout << endl << "This function prepares an ABACUS++ parallel mode run, starting from a preexisting serial run (obtained using the LiebLin_DSF executable) using the same model parameters." << endl; + cout << endl << "This function prepares an ABACUS parallel mode run, starting from a preexisting serial run (obtained using the LiebLin_DSF executable) using the same model parameters." << endl; cout << endl << "Provide the following arguments:" << endl << endl; cout << "char whichDSF \t\t Which structure factor should be calculated ? Options are: d for rho rho, g for psi psi{dagger}, o for psi{dagger} psi" << endl; cout << "DP c_int \t\t Value of the interaction parameter: use positive real values only" << endl; @@ -58,7 +57,7 @@ int main(int argc, char *argv[]) iKmax = atoi(argv[n++]); //kBT = atof(argv[n++]); paralevel = atoi(argv[n++]); // paralevel == 1 means that we have one layer of parallelization, so no previous rank and nr_processors to specify - if (argc != 10 + 2*(paralevel - 1)) JSCerror("Wrong nr of arguments in LiebLin_DSF_GeneralState_par_Prepare."); + if (argc != 10 + 2*(paralevel - 1)) ABACUSerror("Wrong nr of arguments in LiebLin_DSF_GeneralState_par_Prepare."); Vect rank_lower_paralevels(paralevel - 1); Vect nr_processors_lower_paralevels(paralevel - 1); @@ -83,7 +82,7 @@ int main(int argc, char *argv[]) Ix2_input_file.open(filename_Cstr); if (Ix2_input_file.fail()) { cout << filename_Cstr << endl; - JSCerror("Could not open Ix2 input file in LiebLin_DSF_GeneralState"); + ABACUSerror("Could not open Ix2 input file in LiebLin_DSF_GeneralState"); } for (int i = 0; i < N; ++i) { Ix2_input_file >> Ix2_input[i]; @@ -98,9 +97,8 @@ int main(int argc, char *argv[]) // Split up thread list into chunks, one per processor Prepare_Parallel_Scan_LiebLin (whichDSF, c_int, L, N, iKmin, iKmax, kBT, defaultScanStatename, paralevel, rank_lower_paralevels, nr_processors_lower_paralevels, nr_processors_at_newlevel); - + } return(0); } - diff --git a/src/EXECS/LiebLin_DSF_GeneralState_par_Run.cc b/src/EXECS/LiebLin_DSF_GeneralState_par_Run.cc index 1d19c40..d8b62ae 100644 --- a/src/EXECS/LiebLin_DSF_GeneralState_par_Run.cc +++ b/src/EXECS/LiebLin_DSF_GeneralState_par_Run.cc @@ -2,21 +2,20 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- File: LiebLin_DSF_GeneralState_par_Run.cc -Purpose: Parallel version of ABACUS++ using MPICH. - +Purpose: Parallel version of ABACUS using MPICH. ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" #include "mpi.h" -using namespace JSC; +using namespace ABACUS; int main(int argc, char *argv[]) { @@ -29,9 +28,9 @@ int main(int argc, char *argv[]) if (argc < 10) { // provide some info - cout << endl << "Welcome to ABACUS++\t(copyright J.-S. Caux)." << endl; + cout << endl << "Welcome to ABACUS\t(copyright J.-S. Caux)." << endl; cout << endl << "Usage of LiebLin_DSF_par executable: " << endl; - cout << endl << "This function runs ABACUS++ in parallel mode, starting from a preexisting serial run (obtained using the LiebLin_DSF executable) using the same model parameters." << endl; + cout << endl << "This function runs ABACUS in parallel mode, starting from a preexisting serial run (obtained using the LiebLin_DSF executable) using the same model parameters." << endl; cout << endl << "Provide the following arguments:" << endl << endl; cout << "char whichDSF \t\t Which structure factor should be calculated ? Options are: d for rho rho, g for psi psi{dagger}, o for psi{dagger} psi" << endl; cout << "DP c_int \t\t Value of the interaction parameter: use positive real values only" << endl; @@ -59,7 +58,7 @@ int main(int argc, char *argv[]) iKmax = atoi(argv[n++]); //kBT = atof(argv[n++]); paralevel = atoi(argv[n++]); // paralevel == 1 means that we have one layer of parallelization, so no previous rank and nr_processors to specify - if (argc != 10 + 2*(paralevel - 1)) JSCerror("Wrong nr of arguments in LiebLin_DSF_par_Prepare."); + if (argc != 10 + 2*(paralevel - 1)) ABACUSerror("Wrong nr of arguments in LiebLin_DSF_par_Prepare."); Vect rank_lower_paralevels(paralevel - 1); Vect nr_processors_lower_paralevels(paralevel - 1); for (int i = 0; i < paralevel - 1; ++i) { @@ -72,14 +71,14 @@ int main(int argc, char *argv[]) //DP supercycle_time = 600.0; // allotted time per supercycle - if (Max_Secs <= 120) JSCerror("Please allow more time in LiebLin_DSF_par_Run."); + if (Max_Secs <= 120) ABACUSerror("Please allow more time in LiebLin_DSF_par_Run."); int Max_Secs_used = Max_Secs - 120; MPI::Init(argc, argv); - + DP tstart = MPI::Wtime(); - + int rank_here = MPI::COMM_WORLD.Get_rank(); int nr_processors_here = MPI::COMM_WORLD.Get_size(); @@ -95,18 +94,18 @@ int main(int argc, char *argv[]) Ix2_input_file.open(filename_Cstr); if (Ix2_input_file.fail()) { cout << filename_Cstr << endl; - JSCerror("Could not open Ix2 input file in LiebLin_DSF_GeneralState"); + ABACUSerror("Could not open Ix2 input file in LiebLin_DSF_GeneralState"); } for (int i = 0; i < N; ++i) { Ix2_input_file >> Ix2_input[i]; //cout << i << "\t" << Ix2_input[i] << endl; } - + // Now define the AveragingState LiebLin_Bethe_State AveragingState(c_int, L, N); AveragingState.Ix2 = Ix2_input; AveragingState.Compute_All(true); - + Vect rank (paralevel); Vect nr_processors (paralevel); @@ -117,31 +116,31 @@ int main(int argc, char *argv[]) rank[paralevel-1] = rank_here; nr_processors[paralevel-1] = nr_processors_here; - if (nr_processors_here < 2) JSCerror("Give at least 2 processors to ABACUS++ parallel !"); + if (nr_processors_here < 2) ABACUSerror("Give at least 2 processors to ABACUS parallel !"); refine = true; // ASSUMPTION: preexisting files (raw, thr, ...) exist for the run. - + DP tnow = MPI::Wtime(); - + //while (tnow - tstart < Max_Secs - supercycle_time - 120) { // space for one more supercycle, + 2 minutes safety - if (Max_Secs_used > 0) { + if (Max_Secs_used > 0) { // Barrier synchronization MPI_Barrier (MPI::COMM_WORLD); - + // then everybody gets going on their own chunk ! - //Scan_LiebLin (whichDSF, c_int, L, N, iK_UL, fixed_iK, iKneeded, + //Scan_LiebLin (whichDSF, c_int, L, N, iK_UL, fixed_iK, iKneeded, //Scan_LiebLin (whichDSF, c_int, L, N, iKmin, iKmax, kBT, // supercycle_time, target_sumrule, refine, paralevel, rank, nr_processors); Scan_LiebLin (whichDSF, AveragingState, defaultScanStatename, iKmin, iKmax, Max_Secs, target_sumrule, refine, paralevel, rank, nr_processors); - - // Another barrier synchronization + + // Another barrier synchronization MPI_Barrier (MPI::COMM_WORLD); - + tnow = MPI::Wtime(); } // while (tnow - tstart... @@ -150,4 +149,3 @@ int main(int argc, char *argv[]) return(0); } - diff --git a/src/EXECS/LiebLin_DSF_GeneralState_par_Wrapup.cc b/src/EXECS/LiebLin_DSF_GeneralState_par_Wrapup.cc index fd361c4..9e53629 100644 --- a/src/EXECS/LiebLin_DSF_GeneralState_par_Wrapup.cc +++ b/src/EXECS/LiebLin_DSF_GeneralState_par_Wrapup.cc @@ -2,21 +2,20 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- File: LiebLin_DSF_par_Prepare.cc -Purpose: Parallel version of ABACUS++ using MPICH. - +Purpose: Parallel version of ABACUS using MPICH. ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" //#include "mpi.h" // not needed for Prepare -using namespace JSC; +using namespace ABACUS; int main(int argc, char *argv[]) { @@ -29,9 +28,9 @@ int main(int argc, char *argv[]) if (argc < 10) { // provide some info - cout << endl << "Welcome to ABACUS++\t(copyright J.-S. Caux)." << endl; + cout << endl << "Welcome to ABACUS\t(copyright J.-S. Caux)." << endl; cout << endl << "Usage of LiebLin_DSF_par_Wrapup executable: " << endl; - cout << endl << "This function wraps up an ABACUS++ parallel mode run." << endl; + cout << endl << "This function wraps up an ABACUS parallel mode run." << endl; cout << endl << "Provide the following arguments:" << endl << endl; cout << "char whichDSF \t\t Which structure factor should be calculated ? Options are: d for rho rho, g for psi psi{dagger}, o for psi{dagger} psi" << endl; cout << "DP c_int \t\t Value of the interaction parameter: use positive real values only" << endl; @@ -58,7 +57,7 @@ int main(int argc, char *argv[]) iKmax = atoi(argv[n++]); //kBT = atof(argv[n++]); paralevel = atoi(argv[n++]); // paralevel == 1 means that we have one layer of parallelization, so no previous rank and nr_processors to specify - if (argc != 10 + 2*(paralevel - 1)) JSCerror("Wrong nr of arguments in LiebLin_DSF_par_Prepare."); + if (argc != 10 + 2*(paralevel - 1)) ABACUSerror("Wrong nr of arguments in LiebLin_DSF_par_Prepare."); Vect rank_lower_paralevels(paralevel - 1); Vect nr_processors_lower_paralevels(paralevel - 1); @@ -81,7 +80,7 @@ int main(int argc, char *argv[]) Ix2_input_file.open(filename_Cstr); if (Ix2_input_file.fail()) { cout << filename_Cstr << endl; - JSCerror("Could not open Ix2 input file in LiebLin_DSF_GeneralState"); + ABACUSerror("Could not open Ix2 input file in LiebLin_DSF_GeneralState"); } for (int i = 0; i < N; ++i) { Ix2_input_file >> Ix2_input[i]; @@ -93,12 +92,11 @@ int main(int argc, char *argv[]) AveragingState.Ix2 = Ix2_input; //AveragingState.Compute_All(true); */ - + // Digest files into a unique one for the latest paralevel: Wrapup_Parallel_Scan_LiebLin (whichDSF, c_int, L, N, iKmin, iKmax, kBT, defaultScanStatename, paralevel, rank_lower_paralevels, nr_processors_lower_paralevels, nr_processors_at_newlevel); - + } return(0); } - diff --git a/src/EXECS/LiebLin_DSF_MosesState.cc b/src/EXECS/LiebLin_DSF_MosesState.cc index dd791e8..add6b71 100644 --- a/src/EXECS/LiebLin_DSF_MosesState.cc +++ b/src/EXECS/LiebLin_DSF_MosesState.cc @@ -2,28 +2,28 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- File: LiebLin_DSF.cc -Purpose: main function for ABACUS++ for LiebLin gas +Purpose: main function for ABACUS for LiebLin gas ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -int main(int argc, char* argv[]) +int main(int argc, char* argv[]) { if (argc != 13) { // provide some info - cout << endl << "Welcome to ABACUS++\t(copyright J.-S. Caux)." << endl; + cout << endl << "Welcome to ABACUS\t(copyright J.-S. Caux)." << endl; cout << endl << "Usage of LiebLin_DSF_MosesState executable: " << endl; cout << endl << "Provide the following arguments:" << endl << endl; cout << "char whichDSF \t\t Which structure factor should be calculated ? Options are: d for rho rho, g for psi psi{dagger}, o for psi{dagger} psi" << endl; @@ -31,8 +31,8 @@ int main(int argc, char* argv[]) cout << "DP L \t\t\t Length of the system: use positive real values only" << endl; cout << "int N \t\t\t Number of particles: use positive integer values only" << endl; cout << "int Nl \t\t\t Number of particles in left Fermi sea (Nr is then N - Nl)" << endl; - cout << "int DIl \t\t shift of left sea as compared to its ground state position" << endl; - cout << "int DIr \t\t shift of right sea as compared to its ground state position" << endl; + cout << "int DIl \t\t shift of left sea as compared to its ground state position" << endl; + cout << "int DIr \t\t shift of right sea as compared to its ground state position" << endl; cout << "int iKmin" << endl << "int iKmax \t\t Min and max momentum integers to scan over: recommended values: -2*N and 2*N" << endl; //cout << "DP kBT \t\t Temperature (positive only of course)" << endl; cout << "int Max_Secs \t\t Allowed computational time: (in seconds)" << endl; @@ -81,4 +81,3 @@ int main(int argc, char* argv[]) return(0); } - diff --git a/src/EXECS/LiebLin_DSF_MosesState_par.cc b/src/EXECS/LiebLin_DSF_MosesState_par.cc index 3553e40..217d6a0 100644 --- a/src/EXECS/LiebLin_DSF_MosesState_par.cc +++ b/src/EXECS/LiebLin_DSF_MosesState_par.cc @@ -2,21 +2,20 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- File: LiebLin_DSF_par.cc -Purpose: Parallel version of ABACUS++ using MPICH. - +Purpose: Parallel version of ABACUS using MPICH. ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" #include "mpi.h" -using namespace JSC; +using namespace ABACUS; int main(int argc, char *argv[]) { @@ -30,17 +29,17 @@ int main(int argc, char *argv[]) if (argc != 12) { // provide some info - cout << endl << "Welcome to ABACUS++\t(copyright J.-S. Caux)." << endl; + cout << endl << "Welcome to ABACUS\t(copyright J.-S. Caux)." << endl; cout << endl << "Usage of LiebLin_DSF_MosesState_par executable: " << endl; - cout << endl << "This function runs ABACUS++ in parallel mode, starting from a preexisting serial run (obtained using the LiebLin_DSF executable) using the same model parameters." << endl; + cout << endl << "This function runs ABACUS in parallel mode, starting from a preexisting serial run (obtained using the LiebLin_DSF executable) using the same model parameters." << endl; cout << endl << "Provide the following arguments:" << endl << endl; cout << "char whichDSF \t\t Which structure factor should be calculated ? Options are: d for rho rho, g for psi psi{dagger}, o for psi{dagger} psi" << endl; cout << "DP c_int \t\t Value of the interaction parameter: use positive real values only" << endl; cout << "DP L \t\t\t Length of the system: use positive real values only" << endl; cout << "int N \t\t\t Number of particles: use positive integer values only" << endl; cout << "int Nl \t\t\t Number of particles in left Fermi sea (Nr is then N - Nl)" << endl; - cout << "int DIl \t\t shift of left sea as compared to its ground state position" << endl; - cout << "int DIr \t\t shift of right sea as compared to its ground state position" << endl; + cout << "int DIl \t\t shift of left sea as compared to its ground state position" << endl; + cout << "int DIr \t\t shift of right sea as compared to its ground state position" << endl; cout << "int iKmin" << endl << "int iKmax \t\t Min and max momentum integers to scan over: recommended values: -2*N and 2*N" << endl; cout << "int Max_Secs \t\t Allowed computational time: (in seconds)" << endl; cout << "int supercycle_time \t\t time for one supercycle (in seconds)" << endl; @@ -66,21 +65,21 @@ int main(int argc, char *argv[]) //DP supercycle_time = 600.0; // allotted time per supercycle - if (Max_Secs <= supercycle_time) JSCerror("Please allow more time in LiebLin_DSF_par."); + if (Max_Secs <= supercycle_time) ABACUSerror("Please allow more time in LiebLin_DSF_par."); MPI::Init(argc, argv); - + DP tstart = MPI::Wtime(); - + int rank = MPI::COMM_WORLD.Get_rank(); int nr_processors = MPI::COMM_WORLD.Get_size(); - if (nr_processors < 2) JSCerror("Give at least 2 processors to ABACUS++ parallel !"); + if (nr_processors < 2) ABACUSerror("Give at least 2 processors to ABACUS parallel !"); refine = true; // ASSUMPTION: preexisting files (raw, thr, ...) exist for the run. - + DP tnow = MPI::Wtime(); @@ -106,27 +105,27 @@ int main(int argc, char *argv[]) // Split up thread list into chunks, one per processor //Prepare_Parallel_Scan_LiebLin (whichDSF, c_int, L, N, iK_UL, fixed_iK, iKneeded, nr_processors); Prepare_Parallel_Scan_LiebLin (whichDSF, c_int, L, N, iKmin, iKmax, kBT, defaultScanStatename, nr_processors); - - // Barrier synchronization, to make sure other processes wait for process of rank 0 + + // Barrier synchronization, to make sure other processes wait for process of rank 0 // to have finished splitting up the thr file into pieces before starting: MPI_Barrier (MPI::COMM_WORLD); - + // then everybody gets going on their own chunk ! - //Scan_LiebLin (whichDSF, c_int, L, N, iK_UL, fixed_iK, iKneeded, + //Scan_LiebLin (whichDSF, c_int, L, N, iK_UL, fixed_iK, iKneeded, //Scan_LiebLin (whichDSF, c_int, L, N, iKmin, iKmax, kBT, supercycle_time, target_sumrule, refine, rank, nr_processors); Scan_LiebLin (whichDSF, MosesState, defaultScanStatename, iKmin, iKmax, supercycle_time, target_sumrule, refine, rank, nr_processors); - - // Another barrier synchronization + + // Another barrier synchronization MPI_Barrier (MPI::COMM_WORLD); - + // Now that everybody is done, digest data into unique files - - if (rank == 0) + + if (rank == 0) //Wrapup_Parallel_Scan_LiebLin (whichDSF, c_int, L, N, iK_UL, fixed_iK, iKneeded, nr_processors); Wrapup_Parallel_Scan_LiebLin (whichDSF, c_int, L, N, iKmin, iKmax, kBT, defaultScanStatename, nr_processors); - // Another barrier synchronization - MPI_Barrier (MPI::COMM_WORLD); + // Another barrier synchronization + MPI_Barrier (MPI::COMM_WORLD); tnow = MPI::Wtime(); @@ -136,4 +135,3 @@ int main(int argc, char *argv[]) return(0); } - diff --git a/src/EXECS/LiebLin_DSF_MosesState_par_Prepare.cc b/src/EXECS/LiebLin_DSF_MosesState_par_Prepare.cc index 2eea6e1..7fdf66d 100644 --- a/src/EXECS/LiebLin_DSF_MosesState_par_Prepare.cc +++ b/src/EXECS/LiebLin_DSF_MosesState_par_Prepare.cc @@ -2,21 +2,20 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- File: LiebLin_DSF_par_Prepare.cc -Purpose: Parallel version of ABACUS++ using MPICH. - +Purpose: Parallel version of ABACUS using MPICH. ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" //#include "mpi.h" // not needed for Prepare -using namespace JSC; +using namespace ABACUS; int main(int argc, char *argv[]) { @@ -30,17 +29,17 @@ int main(int argc, char *argv[]) if (argc < 12) { // provide some info - cout << endl << "Welcome to ABACUS++\t(copyright J.-S. Caux)." << endl; + cout << endl << "Welcome to ABACUS\t(copyright J.-S. Caux)." << endl; cout << endl << "Usage of LiebLin_DSF_MosesState_par_Prepare executable: " << endl; - cout << endl << "This function prepares an ABACUS++ parallel mode run, starting from a preexisting serial run (obtained using the LiebLin_DSF executable) using the same model parameters." << endl; + cout << endl << "This function prepares an ABACUS parallel mode run, starting from a preexisting serial run (obtained using the LiebLin_DSF executable) using the same model parameters." << endl; cout << endl << "Provide the following arguments:" << endl << endl; cout << "char whichDSF \t\t Which structure factor should be calculated ? Options are: d for rho rho, g for psi psi{dagger}, o for psi{dagger} psi" << endl; cout << "DP c_int \t\t Value of the interaction parameter: use positive real values only" << endl; cout << "DP L \t\t\t Length of the system: use positive real values only" << endl; cout << "int N \t\t\t Number of particles: use positive integer values only" << endl; cout << "int Nl \t\t\t Number of particles in left Fermi sea (Nr is then N - Nl)" << endl; - cout << "int DIl \t\t shift of left sea as compared to its ground state position" << endl; - cout << "int DIr \t\t shift of right sea as compared to its ground state position" << endl; + cout << "int DIl \t\t shift of left sea as compared to its ground state position" << endl; + cout << "int DIr \t\t shift of right sea as compared to its ground state position" << endl; cout << "int iKmin" << endl << "int iKmax \t\t Min and max momentum integers to scan over: recommended values: -2*N and 2*N" << endl; cout << "int paralevel" << endl; cout << "rank[i], nr_processors[i] \t rank and nr_processors of each earlier paralevels." << endl; @@ -61,7 +60,7 @@ int main(int argc, char *argv[]) iKmin = atoi(argv[n++]); iKmax = atoi(argv[n++]); paralevel = atoi(argv[n++]); // paralevel == 1 means that we have one layer of parallelization, so no previous rank and nr_processors to specify - if (argc != 12 + 2*(paralevel - 1)) JSCerror("Wrong nr of arguments in LiebLin_DSF_MosesState_par_Prepare."); + if (argc != 12 + 2*(paralevel - 1)) ABACUSerror("Wrong nr of arguments in LiebLin_DSF_MosesState_par_Prepare."); Vect rank_lower_paralevels(paralevel - 1); Vect nr_processors_lower_paralevels(paralevel - 1); @@ -73,24 +72,23 @@ int main(int argc, char *argv[]) // Define the Moses state: LiebLin_Bethe_State MosesState (c_int, L, N); - + // Split the sea: for (int i = 0; i < Nl; ++i) MosesState.Ix2[i] += 2 * DIl; for (int i = Nl; i < N; ++i) MosesState.Ix2[i] += 2 * DIr; - + MosesState.Compute_All (true); - + // Handy default name: stringstream defaultScanStatename_strstream; defaultScanStatename_strstream << "Moses_Nl_" << Nl << "_DIl_" << DIl << "_DIr_" << DIr; string defaultScanStatename = defaultScanStatename_strstream.str(); - - + + // Split up thread list into chunks, one per processor Prepare_Parallel_Scan_LiebLin (whichDSF, c_int, L, N, iKmin, iKmax, kBT, defaultScanStatename, paralevel, rank_lower_paralevels, nr_processors_lower_paralevels, nr_processors_at_newlevel); - + } return(0); } - diff --git a/src/EXECS/LiebLin_DSF_MosesState_par_Run.cc b/src/EXECS/LiebLin_DSF_MosesState_par_Run.cc index c63de9b..88f2e2a 100644 --- a/src/EXECS/LiebLin_DSF_MosesState_par_Run.cc +++ b/src/EXECS/LiebLin_DSF_MosesState_par_Run.cc @@ -2,21 +2,20 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- File: LiebLin_DSF_par.cc -Purpose: Parallel version of ABACUS++ using MPICH. - +Purpose: Parallel version of ABACUS using MPICH. ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" #include "mpi.h" -using namespace JSC; +using namespace ABACUS; int main(int argc, char *argv[]) { @@ -30,17 +29,17 @@ int main(int argc, char *argv[]) if (argc < 13) { // provide some info - cout << endl << "Welcome to ABACUS++\t(copyright J.-S. Caux)." << endl; + cout << endl << "Welcome to ABACUS\t(copyright J.-S. Caux)." << endl; cout << endl << "Usage of LiebLin_DSF_MosesState_par_Run executable: " << endl; - cout << endl << "This function runs ABACUS++ in parallel mode, starting from a preexisting serial run (obtained using the LiebLin_DSF executable) using the same model parameters." << endl; + cout << endl << "This function runs ABACUS in parallel mode, starting from a preexisting serial run (obtained using the LiebLin_DSF executable) using the same model parameters." << endl; cout << endl << "Provide the following arguments:" << endl << endl; cout << "char whichDSF \t\t Which structure factor should be calculated ? Options are: d for rho rho, g for psi psi{dagger}, o for psi{dagger} psi" << endl; cout << "DP c_int \t\t Value of the interaction parameter: use positive real values only" << endl; cout << "DP L \t\t\t Length of the system: use positive real values only" << endl; cout << "int N \t\t\t Number of particles: use positive integer values only" << endl; cout << "int Nl \t\t\t Number of particles in left Fermi sea (Nr is then N - Nl)" << endl; - cout << "int DIl \t\t shift of left sea as compared to its ground state position" << endl; - cout << "int DIr \t\t shift of right sea as compared to its ground state position" << endl; + cout << "int DIl \t\t shift of left sea as compared to its ground state position" << endl; + cout << "int DIr \t\t shift of right sea as compared to its ground state position" << endl; cout << "int iKmin" << endl << "int iKmax \t\t Min and max momentum integers to scan over: recommended values: -2*N and 2*N" << endl; cout << "int paralevel" << endl; cout << "rank[i], nr_processors[i] \t rank and nr_processors of each earlier paralevels." << endl; @@ -62,7 +61,7 @@ int main(int argc, char *argv[]) iKmin = atoi(argv[n++]); iKmax = atoi(argv[n++]); paralevel = atoi(argv[n++]); // paralevel == 1 means that we have one layer of parallelization, so no previous rank and nr_processors to specify - if (argc != 13 + 2*(paralevel - 1)) JSCerror("Wrong nr of arguments in LiebLin_DSF_par_Prepare."); + if (argc != 13 + 2*(paralevel - 1)) ABACUSerror("Wrong nr of arguments in LiebLin_DSF_par_Prepare."); Vect rank_lower_paralevels(paralevel - 1); Vect nr_processors_lower_paralevels(paralevel - 1); for (int i = 0; i < paralevel - 1; ++i) { @@ -75,12 +74,12 @@ int main(int argc, char *argv[]) //DP supercycle_time = 600.0; // allotted time per supercycle - if (Max_Secs <= supercycle_time) JSCerror("Please allow more time in LiebLin_DSF_par_Run."); + if (Max_Secs <= supercycle_time) ABACUSerror("Please allow more time in LiebLin_DSF_par_Run."); MPI::Init(argc, argv); - + DP tstart = MPI::Wtime(); - + int rank_here = MPI::COMM_WORLD.Get_rank(); int nr_processors_here = MPI::COMM_WORLD.Get_size(); @@ -95,33 +94,33 @@ int main(int argc, char *argv[]) rank[paralevel-1] = rank_here; nr_processors[paralevel-1] = nr_processors_here; - if (nr_processors_here < 2) JSCerror("Give at least 2 processors to ABACUS++ parallel !"); + if (nr_processors_here < 2) ABACUSerror("Give at least 2 processors to ABACUS parallel !"); refine = true; // ASSUMPTION: preexisting files (raw, thr, ...) exist for the run. - + DP tnow = MPI::Wtime(); // Define the Moses state: LiebLin_Bethe_State MosesState (c_int, L, N); - + // Split the sea: for (int i = 0; i < Nl; ++i) MosesState.Ix2[i] += 2 * DIl; for (int i = Nl; i < N; ++i) MosesState.Ix2[i] += 2 * DIr; - + MosesState.Compute_All (true); - + // Handy default name: stringstream defaultScanStatename_strstream; defaultScanStatename_strstream << "Moses_Nl_" << Nl << "_DIl_" << DIl << "_DIr_" << DIr; string defaultScanStatename = defaultScanStatename_strstream.str(); - + //cout << "rank " << rank_here << " out of " << nr_processors_here << " waiting at barrier." << endl; MPI_Barrier (MPI::COMM_WORLD); - + while (tnow - tstart < Max_Secs - supercycle_time - 120) { // space for one more supercycle, + 2 minutes safety @@ -129,27 +128,27 @@ int main(int argc, char *argv[]) // Split up thread list into chunks, one per processor //Prepare_Parallel_Scan_LiebLin (whichDSF, c_int, L, N, iK_UL, fixed_iK, iKneeded, nr_processors); //Prepare_Parallel_Scan_LiebLin (whichDSF, c_int, L, N, iKmin, iKmax, kBT, defaultScanStatename, nr_processors); - - // Barrier synchronization, to make sure other processes wait for process of rank 0 + + // Barrier synchronization, to make sure other processes wait for process of rank 0 // to have finished splitting up the thr file into pieces before starting: MPI_Barrier (MPI::COMM_WORLD); - + // then everybody gets going on their own chunk ! - //Scan_LiebLin (whichDSF, c_int, L, N, iK_UL, fixed_iK, iKneeded, + //Scan_LiebLin (whichDSF, c_int, L, N, iK_UL, fixed_iK, iKneeded, //Scan_LiebLin (whichDSF, c_int, L, N, iKmin, iKmax, kBT, supercycle_time, target_sumrule, refine, paralevel, rank, nr_processors); Scan_LiebLin (whichDSF, MosesState, defaultScanStatename, iKmin, iKmax, supercycle_time, target_sumrule, refine, paralevel, rank, nr_processors); - - // Another barrier synchronization + + // Another barrier synchronization MPI_Barrier (MPI::COMM_WORLD); - + // Now that everybody is done, digest data into unique files - - //if (rank == 0) + + //if (rank == 0) //Wrapup_Parallel_Scan_LiebLin (whichDSF, c_int, L, N, iK_UL, fixed_iK, iKneeded, nr_processors); //Wrapup_Parallel_Scan_LiebLin (whichDSF, c_int, L, N, iKmin, iKmax, kBT, defaultScanStatename, nr_processors); - // Another barrier synchronization - MPI_Barrier (MPI::COMM_WORLD); + // Another barrier synchronization + MPI_Barrier (MPI::COMM_WORLD); tnow = MPI::Wtime(); @@ -159,4 +158,3 @@ int main(int argc, char *argv[]) return(0); } - diff --git a/src/EXECS/LiebLin_DSF_MosesState_par_Wrapup.cc b/src/EXECS/LiebLin_DSF_MosesState_par_Wrapup.cc index f7fae54..f662adc 100644 --- a/src/EXECS/LiebLin_DSF_MosesState_par_Wrapup.cc +++ b/src/EXECS/LiebLin_DSF_MosesState_par_Wrapup.cc @@ -2,21 +2,20 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- File: LiebLin_DSF_MosesState_par_Wrapup.cc -Purpose: Parallel version of ABACUS++ using MPICH. - +Purpose: Parallel version of ABACUS using MPICH. ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" //#include "mpi.h" // not needed for Prepare -using namespace JSC; +using namespace ABACUS; int main(int argc, char *argv[]) { @@ -30,17 +29,17 @@ int main(int argc, char *argv[]) if (argc < 12) { // provide some info - cout << endl << "Welcome to ABACUS++\t(copyright J.-S. Caux)." << endl; + cout << endl << "Welcome to ABACUS\t(copyright J.-S. Caux)." << endl; cout << endl << "Usage of LiebLin_DSF_MosesState_par_Wrapup executable: " << endl; - cout << endl << "This function wraps up an ABACUS++ parallel mode run." << endl; + cout << endl << "This function wraps up an ABACUS parallel mode run." << endl; cout << endl << "Provide the following arguments:" << endl << endl; cout << "char whichDSF \t\t Which structure factor should be calculated ? Options are: d for rho rho, g for psi psi{dagger}, o for psi{dagger} psi" << endl; cout << "DP c_int \t\t Value of the interaction parameter: use positive real values only" << endl; cout << "DP L \t\t\t Length of the system: use positive real values only" << endl; cout << "int N \t\t\t Number of particles: use positive integer values only" << endl; cout << "int Nl \t\t\t Number of particles in left Fermi sea (Nr is then N - Nl)" << endl; - cout << "int DIl \t\t shift of left sea as compared to its ground state position" << endl; - cout << "int DIr \t\t shift of right sea as compared to its ground state position" << endl; + cout << "int DIl \t\t shift of left sea as compared to its ground state position" << endl; + cout << "int DIr \t\t shift of right sea as compared to its ground state position" << endl; cout << "int iKmin" << endl << "int iKmax \t\t Min and max momentum integers to scan over: recommended values: -2*N and 2*N" << endl; cout << "int paralevel" << endl; cout << "rank[i], nr_processors[i] \t rank and nr_processors of each earlier paralevels." << endl; @@ -61,7 +60,7 @@ int main(int argc, char *argv[]) iKmin = atoi(argv[n++]); iKmax = atoi(argv[n++]); paralevel = atoi(argv[n++]); // paralevel == 1 means that we have one layer of parallelization, so no previous rank and nr_processors to specify - if (argc != 12 + 2*(paralevel - 1)) JSCerror("Wrong nr of arguments in LiebLin_DSF_MosesState_par_Prepare."); + if (argc != 12 + 2*(paralevel - 1)) ABACUSerror("Wrong nr of arguments in LiebLin_DSF_MosesState_par_Prepare."); Vect rank_lower_paralevels(paralevel - 1); Vect nr_processors_lower_paralevels(paralevel - 1); @@ -73,24 +72,23 @@ int main(int argc, char *argv[]) // Define the Moses state: LiebLin_Bethe_State MosesState (c_int, L, N); - + // Split the sea: for (int i = 0; i < Nl; ++i) MosesState.Ix2[i] += 2 * DIl; for (int i = Nl; i < N; ++i) MosesState.Ix2[i] += 2 * DIr; - + MosesState.Compute_All (true); - + // Handy default name: stringstream defaultScanStatename_strstream; defaultScanStatename_strstream << "Moses_Nl_" << Nl << "_DIl_" << DIl << "_DIr_" << DIr; string defaultScanStatename = defaultScanStatename_strstream.str(); - - + + // Digest files into a unique one for the latest paralevel: Wrapup_Parallel_Scan_LiebLin (whichDSF, c_int, L, N, iKmin, iKmax, kBT, defaultScanStatename, paralevel, rank_lower_paralevels, nr_processors_lower_paralevels, nr_processors_at_newlevel); - + } return(0); } - diff --git a/src/EXECS/LiebLin_DSF_over_Ensemble.cc b/src/EXECS/LiebLin_DSF_over_Ensemble.cc index 9ba8934..6038c96 100644 --- a/src/EXECS/LiebLin_DSF_over_Ensemble.cc +++ b/src/EXECS/LiebLin_DSF_over_Ensemble.cc @@ -2,28 +2,28 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- File: LiebLin_DSF_over_Ensemble.cc -Purpose: main function for ABACUS++T for LiebLin gas, averaging over an Ensemble. +Purpose: main function for ABACUS for LiebLin gas, averaging over an Ensemble. ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -int main(int argc, char* argv[]) +int main(int argc, char* argv[]) { if (argc != 10) { // provide some info - cout << endl << "Welcome to ABACUS++\t(copyright J.-S. Caux)." << endl; + cout << endl << "Welcome to ABACUS\t(copyright J.-S. Caux)." << endl; cout << endl << "Usage of LiebLin_DSF_Tgt0 executable: " << endl; cout << endl << "Provide the following arguments:" << endl << endl; cout << "char whichDSF \t\t Which structure factor should be calculated ? Options are: d for rho rho, g for psi psi{dagger}, o for psi{dagger} psi" << endl; @@ -75,7 +75,7 @@ int main(int argc, char* argv[]) // Now perform the DSF calculation over each state in the ensemble, distributing the time according to the weight for (int ns = 0; ns < ensemble.nstates; ++ns) { - //void Scan_LiebLin (char whichDSF, LiebLin_Bethe_State AveragingState, string defaultScanStatename, int iKmin, int iKmax, + //void Scan_LiebLin (char whichDSF, LiebLin_Bethe_State AveragingState, string defaultScanStatename, int iKmin, int iKmax, //int Max_Secs, DP target_sumrule, bool refine, int rank, int nr_processors) //Scan_LiebLin (whichDSF, ensemble.state[ns], ensemble.state[ns].label, iKmin, iKmax, int(Max_Secs * ensemble.weight[ns]), 1.0e+6, refine, 0, 1); Scan_LiebLin (whichDSF, ensemble.state[ns], ensemble.state[ns].label, iKmin, iKmax, int(Max_Secs * ensemble.weight[ns]), 1.0e+6, refine); @@ -86,7 +86,7 @@ int main(int argc, char* argv[]) Data_File_Name (FSR_stringstream, whichDSF, c_int, L, N, iKmin, iKmax, kBT, 0.0, ""); FSR_stringstream << "_ns_" << ensemble.nstates << ".fsr"; FSR_string = FSR_stringstream.str(); const char* FSR_Cstr = FSR_string.c_str(); - + DP Chem_Pot = 0.0; Evaluate_F_Sumrule (whichDSF, c_int, L, N, kBT, ensemble.nstates, Chem_Pot, iKmin, iKmax, FSR_Cstr); @@ -96,4 +96,3 @@ int main(int argc, char* argv[]) return(0); } - diff --git a/src/EXECS/LiebLin_DSF_over_Ensemble_par.cc b/src/EXECS/LiebLin_DSF_over_Ensemble_par.cc index 0f2b32e..d0e08e2 100644 --- a/src/EXECS/LiebLin_DSF_over_Ensemble_par.cc +++ b/src/EXECS/LiebLin_DSF_over_Ensemble_par.cc @@ -2,7 +2,7 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -12,19 +12,19 @@ Purpose: main function for ABACUS for LiebLin gas, averaging over an Ensemble, ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" #include "mpi.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -int main(int argc, char* argv[]) +int main(int argc, char* argv[]) { if (argc != 10) { // provide some info - cout << endl << "Welcome to ABACUS++\t(copyright J.-S. Caux)." << endl; + cout << endl << "Welcome to ABACUS\t(copyright J.-S. Caux)." << endl; cout << endl << "Usage of LiebLin_DSF_Tgt0 executable: " << endl; cout << endl << "Provide the following arguments:" << endl << endl; cout << "char whichDSF \t\t Which structure factor should be calculated ? Options are: d for rho rho, g for psi psi{dagger}, o for psi{dagger} psi" << endl; @@ -53,16 +53,16 @@ int main(int argc, char* argv[]) int Max_Secs = atoi(argv[8]); bool refine = (atoi(argv[9]) == 1); - if (refine == false) JSCerror("Please run the serial version of LiebLin_DSF_over_Ensemble first."); + if (refine == false) ABACUSerror("Please run the serial version of LiebLin_DSF_over_Ensemble first."); MPI::Init(argc, argv); - + DP tstart = MPI::Wtime(); - + int rank = MPI::COMM_WORLD.Get_rank(); int nr_processors = MPI::COMM_WORLD.Get_size(); - - if (nr_processors < 2) JSCerror("Give at least 2 processors to ABACUS++ parallel !"); + + if (nr_processors < 2) ABACUSerror("Give at least 2 processors to ABACUS parallel !"); // Start by constructing (or loading) the state ensemble. @@ -91,16 +91,16 @@ int main(int argc, char* argv[]) /* Original implementation: Scan always called serially. Superseded by version below, using successive parallel scans on each state in the ensemble. int nDSFperproc = ensemble.nstates/nr_processors + 1; - //if (ensemble.nstates % nr_processors) JSCerror("Use nr_processors * integer multiple == ensemble.nstates in LiebLin_DSF_over_Ensemble_par."); - - // Processor with rank r does all + //if (ensemble.nstates % nr_processors) ABACUSerror("Use nr_processors * integer multiple == ensemble.nstates in LiebLin_DSF_over_Ensemble_par."); + + // Processor with rank r does all int ns; int Max_Secs_used = Max_Secs/nDSFperproc; for (int ir = 0; ir < nDSFperproc; ++ir) { ns = rank + ir * nr_processors; - //void Scan_LiebLin (char whichDSF, LiebLin_Bethe_State AveragingState, string defaultScanStatename, int iKmin, int iKmax, + //void Scan_LiebLin (char whichDSF, LiebLin_Bethe_State AveragingState, string defaultScanStatename, int iKmin, int iKmax, //int Max_Secs, DP target_sumrule, bool refine, int rank, int nr_processors) if (ns < ensemble.nstates) { //cout << "Processor rank " << rank << " going for ns = " << ns << " out of " << ensemble.nstates << endl; @@ -117,13 +117,13 @@ int main(int argc, char* argv[]) DP supercycle_time = 600.0; // allotted time per supercycle - if (Max_Secs_used <= supercycle_time) JSCerror("Please allow more time in LiebLin_DSF_par."); + if (Max_Secs_used <= supercycle_time) ABACUSerror("Please allow more time in LiebLin_DSF_par."); // Main loop over ensemble: - for (int ns = 0; ns < ensemble.nstates; ++ns) { - + for (int ns = 0; ns < ensemble.nstates; ++ns) { + tstart = MPI::Wtime(); - DP tnow = MPI::Wtime(); + DP tnow = MPI::Wtime(); string defaultScanStatename = ensemble.state[ns].label; @@ -133,31 +133,31 @@ int main(int argc, char* argv[]) // Split up thread list into chunks, one per processor //Prepare_Parallel_Scan_LiebLin (whichDSF, c_int, L, N, iK_UL, fixed_iK, iKneeded, nr_processors); Prepare_Parallel_Scan_LiebLin (whichDSF, c_int, L, N, iKmin, iKmax, kBT, defaultScanStatename, nr_processors); - - // Barrier synchronization, to make sure other processes wait for process of rank 0 + + // Barrier synchronization, to make sure other processes wait for process of rank 0 // to have finished splitting up the thr file into pieces before starting: MPI_Barrier (MPI::COMM_WORLD); - + // then everybody gets going on their own chunk ! - //Scan_LiebLin (whichDSF, c_int, L, N, iK_UL, fixed_iK, iKneeded, + //Scan_LiebLin (whichDSF, c_int, L, N, iK_UL, fixed_iK, iKneeded, //Scan_LiebLin (whichDSF, c_int, L, N, iKmin, iKmax, kBT, //supercycle_time, target_sumrule, refine, rank, nr_processors); Scan_LiebLin (whichDSF, ensemble.state[ns], ensemble.state[ns].label, iKmin, iKmax, supercycle_time, 1.0e+6, refine, rank, nr_processors); - - // Another barrier synchronization + + // Another barrier synchronization MPI_Barrier (MPI::COMM_WORLD); - + // Now that everybody is done, digest data into unique files - - if (rank == 0) + + if (rank == 0) //Wrapup_Parallel_Scan_LiebLin (whichDSF, c_int, L, N, iK_UL, fixed_iK, iKneeded, nr_processors); Wrapup_Parallel_Scan_LiebLin (whichDSF, c_int, L, N, iKmin, iKmax, kBT, defaultScanStatename, nr_processors); - // Another barrier synchronization - MPI_Barrier (MPI::COMM_WORLD); + // Another barrier synchronization + MPI_Barrier (MPI::COMM_WORLD); tnow = MPI::Wtime(); - + } // while (tnow - tstart... } // for ns @@ -174,9 +174,9 @@ int main(int argc, char* argv[]) Data_File_Name (FSR_stringstream, whichDSF, c_int, L, N, iKmin, iKmax, kBT, 0.0, ""); FSR_stringstream << "_ns_" << ensemble.nstates << ".fsr"; FSR_string = FSR_stringstream.str(); const char* FSR_Cstr = FSR_string.c_str(); - + DP Chem_Pot = 0.0; - + Evaluate_F_Sumrule (whichDSF, c_int, L, N, kBT, ensemble.nstates, Chem_Pot, iKmin, iKmax, FSR_Cstr); } @@ -188,4 +188,3 @@ int main(int argc, char* argv[]) return(0); } - diff --git a/src/EXECS/LiebLin_DSF_par.cc b/src/EXECS/LiebLin_DSF_par.cc index 9903e2b..58a9993 100644 --- a/src/EXECS/LiebLin_DSF_par.cc +++ b/src/EXECS/LiebLin_DSF_par.cc @@ -2,21 +2,20 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- File: LiebLin_DSF_par.cc -Purpose: Parallel version of ABACUS++ using MPICH. - +Purpose: Parallel version of ABACUS using MPICH. ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" #include "mpi.h" -using namespace JSC; +using namespace ABACUS; int main(int argc, char *argv[]) { @@ -28,9 +27,9 @@ int main(int argc, char *argv[]) if (argc != 10) { // provide some info - cout << endl << "Welcome to ABACUS++\t(copyright J.-S. Caux)." << endl; + cout << endl << "Welcome to ABACUS\t(copyright J.-S. Caux)." << endl; cout << endl << "Usage of LiebLin_DSF_par executable: " << endl; - cout << endl << "This function runs ABACUS++ in parallel mode, starting from a preexisting serial run (obtained using the LiebLin_DSF executable) using the same model parameters." << endl; + cout << endl << "This function runs ABACUS in parallel mode, starting from a preexisting serial run (obtained using the LiebLin_DSF executable) using the same model parameters." << endl; cout << endl << "Provide the following arguments:" << endl << endl; cout << "char whichDSF \t\t Which structure factor should be calculated ? Options are: d for rho rho, g for psi psi{dagger}, o for psi{dagger} psi" << endl; cout << "DP c_int \t\t Value of the interaction parameter: use positive real values only" << endl; @@ -60,21 +59,21 @@ int main(int argc, char *argv[]) //DP supercycle_time = 600.0; // allotted time per supercycle - if (Max_Secs <= supercycle_time) JSCerror("Please allow more time in LiebLin_DSF_par."); + if (Max_Secs <= supercycle_time) ABACUSerror("Please allow more time in LiebLin_DSF_par."); MPI::Init(argc, argv); - + DP tstart = MPI::Wtime(); - + int rank = MPI::COMM_WORLD.Get_rank(); int nr_processors = MPI::COMM_WORLD.Get_size(); - if (nr_processors < 2) JSCerror("Give at least 2 processors to ABACUS++ parallel !"); + if (nr_processors < 2) ABACUSerror("Give at least 2 processors to ABACUS parallel !"); refine = true; // ASSUMPTION: preexisting files (raw, thr, ...) exist for the run. - + DP tnow = MPI::Wtime(); @@ -86,27 +85,27 @@ int main(int argc, char *argv[]) // Split up thread list into chunks, one per processor //Prepare_Parallel_Scan_LiebLin (whichDSF, c_int, L, N, iK_UL, fixed_iK, iKneeded, nr_processors); Prepare_Parallel_Scan_LiebLin (whichDSF, c_int, L, N, iKmin, iKmax, kBT, defaultScanStatename, nr_processors); - - // Barrier synchronization, to make sure other processes wait for process of rank 0 + + // Barrier synchronization, to make sure other processes wait for process of rank 0 // to have finished splitting up the thr file into pieces before starting: MPI_Barrier (MPI::COMM_WORLD); - + // then everybody gets going on their own chunk ! - //Scan_LiebLin (whichDSF, c_int, L, N, iK_UL, fixed_iK, iKneeded, + //Scan_LiebLin (whichDSF, c_int, L, N, iK_UL, fixed_iK, iKneeded, Scan_LiebLin (whichDSF, c_int, L, N, iKmin, iKmax, kBT, supercycle_time, target_sumrule, refine, rank, nr_processors); - - // Another barrier synchronization + + // Another barrier synchronization MPI_Barrier (MPI::COMM_WORLD); - + // Now that everybody is done, digest data into unique files - - if (rank == 0) + + if (rank == 0) //Wrapup_Parallel_Scan_LiebLin (whichDSF, c_int, L, N, iK_UL, fixed_iK, iKneeded, nr_processors); Wrapup_Parallel_Scan_LiebLin (whichDSF, c_int, L, N, iKmin, iKmax, kBT, defaultScanStatename, nr_processors); - // Another barrier synchronization - MPI_Barrier (MPI::COMM_WORLD); + // Another barrier synchronization + MPI_Barrier (MPI::COMM_WORLD); tnow = MPI::Wtime(); @@ -116,4 +115,3 @@ int main(int argc, char *argv[]) return(0); } - diff --git a/src/EXECS/LiebLin_DSF_par_Prepare.cc b/src/EXECS/LiebLin_DSF_par_Prepare.cc index 5fe5a21..f3afe88 100644 --- a/src/EXECS/LiebLin_DSF_par_Prepare.cc +++ b/src/EXECS/LiebLin_DSF_par_Prepare.cc @@ -2,21 +2,20 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- File: LiebLin_DSF_par_Prepare.cc -Purpose: Parallel version of ABACUS++ using MPICH. - +Purpose: Parallel version of ABACUS using MPICH. ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" //#include "mpi.h" // not needed for Prepare -using namespace JSC; +using namespace ABACUS; int main(int argc, char *argv[]) { @@ -28,9 +27,9 @@ int main(int argc, char *argv[]) if (argc < 10) { // provide some info - cout << endl << "Welcome to ABACUS++\t(copyright J.-S. Caux)." << endl; + cout << endl << "Welcome to ABACUS\t(copyright J.-S. Caux)." << endl; cout << endl << "Usage of LiebLin_DSF_par_Prepare executable: " << endl; - cout << endl << "This function prepares an ABACUS++ parallel mode run, starting from a preexisting serial run (obtained using the LiebLin_DSF executable) using the same model parameters." << endl; + cout << endl << "This function prepares an ABACUS parallel mode run, starting from a preexisting serial run (obtained using the LiebLin_DSF executable) using the same model parameters." << endl; cout << endl << "Provide the following arguments:" << endl << endl; cout << "char whichDSF \t\t Which structure factor should be calculated ? Options are: d for rho rho, g for psi psi{dagger}, o for psi{dagger} psi" << endl; cout << "DP c_int \t\t Value of the interaction parameter: use positive real values only" << endl; @@ -55,7 +54,7 @@ int main(int argc, char *argv[]) iKmax = atoi(argv[n++]); kBT = atof(argv[n++]); paralevel = atoi(argv[n++]); // paralevel == 1 means that we have one layer of parallelization, so no previous rank and nr_processors to specify - if (argc != 10 + 2*(paralevel - 1)) JSCerror("Wrong nr of arguments in LiebLin_DSF_par_Prepare."); + if (argc != 10 + 2*(paralevel - 1)) ABACUSerror("Wrong nr of arguments in LiebLin_DSF_par_Prepare."); Vect rank_lower_paralevels(paralevel - 1); Vect nr_processors_lower_paralevels(paralevel - 1); @@ -66,12 +65,11 @@ int main(int argc, char *argv[]) nr_processors_at_newlevel = atoi(argv[n++]); string defaultScanStatename = ""; - + // Split up thread list into chunks, one per processor Prepare_Parallel_Scan_LiebLin (whichDSF, c_int, L, N, iKmin, iKmax, kBT, defaultScanStatename, paralevel, rank_lower_paralevels, nr_processors_lower_paralevels, nr_processors_at_newlevel); - + } return(0); } - diff --git a/src/EXECS/LiebLin_DSF_par_Run.cc b/src/EXECS/LiebLin_DSF_par_Run.cc index e9a42f7..c9eca98 100644 --- a/src/EXECS/LiebLin_DSF_par_Run.cc +++ b/src/EXECS/LiebLin_DSF_par_Run.cc @@ -2,21 +2,20 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- File: LiebLin_DSF_par_Run.cc -Purpose: Parallel version of ABACUS++ using MPICH. - +Purpose: Parallel version of ABACUS using MPICH. ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" #include "mpi.h" -using namespace JSC; +using namespace ABACUS; int main(int argc, char *argv[]) { @@ -28,9 +27,9 @@ int main(int argc, char *argv[]) if (argc < 10) { // provide some info - cout << endl << "Welcome to ABACUS++\t(copyright J.-S. Caux)." << endl; + cout << endl << "Welcome to ABACUS\t(copyright J.-S. Caux)." << endl; cout << endl << "Usage of LiebLin_DSF_par_Run executable: " << endl; - cout << endl << "This function runs ABACUS++ in parallel mode, starting from a preexisting serial run (obtained using the LiebLin_DSF executable) using the same model parameters." << endl; + cout << endl << "This function runs ABACUS in parallel mode, starting from a preexisting serial run (obtained using the LiebLin_DSF executable) using the same model parameters." << endl; cout << endl << "Provide the following arguments:" << endl << endl; cout << "char whichDSF \t\t Which structure factor should be calculated ? Options are: d for rho rho, g for psi psi{dagger}, o for psi{dagger} psi" << endl; cout << "DP c_int \t\t Value of the interaction parameter: use positive real values only" << endl; @@ -56,7 +55,7 @@ int main(int argc, char *argv[]) iKmax = atoi(argv[n++]); kBT = atof(argv[n++]); paralevel = atoi(argv[n++]); // paralevel == 1 means that we have one layer of parallelization, so no previous rank and nr_processors to specify - if (argc != 10 + 2*(paralevel - 1)) JSCerror("Wrong nr of arguments in LiebLin_DSF_par_Run."); + if (argc != 10 + 2*(paralevel - 1)) ABACUSerror("Wrong nr of arguments in LiebLin_DSF_par_Run."); Vect rank_lower_paralevels(paralevel - 1); Vect nr_processors_lower_paralevels(paralevel - 1); for (int i = 0; i < paralevel - 1; ++i) { @@ -65,14 +64,14 @@ int main(int argc, char *argv[]) } Max_Secs = atoi(argv[n++]); - if (Max_Secs < 120) JSCerror("Please allow more time in LiebLin_DSF_par_Run."); + if (Max_Secs < 120) ABACUSerror("Please allow more time in LiebLin_DSF_par_Run."); int Max_Secs_used = Max_Secs - 120; MPI::Init(argc, argv); - + DP tstart = MPI::Wtime(); - + int rank_here = MPI::COMM_WORLD.Get_rank(); int nr_processors_here = MPI::COMM_WORLD.Get_size(); @@ -85,12 +84,12 @@ int main(int argc, char *argv[]) rank[paralevel-1] = rank_here; nr_processors[paralevel-1] = nr_processors_here; - if (nr_processors_here < 2) JSCerror("Give at least 2 processors to ABACUS parallel !"); + if (nr_processors_here < 2) ABACUSerror("Give at least 2 processors to ABACUS parallel !"); refine = true; // ASSUMPTION: preexisting files (raw, thr, ...) exist for the run. - + DP tnow = MPI::Wtime(); @@ -100,21 +99,20 @@ int main(int argc, char *argv[]) // Barrier synchronization MPI_Barrier (MPI::COMM_WORLD); - + // then everybody gets going on their own chunk ! - //Scan_LiebLin (whichDSF, c_int, L, N, iK_UL, fixed_iK, iKneeded, + //Scan_LiebLin (whichDSF, c_int, L, N, iK_UL, fixed_iK, iKneeded, Scan_LiebLin (whichDSF, c_int, L, N, iKmin, iKmax, kBT, Max_Secs_used, target_sumrule, refine, paralevel, rank, nr_processors); - - // Another barrier synchronization + + // Another barrier synchronization MPI_Barrier (MPI::COMM_WORLD); - + tnow = MPI::Wtime(); - } + } MPI::Finalize(); return(0); } - diff --git a/src/EXECS/LiebLin_DSF_par_Wrapup.cc b/src/EXECS/LiebLin_DSF_par_Wrapup.cc index 51c5d45..04815a3 100644 --- a/src/EXECS/LiebLin_DSF_par_Wrapup.cc +++ b/src/EXECS/LiebLin_DSF_par_Wrapup.cc @@ -2,21 +2,20 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- File: LiebLin_DSF_par_Wrapup.cc -Purpose: Parallel version of ABACUS++ using MPICH. - +Purpose: Parallel version of ABACUS using MPICH. ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" //#include "mpi.h" // not needed for Prepare or Wrapup -using namespace JSC; +using namespace ABACUS; int main(int argc, char *argv[]) { @@ -28,9 +27,9 @@ int main(int argc, char *argv[]) if (argc < 10) { // provide some info - cout << endl << "Welcome to ABACUS++\t(copyright J.-S. Caux)." << endl; + cout << endl << "Welcome to ABACUS\t(copyright J.-S. Caux)." << endl; cout << endl << "Usage of LiebLin_DSF_par_Wrapup executable: " << endl; - cout << endl << "This function wraps up an ABACUS++ parallel mode run." << endl; + cout << endl << "This function wraps up an ABACUS parallel mode run." << endl; cout << endl << "Provide the following arguments:" << endl << endl; cout << "char whichDSF \t\t Which structure factor should be calculated ? Options are: d for rho rho, g for psi psi{dagger}, o for psi{dagger} psi" << endl; cout << "DP c_int \t\t Value of the interaction parameter: use positive real values only" << endl; @@ -55,7 +54,7 @@ int main(int argc, char *argv[]) iKmax = atoi(argv[n++]); kBT = atof(argv[n++]); paralevel = atoi(argv[n++]); // paralevel == 1 means that we have one layer of parallelization, so no previous rank and nr_processors to specify - if (argc != 10 + 2*(paralevel - 1)) JSCerror("Wrong nr of arguments in LiebLin_DSF_par_Wrapup."); + if (argc != 10 + 2*(paralevel - 1)) ABACUSerror("Wrong nr of arguments in LiebLin_DSF_par_Wrapup."); Vect rank_lower_paralevels(paralevel - 1); Vect nr_processors_lower_paralevels(paralevel - 1); @@ -66,12 +65,11 @@ int main(int argc, char *argv[]) nr_processors_at_newlevel = atoi(argv[n++]); string defaultScanStatename = ""; - + // Digest files into a unique one for the latest paralevel: Wrapup_Parallel_Scan_LiebLin (whichDSF, c_int, L, N, iKmin, iKmax, kBT, defaultScanStatename, paralevel, rank_lower_paralevels, nr_processors_lower_paralevels, nr_processors_at_newlevel); - + } return(0); } - diff --git a/src/EXECS/LiebLin_DSF_tester.cc b/src/EXECS/LiebLin_DSF_tester.cc index a68c4f9..03f0410 100644 --- a/src/EXECS/LiebLin_DSF_tester.cc +++ b/src/EXECS/LiebLin_DSF_tester.cc @@ -2,7 +2,7 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -12,18 +12,18 @@ Purpose: allows for Ix2 manipulations (user-prompted) for LiebLin gas ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -int main(int argc, char* argv[]) +int main(int argc, char* argv[]) { if (argc != 6) { // provide some info - cout << endl << "Welcome to ABACUS++\t(copyright J.-S. Caux)." << endl; + cout << endl << "Welcome to ABACUS\t(copyright J.-S. Caux)." << endl; cout << endl << "Usage of LiebLin_DSF_tester executable: " << endl; cout << endl << "Provide the following arguments:" << endl << endl; cout << "char whichDSF \t\t Which structure factor should be calculated ? Options are: d for rho rho, g for psi psi{dagger}, o for psi{dagger} psi" << endl; @@ -42,10 +42,10 @@ int main(int argc, char* argv[]) int N = atoi(argv[4]); DP kBT = atof(argv[5]); - //if (whichDSF != 'd') JSCerror("Other options not implemented yet in finite T Scan_LiebLin"); + //if (whichDSF != 'd') ABACUSerror("Other options not implemented yet in finite T Scan_LiebLin"); // Delta is the number of sites involved in the smoothing of the entropy - //int Delta = int(sqrt(N))/2;//6;//N/20; + //int Delta = int(sqrt(N))/2;//6;//N/20; // Construct the finite-size saddle-point state: //LiebLin_Bethe_State spstate = Canonical_Saddle_Point_State (c_int, L, N, kBT, Delta); @@ -73,11 +73,11 @@ int main(int argc, char* argv[]) estate.Compute_All(false); cout << spstate << endl; cout << estate; - if (whichDSF == 'd') + if (whichDSF == 'd') cout << setprecision(16) << "estate.E - spstate.E = " << estate.E - spstate.E << "\tME = " << real(exp(ln_Density_ME(spstate, estate))) << endl; - else if (whichDSF == 'o') + else if (whichDSF == 'o') cout << setprecision(16) << "estate.E - spstate.E = " << estate.E - spstate.E << "\tME = " << real(exp(ln_Psi_ME(estate, spstate))) << endl; - else if (whichDSF == 'g') + else if (whichDSF == 'g') cout << setprecision(16) << "estate.E - spstate.E = " << estate.E - spstate.E << "\tME = " << real(exp(ln_Psi_ME(spstate, estate))) << endl; //cout << "Another try ? (1 == yes, 0 == no)" << endl; @@ -89,4 +89,3 @@ int main(int argc, char* argv[]) return(0); } - diff --git a/src/EXECS/LiebLin_DSF_tester_Ix2.cc b/src/EXECS/LiebLin_DSF_tester_Ix2.cc index 99aada4..b347d1e 100644 --- a/src/EXECS/LiebLin_DSF_tester_Ix2.cc +++ b/src/EXECS/LiebLin_DSF_tester_Ix2.cc @@ -2,7 +2,7 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -12,18 +12,18 @@ Purpose: allows for Ix2 manipulations (user-prompted) for LiebLin gas ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -int main(int argc, char* argv[]) +int main(int argc, char* argv[]) { if (argc != 6) { // provide some info - cout << endl << "Welcome to ABACUS++\t(copyright J.-S. Caux)." << endl; + cout << endl << "Welcome to ABACUS\t(copyright J.-S. Caux)." << endl; cout << endl << "Usage of LiebLin_DSF_tester executable: " << endl; cout << endl << "Provide the following arguments:" << endl << endl; cout << "char whichDSF \t\t Which structure factor should be calculated ? Options are: d for rho rho, g for psi psi{dagger}, o for psi{dagger} psi" << endl; @@ -42,10 +42,10 @@ int main(int argc, char* argv[]) int N = atoi(argv[4]); DP kBT = atof(argv[5]); - //if (whichDSF != 'd') JSCerror("Other options not implemented yet in finite T Scan_LiebLin"); + //if (whichDSF != 'd') ABACUSerror("Other options not implemented yet in finite T Scan_LiebLin"); // Delta is the number of sites involved in the smoothing of the entropy - //int Delta = int(sqrt(N))/2;//6;//N/20; + //int Delta = int(sqrt(N))/2;//6;//N/20; // Construct the finite-size saddle-point state: //LiebLin_Bethe_State spstate = Canonical_Saddle_Point_State (c_int, L, N, kBT, Delta); @@ -73,11 +73,11 @@ int main(int argc, char* argv[]) estate.Compute_All(false); cout << spstate << endl; cout << estate; - if (whichDSF == 'd') + if (whichDSF == 'd') cout << setprecision(16) << "estate.E - spstate.E = " << estate.E - spstate.E << "\tME = " << real(exp(ln_Density_ME(spstate, estate))) << endl; - else if (whichDSF == 'o') + else if (whichDSF == 'o') cout << setprecision(16) << "estate.E - spstate.E = " << estate.E - spstate.E << "\tME = " << real(exp(ln_Psi_ME(estate, spstate))) << endl; - else if (whichDSF == 'g') + else if (whichDSF == 'g') cout << setprecision(16) << "estate.E - spstate.E = " << estate.E - spstate.E << "\tME = " << real(exp(ln_Psi_ME(spstate, estate))) << endl; cout << "Another try ? (1 == yes, 0 == no)" << endl; @@ -89,4 +89,3 @@ int main(int argc, char* argv[]) return(0); } - diff --git a/src/EXECS/LiebLin_Data_Daemon.cc b/src/EXECS/LiebLin_Data_Daemon.cc index ea6e085..762854c 100644 --- a/src/EXECS/LiebLin_Data_Daemon.cc +++ b/src/EXECS/LiebLin_Data_Daemon.cc @@ -2,7 +2,7 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -12,13 +12,14 @@ Purpose: Produces sets of data files for correlations. ***********************************************************/ -#include "JSC.h" +#include +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -int main(int argc, char* argv[]) +int main(int argc, char* argv[]) { if (argc != 11) { // provide some info @@ -50,7 +51,7 @@ int main(int argc, char* argv[]) DP kBT = atof(argv[ia++]); int Max_Hrs = atoi(argv[ia++]); - // Individual computations are split into chuncks of Max_Hrs/(Nc * 4) + // Individual computations are split into chuncks of Max_Hrs/(Nc * 4) //int Max_Secs = (Max_Hrs * 900)/Nc; int Max_Secs = (Max_Hrs * 2700)/Nc; // to minimize wrapping up & restarting time @@ -63,13 +64,13 @@ int main(int argc, char* argv[]) double ActualTime = omp_get_wtime(); DP c_int; - DP target_sumrule = 1.0; + DP target_sumrule = 1.0; //while (double(ActualTime - StartTime)/CLOCKS_PER_SEC < double(3600 * Max_Hrs - Max_Secs)) { while (ActualTime - StartTime < double(3600 * Max_Hrs - Max_Secs)) { Vect srsat(0.0, Nc); - Vect refine(false, Nc); + Vect refine(false, Nc); DP srmin = 1.0; int icmin = 0; @@ -80,9 +81,9 @@ int main(int argc, char* argv[]) Data_File_Name (SRC_stringstream, whichDSF, c_int, L, N, iKmin, iKmax, kBT, 0.0, ""); SRC_stringstream << ".src"; SRC_string = SRC_stringstream.str(); const char* SRC_Cstr = SRC_string.c_str(); - + fstream srcfile; - srcfile.open(SRC_Cstr, fstream::in); + srcfile.open(SRC_Cstr, fstream::in); if (srcfile.fail()) { srsat[ic] = 0.0; refine[ic] = false; @@ -97,9 +98,9 @@ int main(int argc, char* argv[]) } srcfile.close(); - } // for ic + } // for ic - cout << "srsat min found: " << srmin << "\t for c = " << c_int_max/pow(cfact, icmin) << ". Now refining this." + cout << "srsat min found: " << srmin << "\t for c = " << c_int_max/pow(cfact, icmin) << ". Now refining this." //<< " Time left: " << 3600* Max_Hrs - (ActualTime - StartTime)/CLOCKS_PER_SEC << " seconds." << endl; << " Time left: " << 3600* Max_Hrs - (ActualTime - StartTime) << " seconds." << endl; @@ -109,7 +110,7 @@ int main(int argc, char* argv[]) //ActualTime = clock(); ActualTime = omp_get_wtime(); - } // while there is time + } // while there is time cout << "Wrapping up, time's up." << endl; @@ -117,4 +118,3 @@ int main(int argc, char* argv[]) return(0); } - diff --git a/src/EXECS/LiebLin_Data_Daemon_Nscaling.cc b/src/EXECS/LiebLin_Data_Daemon_Nscaling.cc index fae157d..ce7ce1e 100644 --- a/src/EXECS/LiebLin_Data_Daemon_Nscaling.cc +++ b/src/EXECS/LiebLin_Data_Daemon_Nscaling.cc @@ -2,7 +2,7 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -12,13 +12,14 @@ Purpose: Produces sets of data files for correlations, increasing system size a ***********************************************************/ -#include "JSC.h" +#include +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -int main(int argc, char* argv[]) +int main(int argc, char* argv[]) { if (argc != 9) { // provide some info @@ -46,7 +47,7 @@ int main(int argc, char* argv[]) DP kBT = atof(argv[ia++]); DP target_sumrule = atof(argv[ia++]); int Max_minutes = atoi(argv[ia++]); - + //clock_t StartTime = clock(); double StartTime = omp_get_wtime(); @@ -57,7 +58,7 @@ int main(int argc, char* argv[]) int Secs_left = 60* Max_minutes; int iN = 0; - + while (Secs_left > 0) { iN += 1; @@ -72,9 +73,9 @@ int main(int argc, char* argv[]) Data_File_Name (SRC_stringstream, whichDSF, c_int, L, N, iKmin, iKmax, kBT, 0.0, ""); SRC_stringstream << ".src"; SRC_string = SRC_stringstream.str(); const char* SRC_Cstr = SRC_string.c_str(); - + fstream srcfile; - srcfile.open(SRC_Cstr, fstream::in); + srcfile.open(SRC_Cstr, fstream::in); if (srcfile.fail()) { srsat = 0.0; refine = false; @@ -95,10 +96,9 @@ int main(int argc, char* argv[]) cout << "Done with N = " << N << ". Time left = " << Secs_left << " seconds." << endl; - } // while there is time + } // while there is time } // else if arguments given OK return(0); } - diff --git a/src/EXECS/LiebLin_Fourier_ssf_to_Qsqx.cc b/src/EXECS/LiebLin_Fourier_ssf_to_Qsqx.cc index 8d90882..78d19ee 100644 --- a/src/EXECS/LiebLin_Fourier_ssf_to_Qsqx.cc +++ b/src/EXECS/LiebLin_Fourier_ssf_to_Qsqx.cc @@ -2,7 +2,7 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -12,17 +12,17 @@ Purpose: Compute the Q(x)^2 expectation value for LiebLin, where Q(x) = \int_0^ ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -int main(int argc, char* argv[]) +int main(int argc, char* argv[]) { if (argc != 9) { // provide some info - cout << endl << "Welcome to ABACUS++\t(copyright J.-S. Caux)." << endl; + cout << endl << "Welcome to ABACUS\t(copyright J.-S. Caux)." << endl; cout << endl << "Usage of LiebLin_Fourier_to_Qsqx executable: " << endl; cout << endl << "Provide the following arguments:" << endl << endl; cout << "char whichDSF \t\t Which structure factor ? Options are: d for rho rho, g for psi psi{dagger}, o for psi{dagger} psi" << endl; @@ -46,11 +46,11 @@ int main(int argc, char* argv[]) // Force Npts_x //Npts_x = L; - if (whichDSF != 'd') JSCerror("Must use whichDSF == d in LiebLin_Fourier_ssf_to_Qsqx"); + if (whichDSF != 'd') ABACUSerror("Must use whichDSF == d in LiebLin_Fourier_ssf_to_Qsqx"); stringstream filenameprefix; Data_File_Name (filenameprefix, whichDSF, c_int, L, N, iKmin, iKmax, kBT, 0.0, ""); - string prefix = filenameprefix.str(); + string prefix = filenameprefix.str(); stringstream RAW_stringstream; string RAW_string; RAW_stringstream << prefix << ".raw"; @@ -59,7 +59,7 @@ int main(int argc, char* argv[]) RAW_infile.open(RAW_Cstr); if (RAW_infile.fail()) { cout << RAW_Cstr << endl; - JSCerror("Could not open RAW_infile... "); + ABACUSerror("Could not open RAW_infile... "); } // We also read the f-sumrule file, to correct for missing intensity. @@ -70,7 +70,7 @@ int main(int argc, char* argv[]) FSR_infile.open(FSR_Cstr); if (FSR_infile.fail()) { cout << FSR_Cstr << endl; - JSCerror("Could not open FSR_infile... "); + ABACUSerror("Could not open FSR_infile... "); } stringstream SFT_stringstream; string SFT_string; @@ -78,7 +78,7 @@ int main(int argc, char* argv[]) SFT_string = SFT_stringstream.str(); const char* SFT_Cstr = SFT_string.c_str(); ofstream SFT_outfile; SFT_outfile.open(SFT_Cstr); - if (SFT_outfile.fail()) JSCerror("Could not open SFT_outfile... "); + if (SFT_outfile.fail()) ABACUSerror("Could not open SFT_outfile... "); // First compute the static structure factor from the RAW data: @@ -100,7 +100,7 @@ int main(int argc, char* argv[]) RAW_infile.close(); // Reset proper normalization: - DP normalization = twoPI * L; + DP normalization = twoPI * L; for (int iK = 0; iK < iKmax - iKmin + 1; ++iK) SSF[iK] *= normalization/twoPI; // twoPI from integral over omega @@ -121,15 +121,15 @@ int main(int argc, char* argv[]) // Reset proper normalization: 1/L from space FT, FT[ix] *= 2.0*L/(PI * PI); - // Outside of window iKmin, iKmax, we take the DSF to be a constant with delta function + // Outside of window iKmin, iKmax, we take the DSF to be a constant with delta function // at free energy k^2, so DSF = 2\pi N/L \delta(\omega - k^2) (to fit f-sumrule) // so SSF becomes N/L. // We thus need to correct above by adding // \frac{1}{L} \sum_{-\infty}^{iKmin - 1} SSF e^{ikx} + \frac{1}{L} \sum_{iKmax + 1}^\infty SSF e^{ikx} // Resumming carefully: - //FTre[ix] += (sin(twopioverL * (iKmin - 0.5) * xlattice[ix]) - sin(twopioverL * (iKmax + 0.5) * xlattice[ix])) + //FTre[ix] += (sin(twopioverL * (iKmin - 0.5) * xlattice[ix]) - sin(twopioverL * (iKmax + 0.5) * xlattice[ix])) //* N/(2.0 * L*L * sin(PI * xlattice[ix]/L)); - //FTim[ix] += (-cos(twopioverL * (iKmin - 0.5) * xlattice[ix]) + cos(twopioverL * (iKmax + 0.5) * xlattice[ix])) + //FTim[ix] += (-cos(twopioverL * (iKmin - 0.5) * xlattice[ix]) + cos(twopioverL * (iKmax + 0.5) * xlattice[ix])) //* N/(2.0 * L*L * sin(PI * xlattice[ix]/L)); } diff --git a/src/EXECS/LiebLin_Fourier_to_t_equal_x.cc b/src/EXECS/LiebLin_Fourier_to_t_equal_x.cc index a689bb1..ed437d4 100644 --- a/src/EXECS/LiebLin_Fourier_to_t_equal_x.cc +++ b/src/EXECS/LiebLin_Fourier_to_t_equal_x.cc @@ -2,7 +2,7 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -12,17 +12,17 @@ Purpose: Fourier transform to static space correlator for LiebLin. ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -int main(int argc, char* argv[]) +int main(int argc, char* argv[]) { if (argc != 10) { // provide some info - cout << endl << "Welcome to ABACUS++\t(copyright J.-S. Caux)." << endl; + cout << endl << "Welcome to ABACUS\t(copyright J.-S. Caux)." << endl; cout << endl << "Usage of LiebLin_Fourier_to_x_equal_t executable: " << endl; cout << endl << "Provide the following arguments:" << endl << endl; cout << "char whichDSF \t\t Which structure factor ? Options are: d for rho rho, g for psi psi{dagger}, o for psi{dagger} psi" << endl; @@ -47,11 +47,11 @@ int main(int argc, char* argv[]) DP t_max = atof(argv[9]); // Momentum business: use symmetry - if (iKmin != 0) JSCerror("LiebLin_Fourier_to_t_equal_x only implemented for raw files with iKmin == 0."); + if (iKmin != 0) ABACUSerror("LiebLin_Fourier_to_t_equal_x only implemented for raw files with iKmin == 0."); stringstream filenameprefix; Data_File_Name (filenameprefix, whichDSF, c_int, L, N, iKmin, iKmax, kBT, 0.0, ""); - string prefix = filenameprefix.str(); + string prefix = filenameprefix.str(); stringstream RAW_stringstream; string RAW_string; RAW_stringstream << prefix << ".raw"; @@ -60,7 +60,7 @@ int main(int argc, char* argv[]) RAW_infile.open(RAW_Cstr); if (RAW_infile.fail()) { cout << RAW_Cstr << endl; - JSCerror("Could not open RAW_infile... "); + ABACUSerror("Could not open RAW_infile... "); } // We also read the f-sumrule file, to correct for missing intensity. @@ -71,7 +71,7 @@ int main(int argc, char* argv[]) FSR_infile.open(FSR_Cstr); if (FSR_infile.fail()) { cout << FSR_Cstr << endl; - JSCerror("Could not open FSR_infile... "); + ABACUSerror("Could not open FSR_infile... "); } stringstream SFT_stringstream; string SFT_string; @@ -79,7 +79,7 @@ int main(int argc, char* argv[]) SFT_string = SFT_stringstream.str(); const char* SFT_Cstr = SFT_string.c_str(); ofstream SFT_outfile; SFT_outfile.open(SFT_Cstr); - if (SFT_outfile.fail()) JSCerror("Could not open TFT_outfile... "); + if (SFT_outfile.fail()) ABACUSerror("Could not open TFT_outfile... "); // First compute the static structure factor from the RAW data: @@ -103,11 +103,11 @@ int main(int argc, char* argv[]) while (RAW_infile.peek() != EOF) { RAW_infile >> omega >> iK >> FF >> dev >> label; - if (iK == 0) - for (int it = 0; it < Npts_t; ++it) + if (iK == 0) + for (int it = 0; it < Npts_t; ++it) FT[it] += FF * FF * exp(II * omega * tlattice[it]); - else - for (int it = 0; it < Npts_t; ++it) + else + for (int it = 0; it < Npts_t; ++it) FT[it] += 2.0 * FF * FF * exp(II * omega * tlattice[it]); } RAW_infile.close(); diff --git a/src/EXECS/LiebLin_Fourier_to_t_equal_x_from_RAW.cc b/src/EXECS/LiebLin_Fourier_to_t_equal_x_from_RAW.cc index 8a11b3b..56352ab 100644 --- a/src/EXECS/LiebLin_Fourier_to_t_equal_x_from_RAW.cc +++ b/src/EXECS/LiebLin_Fourier_to_t_equal_x_from_RAW.cc @@ -2,7 +2,7 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -12,17 +12,17 @@ Purpose: Fourier transform to static space correlator for LiebLin. ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -int main(int argc, char* argv[]) +int main(int argc, char* argv[]) { if (argc != 10) { // provide some info - cout << endl << "Welcome to ABACUS++\t(copyright J.-S. Caux)." << endl; + cout << endl << "Welcome to ABACUS\t(copyright J.-S. Caux)." << endl; cout << endl << "Usage of LiebLin_Fourier_to_x_equal_t executable: " << endl; cout << endl << "Provide the following arguments:" << endl << endl; cout << "char whichDSF \t\t Which structure factor ? Options are: d for rho rho, g for psi psi{dagger}, o for psi{dagger} psi" << endl; @@ -49,7 +49,7 @@ int main(int argc, char* argv[]) DP t_max = atof(argv[9]); // Momentum business: use symmetry - if (iKmin != 0) JSCerror("LiebLin_Fourier_to_t_equal_x only implemented for raw files with iKmin == 0."); + if (iKmin != 0) ABACUSerror("LiebLin_Fourier_to_t_equal_x only implemented for raw files with iKmin == 0."); ifstream RAW_infile; //RAW_infile.open(RAW_Cstr); @@ -57,7 +57,7 @@ int main(int argc, char* argv[]) if (RAW_infile.fail()) { //cout << RAW_Cstr << endl; cout << rawfilename << endl; - JSCerror("Could not open RAW_infile... "); + ABACUSerror("Could not open RAW_infile... "); } stringstream SFT_stringstream; string SFT_string; @@ -65,7 +65,7 @@ int main(int argc, char* argv[]) SFT_string = SFT_stringstream.str(); const char* SFT_Cstr = SFT_string.c_str(); ofstream SFT_outfile; SFT_outfile.open(SFT_Cstr); - if (SFT_outfile.fail()) JSCerror("Could not open TFT_outfile... "); + if (SFT_outfile.fail()) ABACUSerror("Could not open TFT_outfile... "); // First compute the static structure factor from the RAW data: @@ -89,11 +89,11 @@ int main(int argc, char* argv[]) while (RAW_infile.peek() != EOF) { RAW_infile >> omega >> iK >> FF >> dev >> label; - if (iK == 0) - for (int it = 0; it < Npts_t; ++it) + if (iK == 0) + for (int it = 0; it < Npts_t; ++it) FT[it] += FF * FF * exp(II * omega * tlattice[it]); - else - for (int it = 0; it < Npts_t; ++it) + else + for (int it = 0; it < Npts_t; ++it) FT[it] += 2.0 * FF * FF * exp(II * omega * tlattice[it]); } RAW_infile.close(); diff --git a/src/EXECS/LiebLin_Fourier_to_x_equal_t.cc b/src/EXECS/LiebLin_Fourier_to_x_equal_t.cc index 6c473c1..683d19c 100644 --- a/src/EXECS/LiebLin_Fourier_to_x_equal_t.cc +++ b/src/EXECS/LiebLin_Fourier_to_x_equal_t.cc @@ -2,7 +2,7 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -12,17 +12,17 @@ Purpose: Fourier transform to static space correlator for LiebLin. ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -int main(int argc, char* argv[]) +int main(int argc, char* argv[]) { if (argc != 9) { // provide some info - cout << endl << "Welcome to ABACUS++\t(copyright J.-S. Caux)." << endl; + cout << endl << "Welcome to ABACUS\t(copyright J.-S. Caux)." << endl; cout << endl << "Usage of LiebLin_Fourier_to_x_equal_t executable: " << endl; cout << endl << "Provide the following arguments:" << endl << endl; cout << "char whichDSF \t\t Which structure factor ? Options are: d for rho rho, g for psi psi{dagger}, o for psi{dagger} psi" << endl; @@ -48,7 +48,7 @@ int main(int argc, char* argv[]) stringstream filenameprefix; Data_File_Name (filenameprefix, whichDSF, c_int, L, N, iKmin, iKmax, kBT, 0.0, ""); - string prefix = filenameprefix.str(); + string prefix = filenameprefix.str(); stringstream RAW_stringstream; string RAW_string; RAW_stringstream << prefix << ".raw"; @@ -57,7 +57,7 @@ int main(int argc, char* argv[]) RAW_infile.open(RAW_Cstr); if (RAW_infile.fail()) { cout << RAW_Cstr << endl; - JSCerror("Could not open RAW_infile... "); + ABACUSerror("Could not open RAW_infile... "); } // We also read the f-sumrule file, to correct for missing intensity. @@ -68,7 +68,7 @@ int main(int argc, char* argv[]) FSR_infile.open(FSR_Cstr); if (FSR_infile.fail()) { cout << FSR_Cstr << endl; - JSCerror("Could not open FSR_infile... "); + ABACUSerror("Could not open FSR_infile... "); } stringstream SFT_stringstream; string SFT_string; @@ -76,7 +76,7 @@ int main(int argc, char* argv[]) SFT_string = SFT_stringstream.str(); const char* SFT_Cstr = SFT_string.c_str(); ofstream SFT_outfile; SFT_outfile.open(SFT_Cstr); - if (SFT_outfile.fail()) JSCerror("Could not open SFT_outfile... "); + if (SFT_outfile.fail()) ABACUSerror("Could not open SFT_outfile... "); // First compute the static structure factor from the RAW data: @@ -98,7 +98,7 @@ int main(int argc, char* argv[]) RAW_infile.close(); // Reset proper normalization: - DP normalization = twoPI * L; + DP normalization = twoPI * L; for (int iK = 0; iK < iKmax - iKmin + 1; ++iK) SSF[iK] *= normalization/twoPI; // twoPI from integral over omega // We now refine the SSF in the following way. @@ -142,23 +142,23 @@ int main(int argc, char* argv[]) FTre[ix] /= L; FTim[ix] /= L; - // Outside of window iKmin, iKmax, we take the DSF to be a constant with delta function + // Outside of window iKmin, iKmax, we take the DSF to be a constant with delta function // at free energy k^2, so DSF = 2\pi N/L \delta(\omega - k^2) (to fit f-sumrule) // so SSF becomes N/L. // We thus need to correct above by adding // \frac{1}{L} \sum_{-\infty}^{iKmin - 1} SSF e^{ikx} + \frac{1}{L} \sum_{iKmax + 1}^\infty SSF e^{ikx} // Resumming carefully: if (whichDSF == 'd') { - FTre[ix] += (sin(twopioverL * (iKmin - 0.5) * xlattice[ix]) - sin(twopioverL * (iKmax + 0.5) * xlattice[ix])) + FTre[ix] += (sin(twopioverL * (iKmin - 0.5) * xlattice[ix]) - sin(twopioverL * (iKmax + 0.5) * xlattice[ix])) * N/(2.0 * L*L * sin(PI * xlattice[ix]/L)); - FTim[ix] += (-cos(twopioverL * (iKmin - 0.5) * xlattice[ix]) + cos(twopioverL * (iKmax + 0.5) * xlattice[ix])) + FTim[ix] += (-cos(twopioverL * (iKmin - 0.5) * xlattice[ix]) + cos(twopioverL * (iKmax + 0.5) * xlattice[ix])) * N/(2.0 * L*L * sin(PI * xlattice[ix]/L)); } } - // Since iKmax and iKmin are finite, we need to average over an interval of + // Since iKmax and iKmin are finite, we need to average over an interval of // deltax such that (2\pi/L) iKmax deltax = 2\pi, with deltax == deltaix * L/Npts_x - // so deltaix = (Npts_x/L) * (L/iKmax) + // so deltaix = (Npts_x/L) * (L/iKmax) /* int deltaix = 0*int(Npts_x/(2.0*iKmax)); cout << "deltaix = " << deltaix << endl; @@ -167,8 +167,8 @@ int main(int argc, char* argv[]) Vect_DP FTimavg(0.0, Npts_x); for (int ix = 0; ix < Npts_x; ++ix) { for (int ix2 = -deltaix; ix2 < deltaix; ++ix2) { - FTreavg[ix] += FTre[JSC::min(JSC::max(0, ix + ix2), Npts_x - 1)]; - FTimavg[ix] += FTim[JSC::min(JSC::max(0, ix + ix2), Npts_x - 1)]; + FTreavg[ix] += FTre[ABACUS::min(ABACUS::max(0, ix + ix2), Npts_x - 1)]; + FTimavg[ix] += FTim[ABACUS::min(ABACUS::max(0, ix + ix2), Npts_x - 1)]; } FTreavg[ix] /= (2*deltaix + 1); FTimavg[ix] /= (2*deltaix + 1); diff --git a/src/EXECS/LiebLin_Fourier_to_x_equal_t_from_RAW.cc b/src/EXECS/LiebLin_Fourier_to_x_equal_t_from_RAW.cc index 2c49b25..7d05eb4 100644 --- a/src/EXECS/LiebLin_Fourier_to_x_equal_t_from_RAW.cc +++ b/src/EXECS/LiebLin_Fourier_to_x_equal_t_from_RAW.cc @@ -2,7 +2,7 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -12,17 +12,17 @@ Purpose: Fourier transform to static space correlator for LiebLin. ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -int main(int argc, char* argv[]) +int main(int argc, char* argv[]) { if (argc != 9) { // provide some info - cout << endl << "Welcome to ABACUS++\t(copyright J.-S. Caux)." << endl; + cout << endl << "Welcome to ABACUS\t(copyright J.-S. Caux)." << endl; cout << endl << "Usage of LiebLin_Fourier_to_x_equal_t executable: " << endl; cout << endl << "Provide the following arguments:" << endl << endl; cout << "char whichDSF \t\t Which structure factor ? Options are: d for rho rho, g for psi psi{dagger}, o for psi{dagger} psi" << endl; @@ -50,7 +50,7 @@ int main(int argc, char* argv[]) //stringstream filenameprefix; //Data_File_Name (filenameprefix, whichDSF, c_int, L, N, iKmin, iKmax, kBT, 0.0, ""); - //string prefix = filenameprefix.str(); + //string prefix = filenameprefix.str(); //stringstream RAW_stringstream; string RAW_string; //RAW_stringstream << prefix << ".raw"; @@ -61,7 +61,7 @@ int main(int argc, char* argv[]) if (RAW_infile.fail()) { //cout << RAW_Cstr << endl; cout << rawfilename << endl; - JSCerror("Could not open RAW_infile... "); + ABACUSerror("Could not open RAW_infile... "); } // Define the output file name: use the RAW file name but with different suffix @@ -71,7 +71,7 @@ int main(int argc, char* argv[]) SFT_string = SFT_stringstream.str(); const char* SFT_Cstr = SFT_string.c_str(); ofstream SFT_outfile; SFT_outfile.open(SFT_Cstr); - if (SFT_outfile.fail()) JSCerror("Could not open SFT_outfile... "); + if (SFT_outfile.fail()) ABACUSerror("Could not open SFT_outfile... "); // First compute the static structure factor from the RAW data: @@ -93,7 +93,7 @@ int main(int argc, char* argv[]) RAW_infile.close(); // Reset proper normalization: - DP normalization = twoPI * L; + DP normalization = twoPI * L; for (int iK = 0; iK < iKmax - iKmin + 1; ++iK) SSF[iK] *= normalization/twoPI; // twoPI from integral over omega @@ -117,16 +117,16 @@ int main(int argc, char* argv[]) FTre[ix] /= L; FTim[ix] /= L; - // Outside of window iKmin, iKmax, we take the DSF to be a constant with delta function + // Outside of window iKmin, iKmax, we take the DSF to be a constant with delta function // at free energy k^2, so DSF = 2\pi N/L \delta(\omega - k^2) (to fit f-sumrule) // so SSF becomes N/L. // We thus need to correct above by adding // \frac{1}{L} \sum_{-\infty}^{iKmin - 1} SSF e^{ikx} + \frac{1}{L} \sum_{iKmax + 1}^\infty SSF e^{ikx} // Resumming carefully: //if (whichDSF == 'd') { - //FTre[ix] += (sin(twopioverL * (iKmin - 0.5) * xlattice[ix]) - sin(twopioverL * (iKmax + 0.5) * xlattice[ix])) + //FTre[ix] += (sin(twopioverL * (iKmin - 0.5) * xlattice[ix]) - sin(twopioverL * (iKmax + 0.5) * xlattice[ix])) // * N/(2.0 * L*L * sin(PI * xlattice[ix]/L)); - //FTim[ix] += (-cos(twopioverL * (iKmin - 0.5) * xlattice[ix]) + cos(twopioverL * (iKmax + 0.5) * xlattice[ix])) + //FTim[ix] += (-cos(twopioverL * (iKmin - 0.5) * xlattice[ix]) + cos(twopioverL * (iKmax + 0.5) * xlattice[ix])) // * N/(2.0 * L*L * sin(PI * xlattice[ix]/L)); //} } diff --git a/src/EXECS/LiebLin_Moses_tester.cc b/src/EXECS/LiebLin_Moses_tester.cc index 4ca4c04..45e0086 100644 --- a/src/EXECS/LiebLin_Moses_tester.cc +++ b/src/EXECS/LiebLin_Moses_tester.cc @@ -2,7 +2,7 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -12,18 +12,18 @@ Purpose: allows for Ix2 manipulations (user-prompted) for LiebLin gas ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -int main(int argc, char* argv[]) +int main(int argc, char* argv[]) { if (argc != 8) { // provide some info - cout << endl << "Welcome to ABACUS++\t(copyright J.-S. Caux)." << endl; + cout << endl << "Welcome to ABACUS\t(copyright J.-S. Caux)." << endl; cout << endl << "Usage of LiebLin_DSF_tester executable: " << endl; cout << endl << "Provide the following arguments:" << endl << endl; cout << "char whichDSF \t\t Which structure factor should be calculated ? Options are: d for rho rho, g for psi psi{dagger}, o for psi{dagger} psi" << endl; @@ -31,8 +31,8 @@ int main(int argc, char* argv[]) cout << "DP L \t\t\t Length of the system: use positive real values only" << endl; cout << "int N \t\t\t Number of particles: use positive integer values only" << endl; cout << "int Nl \t\t\t Number of particles in left Fermi sea (Nr is then N - Nl)" << endl; - cout << "int DIl \t\t shift of left sea as compared to its ground state position" << endl; - cout << "int DIr \t\t shift of right sea as compared to its ground state position" << endl; + cout << "int DIl \t\t shift of left sea as compared to its ground state position" << endl; + cout << "int DIr \t\t shift of right sea as compared to its ground state position" << endl; } else { // (argc == 6), correct nr of arguments @@ -45,7 +45,7 @@ int main(int argc, char* argv[]) int DIl = atoi(argv[6]); int DIr = atoi(argv[7]); - if (whichDSF != 'd') JSCerror("Other options not implemented yet in LiebLin_Moses_tester"); + if (whichDSF != 'd') ABACUSerror("Other options not implemented yet in LiebLin_Moses_tester"); // Define the Moses state: LiebLin_Bethe_State MosesState (c_int, L, N); @@ -76,4 +76,3 @@ int main(int argc, char* argv[]) return(0); } - diff --git a/src/EXECS/LiebLin_RAW_File_Stats.cc b/src/EXECS/LiebLin_RAW_File_Stats.cc index 039cd4a..8c83d0e 100644 --- a/src/EXECS/LiebLin_RAW_File_Stats.cc +++ b/src/EXECS/LiebLin_RAW_File_Stats.cc @@ -2,7 +2,7 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -13,18 +13,18 @@ Purpose: Analyzes the distribution of matrix element values in a RAW file, ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -int main(int argc, char* argv[]) +int main(int argc, char* argv[]) { if (argc != 9) { // provide some info - cout << endl << "Welcome to ABACUS++\t(copyright J.-S. Caux)." << endl; + cout << endl << "Welcome to ABACUS\t(copyright J.-S. Caux)." << endl; cout << endl << "Usage of LiebLin_RAW_File_Stats executable: " << endl; cout << endl << "Provide the following arguments:" << endl << endl; cout << "char whichDSF \t\t Which structure factor? Options are: d for rho rho, g for psi psi{dagger}, o for psi{dagger} psi" << endl; @@ -46,7 +46,7 @@ int main(int argc, char* argv[]) DP kBT = atof(argv[7]); int AgSize = atoi(argv[8]); - if (AgSize < 2) JSCerror("Give an aggregate size > 1 in LiebLin_RAW_File_Stats."); + if (AgSize < 2) ABACUSerror("Give an aggregate size > 1 in LiebLin_RAW_File_Stats."); stringstream RAW_stringstream; string RAW_string; Data_File_Name (RAW_stringstream, whichDSF, c_int, L, N, iKmin, iKmax, kBT, 0.0, ""); @@ -57,7 +57,7 @@ int main(int argc, char* argv[]) RAW_infile.open(RAW_Cstr); if (RAW_infile.fail()) { cout << RAW_Cstr << endl; - JSCerror("Could not open RAW_infile... "); + ABACUSerror("Could not open RAW_infile... "); } stringstream STAT_stringstream; string STAT_string; @@ -66,9 +66,9 @@ int main(int argc, char* argv[]) STAT_string = STAT_stringstream.str(); const char* STAT_Cstr = STAT_string.c_str(); ofstream STATfile; - STATfile.open(STAT_Cstr); + STATfile.open(STAT_Cstr); if (STATfile.fail()) { - cout << STAT_Cstr << endl; JSCerror("Could not open STATfile."); + cout << STAT_Cstr << endl; ABACUSerror("Could not open STATfile."); } LiebLin_Bethe_State AveragingState = Canonical_Saddle_Point_State (c_int, L, N, whichDSF == 'Z' ? 0.0 : kBT); @@ -76,7 +76,7 @@ int main(int argc, char* argv[]) DP Chem_Pot = Chemical_Potential (AveragingState); //DP sumrule_factor = Sumrule_Factor (whichDSF, AveragingState, Chem_Pot, fixed_iK, iKneeded); Vect sumrule_factor(iKmax - iKmin + 1); - for (int ik = 0; ik < iKmax - iKmin + 1; ++ik) + for (int ik = 0; ik < iKmax - iKmin + 1; ++ik) sumrule_factor[ik] = Sumrule_Factor (whichDSF, AveragingState, Chem_Pot, ik, ik); // Normalize by total number of considered momenta DP correction_factor = 1.0/(iKmax - iKmin + 1); @@ -92,7 +92,7 @@ int main(int argc, char* argv[]) DP ME; DP dev; string label; - + int nread = 0; DP srcont = 0.0; @@ -106,11 +106,11 @@ int main(int argc, char* argv[]) RAW_infile >> omega >> iK >> ME >> dev >> label; nread++; - + if (iK >= iKmin && iK <= iKmax) { srcont = omega * ME * ME * sumrule_factor[iK - iKmin]; abssrcont = fabs(srcont); - maxsrcont = JSC::max(maxsrcont, abssrcont); + maxsrcont = ABACUS::max(maxsrcont, abssrcont); totsrcont += srcont; accumulatedsrcont += srcont; naccounted++; @@ -123,7 +123,7 @@ int main(int argc, char* argv[]) totsrcont = 0.0; } } - + RAW_infile.close(); STATfile.close(); } @@ -131,4 +131,3 @@ int main(int argc, char* argv[]) return(0); } - diff --git a/src/EXECS/LiebLin_TBA.cc b/src/EXECS/LiebLin_TBA.cc index 08ebe9f..b8860f9 100755 --- a/src/EXECS/LiebLin_TBA.cc +++ b/src/EXECS/LiebLin_TBA.cc @@ -2,7 +2,7 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -10,19 +10,18 @@ File: LiebLin_TBA.cc Purpose: solves the TBA equations for Lieb-Liniger - ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; int main(int argc, const char* argv[]) { - //if (argc != 7) JSCerror("Wrong number of arguments to 2CBG_ThLim executable. Use c(best to set to 1), nbar, ebar, req_diff, Max_Secs, bool Save_data (0 == false)."); - if (argc != 6) JSCerror("Wrong number of arguments. Use c(best to set to 1), mu, kBT, req_diff, Max_Secs"); + //if (argc != 7) ABACUSerror("Wrong number of arguments to 2CBG_ThLim executable. Use c(best to set to 1), nbar, ebar, req_diff, Max_Secs, bool Save_data (0 == false)."); + if (argc != 6) ABACUSerror("Wrong number of arguments. Use c(best to set to 1), mu, kBT, req_diff, Max_Secs"); DP c_int = atof(argv[1]); DP mu = atof(argv[2]); @@ -30,9 +29,9 @@ int main(int argc, const char* argv[]) DP req_diff = atof(argv[4]); int Max_Secs = atoi(argv[5]); - if (c_int <= 0.0) JSCerror("Give a strictly positive c."); - if (kBT <= 0.0) JSCerror("Negative T ? Not for the LiebLin gas."); - if (Max_Secs < 10) JSCerror("Give more time."); + if (c_int <= 0.0) ABACUSerror("Give a strictly positive c."); + if (kBT <= 0.0) ABACUSerror("Negative T ? Not for the LiebLin gas."); + if (Max_Secs < 10) ABACUSerror("Give more time."); //cout << "Read c_int = " << c_int << "\tmu = " << mu << "\tOmega = " << Omega << "\tkBT = " << kBT << "\tMax_Secs = " << Max_Secs << endl; diff --git a/src/EXECS/LiebLin_TBA_fixed_nbar.cc b/src/EXECS/LiebLin_TBA_fixed_nbar.cc index a69b3b8..9cda528 100755 --- a/src/EXECS/LiebLin_TBA_fixed_nbar.cc +++ b/src/EXECS/LiebLin_TBA_fixed_nbar.cc @@ -2,7 +2,7 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -10,19 +10,18 @@ File: LiebLin_TBA_fixed_nbar.cc Purpose: solves the TBA equations for Lieb-Liniger - ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; int main(int argc, const char* argv[]) { - //if (argc != 7) JSCerror("Wrong number of arguments to 2CBG_ThLim executable. Use c(best to set to 1), nbar, ebar, req_diff, Max_Secs, bool Save_data (0 == false)."); - if (argc != 6) JSCerror("Wrong number of arguments. Use c(best to set to 1), nbar, kBT, req_diff, Max_Secs"); + //if (argc != 7) ABACUSerror("Wrong number of arguments to 2CBG_ThLim executable. Use c(best to set to 1), nbar, ebar, req_diff, Max_Secs, bool Save_data (0 == false)."); + if (argc != 6) ABACUSerror("Wrong number of arguments. Use c(best to set to 1), nbar, kBT, req_diff, Max_Secs"); DP c_int = atof(argv[1]); DP nbar = atof(argv[2]); @@ -30,9 +29,9 @@ int main(int argc, const char* argv[]) DP req_diff = atof(argv[4]); int Max_Secs = atoi(argv[5]); - if (c_int <= 0.0) JSCerror("Give a strictly positive c."); - if (kBT <= 0.0) JSCerror("Negative T ? Not for the LiebLin gas."); - if (Max_Secs < 10) JSCerror("Give more time."); + if (c_int <= 0.0) ABACUSerror("Give a strictly positive c."); + if (kBT <= 0.0) ABACUSerror("Negative T ? Not for the LiebLin gas."); + if (Max_Secs < 10) ABACUSerror("Give more time."); //cout << "Read c_int = " << c_int << "\tmu = " << mu << "\tOmega = " << Omega << "\tkBT = " << kBT << "\tMax_Secs = " << Max_Secs << endl; diff --git a/src/EXECS/LiebLin_TBA_fixed_nbar_ebar.cc b/src/EXECS/LiebLin_TBA_fixed_nbar_ebar.cc index e40d15e..d854c34 100755 --- a/src/EXECS/LiebLin_TBA_fixed_nbar_ebar.cc +++ b/src/EXECS/LiebLin_TBA_fixed_nbar_ebar.cc @@ -2,7 +2,7 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -10,18 +10,17 @@ File: LiebLin_TBA_fixed_nbar_ebar.cc Purpose: solves the TBA equations for Lieb-Liniger - ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; int main(int argc, const char* argv[]) { - if (argc != 7) JSCerror("Wrong number of arguments. Use c(best to set to 1), nbar, ebar, req_diff, Max_Secs, bool Save_data (0 == false)."); + if (argc != 7) ABACUSerror("Wrong number of arguments. Use c(best to set to 1), nbar, ebar, req_diff, Max_Secs, bool Save_data (0 == false)."); DP c_int = atof(argv[1]); DP nbar = atof(argv[2]); @@ -30,8 +29,8 @@ int main(int argc, const char* argv[]) int Max_Secs = atoi(argv[5]); bool Save_data = bool(atoi(argv[6])); - if (c_int <= 0.0) JSCerror("Give a strictly positive c."); - if (Max_Secs < 10) JSCerror("Give more time."); + if (c_int <= 0.0) ABACUSerror("Give a strictly positive c."); + if (Max_Secs < 10) ABACUSerror("Give more time."); //cout << "Read c_int = " << c_int << "\tmu = " << mu << "\tOmega = " << Omega << "\tkBT = " << kBT << "\tMax_Secs = " << Max_Secs << endl; diff --git a/src/EXECS/ODSLF_DSF.cc b/src/EXECS/ODSLF_DSF.cc index fe27258..d478834 100644 --- a/src/EXECS/ODSLF_DSF.cc +++ b/src/EXECS/ODSLF_DSF.cc @@ -1,29 +1,29 @@ /********************************************************** -This software is part of J.-S. Caux's ABACUS++ library. +This software is part of J.-S. Caux's ABACUS library. -Copyright (c) +Copyright (c) J.-S. Caux. ----------------------------------------------------------- File: ODSLF_DSF.cc -Purpose: main function for ABACUS++ for spinless fermions related to Heisenberg spin-1/2 chain +Purpose: main function for ABACUS for spinless fermions related to Heisenberg spin-1/2 chain ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -int main(int argc, char* argv[]) +int main(int argc, char* argv[]) { if (argc != 10) { // provide some info - cout << endl << "Welcome to ABACUS++\t(copyright J.-S. Caux)." << endl; + cout << endl << "Welcome to ABACUS\t(copyright J.-S. Caux)." << endl; cout << "Usage of ODSLF_DSF executable: " << endl; cout << endl << "Provide the following arguments:" << endl << endl; cout << "char whichDSF \t\t Which structure factor should be calculated ? Options are: m for S- S+, z for Sz Sz, p for S+ S-." << endl; @@ -53,8 +53,7 @@ int main(int argc, char* argv[]) } - else JSCerror("Wrong number of arguments to ODSLF_DSF executable."); + else ABACUSerror("Wrong number of arguments to ODSLF_DSF executable."); return(0); } - diff --git a/src/EXECS/Produce_Sorted_RAW_File.cc b/src/EXECS/Produce_Sorted_RAW_File.cc index 3175a41..6eced20 100644 --- a/src/EXECS/Produce_Sorted_RAW_File.cc +++ b/src/EXECS/Produce_Sorted_RAW_File.cc @@ -1,28 +1,28 @@ /********************************************************** -This software is part of J.-S. Caux's ABACUS++ library. +This software is part of J.-S. Caux's ABACUS library. -Copyright (c) +Copyright (c) J.-S. Caux. ----------------------------------------------------------- File: Sort_RAW_File.cc Purpose: produce a sorted .raw file. - + ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -int main(int argc, char* argv[]) +int main(int argc, char* argv[]) { - if (argc != 4) { + if (argc != 4) { cout << "Arguments needed: rawfile, whichDSF, whichsorting." << endl; - JSCerror(""); + ABACUSerror(""); } const char* rawfilename = argv[1]; diff --git a/src/EXECS/RAW_File_Stats.cc b/src/EXECS/RAW_File_Stats.cc index b0ed325..7cd19ef 100644 --- a/src/EXECS/RAW_File_Stats.cc +++ b/src/EXECS/RAW_File_Stats.cc @@ -2,7 +2,7 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -13,18 +13,18 @@ Purpose: Analyzes the distribution of matrix element values in a RAW file, ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -int main(int argc, char* argv[]) +int main(int argc, char* argv[]) { if (argc != 3) { // provide some info - cout << endl << "Welcome to ABACUS++\t(copyright J.-S. Caux)." << endl; + cout << endl << "Welcome to ABACUS\t(copyright J.-S. Caux)." << endl; cout << endl << "Usage of RAW_File_Stats executable: " << endl; cout << endl << "Provide the following arguments:" << endl << endl; cout << endl << "string RAW file name" << endl; @@ -35,13 +35,13 @@ int main(int argc, char* argv[]) const char* rawfilename = argv[1]; int AgSize = atoi(argv[2]); - if (AgSize < 2) JSCerror("Give an aggregate size > 1 in LiebLin_RAW_File_Stats."); + if (AgSize < 2) ABACUSerror("Give an aggregate size > 1 in LiebLin_RAW_File_Stats."); ifstream RAW_infile; RAW_infile.open(rawfilename); if (RAW_infile.fail()) { cout << rawfilename << endl; - JSCerror("Could not open RAW_infile... "); + ABACUSerror("Could not open RAW_infile... "); } stringstream STAT_stringstream; string STAT_string; @@ -49,9 +49,9 @@ int main(int argc, char* argv[]) STAT_string = STAT_stringstream.str(); const char* STAT_Cstr = STAT_string.c_str(); ofstream STATfile; - STATfile.open(STAT_Cstr); + STATfile.open(STAT_Cstr); if (STATfile.fail()) { - cout << STAT_Cstr << endl; JSCerror("Could not open STATfile."); + cout << STAT_Cstr << endl; ABACUSerror("Could not open STATfile."); } DP omega; @@ -59,7 +59,7 @@ int main(int argc, char* argv[]) DP ME; DP dev; string label; - + int nread = 0; DP srcont = 0.0; @@ -73,10 +73,10 @@ int main(int argc, char* argv[]) RAW_infile >> omega >> iK >> ME >> dev >> label; nread++; - + srcont = ME * ME; abssrcont = fabs(srcont); - maxsrcont = JSC::max(maxsrcont, abssrcont); + maxsrcont = ABACUS::max(maxsrcont, abssrcont); totsrcont += srcont; accumulatedsrcont += srcont; naccounted++; @@ -88,7 +88,7 @@ int main(int argc, char* argv[]) totsrcont = 0.0; } } - + RAW_infile.close(); STATfile.close(); } @@ -96,4 +96,3 @@ int main(int argc, char* argv[]) return(0); } - diff --git a/src/EXECS/Smoothen_Heis_DSF.cc b/src/EXECS/Smoothen_Heis_DSF.cc index 98b6422..a76b34f 100644 --- a/src/EXECS/Smoothen_Heis_DSF.cc +++ b/src/EXECS/Smoothen_Heis_DSF.cc @@ -1,8 +1,8 @@ /********************************************************** -This software is part of J.-S. Caux's ABACUS++ library. +This software is part of J.-S. Caux's ABACUS library. -Copyright (c) +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -12,13 +12,13 @@ Purpose: produces .dsf and .ssf files from a .raw file ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -int main(int argc, char* argv[]) +int main(int argc, char* argv[]) { if (argc != 13 && argc != 14) { // Print out instructions //if (strcmp(argv[1],"help") == 0) { // Output some instructions @@ -26,7 +26,7 @@ int main(int argc, char* argv[]) cout << "Provide arguments using one of the following options:" << endl << endl; cout << "1) (for general momenta) whichDSF Delta N M iKmin iKmax DiK kBT ommin ommax Nom gwidth" << endl << endl; cout << "2) (for fixed momentum) whichDSF Delta N M iKneeded ommin ommax Nom gwidth" << endl << endl; - //else JSCerror("Incomprehensible arguments in Smoothen_Heis_DSF executable."); + //else ABACUSerror("Incomprehensible arguments in Smoothen_Heis_DSF executable."); } else if (argc == 13) { // !fixed_iK @@ -45,7 +45,7 @@ int main(int argc, char* argv[]) stringstream filenameprefix; Data_File_Name (filenameprefix, whichDSF, Delta, N, M, iKmin, iKmax, kBT, 0, ""); - string prefix = filenameprefix.str(); + string prefix = filenameprefix.str(); DP normalization = twoPI; DP denom_sum_K = 1.0/N; @@ -74,7 +74,7 @@ int main(int argc, char* argv[]) stringstream filenameprefix; Data_File_Name (filenameprefix, whichDSF, Delta, N, M, fixed_iK, iKneeded, 0.0, 0, ""); - string prefix = filenameprefix.str(); + string prefix = filenameprefix.str(); DP normalization = twoPI; int iKmin = iKneeded; @@ -84,7 +84,7 @@ int main(int argc, char* argv[]) } */ - //else JSCerror("Wrong number of arguments to Smoothen_Heis_DSF executable."); + //else ABACUSerror("Wrong number of arguments to Smoothen_Heis_DSF executable."); return(0); } diff --git a/src/EXECS/Smoothen_LiebLin_DSF.cc b/src/EXECS/Smoothen_LiebLin_DSF.cc index 6a7e531..afa12f2 100644 --- a/src/EXECS/Smoothen_LiebLin_DSF.cc +++ b/src/EXECS/Smoothen_LiebLin_DSF.cc @@ -2,7 +2,7 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -12,17 +12,17 @@ Purpose: produces .dsf and .ssf files from a .raw file ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -int main(int argc, char* argv[]) +int main(int argc, char* argv[]) { if (argc != 13) { // Print out instructions - cout << endl << "Welcome to ABACUS++\t(copyright J.-S. Caux)." << endl; + cout << endl << "Welcome to ABACUS\t(copyright J.-S. Caux)." << endl; cout << endl << "Usage of Smoothen_LiebLin_DSF executable: " << endl; cout << endl << "Provide the following arguments:" << endl << endl; cout << "char whichDSF \t\t Which structure factor should be calculated ? Options are: d for rho rho, g for psi psi{dagger}, o for psi{dagger} psi" << endl; @@ -58,7 +58,7 @@ int main(int argc, char* argv[]) stringstream filenameprefix; //void Data_File_Name (stringstream& name, char whichDSF, DP c_int, DP L, int N, int iKmin, int iKmax, DP kBT, DP L2) Data_File_Name (filenameprefix, whichDSF, c_int, L, N, iKmin, iKmax, kBT, 0.0, ""); - string prefix = filenameprefix.str(); + string prefix = filenameprefix.str(); DP normalization = twoPI * L; DP denom_sum_K = L; @@ -69,7 +69,7 @@ int main(int argc, char* argv[]) // We use the scaled width function as default: DP sumcheck; - //if (kBT < 0.1) + //if (kBT < 0.1) //sumcheck = Smoothen_RAW_into_SF_LiebLin_Scaled (prefix, L, N, iKmin, iKmax, DiK, ommin, ommax, Nom, width, normalization); sumcheck = Smoothen_RAW_into_SF (prefix, iKmin, iKmax, DiK, ommin, ommax, Nom, width, normalization, denom_sum_K); //else sumcheck = Smoothen_RAW_into_SF (prefix, iKmin, iKmax, ommin, ommax, Nom, width, normalization); @@ -88,14 +88,14 @@ int main(int argc, char* argv[]) DP ommax = atof(argv[8]); int Nom = atoi(argv[9]); DP gwidth = atof(argv[10]); - + //bool fixed_iK = true; - //LiebLin_Bethe_State GroundState (c_int, L, N, iK_UL, 0LL); + //LiebLin_Bethe_State GroundState (c_int, L, N, iK_UL, 0LL); stringstream filenameprefix; - //Data_File_Name (filenameprefix, whichDSF, fixed_iK, iKneeded, GroundState, GroundState); + //Data_File_Name (filenameprefix, whichDSF, fixed_iK, iKneeded, GroundState, GroundState); //Data_File_Name (filenameprefix, whichDSF, c_int, L, N, iK_UL, fixed_iK, iKneeded, 0.0); Data_File_Name (filenameprefix, whichDSF, c_int, L, N, iK_UL, iKneeded, iKneeded, 0.0); - string prefix = filenameprefix.str(); + string prefix = filenameprefix.str(); DP normalization = twoPI * L; int iKmin = iKneeded; @@ -105,7 +105,7 @@ int main(int argc, char* argv[]) } */ - //else JSCerror("Wrong number of arguments to Smoothen_LiebLin_DSF executable."); + //else ABACUSerror("Wrong number of arguments to Smoothen_LiebLin_DSF executable."); return(0); } diff --git a/src/EXECS/Smoothen_LiebLin_DSF_GeneralState.cc b/src/EXECS/Smoothen_LiebLin_DSF_GeneralState.cc index 1de11f3..3bf50f2 100644 --- a/src/EXECS/Smoothen_LiebLin_DSF_GeneralState.cc +++ b/src/EXECS/Smoothen_LiebLin_DSF_GeneralState.cc @@ -2,7 +2,7 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -12,17 +12,17 @@ Purpose: produces .dsf and .ssf files from a .raw file ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -int main(int argc, char* argv[]) +int main(int argc, char* argv[]) { if (argc != 13) { // Print out instructions - cout << endl << "Welcome to ABACUS++\t(copyright J.-S. Caux)." << endl; + cout << endl << "Welcome to ABACUS\t(copyright J.-S. Caux)." << endl; cout << endl << "Usage of Smoothen_LiebLin_DSF executable: " << endl; cout << endl << "Provide the following arguments:" << endl << endl; cout << "char whichDSF \t\t Which structure factor should be calculated ? Options are: d for rho rho, g for psi psi{dagger}, o for psi{dagger} psi" << endl; @@ -67,7 +67,7 @@ int main(int argc, char* argv[]) //void Data_File_Name (stringstream& name, char whichDSF, DP c_int, DP L, int N, int iKmin, int iKmax, DP kBT, DP L2) //Data_File_Name (filenameprefix, whichDSF, c_int, L, N, iKmin, iKmax, kBT, 0.0, ""); Data_File_Name (filenameprefix, whichDSF, c_int, L, N, iKmin, iKmax, kBT, 0.0, defaultScanStatename); - string prefix = filenameprefix.str(); + string prefix = filenameprefix.str(); DP normalization = twoPI * L; DP denom_sum_K = L; @@ -78,7 +78,7 @@ int main(int argc, char* argv[]) // We use the scaled width function as default: DP sumcheck; - //if (kBT < 0.1) + //if (kBT < 0.1) //sumcheck = Smoothen_RAW_into_SF_LiebLin_Scaled (prefix, L, N, iKmin, iKmax, DiK, ommin, ommax, Nom, width, normalization); sumcheck = Smoothen_RAW_into_SF (prefix, iKmin, iKmax, DiK, ommin, ommax, Nom, width, normalization, denom_sum_K); //else sumcheck = Smoothen_RAW_into_SF (prefix, iKmin, iKmax, ommin, ommax, Nom, width, normalization); @@ -97,14 +97,14 @@ int main(int argc, char* argv[]) DP ommax = atof(argv[8]); int Nom = atoi(argv[9]); DP gwidth = atof(argv[10]); - + //bool fixed_iK = true; - //LiebLin_Bethe_State GroundState (c_int, L, N, iK_UL, 0LL); + //LiebLin_Bethe_State GroundState (c_int, L, N, iK_UL, 0LL); stringstream filenameprefix; - //Data_File_Name (filenameprefix, whichDSF, fixed_iK, iKneeded, GroundState, GroundState); + //Data_File_Name (filenameprefix, whichDSF, fixed_iK, iKneeded, GroundState, GroundState); //Data_File_Name (filenameprefix, whichDSF, c_int, L, N, iK_UL, fixed_iK, iKneeded, 0.0); Data_File_Name (filenameprefix, whichDSF, c_int, L, N, iK_UL, iKneeded, iKneeded, 0.0); - string prefix = filenameprefix.str(); + string prefix = filenameprefix.str(); DP normalization = twoPI * L; int iKmin = iKneeded; @@ -114,7 +114,7 @@ int main(int argc, char* argv[]) } */ - //else JSCerror("Wrong number of arguments to Smoothen_LiebLin_DSF executable."); + //else ABACUSerror("Wrong number of arguments to Smoothen_LiebLin_DSF executable."); return(0); } diff --git a/src/EXECS/Smoothen_LiebLin_DSF_MosesState.cc b/src/EXECS/Smoothen_LiebLin_DSF_MosesState.cc index cea0046..0305a4d 100644 --- a/src/EXECS/Smoothen_LiebLin_DSF_MosesState.cc +++ b/src/EXECS/Smoothen_LiebLin_DSF_MosesState.cc @@ -2,7 +2,7 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -12,17 +12,17 @@ Purpose: produces .dsf and .ssf files from a .raw file ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -int main(int argc, char* argv[]) +int main(int argc, char* argv[]) { if (argc != 15) { // Print out instructions - cout << endl << "Welcome to ABACUS++\t(copyright J.-S. Caux)." << endl; + cout << endl << "Welcome to ABACUS\t(copyright J.-S. Caux)." << endl; cout << endl << "Usage of Smoothen_LiebLin_DSF_MosesState executable: " << endl; cout << endl << "Provide the following arguments:" << endl << endl; cout << "char whichDSF \t\t Which structure factor should be calculated ? Options are: d for rho rho, g for psi psi{dagger}, o for psi{dagger} psi" << endl; @@ -30,8 +30,8 @@ int main(int argc, char* argv[]) cout << "DP L \t\t\t Length of the system" << endl; cout << "int N \t\t\t Number of particles" << endl; cout << "int Nl \t\t\t Number of particles in left Fermi sea (Nr is then N - Nl)" << endl; - cout << "int DIl \t\t shift of left sea as compared to its ground state position" << endl; - cout << "int DIr \t\t shift of right sea as compared to its ground state position" << endl; + cout << "int DIl \t\t shift of left sea as compared to its ground state position" << endl; + cout << "int DIr \t\t shift of right sea as compared to its ground state position" << endl; cout << "int iKmin" << endl << "int iKmax \t\t Min and max momentum integers" << endl; //cout << "DP kBT \t\t Temperature" << endl; cout << "int DiK \t\t\t Window of iK over which DSF is averaged (DiK == 0 means a single iK is used; DiK == 1 means 3 are used (iK-1, iK, iK+1), etc.)" << endl; @@ -71,7 +71,7 @@ int main(int argc, char* argv[]) stringstream filenameprefix; //void Data_File_Name (stringstream& name, char whichDSF, DP c_int, DP L, int N, int iKmin, int iKmax, DP kBT, DP L2) Data_File_Name (filenameprefix, whichDSF, c_int, L, N, iKmin, iKmax, kBT, 0.0, defaultScanStatename); - string prefix = filenameprefix.str(); + string prefix = filenameprefix.str(); @@ -84,14 +84,14 @@ int main(int argc, char* argv[]) // We use the scaled width function as default: DP sumcheck; - //if (kBT < 0.1) + //if (kBT < 0.1) //sumcheck = Smoothen_RAW_into_SF_LiebLin_Scaled (prefix, L, N, iKmin, iKmax, DiK, ommin, ommax, Nom, width, normalization); sumcheck = Smoothen_RAW_into_SF (prefix, iKmin, iKmax, DiK, ommin, ommax, Nom, width, normalization, denom_sum_K); //else sumcheck = Smoothen_RAW_into_SF (prefix, iKmin, iKmax, ommin, ommax, Nom, width, normalization); //cout << "Smoothing: sumcheck = " << sumcheck << endl; } - //else JSCerror("Wrong number of arguments to Smoothen_LiebLin_DSF executable."); + //else ABACUSerror("Wrong number of arguments to Smoothen_LiebLin_DSF executable."); return(0); } diff --git a/src/EXECS/Smoothen_LiebLin_DSF_Scaled.cc b/src/EXECS/Smoothen_LiebLin_DSF_Scaled.cc index a2b08ea..26413db 100644 --- a/src/EXECS/Smoothen_LiebLin_DSF_Scaled.cc +++ b/src/EXECS/Smoothen_LiebLin_DSF_Scaled.cc @@ -2,7 +2,7 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -12,17 +12,17 @@ Purpose: produces .dsfs and .ssf files from a .raw file ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -int main(int argc, char* argv[]) +int main(int argc, char* argv[]) { if (argc != 13) { // Print out instructions - cout << endl << "Welcome to ABACUS++\t(copyright J.-S. Caux)." << endl; + cout << endl << "Welcome to ABACUS\t(copyright J.-S. Caux)." << endl; cout << endl << "Usage of Smoothen_LiebLin_DSF_Scaled executable: " << endl; cout << endl << "Provide the following arguments:" << endl << endl; cout << "char whichDSF \t\t Which structure factor should be calculated ? Options are: d for rho rho, g for psi psi{dagger}, o for psi{dagger} psi" << endl; @@ -58,7 +58,7 @@ int main(int argc, char* argv[]) stringstream filenameprefix; //void Data_File_Name (stringstream& name, char whichDSF, DP c_int, DP L, int N, int iKmin, int iKmax, DP kBT, DP L2) Data_File_Name (filenameprefix, whichDSF, c_int, L, N, iKmin, iKmax, kBT, 0.0, ""); - string prefix = filenameprefix.str(); + string prefix = filenameprefix.str(); DP normalization = twoPI * L; //DP denom_sum_K = L; @@ -69,14 +69,14 @@ int main(int argc, char* argv[]) // We use the scaled width function as default: DP sumcheck; - //if (kBT < 0.1) + //if (kBT < 0.1) sumcheck = Smoothen_RAW_into_SF_LiebLin_Scaled (prefix, L, N, iKmin, iKmax, DiK, ommin, ommax, Nom, width, normalization); //sumcheck = Smoothen_RAW_into_SF (prefix, iKmin, iKmax, DiK, ommin, ommax, Nom, width, normalization, denom_sum_K); //else sumcheck = Smoothen_RAW_into_SF (prefix, iKmin, iKmax, ommin, ommax, Nom, width, normalization); //cout << "Smoothing: sumcheck = " << sumcheck << endl; } - //else JSCerror("Wrong number of arguments to Smoothen_LiebLin_DSF executable."); + //else ABACUSerror("Wrong number of arguments to Smoothen_LiebLin_DSF executable."); return(0); } diff --git a/src/EXECS/Smoothen_LiebLin_DSF_over_Ensemble.cc b/src/EXECS/Smoothen_LiebLin_DSF_over_Ensemble.cc index 2d0c09d..9b36b2d 100644 --- a/src/EXECS/Smoothen_LiebLin_DSF_over_Ensemble.cc +++ b/src/EXECS/Smoothen_LiebLin_DSF_over_Ensemble.cc @@ -2,7 +2,7 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -12,17 +12,17 @@ Purpose: produces .dsf and .ssf files from an ensemble of .raw files ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -int main(int argc, char* argv[]) +int main(int argc, char* argv[]) { if (argc != 13) { // Print out instructions - cout << endl << "Welcome to ABACUS++\t(copyright J.-S. Caux)." << endl; + cout << endl << "Welcome to ABACUS\t(copyright J.-S. Caux)." << endl; cout << endl << "Usage of Smoothen_LiebLin_DSF_over_Ensemble executable: " << endl; cout << endl << "Provide the following arguments:" << endl << endl; cout << "char whichDSF \t\t Which structure factor should be calculated ? Options are: d for rho rho, g for psi psi{dagger}, o for psi{dagger} psi" << endl; @@ -42,7 +42,7 @@ int main(int argc, char* argv[]) } - else if (argc == 13) { + else if (argc == 13) { char whichDSF = *argv[1]; DP c_int = atof(argv[2]); DP L = atof(argv[3]); @@ -60,7 +60,7 @@ int main(int argc, char* argv[]) stringstream filenameprefix; //void Data_File_Name (stringstream& name, char whichDSF, DP c_int, DP L, int N, int iKmin, int iKmax, DP kBT, DP L2) Data_File_Name (filenameprefix, whichDSF, c_int, L, N, iKmin, iKmax, kBT, 0.0, ""); - string prefix = filenameprefix.str(); + string prefix = filenameprefix.str(); DP normalization = twoPI * L; DP denom_sum_K = L; @@ -85,16 +85,16 @@ int main(int argc, char* argv[]) for (int ns = 0; ns < ensemble.nstates; ++ns) { // Define the raw input file name: stringstream filenameprefix; - //Data_File_Name (filenameprefix, whichDSF, iKmin, iKmax, kBT, ensemble.state[ns], ensemble.state[ns], ensemble.state[ns].label); - Data_File_Name (filenameprefix, whichDSF, iKmin, iKmax, 0.0, ensemble.state[ns], ensemble.state[ns], ensemble.state[ns].label); - string prefix = filenameprefix.str(); + //Data_File_Name (filenameprefix, whichDSF, iKmin, iKmax, kBT, ensemble.state[ns], ensemble.state[ns], ensemble.state[ns].label); + Data_File_Name (filenameprefix, whichDSF, iKmin, iKmax, 0.0, ensemble.state[ns], ensemble.state[ns], ensemble.state[ns].label); + string prefix = filenameprefix.str(); stringstream RAW_stringstream; string RAW_string; RAW_stringstream << prefix << ".raw"; //RAW_string = RAW_stringstream.str(); const char* RAW_Cstr = RAW_string.c_str(); rawfilename[ns] = RAW_stringstream.str(); } - Smoothen_RAW_into_SF (prefix, rawfilename, ensemble.weight, iKmin, iKmax, DiK, + Smoothen_RAW_into_SF (prefix, rawfilename, ensemble.weight, iKmin, iKmax, DiK, ommin, ommax, Nom, width, normalization, denom_sum_K); } diff --git a/src/EXECS/Smoothen_ODSLF_DSF.cc b/src/EXECS/Smoothen_ODSLF_DSF.cc index a343dde..172146e 100644 --- a/src/EXECS/Smoothen_ODSLF_DSF.cc +++ b/src/EXECS/Smoothen_ODSLF_DSF.cc @@ -1,8 +1,8 @@ /********************************************************** -This software is part of J.-S. Caux's ABACUS++ library. +This software is part of J.-S. Caux's ABACUS library. -Copyright (c) +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -12,13 +12,13 @@ Purpose: produces .dsf and .ssf files from a .raw file ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -int main(int argc, char* argv[]) +int main(int argc, char* argv[]) { if (argc != 10 && argc != 11) { // Print out instructions //if (strcmp(argv[1],"help") == 0) { // Output some instructions @@ -26,7 +26,7 @@ int main(int argc, char* argv[]) cout << "Provide arguments using one of the following options:" << endl << endl; cout << "1) (for general momenta) whichDSF Delta N M iKmin iKmax ommin ommax Nom gwidth" << endl << endl; cout << "2) (for fixed momentum) whichDSF Delta N M iKneeded ommin ommax Nom gwidth" << endl << endl; - //else JSCerror("Incomprehensible arguments in Smoothen_ODSLF_DSF executable."); + //else ABACUSerror("Incomprehensible arguments in Smoothen_ODSLF_DSF executable."); } else if (argc == 11) { // !fixed_iK @@ -43,7 +43,7 @@ int main(int argc, char* argv[]) stringstream filenameprefix; ODSLF_Data_File_Name (filenameprefix, whichDSF, Delta, N, M, iKmin, iKmax, 0.0, 0); - string prefix = filenameprefix.str(); + string prefix = filenameprefix.str(); DP normalization = twoPI; @@ -69,7 +69,7 @@ int main(int argc, char* argv[]) stringstream filenameprefix; Data_File_Name (filenameprefix, whichDSF, Delta, N, M, fixed_iK, iKneeded, 0.0, 0); - string prefix = filenameprefix.str(); + string prefix = filenameprefix.str(); DP normalization = twoPI; int iKmin = iKneeded; @@ -78,5 +78,5 @@ int main(int argc, char* argv[]) cout << "Smoothing: sumcheck = " << Smoothen_RAW_into_SF (prefix, iKmin, iKmax, ommin, ommax, Nom, gwidth, normalization) << endl; } - else JSCerror("Wrong number of arguments to Smoothen_Heis_DSF executable."); + else ABACUSerror("Wrong number of arguments to Smoothen_Heis_DSF executable."); } diff --git a/src/EXECS/XXZ_gpd_StagSz_h0.cc b/src/EXECS/XXZ_gpd_StagSz_h0.cc index 7ea767e..1b689d3 100644 --- a/src/EXECS/XXZ_gpd_StagSz_h0.cc +++ b/src/EXECS/XXZ_gpd_StagSz_h0.cc @@ -1,43 +1,42 @@ /********************************************************** -This software is part of J.-S. Caux's ABACUS++ library. +This software is part of J.-S. Caux's ABACUS library. -Copyright (c) +Copyright (c) J.-S. Caux. ----------------------------------------------------------- -File: ABACUS++G_2_testing.cc - -Purpose: testing of ABACUS++2 +File: XXZ_gpd_StagSz_h0.cc +Purpose: Compute the staggered magentization of XXZ_gpd in zero field. ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -int main( int argc, char* argv[]) +int main( int argc, char* argv[]) { if (!(argc == 3 || argc == 5)) { // provide some info cout << endl << "This code computes the (1/N) (-1)^j S^z_j on-site staggered magnetization for XXZ_gpd in zero field." << endl; cout << "First option: provide two arguments: anisotropy Delta (> 1) and system size N (even)." << endl; cout << "Second option: provide five arguments: system size N (even), Delta min, Delta max, NDelta." << endl; cout << "The output is Delta, N, stag mag, energy gap." << endl; - JSCerror(""); + ABACUSerror(""); } else if (argc == 3) { DP Delta = atof(argv[1]); - if (Delta <= 1.0) JSCerror("Provide Delta > 1."); + if (Delta <= 1.0) ABACUSerror("Provide Delta > 1."); int N = atoi(argv[2]); - if (N % 2) JSCerror("Provide an even Delta."); + if (N % 2) ABACUSerror("Provide an even Delta."); int M = N/2; // Define the chain: J, Delta, h, Nsites Heis_Chain chain(1.0, Delta, 0.0, N); - + Heis_Base gbase(chain, M); XXZ_gpd_Bethe_State gstate(chain, gbase); @@ -54,9 +53,9 @@ int main( int argc, char* argv[]) XXZ_gpd_Bethe_State estategap(chain, basegap); estategap.Compute_All(true); - if (!gstate.conv) JSCerror("Ground state did not converge."); - if (!estate.conv) JSCerror("Umklapp state did not converge."); - if (!estategap.conv) JSCerror("Gap state did not converge."); + if (!gstate.conv) ABACUSerror("Ground state did not converge."); + if (!estate.conv) ABACUSerror("Umklapp state did not converge."); + if (!estategap.conv) ABACUSerror("Gap state did not converge."); cout << Delta << "\t" << N << "\t" << setprecision(12) << exp(real(ln_Sz_ME (gstate, estate)))/sqrt(N) << "\t" << estategap.E - gstate.E << endl; @@ -65,14 +64,14 @@ int main( int argc, char* argv[]) else if (argc == 5) { // Do a scan in Delta int N = atoi(argv[1]); - if (N % 2) JSCerror("Provide an even Delta."); + if (N % 2) ABACUSerror("Provide an even Delta."); int M = N/2; DP Deltamin = atof(argv[2]); - if (Deltamin <= 1.0) JSCerror("Provide Deltamin > 1."); + if (Deltamin <= 1.0) ABACUSerror("Provide Deltamin > 1."); DP Deltamax = atof(argv[3]); - if (Deltamin <= 1.0) JSCerror("Provide Deltamax > Deltamin."); + if (Deltamin <= 1.0) ABACUSerror("Provide Deltamax > Deltamin."); int NDelta = atoi(argv[4]); @@ -82,29 +81,29 @@ int main( int argc, char* argv[]) // Define the chain: J, Delta, h, Nsites Heis_Chain chain(1.0, Delta, 0.0, N); - + Heis_Base gbase(chain, M); - + XXZ_gpd_Bethe_State gstate(chain, gbase); gstate.Compute_All(true); - + XXZ_gpd_Bethe_State estate(chain, gbase); estate.Ix2[0][0] = M+1; // umklapp excitation estate.Compute_All(true); - + stringstream basestrstream; basestrstream << M-2 << "x1"; string basestr = basestrstream.str(); Heis_Base basegap(chain, basestr); XXZ_gpd_Bethe_State estategap(chain, basegap); estategap.Compute_All(true); - - if (!gstate.conv) JSCerror("Ground state did not converge."); - if (!estate.conv) JSCerror("Umklapp state did not converge."); - if (!estategap.conv) JSCerror("Gap state did not converge."); - + + if (!gstate.conv) ABACUSerror("Ground state did not converge."); + if (!estate.conv) ABACUSerror("Umklapp state did not converge."); + if (!estategap.conv) ABACUSerror("Gap state did not converge."); + cout << Delta << "\t" << N << "\t" << setprecision(12) << exp(real(ln_Sz_ME (gstate, estate)))/sqrt(N) << "\t" << estategap.E - gstate.E << endl; - + } } diff --git a/src/FITTING/covsrt.cc b/src/FITTING/covsrt.cc index 598869a..773c92a 100644 --- a/src/FITTING/covsrt.cc +++ b/src/FITTING/covsrt.cc @@ -1,26 +1,24 @@ /********************************************************** -This software is part of J.-S. Caux's C++ library. +This software is part of J.-S. Caux's ABACUS library. -Copyright (c) 2007. +Copyright (c) J.-S. Caux. ----------------------------------------------------------- -File: mrqmin.cc +File: covsrt.cc -Purpose: Nonlinear fitting - -Last modified: 14/08/07 +Purpose: covsrt algorithm ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -namespace JSC { +namespace ABACUS { - void covsrt (SQMat_DP& covar, Vect& ia, const int mfit) + void covsrt (SQMat_DP& covar, Vect& ia, const int mfit) { int i, j, k; diff --git a/src/FITTING/lin_reg.cc b/src/FITTING/lin_reg.cc index 8ea33b4..6ef4345 100644 --- a/src/FITTING/lin_reg.cc +++ b/src/FITTING/lin_reg.cc @@ -1,8 +1,8 @@ /********************************************************** -This software is part of J.-S. Caux's C++ library. +This software is part of J.-S. Caux's ABACUS library. -Copyright (c) 2006. +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -10,15 +10,13 @@ File: lin_reg.cc Purpose: Linear regression -Last modified: 11/05/07 - ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -namespace JSC { +namespace ABACUS { void lin_reg (Vect_DP x, Vect_DP y, Vect_DP sigma, DP& a, DP& b, DP& chisq) { diff --git a/src/FITTING/mrq.cc b/src/FITTING/mrq.cc index 2bf62f2..0ddea53 100644 --- a/src/FITTING/mrq.cc +++ b/src/FITTING/mrq.cc @@ -1,26 +1,24 @@ /********************************************************** -This software is part of J.-S. Caux's C++ library. +This software is part of J.-S. Caux's ABACUS library. -Copyright (c) 2007. +Copyright (c) J.-S. Caux. ----------------------------------------------------------- -File: mrqmin.cc +File: mrq.cc -Purpose: Nonlinear fitting - -Last modified: 14/08/07 +Purpose: mrqmin and mrqcof algorithms ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -namespace JSC { +namespace ABACUS { - void mrqmin (Vect_DP& x, Vect_DP& y, Vect_DP& sig, Vect_DP& a, + void mrqmin (Vect_DP& x, Vect_DP& y, Vect_DP& sig, Vect_DP& a, Vect& ia, SQMat_DP& covar, SQMat_DP& alpha, DP& chisq, void funcs(const DP, Vect_DP&, DP&, Vect_DP&), DP& alambda) { diff --git a/src/FITTING/polint.cc b/src/FITTING/polint.cc index e6f1cc1..986df4d 100644 --- a/src/FITTING/polint.cc +++ b/src/FITTING/polint.cc @@ -1,7 +1,21 @@ -#include "JSC.h" +/********************************************************** + +This software is part of J.-S. Caux's ABACUS library. + +Copyright (c) J.-S. Caux. + +----------------------------------------------------------- + +File: polint.cc + +Purpose: Polynomial interpolation + +***********************************************************/ + +#include "ABACUS.h" using namespace std; -void JSC::polint(Vect_DP& xa, Vect_DP& ya, const DP x, DP& y, DP& dy) +void ABACUS::polint(Vect_DP& xa, Vect_DP& ya, const DP x, DP& y, DP& dy) { // Polynomial interpolation/extrapolation, NR page 113. @@ -25,7 +39,7 @@ void JSC::polint(Vect_DP& xa, Vect_DP& ya, const DP x, DP& y, DP& dy) ho = xa[i] - x; hp = xa[i+m] - x; w = c[i+1] - d[i]; - if ((den = ho-hp) == 0.0) JSCerror("Error in routine polint."); + if ((den = ho-hp) == 0.0) ABACUSerror("Error in routine polint."); den = w/den; d[i] = hp * den; c[i] = ho * den; diff --git a/src/FITTING/polint_cx.cc b/src/FITTING/polint_cx.cc index ae6edb8..caf7682 100644 --- a/src/FITTING/polint_cx.cc +++ b/src/FITTING/polint_cx.cc @@ -1,7 +1,21 @@ -#include "JSC.h" +/********************************************************** + +This software is part of J.-S. Caux's ABACUS library. + +Copyright (c) J.-S. Caux. + +----------------------------------------------------------- + +File: polint_cx.cc + +Purpose: Polynomial interpolation + +***********************************************************/ + +#include "ABACUS.h" using namespace std; -void JSC::polint(Vect_CX& xa, Vect_CX& ya, const complex x, complex& y, complex& dy) +void ABACUS::polint(Vect_CX& xa, Vect_CX& ya, const complex x, complex& y, complex& dy) { // Polynomial interpolation/extrapolation, NR page 113. @@ -26,7 +40,7 @@ void JSC::polint(Vect_CX& xa, Vect_CX& ya, const complex x, complex& y, ho = xa[i] - x; hp = xa[i+m] - x; w = c[i+1] - d[i]; - if ((den = ho-hp) == 0.0) JSCerror("Error in routine polint_cx."); + if ((den = ho-hp) == 0.0) ABACUSerror("Error in routine polint_cx."); den = w/den; d[i] = hp * den; c[i] = ho * den; diff --git a/src/HEIS/Heis.cc b/src/HEIS/Heis.cc index cfa5519..e9106b7 100644 --- a/src/HEIS/Heis.cc +++ b/src/HEIS/Heis.cc @@ -1,8 +1,8 @@ /********************************************************** -This software is part of J.-S. Caux's ABACUS++ library. +This software is part of J.-S. Caux's ABACUS library. -Copyright (c) +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -10,31 +10,30 @@ File: src/HEIS/Heis.cc Purpose: defines functions in all HEIS classes. - ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -namespace JSC { +namespace ABACUS { //*************************************************************************************************** // Function definitions: class Heis_Chain - Heis_Chain::Heis_Chain() - : J(0.0), Delta(0.0), anis(0.0), hz(0.0), Nsites(0), Nstrings(0), Str_L(0), par(0), + Heis_Chain::Heis_Chain() + : J(0.0), Delta(0.0), anis(0.0), hz(0.0), Nsites(0), Nstrings(0), Str_L(0), par(0), si_n_anis_over_2(new DP[1]), co_n_anis_over_2(new DP[1]), ta_n_anis_over_2(new DP[1]), prec(ITER_REQ_PREC) {} - Heis_Chain::Heis_Chain (DP JJ, DP DD, DP hh, int NN) - : J(JJ), Delta(DD), anis(0.0), hz(hh), Nsites(NN), Nstrings(MAXSTRINGS), Str_L(new int[MAXSTRINGS]), par(new int[MAXSTRINGS]), + Heis_Chain::Heis_Chain (DP JJ, DP DD, DP hh, int NN) + : J(JJ), Delta(DD), anis(0.0), hz(hh), Nsites(NN), Nstrings(MAXSTRINGS), Str_L(new int[MAXSTRINGS]), par(new int[MAXSTRINGS]), si_n_anis_over_2(new DP[10*MAXSTRINGS]), co_n_anis_over_2(new DP[10*MAXSTRINGS]), ta_n_anis_over_2(new DP[10*MAXSTRINGS]), prec(ITER_REQ_PREC) { // We restrict to even chains everywhere - - if (NN % 2) JSCerror("Please use an even-length chain."); - + + if (NN % 2) ABACUSerror("Please use an even-length chain."); + if ((Delta > 0.0) && (Delta < 1.0)) { // gapless XXZ case @@ -42,42 +41,42 @@ namespace JSC { anis = acos(DD); // Set the Str_L and par vectors: - + DP gammaoverpi = acos(DD)/PI; //cout << "gammaoverpi = " << gammaoverpi << endl; - + Vect Nu(MAXSTRINGS); - + DP gammaoverpi_eff = gammaoverpi; DP gammaoverpi_reached = 0.0; - + // First, define the series Nu[i], like in TakahashiBOOK eqn 9.35 - // CAREFUL: the labelling is different, Nu[0] is \nu_1, etc. + // CAREFUL: the labelling is different, Nu[0] is \nu_1, etc. int l = 0; int ml_temp = 0; // checks the sum of all Nu's - + while (fabs(gammaoverpi - gammaoverpi_reached) > 1.0e-8){ - + Nu[l] = int(1.0/gammaoverpi_eff); ml_temp += Nu[l]; if (Nu[l] == 0) gammaoverpi_eff = 0.0; else gammaoverpi_eff = 1.0/gammaoverpi_eff - DP(Nu[l]); - + // compute gammaoverpi_reached: gammaoverpi_reached = Nu[l]; for (int p = 0; p < l; ++p) gammaoverpi_reached = Nu[l - p - 1] + 1.0/gammaoverpi_reached; gammaoverpi_reached = 1.0/gammaoverpi_reached; - + //cout << "gammaoverpi_reached = " << gammaoverpi_reached << "\tdiff = " << fabs(gammaoverpi - gammaoverpi_reached) << endl; //cout << "ml_temp = " << ml_temp << "\tMAXSTRINGS = " << MAXSTRINGS << endl; l++; - - if (ml_temp > MAXSTRINGS) break; // we defined Str_L and par as arrays of at most MAXSTRINGS elements, so we cut off here... - + + if (ml_temp > MAXSTRINGS) break; // we defined Str_L and par as arrays of at most MAXSTRINGS elements, so we cut off here... + } //cout << "l = " << l << endl; - + // Check: make sure the last Nu is greater than one: if one, add 1 to previous Nu if (l > 1) { @@ -87,9 +86,9 @@ namespace JSC { l -= 1; } } - + // Length of continued fraction is l-1, which is denoted l in Takahashi - + // Second, define the series y[i] and m[i] as in TakahashiBOOK eqn 9.36 // y_{-1} is treated separately, and here y[i] = y_i, m[i] = m_i, i = 0, ..., l Vect y(0, l+1); @@ -104,18 +103,18 @@ namespace JSC { for (int k = 0; k < i; ++k) m[i] += Nu[k]; } // Now determine the lengths and parity, following TakahashiBOOK eqn 9.37 - // Nstrings = JSC::min(m[l] + 1, MAXSTRINGS); // number of different strings that are possible for this chain + // Nstrings = ABACUS::min(m[l] + 1, MAXSTRINGS); // number of different strings that are possible for this chain // Always set to MAXSTRINGS Str_L[0] = 1; par[0] = 1; Str_L[1] = 1; par[1] = -1; - + int max_j = 0; - + for (int i = 0; i < l; ++i) { - for (int j = JSC::max(1, m[i]) + 1; j < JSC::min(m[i+1] + 1, MAXSTRINGS); ++j) { + for (int j = ABACUS::max(1, m[i]) + 1; j < ABACUS::min(m[i+1] + 1, MAXSTRINGS); ++j) { if (i == 0) Str_L[j] = (j - m[0])* y[0]; else if (i >= 1) Str_L[j] = y[i-1] + (j - m[i])*y[i]; par[j] = (int(floor((Str_L[j] - 1)*gammaoverpi)) % 2) ? -1 : 1; @@ -124,14 +123,14 @@ namespace JSC { } // Set the rest of Str_L and par vector elements to zero - + for (int i = max_j + 1; i < MAXSTRINGS; ++i) { Str_L[i] = 0; par[i] = 0; } - + // Set the sin, cos and tan_n_zeta_over_2 vectors: - + for (int i = 0; i < 10*MAXSTRINGS; ++i) si_n_anis_over_2[i] = sin(i * anis/2.0); for (int i = 0; i < 10*MAXSTRINGS; ++i) co_n_anis_over_2[i] = cos(i * anis/2.0); for (int i = 0; i < 10*MAXSTRINGS; ++i) ta_n_anis_over_2[i] = tan(i * anis/2.0); @@ -150,7 +149,7 @@ namespace JSC { Str_L[i] = i + 1; par[i] = 1; } - + } // if XXX AFM else if (Delta > 1.0) { @@ -160,22 +159,22 @@ namespace JSC { anis = acosh(DD); // Set the Str_L and par vectors: - + for (int i = 0; i < MAXSTRINGS; ++i) { Str_L[i] = i + 1; par[i] = 1; } - + // Set the sinh, cosh and tanh_n_eta_over_2 vectors: - + for (int i = 0; i < 10*MAXSTRINGS; ++i) si_n_anis_over_2[i] = sinh(i * anis/2.0); for (int i = 0; i < 10*MAXSTRINGS; ++i) co_n_anis_over_2[i] = cosh(i * anis/2.0); for (int i = 0; i < 10*MAXSTRINGS; ++i) ta_n_anis_over_2[i] = tanh(i * anis/2.0); - + } // if XXZ_gpd } - + Heis_Chain::Heis_Chain (const Heis_Chain& RefChain) // copy constructor { J = RefChain.J; @@ -189,14 +188,14 @@ namespace JSC { par = new int[RefChain.Nstrings]; for (int i = 0; i < RefChain.Nstrings; ++i) par[i] = RefChain.par[i]; si_n_anis_over_2 = new DP[10*MAXSTRINGS]; - for (int i = 0; i < 10*MAXSTRINGS; ++i) si_n_anis_over_2[i] = RefChain.si_n_anis_over_2[i]; + for (int i = 0; i < 10*MAXSTRINGS; ++i) si_n_anis_over_2[i] = RefChain.si_n_anis_over_2[i]; co_n_anis_over_2 = new DP[10*MAXSTRINGS]; - for (int i = 0; i < 10*MAXSTRINGS; ++i) co_n_anis_over_2[i] = RefChain.co_n_anis_over_2[i]; + for (int i = 0; i < 10*MAXSTRINGS; ++i) co_n_anis_over_2[i] = RefChain.co_n_anis_over_2[i]; ta_n_anis_over_2 = new DP[10*MAXSTRINGS]; - for (int i = 0; i < 10*MAXSTRINGS; ++i) ta_n_anis_over_2[i] = RefChain.ta_n_anis_over_2[i]; + for (int i = 0; i < 10*MAXSTRINGS; ++i) ta_n_anis_over_2[i] = RefChain.ta_n_anis_over_2[i]; prec = RefChain.prec; } - + Heis_Chain& Heis_Chain::operator= (const Heis_Chain& RefChain) // assignment operator { if (this != &RefChain) { @@ -207,22 +206,22 @@ namespace JSC { Nsites = RefChain.Nsites; Nstrings = RefChain.Nstrings; if (Str_L != 0) delete[] Str_L; - Str_L = new int[RefChain.Nstrings]; + Str_L = new int[RefChain.Nstrings]; for (int i = 0; i < RefChain.Nstrings; ++i) Str_L[i] = RefChain.Str_L[i]; if (par != 0) delete[] par; par = new int[RefChain.Nstrings]; for (int i = 0; i < RefChain.Nstrings; ++i) par[i] = RefChain.par[i]; if (si_n_anis_over_2 != 0) delete[] si_n_anis_over_2; si_n_anis_over_2 = new DP[10*MAXSTRINGS]; - for (int i = 0; i < 10*MAXSTRINGS; ++i) si_n_anis_over_2[i] = RefChain.si_n_anis_over_2[i]; + for (int i = 0; i < 10*MAXSTRINGS; ++i) si_n_anis_over_2[i] = RefChain.si_n_anis_over_2[i]; if (co_n_anis_over_2 != 0) delete[] co_n_anis_over_2; co_n_anis_over_2 = new DP[10*MAXSTRINGS]; - for (int i = 0; i < 10*MAXSTRINGS; ++i) co_n_anis_over_2[i] = RefChain.co_n_anis_over_2[i]; + for (int i = 0; i < 10*MAXSTRINGS; ++i) co_n_anis_over_2[i] = RefChain.co_n_anis_over_2[i]; if (ta_n_anis_over_2 != 0) delete[] ta_n_anis_over_2; ta_n_anis_over_2 = new DP[10*MAXSTRINGS]; - for (int i = 0; i < 10*MAXSTRINGS; ++i) ta_n_anis_over_2[i] = RefChain.ta_n_anis_over_2[i]; + for (int i = 0; i < 10*MAXSTRINGS; ++i) ta_n_anis_over_2[i] = RefChain.ta_n_anis_over_2[i]; prec = RefChain.prec; - + } return *this; } @@ -235,7 +234,7 @@ namespace JSC { return(answer); } - + bool Heis_Chain::operator!= (const Heis_Chain& RefChain) { bool answer = false; @@ -244,7 +243,7 @@ namespace JSC { return(answer); } - + Heis_Chain::~Heis_Chain() { if (Str_L != 0) delete[] Str_L; @@ -255,10 +254,10 @@ namespace JSC { } /* Deactivated in ++G_8 - void Heis_Chain::Scan_for_Possible_Bases (int Mdown_remaining, Vect& possible_base_label, int& nfound, int nexc_max_used, + void Heis_Chain::Scan_for_Possible_Bases (int Mdown_remaining, Vect& possible_base_label, int& nfound, int nexc_max_used, int base_level_to_scan, Vect& Nrapidities) { - if (Mdown_remaining < 0) { JSCerror("Scan_for_Possible_Bases: shouldn't be here..."); } // reached inconsistent point + if (Mdown_remaining < 0) { ABACUSerror("Scan_for_Possible_Bases: shouldn't be here..."); } // reached inconsistent point //cout << "Mdown_remaining " << Mdown_remaining << "\t" << possible_base_id << "\tnfound " << nfound // << "\tnexc_max_used " << nexc_max_used << "\tbase_level_to_scan " << base_level_to_scan << "\tNrap " << Nrapidities << endl; @@ -270,7 +269,7 @@ namespace JSC { stringstream M0out; M0out << Nrapidities[0]; possible_base_label[nfound] = M0out.str(); - for (int itype = 1; itype < Nrapidities.size(); ++itype) + for (int itype = 1; itype < Nrapidities.size(); ++itype) if (Nrapidities[itype] > 0) { possible_base_label[nfound] += TYPESEP; stringstream typeout; @@ -291,7 +290,7 @@ namespace JSC { for (int i = 0; i <= (Str_L[base_level_to_scan] == 0 ? 0 : nexc_max_used/Str_L[base_level_to_scan]); ++i) { Nrapidities[base_level_to_scan] = i; - Scan_for_Possible_Bases (Mdown_remaining - i*Str_L[base_level_to_scan], possible_base_label, nfound, + Scan_for_Possible_Bases (Mdown_remaining - i*Str_L[base_level_to_scan], possible_base_label, nfound, nexc_max_used - i*Str_L[base_level_to_scan], base_level_to_scan - 1, Nrapidities); } @@ -302,13 +301,13 @@ namespace JSC { Vect Heis_Chain::Possible_Bases (int Mdown) // returns a vector of possible bases { // We partition Mdown into up to NEXC_MAX_HEIS excitations - - int nexc_max_used = JSC::min(NEXC_MAX_HEIS, 2*(Mdown/2)); // since each inner sector can contain at most N/2 holes. + + int nexc_max_used = ABACUS::min(NEXC_MAX_HEIS, 2*(Mdown/2)); // since each inner sector can contain at most N/2 holes. Vect possible_base_label (1000); int nfound = 0; Vect Nrapidities (0, Nstrings); - + //cout << "In Possible_Bases: start scan for Mdown = " << Mdown << endl; (*this).Scan_for_Possible_Bases (Mdown, possible_base_label, nfound, nexc_max_used, Nstrings - 1, Nrapidities); @@ -327,11 +326,11 @@ namespace JSC { // Function definitions: class Heis_Base - Heis_Base::Heis_Base () : Mdown(0), Nrap(Vect()), Nraptot(0), + Heis_Base::Heis_Base () : Mdown(0), Nrap(Vect()), Nraptot(0), Ix2_infty(Vect()), Ix2_min(Vect()), Ix2_max(Vect()), dimH(0.0), baselabel("") {} Heis_Base::Heis_Base (const Heis_Base& RefBase) // copy constructor - : Mdown(RefBase.Mdown), Nrap(Vect(RefBase.Nrap.size())), Nraptot(RefBase.Nraptot), + : Mdown(RefBase.Mdown), Nrap(Vect(RefBase.Nrap.size())), Nraptot(RefBase.Nraptot), Ix2_infty(Vect(RefBase.Nrap.size())), Ix2_min(Vect(RefBase.Nrap.size())), Ix2_max(Vect(RefBase.Nrap.size())), baselabel(RefBase.baselabel) { @@ -342,10 +341,10 @@ namespace JSC { Ix2_max[i] = RefBase.Ix2_max[i]; dimH = RefBase.dimH; } - } + } - Heis_Base::Heis_Base (const Heis_Chain& RefChain, int M) - : Mdown(M), Nrap(Vect(RefChain.Nstrings)), Nraptot(0), + Heis_Base::Heis_Base (const Heis_Chain& RefChain, int M) + : Mdown(M), Nrap(Vect(RefChain.Nstrings)), Nraptot(0), Ix2_infty(Vect(RefChain.Nstrings)), Ix2_min(Vect(RefChain.Nstrings)), Ix2_max(Vect(RefChain.Nstrings)) { for (int i = 0; i < RefChain.Nstrings; ++i) Nrap[i] = 0; @@ -353,23 +352,23 @@ namespace JSC { Nraptot = 0; for (int i = 0; i < RefChain.Nstrings; ++i) Nraptot += Nrap[i]; - + stringstream M0out; M0out << M; baselabel = M0out.str(); - + // Now compute the Ix2_infty numbers (*this).Compute_Ix2_limits(RefChain); // Compute dimensionality of this sub-Hilbert space: complex ln_dimH_cx = 0.0; - for (int i = 0; i < RefChain.Nstrings; ++i) + for (int i = 0; i < RefChain.Nstrings; ++i) if (Nrap[i] > 0) ln_dimH_cx += ln_Gamma(complex((Ix2_max[i] - Ix2_min[i])/2 + 2)) - ln_Gamma(complex((Ix2_max[i] - Ix2_min[i])/2 + 2 - Nrap[i])) - ln_Gamma(complex(Nrap[i] + 1)); - dimH = exp(real(ln_dimH_cx)); + dimH = exp(real(ln_dimH_cx)); } - Heis_Base::Heis_Base (const Heis_Chain& RefChain, const Vect& Nrapidities) - : Mdown(0), Nrap(Nrapidities), Nraptot(0), + Heis_Base::Heis_Base (const Heis_Chain& RefChain, const Vect& Nrapidities) + : Mdown(0), Nrap(Nrapidities), Nraptot(0), Ix2_infty(Vect(RefChain.Nstrings)), Ix2_min(Vect(RefChain.Nstrings)), Ix2_max(Vect(RefChain.Nstrings)) { @@ -377,16 +376,16 @@ namespace JSC { //if (RefChain.Nstrings != Nrapidities.size()) cout << "error: Nstrings = " << RefChain.Nstrings << "\tNrap.size = " << Nrapidities.size() << endl; - if (RefChain.Nstrings != Nrapidities.size()) JSCerror("Incompatible Nrapidities vector used in Heis_Base constructor."); - + if (RefChain.Nstrings != Nrapidities.size()) ABACUSerror("Incompatible Nrapidities vector used in Heis_Base constructor."); + int Mcheck = 0; for (int i = 0; i < RefChain.Nstrings; ++i) Mcheck += RefChain.Str_L[i] * Nrap[i]; Mdown = Mcheck; - + Nraptot = 0; for (int i = 0; i < RefChain.Nstrings; ++i) Nraptot += Nrap[i]; - /* + /* // Compute id id += Nrapidities[0]; long long int factor = 100000LL; @@ -400,7 +399,7 @@ namespace JSC { /* stringstream baselabel_strstream; baselabel_strstream << Nrapidities[0]; - for (int itype = 1; itype < Nrapidities.size(); ++itype) + for (int itype = 1; itype < Nrapidities.size(); ++itype) if (Nrapidities[itype] > 0) { baselabel_strstream << TYPESEP; stringstream typeout; @@ -411,12 +410,12 @@ namespace JSC { Mout << Nrapidities[itype]; baselabel += Mout.str(); } - */ + */ stringstream M0out; M0out << Nrapidities[0]; baselabel = M0out.str(); - for (int itype = 1; itype < Nrapidities.size(); ++itype) + for (int itype = 1; itype < Nrapidities.size(); ++itype) if (Nrapidities[itype] > 0) { baselabel += TYPESEP; stringstream typeout; @@ -433,18 +432,18 @@ namespace JSC { // Compute dimensionality of this sub-Hilbert space: complex ln_dimH_cx = 0.0; - for (int i = 0; i < RefChain.Nstrings; ++i) + for (int i = 0; i < RefChain.Nstrings; ++i) if (Nrap[i] > 0) ln_dimH_cx += ln_Gamma(complex((Ix2_max[i] - Ix2_min[i])/2 + 2)) - ln_Gamma(complex((Ix2_max[i] - Ix2_min[i])/2 + 2 - Nrap[i])) - ln_Gamma(complex(Nrap[i] + 1)); dimH = exp(real(ln_dimH_cx)); } - Heis_Base::Heis_Base (const Heis_Chain& RefChain, string baselabel_ref) - : Mdown(0), Nrap(Vect(0, RefChain.Nstrings)), Nraptot(0), + Heis_Base::Heis_Base (const Heis_Chain& RefChain, string baselabel_ref) + : Mdown(0), Nrap(Vect(0, RefChain.Nstrings)), Nraptot(0), Ix2_infty(Vect(RefChain.Nstrings)), Ix2_min(Vect(RefChain.Nstrings)), Ix2_max(Vect(RefChain.Nstrings)), baselabel (baselabel_ref) { // Build Nrapidities vector from baselabel_ref. - // This is simply done by using the state label standard reading function after conveniently + // This is simply done by using the state label standard reading function after conveniently // making baselabel into a label (as for a state with no excitations): string label_ref = baselabel + "_0_"; Vect > dummyOriginIx2(1); @@ -461,16 +460,16 @@ namespace JSC { int Mcheck = 0; for (int i = 0; i < RefChain.Nstrings; ++i) Mcheck += RefChain.Str_L[i] * Nrap[i]; Mdown = Mcheck; - + Nraptot = 0; for (int i = 0; i < RefChain.Nstrings; ++i) Nraptot += Nrap[i]; - + // Now compute the Ix2_infty numbers (*this).Compute_Ix2_limits(RefChain); // Compute dimensionality of this sub-Hilbert space: complex ln_dimH_cx = 0.0; - for (int i = 0; i < RefChain.Nstrings; ++i) + for (int i = 0; i < RefChain.Nstrings; ++i) if (Nrap[i] > 0) ln_dimH_cx += ln_Gamma(complex((Ix2_max[i] - Ix2_min[i])/2 + 2)) - ln_Gamma(complex((Ix2_max[i] - Ix2_min[i])/2 + 2 - Nrap[i])) - ln_Gamma(complex(Nrap[i] + 1)); dimH = exp(real(ln_dimH_cx)); } @@ -489,7 +488,7 @@ namespace JSC { } return(*this); } - + bool Heis_Base::operator== (const Heis_Base& RefBase) { bool answer = (Nrap == RefBase.Nrap); @@ -510,39 +509,39 @@ namespace JSC { if ((RefChain.Delta > 0.0) && (RefChain.Delta < 1.0)) { // Compute the Ix2_infty numbers - + DP sum1 = 0.0; DP sum2 = 0.0; - + for (int j = 0; j < RefChain.Nstrings; ++j) { - + sum1 = 0.0; - + for (int k = 0; k < RefChain.Nstrings; ++k) { - + sum2 = 0.0; - - sum2 += (RefChain.Str_L[j] == RefChain.Str_L[k]) ? 0.0 : 2.0 * atan(tan(0.25 * PI * (1.0 + RefChain.par[j] * RefChain.par[k]) + + sum2 += (RefChain.Str_L[j] == RefChain.Str_L[k]) ? 0.0 : 2.0 * atan(tan(0.25 * PI * (1.0 + RefChain.par[j] * RefChain.par[k]) - 0.5 * fabs(RefChain.Str_L[j] - RefChain.Str_L[k]) * RefChain.anis)); - sum2 += 2.0 * atan(tan(0.25 * PI * (1.0 + RefChain.par[j] * RefChain.par[k]) + sum2 += 2.0 * atan(tan(0.25 * PI * (1.0 + RefChain.par[j] * RefChain.par[k]) - 0.5 * (RefChain.Str_L[j] + RefChain.Str_L[k]) * RefChain.anis)); - - for (int a = 1; a < JSC::min(RefChain.Str_L[j], RefChain.Str_L[k]); ++a) - sum2 += 2.0 * 2.0 * atan(tan(0.25 * PI * (1.0 + RefChain.par[j] * RefChain.par[k]) + + for (int a = 1; a < ABACUS::min(RefChain.Str_L[j], RefChain.Str_L[k]); ++a) + sum2 += 2.0 * 2.0 * atan(tan(0.25 * PI * (1.0 + RefChain.par[j] * RefChain.par[k]) - 0.5 * (fabs(RefChain.Str_L[j] - RefChain.Str_L[k]) + 2.0*a) * RefChain.anis)); - + sum1 += (Nrap[k] - ((j == k) ? 1 : 0)) * sum2; } - - Ix2_infty[j] = (1.0/PI) * fabs(RefChain.Nsites * 2.0 * atan(tan(0.25 * PI * (1.0 + RefChain.par[j]) + + Ix2_infty[j] = (1.0/PI) * fabs(RefChain.Nsites * 2.0 * atan(tan(0.25 * PI * (1.0 + RefChain.par[j]) - 0.5 * RefChain.Str_L[j] * RefChain.anis)) - sum1); - + } // The Ix2_infty are now set. // Now compute the Ix2_max limits - + for (int j = 0; j < RefChain.Nstrings; ++j) { - + Ix2_max[j] = int(floor(Ix2_infty[j])); // sets basic integer // Reject formally infinite rapidities (i.e. if Delta is root of unity) @@ -556,7 +555,7 @@ namespace JSC { if (!((Nrap[j] + Ix2_max[j]) % 2)) Ix2_max[j] -= 1; while (Ix2_max[j] > RefChain.Nsites) { - Ix2_max[j] -= 2; + Ix2_max[j] -= 2; } Ix2_min[j] = -Ix2_max[j]; } @@ -565,41 +564,41 @@ namespace JSC { else if (RefChain.Delta == 1.0) { // Compute the Ix2_infty numbers - + int sum1 = 0; - + for (int j = 0; j < RefChain.Nstrings; ++j) { - + sum1 = 0; - + for (int k = 0; k < RefChain.Nstrings; ++k) { - - sum1 += Nrap[k] * (2 * JSC::min(RefChain.Str_L[j], RefChain.Str_L[k]) - ((j == k) ? 1 : 0)); + + sum1 += Nrap[k] * (2 * ABACUS::min(RefChain.Str_L[j], RefChain.Str_L[k]) - ((j == k) ? 1 : 0)); } - + //Ix2_infty[j] = (RefChain.Nsites - 1.0 + 2.0 * RefChain.Str_L[j] - sum1); Ix2_infty[j] = (RefChain.Nsites + 1.0 - sum1); // to get counting right... - + } // The Ix2_infty are now set. - + // Now compute the Ix2_max limits - + for (int j = 0; j < RefChain.Nstrings; ++j) { Ix2_max[j] = int(floor(Ix2_infty[j])); // sets basic integer // Give the correct parity to Ix2_max - + // If Nrap is even, Ix2_max must be odd. If odd, then even. if (!((Nrap[j] + Ix2_max[j]) % 2)) Ix2_max[j] -= 1; // If Ix2_max equals Ix2_infty, we reduce it by 2: - + if (Ix2_max[j] == int(Ix2_infty[j])) Ix2_max[j] -= 2; - + while (Ix2_max[j] > RefChain.Nsites) { - Ix2_max[j] -= 2; + Ix2_max[j] -= 2; } Ix2_min[j] = -Ix2_max[j]; } @@ -609,40 +608,40 @@ namespace JSC { else if (RefChain.Delta > 1.0) { // Compute the Ix2_infty numbers - + int sum1 = 0; - + for (int j = 0; j < RefChain.Nstrings; ++j) { - + sum1 = 0; - + for (int k = 0; k < RefChain.Nstrings; ++k) { - - sum1 += Nrap[k] * (2 * JSC::min(RefChain.Str_L[j], RefChain.Str_L[k]) - ((j == k) ? 1 : 0)); + + sum1 += Nrap[k] * (2 * ABACUS::min(RefChain.Str_L[j], RefChain.Str_L[k]) - ((j == k) ? 1 : 0)); } - + Ix2_infty[j] = (RefChain.Nsites - 1 + 2 * RefChain.Str_L[j] - sum1); - + } // The Ix2_infty are now set. - + // Now compute the Ix2_max limits - + for (int j = 0; j < RefChain.Nstrings; ++j) { - + Ix2_max[j] = int(floor(Ix2_infty[j])); // sets basic integer // Give the correct parity to Ix2_max - + // If Nrap is even, Ix2_max must be odd. If odd, then even. if (!((Nrap[j] + Ix2_max[j]) % 2)) Ix2_max[j] -= 1; - + // If Ix2_max equals Ix2_infty, we reduce it by 2: //if (Ix2_max[j] == Ix2_infty[j]) Ix2_max[j] -= 2; while (Ix2_max[j] > RefChain.Nsites) { - Ix2_max[j] -= 2; + Ix2_max[j] -= 2; } // Fudge, for strings: @@ -664,17 +663,17 @@ namespace JSC { Lambda::Lambda () : lambda(NULL) {} - Lambda::Lambda (const Heis_Chain& RefChain, int M) + Lambda::Lambda (const Heis_Chain& RefChain, int M) : Nstrings(1), Nrap(Vect(M,1)), Nraptot(M), lambda(new DP*[1]) // single type of string here //: lambda(Vect > (1)) { lambda[0] = new DP[M]; //lambda[0] = Vect (M); - for (int j = 0; j < M; ++j) lambda[0][j] = 0.0; + for (int j = 0; j < M; ++j) lambda[0][j] = 0.0; } - - Lambda::Lambda (const Heis_Chain& RefChain, const Heis_Base& base) + + Lambda::Lambda (const Heis_Chain& RefChain, const Heis_Base& base) : Nstrings(RefChain.Nstrings), Nrap(base.Nrap), Nraptot(base.Nraptot), lambda(new DP*[RefChain.Nstrings]) //: lambda(Vect > (RefChain.Nstrings)) { @@ -682,7 +681,7 @@ namespace JSC { lambda[0] = new DP[base.Nraptot]; for (int i = 1; i < RefChain.Nstrings; ++i) lambda[i] = lambda[i-1] + base[i-1]; //for (int i = 0; i < RefChain.Nstrings; ++i) lambda[i] = Vect (base[i]); - + for (int i = 0; i < RefChain.Nstrings; ++i) { for (int j = 0; j < base[i]; ++j) lambda[i][j] = 0.0; } @@ -702,7 +701,7 @@ namespace JSC { lambda = new DP*[Nstrings]; lambda[0] = new DP[Nraptot]; for (int i = 1; i < Nstrings; ++i) lambda[i] = lambda[i-1] + Nrap[i-1]; - for (int i = 0; i < Nstrings; ++i) + for (int i = 0; i < Nstrings; ++i) for (int j = 0; j < Nrap[i]; ++j) lambda[i][j] = RefLambda.lambda[i][j]; } @@ -717,13 +716,13 @@ namespace JSC { } } - + //*************************************************************************************************** // Function definitions: class Heis_Bethe_State - Heis_Bethe_State::Heis_Bethe_State () - : chain(Heis_Chain()), base(Heis_Base()), //offsets(Ix2_Offsets()), + Heis_Bethe_State::Heis_Bethe_State () + : chain(Heis_Chain()), base(Heis_Base()), //offsets(Ix2_Offsets()), //Ix2(Ix2_Config(chain, 1)), Ix2(Vect > (1)), lambda(Lambda(chain, 1)), BE(Lambda(chain, 1)), diffsq(0.0), conv(0), dev(1.0), iter(0), iter_Newton(0), @@ -733,14 +732,14 @@ namespace JSC { }; Heis_Bethe_State::Heis_Bethe_State (const Heis_Bethe_State& RefState) // copy constructor - //: chain(RefState.chain), base(RefState.base), offsets(RefState.offsets), Ix2(Ix2_Config(RefState.chain, RefState.base.Mdown)), + //: chain(RefState.chain), base(RefState.base), offsets(RefState.offsets), Ix2(Ix2_Config(RefState.chain, RefState.base.Mdown)), // lambda(Lambda(RefState.chain, RefState.base.Mdown)), BE(Lambda(RefState.chain, RefState.base.Mdown)), - : chain(RefState.chain), base(RefState.base), //offsets(RefState.offsets), - //Ix2(Ix2_Config(RefState.chain, RefState.base)), + : chain(RefState.chain), base(RefState.base), //offsets(RefState.offsets), + //Ix2(Ix2_Config(RefState.chain, RefState.base)), Ix2 (RefState.Ix2), lambda(Lambda(RefState.chain, RefState.base)), BE(Lambda(RefState.chain, RefState.base)), diffsq(RefState.diffsq), conv(RefState.conv), dev(RefState.dev), iter(RefState.iter), iter_Newton(RefState.iter_Newton), - E(RefState.E), iK(RefState.iK), K(RefState.K), lnnorm(RefState.lnnorm), + E(RefState.E), iK(RefState.iK), K(RefState.K), lnnorm(RefState.lnnorm), //id(RefState.id), maxid(RefState.maxid) //base_id(RefState.base_id), type_id(RefState.type_id), id(RefState.id), maxid(RefState.maxid), nparticles(RefState.nparticles) label(RefState.label) @@ -764,11 +763,11 @@ namespace JSC { //cout << "Heis constructor state OK" << endl; } - Heis_Bethe_State::Heis_Bethe_State (const Heis_Chain& RefChain, int M) - : chain(RefChain), base(RefChain, M), //offsets(base, 0LL), - //Ix2(Ix2_Config(RefChain, M)), + Heis_Bethe_State::Heis_Bethe_State (const Heis_Chain& RefChain, int M) + : chain(RefChain), base(RefChain, M), //offsets(base, 0LL), + //Ix2(Ix2_Config(RefChain, M)), Ix2 (Vect > (1)), - lambda(Lambda(RefChain, M)), + lambda(Lambda(RefChain, M)), BE(Lambda(RefChain, M)), diffsq(1.0), conv(0), dev(1.0), iter(0), iter_Newton(0), E(0.0), iK(0), K(0.0), lnnorm(-100.0) //id(0LL), maxid(0LL) @@ -782,24 +781,24 @@ namespace JSC { label = M0out.str() + "_0_"; } - Heis_Bethe_State::Heis_Bethe_State (const Heis_Chain& RefChain, const Heis_Base& RefBase) - : chain(RefChain), base(RefBase), //offsets(RefBase, 0LL), - //Ix2(Ix2_Config(RefChain, RefBase)), + Heis_Bethe_State::Heis_Bethe_State (const Heis_Chain& RefChain, const Heis_Base& RefBase) + : chain(RefChain), base(RefBase), //offsets(RefBase, 0LL), + //Ix2(Ix2_Config(RefChain, RefBase)), Ix2 (Vect > (RefChain.Nstrings)), - lambda(Lambda(RefChain, RefBase)), + lambda(Lambda(RefChain, RefBase)), BE(Lambda(RefChain, RefBase)), diffsq(1.0), conv(0), dev(1.0), iter(0), iter_Newton(0), E(0.0), iK(0), K(0.0), lnnorm(-100.0) //id(0LL), maxid(0LL) //base_id(RefBase.id), type_id(0LL), id(0LL), maxid(offsets.maxid), nparticles(0) { // Check that the number of rapidities is consistent with Mdown - + //cout << "Here in Heis constructor chain base" << endl; //cout << "lambda " << lambda[0][0] << endl; //cout << "lambda OK" << endl; int Mcheck = 0; for (int i = 0; i < RefChain.Nstrings; ++i) Mcheck += base[i] * RefChain.Str_L[i]; - if (RefBase.Mdown != Mcheck) JSCerror("Wrong M from Nrapidities input vector, in Heis_Bethe_State constructor."); + if (RefBase.Mdown != Mcheck) ABACUSerror("Wrong M from Nrapidities input vector, in Heis_Bethe_State constructor."); for (int i = 0; i < RefChain.Nstrings; ++i) Ix2[i] = Vect (base[i]); @@ -808,7 +807,7 @@ namespace JSC { for (int j = 0; j < base[i]; ++j) Ix2[i][j] = -(base[i] - 1) + 2*j; } - label = Return_State_Label (Ix2, Ix2); + label = Return_State_Label (Ix2, Ix2); } void Heis_Bethe_State::Set_to_Label (string label_ref, const Vect >& OriginIx2) @@ -834,13 +833,13 @@ namespace JSC { // Now set the excitations: for (int it = 0; it < labeldata.type.size(); ++it) for (int iexc = 0; iexc < labeldata.nexc[it]; ++iexc) - for (int i = 0; i < labeldata.M[it]; ++i) + for (int i = 0; i < labeldata.M[it]; ++i) if (Ix2[labeldata.type[it] ][i] == labeldata.Ix2old[it][iexc]) { //cout << it << "\t" << iexc << "\t" << i << endl; //cout << "\tSetting Ix2[" << labeldata.type[it] << "][" << i << "] to " << labeldata.Ix2exc[it][iexc] << endl; - //cout << Ix2[labeldata.type[it] ][i] << "\t" << labeldata.Ix2old[it][iexc] << "\t" << labeldata.Ix2exc[it][iexc] << endl; + //cout << Ix2[labeldata.type[it] ][i] << "\t" << labeldata.Ix2old[it][iexc] << "\t" << labeldata.Ix2exc[it][iexc] << endl; Ix2[labeldata.type[it] ][i] = labeldata.Ix2exc[it][iexc]; - //cout << Ix2[labeldata.type[it] ][i] << "\t" << labeldata.Ix2old[it][iexc] << "\t" << labeldata.Ix2exc[it][iexc] << endl; + //cout << Ix2[labeldata.type[it] ][i] << "\t" << labeldata.Ix2old[it][iexc] << "\t" << labeldata.Ix2exc[it][iexc] << endl; } //cout << "State obtained(1): " << (*this) << endl; @@ -862,15 +861,15 @@ namespace JSC { { // This function does not assume any ordering of the Ix2. - // ASSUMPTIONS: + // ASSUMPTIONS: // (*this) has a base already identical to base of OriginIx2 // First check that bases are consistent - if ((*this).chain.Nstrings != OriginIx2.size()) JSCerror("Inconsistent base sizes in Heis_Bethe_State::Set_Label_from_Ix2."); + if ((*this).chain.Nstrings != OriginIx2.size()) ABACUSerror("Inconsistent base sizes in Heis_Bethe_State::Set_Label_from_Ix2."); // Then check that the filling at each level is equal for (int il = 0; il < (*this).chain.Nstrings; ++il) - if ((*this).base.Nrap[il] != OriginIx2[il].size()) JSCerror("Inconsistent base filling in Heis_Bethe_State::Set_Label_from_Ix2."); + if ((*this).base.Nrap[il] != OriginIx2[il].size()) ABACUSerror("Inconsistent base filling in Heis_Bethe_State::Set_Label_from_Ix2."); // Determine how many types of particles are present int ntypes = 1; // level 0 always assumed present @@ -882,7 +881,7 @@ namespace JSC { M_ref[0] = OriginIx2[0].size(); type_ref[0] = 0; int itype = 1; - for (int il = 1; il < chain.Nstrings; ++il) + for (int il = 1; il < chain.Nstrings; ++il) if (base.Nrap[il] > 0) { type_ref[itype] = il; M_ref[itype++] = OriginIx2[il].size(); @@ -897,23 +896,23 @@ namespace JSC { for (int il = 0; il < chain.Nstrings; ++il) { if (il == 0 || base.Nrap[il] > 0) { itype++; - for (int alpha = 0; alpha < base.Nrap[il]; ++alpha) + for (int alpha = 0; alpha < base.Nrap[il]; ++alpha) if (!OriginIx2[il].includes(Ix2[il][alpha])) nexc_ref[itype] += 1; - Ix2old_ref[itype] = Vect(JSC::max(nexc_ref[itype], 1)); - Ix2exc_ref[itype] = Vect(JSC::max(nexc_ref[itype], 1)); + Ix2old_ref[itype] = Vect(ABACUS::max(nexc_ref[itype], 1)); + Ix2exc_ref[itype] = Vect(ABACUS::max(nexc_ref[itype], 1)); int nexccheck = 0; - for (int alpha = 0; alpha < base.Nrap[il]; ++alpha) + for (int alpha = 0; alpha < base.Nrap[il]; ++alpha) if (!OriginIx2[il].includes(Ix2[il][alpha])) Ix2exc_ref[itype][nexccheck++] = Ix2[il][alpha]; if (nexccheck != nexc_ref[itype]) { - cout << "il = " << il << "\titype = " << itype << "\tnexccheck = " << nexccheck << "\tnexc_ref[itype] = " << nexc_ref[itype] << endl; + cout << "il = " << il << "\titype = " << itype << "\tnexccheck = " << nexccheck << "\tnexc_ref[itype] = " << nexc_ref[itype] << endl; cout << OriginIx2[il] << endl << Ix2[il] << endl; - JSCerror("Counting excitations wrong (1) in Heis_Bethe_State::Set_Label_from_Ix2."); + ABACUSerror("Counting excitations wrong (1) in Heis_Bethe_State::Set_Label_from_Ix2."); } nexccheck = 0; - for (int alpha = 0; alpha < base.Nrap[il]; ++alpha) + for (int alpha = 0; alpha < base.Nrap[il]; ++alpha) if (!Ix2[il].includes (OriginIx2[il][alpha])) Ix2old_ref[itype][nexccheck++] = OriginIx2[il][alpha]; if (nexccheck != nexc_ref[itype]) { - JSCerror("Counting excitations wrong (2) in Heis_Bethe_State::Set_Label_from_Ix2."); + ABACUSerror("Counting excitations wrong (2) in Heis_Bethe_State::Set_Label_from_Ix2."); } // Now order the Ix2old_ref and Ix2exc_ref: Ix2old_ref[itype].QuickSort(); @@ -928,7 +927,7 @@ namespace JSC { bool Heis_Bethe_State::Check_Symmetry () { - // Checks whether the I's are symmetrically distributed. + // Checks whether the I's are symmetrically distributed. bool symmetric_state = true; int arg, test1, test3; @@ -939,11 +938,11 @@ namespace JSC { test1 = 0; test3 = 0; for (int alpha = 0; alpha < base[j]; ++alpha) { - arg = (Ix2[j][alpha] != chain.Nsites) ? Ix2[j][alpha] : 0; // since Ix2 = N is same as Ix2 = -N by periodicity, this is symmetric. + arg = (Ix2[j][alpha] != chain.Nsites) ? Ix2[j][alpha] : 0; // since Ix2 = N is same as Ix2 = -N by periodicity, this is symmetric. test1 += arg; test3 += arg * arg * arg; // to make sure that all I's are symmetrical... } - if (!(symmetric_state && (test1 == 0) && (test3 == 0))) symmetric_state = false; + if (!(symmetric_state && (test1 == 0) && (test3 == 0))) symmetric_state = false; } //} /* @@ -954,12 +953,12 @@ namespace JSC { test1 = 0; test3 = 0; for (int alpha = 0; alpha < base[j]; ++alpha) { - arg = (Ix2[j][alpha] != chain.Nsites - && abs(Ix2[j][alpha]) != base.Ix2_max[j]) ? Ix2[j][alpha] : 0; // since Ix2 = N is same as Ix2 = -N by periodicity, this is symmetric. + arg = (Ix2[j][alpha] != chain.Nsites + && abs(Ix2[j][alpha]) != base.Ix2_max[j]) ? Ix2[j][alpha] : 0; // since Ix2 = N is same as Ix2 = -N by periodicity, this is symmetric. test1 += arg; test3 += arg * arg * arg; // to make sure that all I's are symmetrical... } - if (!(symmetric_state && (test1 == 0) && (test3 == 0))) symmetric_state = false; + if (!(symmetric_state && (test1 == 0) && (test3 == 0))) symmetric_state = false; } } */ @@ -974,9 +973,9 @@ namespace JSC { { DP maxterm = 0.0; int jmax, alphamax; - + diffsq = 0.0; - for (int j = 0; j < chain.Nstrings; ++j) + for (int j = 0; j < chain.Nstrings; ++j) for (int alpha = 0; alpha < base[j]; ++alpha) { diffsq += pow(BE[j][alpha], 2.0); if (pow(BE[j][alpha], 2.0)/chain.Nsites > maxterm) { @@ -1000,7 +999,7 @@ namespace JSC { diffsq = 1.0; - if (reset_rapidities) + if (reset_rapidities) (*this).Set_Free_lambdas(); //cout << endl << "After Set_Free_lambdas: " << (*this) << endl; (*this).Compute_BE(); @@ -1034,7 +1033,7 @@ namespace JSC { if (info_findrap) cout << "Find_Rapidities called for state with label " << (*this).label << endl; - while (diffsq > chain.prec && (iter < 500 && iter_Newton < 100 + while (diffsq > chain.prec && (iter < 500 && iter_Newton < 100 || straight_improving || extrap_improving || Newton_improving)) { // If we haven't reset, first try a few Newton steps... @@ -1052,9 +1051,9 @@ namespace JSC { extrap_start = clock(); iter_extrap_start = iter; diffsq_extrap_start = diffsq; - + if (diffsq > iter_prec) (*this).Solve_BAE_straight_iter (iter_prec, 10, iter_factor); - + extrap_stop = clock(); iter_extrap_stop = iter; diffsq_extrap_stop = diffsq; @@ -1063,8 +1062,8 @@ namespace JSC { if (info_findrap) cout << "Straight iter: iter " << iter << "\titer_factor " << iter_factor << "\tdiffsq " << diffsq << endl; - //} while (diffsq > chain.prec && !is_nan(diffsq) && diffsq_extrap_stop/diffsq_extrap_start < 0.01); - } while (diffsq > diffsq_iter_aim && !is_nan(diffsq) && diffsq_extrap_stop/diffsq_extrap_start < 0.01); + //} while (diffsq > chain.prec && !is_nan(diffsq) && diffsq_extrap_stop/diffsq_extrap_start < 0.01); + } while (diffsq > diffsq_iter_aim && !is_nan(diffsq) && diffsq_extrap_stop/diffsq_extrap_start < 0.01); straight_improving = (diffsq < diffsq_start); @@ -1075,47 +1074,47 @@ namespace JSC { diffsq_start = diffsq; - if (diffsq > chain.prec) + if (diffsq > chain.prec) do { extrap_start = clock(); iter_extrap_start = iter; diffsq_extrap_start = diffsq; - + if (diffsq > iter_prec) (*this).Solve_BAE_extrap (iter_prec, 10, iter_factor_extrap); - + extrap_stop = clock(); iter_extrap_stop = iter; diffsq_extrap_stop = diffsq; - + iter_prec = diffsq * 0.1; - + if (info_findrap) cout << "Extrap: iter " << iter << "\tdiffsq " << diffsq << endl; - - } while (diffsq > chain.prec && !is_nan(diffsq) && diffsq_extrap_stop/diffsq_extrap_start < 0.01); + + } while (diffsq > chain.prec && !is_nan(diffsq) && diffsq_extrap_stop/diffsq_extrap_start < 0.01); extrap_improving = (diffsq < diffsq_extrap_start); // Now try Newton diffsq_Newton_start = diffsq; - if (diffsq > chain.prec) + if (diffsq > chain.prec) do { Newton_start = clock(); iter_Newton_start = iter_Newton; diffsq_Newton_start = diffsq; - + if (diffsq > iter_prec) (*this).Solve_BAE_Newton (chain.prec, 5); - + Newton_stop = clock(); iter_Newton_stop = iter_Newton; diffsq_Newton_stop = diffsq; - + if (info_findrap) cout << "Newton: iter_Newton " << iter_Newton << "\tdiffsq " << diffsq << endl; - - } while (diffsq > chain.prec && !is_nan(diffsq) && diffsq_Newton_stop/diffsq_Newton_start < 0.01); + + } while (diffsq > chain.prec && !is_nan(diffsq) && diffsq_Newton_stop/diffsq_Newton_start < 0.01); Newton_improving = (diffsq < diffsq_Newton_start); - + //if (diffsq > iter_prec) (*this).Solve_BAE_smackdown (0.1 * diffsq, 1); //cout << "Before silk: diffsq = " << diffsq << endl; @@ -1133,10 +1132,10 @@ namespace JSC { } iter_prec *= 1.0e-4; - iter_prec = JSC::max(iter_prec, chain.prec); + iter_prec = ABACUS::max(iter_prec, chain.prec); } // while (diffsq > chain.prec && (iter < 300 && iter_Newton < 50... - + // Check convergence: //cout << "Check_Rapidities: " << (*this).Check_Rapidities() << endl; @@ -1206,7 +1205,7 @@ namespace JSC { else { //cout << lambdaleft << "\t" << lambdamid << "\t" << lambdaright << endl; //cout << BEleft << "\t" << BEmid << "\t" << BEright << endl; - //JSCerror("Problem in Solve_BAE_bisect."); + //ABACUSerror("Problem in Solve_BAE_bisect."); return; // this procedure has failed } @@ -1223,7 +1222,7 @@ namespace JSC { { //DP lambda_old; for (int j = 0; j < chain.Nstrings; ++j) { - for (int alpha = 0; alpha < base[j]; ++alpha) + for (int alpha = 0; alpha < base[j]; ++alpha) { //lambda_old = lambda[j][alpha]; //lambda[j][alpha] = Iterate_BAE (j, alpha); @@ -1235,7 +1234,7 @@ namespace JSC { iter++; - (*this).Compute_BE(); + (*this).Compute_BE(); (*this).Compute_diffsq(); } @@ -1263,7 +1262,7 @@ namespace JSC { //cout << "ITERATION " << iter_done_here << endl << (*this) << endl << endl; iter_done_here++; } - + if ((diffsq > diffsq_ref) || (is_nan(diffsq))) { // This procedure has failed. We reset everything to begin values. //cout << "Straight iter failed: resetting." << endl; @@ -1325,26 +1324,26 @@ namespace JSC { Vect_DP rap(0.0, 4); Vect_DP oneoverP(0.0, 4); DP deltalambda = 0.0; - + for (int i = 0; i < 4; ++i) oneoverP[i] = 1.0/(1.0 + i*i); - + for (int j = 0; j < chain.Nstrings; ++j) for (int alpha = 0; alpha < base[j]; ++alpha) { rap[0] = lambda1[j][alpha]; rap[1] = lambda2[j][alpha]; rap[2] = lambda3[j][alpha]; rap[3] = lambda4[j][alpha]; //rap[4] = lambda5[j][alpha]; - - polint (oneoverP, rap, 0.0, lambda[j][alpha], deltalambda); - + + polint (oneoverP, rap, 0.0, lambda[j][alpha], deltalambda); + //cout << j << "\t" << alpha << "\t" << rap << "\t" << lambda[j][alpha] << "\t" << deltalambda << endl; } - + // Iterate once to stabilize result (*this).Iterate_BAE(iter_factor); } - } // ((diffsq > extrap_prec) && (max_iter_extrap > iter_done_here)) + } // ((diffsq > extrap_prec) && (max_iter_extrap > iter_done_here)) if ((diffsq >= diffsq_ref) || (is_nan(diffsq))) { // This procedure has failed. We reset everything to begin values. @@ -1375,12 +1374,12 @@ namespace JSC { int iter_done_here = 0; while ((diffsq > silk_prec) && (max_iter_silk > iter_done_here)) { - + // Find the highest `deviant' rapidity int jmax = 0; int alphamax = 0; DP absBEmax = 0.0; - for (int j = 0; j < chain.Nstrings; ++j) + for (int j = 0; j < chain.Nstrings; ++j) for (int alpha = 0; alpha < base[j]; ++alpha) { //cout << j << "\t" << alpha << "\t" << BE[j][alpha] << endl; if (fabs(BE[j][alpha]) > absBEmax) { @@ -1391,7 +1390,7 @@ namespace JSC { } //cout << "jmax = " << jmax << "\talphamax = " << alphamax << "\t" << lambda[jmax][alphamax] << "\tBE before " << BE[jmax][alphamax] << endl; - // Now recalculate this max deviant rapidity, + // Now recalculate this max deviant rapidity, //cout << lambda[jmax][alphamax] << "\t" << Iterate_BAE (jmax, alphamax) << endl; /* @@ -1401,7 +1400,7 @@ namespace JSC { dlambda = Iterate_BAE (jmax, alphamax) - lambda[jmax][alphamax]; lambda[jmax][alphamax] += iter_factor * dlambda; prevBEmax = BE[jmax][alphamax]; - (*this).Compute_BE(); + (*this).Compute_BE(); iter_done_here++; cout << "jmax = " << jmax << "\talphamax = " << alphamax << "\t" << lambda[jmax][alphamax] << "\t" << dlambda << "\tBE during " << BE[jmax][alphamax] << endl; } while (dlambda * dlambda > silk_prec && fabs(BE[jmax][alphamax]) < fabs(prevBEmax) && max_iter_silk > iter_done_here); @@ -1418,7 +1417,7 @@ namespace JSC { } //cout << "Silk gloves: diffsq from " << diffsq_ref << "\tto " << diffsq << endl; - + if ((diffsq > diffsq_ref) || (is_nan(diffsq))) { // This procedure has failed. We reset everything to begin values. for (int j = 0; j < chain.Nstrings; ++j) for (int alpha = 0; alpha < base[j]; ++alpha) lambda[j][alpha] = lambda_ref[j][alpha]; @@ -1435,8 +1434,8 @@ namespace JSC { // Re-solves for all rapidities lambda[j][alpha] such that BE[j][alpha]^2/N > max_allowed. // Assumes that BE[][] is up-to-date. - for (int j = 0; j < chain.Nstrings; ++j) - for (int alpha = 0; alpha < base[j]; ++alpha) + for (int j = 0; j < chain.Nstrings; ++j) + for (int alpha = 0; alpha < base[j]; ++alpha) if (pow(BE[j][alpha], 2.0)/chain.Nsites > max_allowed) (*this).Solve_BAE (j, alpha, max_allowed, 100); } @@ -1471,7 +1470,7 @@ namespace JSC { (*this).Build_Reduced_Gaudin_Matrix (Gaudin); int index = 0; - for (int j = 0; j < chain.Nstrings; ++j) + for (int j = 0; j < chain.Nstrings; ++j) for (int alpha = 0; alpha < base[j]; ++alpha) { dlambda[index] = - BE[j][alpha] * chain.Nsites; index++; @@ -1495,7 +1494,7 @@ namespace JSC { for (int i = 0; i < base.Nraptot; ++i) if (fabs(real(dlambda[i])) > 1.0) dlambda[i] = 0.0;//(real(dlambda[i]) > 0) ? 1.0 : -1.0; index = 0; - for (int j = 0; j < chain.Nstrings; ++j) + for (int j = 0; j < chain.Nstrings; ++j) for (int alpha = 0; alpha < base[j]; ++alpha) { lambda[j][alpha] = lambda_ref[j][alpha] + real(dlambda[index]); //cout << j << "\t" << alpha << "\t" << dlambda[index] << "\t" << lambda_ref[j][alpha] << "\t" << lambda[j][alpha] << endl; @@ -1547,7 +1546,7 @@ namespace JSC { (*this).Compute_BE(); diffsq = diffsq_ref; } - + return; } @@ -1619,7 +1618,7 @@ namespace JSC { { if (iKboost == 0) return(true); // done - Ix2_Offsets offsets_here = offsets; + Ix2_Offsets offsets_here = offsets; bool success = false; @@ -1643,8 +1642,8 @@ namespace JSC { //cout << "Matching Ix2 for base " << (*this).base.baselabel << " from base " << StateToMatch.base.baselabel << endl; - if ((*this).chain != StateToMatch.chain) - JSCerror("Heis_Bethe_State::Find_Closest_Matching_Ix2_fixed_Base: trying to match Ix2 for two states with different chains."); + if ((*this).chain != StateToMatch.chain) + ABACUSerror("Heis_Bethe_State::Find_Closest_Matching_Ix2_fixed_Base: trying to match Ix2 for two states with different chains."); // Check level by level, match quantum numbers from center up. for (int il = 0; il < chain.Nstrings; ++il) { @@ -1662,17 +1661,17 @@ namespace JSC { // and then do the same thing from the right. for (int a = 0; a < (*this).base.Nrap[il]; ++a) (*this).Ix2[il][a] = -(*this).base.Nrap[il] + 1 + 2*a; - int nleft = StateToMatch.base.Nrap[il]/2; + int nleft = StateToMatch.base.Nrap[il]/2; for (int a = 0; a < nleft; ++a) if (StateToMatch.Ix2[il][a] - Ix2shift < (*this).Ix2[il][a]) (*this).Ix2[il][a] = StateToMatch.Ix2[il][a] - Ix2shift; for (int a = 0; a < StateToMatch.base.Nrap[il] - 1 - nleft; ++a) - if (StateToMatch.Ix2[il][StateToMatch.base.Nrap[il] - 1 - a] - Ix2shift > (*this).Ix2[il][(*this).base.Nrap[il] - 1 - a]) + if (StateToMatch.Ix2[il][StateToMatch.base.Nrap[il] - 1 - a] - Ix2shift > (*this).Ix2[il][(*this).base.Nrap[il] - 1 - a]) (*this).Ix2[il][(*this).base.Nrap[il] - 1 - a] = StateToMatch.Ix2[il][StateToMatch.base.Nrap[il] - 1 - a] - Ix2shift; } } // for il //cout << "StateToMatch:" << endl << StateToMatch << endl << "MatchingState:" << endl << (*this) << endl; - + } @@ -1680,7 +1679,7 @@ namespace JSC { { // sends all the state data to output stream - s << endl << "******** Chain with Delta = " << state.chain.Delta << " Nsites = " << state.chain.Nsites << " Mdown = " << state.base.Mdown + s << endl << "******** Chain with Delta = " << state.chain.Delta << " Nsites = " << state.chain.Nsites << " Mdown = " << state.base.Mdown //<< ": eigenstate with base_id " << state.base_id << ", type_id " << state.type_id << " id " << state.id << " maxid " << state.maxid << endl << ": eigenstate with label " << state.label << endl << "E = " << state.E << " K = " << state.K << " iK = " << state.iK << " lnnorm = " << state.lnnorm << endl @@ -1714,4 +1713,4 @@ namespace JSC { } -} // namespace JSC +} // namespace ABACUS diff --git a/src/HEIS/Heis_Chem_Pot.cc b/src/HEIS/Heis_Chem_Pot.cc index 0d9764f..34e3c53 100644 --- a/src/HEIS/Heis_Chem_Pot.cc +++ b/src/HEIS/Heis_Chem_Pot.cc @@ -1,8 +1,8 @@ /********************************************************** -This software is part of J.-S. Caux's ABACUS++ library. +This software is part of J.-S. Caux's ABACUS library. -Copyright (c) +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -10,19 +10,20 @@ File: src/HEIS/Heis_Chem_Pot.cc Purpose: calculates the chemical potential. - ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" -namespace JSC { +using namespace std; + +namespace ABACUS { DP Ezero (DP Delta, int N, int M) { // Returns the energy of the ground state with M down spins - if (M < 0 || M > N/2) JSCerror("M out of bounds in Ezero."); - + if (M < 0 || M > N/2) ABACUSerror("M out of bounds in Ezero."); + DP E = -1.0; // sentinel value if (M == 0) E = N * Delta/4.0; @@ -30,32 +31,32 @@ namespace JSC { else { Heis_Chain BD1(1.0, Delta, 0.0, N); - + Vect_INT Nrapidities_groundstate(0, BD1.Nstrings); - + Nrapidities_groundstate[0] = M; - + Heis_Base baseconfig_groundstate(BD1, Nrapidities_groundstate); - + if ((Delta > 0.0) && (Delta < 1.0)) { XXZ_Bethe_State groundstate(BD1, baseconfig_groundstate); groundstate.Compute_All(true); E = groundstate.E; } - + else if (Delta == 1.0) { XXX_Bethe_State groundstate(BD1, baseconfig_groundstate); groundstate.Compute_All(true); E = groundstate.E; } - + else if (Delta > 1.0) { XXZ_gpd_Bethe_State groundstate(BD1, baseconfig_groundstate); groundstate.Compute_All(true); E = groundstate.E; } - - else JSCerror("Anisotropy out of bounds in Ezero."); + + else ABACUSerror("Anisotropy out of bounds in Ezero."); } return(E); @@ -67,7 +68,7 @@ namespace JSC { DP H = 0.0; - if (2*M == N) H = 0.0; + if (2*M == N) H = 0.0; else if (Delta <= 1.0) H = Ezero (Delta, N, M - 1) - Ezero (Delta, N, M); @@ -78,7 +79,7 @@ namespace JSC { { if (M < 0 || M > N/2 - 1) { cout << "M = " << M << endl; - JSCerror("M out of bounds in HZmin."); + ABACUSerror("M out of bounds in HZmin."); } if (Ezero_ref[M] == -1.0) Ezero_ref[M] = Ezero(Delta, N, M); @@ -91,7 +92,7 @@ namespace JSC { { // Returns the value of M for given field HZ - if (HZ < 0.0) JSCerror("Please use a positive field in M_vs_H."); + if (HZ < 0.0) ABACUSerror("Please use a positive field in M_vs_H."); else if (HZ == 0.0) return(N/2); @@ -109,7 +110,7 @@ namespace JSC { if (HZ >= 1.0 + Delta) M_actual = 0; // saturation else { - + HZmin_actual = HZmin (Delta, N, M_actual, Ezero); HZmax_actual = HZmin (Delta, N, M_actual - 1, Ezero); @@ -117,15 +118,15 @@ namespace JSC { if (HZmin_actual > HZ) M_actual += M_step; else if (HZmax_actual <= HZ) M_actual -= M_step; - + M_step = (M_step + 1)/2; HZmin_actual = HZmin (Delta, N, M_actual, Ezero); HZmax_actual = HZmin (Delta, N, M_actual - 1, Ezero); - M_found = (HZmin_actual < HZ && HZ <= HZmax_actual); + M_found = (HZmin_actual < HZ && HZ <= HZmax_actual); - //cout << "M_actual = " << M_actual << "\tM_step = " << M_step + //cout << "M_actual = " << M_actual << "\tM_step = " << M_step // << "\tHZmin_actual = " << HZmin_actual << "\tHZmax_actual = " << HZmax_actual << "\tHZ = " << HZ << "\t" << M_found << endl; } } diff --git a/src/HEIS/Heis_Matrix_Element_Contrib.cc b/src/HEIS/Heis_Matrix_Element_Contrib.cc index 0e2799d..dca9278 100644 --- a/src/HEIS/Heis_Matrix_Element_Contrib.cc +++ b/src/HEIS/Heis_Matrix_Element_Contrib.cc @@ -1,8 +1,8 @@ /********************************************************** -This software is part of J.-S. Caux's ABACUS++ library. +This software is part of J.-S. Caux's ABACUS library. -Copyright (c) +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -10,15 +10,14 @@ File: src/HEIS/Heis_Matrix_Element_Contrib.cc Purpose: handles the generic call for a matrix element. - ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -namespace JSC { +namespace ABACUS { //DP Compute_Matrix_Element_Contrib (char whichDSF, bool fixed_iK, XXZ_Bethe_State& LeftState, //XXZ_Bethe_State& RightState, DP Chem_Pot, fstream& DAT_outfile) @@ -50,7 +49,7 @@ namespace JSC { } else if (whichDSF == 'p') ME = exp(real(ln_Smin_ME (LeftState, RightState))); - else JSCerror("Wrong whichDSF in Compute_Matrix_Element_Contrib."); + else ABACUSerror("Wrong whichDSF in Compute_Matrix_Element_Contrib."); if (is_nan(ME)) ME = 0.0; @@ -157,7 +156,7 @@ namespace JSC { else if (whichDSF == 'q') // Geometric quench //ME_CX = ln_Overlap (LeftState, RightState); ME_CX = ln_Overlap (RightState, LeftState); - else JSCerror("Wrong whichDSF in Compute_Matrix_Element_Contrib."); + else ABACUSerror("Wrong whichDSF in Compute_Matrix_Element_Contrib."); if (is_nan(ME)) ME = 0.0; if (is_nan(norm(ME_CX))) ME_CX = -100.0; @@ -254,7 +253,7 @@ namespace JSC { sum1 = 0; for (int k = 0; k < LeftState.chain.Nstrings; ++k) - sum1 += LeftState.base.Nrap[k] * (2 * JSC::min(LeftState.chain.Str_L[j], LeftState.chain.Str_L[k]) - ((j == k) ? 1 : 0)); + sum1 += LeftState.base.Nrap[k] * (2 * ABACUS::min(LeftState.chain.Str_L[j], LeftState.chain.Str_L[k]) - ((j == k) ? 1 : 0)); // This almost does it: only missing are the states with one on -PI/2 and one on PI/2 if (LeftState.base.Nrap[j] >= 1 && (LeftState.Ix2[j][0] <= -(LeftState.chain.Nsites - sum1) @@ -324,7 +323,7 @@ namespace JSC { } else if (whichDSF == 'p') ME = exp(real(ln_Smin_ME (LeftState, RightState))); - else JSCerror("Wrong whichDSF in Compute_Matrix_Element_Contrib."); + else ABACUSerror("Wrong whichDSF in Compute_Matrix_Element_Contrib."); if (is_nan(ME)) ME = 0.0; @@ -376,4 +375,4 @@ namespace JSC { } -} // namespace JSC +} // namespace ABACUS diff --git a/src/HEIS/Heis_Sumrules.cc b/src/HEIS/Heis_Sumrules.cc index 3917d97..48126dc 100644 --- a/src/HEIS/Heis_Sumrules.cc +++ b/src/HEIS/Heis_Sumrules.cc @@ -1,8 +1,8 @@ /********************************************************** -This software is part of J.-S. Caux's ABACUS++ library. +This software is part of J.-S. Caux's ABACUS library. -Copyright (c) +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -10,14 +10,13 @@ File: src/HEIS/Heis_Sumrules.cc Purpose: defines sumrule factors for Heisenberg - ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -namespace JSC { +namespace ABACUS { DP X_avg (char xyorz, DP Delta, int N, int M) { @@ -29,24 +28,24 @@ namespace JSC { // Define the chain: J, Delta, h, Nsites Heis_Chain chain(1.0, Delta, 0.0, N); - + // Define the base: chain, Mdown Heis_Base gbase(chain, M); // Define the chain: J, Delta, h, Nsites Heis_Chain chain2(1.0, Delta + eps_Delta, 0.0, N); - + // Define the base: chain, Mdown Heis_Base gbase2(chain2, M); - + DP E0_Delta = 0.0; - DP E0_Delta_eps = 0.0; + DP E0_Delta_eps = 0.0; if (Delta > 0.0 && Delta < 1.0) { // Define the ground state XXZ_Bethe_State gstate(chain, gbase); - + // Compute everything about the ground state gstate.Compute_All(true); @@ -54,7 +53,7 @@ namespace JSC { // Define the ground state XXZ_Bethe_State gstate2(chain2, gbase2); - + // Compute everything about the ground state gstate2.Compute_All(true); @@ -64,7 +63,7 @@ namespace JSC { else if (Delta == 1.0) { // Define the ground state XXX_Bethe_State gstate(chain, gbase); - + // Compute everything about the ground state gstate.Compute_All(true); @@ -72,7 +71,7 @@ namespace JSC { // Define the ground state XXZ_gpd_Bethe_State gstate2(chain2, gbase2); // need XXZ_gpd here - + // Compute everything about the ground state gstate2.Compute_All(true); @@ -82,7 +81,7 @@ namespace JSC { else if (Delta > 1.0) { // Define the ground state XXZ_gpd_Bethe_State gstate(chain, gbase); - + // Compute everything about the ground state gstate.Compute_All(true); @@ -90,14 +89,14 @@ namespace JSC { // Define the ground state XXZ_gpd_Bethe_State gstate2(chain2, gbase2); - + // Compute everything about the ground state gstate2.Compute_All(true); E0_Delta_eps = gstate2.E; } - else JSCerror("Wrong anisotropy in S1_sumrule_factor."); + else ABACUSerror("Wrong anisotropy in S1_sumrule_factor."); DP answer = 0.0; //if (xyorz == 'x' || xyorz == 'y') answer = 0.5 * (E0_Delta - Delta * (E0_Delta_eps - E0_Delta)/eps_Delta); @@ -106,7 +105,7 @@ namespace JSC { // Careful for z ! Hamiltonian defined as S^z S^z - 1/4, so add back N/4: else if (xyorz == 'z') answer = (E0_Delta_eps - E0_Delta)/eps_Delta + 0.25 * N; - else JSCerror("option not implemented in X_avg."); + else ABACUSerror("option not implemented in X_avg."); return(answer); } @@ -129,7 +128,7 @@ namespace JSC { else if (mporz == 'b') sumrule = 1.0; else if (mporz == 'c') sumrule = 1.0; - else JSCerror("option not implemented in S1_sumrule_factor."); + else ABACUSerror("option not implemented in S1_sumrule_factor."); //return(1.0/sumrule); return(1.0/(sumrule + 1.0e-16)); // sumrule is 0 for iK == 0 or N @@ -153,7 +152,7 @@ namespace JSC { else if (mporz == 'b') sumrule = 1.0; else if (mporz == 'c') sumrule = 1.0; - else JSCerror("option not implemented in S1_sumrule_factor."); + else ABACUSerror("option not implemented in S1_sumrule_factor."); return(1.0/(sumrule + 1.0e-16)); // sumrule is 0 for iK == 0 or N } @@ -166,7 +165,7 @@ namespace JSC { //if (!fixed_iK) { if (iKmin != iKmax) { if (whichDSF == 'Z') sumrule_factor = 1.0; - else if (whichDSF == 'm') + else if (whichDSF == 'm') sumrule_factor = 1.0/AveragingState.base.Mdown; else if (whichDSF == 'z') sumrule_factor = 1.0/(0.25 * AveragingState.chain.Nsites); else if (whichDSF == 'p') sumrule_factor = 1.0/(AveragingState.chain.Nsites - AveragingState.base.Mdown); @@ -175,33 +174,33 @@ namespace JSC { else if (whichDSF == 'c') sumrule_factor = 1.0; else if (whichDSF == 'q') sumrule_factor = 1.0; - else JSCerror("whichDSF option not consistent in Sumrule_Factor"); + else ABACUSerror("whichDSF option not consistent in Sumrule_Factor"); } //else if (fixed_iK) { else if (iKmin == iKmax) { if (whichDSF == 'Z') sumrule_factor = 1.0; - else if (whichDSF == 'm' || whichDSF == 'z' || whichDSF == 'p') + else if (whichDSF == 'm' || whichDSF == 'z' || whichDSF == 'p') //sumrule_factor = S1_sumrule_factor (whichDSF, AveragingState.chain.Delta, AveragingState.chain.Nsites, AveragingState.base.Mdown, iKneeded); sumrule_factor = S1_sumrule_factor (whichDSF, AveragingState.chain.Delta, AveragingState.chain.Nsites, AveragingState.base.Mdown, Chem_Pot, iKmax); else if (whichDSF == 'a') sumrule_factor = 1.0; else if (whichDSF == 'b') sumrule_factor = 1.0; else if (whichDSF == 'c') sumrule_factor = 1.0; else if (whichDSF == 'q') sumrule_factor = 1.0; - - else JSCerror("whichDSF option not consistent in Sumrule_Factor"); + + else ABACUSerror("whichDSF option not consistent in Sumrule_Factor"); } - + return(sumrule_factor); } - + void Evaluate_F_Sumrule (string prefix, char whichDSF, const Heis_Bethe_State& AveragingState, DP Chem_Pot, int iKmin_ref, int iKmax_ref) { stringstream RAW_stringstream; string RAW_string; - RAW_stringstream << prefix << ".raw"; + RAW_stringstream << prefix << ".raw"; RAW_string = RAW_stringstream.str(); const char* RAW_Cstr = RAW_string.c_str(); stringstream FSR_stringstream; string FSR_string; @@ -210,15 +209,15 @@ namespace JSC { ifstream infile; infile.open(RAW_Cstr); - if(infile.fail()) JSCerror("Could not open raw input file in Evaluate_F_Sumrule(Heis...)."); + if(infile.fail()) ABACUSerror("Could not open raw input file in Evaluate_F_Sumrule(Heis...)."); int iKmin = 0; int iKmax = AveragingState.chain.Nsites; int iKmod = AveragingState.chain.Nsites; // We run through the data file to chech the f sumrule at each positive momenta: - //Vect Sum_omega_MEsq(0.0, iKmax - iKmin + 1); - Vect Sum_omega_MEsq(0.0, iKmax - iKmin + 1); + //Vect Sum_omega_MEsq(0.0, iKmax - iKmin + 1); + Vect Sum_omega_MEsq(0.0, iKmax - iKmin + 1); DP omega, ME; int iK, iKexc; @@ -252,4 +251,4 @@ namespace JSC { outfile.close(); } -} // namespace JSC +} // namespace ABACUS diff --git a/src/HEIS/M_vs_H.cc b/src/HEIS/M_vs_H.cc index b23979a..72f7bda 100644 --- a/src/HEIS/M_vs_H.cc +++ b/src/HEIS/M_vs_H.cc @@ -1,8 +1,8 @@ /********************************************************** -This software is part of J.-S. Caux's ABACUS++ library. +This software is part of J.-S. Caux's ABACUS library. -Copyright (c) 2006-9. +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -10,21 +10,20 @@ File: M_vs_H.cc Purpose: field to and from magnetization for Heisenberg -Last modified: 21/10/09 - - ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" -namespace JSC { +using namespace std; + +namespace ABACUS { DP Ezero (DP Delta, int N, int M) { // Returns the energy of the ground state with M down spins - if (M < 0 || M > N/2) JSCerror("M out of bounds in Ezero."); - + if (M < 0 || M > N/2) ABACUSerror("M out of bounds in Ezero."); + DP E = -1.0; // sentinel value if (M == 0) E = N * Delta/4.0; @@ -32,32 +31,32 @@ namespace JSC { else { Heis_Chain BD1(1.0, Delta, 0.0, N); - + Vect_INT Nrapidities_groundstate(0, BD1.Nstrings); - + Nrapidities_groundstate[0] = M; - + Heis_Base baseconfig_groundstate(BD1, Nrapidities_groundstate); - + if ((Delta > 0.0) && (Delta < 1.0)) { XXZ_Bethe_State groundstate(BD1, baseconfig_groundstate); groundstate.Compute_All(true); E = groundstate.E; } - + else if (Delta == 1.0) { XXX_Bethe_State groundstate(BD1, baseconfig_groundstate); groundstate.Compute_All(true); E = groundstate.E; } - + else if (Delta > 1.0) { XXZ_gpd_Bethe_State groundstate(BD1, baseconfig_groundstate); groundstate.Compute_All(true); E = groundstate.E; } - - else JSCerror("Anisotropy out of bounds in Ezero."); + + else ABACUSerror("Anisotropy out of bounds in Ezero."); } return(E); @@ -69,7 +68,7 @@ namespace JSC { DP H = 0.0; - if (2*M == N) H = 0.0; + if (2*M == N) H = 0.0; else if (Delta <= 1.0) H = Ezero (Delta, N, M - 1) - Ezero (Delta, N, M); @@ -80,7 +79,7 @@ namespace JSC { { if (M < 0 || M > N/2 - 1) { cout << "M = " << M << endl; - JSCerror("M out of bounds in HZmin."); + ABACUSerror("M out of bounds in HZmin."); } if (Ezero_ref[M] == -1.0) Ezero_ref[M] = Ezero(Delta, N, M); @@ -93,7 +92,7 @@ namespace JSC { { // Returns the value of M for given field HZ - if (HZ < 0.0) JSCerror("Please use a positive field in M_vs_H."); + if (HZ < 0.0) ABACUSerror("Please use a positive field in M_vs_H."); else if (HZ == 0.0) return(N/2); @@ -111,7 +110,7 @@ namespace JSC { if (HZ >= 1.0 + Delta) M_actual = 0; // saturation else { - + HZmin_actual = HZmin (Delta, N, M_actual, Ezero); HZmax_actual = HZmin (Delta, N, M_actual - 1, Ezero); @@ -119,15 +118,15 @@ namespace JSC { if (HZmin_actual > HZ) M_actual += M_step; else if (HZmax_actual <= HZ) M_actual -= M_step; - + M_step = (M_step + 1)/2; HZmin_actual = HZmin (Delta, N, M_actual, Ezero); HZmax_actual = HZmin (Delta, N, M_actual - 1, Ezero); - M_found = (HZmin_actual < HZ && HZ <= HZmax_actual); + M_found = (HZmin_actual < HZ && HZ <= HZmax_actual); - //cout << "M_actual = " << M_actual << "\tM_step = " << M_step + //cout << "M_actual = " << M_actual << "\tM_step = " << M_step // << "\tHZmin_actual = " << HZmin_actual << "\tHZmax_actual = " << HZmax_actual << "\tHZ = " << HZ << "\t" << M_found << endl; } } diff --git a/src/HEIS/XXX_Bethe_State.cc b/src/HEIS/XXX_Bethe_State.cc index b829c7e..32c3ae2 100644 --- a/src/HEIS/XXX_Bethe_State.cc +++ b/src/HEIS/XXX_Bethe_State.cc @@ -1,6 +1,6 @@ /********************************************************** -This software is part of J.-S. Caux's ABACUS++ library. +This software is part of J.-S. Caux's ABACUS library. Copyright (c) @@ -12,11 +12,11 @@ Purpose: Defines all functions for XXX_Bethe_State ******************************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -namespace JSC { +namespace ABACUS { // Function prototypes @@ -27,7 +27,7 @@ namespace JSC { // Function definitions: class XXX_Bethe_State - XXX_Bethe_State::XXX_Bethe_State () + XXX_Bethe_State::XXX_Bethe_State () : Heis_Bethe_State() {}; @@ -35,22 +35,22 @@ namespace JSC { : Heis_Bethe_State(RefState) { } - - XXX_Bethe_State::XXX_Bethe_State (const Heis_Chain& RefChain, int M) + + XXX_Bethe_State::XXX_Bethe_State (const Heis_Chain& RefChain, int M) : Heis_Bethe_State(RefChain, M) { if (RefChain.Delta != 1.0) { cout << setprecision(16) << RefChain.Delta << endl; - JSCerror("Delta != 1.0 in XXX_Bethe_State constructor"); + ABACUSerror("Delta != 1.0 in XXX_Bethe_State constructor"); } } - - XXX_Bethe_State::XXX_Bethe_State (const Heis_Chain& RefChain, const Heis_Base& RefBase) + + XXX_Bethe_State::XXX_Bethe_State (const Heis_Chain& RefChain, const Heis_Base& RefBase) : Heis_Bethe_State(RefChain, RefBase) { if (RefChain.Delta != 1.0) { cout << setprecision(16) << RefChain.Delta << endl; - JSCerror("Delta != 1.0 in XXX_Bethe_State constructor"); + ABACUSerror("Delta != 1.0 in XXX_Bethe_State constructor"); } } /* @@ -59,7 +59,7 @@ namespace JSC { { if (RefChain.Delta != 1.0) { cout << setprecision(16) << RefChain.Delta << endl; - JSCerror("Delta != 1.0 in XXX_Bethe_State constructor"); + ABACUSerror("Delta != 1.0 in XXX_Bethe_State constructor"); } } */ @@ -104,13 +104,13 @@ namespace JSC { } } - + return; } bool XXX_Bethe_State::Check_Admissibility(char option) { - // This function checks the admissibility of the Ix2's of a state: + // This function checks the admissibility of the Ix2's of a state: // returns false if there are higher strings with Ix2 = 0, a totally symmetric distribution of I's at each level, // and strings of equal length modulo 2 and parity with Ix2 = 0, meaning at least two equal roots in BAE. @@ -122,9 +122,9 @@ namespace JSC { for (int j = 0; j < chain.Nstrings; ++j) { // The following line puts answer to true if there is at least one higher string with zero Ix2 - for (int alpha = 0; alpha < base[j]; ++alpha) if ((Ix2[j][alpha] == 0) && (chain.Str_L[j] > 2) && !(chain.Str_L[j] % 2)) - higher_string_on_zero = true; - for (int alpha = 0; alpha < base[j]; ++alpha) if (Ix2[j][alpha] == 0) Zero_at_level[j] = true; + for (int alpha = 0; alpha < base[j]; ++alpha) if ((Ix2[j][alpha] == 0) && (chain.Str_L[j] > 2) && !(chain.Str_L[j] % 2)) + higher_string_on_zero = true; + for (int alpha = 0; alpha < base[j]; ++alpha) if (Ix2[j][alpha] == 0) Zero_at_level[j] = true; // NOTE: if base[j] == 0, Zero_at_level[j] remains false. } @@ -134,7 +134,7 @@ namespace JSC { // Checks that we have strings of equal length modulo 2 with Ix2 == 0, so equal rapidities, and inadmissibility for (int j1 = 0; j1 < chain.Nstrings; ++j1) { for (int j2 = j1 + 1; j2 < chain.Nstrings; ++j2) - if (Zero_at_level[j1] && Zero_at_level[j2] && (!((chain.Str_L[j1] + chain.Str_L[j2])%2))) + if (Zero_at_level[j1] && Zero_at_level[j2] && (!((chain.Str_L[j1] + chain.Str_L[j2])%2))) string_coincidence = true; } /* @@ -147,8 +147,8 @@ namespace JSC { // Now check that no Ix2 is equal to +N (since we take -N into account, and I + N == I by periodicity of exp) - for (int j = 0; j < chain.Nstrings; ++j) - for (int alpha = 0; alpha < base[j]; ++alpha) if ((Ix2[j][alpha] < -chain.Nsites) || (Ix2[j][alpha] >= chain.Nsites)) answer = false; + for (int j = 0; j < chain.Nstrings; ++j) + for (int alpha = 0; alpha < base[j]; ++alpha) if ((Ix2[j][alpha] < -chain.Nsites) || (Ix2[j][alpha] >= chain.Nsites)) answer = false; if (!answer) { E = 0.0; @@ -170,15 +170,15 @@ namespace JSC { sumtheta = 0.0; for (int k = 0; k < chain.Nstrings; ++k) { - for (int beta = 0; beta < base[k]; ++beta) - - if ((chain.Str_L[j] == 1) && (chain.Str_L[k] == 1)) - sumtheta += atan(lambda[j][alpha] - lambda[k][beta]); - + for (int beta = 0; beta < base[k]; ++beta) + + if ((chain.Str_L[j] == 1) && (chain.Str_L[k] == 1)) + sumtheta += atan(lambda[j][alpha] - lambda[k][beta]); + else sumtheta += 0.5 * Theta_XXX((lambda[j][alpha] - lambda[k][beta]), chain.Str_L[j], chain.Str_L[k]); } sumtheta *= 2.0; - + BE[j][alpha] = 2.0 * atan(2.0 * lambda[j][alpha]/chain.Str_L[j]) - (sumtheta + PI*Ix2[j][alpha])/chain.Nsites; } @@ -190,18 +190,18 @@ namespace JSC { for (int j = 0; j < chain.Nstrings; ++j) { for (int alpha = 0; alpha < base[j]; ++alpha) { - + sumtheta = 0.0; for (int k = 0; k < chain.Nstrings; ++k) { - for (int beta = 0; beta < base[k]; ++beta) - - if ((chain.Str_L[j] == 1) && (chain.Str_L[k] == 1)) - sumtheta += atan(lambda[j][alpha] - lambda[k][beta]); - + for (int beta = 0; beta < base[k]; ++beta) + + if ((chain.Str_L[j] == 1) && (chain.Str_L[k] == 1)) + sumtheta += atan(lambda[j][alpha] - lambda[k][beta]); + else sumtheta += 0.5 * Theta_XXX((lambda[j][alpha] - lambda[k][beta]), chain.Str_L[j], chain.Str_L[k]); } sumtheta *= 2.0; - + BE[j][alpha] = 2.0 * atan(2.0 * lambda[j][alpha]/chain.Str_L[j]) - (sumtheta + PI*Ix2[j][alpha])/chain.Nsites; } } @@ -211,7 +211,7 @@ namespace JSC { { // Returns a new iteration value for lambda[j][alpha] given BE[j][alpha] - return(0.5 * chain.Str_L[j] * tan(0.5 * + return(0.5 * chain.Str_L[j] * tan(0.5 * //(PI * Ix2[j][alpha] + sumtheta)/chain.Nsites (2.0 * atan(2.0 * lambda[j][alpha]/chain.Str_L[j]) - BE[j][alpha]) )); @@ -231,10 +231,10 @@ namespace JSC { sumtheta = 0.0; for (int k = 0; k < chain.Nstrings; ++k) { - for (int beta = 0; beta < base[k]; ++beta) + for (int beta = 0; beta < base[k]; ++beta) - if ((chain.Str_L[j] == 1) && (chain.Str_L[k] == 1)) - sumtheta += atan(lambda[j][alpha] - lambda[k][beta]); + if ((chain.Str_L[j] == 1) && (chain.Str_L[k] == 1)) + sumtheta += atan(lambda[j][alpha] - lambda[k][beta]); else sumtheta += 0.5 * Theta_XXX(lambda[j][alpha] - lambda[k][beta], chain.Str_L[j], chain.Str_L[k]); } @@ -283,10 +283,10 @@ namespace JSC { sumtheta = 0.0; for (int k = 0; k < chain.Nstrings; ++k) { - for (int beta = 0; beta < base[k]; ++beta) + for (int beta = 0; beta < base[k]; ++beta) - if ((chain.Str_L[j] == 1) && (chain.Str_L[k] == 1)) - sumtheta += atan(lambda[j][alpha] - lambda[k][beta]); + if ((chain.Str_L[j] == 1) && (chain.Str_L[k] == 1)) + sumtheta += atan(lambda[j][alpha] - lambda[k][beta]); else sumtheta += 0.5 * Theta_XXX((lambda[j][alpha] - lambda[k][beta]), chain.Str_L[j], chain.Str_L[k]); } @@ -296,7 +296,7 @@ namespace JSC { index++; } } - + (*this).Build_Reduced_Gaudin_Matrix (Gaudin); for (int i = 0; i < base.Nraptot; ++i) dlambda[i] = - RHSBAE[i]; @@ -334,7 +334,7 @@ namespace JSC { for (int j = 0; j < chain.Nstrings; ++j) for (int alpha = 0; alpha < base[j]; ++alpha) nonan *= !is_nan(lambda[j][alpha]); - + return nonan; } @@ -362,48 +362,48 @@ namespace JSC { for (int alpha = 0; alpha < (*this).base[j]; ++alpha) { ln_deltadiff = 0.0; - + for (int a = 1; a <= (*this).chain.Str_L[j]; ++a) { - + if ((*this).chain.Str_L[j] > 1) { // else the BAE are already 1 log_BAE_reg = DP((*this).chain.Nsites) * log(((*this).lambda[j][alpha] + 0.5 * II * ((*this).chain.Str_L[j] + 1.0 - 2.0 * a + 1.0)) /((*this).lambda[j][alpha] + 0.5 * II * ((*this).chain.Str_L[j] + 1.0 - 2.0 * a - 1.0))); - - for (int k = 0; k < (*this).chain.Nstrings; ++k) - for (int beta = 0; beta < (*this).base[k]; ++beta) + + for (int k = 0; k < (*this).chain.Nstrings; ++k) + for (int beta = 0; beta < (*this).base[k]; ++beta) for (int b = 1; b <= (*this).chain.Str_L[k]; ++b) { - if ((j != k) || (alpha != beta) || (a != b - 1)) + if ((j != k) || (alpha != beta) || (a != b - 1)) log_BAE_reg += log((*this).lambda[j][alpha] + 0.5 * II * ((*this).chain.Str_L[j] + 1.0 - 2.0 * a ) - ((*this).lambda[k][beta] + 0.5 * II * ((*this).chain.Str_L[k] + 1.0 - 2.0 * b ) ) - II ); - - if ((j != k) || (alpha != beta) || (a != b + 1)) + + if ((j != k) || (alpha != beta) || (a != b + 1)) log_BAE_reg -= log(((*this).lambda[j][alpha] + 0.5 * II * ((*this).chain.Str_L[j] + 1.0 - 2.0 * a ) - ) + ) - ((*this).lambda[k][beta] + 0.5 * II * ((*this).chain.Str_L[k] + 1.0 - 2.0 * b ) ) + II ); } // The regular LHS of BAE is now defined. Now sum up the deltas... - + if (a == 1) ln_deltadiff[0] = - real(log_BAE_reg); - + else if (a < (*this).chain.Str_L[j]) ln_deltadiff[a - 1] = ln_deltadiff[a-2] - real(log_BAE_reg); - + else if (a == (*this).chain.Str_L[j]) ln_deltadiff[a-1] = real(log_BAE_reg); } // if ((*this).chain.Str_L[j] > 1) - + } // for (int a = 1; ... for (int a = 0; a < (*this).chain.Str_L[j]; ++a) { deltadiff[a] = ln_deltadiff[a] != 0.0 ? exp(ln_deltadiff[a]) : 0.0; delta += fabs(deltadiff[a]); - } - + } + } // alpha sum } // j sum @@ -418,7 +418,7 @@ namespace JSC { void XXX_Bethe_State::Compute_Energy () { DP sum = 0.0; - + for (int j = 0; j < chain.Nstrings; ++j) { for (int alpha = 0; alpha < base[j]; ++alpha) { sum += chain.Str_L[j] / ( 4.0 * lambda[j][alpha] * lambda[j][alpha] + chain.Str_L[j] * chain.Str_L[j]); @@ -426,7 +426,7 @@ namespace JSC { } sum *= - chain.J * 2.0; - + E = sum; return; @@ -462,7 +462,7 @@ namespace JSC { void XXX_Bethe_State::Build_Reduced_Gaudin_Matrix (SQMat >& Gaudin_Red) { - if (Gaudin_Red.size() != base.Nraptot) JSCerror("Passing matrix of wrong size in Build_Reduced_Gaudin_Matrix."); + if (Gaudin_Red.size() != base.Nraptot) ABACUSerror("Passing matrix of wrong size in Build_Reduced_Gaudin_Matrix."); int index_jalpha; int index_kbeta; @@ -482,24 +482,24 @@ namespace JSC { for (int kp = 0; kp < chain.Nstrings; ++kp) { for (int betap = 0; betap < base[kp]; ++betap) { - if (!((j == kp) && (alpha == betap))) - sum_hbar_XXX + if (!((j == kp) && (alpha == betap))) + sum_hbar_XXX += ddlambda_Theta_XXX (lambda[j][alpha] - lambda[kp][betap], chain.Str_L[j], chain.Str_L[kp]); } } - Gaudin_Red[index_jalpha][index_kbeta] - = complex ( chain.Nsites * chain.Str_L[j]/(lambda[j][alpha] * lambda[j][alpha] + 0.25 * chain.Str_L[j] * chain.Str_L[j]) + Gaudin_Red[index_jalpha][index_kbeta] + = complex ( chain.Nsites * chain.Str_L[j]/(lambda[j][alpha] * lambda[j][alpha] + 0.25 * chain.Str_L[j] * chain.Str_L[j]) - sum_hbar_XXX); } else { - if ((chain.Str_L[j] == 1) && (chain.Str_L[k] == 1)) - Gaudin_Red[index_jalpha][index_kbeta] = + if ((chain.Str_L[j] == 1) && (chain.Str_L[k] == 1)) + Gaudin_Red[index_jalpha][index_kbeta] = complex ( 2.0/(pow(lambda[j][alpha] - lambda[k][beta], 2.0) + 1.0)); - else - Gaudin_Red[index_jalpha][index_kbeta] = + else + Gaudin_Red[index_jalpha][index_kbeta] = complex (ddlambda_Theta_XXX (lambda[j][alpha] - lambda[k][beta], chain.Str_L[j], chain.Str_L[k])); } index_kbeta++; @@ -520,7 +520,7 @@ namespace JSC { if (fabs(lambda[j][alpha]) > 1.0e6) answer = false; } } - + return(answer); } @@ -533,12 +533,12 @@ namespace JSC { DP result; if ((nj == 1) && (nk == 1)) result = 2.0 * atan(lambda); - + else { result = (nj == nk) ? 0.0 : 2.0 * atan(2.0 * lambda/fabs(nj - nk)); - for (int a = 1; a < JSC::min(nj, nk); ++a) result += 4.0 * atan(2.0 * lambda/(fabs(nj - nk) + 2*a)); + for (int a = 1; a < ABACUS::min(nj, nk); ++a) result += 4.0 * atan(2.0 * lambda/(fabs(nj - nk) + 2*a)); result += 2.0 * atan(2.0 * lambda/(nj + nk)); } @@ -552,7 +552,7 @@ namespace JSC { DP result = (nj == nk) ? 0.0 : DP(n)/(lambda * lambda + 0.25 * n * n); - for (int a = 1; a < JSC::min(nj, nk); ++a) result += 2.0 * (n + 2.0*a) + for (int a = 1; a < ABACUS::min(nj, nk); ++a) result += 2.0 * (n + 2.0*a) / (lambda * lambda + 0.25 * (n + 2.0*a) * (n + 2.0*a)); result += DP(nj + nk)/(lambda * lambda + 0.25 * (nj + nk) * (nj + nk)); @@ -564,7 +564,7 @@ namespace JSC { { DP result = (nj == nk) ? 0.0 : DP(nj - nk)/(lambda * lambda + 0.25 * (nj - nk) * (nj - nk)); - for (int a = 1; a < JSC::min(nj, nk); ++a) result += 2.0 * (nj - nk + 2.0*a) * (nj - nk + 2.0*a) + for (int a = 1; a < ABACUS::min(nj, nk); ++a) result += 2.0 * (nj - nk + 2.0*a) * (nj - nk + 2.0*a) / (lambda * lambda + 0.25 * (nj - nk + 2.0*a) * (nj - nk + 2.0*a)); result += DP(nj + nk)/(lambda * lambda + 0.25 * (nj + nk) * (nj + nk)); @@ -575,8 +575,8 @@ namespace JSC { XXX_Bethe_State Add_Particle_at_Center (const XXX_Bethe_State& RefState) { - if (2*RefState.base.Mdown == RefState.chain.Nsites) - JSCerror("Trying to add a down spin to a zero-magnetized chain in Add_Particle_at_Center."); + if (2*RefState.base.Mdown == RefState.chain.Nsites) + ABACUSerror("Trying to add a down spin to a zero-magnetized chain in Add_Particle_at_Center."); Vect newM = RefState.base.Nrap; newM[0] = newM[0] + 1; @@ -586,10 +586,10 @@ namespace JSC { XXX_Bethe_State ReturnState (RefState.chain, newBase); for (int il = 1; il < RefState.chain.Nstrings; ++il) - for (int alpha = 0; alpha < RefState.base.Nrap[il]; ++alpha) + for (int alpha = 0; alpha < RefState.base.Nrap[il]; ++alpha) ReturnState.Ix2[il][alpha] = RefState.Ix2[il][alpha]; - // Add a quantum number in middle (explicitly: to right of index M[0]/2) + // Add a quantum number in middle (explicitly: to right of index M[0]/2) // and shift quantum numbers by half-integer away from added one: ReturnState.Ix2[0][RefState.base.Nrap[0]/2] = RefState.Ix2[0][RefState.base.Nrap[0]/2] - 1; for (int i = 0; i < RefState.base.Nrap[0] + 1; ++i) @@ -602,7 +602,7 @@ namespace JSC { XXX_Bethe_State Remove_Particle_at_Center (const XXX_Bethe_State& RefState) { if (RefState.base.Nrap[0] == 0) - JSCerror("Trying to remove a down spin in an empty Nrap[0] state."); + ABACUSerror("Trying to remove a down spin in an empty Nrap[0] state."); Vect newM = RefState.base.Nrap; newM[0] = newM[0] - 1; @@ -612,7 +612,7 @@ namespace JSC { XXX_Bethe_State ReturnState (RefState.chain, newBase); for (int il = 1; il < RefState.chain.Nstrings; ++il) - for (int alpha = 0; alpha < RefState.base.Nrap[il]; ++alpha) + for (int alpha = 0; alpha < RefState.base.Nrap[il]; ++alpha) ReturnState.Ix2[il][alpha] = RefState.Ix2[il][alpha]; // Remove midmost and shift quantum numbers by half-integer towards removed one: @@ -622,5 +622,5 @@ namespace JSC { return(ReturnState); } - -} // namespace JSC + +} // namespace ABACUS diff --git a/src/HEIS/XXZ_Bethe_State.cc b/src/HEIS/XXZ_Bethe_State.cc index 78b0ad4..18531eb 100644 --- a/src/HEIS/XXZ_Bethe_State.cc +++ b/src/HEIS/XXZ_Bethe_State.cc @@ -1,6 +1,6 @@ /********************************************************** -This software is part of J.-S. Caux's ABACUS++ library. +This software is part of J.-S. Caux's ABACUS library. Copyright (c) @@ -12,11 +12,11 @@ Purpose: Defines all functions for XXZ_Bethe_State ******************************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -namespace JSC { +namespace ABACUS { // Function prototypes @@ -30,12 +30,12 @@ namespace JSC { // Function definitions: class XXZ_Bethe_State - XXZ_Bethe_State::XXZ_Bethe_State () - : Heis_Bethe_State(), sinhlambda(Lambda(chain, 1)), coshlambda(Lambda(chain, 1)), tanhlambda(Lambda(chain, 1)) + XXZ_Bethe_State::XXZ_Bethe_State () + : Heis_Bethe_State(), sinhlambda(Lambda(chain, 1)), coshlambda(Lambda(chain, 1)), tanhlambda(Lambda(chain, 1)) {}; XXZ_Bethe_State::XXZ_Bethe_State (const XXZ_Bethe_State& RefState) // copy constructor - : Heis_Bethe_State(RefState), sinhlambda(Lambda(RefState.chain, RefState.base)), coshlambda(Lambda(RefState.chain, RefState.base)), + : Heis_Bethe_State(RefState), sinhlambda(Lambda(RefState.chain, RefState.base)), coshlambda(Lambda(RefState.chain, RefState.base)), tanhlambda(Lambda(RefState.chain, RefState.base)) { // copy arrays into new ones @@ -50,29 +50,29 @@ namespace JSC { } //cout << "Done calling XXZ state copy constructor." << endl; } - - XXZ_Bethe_State::XXZ_Bethe_State (const Heis_Chain& RefChain, int M) - : Heis_Bethe_State(RefChain, M), + + XXZ_Bethe_State::XXZ_Bethe_State (const Heis_Chain& RefChain, int M) + : Heis_Bethe_State(RefChain, M), sinhlambda(Lambda(RefChain, M)), coshlambda(Lambda(RefChain, M)), tanhlambda(Lambda(RefChain, M)) { //cout << "Here in XXZ BS constructor." << endl; //cout << (*this).lambda[0][0] << endl; //cout << "OK" << endl; - if ((RefChain.Delta <= -1.0) || (RefChain.Delta >= 1.0)) JSCerror("Delta out of range in XXZ_Bethe_State constructor"); + if ((RefChain.Delta <= -1.0) || (RefChain.Delta >= 1.0)) ABACUSerror("Delta out of range in XXZ_Bethe_State constructor"); } - - XXZ_Bethe_State::XXZ_Bethe_State (const Heis_Chain& RefChain, const Heis_Base& RefBase) - : Heis_Bethe_State(RefChain, RefBase), + + XXZ_Bethe_State::XXZ_Bethe_State (const Heis_Chain& RefChain, const Heis_Base& RefBase) + : Heis_Bethe_State(RefChain, RefBase), sinhlambda(Lambda(RefChain, RefBase)), coshlambda(Lambda(RefChain, RefBase)), tanhlambda(Lambda(RefChain, RefBase)) { - if ((RefChain.Delta <= -1.0) || (RefChain.Delta >= 1.0)) JSCerror("Delta out of range in XXZ_Bethe_State constructor"); + if ((RefChain.Delta <= -1.0) || (RefChain.Delta >= 1.0)) ABACUSerror("Delta out of range in XXZ_Bethe_State constructor"); } /* XXZ_Bethe_State::XXZ_Bethe_State (const Heis_Chain& RefChain, long long int base_id_ref, long long int type_id_ref) : Heis_Bethe_State(RefChain, base_id_ref, type_id_ref), sinhlambda(Lambda(chain, base)), coshlambda(Lambda(chain, base)), tanhlambda(Lambda(chain, base)) { - if ((RefChain.Delta <= -1.0) || (RefChain.Delta >= 1.0)) JSCerror("Delta out of range in XXZ_Bethe_State constructor"); + if ((RefChain.Delta <= -1.0) || (RefChain.Delta >= 1.0)) ABACUSerror("Delta out of range in XXZ_Bethe_State constructor"); } */ @@ -130,13 +130,13 @@ namespace JSC { lambda[i][alpha] = atanh(x/sqrt(1.0 + x*x)); // lambda then always initiated real } - else JSCerror("Invalid parities in Set_Free_lambdas."); + else ABACUSerror("Invalid parities in Set_Free_lambdas."); //cout << tan(chain.Str_L[i] * 0.5 * chain.anis) << endl; //cout << "Set_Free_lambdas: " << i << "\t" << alpha << "\t" << lambda[i][alpha] << "\t" << tan(chain.Str_L[i] * 0.5 * chain.anis) * tan(PI * 0.5 * Ix2[i][alpha]/chain.Nsites) << endl; } } - + return; } @@ -169,7 +169,7 @@ namespace JSC { bool XXZ_Bethe_State::Check_Admissibility(char option) { - // This function checks the admissibility of the Ix2's of a state: + // This function checks the admissibility of the Ix2's of a state: // returns false if there are higher strings with Ix2 = 0, a totally symmetric distribution of I's at each level, // and strings of equal length modulo 2 and parity with Ix2 = 0, meaning at least two equal roots in BAE. @@ -179,9 +179,9 @@ namespace JSC { bool higher_string_on_zero = false; for (int j = 0; j < chain.Nstrings; ++j) { // The following line puts answer to true if there is at least one higher string with zero Ix2 - for (int alpha = 0; alpha < base[j]; ++alpha) if ((Ix2[j][alpha] == 0) && (chain.Str_L[j] >= 2) /*&& !(chain.Str_L[j] % 2)*/) - higher_string_on_zero = true; - for (int alpha = 0; alpha < base[j]; ++alpha) if (Ix2[j][alpha] == 0) Zero_at_level[j] = true; + for (int alpha = 0; alpha < base[j]; ++alpha) if ((Ix2[j][alpha] == 0) && (chain.Str_L[j] >= 2) /*&& !(chain.Str_L[j] % 2)*/) + higher_string_on_zero = true; + for (int alpha = 0; alpha < base[j]; ++alpha) if (Ix2[j][alpha] == 0) Zero_at_level[j] = true; // NOTE: if base[j] == 0, Zero_at_level[j] remains false. } @@ -192,12 +192,12 @@ namespace JSC { bool string_coincidence = false; for (int j1 = 0; j1 < chain.Nstrings; ++j1) { for (int j2 = j1 + 1; j2 < chain.Nstrings; ++j2) - if (Zero_at_level[j1] && Zero_at_level[j2] && (chain.par[j1] == chain.par[j2]) && (!((chain.Str_L[j1] + chain.Str_L[j2])%2))) + if (Zero_at_level[j1] && Zero_at_level[j2] && (chain.par[j1] == chain.par[j2]) && (!((chain.Str_L[j1] + chain.Str_L[j2])%2))) string_coincidence = true; } bool M_odd_and_onep_on_zero = false; - if (option == 'z') { // for Sz, if M is odd, exclude symmetric states with a 1+ on zero + if (option == 'z') { // for Sz, if M is odd, exclude symmetric states with a 1+ on zero // (zero rapidities in left and right states, so FF det not defined). bool is_ground_state = base.Nrap[0] == base.Mdown && Ix2[0][0] == -(base.Mdown - 1) && Ix2[0][base.Mdown-1] == base.Mdown - 1; if (Zero_at_level[0] && (base.Mdown % 2) && !is_ground_state) M_odd_and_onep_on_zero = true; @@ -212,8 +212,8 @@ namespace JSC { // Now check that no Ix2 is equal to +N (since we take -N into account, and I + N == I by periodicity of exp) - for (int j = 0; j < chain.Nstrings; ++j) - for (int alpha = 0; alpha < base[j]; ++alpha) if ((Ix2[j][alpha] < -chain.Nsites) || (Ix2[j][alpha] >= chain.Nsites)) answer = false; + for (int j = 0; j < chain.Nstrings; ++j) + for (int alpha = 0; alpha < base[j]; ++alpha) if ((Ix2[j][alpha] < -chain.Nsites) || (Ix2[j][alpha] >= chain.Nsites)) answer = false; if (!answer) { E = 0.0; @@ -233,18 +233,18 @@ namespace JSC { DP sumtheta = 0.0; - for (int k = 0; k < chain.Nstrings; ++k) + for (int k = 0; k < chain.Nstrings; ++k) for (int beta = 0; beta < base[k]; ++beta) { - if ((chain.Str_L[j] == 1) && (chain.Str_L[k] == 1)) - sumtheta += (chain.par[j] == chain.par[k]) - ? atan((tanhlambda[j][alpha] - tanhlambda[k][beta])/((1.0 - tanhlambda[j][alpha] * tanhlambda[k][beta]) * chain.ta_n_anis_over_2[2])) - : - atan(((tanhlambda[j][alpha] - tanhlambda[k][beta])/(1.0 - tanhlambda[j][alpha] * tanhlambda[k][beta])) * chain.ta_n_anis_over_2[2]) ; - else sumtheta += 0.5 * Theta_XXZ((tanhlambda[j][alpha] - tanhlambda[k][beta])/(1.0 - tanhlambda[j][alpha] * tanhlambda[k][beta]), + if ((chain.Str_L[j] == 1) && (chain.Str_L[k] == 1)) + sumtheta += (chain.par[j] == chain.par[k]) + ? atan((tanhlambda[j][alpha] - tanhlambda[k][beta])/((1.0 - tanhlambda[j][alpha] * tanhlambda[k][beta]) * chain.ta_n_anis_over_2[2])) + : - atan(((tanhlambda[j][alpha] - tanhlambda[k][beta])/(1.0 - tanhlambda[j][alpha] * tanhlambda[k][beta])) * chain.ta_n_anis_over_2[2]) ; + else sumtheta += 0.5 * Theta_XXZ((tanhlambda[j][alpha] - tanhlambda[k][beta])/(1.0 - tanhlambda[j][alpha] * tanhlambda[k][beta]), chain.Str_L[j], chain.Str_L[k], chain.par[j], chain.par[k], chain.ta_n_anis_over_2); } sumtheta *= 2.0; - - BE[j][alpha] = ((chain.par[j] == 1) ? 2.0 * atan(tanhlambda[j][alpha]/chain.ta_n_anis_over_2[chain.Str_L[j]]) + + BE[j][alpha] = ((chain.par[j] == 1) ? 2.0 * atan(tanhlambda[j][alpha]/chain.ta_n_anis_over_2[chain.Str_L[j]]) : -2.0 * atan(tanhlambda[j][alpha] * chain.ta_n_anis_over_2[chain.Str_L[j]])) - (sumtheta + PI*Ix2[j][alpha])/chain.Nsites; } @@ -257,22 +257,22 @@ namespace JSC { DP sumtheta = 0.0; - for (int j = 0; j < chain.Nstrings; ++j) + for (int j = 0; j < chain.Nstrings; ++j) for (int alpha = 0; alpha < base[j]; ++alpha) { - + sumtheta = 0.0; - for (int k = 0; k < chain.Nstrings; ++k) + for (int k = 0; k < chain.Nstrings; ++k) for (int beta = 0; beta < base[k]; ++beta) { - if ((chain.Str_L[j] == 1) && (chain.Str_L[k] == 1)) - sumtheta += (chain.par[j] == chain.par[k]) - ? atan((tanhlambda[j][alpha] - tanhlambda[k][beta])/((1.0 - tanhlambda[j][alpha] * tanhlambda[k][beta]) * chain.ta_n_anis_over_2[2])) - : - atan(((tanhlambda[j][alpha] - tanhlambda[k][beta])/(1.0 - tanhlambda[j][alpha] * tanhlambda[k][beta])) * chain.ta_n_anis_over_2[2]) ; - else sumtheta += 0.5 * Theta_XXZ((tanhlambda[j][alpha] - tanhlambda[k][beta])/(1.0 - tanhlambda[j][alpha] * tanhlambda[k][beta]), + if ((chain.Str_L[j] == 1) && (chain.Str_L[k] == 1)) + sumtheta += (chain.par[j] == chain.par[k]) + ? atan((tanhlambda[j][alpha] - tanhlambda[k][beta])/((1.0 - tanhlambda[j][alpha] * tanhlambda[k][beta]) * chain.ta_n_anis_over_2[2])) + : - atan(((tanhlambda[j][alpha] - tanhlambda[k][beta])/(1.0 - tanhlambda[j][alpha] * tanhlambda[k][beta])) * chain.ta_n_anis_over_2[2]) ; + else sumtheta += 0.5 * Theta_XXZ((tanhlambda[j][alpha] - tanhlambda[k][beta])/(1.0 - tanhlambda[j][alpha] * tanhlambda[k][beta]), chain.Str_L[j], chain.Str_L[k], chain.par[j], chain.par[k], chain.ta_n_anis_over_2); } sumtheta *= 2.0; - - BE[j][alpha] = ((chain.par[j] == 1) ? 2.0 * atan(tanhlambda[j][alpha]/chain.ta_n_anis_over_2[chain.Str_L[j]]) + + BE[j][alpha] = ((chain.par[j] == 1) ? 2.0 * atan(tanhlambda[j][alpha]/chain.ta_n_anis_over_2[chain.Str_L[j]]) : -2.0 * atan(tanhlambda[j][alpha] * chain.ta_n_anis_over_2[chain.Str_L[j]])) - (sumtheta + PI*Ix2[j][alpha])/chain.Nsites; //if (is_nan(BE[j][alpha])) cout << "BE nan: " << j << "\t" << alpha << "\t" << lambda[j][alpha] << "\t" << tanhlambda[j][alpha] << endl; @@ -281,59 +281,59 @@ namespace JSC { DP XXZ_Bethe_State::Iterate_BAE (int j, int alpha) { - // Returns a new iteration value for lambda[j][alpha] given tanhlambda and BE Lambdas + // Returns a new iteration value for lambda[j][alpha] given tanhlambda and BE Lambdas // Assumes that tanhlambda[][] and BE[][] have been computed. DP new_lambda = 0.0; DP arg = 0.0; - if (chain.par[j] == 1) arg = chain.ta_n_anis_over_2[chain.Str_L[j]] - * tan(0.5 * + if (chain.par[j] == 1) arg = chain.ta_n_anis_over_2[chain.Str_L[j]] + * tan(0.5 * //(PI * Ix2[j][alpha] + sumtheta)/chain.Nsites (2.0 * atan(tanhlambda[j][alpha]/chain.ta_n_anis_over_2[chain.Str_L[j]]) - BE[j][alpha]) ); - - else if (chain.par[j] == -1) arg = -tan(0.5 * + + else if (chain.par[j] == -1) arg = -tan(0.5 * //(PI * Ix2[j][alpha] + sumtheta)/chain.Nsites) (-2.0 * atan(tanhlambda[j][alpha] * chain.ta_n_anis_over_2[chain.Str_L[j]]) - BE[j][alpha])) /chain.ta_n_anis_over_2[chain.Str_L[j]]; - + if (fabs(arg) < 1.0) { new_lambda = atanh(arg); } - + else { new_lambda = lambda[j][alpha]; // back to drawing board... - int block = 0; // counter to prevent runaway while loop + int block = 0; // counter to prevent runaway while loop DP new_tanhlambda = 0.0; DP sumtheta = 0.0; - arg = 10.0; // reset value to start while loop + arg = 10.0; // reset value to start while loop while ((fabs(arg) > 1.0) && (block++ < 100)) { // recompute the diverging root on its own... new_lambda *= 1.01; // try to go slowly towards infinity... new_tanhlambda = tanh(new_lambda); sumtheta = 0.0; for (int k = 0; k < chain.Nstrings; ++k) { - for (int beta = 0; beta < base[k]; ++beta) - if ((chain.Str_L[j] == 1) && (chain.Str_L[k] == 1)) - sumtheta += (chain.par[j] == chain.par[k]) - ? atan((new_tanhlambda - tanhlambda[k][beta])/((1.0 - new_tanhlambda * tanhlambda[k][beta]) * chain.ta_n_anis_over_2[2])) - : - atan(((new_tanhlambda - tanhlambda[k][beta])/(1.0 - new_tanhlambda * tanhlambda[k][beta])) * chain.ta_n_anis_over_2[2]) ; - else sumtheta += 0.5 * Theta_XXZ((new_tanhlambda - tanhlambda[k][beta])/(1.0 - new_tanhlambda * tanhlambda[k][beta]), + for (int beta = 0; beta < base[k]; ++beta) + if ((chain.Str_L[j] == 1) && (chain.Str_L[k] == 1)) + sumtheta += (chain.par[j] == chain.par[k]) + ? atan((new_tanhlambda - tanhlambda[k][beta])/((1.0 - new_tanhlambda * tanhlambda[k][beta]) * chain.ta_n_anis_over_2[2])) + : - atan(((new_tanhlambda - tanhlambda[k][beta])/(1.0 - new_tanhlambda * tanhlambda[k][beta])) * chain.ta_n_anis_over_2[2]) ; + else sumtheta += 0.5 * Theta_XXZ((new_tanhlambda - tanhlambda[k][beta])/(1.0 - new_tanhlambda * tanhlambda[k][beta]), chain.Str_L[j], chain.Str_L[k], chain.par[j], chain.par[k], chain.ta_n_anis_over_2); } sumtheta *= 2.0; if (chain.par[j] == 1) arg = chain.ta_n_anis_over_2[chain.Str_L[j]] * tan(0.5 * (PI * Ix2[j][alpha] + sumtheta)/chain.Nsites); - + else if (chain.par[j] == -1) arg = -tan(0.5 * (PI * Ix2[j][alpha] + sumtheta)/chain.Nsites)/chain.ta_n_anis_over_2[chain.Str_L[j]]; - - else JSCerror("Invalid parities in Iterate_BAE."); + + else ABACUSerror("Invalid parities in Iterate_BAE."); } - + if (fabs(arg) < 1.0) { new_lambda = atanh(arg); } - + //else cout << "Rapidity blows up !\t" << lambda[j][alpha] << "\t" << new_lambda << endl; } // else @@ -346,7 +346,7 @@ namespace JSC { for (int j = 0; j < chain.Nstrings; ++j) for (int alpha = 0; alpha < base[j]; ++alpha) nonan *= !is_nan(lambda[j][alpha]); - + return nonan; } @@ -360,8 +360,8 @@ namespace JSC { for (int i = 0; i < (*this).chain.Nstrings; ++i) if ((*this).chain.Str_L[i] > 1) occupied_strings += (*this).base.Nrap[i]; //if ((*this).conv == 0) delta = 1.0; - - if (occupied_strings == 0) delta = 0.0; + + if (occupied_strings == 0) delta = 0.0; else { @@ -369,56 +369,56 @@ namespace JSC { Vect_DP deltadiff(0.0, 1000); // contains |delta^{a, a+1}| complex log_BAE_reg = 0.0; - + for (int j = 0; j < (*this).chain.Nstrings; ++j) { for (int alpha = 0; alpha < (*this).base[j]; ++alpha) { ln_deltadiff = 0.0; - + for (int a = 1; a <= (*this).chain.Str_L[j]; ++a) { - + if ((*this).chain.Str_L[j] > 1) { // else the BAE are already 1 - log_BAE_reg = DP((*this).chain.Nsites) * log(sinh((*this).lambda[j][alpha] + log_BAE_reg = DP((*this).chain.Nsites) * log(sinh((*this).lambda[j][alpha] + 0.5 * II * (*this).chain.anis * ((*this).chain.Str_L[j] + 1.0 - 2.0 * a + 1.0) + 0.25 * II * PI * (1.0 - (*this).chain.par[j])) /sinh((*this).lambda[j][alpha] + 0.5 * II * (*this).chain.anis * ((*this).chain.Str_L[j] + 1.0 - 2.0 * a - 1.0) + 0.25 * II * PI * (1.0 - (*this).chain.par[j]))); - - for (int k = 0; k < (*this).chain.Nstrings; ++k) - for (int beta = 0; beta < (*this).base[k]; ++beta) + + for (int k = 0; k < (*this).chain.Nstrings; ++k) + for (int beta = 0; beta < (*this).base[k]; ++beta) for (int b = 1; b <= (*this).chain.Str_L[k]; ++b) { - if ((j != k) || (alpha != beta) || (a != b - 1)) + if ((j != k) || (alpha != beta) || (a != b - 1)) log_BAE_reg += log(sinh(((*this).lambda[j][alpha] + 0.5 * II * (*this).chain.anis * ((*this).chain.Str_L[j] + 1.0 - 2.0 * a ) - + 0.25 * II * PI * (1.0 - (*this).chain.par[j])) + + 0.25 * II * PI * (1.0 - (*this).chain.par[j])) - ((*this).lambda[k][beta] + 0.5 * II * (*this).chain.anis * ((*this).chain.Str_L[k] + 1.0 - 2.0 * b ) + 0.25 * II * PI * (1.0 - (*this).chain.par[k])) - II * (*this).chain.anis)); - - if ((j != k) || (alpha != beta) || (a != b + 1)) + + if ((j != k) || (alpha != beta) || (a != b + 1)) log_BAE_reg -= log(sinh(((*this).lambda[j][alpha] + 0.5 * II * (*this).chain.anis * ((*this).chain.Str_L[j] + 1.0 - 2.0 * a ) - + 0.25 * II * PI * (1.0 - (*this).chain.par[j])) + + 0.25 * II * PI * (1.0 - (*this).chain.par[j])) - ((*this).lambda[k][beta] + 0.5 * II * (*this).chain.anis * ((*this).chain.Str_L[k] + 1.0 - 2.0 * b ) + 0.25 * II * PI * (1.0 - (*this).chain.par[k])) + II * (*this).chain.anis)); } // The regular LHS of BAE is now defined. Now sum up the deltas... - + if (a == 1) ln_deltadiff[0] = - real(log_BAE_reg); - + else if (a < (*this).chain.Str_L[j]) ln_deltadiff[a - 1] = ln_deltadiff[a-2] - real(log_BAE_reg); - + else if (a == (*this).chain.Str_L[j]) ln_deltadiff[a-1] = real(log_BAE_reg); } // if ((*this).chain.Str_L[j] > 1) - + } // for (int a = 1; ... for (int a = 0; a < (*this).chain.Str_L[j]; ++a) { deltadiff[a] = ln_deltadiff[a] != 0.0 ? exp(ln_deltadiff[a]) : 0.0; delta += fabs(deltadiff[a]); - } + } } // alpha sum } // j sum @@ -434,7 +434,7 @@ namespace JSC { void XXZ_Bethe_State::Compute_Energy () { DP sum = 0.0; - + for (int j = 0; j < chain.Nstrings; ++j) { for (int alpha = 0; alpha < base[j]; ++alpha) { sum += sin(chain.Str_L[j] * chain.anis) / (chain.par[j] * cosh(2.0 * lambda[j][alpha]) - cos(chain.Str_L[j] * chain.anis)); @@ -442,7 +442,7 @@ namespace JSC { } sum *= - chain.J * sin(chain.anis); - + E = sum; return; @@ -477,7 +477,7 @@ namespace JSC { void XXZ_Bethe_State::Build_Reduced_Gaudin_Matrix (SQMat >& Gaudin_Red) { - if (Gaudin_Red.size() != base.Nraptot) JSCerror("Passing matrix of wrong size in Build_Reduced_Gaudin_Matrix."); + if (Gaudin_Red.size() != base.Nraptot) ABACUSerror("Passing matrix of wrong size in Build_Reduced_Gaudin_Matrix."); int index_jalpha; int index_kbeta; @@ -502,26 +502,26 @@ namespace JSC { for (int kp = 0; kp < chain.Nstrings; ++kp) { for (int betap = 0; betap < base[kp]; ++betap) { - if (!((j == kp) && (alpha == betap))) - sum_hbar_XXZ - += ddlambda_Theta_XXZ (lambda[j][alpha] - lambda[kp][betap], chain.Str_L[j], chain.Str_L[kp], chain.par[j], chain.par[kp], + if (!((j == kp) && (alpha == betap))) + sum_hbar_XXZ + += ddlambda_Theta_XXZ (lambda[j][alpha] - lambda[kp][betap], chain.Str_L[j], chain.Str_L[kp], chain.par[j], chain.par[kp], chain.si_n_anis_over_2); } } - Gaudin_Red[index_jalpha][index_kbeta] + Gaudin_Red[index_jalpha][index_kbeta] = complex ( chain.Nsites * hbar_XXZ (lambda[j][alpha], chain.Str_L[j], chain.par[j], chain.si_n_anis_over_2) - sum_hbar_XXZ); } else { - if ((chain.Str_L[j] == 1) && (chain.Str_L[k] == 1)) - Gaudin_Red[index_jalpha][index_kbeta] = - complex ((chain.par[j] * chain.par[k] == 1) - ? chain.si_n_anis_over_2[4]/(pow(sinhlambda[j][alpha] * coshlambda[k][beta] + if ((chain.Str_L[j] == 1) && (chain.Str_L[k] == 1)) + Gaudin_Red[index_jalpha][index_kbeta] = + complex ((chain.par[j] * chain.par[k] == 1) + ? chain.si_n_anis_over_2[4]/(pow(sinhlambda[j][alpha] * coshlambda[k][beta] - coshlambda[j][alpha] * sinhlambda[k][beta], 2.0) + sinzetasq) - : chain.si_n_anis_over_2[4]/(-pow(coshlambda[j][alpha] * coshlambda[k][beta] + : chain.si_n_anis_over_2[4]/(-pow(coshlambda[j][alpha] * coshlambda[k][beta] - sinhlambda[j][alpha] * sinhlambda[k][beta], 2.0) + sinzetasq) ); - else + else Gaudin_Red[index_jalpha][index_kbeta] = complex (ddlambda_Theta_XXZ (lambda[j][alpha] - lambda[k][beta], chain.Str_L[j], chain.Str_L[k], chain.par[j], chain.par[k], chain.si_n_anis_over_2)); } @@ -546,7 +546,7 @@ namespace JSC { else if (par == -1) result = -2.0 * atan(tanhlambda * tannzetaover2); - else JSCerror("Faulty parity in fbar_XXZ."); + else ABACUSerror("Faulty parity in fbar_XXZ."); return (result); } @@ -556,12 +556,12 @@ namespace JSC { DP result = 0.0; if ((nj == 1) && (nk == 1)) result = fbar_XXZ(tanhlambda, parj*park, tannzetaover2[2]); - + else { result = (nj == nk) ? 0.0 : fbar_XXZ(tanhlambda, parj*park, tannzetaover2[fabs(nj - nk)]); - for (int a = 1; a < JSC::min(nj, nk); ++a) result += 2.0 * fbar_XXZ(tanhlambda, parj*park, tannzetaover2[fabs(nj - nk) + 2*a]); + for (int a = 1; a < ABACUS::min(nj, nk); ++a) result += 2.0 * fbar_XXZ(tanhlambda, parj*park, tannzetaover2[fabs(nj - nk) + 2*a]); result += fbar_XXZ(tanhlambda, parj*park, tannzetaover2[nj + nk]); } @@ -577,16 +577,16 @@ namespace JSC { else if (par == -1) result = si_n_anis_over_2[2*n]/(-pow(cosh(lambda), 2.0) + pow(si_n_anis_over_2[n], 2.0)); - else JSCerror("Faulty parity in hbar_XXZ."); + else ABACUSerror("Faulty parity in hbar_XXZ."); return (result); } - + DP ddlambda_Theta_XXZ (DP lambda, int nj, int nk, int parj, int park, DP* si_n_anis_over_2) { DP result = (nj == nk) ? 0.0 : hbar_XXZ(lambda, fabs(nj - nk), parj*park, si_n_anis_over_2); - for (int a = 1; a < JSC::min(nj, nk); ++a) result += 2.0 * hbar_XXZ(lambda, fabs(nj - nk) + 2*a, parj*park, si_n_anis_over_2); + for (int a = 1; a < ABACUS::min(nj, nk); ++a) result += 2.0 * hbar_XXZ(lambda, fabs(nj - nk) + 2*a, parj*park, si_n_anis_over_2); result += hbar_XXZ(lambda, nj + nk, parj*park, si_n_anis_over_2); @@ -596,8 +596,8 @@ namespace JSC { XXZ_Bethe_State Add_Particle_at_Center (const XXZ_Bethe_State& RefState) { - if (2*RefState.base.Mdown == RefState.chain.Nsites) - JSCerror("Trying to add a down spin to a zero-magnetized chain in Add_Particle_at_Center."); + if (2*RefState.base.Mdown == RefState.chain.Nsites) + ABACUSerror("Trying to add a down spin to a zero-magnetized chain in Add_Particle_at_Center."); Vect newM = RefState.base.Nrap; newM[0] = newM[0] + 1; @@ -607,10 +607,10 @@ namespace JSC { XXZ_Bethe_State ReturnState (RefState.chain, newBase); for (int il = 1; il < RefState.chain.Nstrings; ++il) - for (int alpha = 0; alpha < RefState.base.Nrap[il]; ++alpha) + for (int alpha = 0; alpha < RefState.base.Nrap[il]; ++alpha) ReturnState.Ix2[il][alpha] = RefState.Ix2[il][alpha]; - // Add a quantum number in middle (explicitly: to right of index M[0]/2) + // Add a quantum number in middle (explicitly: to right of index M[0]/2) // and shift quantum numbers by half-integer away from added one: ReturnState.Ix2[0][RefState.base.Nrap[0]/2] = RefState.Ix2[0][RefState.base.Nrap[0]/2] - 1; for (int i = 0; i < RefState.base.Nrap[0] + 1; ++i) @@ -623,7 +623,7 @@ namespace JSC { XXZ_Bethe_State Remove_Particle_at_Center (const XXZ_Bethe_State& RefState) { if (RefState.base.Nrap[0] == 0) - JSCerror("Trying to remove a down spin in an empty Nrap[0] state."); + ABACUSerror("Trying to remove a down spin in an empty Nrap[0] state."); Vect newM = RefState.base.Nrap; newM[0] = newM[0] - 1; @@ -633,7 +633,7 @@ namespace JSC { XXZ_Bethe_State ReturnState (RefState.chain, newBase); for (int il = 1; il < RefState.chain.Nstrings; ++il) - for (int alpha = 0; alpha < RefState.base.Nrap[il]; ++alpha) + for (int alpha = 0; alpha < RefState.base.Nrap[il]; ++alpha) ReturnState.Ix2[il][alpha] = RefState.Ix2[il][alpha]; // Remove midmost and shift quantum numbers by half-integer towards removed one: @@ -642,5 +642,5 @@ namespace JSC { return(ReturnState); } - -} // namespace JSC + +} // namespace ABACUS diff --git a/src/HEIS/XXZ_gpd_Bethe_State.cc b/src/HEIS/XXZ_gpd_Bethe_State.cc index 02577e8..1dfe2b2 100644 --- a/src/HEIS/XXZ_gpd_Bethe_State.cc +++ b/src/HEIS/XXZ_gpd_Bethe_State.cc @@ -1,6 +1,6 @@ /********************************************************** -This software is part of J.-S. Caux's ABACUS++ library. +This software is part of J.-S. Caux's ABACUS library. Copyright (c) @@ -12,12 +12,11 @@ Purpose: Defines all functions for XXZ_gpd_Bethe_State ******************************************************************/ - -#include "JSC.h" +#include "ABACUS.h" using namespace std; -namespace JSC { +namespace ABACUS { // Function prototypes @@ -31,14 +30,14 @@ namespace JSC { // Function definitions: class XXZ_gpd_Bethe_State - XXZ_gpd_Bethe_State::XXZ_gpd_Bethe_State () - : Heis_Bethe_State(), sinlambda(Lambda(chain, 1)), coslambda(Lambda(chain, 1)), tanlambda(Lambda(chain, 1)) + XXZ_gpd_Bethe_State::XXZ_gpd_Bethe_State () + : Heis_Bethe_State(), sinlambda(Lambda(chain, 1)), coslambda(Lambda(chain, 1)), tanlambda(Lambda(chain, 1)) {}; XXZ_gpd_Bethe_State::XXZ_gpd_Bethe_State (const XXZ_gpd_Bethe_State& RefState) // copy constructor - : Heis_Bethe_State(RefState), - sinlambda(Lambda(RefState.chain, RefState.base)), coslambda(Lambda(RefState.chain, RefState.base)), - tanlambda(Lambda(RefState.chain, RefState.base)) + : Heis_Bethe_State(RefState), + sinlambda(Lambda(RefState.chain, RefState.base)), coslambda(Lambda(RefState.chain, RefState.base)), + tanlambda(Lambda(RefState.chain, RefState.base)) { // copy arrays into new ones @@ -50,27 +49,27 @@ namespace JSC { } } } - - XXZ_gpd_Bethe_State::XXZ_gpd_Bethe_State (const Heis_Chain& RefChain, int M) - : Heis_Bethe_State(RefChain, M), + + XXZ_gpd_Bethe_State::XXZ_gpd_Bethe_State (const Heis_Chain& RefChain, int M) + : Heis_Bethe_State(RefChain, M), sinlambda(Lambda(RefChain, M)), coslambda(Lambda(RefChain, M)), tanlambda(Lambda(RefChain, M)) { - if (RefChain.Delta <= 1.0) JSCerror("Delta too low in XXZ_gpd_Bethe_State constructor"); + if (RefChain.Delta <= 1.0) ABACUSerror("Delta too low in XXZ_gpd_Bethe_State constructor"); } - XXZ_gpd_Bethe_State::XXZ_gpd_Bethe_State (const Heis_Chain& RefChain, const Heis_Base& RefBase) + XXZ_gpd_Bethe_State::XXZ_gpd_Bethe_State (const Heis_Chain& RefChain, const Heis_Base& RefBase) : Heis_Bethe_State(RefChain, RefBase), - sinlambda(Lambda(RefChain, RefBase)), coslambda(Lambda(RefChain, RefBase)), - tanlambda(Lambda(RefChain, RefBase)) + sinlambda(Lambda(RefChain, RefBase)), coslambda(Lambda(RefChain, RefBase)), + tanlambda(Lambda(RefChain, RefBase)) { - if (RefChain.Delta <= 1.0) JSCerror("Delta too low in XXZ_gpd_Bethe_State constructor"); + if (RefChain.Delta <= 1.0) ABACUSerror("Delta too low in XXZ_gpd_Bethe_State constructor"); } /* XXZ_gpd_Bethe_State::XXZ_gpd_Bethe_State (const Heis_Chain& RefChain, long long int base_id_ref, long long int type_id_ref) : Heis_Bethe_State(RefChain, base_id_ref, type_id_ref), sinlambda(Lambda(chain, base)), coslambda(Lambda(chain, base)), tanlambda(Lambda(chain, base)) { - if (RefChain.Delta <= 1.0) JSCerror("Delta too low in XXZ_gpd_Bethe_State constructor"); + if (RefChain.Delta <= 1.0) ABACUSerror("Delta too low in XXZ_gpd_Bethe_State constructor"); } */ XXZ_gpd_Bethe_State& XXZ_gpd_Bethe_State::operator= (const XXZ_gpd_Bethe_State& RefState) @@ -119,7 +118,7 @@ namespace JSC { } } - + return; } @@ -155,7 +154,7 @@ namespace JSC { bool XXZ_gpd_Bethe_State::Check_Admissibility(char option) { - // This function checks the admissibility of the Ix2's of a state: + // This function checks the admissibility of the Ix2's of a state: // returns false if there are higher strings with Ix2 = 0, a totally symmetric distribution of I's at each level, // and strings of equal length modulo 2 and parity with Ix2 = 0, meaning at least two equal roots in BAE. @@ -163,18 +162,18 @@ namespace JSC { Vect Zero_at_level(false, chain.Nstrings); // whether there exists an Ix2 == 0 at a given level /* - Vect min_Ix2_max_busy(false, chain.Nstrings); + Vect min_Ix2_max_busy(false, chain.Nstrings); Vect plus_Ix2_max_busy(false, chain.Nstrings); - for (int j = 0; j < chain.Nstrings; ++j) + for (int j = 0; j < chain.Nstrings; ++j) for (int alpha = 0; alpha < base[j]; ++alpha) { if (Ix2[j][alpha] == -base.Ix2_max[j]) min_Ix2_max_busy[j] = true; if (Ix2[j][alpha] == base.Ix2_max[j]) plus_Ix2_max_busy[j] = true; } */ /* - // State is not admissible if this is false: -N/2 + 1 \leq \sum I^j_{\alpha} \leq N + // State is not admissible if this is false: -N/2 + 1 \leq \sum I^j_{\alpha} \leq N int sum_all_Ix2 = 0; - for (int j = 0; j < chain.Nstrings; ++j) + for (int j = 0; j < chain.Nstrings; ++j) for (int alpha = 0; alpha < base[j]; ++alpha) { sum_all_Ix2 += Ix2[j][alpha]; } @@ -190,13 +189,13 @@ namespace JSC { for (int j = 0; j < chain.Nstrings; ++j) { sum1 = 0; for (int k = 0; k < chain.Nstrings; ++k) { - sum1 += base[k] * (2 * JSC::min(chain.Str_L[j], chain.Str_L[k]) - ((j == k) ? 1 : 0)); + sum1 += base[k] * (2 * ABACUS::min(chain.Str_L[j], chain.Str_L[k]) - ((j == k) ? 1 : 0)); } // Define limits... //if (!((Nrap[j] + Ix2_max[j]) % 2)) Ix2_max[j] -= 1; // This almost does it: only missing are the states with one on -PI/2 and one on PI/2 - if (base[j] >= 1 && (Ix2[j][0] <= -(chain.Nsites - sum1) || + if (base[j] >= 1 && (Ix2[j][0] <= -(chain.Nsites - sum1) || (Ix2[j][base[j] - 1] - Ix2[j][0]) > 2*(chain.Nsites - sum1))) { //cout << "\tAn Ix2 is out of interval at level " << j << endl; //cout << Ix2[j][base[j] - 1] << "\t" << Ix2[j][0] << "\t" << chain.Nsites << "\t" << sum1 << endl; @@ -215,19 +214,19 @@ namespace JSC { /* // State is not admissible if all min_Ix2_max are busy simultaneously: bool any_min_Ix2_max_free = false; - for (int j = 0; j < chain.Nstrings; ++j) + for (int j = 0; j < chain.Nstrings; ++j) if (base[j] > 0 && !min_Ix2_max_busy[j]) any_min_Ix2_max_free = true; if (!any_min_Ix2_max_free) return(false); */ /* // State is not admissible if -Ix2_max, -Ix2_max + 2, ..., -Ix2_max + 2*(Str_L - 1) are busy: - for (int j = 0; j < chain.Nstrings; ++j) - if (base[j] > 0 && Ix2[j][0] <= -base.Ix2_max[j] + 2*(chain.Str_L[j] - 1)) + for (int j = 0; j < chain.Nstrings; ++j) + if (base[j] > 0 && Ix2[j][0] <= -base.Ix2_max[j] + 2*(chain.Str_L[j] - 1)) return(false); - // Almost correct with above ! + // Almost correct with above ! // State is not admissible if Ix2_max - 2, ..., Ix2_max - 2*(Str_L - 2) are busy (NB: one slot more than on left): - for (int j = 0; j < chain.Nstrings; ++j) - if (base[j] > 0 && Ix2[j][base[j] - 1] >= base.Ix2_max[j] - 2*(chain.Str_L[j] - 2)) + for (int j = 0; j < chain.Nstrings; ++j) + if (base[j] > 0 && Ix2[j][base[j] - 1] >= base.Ix2_max[j] - 2*(chain.Str_L[j] - 2)) return(false); */ @@ -242,9 +241,9 @@ namespace JSC { for (int j = 0; j < chain.Nstrings; ++j) { // The following line puts answer to true if there is at least one higher string with zero Ix2 - for (int alpha = 0; alpha < base[j]; ++alpha) if ((Ix2[j][alpha] == 0) && (chain.Str_L[j] > 2) /*&& !(chain.Str_L[j] % 2)*/) - higher_string_on_zero = true; - for (int alpha = 0; alpha < base[j]; ++alpha) if (Ix2[j][alpha] == 0) Zero_at_level[j] = true; + for (int alpha = 0; alpha < base[j]; ++alpha) if ((Ix2[j][alpha] == 0) && (chain.Str_L[j] > 2) /*&& !(chain.Str_L[j] % 2)*/) + higher_string_on_zero = true; + for (int alpha = 0; alpha < base[j]; ++alpha) if (Ix2[j][alpha] == 0) Zero_at_level[j] = true; // NOTE: if base[j] == 0, Zero_at_level[j] remains false. } @@ -254,7 +253,7 @@ namespace JSC { // Checks that we have strings of equal length modulo 2 and same parity with Ix2 == 0, so equal rapidities, and inadmissibility for (int j1 = 0; j1 < chain.Nstrings; ++j1) { for (int j2 = j1 + 1; j2 < chain.Nstrings; ++j2) - if (Zero_at_level[j1] && Zero_at_level[j2] && (!((chain.Str_L[j1] + chain.Str_L[j2])%2))) + if (Zero_at_level[j1] && Zero_at_level[j2] && (!((chain.Str_L[j1] + chain.Str_L[j2])%2))) string_coincidence = true; } @@ -274,8 +273,8 @@ namespace JSC { // Now check that no Ix2 is equal to +N (since we take -N into account, and I + N == I by periodicity of exp) - for (int j = 0; j < chain.Nstrings; ++j) - for (int alpha = 0; alpha < base[j]; ++alpha) if ((Ix2[j][alpha] < -chain.Nsites) || (Ix2[j][alpha] >= chain.Nsites)) answer = false; + for (int j = 0; j < chain.Nstrings; ++j) + for (int alpha = 0; alpha < base[j]; ++alpha) if ((Ix2[j][alpha] < -chain.Nsites) || (Ix2[j][alpha] >= chain.Nsites)) answer = false; if (!answer) { E = 0.0; @@ -296,26 +295,26 @@ namespace JSC { tanlambda[j][alpha] = tan(lambda[j][alpha]); DP sumtheta = 0.0; - + sumtheta = 0.0; for (int k = 0; k < chain.Nstrings; ++k) { - for (int beta = 0; beta < base[k]; ++beta) + for (int beta = 0; beta < base[k]; ++beta) if ((chain.Str_L[j] == 1) && (chain.Str_L[k] == 1)) { - sumtheta += atan ((tanlambda[j][alpha] - tanlambda[k][beta])/((1.0 + tanlambda[j][alpha] * tanlambda[k][beta]) - * chain.ta_n_anis_over_2[2])) - + PI * floor(0.5 + (lambda[j][alpha] - lambda[k][beta])/PI); - } - else sumtheta += 0.5 * Theta_XXZ_gpd((tanlambda[j][alpha] - tanlambda[k][beta])/(1.0 + tanlambda[j][alpha] * tanlambda[k][beta]), + sumtheta += atan ((tanlambda[j][alpha] - tanlambda[k][beta])/((1.0 + tanlambda[j][alpha] * tanlambda[k][beta]) + * chain.ta_n_anis_over_2[2])) + + PI * floor(0.5 + (lambda[j][alpha] - lambda[k][beta])/PI); + } + else sumtheta += 0.5 * Theta_XXZ_gpd((tanlambda[j][alpha] - tanlambda[k][beta])/(1.0 + tanlambda[j][alpha] * tanlambda[k][beta]), chain.Str_L[j], chain.Str_L[k], chain.ta_n_anis_over_2) - + PI * (2.0 * JSC::min(chain.Str_L[j], chain.Str_L[k]) - ((j == k) ? 1.0 : 0)) + + PI * (2.0 * ABACUS::min(chain.Str_L[j], chain.Str_L[k]) - ((j == k) ? 1.0 : 0)) * floor(0.5 + (lambda[j][alpha] - lambda[k][beta])/PI); } sumtheta *= 2.0; - - BE[j][alpha] = 2.0 * (atan(tanlambda[j][alpha]/chain.ta_n_anis_over_2[chain.Str_L[j]]) + + BE[j][alpha] = 2.0 * (atan(tanlambda[j][alpha]/chain.ta_n_anis_over_2[chain.Str_L[j]]) + PI * floor(0.5 + lambda[j][alpha]/PI)) - (sumtheta + PI*Ix2[j][alpha])/chain.Nsites; - } + } void XXZ_gpd_Bethe_State::Compute_BE () { @@ -324,29 +323,29 @@ namespace JSC { (*this).Compute_tanlambda(); DP sumtheta = 0.0; - - for (int j = 0; j < chain.Nstrings; ++j) + + for (int j = 0; j < chain.Nstrings; ++j) for (int alpha = 0; alpha < base[j]; ++alpha) { - + sumtheta = 0.0; for (int k = 0; k < chain.Nstrings; ++k) { - for (int beta = 0; beta < base[k]; ++beta) + for (int beta = 0; beta < base[k]; ++beta) if ((chain.Str_L[j] == 1) && (chain.Str_L[k] == 1)) { - sumtheta += atan ((tanlambda[j][alpha] - tanlambda[k][beta])/((1.0 + tanlambda[j][alpha] * tanlambda[k][beta]) - * chain.ta_n_anis_over_2[2])) - + PI * floor(0.5 + (lambda[j][alpha] - lambda[k][beta])/PI); - } - else sumtheta += 0.5 * Theta_XXZ_gpd((tanlambda[j][alpha] - tanlambda[k][beta])/(1.0 + tanlambda[j][alpha] * tanlambda[k][beta]), + sumtheta += atan ((tanlambda[j][alpha] - tanlambda[k][beta])/((1.0 + tanlambda[j][alpha] * tanlambda[k][beta]) + * chain.ta_n_anis_over_2[2])) + + PI * floor(0.5 + (lambda[j][alpha] - lambda[k][beta])/PI); + } + else sumtheta += 0.5 * Theta_XXZ_gpd((tanlambda[j][alpha] - tanlambda[k][beta])/(1.0 + tanlambda[j][alpha] * tanlambda[k][beta]), chain.Str_L[j], chain.Str_L[k], chain.ta_n_anis_over_2) - + PI * (2.0 * JSC::min(chain.Str_L[j], chain.Str_L[k]) - ((j == k) ? 1.0 : 0)) + + PI * (2.0 * ABACUS::min(chain.Str_L[j], chain.Str_L[k]) - ((j == k) ? 1.0 : 0)) * floor(0.5 + (lambda[j][alpha] - lambda[k][beta])/PI); } sumtheta *= 2.0; - - BE[j][alpha] = 2.0 * (atan(tanlambda[j][alpha]/chain.ta_n_anis_over_2[chain.Str_L[j]]) + + BE[j][alpha] = 2.0 * (atan(tanlambda[j][alpha]/chain.ta_n_anis_over_2[chain.Str_L[j]]) + PI * floor(0.5 + lambda[j][alpha]/PI)) - (sumtheta + PI*Ix2[j][alpha])/chain.Nsites; - } + } } DP XXZ_gpd_Bethe_State::Iterate_BAE (int j, int alpha) @@ -354,17 +353,17 @@ namespace JSC { // Returns a new iteration value for lambda[j][alpha] given tanlambda[][] and BE[][] // Assumes that tanlambda[][] and BE[][] have been computed. - DP arg0 = 0.5 * (2.0 * (atan(tanlambda[j][alpha]/chain.ta_n_anis_over_2[chain.Str_L[j]]) + DP arg0 = 0.5 * (2.0 * (atan(tanlambda[j][alpha]/chain.ta_n_anis_over_2[chain.Str_L[j]]) + PI * floor(0.5 + lambda[j][alpha]/PI)) - BE[j][alpha]); DP arg = chain.ta_n_anis_over_2[chain.Str_L[j]] * tan( arg0 - //0.5 * + //0.5 * //(PI * Ix2[j][alpha] + sumtheta)/chain.Nsites - //(2.0 * (atan(tanlambda[j][alpha]/chain.ta_n_anis_over_2[chain.Str_L[j]]) + //(2.0 * (atan(tanlambda[j][alpha]/chain.ta_n_anis_over_2[chain.Str_L[j]]) // + PI * floor(0.5 + lambda[j][alpha]/PI)) - BE[j][alpha]) ); - return(atan(arg) + return(atan(arg) //+ PI * floor(0.5 + arg0) //0.5 * (Ix2[j][alpha] + sumtheta/PI)/(chain.Nsites) + PI * floor(0.5 + arg0/PI) @@ -388,15 +387,15 @@ namespace JSC { sumtheta = 0.0; for (int k = 0; k < chain.Nstrings; ++k) { - for (int beta = 0; beta < base[k]; ++beta) - if ((chain.Str_L[j] == 1) && (chain.Str_L[k] == 1)) - sumtheta += atan((tanlambda[j][alpha] - tanlambda[k][beta])/((1.0 + tanlambda[j][alpha] * tanlambda[k][beta]) + for (int beta = 0; beta < base[k]; ++beta) + if ((chain.Str_L[j] == 1) && (chain.Str_L[k] == 1)) + sumtheta += atan((tanlambda[j][alpha] - tanlambda[k][beta])/((1.0 + tanlambda[j][alpha] * tanlambda[k][beta]) * chain.ta_n_anis_over_2[2])) - + PI * floor(0.5 + (lambda[j][alpha] - lambda[k][beta])/PI); + + PI * floor(0.5 + (lambda[j][alpha] - lambda[k][beta])/PI); - else sumtheta += 0.5 * Theta_XXZ_gpd((tanlambda[j][alpha] - tanlambda[k][beta])/(1.0 + tanlambda[j][alpha] * tanlambda[k][beta]), + else sumtheta += 0.5 * Theta_XXZ_gpd((tanlambda[j][alpha] - tanlambda[k][beta])/(1.0 + tanlambda[j][alpha] * tanlambda[k][beta]), chain.Str_L[j], chain.Str_L[k], chain.ta_n_anis_over_2) - + PI * (2.0 * JSC::min(chain.Str_L[j], chain.Str_L[k]) - ((j == k) ? 1.0 : 0)) + + PI * (2.0 * ABACUS::min(chain.Str_L[j], chain.Str_L[k]) - ((j == k) ? 1.0 : 0)) * floor(0.5 + (lambda[j][alpha] - lambda[k][beta])/PI); } sumtheta *= 2.0; @@ -449,27 +448,27 @@ namespace JSC { sumtheta = 0.0; for (int k = 0; k < chain.Nstrings; ++k) { - for (int beta = 0; beta < base[k]; ++beta) + for (int beta = 0; beta < base[k]; ++beta) if ((chain.Str_L[j] == 1) && (chain.Str_L[k] == 1)) { - sumtheta += atan ((tanlambda[j][alpha] - tanlambda[k][beta])/((1.0 + tanlambda[j][alpha] * tanlambda[k][beta]) - * chain.ta_n_anis_over_2[2])) - + PI * floor(0.5 + (lambda[j][alpha] - lambda[k][beta])/PI); - } - else sumtheta += 0.5 * Theta_XXZ_gpd((tanlambda[j][alpha] - tanlambda[k][beta])/(1.0 + tanlambda[j][alpha] * tanlambda[k][beta]), + sumtheta += atan ((tanlambda[j][alpha] - tanlambda[k][beta])/((1.0 + tanlambda[j][alpha] * tanlambda[k][beta]) + * chain.ta_n_anis_over_2[2])) + + PI * floor(0.5 + (lambda[j][alpha] - lambda[k][beta])/PI); + } + else sumtheta += 0.5 * Theta_XXZ_gpd((tanlambda[j][alpha] - tanlambda[k][beta])/(1.0 + tanlambda[j][alpha] * tanlambda[k][beta]), chain.Str_L[j], chain.Str_L[k], chain.ta_n_anis_over_2) - + PI * (2.0 * JSC::min(chain.Str_L[j], chain.Str_L[k]) - ((j == k) ? 1.0 : 0)) + + PI * (2.0 * ABACUS::min(chain.Str_L[j], chain.Str_L[k]) - ((j == k) ? 1.0 : 0)) * floor(0.5 + (lambda[j][alpha] - lambda[k][beta])/PI); } sumtheta *= 2.0; - RHSBAE[index] = chain.Nsites * 2.0 * (atan(tanlambda[j][alpha]/chain.ta_n_anis_over_2[chain.Str_L[j]]) + RHSBAE[index] = chain.Nsites * 2.0 * (atan(tanlambda[j][alpha]/chain.ta_n_anis_over_2[chain.Str_L[j]]) + PI * floor(0.5 + lambda[j][alpha]/PI)) // ) - sumtheta - PI*Ix2[j][alpha]; index++; } } - + (*this).Build_Reduced_Gaudin_Matrix (Gaudin); for (int i = 0; i < base.Nraptot; ++i) dlambda[i] = - RHSBAE[i]; @@ -516,8 +515,8 @@ namespace JSC { bool nonan = true; for (int j = 0; j < chain.Nstrings; ++j) - for (int alpha = 0; alpha < base[j]; ++alpha) if (nonan) nonan = ((!is_nan(lambda[j][alpha])) - //&& (lambda[j][alpha] > -0.5*PI*chain.Str_L[j]) + for (int alpha = 0; alpha < base[j]; ++alpha) if (nonan) nonan = ((!is_nan(lambda[j][alpha])) + //&& (lambda[j][alpha] > -0.5*PI*chain.Str_L[j]) //&& (lambda[j][alpha] <= 0.5*PI*chain.Str_L[j]) ); @@ -557,53 +556,53 @@ namespace JSC { Vect_DP deltadiff(0.0, 1000); // contains |delta^{a, a+1}| complex log_BAE_reg = 0.0; - + for (int j = 0; j < (*this).chain.Nstrings; ++j) { for (int alpha = 0; alpha < (*this).base[j]; ++alpha) { ln_deltadiff = 0.0; - + for (int a = 1; a <= (*this).chain.Str_L[j]; ++a) { - + if ((*this).chain.Str_L[j] > 1) { // else the BAE are already 1 - log_BAE_reg = DP((*this).chain.Nsites) * log(sin((*this).lambda[j][alpha] + 0.5 * II * (*this).chain.anis + log_BAE_reg = DP((*this).chain.Nsites) * log(sin((*this).lambda[j][alpha] + 0.5 * II * (*this).chain.anis * ((*this).chain.Str_L[j] + 1.0 - 2.0 * a + 1.0)) /sin((*this).lambda[j][alpha] + 0.5 * II * (*this).chain.anis * ((*this).chain.Str_L[j] + 1.0 - 2.0 * a - 1.0))); - - for (int k = 0; k < (*this).chain.Nstrings; ++k) - for (int beta = 0; beta < (*this).base[k]; ++beta) - for (int b = 1; b <= (*this).chain.Str_L[k]; ++b) { - if ((j != k) || (alpha != beta) || (a != b - 1)) - log_BAE_reg += log(sin(((*this).lambda[j][alpha] + 0.5 * II * (*this).chain.anis * ((*this).chain.Str_L[j] + 1.0 - 2.0 * a )) - - ((*this).lambda[k][beta] + 0.5 * II * (*this).chain.anis * ((*this).chain.Str_L[k] + 1.0 - 2.0 * b )) + for (int k = 0; k < (*this).chain.Nstrings; ++k) + for (int beta = 0; beta < (*this).base[k]; ++beta) + for (int b = 1; b <= (*this).chain.Str_L[k]; ++b) { + if ((j != k) || (alpha != beta) || (a != b - 1)) + + log_BAE_reg += log(sin(((*this).lambda[j][alpha] + 0.5 * II * (*this).chain.anis * ((*this).chain.Str_L[j] + 1.0 - 2.0 * a )) + - ((*this).lambda[k][beta] + 0.5 * II * (*this).chain.anis * ((*this).chain.Str_L[k] + 1.0 - 2.0 * b )) - II * (*this).chain.anis)); - - if ((j != k) || (alpha != beta) || (a != b + 1)) + + if ((j != k) || (alpha != beta) || (a != b + 1)) log_BAE_reg -= log(sin(((*this).lambda[j][alpha] + 0.5 * II * (*this).chain.anis * ((*this).chain.Str_L[j] + 1.0 - 2.0 * a )) - - ((*this).lambda[k][beta] + 0.5 * II * (*this).chain.anis * ((*this).chain.Str_L[k] + 1.0 - 2.0 * b )) + - ((*this).lambda[k][beta] + 0.5 * II * (*this).chain.anis * ((*this).chain.Str_L[k] + 1.0 - 2.0 * b )) + II * (*this).chain.anis)); } // The regular LHS of BAE is now defined. Now sum up the deltas... - + if (a == 1) ln_deltadiff[0] = -real(log_BAE_reg); - + else if (a < (*this).chain.Str_L[j]) ln_deltadiff[a - 1] = ln_deltadiff[a-2] - real(log_BAE_reg); - + else if (a == (*this).chain.Str_L[j]) ln_deltadiff[a-1] = real(log_BAE_reg); } // if ((*this).chain.Str_L[j] > 1) - + } // for (int a = 1; ... for (int a = 0; a < (*this).chain.Str_L[j]; ++a) { deltadiff[a] = ln_deltadiff[a] != 0.0 ? exp(ln_deltadiff[a]) : 0.0; delta += fabs(deltadiff[a]); - } - + } + } // alpha sum } // j sum @@ -618,7 +617,7 @@ namespace JSC { void XXZ_gpd_Bethe_State::Compute_Energy () { DP sum = 0.0; - + for (int j = 0; j < chain.Nstrings; ++j) { for (int alpha = 0; alpha < base[j]; ++alpha) { sum += sinh(chain.Str_L[j] * chain.anis) / (cos(2.0 * lambda[j][alpha]) - cosh(chain.Str_L[j] * chain.anis)); @@ -626,7 +625,7 @@ namespace JSC { } sum *= chain.J * sinh(chain.anis); - + E = sum; return; @@ -662,7 +661,7 @@ namespace JSC { void XXZ_gpd_Bethe_State::Build_Reduced_Gaudin_Matrix (SQMat >& Gaudin_Red) { - if (Gaudin_Red.size() != base.Nraptot) JSCerror("Passing matrix of wrong size in Build_Reduced_Gaudin_Matrix."); + if (Gaudin_Red.size() != base.Nraptot) ABACUSerror("Passing matrix of wrong size in Build_Reduced_Gaudin_Matrix."); int index_jalpha; int index_kbeta; @@ -687,24 +686,24 @@ namespace JSC { for (int kp = 0; kp < chain.Nstrings; ++kp) { for (int betap = 0; betap < base[kp]; ++betap) { - if (!((j == kp) && (alpha == betap))) - sum_hbar_XXZ - += ddlambda_Theta_XXZ_gpd (lambda[j][alpha] - lambda[kp][betap], chain.Str_L[j], chain.Str_L[kp], + if (!((j == kp) && (alpha == betap))) + sum_hbar_XXZ + += ddlambda_Theta_XXZ_gpd (lambda[j][alpha] - lambda[kp][betap], chain.Str_L[j], chain.Str_L[kp], chain.si_n_anis_over_2); } } - Gaudin_Red[index_jalpha][index_kbeta] + Gaudin_Red[index_jalpha][index_kbeta] = complex ( chain.Nsites * hbar_XXZ_gpd (lambda[j][alpha], chain.Str_L[j], chain.si_n_anis_over_2) - sum_hbar_XXZ); } - + else { - if ((chain.Str_L[j] == 1) && (chain.Str_L[k] == 1)) - Gaudin_Red[index_jalpha][index_kbeta] = - complex (chain.si_n_anis_over_2[4]/(pow(sinlambda[j][alpha] * coslambda[k][beta] + if ((chain.Str_L[j] == 1) && (chain.Str_L[k] == 1)) + Gaudin_Red[index_jalpha][index_kbeta] = + complex (chain.si_n_anis_over_2[4]/(pow(sinlambda[j][alpha] * coslambda[k][beta] - coslambda[j][alpha] * sinlambda[k][beta], 2.0) + sinhetasq)); - else - Gaudin_Red[index_jalpha][index_kbeta] = complex (ddlambda_Theta_XXZ_gpd (lambda[j][alpha] - lambda[k][beta], chain.Str_L[j], + else + Gaudin_Red[index_jalpha][index_kbeta] = complex (ddlambda_Theta_XXZ_gpd (lambda[j][alpha] - lambda[k][beta], chain.Str_L[j], chain.Str_L[k], chain.si_n_anis_over_2)); } index_kbeta++; @@ -732,12 +731,12 @@ namespace JSC { DP result; if ((nj == 1) && (nk == 1)) result = fbar_XXZ_gpd(tanlambda, tanhnetaover2[2]); - + else { result = (nj == nk) ? 0.0 : fbar_XXZ_gpd(tanlambda, tanhnetaover2[fabs(nj - nk)]); - for (int a = 1; a < JSC::min(nj, nk); ++a) result += 2.0 * fbar_XXZ_gpd(tanlambda, tanhnetaover2[fabs(nj - nk) + 2*a]); + for (int a = 1; a < ABACUS::min(nj, nk); ++a) result += 2.0 * fbar_XXZ_gpd(tanlambda, tanhnetaover2[fabs(nj - nk) + 2*a]); result += fbar_XXZ_gpd(tanlambda, tanhnetaover2[nj + nk]); } @@ -749,12 +748,12 @@ namespace JSC { { return (si_n_anis_over_2[2*n]/(pow(sin(lambda), 2.0) + pow(si_n_anis_over_2[n], 2.0))); } - + DP ddlambda_Theta_XXZ_gpd (DP lambda, int nj, int nk, DP* si_n_anis_over_2) { DP result = (nj == nk) ? 0.0 : hbar_XXZ_gpd(lambda, fabs(nj - nk), si_n_anis_over_2); - for (int a = 1; a < JSC::min(nj, nk); ++a) result += 2.0 * hbar_XXZ_gpd(lambda, fabs(nj - nk) + 2*a, si_n_anis_over_2); + for (int a = 1; a < ABACUS::min(nj, nk); ++a) result += 2.0 * hbar_XXZ_gpd(lambda, fabs(nj - nk) + 2*a, si_n_anis_over_2); result += hbar_XXZ_gpd(lambda, nj + nk, si_n_anis_over_2); @@ -764,8 +763,8 @@ namespace JSC { XXZ_gpd_Bethe_State Add_Particle_at_Center (const XXZ_gpd_Bethe_State& RefState) { - if (2*RefState.base.Mdown == RefState.chain.Nsites) - JSCerror("Trying to add a down spin to a zero-magnetized chain in Add_Particle_at_Center."); + if (2*RefState.base.Mdown == RefState.chain.Nsites) + ABACUSerror("Trying to add a down spin to a zero-magnetized chain in Add_Particle_at_Center."); Vect newM = RefState.base.Nrap; newM[0] = newM[0] + 1; @@ -775,10 +774,10 @@ namespace JSC { XXZ_gpd_Bethe_State ReturnState (RefState.chain, newBase); for (int il = 1; il < RefState.chain.Nstrings; ++il) - for (int alpha = 0; alpha < RefState.base.Nrap[il]; ++alpha) + for (int alpha = 0; alpha < RefState.base.Nrap[il]; ++alpha) ReturnState.Ix2[il][alpha] = RefState.Ix2[il][alpha]; - // Add a quantum number in middle (explicitly: to right of index M[0]/2) + // Add a quantum number in middle (explicitly: to right of index M[0]/2) // and shift quantum numbers by half-integer away from added one: ReturnState.Ix2[0][RefState.base.Nrap[0]/2] = RefState.Ix2[0][RefState.base.Nrap[0]/2] - 1; for (int i = 0; i < RefState.base.Nrap[0] + 1; ++i) @@ -791,7 +790,7 @@ namespace JSC { XXZ_gpd_Bethe_State Remove_Particle_at_Center (const XXZ_gpd_Bethe_State& RefState) { if (RefState.base.Nrap[0] == 0) - JSCerror("Trying to remove a down spin in an empty Nrap[0] state."); + ABACUSerror("Trying to remove a down spin in an empty Nrap[0] state."); Vect newM = RefState.base.Nrap; newM[0] = newM[0] - 1; @@ -801,7 +800,7 @@ namespace JSC { XXZ_gpd_Bethe_State ReturnState (RefState.chain, newBase); for (int il = 1; il < RefState.chain.Nstrings; ++il) - for (int alpha = 0; alpha < RefState.base.Nrap[il]; ++alpha) + for (int alpha = 0; alpha < RefState.base.Nrap[il]; ++alpha) ReturnState.Ix2[il][alpha] = RefState.Ix2[il][alpha]; // Remove midmost and shift quantum numbers by half-integer towards removed one: @@ -810,5 +809,5 @@ namespace JSC { return(ReturnState); } - -} // namespace JSC + +} // namespace ABACUS diff --git a/src/HEIS/ln_Overlap_XXX.cc b/src/HEIS/ln_Overlap_XXX.cc index 7569aba..d1dfb16 100644 --- a/src/HEIS/ln_Overlap_XXX.cc +++ b/src/HEIS/ln_Overlap_XXX.cc @@ -1,18 +1,23 @@ /********************************************************** -This software is part of J.-S. Caux's ABACUS++ library. +This software is part of J.-S. Caux's ABACUS library. -Copyright (c) +Copyright (c) J.-S. Caux. ----------------------------------------------------------- +File: ln_Overlap_XXX.cc + +Purpose: compute the overlap between an on-shell and an off-shell states + ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" -using namespace JSC; +using namespace std; +using namespace ABACUS; -namespace JSC { +namespace ABACUS { inline complex ln_Fn_F (XXX_Bethe_State& B, int k, int beta, int b) { @@ -22,9 +27,9 @@ inline complex ln_Fn_F (XXX_Bethe_State& B, int k, int beta, int b) for (int alpha = 0; alpha < B.base.Nrap[j]; ++alpha) { for (int a = 1; a <= B.chain.Str_L[j]; ++a) { - if (!((j == k) && (alpha == beta) && (a == b))) + if (!((j == k) && (alpha == beta) && (a == b))) ans += log(B.lambda[j][alpha] - B.lambda[k][beta] - + 0.5 * II * (B.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b))); + + 0.5 * II * (B.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b))); } } } @@ -60,8 +65,8 @@ inline complex Fn_K (XXX_Bethe_State& A, int j, int alpha, int a, XXX_Bethe_ inline complex Fn_L (XXX_Bethe_State& A, int j, int alpha, int a, XXX_Bethe_State& B, int k, int beta, int b) { return ((2.0 * (A.lambda[j][alpha] - B.lambda[k][beta] - + 0.5 * II * (A.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b - 0.5)) - )) + + 0.5 * II * (A.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b - 0.5)) + )) * pow(Fn_K (A, j, alpha, a, B, k, beta, b), 2.0)); } @@ -71,7 +76,7 @@ complex ln_Overlap (XXX_Bethe_State& A, XXX_Bethe_State& B) // The A and B states can contain strings. // IMPORTANT ASSUMPTIONS: - // - State B is an eigenstate of the model on which the overlap measure is defined + // - State B is an eigenstate of the model on which the overlap measure is defined // Check that A and B are compatible: same Mdown @@ -92,12 +97,12 @@ complex ln_Overlap (XXX_Bethe_State& A, XXX_Bethe_State& B) complex ln_prod4 = 0.0; /* - for (int i = 0; i < A.chain.Nstrings; ++i) + for (int i = 0; i < A.chain.Nstrings; ++i) for (int alpha = 0; alpha < A.base.Nrap[i]; ++alpha) for (int a = 1; a <= A.chain.Str_L[i]; ++a) ln_prod1 += log(norm((A.lambda[i][alpha] + 0.5 * II * (A.chain.Str_L[i] + 1.0 - 2.0 * a - 1.0)))); - for (int i = 0; i < B.chain.Nstrings; ++i) + for (int i = 0; i < B.chain.Nstrings; ++i) for (int alpha = 0; alpha < B.base.Nrap[i]; ++alpha) for (int a = 1; a <= B.chain.Str_L[i]; ++a) if (norm((B.lambda[i][alpha] + 0.5 * II * (B.chain.Str_L[i] + 1.0 - 2.0 * a - 1.0))) > 100.0 * MACHINE_EPS_SQ) @@ -121,8 +126,8 @@ complex ln_Overlap (XXX_Bethe_State& A, XXX_Bethe_State& B) for (int j = 0; j < A.chain.Nstrings; ++j) for (int alpha = 0; alpha < A.base.Nrap[j]; ++alpha) - for (int a = 1; a <= A.chain.Str_L[j]; ++a) - ln_prod3 += ln_Fn_F (A, j, alpha, a - 1); + for (int a = 1; a <= A.chain.Str_L[j]; ++a) + ln_prod3 += ln_Fn_F (A, j, alpha, a - 1); // ln_prod3 -= A.base.Mdown * log(abs(sin(A.chain.zeta))); @@ -132,7 +137,7 @@ complex ln_Overlap (XXX_Bethe_State& A, XXX_Bethe_State& B) if (b == 1) ln_prod4 += re_ln_Fn_F_B_0[k][beta]; else if (b > 1) ln_prod4 += ln_Fn_F(B, k, beta, b - 1); } - + // ln_prod4 -= B.base.Mdown * log(abs(sin(B.chain.zeta))); // Now proceed to build the Hm2P matrix @@ -153,12 +158,12 @@ complex ln_Overlap (XXX_Bethe_State& A, XXX_Bethe_State& B) for (int j = 0; j < A.chain.Nstrings; ++j) { for (int alpha = 0; alpha < A.base.Nrap[j]; ++alpha) { for (int a = 1; a <= A.chain.Str_L[j]; ++a) { - + index_b = 0; //two_over_A_lambda_sq_plus_1over2sq = 2.0/((A.lambda[j][alpha] + 0.5 * II * (A.chain.Str_L[j] + 1.0 - 2.0 * a)) * // (A.lambda[j][alpha] + 0.5 * II * (A.chain.Str_L[j] + 1.0 - 2.0 * a)) + 0.25); - + for (int k = 0; k < B.chain.Nstrings; ++k) { for (int beta = 0; beta < B.base.Nrap[k]; ++beta) { for (int b = 1; b <= B.chain.Str_L[k]; ++b) { @@ -173,51 +178,51 @@ complex ln_Overlap (XXX_Bethe_State& A, XXX_Bethe_State& B) exp(re_ln_Fn_G_2[k][beta] + II * im_ln_Fn_G_2[k][beta] - re_ln_Fn_F_B_0[k][beta]); //Prod_powerN = pow((B.lambda[k][beta] + 0.5 * II)/(B.lambda[k][beta] - 0.5 * II), complex (B.chain.Nsites)); - Prod_powerN = pow((B.lambda[k][beta] + 0.5 * II)/(B.lambda[k][beta] - 0.5 * II), complex (A.chain.Nsites)); // careful ! + Prod_powerN = pow((B.lambda[k][beta] + 0.5 * II)/(B.lambda[k][beta] - 0.5 * II), complex (A.chain.Nsites)); // careful ! Hm2P[index_a][index_b] = Fn_K_0_G_0 - Prod_powerN * Fn_K_1_G_2 //- two_over_A_lambda_sq_plus_1over2sq * exp(II*im_ln_Fn_F_B_0[k][beta]); ; } - + else { if (b <= B.chain.Str_L[k] - 1) Hm2P[index_a][index_b] = Fn_K(A, j, alpha, a, B, k, beta, b); else if (b == B.chain.Str_L[k]) { - + Vect_CX ln_FunctionF(B.chain.Str_L[k] + 2); for (int i = 0; i < B.chain.Str_L[k] + 2; ++i) ln_FunctionF[i] = ln_Fn_F (B, k, beta, i); - + Vect_CX ln_FunctionG(B.chain.Str_L[k] + 2); for (int i = 0; i < B.chain.Str_L[k] + 2; ++i) ln_FunctionG[i] = ln_Fn_G (A, B, k, beta, i); sum1 = 0.0; - + sum1 += Fn_K (A, j, alpha, a, B, k, beta, 0) * exp(ln_FunctionG[0] + ln_FunctionG[1] - ln_FunctionF[0] - ln_FunctionF[1]); - - sum1 += Fn_K (A, j, alpha, a, B, k, beta, B.chain.Str_L[k]) - * exp(ln_FunctionG[B.chain.Str_L[k]] + ln_FunctionG[B.chain.Str_L[k] + 1] + + sum1 += Fn_K (A, j, alpha, a, B, k, beta, B.chain.Str_L[k]) + * exp(ln_FunctionG[B.chain.Str_L[k]] + ln_FunctionG[B.chain.Str_L[k] + 1] - ln_FunctionF[B.chain.Str_L[k]] - ln_FunctionF[B.chain.Str_L[k] + 1]); - - for (int jsum = 1; jsum < B.chain.Str_L[k]; ++jsum) - + + for (int jsum = 1; jsum < B.chain.Str_L[k]; ++jsum) + sum1 -= Fn_L (A, j, alpha, a, B, k, beta, jsum) * exp(ln_FunctionG[jsum] + ln_FunctionG[jsum + 1] - ln_FunctionF[jsum] - ln_FunctionF[jsum + 1]); - + //sum2 = 0.0; - + //for (int jsum = 1; jsum <= B.chain.Str_L[k]; ++jsum) sum2 += exp(ln_FunctionG[jsum] - ln_FunctionF[jsum]); - + prod_num = exp(II * im_ln_Fn_F_B_0[k][beta] + ln_FunctionF[1] - ln_FunctionG[B.chain.Str_L[k]]); - for (int jsum = 2; jsum <= B.chain.Str_L[k]; ++jsum) + for (int jsum = 2; jsum <= B.chain.Str_L[k]; ++jsum) prod_num *= exp(ln_FunctionG[jsum] - real(ln_Fn_F(B, k, beta, jsum - 1))); // include all string contributions F_B_0 in this term //Hm2P[index_a][index_b] = prod_num * (sum1 - sum2 * two_over_A_lambda_sq_plus_1over2sq); Hm2P[index_a][index_b] = prod_num * sum1; } // else if (b == B.chain.Str_L[k]) - } // else + } // else index_b++; }}} // sums over k, beta, b @@ -232,22 +237,22 @@ complex ln_Overlap (XXX_Bethe_State& A, XXX_Bethe_State& B) /* complex ln_form_factor_sq = log(0.25 * A.chain.Nsites) + real(ln_prod1 - ln_prod2) - real(ln_prod3) + real(ln_prod4) - // + 2.0 * real(lndet_LU_CX_dstry(Hm2P)) + // + 2.0 * real(lndet_LU_CX_dstry(Hm2P)) + 2.0 * det - A.lnnorm - B.lnnorm; - //cout << "ln_SZ: " << endl << ln_prod1 << "\t" << -ln_prod2 << "\t" << -ln_prod3 << "\t" << ln_prod4 << "\t" << 2.0 * det + //cout << "ln_SZ: " << endl << ln_prod1 << "\t" << -ln_prod2 << "\t" << -ln_prod3 << "\t" << ln_prod4 << "\t" << 2.0 * det // << "\t" << -A.lnnorm << "\t" << -B.lnnorm << endl; return(ln_form_factor_sq); */ complex ln_overlap = 0.5 * (-ln_prod3 + ln_prod4) + det - 0.5 * (A.lnnorm + B.lnnorm); - cout << "ln_overlap: " << endl << -ln_prod3 << "\t" << ln_prod4 << "\t" << 2.0 * det + cout << "ln_overlap: " << endl << -ln_prod3 << "\t" << ln_prod4 << "\t" << 2.0 * det << "\t" << -A.lnnorm << "\t" << -B.lnnorm << endl; return(ln_overlap); } -} // namespace JSC +} // namespace ABACUS diff --git a/src/HEIS/ln_Smin_ME_XXX.cc b/src/HEIS/ln_Smin_ME_XXX.cc index 5162573..3af2670 100644 --- a/src/HEIS/ln_Smin_ME_XXX.cc +++ b/src/HEIS/ln_Smin_ME_XXX.cc @@ -1,8 +1,23 @@ -#include "JSC.h" +/********************************************************** -using namespace JSC; +This software is part of J.-S. Caux's ABACUS library. -namespace JSC { +Copyright (c) J.-S. Caux. + +----------------------------------------------------------- + +File: ln_Smin_ME_XXX.cc + +Purpose: compute the S^- matrix elemment for XXX + +***********************************************************/ + +#include "ABACUS.h" + +using namespace std; +using namespace ABACUS; + +namespace ABACUS { inline complex ln_Fn_F (XXX_Bethe_State& B, int k, int beta, int b) { @@ -12,12 +27,12 @@ inline complex ln_Fn_F (XXX_Bethe_State& B, int k, int beta, int b) for (int alpha = 0; alpha < B.base.Nrap[j]; ++alpha) { for (int a = 1; a <= B.chain.Str_L[j]; ++a) { - if (!((j == k) && (alpha == beta) && (a == b))) + if (!((j == k) && (alpha == beta) && (a == b))) ans += log(B.lambda[j][alpha] - B.lambda[k][beta] - + 0.5 * II * (B.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b))); + + 0.5 * II * (B.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b))); } } - } + } return(ans); } @@ -50,8 +65,8 @@ inline complex Fn_K (XXX_Bethe_State& A, int j, int alpha, int a, XXX_Bethe_ inline complex Fn_L (XXX_Bethe_State& A, int j, int alpha, int a, XXX_Bethe_State& B, int k, int beta, int b) { return ((2.0 * (A.lambda[j][alpha] - B.lambda[k][beta] - + 0.5 * II * (A.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b - 0.5)) - )) + + 0.5 * II * (A.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b - 0.5)) + )) * pow(Fn_K (A, j, alpha, a, B, k, beta, b), 2.0)); } @@ -62,11 +77,11 @@ complex ln_Smin_ME (XXX_Bethe_State& A, XXX_Bethe_State& B) // Check that the two states are compatible - if (A.chain != B.chain) JSCerror("Incompatible XXX_Chains in Smin matrix element."); + if (A.chain != B.chain) ABACUSerror("Incompatible XXX_Chains in Smin matrix element."); - // Check that A and B are Mdown-compatible: + // Check that A and B are Mdown-compatible: - if (A.base.Mdown != B.base.Mdown + 1) JSCerror("Incompatible Mdown between the two states in Smin matrix element!"); + if (A.base.Mdown != B.base.Mdown + 1) ABACUSerror("Incompatible Mdown between the two states in Smin matrix element!"); // Some convenient arrays @@ -82,12 +97,12 @@ complex ln_Smin_ME (XXX_Bethe_State& A, XXX_Bethe_State& B) complex ln_prod3 = 0.0; complex ln_prod4 = 0.0; - for (int i = 0; i < A.chain.Nstrings; ++i) + for (int i = 0; i < A.chain.Nstrings; ++i) for (int alpha = 0; alpha < A.base.Nrap[i]; ++alpha) for (int a = 1; a <= A.chain.Str_L[i]; ++a) ln_prod1 += log(norm(A.lambda[i][alpha] + 0.5 * II * (A.chain.Str_L[i] + 1.0 - 2.0 * a - 1.0))); - for (int i = 0; i < B.chain.Nstrings; ++i) + for (int i = 0; i < B.chain.Nstrings; ++i) for (int alpha = 0; alpha < B.base.Nrap[i]; ++alpha) for (int a = 1; a <= B.chain.Str_L[i]; ++a) if (norm(B.lambda[i][alpha] + 0.5 * II * (B.chain.Str_L[i] + 1.0 - 2.0 * a - 1.0)) > 100.0 * MACHINE_EPS_SQ) @@ -120,8 +135,8 @@ complex ln_Smin_ME (XXX_Bethe_State& A, XXX_Bethe_State& B) for (int j = 0; j < A.chain.Nstrings; ++j) for (int alpha = 0; alpha < A.base.Nrap[j]; ++alpha) - for (int a = 1; a <= A.chain.Str_L[j]; ++a) - ln_prod3 += ln_Fn_F(A, j, alpha, a - 1); + for (int a = 1; a <= A.chain.Str_L[j]; ++a) + ln_prod3 += ln_Fn_F(A, j, alpha, a - 1); // ln_prod3 -= A.base.Mdown * log(abs(sin(A.chain.zeta))); @@ -131,7 +146,7 @@ complex ln_Smin_ME (XXX_Bethe_State& A, XXX_Bethe_State& B) if (b == 1) ln_prod4 += re_ln_Fn_F_B_0[k][beta]; else if (b > 1) ln_prod4 += ln_Fn_F(B, k, beta, b - 1); } - + // ln_prod4 -= B.base.Mdown * log(abs(sin(B.chain.zeta))); // Now proceed to build the Hm matrix @@ -152,10 +167,10 @@ complex ln_Smin_ME (XXX_Bethe_State& A, XXX_Bethe_State& B) for (int j = 0; j < A.chain.Nstrings; ++j) { for (int alpha = 0; alpha < A.base.Nrap[j]; ++alpha) { for (int a = 1; a <= A.chain.Str_L[j]; ++a) { - + index_b = 0; - - one_over_A_lambda_sq_plus_1over2sq = 1.0/((A.lambda[j][alpha] + 0.5 * II * (A.chain.Str_L[j] + 1.0 - 2.0 * a)) * + + one_over_A_lambda_sq_plus_1over2sq = 1.0/((A.lambda[j][alpha] + 0.5 * II * (A.chain.Str_L[j] + 1.0 - 2.0 * a)) * (A.lambda[j][alpha] + 0.5 * II * (A.chain.Str_L[j] + 1.0 - 2.0 * a)) + 0.25); for (int k = 0; k < B.chain.Nstrings; ++k) { @@ -166,9 +181,9 @@ complex ln_Smin_ME (XXX_Bethe_State& A, XXX_Bethe_State& B) // use simplified code for one-string here: original form of Hm2P matrix - Fn_K_0_G_0 = Fn_K (A, j, alpha, a, B, k, beta, 0) * + Fn_K_0_G_0 = Fn_K (A, j, alpha, a, B, k, beta, 0) * exp(re_ln_Fn_G_0[k][beta] + II * im_ln_Fn_G_0[k][beta] - re_ln_Fn_F_B_0[k][beta]); - Fn_K_1_G_2 = Fn_K (A, j, alpha, a, B, k, beta, 1) * + Fn_K_1_G_2 = Fn_K (A, j, alpha, a, B, k, beta, 1) * exp(re_ln_Fn_G_2[k][beta] + II * im_ln_Fn_G_2[k][beta] - re_ln_Fn_F_B_0[k][beta]); Prod_powerN = pow((B.lambda[k][beta] + II * 0.5) /(B.lambda[k][beta] - II * 0.5), complex (B.chain.Nsites)); @@ -176,54 +191,54 @@ complex ln_Smin_ME (XXX_Bethe_State& A, XXX_Bethe_State& B) Hm[index_a][index_b] = Fn_K_0_G_0 - Prod_powerN * Fn_K_1_G_2; } // if (B.chain.Str_L == 1) - + else { if (b <= B.chain.Str_L[k] - 1) Hm[index_a][index_b] = Fn_K(A, j, alpha, a, B, k, beta, b); else if (b == B.chain.Str_L[k]) { - + Vect_CX ln_FunctionF(B.chain.Str_L[k] + 2); for (int i = 0; i < B.chain.Str_L[k] + 2; ++i) ln_FunctionF[i] = ln_Fn_F (B, k, beta, i); - + Vect_CX ln_FunctionG(B.chain.Str_L[k] + 2); for (int i = 0; i < B.chain.Str_L[k] + 2; ++i) ln_FunctionG[i] = ln_Fn_G (A, B, k, beta, i); - + sum1 = 0.0; - + sum1 += Fn_K (A, j, alpha, a, B, k, beta, 0) * exp(ln_FunctionG[0] + ln_FunctionG[1] - ln_FunctionF[0] - ln_FunctionF[1]); - - sum1 += Fn_K (A, j, alpha, a, B, k, beta, B.chain.Str_L[k]) - * exp(ln_FunctionG[B.chain.Str_L[k]] + ln_FunctionG[B.chain.Str_L[k] + 1] + + sum1 += Fn_K (A, j, alpha, a, B, k, beta, B.chain.Str_L[k]) + * exp(ln_FunctionG[B.chain.Str_L[k]] + ln_FunctionG[B.chain.Str_L[k] + 1] - ln_FunctionF[B.chain.Str_L[k]] - ln_FunctionF[B.chain.Str_L[k] + 1]); - - for (int jsum = 1; jsum < B.chain.Str_L[k]; ++jsum) - + + for (int jsum = 1; jsum < B.chain.Str_L[k]; ++jsum) + sum1 -= Fn_L (A, j, alpha, a, B, k, beta, jsum) * exp(ln_FunctionG[jsum] + ln_FunctionG[jsum + 1] - ln_FunctionF[jsum] - ln_FunctionF[jsum + 1]); - + /* sum2 = 0.0; - + for (int jsum = 1; jsum <= B.chain.Str_L[k]; ++jsum) sum2 += exp(ln_FunctionG[jsum] - ln_FunctionF[jsum]); - + */ prod_num = exp(II * im_ln_Fn_F_B_0[k][beta] + ln_FunctionF[1] - ln_FunctionG[B.chain.Str_L[k]]); - for (int jsum = 2; jsum <= B.chain.Str_L[k]; ++jsum) - prod_num *= exp(ln_FunctionG[jsum] - real(ln_Fn_F(B, k, beta, jsum - 1))); + for (int jsum = 2; jsum <= B.chain.Str_L[k]; ++jsum) + prod_num *= exp(ln_FunctionG[jsum] - real(ln_Fn_F(B, k, beta, jsum - 1))); // include all string contributions F_B_0 in this term Hm[index_a][index_b] = prod_num * sum1; } // else if (b == B.chain.Str_L[k]) - } // else + } // else index_b++; }}} // sums over k, beta, b // now define the elements Hm[a][M] - Hm[index_a][B.base.Mdown] = one_over_A_lambda_sq_plus_1over2sq; + Hm[index_a][B.base.Mdown] = one_over_A_lambda_sq_plus_1over2sq; index_a++; }}} // sums over j, alpha, a @@ -236,4 +251,4 @@ complex ln_Smin_ME (XXX_Bethe_State& A, XXX_Bethe_State& B) } -} // namespace JSC +} // namespace ABACUS diff --git a/src/HEIS/ln_Smin_ME_XXZ.cc b/src/HEIS/ln_Smin_ME_XXZ.cc index 6a3aef7..edad51c 100644 --- a/src/HEIS/ln_Smin_ME_XXZ.cc +++ b/src/HEIS/ln_Smin_ME_XXZ.cc @@ -1,8 +1,23 @@ -#include "JSC.h" +/********************************************************** -using namespace JSC; +This software is part of J.-S. Caux's ABACUS library. -namespace JSC { +Copyright (c) J.-S. Caux. + +----------------------------------------------------------- + +File: ln_Smin_ME_XXZ.cc + +Purpose: compute the S^- matrix elemment for XXZ + +***********************************************************/ + +#include "ABACUS.h" + +using namespace std; +using namespace ABACUS; + +namespace ABACUS { inline complex ln_Fn_F (XXZ_Bethe_State& B, int k, int beta, int b) { @@ -25,19 +40,19 @@ inline complex ln_Fn_F (XXZ_Bethe_State& B, int k, int beta, int b) arg = B.chain.Str_L[j] - B.chain.Str_L[k] - 2 * (a - b); absarg = abs(arg); - /* + /* prod_temp *= 0.5 * //done later... - ((B.sinhlambda[j][alpha] * B.coshlambda[k][beta] - B.coshlambda[j][alpha] * B.sinhlambda[k][beta]) - * (B.chain.co_n_anis_over_2[absarg] * (1.0 + B.chain.par[j] * B.chain.par[k]) + ((B.sinhlambda[j][alpha] * B.coshlambda[k][beta] - B.coshlambda[j][alpha] * B.sinhlambda[k][beta]) + * (B.chain.co_n_anis_over_2[absarg] * (1.0 + B.chain.par[j] * B.chain.par[k]) - sgn_int(arg) * B.chain.si_n_anis_over_2[absarg] * (B.chain.par[k] - B.chain.par[j])) - + II * (B.coshlambda[j][alpha] * B.coshlambda[k][beta] - B.sinhlambda[j][alpha] * B.sinhlambda[k][beta]) + + II * (B.coshlambda[j][alpha] * B.coshlambda[k][beta] - B.sinhlambda[j][alpha] * B.sinhlambda[k][beta]) * (sgn_int(arg) * B.chain.si_n_anis_over_2[absarg] * (1.0 + B.chain.par[j] * B.chain.par[k]) + B.chain.co_n_anis_over_2[absarg] * (B.chain.par[k] - B.chain.par[j])) ); */ - prod_temp *= ((B.sinhlambda[j][alpha] * B.coshlambda[k][beta] - B.coshlambda[j][alpha] * B.sinhlambda[k][beta]) + prod_temp *= ((B.sinhlambda[j][alpha] * B.coshlambda[k][beta] - B.coshlambda[j][alpha] * B.sinhlambda[k][beta]) * (B.chain.co_n_anis_over_2[absarg] * par_comb_1 - sgn_int(arg) * B.chain.si_n_anis_over_2[absarg] * par_comb_2) - + II * (B.coshlambda[j][alpha] * B.coshlambda[k][beta] - B.sinhlambda[j][alpha] * B.sinhlambda[k][beta]) + + II * (B.coshlambda[j][alpha] * B.coshlambda[k][beta] - B.sinhlambda[j][alpha] * B.sinhlambda[k][beta]) * (sgn_int(arg) * B.chain.si_n_anis_over_2[absarg] * par_comb_1 + B.chain.co_n_anis_over_2[absarg] * par_comb_2)); } @@ -73,16 +88,16 @@ inline complex ln_Fn_G (XXZ_Bethe_State& A, XXZ_Bethe_State& B, int k, int b absarg = abs(arg); /* prod_temp *= 0.5 * //done later... - ((A.sinhlambda[j][alpha] * B.coshlambda[k][beta] - A.coshlambda[j][alpha] * B.sinhlambda[k][beta]) + ((A.sinhlambda[j][alpha] * B.coshlambda[k][beta] - A.coshlambda[j][alpha] * B.sinhlambda[k][beta]) * (A.chain.co_n_anis_over_2[absarg] * (1.0 + A.chain.par[j] * B.chain.par[k]) - sgn_int(arg) * A.chain.si_n_anis_over_2[absarg] * (B.chain.par[k] - A.chain.par[j])) - + II * (A.coshlambda[j][alpha] * B.coshlambda[k][beta] - A.sinhlambda[j][alpha] * B.sinhlambda[k][beta]) + + II * (A.coshlambda[j][alpha] * B.coshlambda[k][beta] - A.sinhlambda[j][alpha] * B.sinhlambda[k][beta]) * (sgn_int(arg) * A.chain.si_n_anis_over_2[absarg] * (1.0 + A.chain.par[j] * B.chain.par[k]) + A.chain.co_n_anis_over_2[absarg] * (B.chain.par[k] - A.chain.par[j])) ); */ - prod_temp *= ((A.sinhlambda[j][alpha] * B.coshlambda[k][beta] - A.coshlambda[j][alpha] * B.sinhlambda[k][beta]) + prod_temp *= ((A.sinhlambda[j][alpha] * B.coshlambda[k][beta] - A.coshlambda[j][alpha] * B.sinhlambda[k][beta]) * (A.chain.co_n_anis_over_2[absarg] * par_comb_1 - sgn_int(arg) * A.chain.si_n_anis_over_2[absarg] * par_comb_2) - + II * (A.coshlambda[j][alpha] * B.coshlambda[k][beta] - A.sinhlambda[j][alpha] * B.sinhlambda[k][beta]) + + II * (A.coshlambda[j][alpha] * B.coshlambda[k][beta] - A.sinhlambda[j][alpha] * B.sinhlambda[k][beta]) * (sgn_int(arg) * A.chain.si_n_anis_over_2[absarg] * par_comb_1 + A.chain.co_n_anis_over_2[absarg] * par_comb_2)); if (counter++ > 100) { // we do at most 100 products before taking a log @@ -103,17 +118,17 @@ inline complex Fn_K (XXZ_Bethe_State& A, int j, int alpha, int a, XXZ_Bethe_ int absarg2 = abs(arg2); return(4.0/( - ((A.sinhlambda[j][alpha] * B.coshlambda[k][beta] - A.coshlambda[j][alpha] * B.sinhlambda[k][beta]) + ((A.sinhlambda[j][alpha] * B.coshlambda[k][beta] - A.coshlambda[j][alpha] * B.sinhlambda[k][beta]) * (A.chain.co_n_anis_over_2[absarg1] * (1.0 + A.chain.par[j] * B.chain.par[k]) - sgn_int(arg1) * A.chain.si_n_anis_over_2[absarg1] * (B.chain.par[k] - A.chain.par[j])) - + II * (A.coshlambda[j][alpha] * B.coshlambda[k][beta] - A.sinhlambda[j][alpha] * B.sinhlambda[k][beta]) + + II * (A.coshlambda[j][alpha] * B.coshlambda[k][beta] - A.sinhlambda[j][alpha] * B.sinhlambda[k][beta]) * (sgn_int(arg1) * A.chain.si_n_anis_over_2[absarg1] * (1.0 + A.chain.par[j] * B.chain.par[k]) + A.chain.co_n_anis_over_2[absarg1] * (B.chain.par[k] - A.chain.par[j])) ) * - ((A.sinhlambda[j][alpha] * B.coshlambda[k][beta] - A.coshlambda[j][alpha] * B.sinhlambda[k][beta]) + ((A.sinhlambda[j][alpha] * B.coshlambda[k][beta] - A.coshlambda[j][alpha] * B.sinhlambda[k][beta]) * (A.chain.co_n_anis_over_2[absarg2] * (1.0 + A.chain.par[j] * B.chain.par[k]) - sgn_int(arg2) * A.chain.si_n_anis_over_2[absarg2] * (B.chain.par[k] - A.chain.par[j])) - + II * (A.coshlambda[j][alpha] * B.coshlambda[k][beta] - A.sinhlambda[j][alpha] * B.sinhlambda[k][beta]) + + II * (A.coshlambda[j][alpha] * B.coshlambda[k][beta] - A.sinhlambda[j][alpha] * B.sinhlambda[k][beta]) * (sgn_int(arg2) * A.chain.si_n_anis_over_2[absarg2] * (1.0 + A.chain.par[j] * B.chain.par[k]) + A.chain.co_n_anis_over_2[absarg2] * (B.chain.par[k] - A.chain.par[j])) ) )); @@ -123,8 +138,8 @@ inline complex Fn_K (XXZ_Bethe_State& A, int j, int alpha, int a, XXZ_Bethe_ inline complex Fn_L (XXZ_Bethe_State& A, int j, int alpha, int a, XXZ_Bethe_State& B, int k, int beta, int b) { return (sinh(2.0 * (A.lambda[j][alpha] - B.lambda[k][beta] - + 0.5 * II * B.chain.anis * (A.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b - 0.5)) - + 0.25 * II * PI * complex(-A.chain.par[j] + B.chain.par[k]))) + + 0.5 * II * B.chain.anis * (A.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b - 0.5)) + + 0.25 * II * PI * complex(-A.chain.par[j] + B.chain.par[k]))) * pow(Fn_K (A, j, alpha, a, B, k, beta, b), 2.0)); } @@ -135,14 +150,14 @@ complex ln_Smin_ME (XXZ_Bethe_State& A, XXZ_Bethe_State& B) // Check that the two states are compatible - if (A.chain != B.chain) JSCerror("Incompatible XXZ_Chains in Smin matrix element."); + if (A.chain != B.chain) ABACUSerror("Incompatible XXZ_Chains in Smin matrix element."); - // Check that A and B are Mdown-compatible: + // Check that A and B are Mdown-compatible: if (A.base.Mdown != B.base.Mdown + 1) { cout << "A.base.Mdown = " << A.base.Mdown << "\tB.base.Mdown = " << B.base.Mdown << endl; cout << "A: " << A << endl << "B: " << B << endl; - JSCerror("Incompatible Mdown between the two states in Smin matrix element!"); + ABACUSerror("Incompatible Mdown between the two states in Smin matrix element!"); } // Compute the sinh and cosh of rapidities @@ -166,13 +181,13 @@ complex ln_Smin_ME (XXZ_Bethe_State& A, XXZ_Bethe_State& B) complex ln_prod3 = 0.0; complex ln_prod4 = 0.0; - for (int i = 0; i < A.chain.Nstrings; ++i) + for (int i = 0; i < A.chain.Nstrings; ++i) for (int alpha = 0; alpha < A.base.Nrap[i]; ++alpha) for (int a = 1; a <= A.chain.Str_L[i]; ++a) ln_prod1 += log(norm(sinh(A.lambda[i][alpha] + 0.5 * II * A.chain.anis * (A.chain.Str_L[i] + 1.0 - 2.0 * a - 1.0) + 0.25 * II * PI * (1.0 - A.chain.par[i])))); - for (int i = 0; i < B.chain.Nstrings; ++i) + for (int i = 0; i < B.chain.Nstrings; ++i) for (int alpha = 0; alpha < B.base.Nrap[i]; ++alpha) for (int a = 1; a <= B.chain.Str_L[i]; ++a) if (norm(sinh(B.lambda[i][alpha] + 0.5 * II * B.chain.anis * (B.chain.Str_L[i] + 1.0 - 2.0 * a - 1.0) @@ -199,7 +214,7 @@ complex ln_Smin_ME (XXZ_Bethe_State& A, XXZ_Bethe_State& B) for (int j = 0; j < A.chain.Nstrings; ++j) for (int alpha = 0; alpha < A.base.Nrap[j]; ++alpha) - for (int a = 1; a <= A.chain.Str_L[j]; ++a) + for (int a = 1; a <= A.chain.Str_L[j]; ++a) ln_prod3 += ln_Fn_F(A, j, alpha, a - 1); // assume only one-strings here ln_prod3 -= A.base.Mdown * log(abs(sin(A.chain.anis))); @@ -210,7 +225,7 @@ complex ln_Smin_ME (XXZ_Bethe_State& A, XXZ_Bethe_State& B) if (b == 1) ln_prod4 += re_ln_Fn_F_B_0[k][beta]; else if (b > 1) ln_prod4 += ln_Fn_F(B, k, beta, b - 1); } - + ln_prod4 -= B.base.Mdown * log(abs(sin(B.chain.anis))); // Now proceed to build the Hm matrix @@ -232,11 +247,11 @@ complex ln_Smin_ME (XXZ_Bethe_State& A, XXZ_Bethe_State& B) for (int j = 0; j < A.chain.Nstrings; ++j) { for (int alpha = 0; alpha < A.base.Nrap[j]; ++alpha) { for (int a = 1; a <= A.chain.Str_L[j]; ++a) { - + index_b = 0; - + one_over_A_sinhlambda_sq_plus_sinzetaover2sq = 1.0/((sinh(A.lambda[j][alpha] + 0.5 * II * A.chain.anis * (A.chain.Str_L[j] + 1.0 - 2.0 * a) - + 0.25 * II * PI * (1.0 - A.chain.par[j]))) + + 0.25 * II * PI * (1.0 - A.chain.par[j]))) * (sinh(A.lambda[j][alpha] + 0.5 * II * A.chain.anis * (A.chain.Str_L[j] + 1.0 - 2.0 * a) + 0.25 * II * PI * (1.0 - A.chain.par[j]))) + pow(sin(0.5*A.chain.anis), 2.0)); @@ -249,12 +264,12 @@ complex ln_Smin_ME (XXZ_Bethe_State& A, XXZ_Bethe_State& B) // use simplified code for one-string here: original form of Hm matrix - Fn_K_0_G_0 = Fn_K (A, j, alpha, a, B, k, beta, 0) * + Fn_K_0_G_0 = Fn_K (A, j, alpha, a, B, k, beta, 0) * exp(re_ln_Fn_G_0[k][beta] + II * im_ln_Fn_G_0[k][beta] - re_ln_Fn_F_B_0[k][beta] + logabssinzeta); - Fn_K_1_G_2 = Fn_K (A, j, alpha, a, B, k, beta, 1) * + Fn_K_1_G_2 = Fn_K (A, j, alpha, a, B, k, beta, 1) * exp(re_ln_Fn_G_2[k][beta] + II * im_ln_Fn_G_2[k][beta] - re_ln_Fn_F_B_0[k][beta] + logabssinzeta); - Prod_powerN = pow( B.chain.par[k] == 1 ? + Prod_powerN = pow( B.chain.par[k] == 1 ? (B.sinhlambda[k][beta] * B.chain.co_n_anis_over_2[1] + II * B.coshlambda[k][beta] * B.chain.si_n_anis_over_2[1]) /(B.sinhlambda[k][beta] * B.chain.co_n_anis_over_2[1] - II * B.coshlambda[k][beta] * B.chain.si_n_anis_over_2[1]) : @@ -265,59 +280,59 @@ complex ln_Smin_ME (XXZ_Bethe_State& A, XXZ_Bethe_State& B) Hm[index_a][index_b] = Fn_K_0_G_0 - Prod_powerN * Fn_K_1_G_2; } // if (B.chain.Str_L == 1) - + else { if (b <= B.chain.Str_L[k] - 1) Hm[index_a][index_b] = Fn_K(A, j, alpha, a, B, k, beta, b); else if (b == B.chain.Str_L[k]) { - + Vect_CX ln_FunctionF(B.chain.Str_L[k] + 2); for (int i = 0; i < B.chain.Str_L[k] + 2; ++i) ln_FunctionF[i] = ln_Fn_F (B, k, beta, i); - + Vect_CX ln_FunctionG(B.chain.Str_L[k] + 2); for (int i = 0; i < B.chain.Str_L[k] + 2; ++i) ln_FunctionG[i] = ln_Fn_G (A, B, k, beta, i); - + sum1 = 0.0; - + sum1 += Fn_K (A, j, alpha, a, B, k, beta, 0) * exp(ln_FunctionG[0] + ln_FunctionG[1] - ln_FunctionF[0] - ln_FunctionF[1]); - - sum1 += Fn_K (A, j, alpha, a, B, k, beta, B.chain.Str_L[k]) - * exp(ln_FunctionG[B.chain.Str_L[k]] + ln_FunctionG[B.chain.Str_L[k] + 1] + + sum1 += Fn_K (A, j, alpha, a, B, k, beta, B.chain.Str_L[k]) + * exp(ln_FunctionG[B.chain.Str_L[k]] + ln_FunctionG[B.chain.Str_L[k] + 1] - ln_FunctionF[B.chain.Str_L[k]] - ln_FunctionF[B.chain.Str_L[k] + 1]); - - for (int jsum = 1; jsum < B.chain.Str_L[k]; ++jsum) - + + for (int jsum = 1; jsum < B.chain.Str_L[k]; ++jsum) + sum1 -= Fn_L (A, j, alpha, a, B, k, beta, jsum) * exp(ln_FunctionG[jsum] + ln_FunctionG[jsum + 1] - ln_FunctionF[jsum] - ln_FunctionF[jsum + 1]); - + /* sum2 = 0.0; - + for (int jsum = 1; jsum <= B.chain.Str_L[k]; ++jsum) sum2 += exp(ln_FunctionG[jsum] - ln_FunctionF[jsum]); - + */ prod_num = exp(II * im_ln_Fn_F_B_0[k][beta] + ln_FunctionF[1] - ln_FunctionG[B.chain.Str_L[k]] + logabssinzeta); - for (int jsum = 2; jsum <= B.chain.Str_L[k]; ++jsum) - prod_num *= exp(ln_FunctionG[jsum] - real(ln_Fn_F(B, k, beta, jsum - 1)) + logabssinzeta); + for (int jsum = 2; jsum <= B.chain.Str_L[k]; ++jsum) + prod_num *= exp(ln_FunctionG[jsum] - real(ln_Fn_F(B, k, beta, jsum - 1)) + logabssinzeta); // include all string contributions F_B_0 in this term Hm[index_a][index_b] = prod_num * sum1; } // else if (b == B.chain.Str_L[k]) - } // else + } // else index_b++; }}} // sums over k, beta, b // now define the elements Hm[a][M] - Hm[index_a][B.base.Mdown] = one_over_A_sinhlambda_sq_plus_sinzetaover2sq; + Hm[index_a][B.base.Mdown] = one_over_A_sinhlambda_sq_plus_sinzetaover2sq; index_a++; }}} // sums over j, alpha, a - complex ln_ME_sq = log(1.0 * A.chain.Nsites) + real(ln_prod1 - ln_prod2) - real(ln_prod3) + real(ln_prod4) + complex ln_ME_sq = log(1.0 * A.chain.Nsites) + real(ln_prod1 - ln_prod2) - real(ln_prod3) + real(ln_prod4) + 2.0 * real(lndet_LU_CX_dstry(Hm)) + logabssinzeta - A.lnnorm - B.lnnorm; //return(ln_ME_sq); @@ -325,4 +340,4 @@ complex ln_Smin_ME (XXZ_Bethe_State& A, XXZ_Bethe_State& B) } -} // namespace JSC +} // namespace ABACUS diff --git a/src/HEIS/ln_Smin_ME_XXZ_gpd.cc b/src/HEIS/ln_Smin_ME_XXZ_gpd.cc index f5c93be..8557b41 100644 --- a/src/HEIS/ln_Smin_ME_XXZ_gpd.cc +++ b/src/HEIS/ln_Smin_ME_XXZ_gpd.cc @@ -1,8 +1,23 @@ -#include "JSC.h" +/********************************************************** -using namespace JSC; +This software is part of J.-S. Caux's ABACUS library. -namespace JSC { +Copyright (c) J.-S. Caux. + +----------------------------------------------------------- + +File: ln_Smin_ME_XXZ_gpd.cc + +Purpose: compute the S^- matrix elemment for XXX_gpd + +***********************************************************/ + +#include "ABACUS.h" + +using namespace std; +using namespace ABACUS; + +namespace ABACUS { inline complex ln_Fn_F (XXZ_gpd_Bethe_State& B, int k, int beta, int b) { @@ -14,7 +29,7 @@ inline complex ln_Fn_F (XXZ_gpd_Bethe_State& B, int k, int beta, int b) for (int alpha = 0; alpha < B.base.Nrap[j]; ++alpha) { for (int a = 1; a <= B.chain.Str_L[j]; ++a) { /* - if (!((j == k) && (alpha == beta) && (a == b))) + if (!((j == k) && (alpha == beta) && (a == b))) ans += log(-II * sin(B.lambda[j][alpha] - B.lambda[k][beta] + 0.5 * II * B.chain.eta * (B.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b)))); */ @@ -23,10 +38,10 @@ inline complex ln_Fn_F (XXZ_gpd_Bethe_State& B, int k, int beta, int b) // arg = B.chain.Str_L[j] - B.chain.Str_L[k] - 2 * (a - b); // absarg = abs(arg); - + prod_temp *= -II * (B.sinlambda[j][alpha] * B.coslambda[k][beta] - B.coslambda[j][alpha] * B.sinlambda[k][beta]) * cosh(0.5 * B.chain.anis * (B.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b))) + - (B.coslambda[j][alpha] * B.coslambda[k][beta] + B.sinlambda[j][alpha] * B.sinlambda[k][beta]) + (B.coslambda[j][alpha] * B.coslambda[k][beta] + B.sinlambda[j][alpha] * B.sinlambda[k][beta]) * sinh(0.5 * B.chain.anis * (B.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b))); } @@ -81,7 +96,7 @@ inline complex Fn_K (XXZ_gpd_Bethe_State& A, int j, int alpha, int a, XXZ_gp { /* return(-1.0/(sin(A.lambda[j][alpha] - B.lambda[k][beta] - + 0.5 * II * B.chain.zeta * (A.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b))) + + 0.5 * II * B.chain.zeta * (A.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b))) * sin(A.lambda[j][alpha] - B.lambda[k][beta] + 0.5 * II * B.chain.zeta * (A.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b - 1.0))))); */ @@ -107,12 +122,12 @@ inline complex Fn_L (XXZ_gpd_Bethe_State& A, int j, int alpha, int a, XXZ_gp { /* complex ans = -II * sin(2.0 * (A.lambda[j][alpha] - B.lambda[k][beta] - + 0.5 * II * B.chain.zeta * (A.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b - 0.5)))); + + 0.5 * II * B.chain.zeta * (A.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b - 0.5)))); return (ans * pow(Fn_K (A, j, alpha, a, B, k, beta, b), 2.0)); */ return (-II * sin(2.0 * (A.lambda[j][alpha] - B.lambda[k][beta] - + 0.5 * II * B.chain.anis * (A.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b - 0.5)))) + + 0.5 * II * B.chain.anis * (A.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b - 0.5)))) * pow(Fn_K (A, j, alpha, a, B, k, beta, b), 2.0)); } @@ -123,11 +138,11 @@ complex ln_Smin_ME (XXZ_gpd_Bethe_State& A, XXZ_gpd_Bethe_State& B) // Check that the two states refer to the same XXZ_gpd_Chain - if (A.chain != B.chain) JSCerror("Incompatible XXZ_gpd_Chains in Smin matrix element."); + if (A.chain != B.chain) ABACUSerror("Incompatible XXZ_gpd_Chains in Smin matrix element."); // Check that A and B are compatible: same Mdown - if (A.base.Mdown != B.base.Mdown + 1) JSCerror("Incompatible Mdown between the two states in Smin matrix element!"); + if (A.base.Mdown != B.base.Mdown + 1) ABACUSerror("Incompatible Mdown between the two states in Smin matrix element!"); // Compute the sin and cos of rapidities @@ -150,12 +165,12 @@ complex ln_Smin_ME (XXZ_gpd_Bethe_State& A, XXZ_gpd_Bethe_State& B) complex ln_prod3 = 0.0; complex ln_prod4 = 0.0; - for (int i = 0; i < A.chain.Nstrings; ++i) + for (int i = 0; i < A.chain.Nstrings; ++i) for (int alpha = 0; alpha < A.base.Nrap[i]; ++alpha) for (int a = 1; a <= A.chain.Str_L[i]; ++a) ln_prod1 += log(norm(sin(A.lambda[i][alpha] + 0.5 * II * A.chain.anis * (A.chain.Str_L[i] + 1.0 - 2.0 * a - 1.0)))); - for (int i = 0; i < B.chain.Nstrings; ++i) + for (int i = 0; i < B.chain.Nstrings; ++i) for (int alpha = 0; alpha < B.base.Nrap[i]; ++alpha) for (int a = 1; a <= B.chain.Str_L[i]; ++a) if (norm(sin(B.lambda[i][alpha] + 0.5 * II * B.chain.anis * (B.chain.Str_L[i] + 1.0 - 2.0 * a - 1.0))) > 100.0 * MACHINE_EPS_SQ) @@ -182,8 +197,8 @@ complex ln_Smin_ME (XXZ_gpd_Bethe_State& A, XXZ_gpd_Bethe_State& B) for (int j = 0; j < A.chain.Nstrings; ++j) for (int alpha = 0; alpha < A.base.Nrap[j]; ++alpha) - for (int a = 1; a <= A.chain.Str_L[j]; ++a) - ln_prod3 += ln_Fn_F(A, j, alpha, a - 1); + for (int a = 1; a <= A.chain.Str_L[j]; ++a) + ln_prod3 += ln_Fn_F(A, j, alpha, a - 1); ln_prod3 -= A.base.Mdown * log(abs(sinh(A.chain.anis))); @@ -193,7 +208,7 @@ complex ln_Smin_ME (XXZ_gpd_Bethe_State& A, XXZ_gpd_Bethe_State& B) if (b == 1) ln_prod4 += re_ln_Fn_F_B_0[k][beta]; else if (b > 1) ln_prod4 += ln_Fn_F(B, k, beta, b - 1); } - + ln_prod4 -= B.base.Mdown * log(abs(sinh(B.chain.anis))); // Now proceed to build the Hm matrix @@ -214,15 +229,15 @@ complex ln_Smin_ME (XXZ_gpd_Bethe_State& A, XXZ_gpd_Bethe_State& B) for (int j = 0; j < A.chain.Nstrings; ++j) { for (int alpha = 0; alpha < A.base.Nrap[j]; ++alpha) { for (int a = 1; a <= A.chain.Str_L[j]; ++a) { - + index_b = 0; - + one_over_A_sinlambda_sq_plus_sinhetaover2sq = -1.0/((sin(A.lambda[j][alpha] // minus sign: from 1/(sinh^2... to -1/(sin^2... + 0.5 * II * A.chain.anis * (A.chain.Str_L[j] + 1.0 - 2.0 * a))) * (sin(A.lambda[j][alpha] // minus sign: from 1/(sinh^2... to -1/(sin^2... - + 0.5 * II * A.chain.anis * (A.chain.Str_L[j] + 1.0 - 2.0 * a))) + + 0.5 * II * A.chain.anis * (A.chain.Str_L[j] + 1.0 - 2.0 * a))) + pow(sinh(0.5*A.chain.anis), 2.0)); - + for (int k = 0; k < B.chain.Nstrings; ++k) { for (int beta = 0; beta < B.base.Nrap[k]; ++beta) { for (int b = 1; b <= B.chain.Str_L[k]; ++b) { @@ -231,63 +246,63 @@ complex ln_Smin_ME (XXZ_gpd_Bethe_State& A, XXZ_gpd_Bethe_State& B) // use simplified code for one-string here: original form of Hm2P matrix - Fn_K_0_G_0 = Fn_K (A, j, alpha, a, B, k, beta, 0) * + Fn_K_0_G_0 = Fn_K (A, j, alpha, a, B, k, beta, 0) * exp(re_ln_Fn_G_0[k][beta] + II * im_ln_Fn_G_0[k][beta] - re_ln_Fn_F_B_0[k][beta] + logabssinheta); - Fn_K_1_G_2 = Fn_K (A, j, alpha, a, B, k, beta, 1) * + Fn_K_1_G_2 = Fn_K (A, j, alpha, a, B, k, beta, 1) * exp(re_ln_Fn_G_2[k][beta] + II * im_ln_Fn_G_2[k][beta] - re_ln_Fn_F_B_0[k][beta] + logabssinheta); Prod_powerN = pow((B.sinlambda[k][beta] * B.chain.co_n_anis_over_2[1] + II * B.coslambda[k][beta] * B.chain.si_n_anis_over_2[1]) - /(B.sinlambda[k][beta] * B.chain.co_n_anis_over_2[1] - II * B.coslambda[k][beta] * B.chain.si_n_anis_over_2[1]), + /(B.sinlambda[k][beta] * B.chain.co_n_anis_over_2[1] - II * B.coslambda[k][beta] * B.chain.si_n_anis_over_2[1]), complex (B.chain.Nsites)); Hm[index_a][index_b] = Fn_K_0_G_0 - Prod_powerN * Fn_K_1_G_2; } - + else { if (b <= B.chain.Str_L[k] - 1) Hm[index_a][index_b] = Fn_K(A, j, alpha, a, B, k, beta, b); else if (b == B.chain.Str_L[k]) { - + Vect_CX ln_FunctionF(B.chain.Str_L[k] + 2); for (int i = 0; i < B.chain.Str_L[k] + 2; ++i) ln_FunctionF[i] = ln_Fn_F (B, k, beta, i); - + Vect_CX ln_FunctionG(B.chain.Str_L[k] + 2); for (int i = 0; i < B.chain.Str_L[k] + 2; ++i) ln_FunctionG[i] = ln_Fn_G (A, B, k, beta, i); - + sum1 = 0.0; - + sum1 += Fn_K (A, j, alpha, a, B, k, beta, 0) * exp(ln_FunctionG[0] + ln_FunctionG[1] - ln_FunctionF[0] - ln_FunctionF[1]); - - sum1 += Fn_K (A, j, alpha, a, B, k, beta, B.chain.Str_L[k]) - * exp(ln_FunctionG[B.chain.Str_L[k]] + ln_FunctionG[B.chain.Str_L[k] + 1] + + sum1 += Fn_K (A, j, alpha, a, B, k, beta, B.chain.Str_L[k]) + * exp(ln_FunctionG[B.chain.Str_L[k]] + ln_FunctionG[B.chain.Str_L[k] + 1] - ln_FunctionF[B.chain.Str_L[k]] - ln_FunctionF[B.chain.Str_L[k] + 1]); - - for (int jsum = 1; jsum < B.chain.Str_L[k]; ++jsum) - + + for (int jsum = 1; jsum < B.chain.Str_L[k]; ++jsum) + sum1 -= Fn_L (A, j, alpha, a, B, k, beta, jsum) * exp(ln_FunctionG[jsum] + ln_FunctionG[jsum + 1] - ln_FunctionF[jsum] - ln_FunctionF[jsum + 1]); - /* + /* sum2 = 0.0; - + for (int jsum = 1; jsum <= B.chain.Str_L[k]; ++jsum) sum2 += exp(ln_FunctionG[jsum] - ln_FunctionF[jsum]); - */ + */ prod_num = exp(II * im_ln_Fn_F_B_0[k][beta] + ln_FunctionF[1] - ln_FunctionG[B.chain.Str_L[k]] + logabssinheta); - for (int jsum = 2; jsum <= B.chain.Str_L[k]; ++jsum) - prod_num *= exp(ln_FunctionG[jsum] - real(ln_Fn_F(B, k, beta, jsum - 1)) + logabssinheta); + for (int jsum = 2; jsum <= B.chain.Str_L[k]; ++jsum) + prod_num *= exp(ln_FunctionG[jsum] - real(ln_Fn_F(B, k, beta, jsum - 1)) + logabssinheta); // include all string contributions F_B_0 in this term Hm[index_a][index_b] = prod_num * sum1; } // else if (b == B.chain.Str_L[k]) - } // else + } // else index_b++; }}} // sums over k, beta, b // now define the elements Hm[a][M] - Hm[index_a][B.base.Mdown] = one_over_A_sinlambda_sq_plus_sinhetaover2sq; + Hm[index_a][B.base.Mdown] = one_over_A_sinlambda_sq_plus_sinhetaover2sq; index_a++; }}} // sums over j, alpha, a @@ -300,4 +315,4 @@ complex ln_Smin_ME (XXZ_gpd_Bethe_State& A, XXZ_gpd_Bethe_State& B) } -} // namespace JSC +} // namespace ABACUS diff --git a/src/HEIS/ln_Smm_ME_XXX.cc b/src/HEIS/ln_Smm_ME_XXX.cc index 7975319..d71c399 100644 --- a/src/HEIS/ln_Smm_ME_XXX.cc +++ b/src/HEIS/ln_Smm_ME_XXX.cc @@ -1,8 +1,23 @@ -#include "JSC.h" +/********************************************************** -using namespace JSC; +This software is part of J.-S. Caux's ABACUS library. -namespace JSC { +Copyright (c) J.-S. Caux. + +----------------------------------------------------------- + +File: ln_Smm_ME_XXX.cc + +Purpose: compute the S^-_j S^-_{j+1} matrix elemment for XXX + +***********************************************************/ + +#include "ABACUS.h" + +using namespace std; +using namespace ABACUS; + +namespace ABACUS { inline complex phi(complex x){return x;} inline complex a(complex x){return 1;} inline complex b(complex x,complex y, complex eta){ return phi(x-y)/phi(x-y+complex(0.0,1.0)*eta);} @@ -17,12 +32,12 @@ inline complex ln_Fn_F (XXX_Bethe_State& B, int k, int beta, int b) for (int alpha = 0; alpha < B.base.Nrap[j]; ++alpha) { for (int a = 1; a <= B.chain.Str_L[j]; ++a) { - if (!((j == k) && (alpha == beta) && (a == b))) + if (!((j == k) && (alpha == beta) && (a == b))) ans += log(B.lambda[j][alpha] - B.lambda[k][beta] - + 0.5 * II * (B.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b))); + + 0.5 * II * (B.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b))); } } - } + } return(ans); } @@ -53,14 +68,14 @@ inline complex Fn_K (XXX_Bethe_State& A, int j, int alpha, int a, XXX_Bethe_ + 0.5 * II * (A.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b))) * (A.lambda[j][alpha] - B.lambda[k][beta] + 0.5 * II * (A.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b - 1.0)) ))); - + } inline complex Fn_L (XXX_Bethe_State& A, int j, int alpha, int a, XXX_Bethe_State& B, int k, int beta, int b) { return ((2.0 * (A.lambda[j][alpha] - B.lambda[k][beta] - + 0.5 * II * (A.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b - 0.5)) - )) + + 0.5 * II * (A.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b - 0.5)) + )) * pow(Fn_K (A, j, alpha, a, B, k, beta, b), 2.0)); } @@ -79,12 +94,12 @@ const DP real_dev=1.0e-14; // Check that the two states refer to the same XXX_Chain - if (A.chain != B.chain) JSCerror("Incompatible XXX_Chains in Smm matrix element."); + if (A.chain != B.chain) ABACUSerror("Incompatible XXX_Chains in Smm matrix element."); // Check that A and B are compatible: same Mdown - if (A.base.Mdown != B.base.Mdown + 2) JSCerror("Incompatible Mdown between the two states in Smm matrix element!"); - + if (A.base.Mdown != B.base.Mdown + 2) ABACUSerror("Incompatible Mdown between the two states in Smm matrix element!"); + //if(B.String_delta()> HEIS_deltaprec) return(complex(-300.0)); // DEPRECATED in ++T_9 @@ -95,29 +110,29 @@ const DP real_dev=1.0e-14; complex ln_prod = complex(0.0,0.0); complex result=-300; complex prev_result=-300; - + XXX_Bethe_State B_origin; B_origin=B; bool zero_string=false; - for (int j = 0; j < B_origin.chain.Nstrings; ++j) + for (int j = 0; j < B_origin.chain.Nstrings; ++j) for (int alpha = 0; alpha < B_origin.base.Nrap[j]; ++alpha) if(abs(B_origin.lambda[j][alpha])* mu = new complex[sizeA]; complex* lam = new complex[sizeB]; int index=0; - for (int i = 0; i < A.chain.Nstrings; ++i) + for (int i = 0; i < A.chain.Nstrings; ++i) for (int alpha = 0; alpha < A.base.Nrap[i]; ++alpha) for (int a = 1; a <= A.chain.Str_L[i]; ++a) { @@ -144,7 +159,7 @@ int sizeB=0; } index=0; - for (int i = 0; i < B.chain.Nstrings; ++i) + for (int i = 0; i < B.chain.Nstrings; ++i) for (int alpha = 0; alpha < B.base.Nrap[i]; ++alpha) for (int a = 1; a <= B.chain.Str_L[i]; ++a) { @@ -166,7 +181,7 @@ for (int j = 0; j < B.chain.Nstrings; ++j) { re_ln_Fn_G_0[j][alpha] = real(ln_Fn_G(A, B, j, alpha, 0)); im_ln_Fn_G_0[j][alpha] = imag(ln_Fn_G(A, B, j, alpha, 0)); re_ln_Fn_G_2[j][alpha] = real(ln_Fn_G(A, B, j, alpha, 2)); - im_ln_Fn_G_2[j][alpha] = imag(ln_Fn_G(A, B, j, alpha, 2)); + im_ln_Fn_G_2[j][alpha] = imag(ln_Fn_G(A, B, j, alpha, 2)); } } @@ -175,12 +190,12 @@ for (int j = 0; j < B.chain.Nstrings; ++j) { complex ln_prod3 = 0.0; complex ln_prod4 = 0.0; - for (int i = 0; i < A.chain.Nstrings; ++i) + for (int i = 0; i < A.chain.Nstrings; ++i) for (int alpha = 0; alpha < A.base.Nrap[i]; ++alpha) for (int a = 1; a <= A.chain.Str_L[i]; ++a) ln_prod1 += log(norm(A.lambda[i][alpha] + 0.5 * II * (A.chain.Str_L[i] + 1.0 - 2.0 * a - 1.0))); - for (int i = 0; i < B.chain.Nstrings; ++i) + for (int i = 0; i < B.chain.Nstrings; ++i) for (int alpha = 0; alpha < B.base.Nrap[i]; ++alpha) for (int a = 1; a <= B.chain.Str_L[i]; ++a) if (norm(B.lambda[i][alpha] + 0.5 * II * (B.chain.Str_L[i] + 1.0 - 2.0 * a - 1.0)) > 100.0 * MACHINE_EPS_SQ) @@ -189,15 +204,15 @@ for (int j = 0; j < B.chain.Nstrings; ++j) { // Define regularized products in prefactors for (int j = 0; j < A.chain.Nstrings; ++j) for (int alpha = 0; alpha < A.base.Nrap[j]; ++alpha) - for (int a = 1; a <= A.chain.Str_L[j]; ++a) - ln_prod3 += ln_Fn_F(A, j, alpha, a - 1); + for (int a = 1; a <= A.chain.Str_L[j]; ++a) + ln_prod3 += ln_Fn_F(A, j, alpha, a - 1); for (int k = 0; k < B.chain.Nstrings; ++k) for (int beta = 0; beta < B.base.Nrap[k]; ++beta) for (int b = 1; b <= B.chain.Str_L[k]; ++b) { if (b == 1) ln_prod4 += re_ln_Fn_F_B_0[k][beta]; else if (b > 1) ln_prod4 += ln_Fn_F(B, k, beta, b - 1); - } + } result += 2.0*real(ln_prod1 - ln_prod2) - real(ln_prod3) + real(ln_prod4) - A.lnnorm - B.lnnorm; // Define the F ones earlier... @@ -209,23 +224,23 @@ for (int j = 0; j < B.chain.Nstrings; ++j) { //A -> mu, B -> lam SQMat_CX H(0.0, A.base.Mdown); index_a = 0; - + for (int j = 0; j < A.chain.Nstrings; ++j) { for (int alpha = 0; alpha < A.base.Nrap[j]; ++alpha) { for (int a = 1; a <= A.chain.Str_L[j]; ++a) { - + index_b = 0; complex Da; complex Ca; Da=eta/((mu[index_a]-eta*0.5)*(mu[index_a]+eta*0.5)); Ca=eta*((mu[index_a]-eta*0.5)+(mu[index_a]+eta*0.5))/pow(((mu[index_a]-eta*0.5)*(mu[index_a]+eta*0.5)),2.0); - - + + for (int k = 0; k < B.chain.Nstrings; ++k) { for (int beta = 0; beta < B.base.Nrap[k]; ++beta) { for (int b = 1; b <= B.chain.Str_L[k]; ++b) { - + if (B.chain.Str_L[k] == 1) { @@ -238,49 +253,49 @@ SQMat_CX H(0.0, A.base.Mdown); prodminus = Fn_K (A, j, alpha, a, B, k, beta, 1);// 1.0/ (phi(mu[l]-lam[k]) phi(mu[l]-lam[k]-eta) ) prodminus*= exp(re_ln_Fn_G_2[k][beta] + II * im_ln_Fn_G_2[k][beta] - re_ln_Fn_F_B_0[k][beta]);//Prod phi(mu[l]-lam[k]-eta)/ prod_l!=k | phi(lam[l]-lam[k]) |; - + Prod_powerN = pow((B.lambda[k][beta] - eta*0.5) /(B.lambda[k][beta] + eta*0.5), complex (B.chain.Nsites)); H[index_a][index_b] =eta*(prodplus-prodminus*Prod_powerN); } // if (B.chain.Str_L == 1) - + else { // */{ - - if (b > 1){ + + if (b > 1){ H[index_a][index_b] = eta* Fn_K(A, j, alpha, a, B, k, beta, b-1)*exp(ln_Fn_G(A,B,k,beta,b-1))*exp(-real(ln_Fn_F(B, k, beta, b - 1)));//.../ prod_l!=k | phi(lam[l]-lam[k]) | } else if (b == 1) { - + Vect_CX ln_FunctionF(B.chain.Str_L[k] + 2); for (int i = 0; i < B.chain.Str_L[k] + 2; ++i) ln_FunctionF[i] = ln_Fn_F (B, k, beta, i); - + Vect_CX ln_FunctionG(B.chain.Str_L[k] + 2); for (int i = 0; i < B.chain.Str_L[k] + 2; ++i) ln_FunctionG[i] = ln_Fn_G (A, B, k, beta, i); - + complex sum1 = complex(0.0,0.0); - - sum1 += Fn_K (A, j, alpha, a, B, k, beta, 0) *exp(ln_FunctionG[0]+ ln_FunctionG[1] + + sum1 += Fn_K (A, j, alpha, a, B, k, beta, 0) *exp(ln_FunctionG[0]+ ln_FunctionG[1] - ln_FunctionF[0] - ln_FunctionF[1]);//sum term when i=0 - + sum1 += Fn_K (A, j, alpha, a, B, k, beta, B.chain.Str_L[k]) * exp( ln_FunctionG[B.chain.Str_L[k]] + ln_FunctionG[B.chain.Str_L[k] + 1] - ln_FunctionF[B.chain.Str_L[k]] - ln_FunctionF[B.chain.Str_L[k] + 1]); //sum term when i=n - - - for (int jsum = 1; jsum < B.chain.Str_L[k]; ++jsum) { + + + for (int jsum = 1; jsum < B.chain.Str_L[k]; ++jsum) { sum1 -= Fn_L (A, j, alpha, a, B, k, beta, jsum) * exp(ln_FunctionG[jsum] + ln_FunctionG[jsum + 1] - ln_FunctionF[jsum] - ln_FunctionF[jsum + 1]); - + } H[index_a][index_b] = eta * exp(ln_FunctionF[0]+ ln_FunctionF[1] - ln_FunctionG[1]) * sum1 * exp( - real(ln_Fn_F(B, k, beta, b - 1))); //the absolute value prod_l!=k phi(lam[l]-lam[k]) : real(ln_...) } // else if (b == B.chain.Str_L[k]) - } // else + } // else index_b++; }}} // sums over k, beta, b - + // now define the elements H[a][M] & H[a][M-1] - H[index_a][B.base.Mdown]=Da; + H[index_a][B.base.Mdown]=Da; H[index_a][B.base.Mdown+1]=Ca; index_a++; }}} // sums over j, alpha, a @@ -290,7 +305,7 @@ SQMat_CX H(0.0, A.base.Mdown); result+=log(2.0)-log((A.chain.Nsites-A.base.Mdown*2+3.0)*((A.chain.Nsites-A.base.Mdown*2+4.0))); if (!(real_dev_conv) && abs(exp(result)-exp(prev_result))20){ result=-300; real_dev_conv=true; @@ -303,5 +318,5 @@ SQMat_CX H(0.0, A.base.Mdown); //return(result); return(0.5 * result); // Return ME, not MEsq } - -} // namespace JSC + +} // namespace ABACUS diff --git a/src/HEIS/ln_Sz_ME_XXX.cc b/src/HEIS/ln_Sz_ME_XXX.cc index aeeb41f..39d9ae6 100644 --- a/src/HEIS/ln_Sz_ME_XXX.cc +++ b/src/HEIS/ln_Sz_ME_XXX.cc @@ -1,18 +1,23 @@ /********************************************************** -This software is part of J.-S. Caux's ABACUS++ library. +This software is part of J.-S. Caux's ABACUS library. -Copyright (c) +Copyright (c) J.-S. Caux. ----------------------------------------------------------- +File: ln_Sz_ME_XXX.cc + +Purpose: compute the S^z matrix elemment for XXX + ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" -using namespace JSC; +using namespace std; +using namespace ABACUS; -namespace JSC { +namespace ABACUS { inline complex ln_Fn_F (XXX_Bethe_State& B, int k, int beta, int b) { @@ -22,9 +27,9 @@ inline complex ln_Fn_F (XXX_Bethe_State& B, int k, int beta, int b) for (int alpha = 0; alpha < B.base.Nrap[j]; ++alpha) { for (int a = 1; a <= B.chain.Str_L[j]; ++a) { - if (!((j == k) && (alpha == beta) && (a == b))) + if (!((j == k) && (alpha == beta) && (a == b))) ans += log(B.lambda[j][alpha] - B.lambda[k][beta] - + 0.5 * II * (B.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b))); + + 0.5 * II * (B.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b))); } } } @@ -60,8 +65,8 @@ inline complex Fn_K (XXX_Bethe_State& A, int j, int alpha, int a, XXX_Bethe_ inline complex Fn_L (XXX_Bethe_State& A, int j, int alpha, int a, XXX_Bethe_State& B, int k, int beta, int b) { return ((2.0 * (A.lambda[j][alpha] - B.lambda[k][beta] - + 0.5 * II * (A.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b - 0.5)) - )) + + 0.5 * II * (A.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b - 0.5)) + )) * pow(Fn_K (A, j, alpha, a, B, k, beta, b), 2.0)); } @@ -72,11 +77,11 @@ complex ln_Sz_ME (XXX_Bethe_State& A, XXX_Bethe_State& B) // Check that the two states refer to the same XXX_Chain - if (A.chain != B.chain) JSCerror("Incompatible XXX_Chains in Sz matrix element."); + if (A.chain != B.chain) ABACUSerror("Incompatible XXX_Chains in Sz matrix element."); // Check that A and B are compatible: same Mdown - if (A.base.Mdown != B.base.Mdown) JSCerror("Incompatible Mdown between the two states in Sz matrix element!"); + if (A.base.Mdown != B.base.Mdown) ABACUSerror("Incompatible Mdown between the two states in Sz matrix element!"); //if (A.iK == B.iK && (A.label != B.label)) if (A.iK == B.iK && (A.label.compare(B.label) != 0)) @@ -96,12 +101,12 @@ complex ln_Sz_ME (XXX_Bethe_State& A, XXX_Bethe_State& B) complex ln_prod3 = 0.0; complex ln_prod4 = 0.0; - for (int i = 0; i < A.chain.Nstrings; ++i) + for (int i = 0; i < A.chain.Nstrings; ++i) for (int alpha = 0; alpha < A.base.Nrap[i]; ++alpha) for (int a = 1; a <= A.chain.Str_L[i]; ++a) ln_prod1 += log(norm((A.lambda[i][alpha] + 0.5 * II * (A.chain.Str_L[i] + 1.0 - 2.0 * a - 1.0)))); - for (int i = 0; i < B.chain.Nstrings; ++i) + for (int i = 0; i < B.chain.Nstrings; ++i) for (int alpha = 0; alpha < B.base.Nrap[i]; ++alpha) for (int a = 1; a <= B.chain.Str_L[i]; ++a) if (norm((B.lambda[i][alpha] + 0.5 * II * (B.chain.Str_L[i] + 1.0 - 2.0 * a - 1.0))) > 100.0 * MACHINE_EPS_SQ) @@ -124,8 +129,8 @@ complex ln_Sz_ME (XXX_Bethe_State& A, XXX_Bethe_State& B) for (int j = 0; j < A.chain.Nstrings; ++j) for (int alpha = 0; alpha < A.base.Nrap[j]; ++alpha) - for (int a = 1; a <= A.chain.Str_L[j]; ++a) - ln_prod3 += ln_Fn_F (A, j, alpha, a - 1); + for (int a = 1; a <= A.chain.Str_L[j]; ++a) + ln_prod3 += ln_Fn_F (A, j, alpha, a - 1); // ln_prod3 -= A.base.Mdown * log(abs(sin(A.chain.zeta))); @@ -135,7 +140,7 @@ complex ln_Sz_ME (XXX_Bethe_State& A, XXX_Bethe_State& B) if (b == 1) ln_prod4 += re_ln_Fn_F_B_0[k][beta]; else if (b > 1) ln_prod4 += ln_Fn_F(B, k, beta, b - 1); } - + // ln_prod4 -= B.base.Mdown * log(abs(sin(B.chain.zeta))); // Now proceed to build the Hm2P matrix @@ -156,12 +161,12 @@ complex ln_Sz_ME (XXX_Bethe_State& A, XXX_Bethe_State& B) for (int j = 0; j < A.chain.Nstrings; ++j) { for (int alpha = 0; alpha < A.base.Nrap[j]; ++alpha) { for (int a = 1; a <= A.chain.Str_L[j]; ++a) { - + index_b = 0; two_over_A_lambda_sq_plus_1over2sq = 2.0/((A.lambda[j][alpha] + 0.5 * II * (A.chain.Str_L[j] + 1.0 - 2.0 * a)) * (A.lambda[j][alpha] + 0.5 * II * (A.chain.Str_L[j] + 1.0 - 2.0 * a)) + 0.25); - + for (int k = 0; k < B.chain.Nstrings; ++k) { for (int beta = 0; beta < B.base.Nrap[k]; ++beta) { for (int b = 1; b <= B.chain.Str_L[k]; ++b) { @@ -181,44 +186,44 @@ complex ln_Sz_ME (XXX_Bethe_State& A, XXX_Bethe_State& B) - two_over_A_lambda_sq_plus_1over2sq * exp(II*im_ln_Fn_F_B_0[k][beta]); } - + else { if (b <= B.chain.Str_L[k] - 1) Hm2P[index_a][index_b] = Fn_K(A, j, alpha, a, B, k, beta, b); else if (b == B.chain.Str_L[k]) { - + Vect_CX ln_FunctionF(B.chain.Str_L[k] + 2); for (int i = 0; i < B.chain.Str_L[k] + 2; ++i) ln_FunctionF[i] = ln_Fn_F (B, k, beta, i); - + Vect_CX ln_FunctionG(B.chain.Str_L[k] + 2); for (int i = 0; i < B.chain.Str_L[k] + 2; ++i) ln_FunctionG[i] = ln_Fn_G (A, B, k, beta, i); sum1 = 0.0; - + sum1 += Fn_K (A, j, alpha, a, B, k, beta, 0) * exp(ln_FunctionG[0] + ln_FunctionG[1] - ln_FunctionF[0] - ln_FunctionF[1]); - - sum1 += Fn_K (A, j, alpha, a, B, k, beta, B.chain.Str_L[k]) - * exp(ln_FunctionG[B.chain.Str_L[k]] + ln_FunctionG[B.chain.Str_L[k] + 1] + + sum1 += Fn_K (A, j, alpha, a, B, k, beta, B.chain.Str_L[k]) + * exp(ln_FunctionG[B.chain.Str_L[k]] + ln_FunctionG[B.chain.Str_L[k] + 1] - ln_FunctionF[B.chain.Str_L[k]] - ln_FunctionF[B.chain.Str_L[k] + 1]); - - for (int jsum = 1; jsum < B.chain.Str_L[k]; ++jsum) - + + for (int jsum = 1; jsum < B.chain.Str_L[k]; ++jsum) + sum1 -= Fn_L (A, j, alpha, a, B, k, beta, jsum) * exp(ln_FunctionG[jsum] + ln_FunctionG[jsum + 1] - ln_FunctionF[jsum] - ln_FunctionF[jsum + 1]); - + sum2 = 0.0; - + for (int jsum = 1; jsum <= B.chain.Str_L[k]; ++jsum) sum2 += exp(ln_FunctionG[jsum] - ln_FunctionF[jsum]); - + prod_num = exp(II * im_ln_Fn_F_B_0[k][beta] + ln_FunctionF[1] - ln_FunctionG[B.chain.Str_L[k]]); - for (int jsum = 2; jsum <= B.chain.Str_L[k]; ++jsum) + for (int jsum = 2; jsum <= B.chain.Str_L[k]; ++jsum) prod_num *= exp(ln_FunctionG[jsum] - real(ln_Fn_F(B, k, beta, jsum - 1))); // include all string contributions F_B_0 in this term Hm2P[index_a][index_b] = prod_num * (sum1 - sum2 * two_over_A_lambda_sq_plus_1over2sq); } // else if (b == B.chain.Str_L[k]) - } // else + } // else index_b++; }}} // sums over k, beta, b @@ -232,11 +237,11 @@ complex ln_Sz_ME (XXX_Bethe_State& A, XXX_Bethe_State& B) DP det = real(lndet_LU_CX_dstry(Hm2P)); complex ln_ME_sq = log(0.25 * A.chain.Nsites) + real(ln_prod1 - ln_prod2) - real(ln_prod3) + real(ln_prod4) - // + 2.0 * real(lndet_LU_CX_dstry(Hm2P)) + // + 2.0 * real(lndet_LU_CX_dstry(Hm2P)) + 2.0 * det - A.lnnorm - B.lnnorm; - //cout << "ln_Sz: " << endl << ln_prod1 << "\t" << -ln_prod2 << "\t" << -ln_prod3 << "\t" << ln_prod4 << "\t" << 2.0 * det + //cout << "ln_Sz: " << endl << ln_prod1 << "\t" << -ln_prod2 << "\t" << -ln_prod3 << "\t" << ln_prod4 << "\t" << 2.0 * det // << "\t" << -A.lnnorm << "\t" << -B.lnnorm << endl; //return(ln_ME_sq); @@ -244,4 +249,4 @@ complex ln_Sz_ME (XXX_Bethe_State& A, XXX_Bethe_State& B) } -} // namespace JSC +} // namespace ABACUS diff --git a/src/HEIS/ln_Sz_ME_XXZ.cc b/src/HEIS/ln_Sz_ME_XXZ.cc index d6d179e..0053262 100644 --- a/src/HEIS/ln_Sz_ME_XXZ.cc +++ b/src/HEIS/ln_Sz_ME_XXZ.cc @@ -1,8 +1,23 @@ -#include "JSC.h" +/********************************************************** -using namespace JSC; +This software is part of J.-S. Caux's ABACUS library. -namespace JSC { +Copyright (c) J.-S. Caux. + +----------------------------------------------------------- + +File: ln_Sz_ME_XXZ.cc + +Purpose: compute the S^z matrix elemment for XXZ + +***********************************************************/ + +#include "ABACUS.h" + +using namespace std; +using namespace ABACUS; + +namespace ABACUS { inline complex ln_Fn_F (XXZ_Bethe_State& B, int k, int beta, int b) { @@ -12,48 +27,48 @@ namespace JSC { int arg = 0; int absarg = 0; int par_comb_1, par_comb_2; - + for (int j = 0; j < B.chain.Nstrings; ++j) { - + par_comb_1 = B.chain.par[j] == B.chain.par[k] ? 1 : 0; par_comb_2 = B.chain.par[k] == B.chain.par[j] ? 0 : B.chain.par[k]; - + for (int alpha = 0; alpha < B.base.Nrap[j]; ++alpha) { - + for (int a = 1; a <= B.chain.Str_L[j]; ++a) { - + if (!((j == k) && (alpha == beta) && (a == b))) { - + arg = B.chain.Str_L[j] - B.chain.Str_L[k] - 2 * (a - b); absarg = abs(arg); /* - prod_temp *= 0.5 * - ((B.sinhlambda[j][alpha] * B.coshlambda[k][beta] - B.coshlambda[j][alpha] * B.sinhlambda[k][beta]) + prod_temp *= 0.5 * + ((B.sinhlambda[j][alpha] * B.coshlambda[k][beta] - B.coshlambda[j][alpha] * B.sinhlambda[k][beta]) * (B.chain.co_n_anis_over_2[absarg] * (1.0 + B.chain.par[j] * B.chain.par[k]) - sgn_int(arg) * B.chain.si_n_anis_over_2[absarg] * (B.chain.par[k] - B.chain.par[j])) - + II * (B.coshlambda[j][alpha] * B.coshlambda[k][beta] - B.sinhlambda[j][alpha] * B.sinhlambda[k][beta]) - * (sgn_int(arg) + + II * (B.coshlambda[j][alpha] * B.coshlambda[k][beta] - B.sinhlambda[j][alpha] * B.sinhlambda[k][beta]) + * (sgn_int(arg) * B.chain.si_n_anis_over_2[absarg] * (1.0 + B.chain.par[j] * B.chain.par[k]) + B.chain.co_n_anis_over_2[absarg] * (B.chain.par[k] - B.chain.par[j])) ); */ - prod_temp *= ((B.sinhlambda[j][alpha] * B.coshlambda[k][beta] - B.coshlambda[j][alpha] * B.sinhlambda[k][beta]) + prod_temp *= ((B.sinhlambda[j][alpha] * B.coshlambda[k][beta] - B.coshlambda[j][alpha] * B.sinhlambda[k][beta]) * (B.chain.co_n_anis_over_2[absarg] * par_comb_1 - sgn_int(arg) * B.chain.si_n_anis_over_2[absarg] * par_comb_2) - + II * (B.coshlambda[j][alpha] * B.coshlambda[k][beta] - B.sinhlambda[j][alpha] * B.sinhlambda[k][beta]) + + II * (B.coshlambda[j][alpha] * B.coshlambda[k][beta] - B.sinhlambda[j][alpha] * B.sinhlambda[k][beta]) * (sgn_int(arg) * B.chain.si_n_anis_over_2[absarg] * par_comb_1 + B.chain.co_n_anis_over_2[absarg] * par_comb_2)); - + } - + if (counter++ > 100) { // we do at most 100 products before taking a log ans += log(prod_temp); prod_temp = 1.0; counter = 0; } - + }}} - + return(ans + log(prod_temp)); } - + inline complex ln_Fn_G (XXZ_Bethe_State& A, XXZ_Bethe_State& B, int k, int beta, int b) { complex ans = 0.0; @@ -62,138 +77,138 @@ namespace JSC { int arg = 0; int absarg = 0; int par_comb_1, par_comb_2; - + for (int j = 0; j < A.chain.Nstrings; ++j) { - + par_comb_1 = A.chain.par[j] == B.chain.par[k] ? 1 : 0; par_comb_2 = B.chain.par[k] == A.chain.par[j] ? 0 : B.chain.par[k]; - + for (int alpha = 0; alpha < A.base.Nrap[j]; ++alpha) { - + for (int a = 1; a <= A.chain.Str_L[j]; ++a) { - + arg = A.chain.Str_L[j] - B.chain.Str_L[k] - 2 * (a - b); absarg = abs(arg); - + /* - prod_temp *= 0.5 * - ((A.sinhlambda[j][alpha] * B.coshlambda[k][beta] - A.coshlambda[j][alpha] * B.sinhlambda[k][beta]) + prod_temp *= 0.5 * + ((A.sinhlambda[j][alpha] * B.coshlambda[k][beta] - A.coshlambda[j][alpha] * B.sinhlambda[k][beta]) * (A.chain.co_n_anis_over_2[absarg] * (1.0 + A.chain.par[j] * B.chain.par[k]) - sgn_int(arg) * A.chain.si_n_anis_over_2[absarg] * (B.chain.par[k] - A.chain.par[j])) - + II * (A.coshlambda[j][alpha] * B.coshlambda[k][beta] - A.sinhlambda[j][alpha] * B.sinhlambda[k][beta]) + + II * (A.coshlambda[j][alpha] * B.coshlambda[k][beta] - A.sinhlambda[j][alpha] * B.sinhlambda[k][beta]) * (sgn_int(arg) * A.chain.si_n_anis_over_2[absarg] * (1.0 + A.chain.par[j] * B.chain.par[k]) + A.chain.co_n_anis_over_2[absarg] * (B.chain.par[k] - A.chain.par[j])) ); */ - prod_temp *= ((A.sinhlambda[j][alpha] * B.coshlambda[k][beta] - A.coshlambda[j][alpha] * B.sinhlambda[k][beta]) + prod_temp *= ((A.sinhlambda[j][alpha] * B.coshlambda[k][beta] - A.coshlambda[j][alpha] * B.sinhlambda[k][beta]) * (A.chain.co_n_anis_over_2[absarg] * par_comb_1 - sgn_int(arg) * A.chain.si_n_anis_over_2[absarg] * par_comb_2) - + II * (A.coshlambda[j][alpha] * B.coshlambda[k][beta] - A.sinhlambda[j][alpha] * B.sinhlambda[k][beta]) + + II * (A.coshlambda[j][alpha] * B.coshlambda[k][beta] - A.sinhlambda[j][alpha] * B.sinhlambda[k][beta]) * (sgn_int(arg) * A.chain.si_n_anis_over_2[absarg] * par_comb_1 + A.chain.co_n_anis_over_2[absarg] * par_comb_2)); - + if (counter++ > 100) { // we do at most 100 products before taking a log ans += log(prod_temp); prod_temp = 1.0; counter = 0; } }}} - + return(ans + log(prod_temp)); } - + inline complex Fn_K (XXZ_Bethe_State& A, int j, int alpha, int a, XXZ_Bethe_State& B, int k, int beta, int b) { int arg1 = A.chain.Str_L[j] - B.chain.Str_L[k] - 2 * (a - b); int absarg1 = abs(arg1); int arg2 = arg1 + 2; int absarg2 = abs(arg2); - + return(4.0/( - ((A.sinhlambda[j][alpha] * B.coshlambda[k][beta] - A.coshlambda[j][alpha] * B.sinhlambda[k][beta]) + ((A.sinhlambda[j][alpha] * B.coshlambda[k][beta] - A.coshlambda[j][alpha] * B.sinhlambda[k][beta]) * (A.chain.co_n_anis_over_2[absarg1] * (1.0 + A.chain.par[j] * B.chain.par[k]) - sgn_int(arg1) * A.chain.si_n_anis_over_2[absarg1] * (B.chain.par[k] - A.chain.par[j])) - + II * (A.coshlambda[j][alpha] * B.coshlambda[k][beta] - A.sinhlambda[j][alpha] * B.sinhlambda[k][beta]) + + II * (A.coshlambda[j][alpha] * B.coshlambda[k][beta] - A.sinhlambda[j][alpha] * B.sinhlambda[k][beta]) * (sgn_int(arg1) * A.chain.si_n_anis_over_2[absarg1] * (1.0 + A.chain.par[j] * B.chain.par[k]) + A.chain.co_n_anis_over_2[absarg1] * (B.chain.par[k] - A.chain.par[j])) ) * - ((A.sinhlambda[j][alpha] * B.coshlambda[k][beta] - A.coshlambda[j][alpha] * B.sinhlambda[k][beta]) + ((A.sinhlambda[j][alpha] * B.coshlambda[k][beta] - A.coshlambda[j][alpha] * B.sinhlambda[k][beta]) * (A.chain.co_n_anis_over_2[absarg2] * (1.0 + A.chain.par[j] * B.chain.par[k]) - sgn_int(arg2) * A.chain.si_n_anis_over_2[absarg2] * (B.chain.par[k] - A.chain.par[j])) - + II * (A.coshlambda[j][alpha] * B.coshlambda[k][beta] - A.sinhlambda[j][alpha] * B.sinhlambda[k][beta]) + + II * (A.coshlambda[j][alpha] * B.coshlambda[k][beta] - A.sinhlambda[j][alpha] * B.sinhlambda[k][beta]) * (sgn_int(arg2) * A.chain.si_n_anis_over_2[absarg2] * (1.0 + A.chain.par[j] * B.chain.par[k]) + A.chain.co_n_anis_over_2[absarg2] * (B.chain.par[k] - A.chain.par[j])) ) )); - + } - + inline complex Fn_L (XXZ_Bethe_State& A, int j, int alpha, int a, XXZ_Bethe_State& B, int k, int beta, int b) { return (sinh(2.0 * (A.lambda[j][alpha] - B.lambda[k][beta] - + 0.5 * II * B.chain.anis * (A.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b - 0.5)) - + 0.25 * II * PI * complex(-A.chain.par[j] + B.chain.par[k]))) + + 0.5 * II * B.chain.anis * (A.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b - 0.5)) + + 0.25 * II * PI * complex(-A.chain.par[j] + B.chain.par[k]))) * pow(Fn_K (A, j, alpha, a, B, k, beta, b), 2.0)); } - - + + // Version without phases: complex ln_Sz_ME (XXZ_Bethe_State& A, XXZ_Bethe_State& B) { // This function returns the natural log of the S^z operator matrix element. // The A and B states can contain strings. - + // Check that the two states refer to the same XXZ_Chain - + if (A.chain != B.chain) { - JSCerror("Incompatible XXZ_Chains in Sz matrix element."); + ABACUSerror("Incompatible XXZ_Chains in Sz matrix element."); } - + // Check that A and B are compatible: same Mdown - + if (A.base.Mdown != B.base.Mdown) { cout << "Bra state: " << endl << A << endl; cout << "Ket state: " << endl << B << endl; cout << A.base.Mdown << "\t" << B.base.Mdown << endl; - JSCerror("Incompatible Mdown between the two states in Sz matrix element!"); + ABACUSerror("Incompatible Mdown between the two states in Sz matrix element!"); } - + if (A.iK == B.iK && (A.label != B.label)) return(-300.0); // matrix element identically vanishes - + // Compute the sinh and cosh of rapidities - + A.Compute_sinhlambda(); A.Compute_coshlambda(); B.Compute_sinhlambda(); B.Compute_coshlambda(); - + // Some convenient arrays - + Lambda re_ln_Fn_F_B_0(B.chain, B.base); Lambda im_ln_Fn_F_B_0(B.chain, B.base); Lambda re_ln_Fn_G_0(B.chain, B.base); Lambda im_ln_Fn_G_0(B.chain, B.base); Lambda re_ln_Fn_G_2(B.chain, B.base); Lambda im_ln_Fn_G_2(B.chain, B.base); - + complex ln_prod1 = 0.0; complex ln_prod2 = 0.0; complex ln_prod3 = 0.0; complex ln_prod4 = 0.0; - - for (int i = 0; i < A.chain.Nstrings; ++i) + + for (int i = 0; i < A.chain.Nstrings; ++i) for (int alpha = 0; alpha < A.base.Nrap[i]; ++alpha) for (int a = 1; a <= A.chain.Str_L[i]; ++a) ln_prod1 += log(norm(sinh(A.lambda[i][alpha] + 0.5 * II * A.chain.anis * (A.chain.Str_L[i] + 1.0 - 2.0 * a - 1.0) + 0.25 * II * PI * (1.0 - A.chain.par[i])))); - - for (int i = 0; i < B.chain.Nstrings; ++i) + + for (int i = 0; i < B.chain.Nstrings; ++i) for (int alpha = 0; alpha < B.base.Nrap[i]; ++alpha) for (int a = 1; a <= B.chain.Str_L[i]; ++a) if (norm(sinh(B.lambda[i][alpha] + 0.5 * II * B.chain.anis * (B.chain.Str_L[i] + 1.0 - 2.0 * a - 1.0) + 0.25 * II * PI * (1.0 - B.chain.par[i]))) > 100.0 * MACHINE_EPS_SQ) ln_prod2 += log(norm(sinh(B.lambda[i][alpha] + 0.5 * II * B.chain.anis * (B.chain.Str_L[i] + 1.0 - 2.0 * a - 1.0) + 0.25 * II * PI * (1.0 - B.chain.par[i])))); - + // Define the F ones earlier... - + complex ln_Fn_F_B_0; for (int j = 0; j < B.chain.Nstrings; ++j) { for (int alpha = 0; alpha < B.base.Nrap[j]; ++alpha) { @@ -208,35 +223,35 @@ namespace JSC { im_ln_Fn_G_2[j][alpha] = imag(ln_Fn_G(A, B, j, alpha, 2)); } } - + DP logabssinzeta = log(abs(sin(A.chain.anis))); - + // Define regularized products in prefactors - + for (int j = 0; j < A.chain.Nstrings; ++j) for (int alpha = 0; alpha < A.base.Nrap[j]; ++alpha) for (int a = 1; a <= A.chain.Str_L[j]; ++a) { ln_prod3 += ln_Fn_F (A, j, alpha, a - 1); } - + ln_prod3 -= A.base.Mdown * log(abs(sin(A.chain.anis))); - + for (int k = 0; k < B.chain.Nstrings; ++k) for (int beta = 0; beta < B.base.Nrap[k]; ++beta) for (int b = 1; b <= B.chain.Str_L[k]; ++b) { if (b == 1) ln_prod4 += re_ln_Fn_F_B_0[k][beta]; else if (b > 1) ln_prod4 += ln_Fn_F(B, k, beta, b - 1); } - + ln_prod4 -= B.base.Mdown * log(abs(sin(B.chain.anis))); - + // Now proceed to build the Hm2P matrix - + SQMat_CX Hm2P(0.0, A.base.Mdown); - + int index_a = 0; int index_b = 0; - + complex sum1 = 0.0; complex sum2 = 0.0; complex prod_num = 0.0; @@ -244,103 +259,103 @@ namespace JSC { complex Prod_powerN = 0.0; complex Fn_K_1_G_2 = 0.0; complex two_over_A_sinhlambda_sq_plus_sinzetaover2sq; - - + + for (int j = 0; j < A.chain.Nstrings; ++j) { for (int alpha = 0; alpha < A.base.Nrap[j]; ++alpha) { for (int a = 1; a <= A.chain.Str_L[j]; ++a) { - + index_b = 0; - + two_over_A_sinhlambda_sq_plus_sinzetaover2sq = 2.0/((sinh(A.lambda[j][alpha] + 0.5 * II * A.chain.anis * (A.chain.Str_L[j] + 1.0 - 2.0 * a) - + 0.25 * II * PI * (1.0 - A.chain.par[j]))) + + 0.25 * II * PI * (1.0 - A.chain.par[j]))) * (sinh(A.lambda[j][alpha] + 0.5 * II * A.chain.anis * (A.chain.Str_L[j] + 1.0 - 2.0 * a) - + 0.25 * II * PI * (1.0 - A.chain.par[j]))) + + 0.25 * II * PI * (1.0 - A.chain.par[j]))) + pow(sin(0.5*A.chain.anis), 2.0)); - + for (int k = 0; k < B.chain.Nstrings; ++k) { for (int beta = 0; beta < B.base.Nrap[k]; ++beta) { for (int b = 1; b <= B.chain.Str_L[k]; ++b) { - + if (B.chain.Str_L[k] == 1) { - + // use simplified code for one-string here: original form of Hm2P matrix - - Fn_K_0_G_0 = Fn_K (A, j, alpha, a, B, k, beta, 0) * + + Fn_K_0_G_0 = Fn_K (A, j, alpha, a, B, k, beta, 0) * exp(re_ln_Fn_G_0[k][beta] + II * im_ln_Fn_G_0[k][beta] - re_ln_Fn_F_B_0[k][beta] + logabssinzeta); Fn_K_1_G_2 = Fn_K (A, j, alpha, a, B, k, beta, 1) * exp(re_ln_Fn_G_2[k][beta] + II * im_ln_Fn_G_2[k][beta] - re_ln_Fn_F_B_0[k][beta] + logabssinzeta); - - Prod_powerN = pow( B.chain.par[k] == 1 ? + + Prod_powerN = pow( B.chain.par[k] == 1 ? (B.sinhlambda[k][beta] * B.chain.co_n_anis_over_2[1] + II * B.coshlambda[k][beta] * B.chain.si_n_anis_over_2[1]) /(B.sinhlambda[k][beta] * B.chain.co_n_anis_over_2[1] - II * B.coshlambda[k][beta] * B.chain.si_n_anis_over_2[1]) : (B.coshlambda[k][beta] * B.chain.co_n_anis_over_2[1] + II * B.sinhlambda[k][beta] * B.chain.si_n_anis_over_2[1]) /(B.coshlambda[k][beta] * B.chain.co_n_anis_over_2[1] - II * B.sinhlambda[k][beta] * B.chain.si_n_anis_over_2[1]) , complex (B.chain.Nsites)); - + //cout << "Prod_powerN = " << Prod_powerN << "\t" << abs(Prod_powerN) << endl; - + Hm2P[index_a][index_b] = Fn_K_0_G_0 - Prod_powerN * Fn_K_1_G_2 - two_over_A_sinhlambda_sq_plus_sinzetaover2sq * exp(II*im_ln_Fn_F_B_0[k][beta] + logabssinzeta); - + } - + else { - + if (b <= B.chain.Str_L[k] - 1) Hm2P[index_a][index_b] = Fn_K(A, j, alpha, a, B, k, beta, b); else if (b == B.chain.Str_L[k]) { - + Vect_CX ln_FunctionF(B.chain.Str_L[k] + 2); for (int i = 0; i < B.chain.Str_L[k] + 2; ++i) ln_FunctionF[i] = ln_Fn_F (B, k, beta, i); - + Vect_CX ln_FunctionG(B.chain.Str_L[k] + 2); for (int i = 0; i < B.chain.Str_L[k] + 2; ++i) ln_FunctionG[i] = ln_Fn_G (A, B, k, beta, i); - + sum1 = 0.0; - + sum1 += Fn_K (A, j, alpha, a, B, k, beta, 0) * exp(ln_FunctionG[0] + ln_FunctionG[1] - ln_FunctionF[0] - ln_FunctionF[1]); - - sum1 += Fn_K (A, j, alpha, a, B, k, beta, B.chain.Str_L[k]) - * exp(ln_FunctionG[B.chain.Str_L[k]] + ln_FunctionG[B.chain.Str_L[k] + 1] + + sum1 += Fn_K (A, j, alpha, a, B, k, beta, B.chain.Str_L[k]) + * exp(ln_FunctionG[B.chain.Str_L[k]] + ln_FunctionG[B.chain.Str_L[k] + 1] - ln_FunctionF[B.chain.Str_L[k]] - ln_FunctionF[B.chain.Str_L[k] + 1]); - - for (int jsum = 1; jsum < B.chain.Str_L[k]; ++jsum) - + + for (int jsum = 1; jsum < B.chain.Str_L[k]; ++jsum) + sum1 -= Fn_L (A, j, alpha, a, B, k, beta, jsum) * exp(ln_FunctionG[jsum] + ln_FunctionG[jsum + 1] - ln_FunctionF[jsum] - ln_FunctionF[jsum + 1]); - + sum2 = 0.0; - + for (int jsum = 1; jsum <= B.chain.Str_L[k]; ++jsum) sum2 += exp(ln_FunctionG[jsum] - ln_FunctionF[jsum]); - + prod_num = exp(II * im_ln_Fn_F_B_0[k][beta] + ln_FunctionF[1] - ln_FunctionG[B.chain.Str_L[k]] + logabssinzeta); - - for (int jsum = 2; jsum <= B.chain.Str_L[k]; ++jsum) - prod_num *= exp(ln_FunctionG[jsum] - real(ln_FunctionF[jsum - 1]) + logabssinzeta); + + for (int jsum = 2; jsum <= B.chain.Str_L[k]; ++jsum) + prod_num *= exp(ln_FunctionG[jsum] - real(ln_FunctionF[jsum - 1]) + logabssinzeta); // include all string contributions F_B_0 in this term - + Hm2P[index_a][index_b] = prod_num * (sum1 - sum2 * two_over_A_sinhlambda_sq_plus_sinzetaover2sq); - + } // else if (b == B.chain.Str_L[k]) - } // else - + } // else + index_b++; }}} // sums over k, beta, b index_a++; }}} // sums over j, alpha, a - + DP re_ln_det = real(lndet_LU_CX_dstry(Hm2P)); - + complex ln_ME_sq = log(0.25 * A.chain.Nsites) + real(ln_prod1 - ln_prod2) - real(ln_prod3) + real(ln_prod4) + 2.0 * /*real(lndet_LU_CX_dstry(Hm2P))*/ re_ln_det - A.lnnorm - B.lnnorm; - - //cout << endl << ln_prod1 << "\t" << ln_prod2 << "\t" << ln_prod3 << "\t" << ln_prod4 << "\t" << A.lnnorm << "\t" << B.lnnorm + + //cout << endl << ln_prod1 << "\t" << ln_prod2 << "\t" << ln_prod3 << "\t" << ln_prod4 << "\t" << A.lnnorm << "\t" << B.lnnorm //<< "\t" << re_ln_det << "\t" << ln_ME_sq << endl; - + //return(ln_ME_sq); return(0.5 * ln_ME_sq); // Return ME, not MEsq - + } // Version with phases: @@ -348,52 +363,52 @@ namespace JSC { { // This function returns the natural log of the S^z operator matrix element. // The A and B states can contain strings. - + // Check that the two states refer to the same XXZ_Chain - - if (A.chain != B.chain) JSCerror("Incompatible XXZ_Chains in Sz matrix element."); - + + if (A.chain != B.chain) ABACUSerror("Incompatible XXZ_Chains in Sz matrix element."); + // Check that A and B are compatible: same Mdown - + if (A.base.Mdown != B.base.Mdown) { cout << "Bra state: " << endl << A << endl; cout << "Ket state: " << endl << B << endl; cout << A.base.Mdown << "\t" << B.base.Mdown << endl; - JSCerror("Incompatible Mdown between the two states in Sz matrix element!"); + ABACUSerror("Incompatible Mdown between the two states in Sz matrix element!"); } - + if (A.iK == B.iK && (A.label != B.label)) return(-300.0); // matrix element identically vanishes - + // Compute the sinh and cosh of rapidities - + A.Compute_sinhlambda(); A.Compute_coshlambda(); B.Compute_sinhlambda(); B.Compute_coshlambda(); - + // Some convenient arrays - + Lambda re_ln_Fn_F_B_0(B.chain, B.base); Lambda im_ln_Fn_F_B_0(B.chain, B.base); Lambda re_ln_Fn_G_0(B.chain, B.base); Lambda im_ln_Fn_G_0(B.chain, B.base); Lambda re_ln_Fn_G_2(B.chain, B.base); Lambda im_ln_Fn_G_2(B.chain, B.base); - + complex ln_prod1 = 0.0; complex ln_prod2 = 0.0; complex ln_prod3 = 0.0; complex ln_prod4 = 0.0; - - for (int i = 0; i < A.chain.Nstrings; ++i) + + for (int i = 0; i < A.chain.Nstrings; ++i) for (int alpha = 0; alpha < A.base.Nrap[i]; ++alpha) for (int a = 1; a <= A.chain.Str_L[i]; ++a) ln_prod1 += log(sinh(A.lambda[i][alpha] + 0.5 * II * A.chain.anis * (A.chain.Str_L[i] + 1.0 - 2.0 * a - 1.0) + 0.25 * II * PI * (1.0 - A.chain.par[i]))); complex shB; - for (int i = 0; i < B.chain.Nstrings; ++i) + for (int i = 0; i < B.chain.Nstrings; ++i) for (int alpha = 0; alpha < B.base.Nrap[i]; ++alpha) for (int a = 1; a <= B.chain.Str_L[i]; ++a) if (norm(shB = sinh(B.lambda[i][alpha] + 0.5 * II * B.chain.anis * (B.chain.Str_L[i] + 1.0 - 2.0 * a - 1.0) @@ -401,9 +416,9 @@ namespace JSC { //ln_prod2 += log(norm(sinh(B.lambda[i][alpha] + 0.5 * II * B.chain.anis * (B.chain.Str_L[i] + 1.0 - 2.0 * a - 1.0) // + 0.25 * II * PI * (1.0 - B.chain.par[i])))); ln_prod2 += log(shB); - + // Define the F ones earlier... - + complex ln_Fn_F_B_0, ln_Fn_G_0, ln_Fn_G_2; for (int j = 0; j < B.chain.Nstrings; ++j) { for (int alpha = 0; alpha < B.base.Nrap[j]; ++alpha) { @@ -424,37 +439,37 @@ namespace JSC { im_ln_Fn_G_2[j][alpha] = imag(ln_Fn_G_2); } } - + DP logsinzeta = log(sin(A.chain.anis)); - + // Define regularized products in prefactors - + for (int j = 0; j < A.chain.Nstrings; ++j) for (int alpha = 0; alpha < A.base.Nrap[j]; ++alpha) for (int a = 1; a <= A.chain.Str_L[j]; ++a) { ln_prod3 += ln_Fn_F (A, j, alpha, a - 1); } - + //ln_prod3 -= A.base.Mdown * log(abs(sin(A.chain.anis))); ln_prod3 -= A.base.Mdown * logsinzeta; - + for (int k = 0; k < B.chain.Nstrings; ++k) for (int beta = 0; beta < B.base.Nrap[k]; ++beta) for (int b = 1; b <= B.chain.Str_L[k]; ++b) { if (b == 1) ln_prod4 += re_ln_Fn_F_B_0[k][beta]; else if (b > 1) ln_prod4 += ln_Fn_F(B, k, beta, b - 1); } - + //ln_prod4 -= B.base.Mdown * log(abs(sin(B.chain.anis))); ln_prod4 -= B.base.Mdown * logsinzeta; - + // Now proceed to build the Hm2P matrix - + SQMat_CX Hm2P(0.0, A.base.Mdown); - + int index_a = 0; int index_b = 0; - + complex sum1 = 0.0; complex sum2 = 0.0; complex prod_num = 0.0; @@ -462,102 +477,102 @@ namespace JSC { complex Prod_powerN = 0.0; complex Fn_K_1_G_2 = 0.0; complex two_over_A_sinhlambda_sq_plus_sinzetaover2sq; - - + + for (int j = 0; j < A.chain.Nstrings; ++j) { for (int alpha = 0; alpha < A.base.Nrap[j]; ++alpha) { for (int a = 1; a <= A.chain.Str_L[j]; ++a) { - + index_b = 0; - + two_over_A_sinhlambda_sq_plus_sinzetaover2sq = 2.0/((sinh(A.lambda[j][alpha] + 0.5 * II * A.chain.anis * (A.chain.Str_L[j] + 1.0 - 2.0 * a) - + 0.25 * II * PI * (1.0 - A.chain.par[j]))) + + 0.25 * II * PI * (1.0 - A.chain.par[j]))) * (sinh(A.lambda[j][alpha] + 0.5 * II * A.chain.anis * (A.chain.Str_L[j] + 1.0 - 2.0 * a) - + 0.25 * II * PI * (1.0 - A.chain.par[j]))) + + 0.25 * II * PI * (1.0 - A.chain.par[j]))) + pow(sin(0.5*A.chain.anis), 2.0)); - + for (int k = 0; k < B.chain.Nstrings; ++k) { for (int beta = 0; beta < B.base.Nrap[k]; ++beta) { for (int b = 1; b <= B.chain.Str_L[k]; ++b) { - + if (B.chain.Str_L[k] == 1) { - + // use simplified code for one-string here: original form of Hm2P matrix - - Fn_K_0_G_0 = Fn_K (A, j, alpha, a, B, k, beta, 0) * + + Fn_K_0_G_0 = Fn_K (A, j, alpha, a, B, k, beta, 0) * exp(re_ln_Fn_G_0[k][beta] + II * im_ln_Fn_G_0[k][beta] - re_ln_Fn_F_B_0[k][beta] + logsinzeta); Fn_K_1_G_2 = Fn_K (A, j, alpha, a, B, k, beta, 1) * exp(re_ln_Fn_G_2[k][beta] + II * im_ln_Fn_G_2[k][beta] - re_ln_Fn_F_B_0[k][beta] + logsinzeta); - - Prod_powerN = pow( B.chain.par[k] == 1 ? + + Prod_powerN = pow( B.chain.par[k] == 1 ? (B.sinhlambda[k][beta] * B.chain.co_n_anis_over_2[1] + II * B.coshlambda[k][beta] * B.chain.si_n_anis_over_2[1]) /(B.sinhlambda[k][beta] * B.chain.co_n_anis_over_2[1] - II * B.coshlambda[k][beta] * B.chain.si_n_anis_over_2[1]) : (B.coshlambda[k][beta] * B.chain.co_n_anis_over_2[1] + II * B.sinhlambda[k][beta] * B.chain.si_n_anis_over_2[1]) /(B.coshlambda[k][beta] * B.chain.co_n_anis_over_2[1] - II * B.sinhlambda[k][beta] * B.chain.si_n_anis_over_2[1]) , complex (B.chain.Nsites)); - + //cout << "Prod_powerN = " << Prod_powerN << "\t" << abs(Prod_powerN) << endl; - + Hm2P[index_a][index_b] = Fn_K_0_G_0 - Prod_powerN * Fn_K_1_G_2 - two_over_A_sinhlambda_sq_plus_sinzetaover2sq * exp(II*im_ln_Fn_F_B_0[k][beta] + logsinzeta); - + } - + else { - + if (b <= B.chain.Str_L[k] - 1) Hm2P[index_a][index_b] = Fn_K(A, j, alpha, a, B, k, beta, b); else if (b == B.chain.Str_L[k]) { - + Vect_CX ln_FunctionF(B.chain.Str_L[k] + 2); for (int i = 0; i < B.chain.Str_L[k] + 2; ++i) ln_FunctionF[i] = ln_Fn_F (B, k, beta, i); - + Vect_CX ln_FunctionG(B.chain.Str_L[k] + 2); for (int i = 0; i < B.chain.Str_L[k] + 2; ++i) ln_FunctionG[i] = ln_Fn_G (A, B, k, beta, i); - + sum1 = 0.0; - + sum1 += Fn_K (A, j, alpha, a, B, k, beta, 0) * exp(ln_FunctionG[0] + ln_FunctionG[1] - ln_FunctionF[0] - ln_FunctionF[1]); - - sum1 += Fn_K (A, j, alpha, a, B, k, beta, B.chain.Str_L[k]) - * exp(ln_FunctionG[B.chain.Str_L[k]] + ln_FunctionG[B.chain.Str_L[k] + 1] + + sum1 += Fn_K (A, j, alpha, a, B, k, beta, B.chain.Str_L[k]) + * exp(ln_FunctionG[B.chain.Str_L[k]] + ln_FunctionG[B.chain.Str_L[k] + 1] - ln_FunctionF[B.chain.Str_L[k]] - ln_FunctionF[B.chain.Str_L[k] + 1]); - - for (int jsum = 1; jsum < B.chain.Str_L[k]; ++jsum) - + + for (int jsum = 1; jsum < B.chain.Str_L[k]; ++jsum) + sum1 -= Fn_L (A, j, alpha, a, B, k, beta, jsum) * exp(ln_FunctionG[jsum] + ln_FunctionG[jsum + 1] - ln_FunctionF[jsum] - ln_FunctionF[jsum + 1]); - + sum2 = 0.0; - + for (int jsum = 1; jsum <= B.chain.Str_L[k]; ++jsum) sum2 += exp(ln_FunctionG[jsum] - ln_FunctionF[jsum]); - + prod_num = exp(II * im_ln_Fn_F_B_0[k][beta] + ln_FunctionF[1] - ln_FunctionG[B.chain.Str_L[k]] + logsinzeta); - - for (int jsum = 2; jsum <= B.chain.Str_L[k]; ++jsum) - prod_num *= exp(ln_FunctionG[jsum] - real(ln_FunctionF[jsum - 1]) + logsinzeta); + + for (int jsum = 2; jsum <= B.chain.Str_L[k]; ++jsum) + prod_num *= exp(ln_FunctionG[jsum] - real(ln_FunctionF[jsum - 1]) + logsinzeta); // include all string contributions F_B_0 in this term - + Hm2P[index_a][index_b] = prod_num * (sum1 - sum2 * two_over_A_sinhlambda_sq_plus_sinzetaover2sq); - + } // else if (b == B.chain.Str_L[k]) - } // else - + } // else + index_b++; }}} // sums over k, beta, b index_a++; }}} // sums over j, alpha, a - + complex ln_det = lndet_LU_CX_dstry(Hm2P); - + complex ln_ME = log(0.5 * sqrt(A.chain.Nsites)) + ln_prod1 - ln_prod2 - ln_prod3 + ln_prod4 + 2.0 * ln_det - A.lnnorm - B.lnnorm; - - //cout << endl << ln_prod1 << "\t" << ln_prod2 << "\t" << ln_prod3 << "\t" << ln_prod4 << "\t" << A.lnnorm << "\t" << B.lnnorm + + //cout << endl << ln_prod1 << "\t" << ln_prod2 << "\t" << ln_prod3 << "\t" << ln_prod4 << "\t" << A.lnnorm << "\t" << B.lnnorm //<< "\t" << re_ln_det << "\t" << ln_form_factor_sq << endl; - + //return(ln_ME_sq); return(ln_ME); // Return ME, not MEsq - + } - -} // namespace JSC + +} // namespace ABACUS diff --git a/src/HEIS/ln_Sz_ME_XXZ_gpd.cc b/src/HEIS/ln_Sz_ME_XXZ_gpd.cc index 2f9eefb..be2eef9 100644 --- a/src/HEIS/ln_Sz_ME_XXZ_gpd.cc +++ b/src/HEIS/ln_Sz_ME_XXZ_gpd.cc @@ -1,8 +1,23 @@ -#include "JSC.h" +/********************************************************** -using namespace JSC; +This software is part of J.-S. Caux's ABACUS library. -namespace JSC { +Copyright (c) J.-S. Caux. + +----------------------------------------------------------- + +File: ln_Sz_ME_XXZ_gpd.cc + +Purpose: compute the S^z matrix elemment for XXZ_gpd + +***********************************************************/ + +#include "ABACUS.h" + +using namespace std; +using namespace ABACUS; + +namespace ABACUS { inline complex ln_Fn_F (XXZ_gpd_Bethe_State& B, int k, int beta, int b) { @@ -14,7 +29,7 @@ inline complex ln_Fn_F (XXZ_gpd_Bethe_State& B, int k, int beta, int b) for (int alpha = 0; alpha < B.base.Nrap[j]; ++alpha) { for (int a = 1; a <= B.chain.Str_L[j]; ++a) { /* - if (!((j == k) && (alpha == beta) && (a == b))) + if (!((j == k) && (alpha == beta) && (a == b))) ans += log(-II * sin(B.lambda[j][alpha] - B.lambda[k][beta] + 0.5 * II * B.chain.eta * (B.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b)))); */ @@ -23,10 +38,10 @@ inline complex ln_Fn_F (XXZ_gpd_Bethe_State& B, int k, int beta, int b) // arg = B.chain.Str_L[j] - B.chain.Str_L[k] - 2 * (a - b); // absarg = abs(arg); - + prod_temp *= -II * (B.sinlambda[j][alpha] * B.coslambda[k][beta] - B.coslambda[j][alpha] * B.sinlambda[k][beta]) * cosh(0.5 * B.chain.anis * (B.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b))) + - (B.coslambda[j][alpha] * B.coslambda[k][beta] + B.sinlambda[j][alpha] * B.sinlambda[k][beta]) + (B.coslambda[j][alpha] * B.coslambda[k][beta] + B.sinlambda[j][alpha] * B.sinlambda[k][beta]) * sinh(0.5 * B.chain.anis * (B.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b))); } @@ -81,7 +96,7 @@ inline complex Fn_K (XXZ_gpd_Bethe_State& A, int j, int alpha, int a, XXZ_gp { /* return(-1.0/(sin(A.lambda[j][alpha] - B.lambda[k][beta] - + 0.5 * II * B.chain.zeta * (A.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b))) + + 0.5 * II * B.chain.zeta * (A.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b))) * sin(A.lambda[j][alpha] - B.lambda[k][beta] + 0.5 * II * B.chain.zeta * (A.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b - 1.0))))); */ @@ -107,12 +122,12 @@ inline complex Fn_L (XXZ_gpd_Bethe_State& A, int j, int alpha, int a, XXZ_gp { /* complex ans = -II * sin(2.0 * (A.lambda[j][alpha] - B.lambda[k][beta] - + 0.5 * II * B.chain.zeta * (A.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b - 0.5)))); + + 0.5 * II * B.chain.zeta * (A.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b - 0.5)))); return (ans * pow(Fn_K (A, j, alpha, a, B, k, beta, b), 2.0)); */ return (-II * sin(2.0 * (A.lambda[j][alpha] - B.lambda[k][beta] - + 0.5 * II * B.chain.anis * (A.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b - 0.5)))) + + 0.5 * II * B.chain.anis * (A.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b - 0.5)))) * pow(Fn_K (A, j, alpha, a, B, k, beta, b), 2.0)); } @@ -123,11 +138,11 @@ complex ln_Sz_ME (XXZ_gpd_Bethe_State& A, XXZ_gpd_Bethe_State& B) // Check that the two states refer to the same XXZ_gpd_Chain - if (A.chain != B.chain) JSCerror("Incompatible XXZ_gpd_Chains in Sz matrix element."); + if (A.chain != B.chain) ABACUSerror("Incompatible XXZ_gpd_Chains in Sz matrix element."); // Check that A and B are compatible: same Mdown - if (A.base.Mdown != B.base.Mdown) JSCerror("Incompatible Mdown between the two states in Sz matrix element!"); + if (A.base.Mdown != B.base.Mdown) ABACUSerror("Incompatible Mdown between the two states in Sz matrix element!"); if (A.iK == B.iK && (A.label != B.label)) return(-300.0); // matrix element identically vanishes @@ -153,12 +168,12 @@ complex ln_Sz_ME (XXZ_gpd_Bethe_State& A, XXZ_gpd_Bethe_State& B) complex ln_prod3 = 0.0; complex ln_prod4 = 0.0; - for (int i = 0; i < A.chain.Nstrings; ++i) + for (int i = 0; i < A.chain.Nstrings; ++i) for (int alpha = 0; alpha < A.base.Nrap[i]; ++alpha) for (int a = 1; a <= A.chain.Str_L[i]; ++a) ln_prod1 += log(norm(sin(A.lambda[i][alpha] + 0.5 * II * A.chain.anis * (A.chain.Str_L[i] + 1.0 - 2.0 * a - 1.0)))); - for (int i = 0; i < B.chain.Nstrings; ++i) + for (int i = 0; i < B.chain.Nstrings; ++i) for (int alpha = 0; alpha < B.base.Nrap[i]; ++alpha) for (int a = 1; a <= B.chain.Str_L[i]; ++a) if (norm(sin(B.lambda[i][alpha] + 0.5 * II * B.chain.anis * (B.chain.Str_L[i] + 1.0 - 2.0 * a - 1.0))) > 100.0 * MACHINE_EPS_SQ) @@ -184,7 +199,7 @@ complex ln_Sz_ME (XXZ_gpd_Bethe_State& A, XXZ_gpd_Bethe_State& B) for (int j = 0; j < A.chain.Nstrings; ++j) for (int alpha = 0; alpha < A.base.Nrap[j]; ++alpha) for (int a = 1; a <= A.chain.Str_L[j]; ++a) - ln_prod3 += ln_Fn_F(A, j, alpha, a - 1); + ln_prod3 += ln_Fn_F(A, j, alpha, a - 1); ln_prod3 -= A.base.Mdown * log(abs(sinh(A.chain.anis))); @@ -194,7 +209,7 @@ complex ln_Sz_ME (XXZ_gpd_Bethe_State& A, XXZ_gpd_Bethe_State& B) if (b == 1) ln_prod4 += re_ln_Fn_F_B_0[k][beta]; else if (b > 1) ln_prod4 += ln_Fn_F(B, k, beta, b - 1); } - + ln_prod4 -= B.base.Mdown * log(abs(sinh(B.chain.anis))); // Now proceed to build the Hm2P matrix @@ -215,11 +230,11 @@ complex ln_Sz_ME (XXZ_gpd_Bethe_State& A, XXZ_gpd_Bethe_State& B) for (int j = 0; j < A.chain.Nstrings; ++j) { for (int alpha = 0; alpha < A.base.Nrap[j]; ++alpha) { for (int a = 1; a <= A.chain.Str_L[j]; ++a) { - + index_b = 0; - + two_over_A_sinlambda_sq_plus_sinhetaover2sq = -2.0/((sin(A.lambda[j][alpha] // minus sign: from 1/(sinh^2... to -1/(sin^2... - + 0.5 * II * A.chain.anis * (A.chain.Str_L[j] + 1.0 - 2.0 * a))) * + + 0.5 * II * A.chain.anis * (A.chain.Str_L[j] + 1.0 - 2.0 * a))) * (sin(A.lambda[j][alpha] // minus sign: from 1/(sinh^2... to -1/(sin^2... + 0.5 * II * A.chain.anis * (A.chain.Str_L[j] + 1.0 - 2.0 * a))) + pow(sinh(0.5*A.chain.anis), 2.0)); @@ -232,58 +247,58 @@ complex ln_Sz_ME (XXZ_gpd_Bethe_State& A, XXZ_gpd_Bethe_State& B) // use simplified code for one-string here: original form of Hm2P matrix - Fn_K_0_G_0 = Fn_K (A, j, alpha, a, B, k, beta, 0) * + Fn_K_0_G_0 = Fn_K (A, j, alpha, a, B, k, beta, 0) * exp(re_ln_Fn_G_0[k][beta] + II * im_ln_Fn_G_0[k][beta] - re_ln_Fn_F_B_0[k][beta] + logabssinheta); - Fn_K_1_G_2 = Fn_K (A, j, alpha, a, B, k, beta, 1) * + Fn_K_1_G_2 = Fn_K (A, j, alpha, a, B, k, beta, 1) * exp(re_ln_Fn_G_2[k][beta] + II * im_ln_Fn_G_2[k][beta] - re_ln_Fn_F_B_0[k][beta] + logabssinheta); Prod_powerN = pow((B.sinlambda[k][beta] * B.chain.co_n_anis_over_2[1] + II * B.coslambda[k][beta] * B.chain.si_n_anis_over_2[1]) - /(B.sinlambda[k][beta] * B.chain.co_n_anis_over_2[1] - II * B.coslambda[k][beta] * B.chain.si_n_anis_over_2[1]), + /(B.sinlambda[k][beta] * B.chain.co_n_anis_over_2[1] - II * B.coslambda[k][beta] * B.chain.si_n_anis_over_2[1]), complex (B.chain.Nsites)); - Hm2P[index_a][index_b] = Fn_K_0_G_0 - Prod_powerN * Fn_K_1_G_2 + Hm2P[index_a][index_b] = Fn_K_0_G_0 - Prod_powerN * Fn_K_1_G_2 - two_over_A_sinlambda_sq_plus_sinhetaover2sq * exp(II*im_ln_Fn_F_B_0[k][beta] + logabssinheta); } - + else { if (b <= B.chain.Str_L[k] - 1) Hm2P[index_a][index_b] = Fn_K(A, j, alpha, a, B, k, beta, b); else if (b == B.chain.Str_L[k]) { - + Vect_CX ln_FunctionF(B.chain.Str_L[k] + 2); for (int i = 0; i < B.chain.Str_L[k] + 2; ++i) ln_FunctionF[i] = ln_Fn_F (B, k, beta, i); - + Vect_CX ln_FunctionG(B.chain.Str_L[k] + 2); for (int i = 0; i < B.chain.Str_L[k] + 2; ++i) ln_FunctionG[i] = ln_Fn_G (A, B, k, beta, i); - + sum1 = 0.0; - + sum1 += Fn_K (A, j, alpha, a, B, k, beta, 0) * exp(ln_FunctionG[0] + ln_FunctionG[1] - ln_FunctionF[0] - ln_FunctionF[1]); - - sum1 += Fn_K (A, j, alpha, a, B, k, beta, B.chain.Str_L[k]) - * exp(ln_FunctionG[B.chain.Str_L[k]] + ln_FunctionG[B.chain.Str_L[k] + 1] + + sum1 += Fn_K (A, j, alpha, a, B, k, beta, B.chain.Str_L[k]) + * exp(ln_FunctionG[B.chain.Str_L[k]] + ln_FunctionG[B.chain.Str_L[k] + 1] - ln_FunctionF[B.chain.Str_L[k]] - ln_FunctionF[B.chain.Str_L[k] + 1]); - - for (int jsum = 1; jsum < B.chain.Str_L[k]; ++jsum) - + + for (int jsum = 1; jsum < B.chain.Str_L[k]; ++jsum) + sum1 -= Fn_L (A, j, alpha, a, B, k, beta, jsum) * exp(ln_FunctionG[jsum] + ln_FunctionG[jsum + 1] - ln_FunctionF[jsum] - ln_FunctionF[jsum + 1]); - + sum2 = 0.0; - + for (int jsum = 1; jsum <= B.chain.Str_L[k]; ++jsum) sum2 += exp(ln_FunctionG[jsum] - ln_FunctionF[jsum]); - + prod_num = exp(II * im_ln_Fn_F_B_0[k][beta] + ln_FunctionF[1] - ln_FunctionG[B.chain.Str_L[k]] + logabssinheta); - for (int jsum = 2; jsum <= B.chain.Str_L[k]; ++jsum) - prod_num *= exp(ln_FunctionG[jsum] - real(ln_Fn_F(B, k, beta, jsum - 1)) + logabssinheta); + for (int jsum = 2; jsum <= B.chain.Str_L[k]; ++jsum) + prod_num *= exp(ln_FunctionG[jsum] - real(ln_Fn_F(B, k, beta, jsum - 1)) + logabssinheta); // include all string contributions F_B_0 in this term Hm2P[index_a][index_b] = prod_num * (sum1 - sum2 * two_over_A_sinlambda_sq_plus_sinhetaover2sq); } // else if (b == B.chain.Str_L[k]) - } // else + } // else index_b++; }}} // sums over k, beta, b @@ -293,12 +308,12 @@ complex ln_Sz_ME (XXZ_gpd_Bethe_State& A, XXZ_gpd_Bethe_State& B) complex ln_ME_sq = log(0.25 * A.chain.Nsites) + real(ln_prod1 - ln_prod2) - real(ln_prod3) + real(ln_prod4) + 2.0 * real(lndet_LU_CX_dstry(Hm2P)) - A.lnnorm - B.lnnorm; - //cout << endl << ln_prod1 << "\t" << ln_prod2 << "\t" << ln_prod3 << "\t" << ln_prod4 << "\t" << A.lnnorm << "\t" << B.lnnorm << "\t" + //cout << endl << ln_prod1 << "\t" << ln_prod2 << "\t" << ln_prod3 << "\t" << ln_prod4 << "\t" << A.lnnorm << "\t" << B.lnnorm << "\t" // << lndet_LU_CX(Hm2P) << endl; - + //return(ln_ME_sq); return(0.5 * ln_ME_sq); // Return ME, not MEsq } -} // namespace JSC +} // namespace ABACUS diff --git a/src/HEIS/ln_Szm_p_Smz_ME_XXX.cc b/src/HEIS/ln_Szm_p_Smz_ME_XXX.cc index 9cb8f6f..032364c 100644 --- a/src/HEIS/ln_Szm_p_Smz_ME_XXX.cc +++ b/src/HEIS/ln_Szm_p_Smz_ME_XXX.cc @@ -1,9 +1,25 @@ -#include "JSC.h" +/********************************************************** -using namespace JSC; +This software is part of J.-S. Caux's ABACUS library. + +Copyright (c) J.-S. Caux. + +----------------------------------------------------------- + +File: ln_Szm_p_Smz_ME_XXX.cc + +Purpose: compute the S^z_j S^-_{j+1} + S^m_j S^z_{j+1} + matrix elemment for XXX + +***********************************************************/ + +#include "ABACUS.h" + +using namespace std; +using namespace ABACUS; -namespace JSC { +namespace ABACUS { inline complex phi(complex x){return x;} inline complex a(complex x){return 1;} inline complex b(complex x,complex y, complex eta){ return phi(x-y)/phi(x-y+complex(0.0,1.0)*eta);} @@ -18,12 +34,12 @@ inline complex ln_Fn_F (XXX_Bethe_State& B, int k, int beta, int b) for (int alpha = 0; alpha < B.base.Nrap[j]; ++alpha) { for (int a = 1; a <= B.chain.Str_L[j]; ++a) { - if (!((j == k) && (alpha == beta) && (a == b))) + if (!((j == k) && (alpha == beta) && (a == b))) ans += log(B.lambda[j][alpha] - B.lambda[k][beta] - + 0.5 * II * (B.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b))); + + 0.5 * II * (B.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b))); } } - } + } return(ans); } @@ -56,8 +72,8 @@ inline complex Fn_K (XXX_Bethe_State& A, int j, int alpha, int a, XXX_Bethe_ inline complex Fn_L (XXX_Bethe_State& A, int j, int alpha, int a, XXX_Bethe_State& B, int k, int beta, int b) { return ((2.0 * (A.lambda[j][alpha] - B.lambda[k][beta] - + 0.5 * II * (A.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b - 0.5)) - )) + + 0.5 * II * (A.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b - 0.5)) + )) * pow(Fn_K (A, j, alpha, a, B, k, beta, b), 2.0)); } @@ -72,25 +88,25 @@ complex ln_Szm_p_Smz_ME (XXX_Bethe_State& A, XXX_Bethe_State& B) // Check that the two states refer to the same XXX_Chain - if (A.chain != B.chain) JSCerror("Incompatible XXX_Chains in Szm_p_Smz matrix element."); + if (A.chain != B.chain) ABACUSerror("Incompatible XXX_Chains in Szm_p_Smz matrix element."); // Check that A and B are compatible: same Mdown - if (A.base.Mdown != B.base.Mdown + 1) JSCerror("Incompatible Mdown between the two states in SzSm_p_SmSz matrix element!"); + if (A.base.Mdown != B.base.Mdown + 1) ABACUSerror("Incompatible Mdown between the two states in SzSm_p_SmSz matrix element!"); //if (B.type_id > 999999LL) return(complex(-300.0)); //add a delta to the origin of the centered strings - for (int i = 0; i < A.chain.Nstrings; ++i) + for (int i = 0; i < A.chain.Nstrings; ++i) for (int alpha = 0; alpha < A.base.Nrap[i]; ++alpha) - if(abs(A.lambda[i][alpha])<5.55112e-12)A.lambda[i][alpha]=5.55112e-12; - for (int i = 0; i < B.chain.Nstrings; ++i) + if(abs(A.lambda[i][alpha])<5.55112e-12)A.lambda[i][alpha]=5.55112e-12; + for (int i = 0; i < B.chain.Nstrings; ++i) for (int alpha = 0; alpha < B.base.Nrap[i]; ++alpha) if(abs(B.lambda[i][alpha])<5.55112e-5)B.lambda[i][alpha]=5.55112e-5; // Some convenient arrays - complex i=complex(0.0,1.0); + complex i=complex(0.0,1.0); complex eta=-i; complex ln_prod = complex(0.0,0.0); complex result; @@ -98,16 +114,16 @@ complex ln_Szm_p_Smz_ME (XXX_Bethe_State& A, XXX_Bethe_State& B) int sizeA=0; int sizeB=0; - - for (int i = 0; i < A.chain.Nstrings; ++i) + + for (int i = 0; i < A.chain.Nstrings; ++i) sizeA+=A.base.Nrap[i]*A.chain.Str_L[i]; - for (int i = 0; i < B.chain.Nstrings; ++i) - sizeB+=B.base.Nrap[i]*B.chain.Str_L[i]; + for (int i = 0; i < B.chain.Nstrings; ++i) + sizeB+=B.base.Nrap[i]*B.chain.Str_L[i]; complex* mu = new complex[sizeA]; complex* lam = new complex[sizeB]; int index=0; - for (int i = 0; i < A.chain.Nstrings; ++i) + for (int i = 0; i < A.chain.Nstrings; ++i) for (int alpha = 0; alpha < A.base.Nrap[i]; ++alpha) for (int a = 1; a <= A.chain.Str_L[i]; ++a) { @@ -117,7 +133,7 @@ int sizeB=0; } index=0; - for (int i = 0; i < B.chain.Nstrings; ++i) + for (int i = 0; i < B.chain.Nstrings; ++i) for (int alpha = 0; alpha < B.base.Nrap[i]; ++alpha) for (int a = 1; a <= B.chain.Str_L[i]; ++a) { @@ -138,12 +154,12 @@ index=0; complex ln_prod3 = 0.0; complex ln_prod4 = 0.0; - for (int i = 0; i < A.chain.Nstrings; ++i) + for (int i = 0; i < A.chain.Nstrings; ++i) for (int alpha = 0; alpha < A.base.Nrap[i]; ++alpha) for (int a = 1; a <= A.chain.Str_L[i]; ++a) ln_prod1 += log(norm(A.lambda[i][alpha] + 0.5 * II * (A.chain.Str_L[i] + 1.0 - 2.0 * a - 1.0))); - for (int i = 0; i < B.chain.Nstrings; ++i) + for (int i = 0; i < B.chain.Nstrings; ++i) for (int alpha = 0; alpha < B.base.Nrap[i]; ++alpha) for (int a = 1; a <= B.chain.Str_L[i]; ++a) if (norm(B.lambda[i][alpha] + 0.5 * II * (B.chain.Str_L[i] + 1.0 - 2.0 * a - 1.0)) > 100.0 * MACHINE_EPS_SQ) @@ -158,34 +174,34 @@ index=0; re_ln_Fn_G_0[j][alpha] = real(ln_Fn_G(A, B, j, alpha, 0)); im_ln_Fn_G_0[j][alpha] = imag(ln_Fn_G(A, B, j, alpha, 0)); re_ln_Fn_G_2[j][alpha] = real(ln_Fn_G(A, B, j, alpha, 2)); - im_ln_Fn_G_2[j][alpha] = imag(ln_Fn_G(A, B, j, alpha, 2)); + im_ln_Fn_G_2[j][alpha] = imag(ln_Fn_G(A, B, j, alpha, 2)); } } -// for (int i = 0; i < A.chain.Nstrings; ++i) +// for (int i = 0; i < A.chain.Nstrings; ++i) // for (int alpha = 0; alpha < A.base.Nrap[i]; ++alpha) // for (int a = 1; a <= A.chain.Str_L[i]; ++a) // ln_prod+=log(abs(phi((A.lambda[i][alpha] + 0.5 * II * (A.chain.Str_L[i] + 1.0 - 2.0 * a))+eta*0.5))) -// for (int i = 0; i < B.chain.Nstrings; ++i) +// for (int i = 0; i < B.chain.Nstrings; ++i) // for (int alpha = 0; alpha < B.base.Nrap[i]; ++alpha) // for (int a = 1; a <= B.chain.Str_L[i]; ++a) // ln_prod+=-log(abs(phi(-(B.lambda[i][alpha] + 0.5 * II * (B.chain.Str_L[i] + 1.0 - 2.0 * a))+eta*0.5))); -// for (int i = 0; i < B.chain.Nstrings; ++i) +// for (int i = 0; i < B.chain.Nstrings; ++i) // for (int alpha = 0; alpha < B.base.Nrap[i]; ++alpha) // for (int a = 1; a <= B.chain.Str_L[i]; ++a) -// for (int j = 0; j < B.chain.Nstrings; ++j) +// for (int j = 0; j < B.chain.Nstrings; ++j) // for (int beta = 0; beta < B.base.Nrap[j]; ++beta) // for (int b = 1; b <= B.chain.Str_L[j]; ++b) // if(i!=j || alpha!=beta ||a!=b)ln_prod3+=-0.5*log(abs(phi((B.lambda[i][alpha] + 0.5 * II * (B.chain.Str_L[i] + 1.0 - 2.0 * a))-(B.lambda[j][beta] + 0.5 * II * (B.chain.Str_L[j] + 1.0 - 2.0 * b))-eta))); -// for (int i = 0; i < A.chain.Nstrings; ++i) +// for (int i = 0; i < A.chain.Nstrings; ++i) // for (int alpha = 0; alpha < A.base.Nrap[i]; ++alpha) // for (int a = 1; a <= A.chain.Str_L[i]; ++a) -// for (int j = 0; j < A.chain.Nstrings; ++j) +// for (int j = 0; j < A.chain.Nstrings; ++j) // for (int beta = 0; beta < A.base.Nrap[j]; ++beta) // for (int b = 1; b <= A.chain.Str_L[j]; ++b) // if(abs((A.lambda[i][alpha] + 0.5 * II * (A.chain.Str_L[i] + 1.0 - 2.0 * a))-(A.lambda[j][beta] + 0.5 * II * (A.chain.Str_L[j] + 1.0 - 2.0 * b))-eta)!=0 && (i!=j && alpha!=beta && a!=b)) @@ -197,20 +213,20 @@ index=0; //A -> mu, B -> lam complex prod=complex(1.0,0.0); complex prod2=complex(1.0,0.0); -complex prod3=complex(1.0,0.0); +complex prod3=complex(1.0,0.0); for(int l=0; l H[sizeA][sizeA]; // cout<<"mu[l]:"; // for(int l=0; l prod3=complex(1.0,0.0); // for(int l=0; l Prod_powerN; - + for (int j = 0; j < A.chain.Nstrings; ++j) { for (int alpha = 0; alpha < A.base.Nrap[j]; ++alpha) { for (int a = 1; a <= A.chain.Str_L[j]; ++a) { - + index_b = 0; - + for (int k = 0; k < B.chain.Nstrings; ++k) { for (int beta = 0; beta < B.base.Nrap[k]; ++beta) { for (int b = 1; b <= B.chain.Str_L[k]; ++b) { - + if (B.chain.Str_L[k] == 1) { - + complex prodplus= complex(1.0,0.0); complex prodminus= complex(1.0,0.0); // use simplified code for one-string here: original form of Hm2P matrix - + prodplus = Fn_K (A, j, alpha, a, B, k, beta, 0);// 1.0/ (phi(mu[l]-lam[k]) phi(mu[l]-lam[k]+eta) ) prodplus*= exp(re_ln_Fn_G_0[k][beta] + II * im_ln_Fn_G_0[k][beta] - re_ln_Fn_F_B_0[k][beta]);//Prod phi(mu[l]-lam[k]+eta) / prod_l!=k |phi(lam[l]-lam[k]) |; prodminus = Fn_K (A, j, alpha, a, B, k, beta, 1);// 1.0/ (phi(mu[l]-lam[k]) phi(mu[l]-lam[k]-eta) ) prodminus*= exp(re_ln_Fn_G_2[k][beta] + II * im_ln_Fn_G_2[k][beta] - re_ln_Fn_F_B_0[k][beta]);//Prod phi(mu[l]-lam[k]-eta)/ prod_l!=k | phi(lam[l]-lam[k]) |; - + Prod_powerN = pow((B.lambda[k][beta] -eta*0.5) /(B.lambda[k][beta] +eta*0.5), complex (B.chain.Nsites)); - + Hm[index_a][index_b] =eta*(prodplus-prodminus*Prod_powerN); } // if (B.chain.Str_L == 1) - + else { if (b > 1) Hm[index_a][index_b] = eta* Fn_K(A, j, alpha, a, B, k, beta, b-1)*exp(ln_Fn_G(A,B,k,beta,b-1))*exp(-real(ln_Fn_F(B, k, beta, b - 1)));//.../ prod_l!=k | phi(lam[l]-lam[k]) | else if (b == 1) { - + Vect_CX ln_FunctionF(B.chain.Str_L[k] + 2); for (int i = 0; i < B.chain.Str_L[k] + 2; ++i) ln_FunctionF[i] = ln_Fn_F (B, k, beta, i); - + Vect_CX ln_FunctionG(B.chain.Str_L[k] + 2); for (int i = 0; i < B.chain.Str_L[k] + 2; ++i) ln_FunctionG[i] = ln_Fn_G (A, B, k, beta, i); - + complex sum1 = complex(0.0,0.0); - + sum1 += Fn_K (A, j, alpha, a, B, k, beta, 0) *exp(ln_FunctionG[0]+ ln_FunctionG[1] //sum term when i=0 - ln_FunctionF[0] - ln_FunctionF[1]); - + sum1 += Fn_K (A, j, alpha, a, B, k, beta, B.chain.Str_L[k]) //sum term when i=n * exp( ln_FunctionG[B.chain.Str_L[k]] + ln_FunctionG[B.chain.Str_L[k] + 1] - ln_FunctionF[B.chain.Str_L[k]] - ln_FunctionF[B.chain.Str_L[k] + 1]); - - for (int jsum = 1; jsum < B.chain.Str_L[k]; ++jsum) - + + for (int jsum = 1; jsum < B.chain.Str_L[k]; ++jsum) + sum1 -= Fn_L (A, j, alpha, a, B, k, beta, jsum) * exp(ln_FunctionG[jsum] + ln_FunctionG[jsum + 1] - ln_FunctionF[jsum] - ln_FunctionF[jsum + 1]); - + Hm[index_a][index_b] = eta * exp(ln_FunctionF[0]+ ln_FunctionF[1] - ln_FunctionG[1]) * sum1 * exp( - real(ln_Fn_F(B, k, beta, b - 1))); //the absolute value prod_l!=k phi(lam[l]-lam[k]) : real(ln_...) } // else if (b == B.chain.Str_L[k]) - } // else + } // else index_b++; }}} // sums over k, beta, b - + // now define the elements Hm[a][M] - - //Hm[index_a][B.base.Mdown] = one_over_A_lambda_sq_plus_1over2sq; - //Hm[index_a][B.base.Mdown] = eta/((A.lambda[j][alpha] + 0.5 * II * (A.chain.Str_L[j] + 1.0 - 2.0 * a)) * + + //Hm[index_a][B.base.Mdown] = one_over_A_lambda_sq_plus_1over2sq; + //Hm[index_a][B.base.Mdown] = eta/((A.lambda[j][alpha] + 0.5 * II * (A.chain.Str_L[j] + 1.0 - 2.0 * a)) * // (A.lambda[j][alpha] + 0.5 * II * (A.chain.Str_L[j] + 1.0 - 2.0 * a)) + 0.25); Hm[index_a][B.base.Mdown] = eta/((mu[index_a]-eta*0.5)*(mu[index_a]+eta*0.5)); index_a++; }}} // sums over j, alpha, a - + // cout<<"Hm:"; // for(int j=0; j F= complex(0.0,0.0); - + complex detmatrix; detmatrix=exp(lndet_LU_CX_dstry(Hm)); //cout<<"exp(lndet_LU_CX(Hm)):"< prod3=complex(1.0,0.0); SQMat_CX G(0.0, A.base.Mdown); SQMat_CX BbDa(0.0, A.base.Mdown); index_a = 0; - + for (int j = 0; j < A.chain.Nstrings; ++j) { for (int alpha = 0; alpha < A.base.Nrap[j]; ++alpha) { for (int a = 1; a <= A.chain.Str_L[j]; ++a) { - + index_b = 0; complex Da; complex Ca; Da=eta/((mu[index_a]-eta*0.5)*(mu[index_a]+eta*0.5)); Ca=eta*((mu[index_a]-eta*0.5)+(mu[index_a]+eta*0.5))/pow(((mu[index_a]-eta*0.5)*(mu[index_a]+eta*0.5)),2.0); - - + + for (int k = 0; k < B.chain.Nstrings; ++k) { for (int beta = 0; beta < B.base.Nrap[k]; ++beta) { for (int b = 1; b <= B.chain.Str_L[k]; ++b) { - + /*if (B.chain.Str_L[k] == 1) { complex Bb; - Bb=-(phi(lam[index_b]+eta*0.5)+phi(lam[index_b]-eta*0.5)); + Bb=-(phi(lam[index_b]+eta*0.5)+phi(lam[index_b]-eta*0.5)); complex product=complex(1.0,0.0); - for(int o=0; o prodplus= complex(1.0,0.0); complex prodminus= complex(1.0,0.0); @@ -348,44 +364,44 @@ SQMat_CX BbDa(0.0, A.base.Mdown); prodminus = Fn_K (A, j, alpha, a, B, k, beta, 1);// 1.0/ (phi(mu[l]-lam[k]) phi(mu[l]-lam[k]-eta) ) prodminus*= exp(re_ln_Fn_G_2[k][beta] + II * im_ln_Fn_G_2[k][beta] - re_ln_Fn_F_B_0[k][beta]);//Prod phi(mu[l]-lam[k]-eta)/ prod_l!=k | phi(lam[l]-lam[k]) |; // prodminus*= exp(re_ln_Fn_G_2[k][beta] + II * im_ln_Fn_G_2[k][beta]);// - re_ln_Fn_F_B_0[k][beta]);//Prod phi(mu[l]-lam[k]-eta)/ prod_l!=k | phi(lam[l]-lam[k]) |; - + Prod_powerN = pow((B.lambda[k][beta] - eta*0.5) /(B.lambda[k][beta] + eta*0.5), complex (B.chain.Nsites)); - + G[index_a][index_b] =eta*(prodplus-prodminus*Prod_powerN); BbDa[index_a][index_b]=Bb*Da*exp(- re_ln_Fn_F_B_0[k][beta]); - + } // if (B.chain.Str_L == 1) - + else { */{ - - if (b > 1){ + + if (b > 1){ G[index_a][index_b] = eta* Fn_K(A, j, alpha, a, B, k, beta, b-1)*exp(ln_Fn_G(A,B,k,beta,b-1))*exp(-real(ln_Fn_F(B, k, beta, b - 1)));//.../ prod_l!=k | phi(lam[l]-lam[k]) | BbDa[index_a][index_b] =0 ; } else if (b == 1) { - + Vect_CX ln_FunctionF(B.chain.Str_L[k] + 2); for (int i = 0; i < B.chain.Str_L[k] + 2; ++i) ln_FunctionF[i] = ln_Fn_F (B, k, beta, i); - + Vect_CX ln_FunctionG(B.chain.Str_L[k] + 2); for (int i = 0; i < B.chain.Str_L[k] + 2; ++i) ln_FunctionG[i] = ln_Fn_G (A, B, k, beta, i); - + complex sum1 = complex(0.0,0.0); complex sum2 = complex(0.0,0.0); - - sum1 += Fn_K (A, j, alpha, a, B, k, beta, 0) *exp(ln_FunctionG[0]+ ln_FunctionG[1] + + sum1 += Fn_K (A, j, alpha, a, B, k, beta, 0) *exp(ln_FunctionG[0]+ ln_FunctionG[1] - ln_FunctionF[0] - ln_FunctionF[1]);//sum term when i=0 //sum2 doesn't have a i=0 term - + sum1 += Fn_K (A, j, alpha, a, B, k, beta, B.chain.Str_L[k]) * exp( ln_FunctionG[B.chain.Str_L[k]] + ln_FunctionG[B.chain.Str_L[k] + 1] - ln_FunctionF[B.chain.Str_L[k]] - ln_FunctionF[B.chain.Str_L[k] + 1]); //sum term when i=n sum2 += exp(ln_FunctionG[B.chain.Str_L[k]]- ln_FunctionF[B.chain.Str_L[k]] ) * (phi((B.lambda[k][beta] + 0.5 * II * (B.chain.Str_L[k] + 1.0 - 2.0 * B.chain.Str_L[k]))-eta*0.5) + phi((B.lambda[k][beta] + 0.5 * II * (B.chain.Str_L[k] + 1.0 - 2.0 * B.chain.Str_L[k]))+eta*0.5) ); //sum term when i=n - - for (int jsum = 1; jsum < B.chain.Str_L[k]; ++jsum) { + + for (int jsum = 1; jsum < B.chain.Str_L[k]; ++jsum) { sum1 -= Fn_L (A, j, alpha, a, B, k, beta, jsum) * exp(ln_FunctionG[jsum] + ln_FunctionG[jsum + 1] - ln_FunctionF[jsum] - ln_FunctionF[jsum + 1]); sum2 += exp(ln_FunctionG[jsum]- ln_FunctionF[jsum] ) @@ -396,12 +412,12 @@ SQMat_CX BbDa(0.0, A.base.Mdown); G[index_a][index_b] = eta * exp(ln_FunctionF[0]+ ln_FunctionF[1] - ln_FunctionG[1]) * sum1 * exp( - real(ln_Fn_F(B, k, beta, b - 1))); //the absolute value prod_l!=k phi(lam[l]-lam[k]) : real(ln_...) BbDa[index_a][index_b] = - Da* exp(ln_FunctionF[0]+ ln_FunctionF[1] - ln_FunctionG[1]) * sum2 * exp( - real(ln_Fn_F(B, k, beta, b - 1)));//the absolute value prod_l!=k phi(lam[l]-lam[k]) : real(ln_...) } // else if (b == B.chain.Str_L[k]) - } // else + } // else index_b++; }}} // sums over k, beta, b - + // now define the elements Hm[a][M] - + //Hm[index_a][B.base.Mdown] = eta/((A.lambda[j][alpha] + 0.5 * II * (A.chain.Str_L[j] + 1.0 - 2.0 * a)) * (A.lambda[j][alpha] + 0.5 * II * (A.chain.Str_L[j] + 1.0 - 2.0 * a)) + 0.25); G[index_a][B.base.Mdown]=Ca; @@ -409,7 +425,7 @@ SQMat_CX BbDa(0.0, A.base.Mdown); index_a++; }}} // sums over j, alpha, a -SQMat_CX matrix(0.0, A.base.Mdown); +SQMat_CX matrix(0.0, A.base.Mdown); for(int a=0; a F2=exp(eta*(B.K-A.K))*(-2.0*sum); + complex F2=exp(eta*(B.K-A.K))*(-2.0*sum); complex F3=(exp(eta*(B.K-A.K)))*(detmatrix); F=detmatrix; // cout<<"F1:"< ln_ME_sq = result; @@ -499,4 +515,4 @@ complex ln_ME_sq = result; } -} // namespace JSC +} // namespace ABACUS diff --git a/src/HEIS/ln_Szz_ME_XXX.cc b/src/HEIS/ln_Szz_ME_XXX.cc index 830beea..817d104 100644 --- a/src/HEIS/ln_Szz_ME_XXX.cc +++ b/src/HEIS/ln_Szz_ME_XXX.cc @@ -1,8 +1,23 @@ -#include "JSC.h" +/********************************************************** -using namespace JSC; +This software is part of J.-S. Caux's ABACUS library. -namespace JSC { +Copyright (c) J.-S. Caux. + +----------------------------------------------------------- + +File: ln_Szz_ME_XXX.cc + +Purpose: compute the S^z_j S^z_{j+1} matrix elemment for XXX + +***********************************************************/ + +#include "ABACUS.h" + +using namespace std; +using namespace ABACUS; + +namespace ABACUS { complex phi(complex x){return x;} complex a(complex x){return 1;} @@ -18,12 +33,12 @@ inline complex ln_Fn_F (XXX_Bethe_State& B, int k, int beta, int b) for (int alpha = 0; alpha < B.base.Nrap[j]; ++alpha) { for (int a = 1; a <= B.chain.Str_L[j]; ++a) { - if (!((j == k) && (alpha == beta) && (a == b))) + if (!((j == k) && (alpha == beta) && (a == b))) ans += log(B.lambda[j][alpha] - B.lambda[k][beta] - + 0.5 * II * (B.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b))); + + 0.5 * II * (B.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b))); } } - } + } return(ans); } @@ -56,8 +71,8 @@ inline complex Fn_K (XXX_Bethe_State& A, int j, int alpha, int a, XXX_Bethe_ inline complex Fn_L (XXX_Bethe_State& A, int j, int alpha, int a, XXX_Bethe_State& B, int k, int beta, int b) { return ((2.0 * (A.lambda[j][alpha] - B.lambda[k][beta] - + 0.5 * II * (A.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b - 0.5)) - )) + + 0.5 * II * (A.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b - 0.5)) + )) * pow(Fn_K (A, j, alpha, a, B, k, beta, b), 2.0)); } @@ -73,11 +88,11 @@ inline complex Fn_L (XXX_Bethe_State& A, int j, int alpha, int a, XXX_Bethe_ // Check that the two states refer to the same XXX_Chain - if (A.chain != B.chain) JSCerror("Incompatible XXX_Chains in Szz matrix element."); + if (A.chain != B.chain) ABACUSerror("Incompatible XXX_Chains in Szz matrix element."); // Check that A and B are compatible: same Mdown - if (A.base.Mdown != B.base.Mdown) JSCerror("Incompatible Mdown between the two states in Szz matrix element!"); + if (A.base.Mdown != B.base.Mdown) ABACUSerror("Incompatible Mdown between the two states in Szz matrix element!"); complex eta=-II; complex ln_prod = complex(0.0,0.0); @@ -85,54 +100,54 @@ inline complex Fn_L (XXX_Bethe_State& A, int j, int alpha, int a, XXX_Bethe_ complex prev_result=-300; //if(A.String_delta()> HEIS_deltaprec) return(complex(-300.0)); // DEPRECATED in ++T_9 - + if((A.E)==(B.E) && B.chain.Nsites ==B.base.Mdown*2){ return(2*log(abs((B.E+(B.chain.Nsites)/4.0)/(3.0*sqrt(B.chain.Nsites))))); } XXX_Bethe_State A_origin; A_origin=A; bool zero_string=false; - for (int j = 0; j < A_origin.chain.Nstrings; ++j) + for (int j = 0; j < A_origin.chain.Nstrings; ++j) for (int alpha = 0; alpha < A_origin.base.Nrap[j]; ++alpha) if(abs(A_origin.lambda[j][alpha])* mu = new complex[sizeA]; complex* lam = new complex[sizeB]; int index=0; - for (int i = 0; i < A.chain.Nstrings; ++i) + for (int i = 0; i < A.chain.Nstrings; ++i) for (int alpha = 0; alpha < A.base.Nrap[i]; ++alpha) for (int a = 1; a <= A.chain.Str_L[i]; ++a) { @@ -141,7 +156,7 @@ int sizeB=0; } index=0; - for (int i = 0; i < B.chain.Nstrings; ++i) + for (int i = 0; i < B.chain.Nstrings; ++i) for (int alpha = 0; alpha < B.base.Nrap[i]; ++alpha) for (int a = 1; a <= B.chain.Str_L[i]; ++a) { @@ -163,12 +178,12 @@ index=0; complex ln_prod3 = 0.0; complex ln_prod4 = 0.0; - for (int i = 0; i < A.chain.Nstrings; ++i) + for (int i = 0; i < A.chain.Nstrings; ++i) for (int alpha = 0; alpha < A.base.Nrap[i]; ++alpha) for (int a = 1; a <= A.chain.Str_L[i]; ++a) ln_prod1 += log(norm(A.lambda[i][alpha] + 0.5 * II * (A.chain.Str_L[i] + 1.0 - 2.0 * a - 1.0))); - for (int i = 0; i < B.chain.Nstrings; ++i) + for (int i = 0; i < B.chain.Nstrings; ++i) for (int alpha = 0; alpha < B.base.Nrap[i]; ++alpha) for (int a = 1; a <= B.chain.Str_L[i]; ++a) if (norm(B.lambda[i][alpha] + 0.5 * II * (B.chain.Str_L[i] + 1.0 - 2.0 * a - 1.0)) > 100.0 * MACHINE_EPS_SQ) @@ -189,7 +204,7 @@ index=0; re_ln_Fn_G_0[j][alpha] = real(ln_Fn_G(A, B, j, alpha, 0)); im_ln_Fn_G_0[j][alpha] = imag(ln_Fn_G(A, B, j, alpha, 0)); re_ln_Fn_G_2[j][alpha] = real(ln_Fn_G(A, B, j, alpha, 2)); - im_ln_Fn_G_2[j][alpha] = imag(ln_Fn_G(A, B, j, alpha, 2)); + im_ln_Fn_G_2[j][alpha] = imag(ln_Fn_G(A, B, j, alpha, 2)); } } @@ -208,7 +223,7 @@ for (int k = 0; k < A.chain.Nstrings; ++k) if (b == 1) ln_prod4 += re_ln_Fn_F_B_0[k][beta]; else if (b > 1) ln_prod4 += ln_Fn_F(B, k, beta, b - 1); } - + complex prod=complex(1.0,0.0); for(int l=0; l prod=complex(1.0,0.0); double factor = log((B.chain.Nsites)*1/16.0); factor +=(2.0*log(abs(prod)) - real(ln_prod3) + real(ln_prod4) - A.lnnorm - B.lnnorm);// a factor prod4^-2 is inserted in the determinant! - - + + int index_a = 0; int index_b = 0; complex Prod_powerN; - + SQMat_CX H(0.0, A.base.Mdown); SQMat_CX P(0.0, A.base.Mdown); index_a = 0; - + for (int j = 0; j < A.chain.Nstrings; ++j) { for (int alpha = 0; alpha < A.base.Nrap[j]; ++alpha) { for (int a = 1; a <= A.chain.Str_L[j]; ++a) { - + index_b = 0; complex Da; complex Ca; Da=eta/((mu[index_a]-eta*0.5)*(mu[index_a]+eta*0.5)); - - + + for (int k = 0; k < B.chain.Nstrings; ++k) { for (int beta = 0; beta < B.base.Nrap[k]; ++beta) { for (int b = 1; b <= B.chain.Str_L[k]; ++b) { - + if (B.chain.Str_L[k] == 1) { complex Bb=complex(1.0,0.0); - for(int o=0; o prodplus= complex(1.0,0.0); complex prodminus= complex(1.0,0.0); // use simplified code for one-string here: original form of Hm2P matrix prodplus = Fn_K (A, j, alpha, a, B, k, beta, 0); - + prodplus*= exp(re_ln_Fn_G_0[k][beta] + II * im_ln_Fn_G_0[k][beta] - re_ln_Fn_F_B_0[k][beta]); - + prodminus = Fn_K (A, j, alpha, a, B, k, beta, 1); - - prodminus*= exp(re_ln_Fn_G_2[k][beta] + II * im_ln_Fn_G_2[k][beta] - re_ln_Fn_F_B_0[k][beta]); - + + prodminus*= exp(re_ln_Fn_G_2[k][beta] + II * im_ln_Fn_G_2[k][beta] - re_ln_Fn_F_B_0[k][beta]); + Prod_powerN = pow((B.lambda[k][beta] - eta*0.5) /(B.lambda[k][beta] + eta*0.5), complex (B.chain.Nsites)); - + H[index_a][index_b] = eta*(prodplus-prodminus*Prod_powerN); P[index_a][index_b] = Bb*Da*exp(- re_ln_Fn_F_B_0[k][beta]); - + } // if (B.chain.Str_L == 1) - + else { - if (b > 1){ + if (b > 1){ H[index_a][index_b] = eta* Fn_K(A, j, alpha, a, B, k, beta, b-1)*exp(ln_Fn_G(A,B,k,beta,b-1))*exp(-real(ln_Fn_F(B, k, beta, b - 1)));//.../ prod_l!=k | phi(lam[l]-lam[k]) | P[index_a][index_b] =0 ; } else if (b == 1) { - + Vect_CX ln_FunctionF(B.chain.Str_L[k] + 2); for (int i = 0; i < B.chain.Str_L[k] + 2; ++i) ln_FunctionF[i] = ln_Fn_F (B, k, beta, i); - + Vect_CX ln_FunctionG(B.chain.Str_L[k] + 2); for (int i = 0; i < B.chain.Str_L[k] + 2; ++i) ln_FunctionG[i] = ln_Fn_G (A, B, k, beta, i); - + complex sum1 = complex(0.0,0.0); complex sum2 = complex(0.0,0.0); - - sum1 += Fn_K (A, j, alpha, a, B, k, beta, 0) *exp(ln_FunctionG[0]+ ln_FunctionG[1] + + sum1 += Fn_K (A, j, alpha, a, B, k, beta, 0) *exp(ln_FunctionG[0]+ ln_FunctionG[1] - ln_FunctionF[0] - ln_FunctionF[1]);//sum term when i=0 //sum2 doesn't have a i=0 term - + sum1 += Fn_K (A, j, alpha, a, B, k, beta, B.chain.Str_L[k]) * exp( ln_FunctionG[B.chain.Str_L[k]] + ln_FunctionG[B.chain.Str_L[k] + 1] - ln_FunctionF[B.chain.Str_L[k]] - ln_FunctionF[B.chain.Str_L[k] + 1]); //sum term when i=n sum2 += exp(ln_FunctionG[B.chain.Str_L[k]]- ln_FunctionF[B.chain.Str_L[k]] ); //sum term when i=n - - for (int jsum = 1; jsum < B.chain.Str_L[k]; ++jsum) { + + for (int jsum = 1; jsum < B.chain.Str_L[k]; ++jsum) { sum1 -= Fn_L (A, j, alpha, a, B, k, beta, jsum) * exp(ln_FunctionG[jsum] + ln_FunctionG[jsum + 1] - ln_FunctionF[jsum] - ln_FunctionF[jsum + 1]); sum2 += exp(ln_FunctionG[jsum]- ln_FunctionF[jsum] ); @@ -301,21 +316,21 @@ SQMat_CX P(0.0, A.base.Mdown); H[index_a][index_b] = eta * exp(ln_FunctionF[0]+ ln_FunctionF[1] - ln_FunctionG[1]) * sum1 * exp( - real(ln_Fn_F(B, k, beta, b - 1))); //the absolute value prod_l!=k phi(lam[l]-lam[k]) : real(ln_...) P[index_a][index_b] = - Da* exp(ln_FunctionF[0]+ ln_FunctionF[1] - ln_FunctionG[1]) * sum2 * exp( - real(ln_Fn_F(B, k, beta, b - 1)));//the absolute value prod_l!=k phi(lam[l]-lam[k]) : real(ln_...) } // else if (b == B.chain.Str_L[k]) - } // else + } // else index_b++; }}} // sums over k, beta, b - + index_a++; }}} // sums over j, alpha, a complex F= complex(0.0,0.0); - + SQMat_CX matrix(0.0, A.base.Mdown); for(int j=0; j detmatrix; detmatrix=exp(lndet_LU_CX_dstry(matrix)+0.5*factor); @@ -331,59 +346,59 @@ SQMat_CX Gn(0.0, A.base.Mdown); SQMat_CX Gn(0.0, A.base.Mdown); SQMat_CX BnbDa(0.0, A.base.Mdown); index_a = 0; - + for (int j = 0; j < A.chain.Nstrings; ++j) { for (int alpha = 0; alpha < A.base.Nrap[j]; ++alpha) { for (int a = 1; a <= A.chain.Str_L[j]; ++a) { - + index_b = 0; - + complex Da; complex Ca; Da=eta/((mu[index_a]-eta*0.5)*(mu[index_a]+eta*0.5)); Ca=(eta)*((mu[index_a]-eta*0.5)+(mu[index_a]+eta*0.5))/pow(((mu[index_a]-eta*0.5)*(mu[index_a]+eta*0.5)),2.0); - + for (int k = 0; k < B.chain.Nstrings; ++k) { for (int beta = 0; beta < B.base.Nrap[k]; ++beta) { for (int b = 1; b <= B.chain.Str_L[k]; ++b) { - if(index_b==n){ + if(index_b==n){ Gn[index_a][index_b] = Ca*exp(-real(ln_Fn_F(B, k, beta, b - 1))); BnbDa[index_a][index_b] = 0; } // else (index_b!=n) else if (B.chain.Str_L[k] == 1) { complex Bnb; - Bnb=-phi(lam[index_b]+eta*0.5)/phi(lam[n]-lam[index_b]-eta); + Bnb=-phi(lam[index_b]+eta*0.5)/phi(lam[n]-lam[index_b]-eta); complex product=complex(1.0,0.0); - for(int o=0; o prodplus= complex(1.0,0.0); complex prodminus= complex(1.0,0.0); - + // use simplified code for one-string here: original form of Hm2P matrix prodplus = Fn_K (A, j, alpha, a, B, k, beta, 0);// 1.0/ (phi(mu[l]-lam[k]) phi(mu[l]-lam[k]+eta) ) prodplus*= exp(re_ln_Fn_G_0[k][beta] + II * im_ln_Fn_G_0[k][beta] - re_ln_Fn_F_B_0[k][beta]);//Prod phi(mu[l]-lam[k]+eta) / prod_l!=k |phi(lam[l]-lam[k]) |; prodminus = Fn_K (A, j, alpha, a, B, k, beta, 1);// 1.0/ (phi(mu[l]-lam[k]) phi(mu[l]-lam[k]-eta) ) prodminus*= exp(re_ln_Fn_G_2[k][beta] + II * im_ln_Fn_G_2[k][beta] - re_ln_Fn_F_B_0[k][beta]);//Prod phi(mu[l]-lam[k]-eta)/ prod_l!=k | phi(lam[l]-lam[k]) |; - + Prod_powerN = pow((B.lambda[k][beta] - eta*0.5) /(B.lambda[k][beta] + eta*0.5), complex (B.chain.Nsites)); - + Gn[index_a][index_b] =eta*(prodplus-prodminus*Prod_powerN); - BnbDa[index_a][index_b]=Bnb*Da*exp(- re_ln_Fn_F_B_0[k][beta]); - + BnbDa[index_a][index_b]=Bnb*Da*exp(- re_ln_Fn_F_B_0[k][beta]); + } // if (B.chain.Str_L == 1) - + else{ - JSCerror("The Szz matrix element computation is not able to handle string states in the B.state (second argument). This is in development..."); - - } // else + ABACUSerror("The Szz matrix element computation is not able to handle string states in the B.state (second argument). This is in development..."); + + } // else index_b++; }}} // sums over k, beta, b index_a++; }}} // sums over j, alpha, a - -SQMat_CX matrix(0.0, A.base.Mdown); + +SQMat_CX matrix(0.0, A.base.Mdown); for(int a=0; a20){ result=-300; @@ -409,9 +424,9 @@ result=2*log(abs(F)); delete[] lam; } - + //return(result); return(0.5 * result); // Return ME, not MEsq } -} // namespace JSC +} // namespace ABACUS diff --git a/src/INFPREC/Infprec.cc b/src/INFPREC/Infprec.cc deleted file mode 100644 index fd64016..0000000 --- a/src/INFPREC/Infprec.cc +++ /dev/null @@ -1,25 +0,0 @@ -/********************************************************** - -This software is part of J.-S. Caux's ABACUS++ library. - -Copyright (c) - ------------------------------------------------------------ - -File: Infprec.cc - -Purpose: Definitions for infinite precision arithmetic classes. - -***********************************************************/ - -#include "JSC.h" - -using namespace std; - -namespace JSC { - - //*************************************************************************************************** - - - -} // namespace JSC diff --git a/src/INTEG/Integration.cc b/src/INTEG/Integration.cc index 663ee05..b00ec2e 100644 --- a/src/INTEG/Integration.cc +++ b/src/INTEG/Integration.cc @@ -1,8 +1,8 @@ /**************************************************************** -This software is part of J.-S. Caux's ABACUS++ library. +This software is part of J.-S. Caux's ABACUS library. -Copyright (c) +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -10,14 +10,13 @@ Integration.cc Defines all functions to perform integration of functions. - ******************************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -namespace JSC { +namespace ABACUS { // ********************* class I_table ****************************** @@ -26,7 +25,7 @@ namespace JSC { function = function_ref; if (!(*this).Load(rhomin_ref, rhomax_ref, Nvals_ref, req_prec)) { - + Nvals = Nvals_ref; rhomin = rhomin_ref; rhomax = rhomax_ref; @@ -35,10 +34,10 @@ namespace JSC { //I_tbl = Vect_DP (Nvals + 1); rho_tbl = new DP[Nvals + 1]; I_tbl = new DP[Nvals + 1]; - + logalpha = log(rhomax/rhomin)/Nvals; alpha = exp(logalpha); - + for (int i = 0; i <= Nvals ; ++i) { rho_tbl[i] = rhomin * pow(alpha, DP(i)); //I_tbl[i] = I_integral (rho_tbl[i], req_prec); @@ -51,7 +50,7 @@ namespace JSC { DP I_table::Return_val (DP req_rho) { - + //cout << "requesting I of " << req_rho << endl; DP used_rho = fabs(req_rho); @@ -83,7 +82,7 @@ namespace JSC { ofstream outfile; outfile.open(outfilename); outfile.precision(16); - + outfile << rho_tbl[0] << "\t" << I_tbl[0]; for (int i = 1; i <= Nvals; ++i) outfile << endl << rho_tbl[i] << "\t" << I_tbl[i]; @@ -101,7 +100,7 @@ namespace JSC { infile.open(infilename); if (infile.fail()) return (false); - + Nvals = Nvals_ref; rhomin = rhomin_ref; rhomax = rhomax_ref; @@ -120,7 +119,7 @@ namespace JSC { i++; } - if (i != Nvals + 1) JSCerror("Bad input file in I.Load."); + if (i != Nvals + 1) ABACUSerror("Bad input file in I.Load."); return(true); } @@ -128,8 +127,8 @@ namespace JSC { // ********************* class Integral_table ****************************** - Integral_table::Integral_table (DP (*function_ref) (DP, DP, int), const char* filenameprefix, - DP rhomin_ref, DP rhomax_ref, int Nvals_ref, DP req_prec, int max_nr_pts) + Integral_table::Integral_table (DP (*function_ref) (DP, DP, int), const char* filenameprefix, + DP rhomin_ref, DP rhomax_ref, int Nvals_ref, DP req_prec, int max_nr_pts) { function = function_ref; @@ -143,10 +142,10 @@ namespace JSC { rho_tbl = new DP[Nvals + 1]; I_tbl = new DP[Nvals + 1]; - + logalpha = log(rhomax/rhomin)/Nvals; alpha = exp(logalpha); - + for (int i = 0; i <= Nvals ; ++i) { rho_tbl[i] = rhomin * pow(alpha, DP(i)); I_tbl[i] = function (rho_tbl[i], req_prec, max_nr_pts); @@ -157,7 +156,7 @@ namespace JSC { } DP Integral_table::Return_val (DP req_rho) { - + //cout << "requesting I of " << req_rho << endl; if (req_rho < rhomin || req_rho >= rhomax) @@ -178,7 +177,7 @@ namespace JSC { void Integral_table::Save (const char* filenameprefix) { stringstream outfile_strstream; - outfile_strstream << "Integral_table_" << filenameprefix << "_rhomin_" << rhomin << "_rhomax_" << rhomax + outfile_strstream << "Integral_table_" << filenameprefix << "_rhomin_" << rhomin << "_rhomax_" << rhomax << "_Nvals_" << Nvals << "_prec_" << prec << "_maxnrpts_" << maxnrpts << ".dat"; string outfile_str = outfile_strstream.str(); const char* outfilename = outfile_str.c_str(); @@ -186,7 +185,7 @@ namespace JSC { ofstream outfile; outfile.open(outfilename); outfile.precision(16); - + outfile << rho_tbl[0] << "\t" << I_tbl[0]; for (int i = 1; i <= Nvals; ++i) outfile << endl << rho_tbl[i] << "\t" << I_tbl[i]; @@ -226,7 +225,7 @@ namespace JSC { i++; } - if (i != Nvals + 1) JSCerror("Bad input file in Integral_table.Load."); + if (i != Nvals + 1) ABACUSerror("Bad input file in Integral_table.Load."); return(true); } @@ -238,62 +237,62 @@ namespace JSC { DP Integrate_Riemann (DP (*function) (Vect_DP), Vect_DP& args, int arg_to_integ, DP xmin, DP xmax, int Npts) { if (xmax < xmin) return(-Integrate_Riemann (function, args, arg_to_integ, xmax, xmin, Npts)); - + //cout << "Calling Integrate on argument " << arg_to_integ << " between " << xmin << " and " << xmax << " to prec " << req_prec << endl; - + DP dx = (xmax - xmin)/Npts; - + DP result = 0.0; - + for (int i = 0; i < Npts; ++i) { args[arg_to_integ] = xmin + (i + 0.5) * dx; result += function (args); } result *= dx; - + return(result); } - DP Integrate_Riemann_using_table (DP (*function) (Vect_DP, I_table), Vect_DP& args, int arg_to_integ, I_table Itable, + DP Integrate_Riemann_using_table (DP (*function) (Vect_DP, I_table), Vect_DP& args, int arg_to_integ, I_table Itable, DP xmin, DP xmax, int Npts) { if (xmax < xmin) return(-Integrate_Riemann_using_table (function, args, arg_to_integ, Itable, xmax, xmin, Npts)); - + //cout << "Calling Integrate on argument " << arg_to_integ << " between " << xmin << " and " << xmax << " to prec " << req_prec << endl; - + DP dx = (xmax - xmin)/Npts; - + DP result = 0.0; - + for (int i = 0; i < Npts; ++i) { args[arg_to_integ] = xmin + (i + 0.5) * dx; result += function (args, Itable); } result *= dx; - + return(result); } // *********************************** Adaptive Riemann sum (straight recursive) ******************************************* - + DP Integrate_rec_main (DP (*function) (Vect_DP), Vect_DP& args, int arg_to_integ, DP xmin, DP xmax, DP req_prec, int rec_level, int max_rec_level, DP* f) { //cout << "Recursion level " << rec_level << endl; - + //cout << "Calling Integrate_rec on argument " << arg_to_integ << " between " << xmin << " and " << xmax << " to prec " << req_prec << endl; - + if (rec_level > max_rec_level) { //cout << "Warning: integral didn't converge between " << setprecision(10) << xmin << " and " << xmax << endl; return((xmax - xmin) * (f[0] + f[1] + f[2])/3.0); } - //if (rec_level > 16) JSCerror("Recursion level too high in Integrate_rec."); - + //if (rec_level > 16) ABACUSerror("Recursion level too high in Integrate_rec."); + DP* f1 = new DP[9]; - + DP dx = (xmax - xmin)/9.0; - + args[arg_to_integ] = xmin + 0.5 * dx; f1[0] = function (args); f1[1] = f[0]; @@ -309,75 +308,75 @@ namespace JSC { f1[7] = f[2]; args[arg_to_integ] = xmin + 8.5 * dx; f1[8] = function (args); - + DP I1_pre = 3.0 * dx * f[0]; DP I1 = dx * (f1[0] + f1[1] + f1[2]); - - if (fabs(I1 - I1_pre) > req_prec || rec_level < 5) + + if (fabs(I1 - I1_pre) > req_prec || rec_level < 5) I1 = Integrate_rec_main (function, args, arg_to_integ, xmin, xmin + 3.0 * dx, req_prec, rec_level + 1, max_rec_level, f1); - + DP I2_pre = 3.0 * dx * f[1]; DP I2 = dx * (f1[3] + f1[4] + f1[5]); - + if (fabs(I2 - I2_pre) > req_prec || rec_level < 5) I2 = Integrate_rec_main (function, args, arg_to_integ, xmin + 3.0 * dx, xmin + 6.0 * dx, req_prec, rec_level + 1, max_rec_level, &f1[3]); - + DP I3_pre = 3.0 * dx * f[2]; DP I3 = dx * (f1[6] + f1[7] + f1[8]); - - if (fabs(I3 - I3_pre) > req_prec || rec_level < 5) + + if (fabs(I3 - I3_pre) > req_prec || rec_level < 5) I3 = Integrate_rec_main (function, args, arg_to_integ, xmin + 6.0 * dx, xmax, req_prec, rec_level + 1, max_rec_level, &f1[6]); - + delete[] f1; - + return(I1 + I2 + I3); } - + DP Integrate_rec (DP (*function) (Vect_DP), Vect_DP& args, int arg_to_integ, DP xmin, DP xmax, DP req_prec, int max_rec_level) { if (xmax < xmin) return(-Integrate_rec(function, args, arg_to_integ, xmax, xmin, req_prec, max_rec_level)); - + //cout << "Calling Integrate on argument " << arg_to_integ << " between " << xmin << " and " << xmax << " to prec " << req_prec << endl; - + DP* f = new DP[3]; DP dx = (xmax - xmin)/3.0; - + DP sum_fabs_f = 0.0; - + for (int i = 0; i < 3; ++i) { args[arg_to_integ] = xmin + (i + 0.5) * dx; f[i] = function (args); sum_fabs_f += fabs(f[i]); } - + DP req_prec_rec = sum_fabs_f > 1.0 ? sum_fabs_f * req_prec : req_prec; - + //cout << "In Integrate: sum_fabs_f = " << sum_fabs_f << endl; - - DP answer = Integrate_rec_main (function, args, arg_to_integ, xmin, xmax, req_prec_rec, 0, max_rec_level, f); - + + DP answer = Integrate_rec_main (function, args, arg_to_integ, xmin, xmax, req_prec_rec, 0, max_rec_level, f); + delete[] f; - + return(answer); } - DP Integrate_rec_main_using_table (DP (*function) (Vect_DP, I_table), Vect_DP& args, int arg_to_integ, I_table Itable, + DP Integrate_rec_main_using_table (DP (*function) (Vect_DP, I_table), Vect_DP& args, int arg_to_integ, I_table Itable, DP xmin, DP xmax, DP req_prec, int rec_level, int max_rec_level, DP* f) { //cout << "Recursion level " << rec_level << endl; - + //cout << "Calling Integrate_rec on argument " << arg_to_integ << " between " << xmin << " and " << xmax << " to prec " << req_prec << endl; - + if (rec_level > max_rec_level) { //cout << "Warning: integral didn't converge between " << setprecision(10) << xmin << " and " << xmax << endl; return((xmax - xmin) * (f[0] + f[1] + f[2])/3.0); } - //if (rec_level > 16) JSCerror("Recursion level too high in Integrate_rec."); - + //if (rec_level > 16) ABACUSerror("Recursion level too high in Integrate_rec."); + DP* f1 = new DP[9]; - + DP dx = (xmax - xmin)/9.0; - + args[arg_to_integ] = xmin + 0.5 * dx; f1[0] = function (args, Itable); f1[1] = f[0]; @@ -393,76 +392,76 @@ namespace JSC { f1[7] = f[2]; args[arg_to_integ] = xmin + 8.5 * dx; f1[8] = function (args, Itable); - + DP I1_pre = 3.0 * dx * f[0]; DP I1 = dx * (f1[0] + f1[1] + f1[2]); - - if (fabs(I1 - I1_pre) > req_prec || rec_level < 5) + + if (fabs(I1 - I1_pre) > req_prec || rec_level < 5) I1 = Integrate_rec_main_using_table (function, args, arg_to_integ, Itable, xmin, xmin + 3.0 * dx, req_prec, rec_level + 1, max_rec_level, f1); - + DP I2_pre = 3.0 * dx * f[1]; DP I2 = dx * (f1[3] + f1[4] + f1[5]); - + if (fabs(I2 - I2_pre) > req_prec || rec_level < 5) I2 = Integrate_rec_main_using_table (function, args, arg_to_integ, Itable, xmin + 3.0 * dx, xmin + 6.0 * dx, req_prec, rec_level + 1, max_rec_level, &f1[3]); - + DP I3_pre = 3.0 * dx * f[2]; DP I3 = dx * (f1[6] + f1[7] + f1[8]); - - if (fabs(I3 - I3_pre) > req_prec || rec_level < 5) + + if (fabs(I3 - I3_pre) > req_prec || rec_level < 5) I3 = Integrate_rec_main_using_table (function, args, arg_to_integ, Itable, xmin + 6.0 * dx, xmax, req_prec, rec_level + 1, max_rec_level, &f1[6]); - + delete[] f1; - + return(I1 + I2 + I3); } - DP Integrate_rec_using_table (DP (*function) (Vect_DP, I_table), Vect_DP& args, int arg_to_integ, I_table Itable, + DP Integrate_rec_using_table (DP (*function) (Vect_DP, I_table), Vect_DP& args, int arg_to_integ, I_table Itable, DP xmin, DP xmax, DP req_prec, int max_rec_level) { if (xmax < xmin) return(-Integrate_rec_using_table (function, args, arg_to_integ, Itable, xmax, xmin, req_prec, max_rec_level)); - + //cout << "Calling Integrate on argument " << arg_to_integ << " between " << xmin << " and " << xmax << " to prec " << req_prec << endl; - + DP* f = new DP[3]; DP dx = (xmax - xmin)/3.0; - + DP sum_fabs_f = 0.0; - + for (int i = 0; i < 3; ++i) { args[arg_to_integ] = xmin + (i + 0.5) * dx; f[i] = function (args, Itable); sum_fabs_f += fabs(f[i]); } - + DP req_prec_rec = sum_fabs_f > 1.0 ? sum_fabs_f * req_prec : req_prec; - + //cout << "In Integrate: sum_fabs_f = " << sum_fabs_f << endl; - - DP answer = Integrate_rec_main_using_table (function, args, arg_to_integ, Itable, xmin, xmax, req_prec_rec, 0, max_rec_level, f); - + + DP answer = Integrate_rec_main_using_table (function, args, arg_to_integ, Itable, xmin, xmax, req_prec_rec, 0, max_rec_level, f); + delete[] f; - + return(answer); } - - DP Integrate_rec_main_using_table (DP (*function) (Vect_DP, I_table), Vect_DP& args, int arg_to_integ, I_table Itable, + + DP Integrate_rec_main_using_table (DP (*function) (Vect_DP, I_table), Vect_DP& args, int arg_to_integ, I_table Itable, DP xmin, DP xmax, DP req_prec, int rec_level, int max_rec_level, DP* f, ofstream& outfile) { //cout << "Recursion level " << rec_level << endl; - + //cout << "Calling Integrate_rec on argument " << arg_to_integ << " between " << xmin << " and " << xmax << " to prec " << req_prec << endl; - + if (rec_level > max_rec_level) { //cout << "Warning: integral didn't converge between " << setprecision(10) << xmin << " and " << xmax << endl; return((xmax - xmin) * (f[0] + f[1] + f[2])/3.0); } - //if (rec_level > 16) JSCerror("Recursion level too high in Integrate_rec."); - + //if (rec_level > 16) ABACUSerror("Recursion level too high in Integrate_rec."); + DP* f1 = new DP[9]; - + DP dx = (xmax - xmin)/9.0; - + args[arg_to_integ] = xmin + 0.5 * dx; f1[0] = function (args, Itable); //outfile << args[arg_to_integ] << "\t" << f1[0] << endl; @@ -490,42 +489,42 @@ namespace JSC { f1[8] = function (args, Itable); //outfile << args[arg_to_integ] << "\t" << f1[8] << endl; outfile << args << "\t" << f1[8] << endl; - + DP I1_pre = 3.0 * dx * f[0]; DP I1 = dx * (f1[0] + f1[1] + f1[2]); - - if (fabs(I1 - I1_pre) > req_prec || rec_level < 5) + + if (fabs(I1 - I1_pre) > req_prec || rec_level < 5) I1 = Integrate_rec_main_using_table (function, args, arg_to_integ, Itable, xmin, xmin + 3.0 * dx, req_prec, rec_level + 1, max_rec_level, f1, outfile); - + DP I2_pre = 3.0 * dx * f[1]; DP I2 = dx * (f1[3] + f1[4] + f1[5]); - + if (fabs(I2 - I2_pre) > req_prec || rec_level < 5) I2 = Integrate_rec_main_using_table (function, args, arg_to_integ, Itable, xmin + 3.0 * dx, xmin + 6.0 * dx, req_prec, rec_level + 1, max_rec_level, &f1[3], outfile); - + DP I3_pre = 3.0 * dx * f[2]; DP I3 = dx * (f1[6] + f1[7] + f1[8]); - - if (fabs(I3 - I3_pre) > req_prec || rec_level < 5) + + if (fabs(I3 - I3_pre) > req_prec || rec_level < 5) I3 = Integrate_rec_main_using_table (function, args, arg_to_integ, Itable, xmin + 6.0 * dx, xmax, req_prec, rec_level + 1, max_rec_level, &f1[6], outfile); - + delete[] f1; - + return(I1 + I2 + I3); } - DP Integrate_rec_using_table (DP (*function) (Vect_DP, I_table), Vect_DP& args, int arg_to_integ, I_table Itable, + DP Integrate_rec_using_table (DP (*function) (Vect_DP, I_table), Vect_DP& args, int arg_to_integ, I_table Itable, DP xmin, DP xmax, DP req_prec, int max_rec_level, ofstream& outfile) { if (xmax < xmin) return(-Integrate_rec_using_table (function, args, arg_to_integ, Itable, xmax, xmin, req_prec, max_rec_level, outfile)); - + //cout << "Calling Integrate on argument " << arg_to_integ << " between " << xmin << " and " << xmax << " to prec " << req_prec << endl; - + DP* f = new DP[3]; DP dx = (xmax - xmin)/3.0; - + DP sum_fabs_f = 0.0; - + for (int i = 0; i < 3; ++i) { args[arg_to_integ] = xmin + (i + 0.5) * dx; f[i] = function (args, Itable); @@ -533,35 +532,35 @@ namespace JSC { outfile << args << "\t" << f[i] << endl; sum_fabs_f += fabs(f[i]); } - + DP req_prec_rec = sum_fabs_f > 1.0 ? sum_fabs_f * req_prec : req_prec; - + //cout << "In Integrate: sum_fabs_f = " << sum_fabs_f << endl; - - DP answer = Integrate_rec_main_using_table (function, args, arg_to_integ, Itable, xmin, xmax, req_prec_rec, 0, max_rec_level, f, outfile); - + + DP answer = Integrate_rec_main_using_table (function, args, arg_to_integ, Itable, xmin, xmax, req_prec_rec, 0, max_rec_level, f, outfile); + delete[] f; - + return(answer); } - DP Integrate_rec_main_using_table_and_file (DP (*function) (Vect_DP, I_table, ofstream&), Vect_DP& args, int arg_to_integ, I_table Itable, + DP Integrate_rec_main_using_table_and_file (DP (*function) (Vect_DP, I_table, ofstream&), Vect_DP& args, int arg_to_integ, I_table Itable, DP xmin, DP xmax, DP req_prec, int rec_level, int max_rec_level, DP* f, ofstream& outfile) { //cout << "Recursion level " << rec_level << endl; - + //cout << "Calling Integrate_rec on argument " << arg_to_integ << " between " << xmin << " and " << xmax << " to prec " << req_prec << endl; - + if (rec_level > max_rec_level) { //cout << "Warning: integral didn't converge between " << setprecision(10) << xmin << " and " << xmax << endl; return((xmax - xmin) * (f[0] + f[1] + f[2])/3.0); } - //if (rec_level > 16) JSCerror("Recursion level too high in Integrate_rec."); - + //if (rec_level > 16) ABACUSerror("Recursion level too high in Integrate_rec."); + DP* f1 = new DP[9]; - + DP dx = (xmax - xmin)/9.0; - + args[arg_to_integ] = xmin + 0.5 * dx; f1[0] = function (args, Itable, outfile); //outfile << args[arg_to_integ] << "\t" << f1[0] << endl; @@ -589,42 +588,42 @@ namespace JSC { f1[8] = function (args, Itable, outfile); //outfile << args[arg_to_integ] << "\t" << f1[8] << endl; outfile << args << "\t" << f1[8] << endl; - + DP I1_pre = 3.0 * dx * f[0]; DP I1 = dx * (f1[0] + f1[1] + f1[2]); - - if (fabs(I1 - I1_pre) > req_prec || rec_level < 5) + + if (fabs(I1 - I1_pre) > req_prec || rec_level < 5) I1 = Integrate_rec_main_using_table_and_file (function, args, arg_to_integ, Itable, xmin, xmin + 3.0 * dx, req_prec, rec_level + 1, max_rec_level, f1, outfile); - + DP I2_pre = 3.0 * dx * f[1]; DP I2 = dx * (f1[3] + f1[4] + f1[5]); - + if (fabs(I2 - I2_pre) > req_prec || rec_level < 5) I2 = Integrate_rec_main_using_table_and_file (function, args, arg_to_integ, Itable, xmin + 3.0 * dx, xmin + 6.0 * dx, req_prec, rec_level + 1, max_rec_level, &f1[3], outfile); - + DP I3_pre = 3.0 * dx * f[2]; DP I3 = dx * (f1[6] + f1[7] + f1[8]); - - if (fabs(I3 - I3_pre) > req_prec || rec_level < 5) + + if (fabs(I3 - I3_pre) > req_prec || rec_level < 5) I3 = Integrate_rec_main_using_table_and_file (function, args, arg_to_integ, Itable, xmin + 6.0 * dx, xmax, req_prec, rec_level + 1, max_rec_level, &f1[6], outfile); - + delete[] f1; - + return(I1 + I2 + I3); } - DP Integrate_rec_using_table_and_file (DP (*function) (Vect_DP, I_table, ofstream&), Vect_DP& args, int arg_to_integ, I_table Itable, + DP Integrate_rec_using_table_and_file (DP (*function) (Vect_DP, I_table, ofstream&), Vect_DP& args, int arg_to_integ, I_table Itable, DP xmin, DP xmax, DP req_prec, int max_rec_level, ofstream& outfile) { if (xmax < xmin) return(-Integrate_rec_using_table_and_file (function, args, arg_to_integ, Itable, xmax, xmin, req_prec, max_rec_level, outfile)); - + //cout << "Calling Integrate on argument " << arg_to_integ << " between " << xmin << " and " << xmax << " to prec " << req_prec << endl; - + DP* f = new DP[3]; DP dx = (xmax - xmin)/3.0; - + DP sum_fabs_f = 0.0; - + for (int i = 0; i < 3; ++i) { args[arg_to_integ] = xmin + (i + 0.5) * dx; f[i] = function (args, Itable, outfile); @@ -632,35 +631,35 @@ namespace JSC { outfile << args << "\t" << f[i] << endl; sum_fabs_f += fabs(f[i]); } - + DP req_prec_rec = sum_fabs_f > 1.0 ? sum_fabs_f * req_prec : req_prec; - + //cout << "In Integrate: sum_fabs_f = " << sum_fabs_f << endl; - - DP answer = Integrate_rec_main_using_table_and_file (function, args, arg_to_integ, Itable, xmin, xmax, req_prec_rec, 0, max_rec_level, f, outfile); - + + DP answer = Integrate_rec_main_using_table_and_file (function, args, arg_to_integ, Itable, xmin, xmax, req_prec_rec, 0, max_rec_level, f, outfile); + delete[] f; - + return(answer); } // THESE TWO FUNCTIONS HAVE NOT BEEN TESTED !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! - DP Integrate_exp_rec_using_table (DP (*function) (Vect_DP, I_table), Vect_DP& args, int arg_to_integ, I_table Itable, + DP Integrate_exp_rec_using_table (DP (*function) (Vect_DP, I_table), Vect_DP& args, int arg_to_integ, I_table Itable, DP xmin, DP xmax, DP eta_old, DP req_prec, int rec_level, int max_rec_level, DP* f, ofstream& outfile) { //cout << "Recursion level " << rec_level << endl; - + //cout << "Calling Integrate_rec on argument " << arg_to_integ << " between " << xmin << " and " << xmax << " to prec " << req_prec << endl; DP dx_over_x_old = 0.5 * (eta_old - 1.0/eta_old); if (rec_level > max_rec_level) { //cout << "Warning: integral didn't converge between " << setprecision(10) << xmin << " and " << xmax << endl; //return((xmax - xmin) * (f[0] + f[1] + f[2])/3.0); - return(dx_over_x_old * xmin * eta_old * (f[0] + eta_old * (f[1] + eta_old * f[2]))); + return(dx_over_x_old * xmin * eta_old * (f[0] + eta_old * (f[1] + eta_old * f[2]))); } - //if (rec_level > 16) JSCerror("Recursion level too high in Integrate_rec."); - + //if (rec_level > 16) ABACUSerror("Recursion level too high in Integrate_rec."); + DP* f1 = new DP[9]; DP* x_pts = new DP[9]; DP eta = pow(xmax/xmin, 1.0/18.0); @@ -669,7 +668,7 @@ namespace JSC { x_pts[0] = xmin * eta; for (int i = 1; i < 9; ++i) x_pts[i] = x_pts[i-1] * eta_sq; - + args[arg_to_integ] = x_pts[0]; f1[0] = function (args, Itable); outfile << args[arg_to_integ] << "\t" << f1[0] << endl; @@ -691,46 +690,46 @@ namespace JSC { args[arg_to_integ] = x_pts[8]; f1[8] = function (args, Itable); outfile << args[arg_to_integ] << "\t" << f1[8] << endl; - + DP I1_pre = dx_over_x_old * x_pts[1] * f1[1]; DP I1 = dx_over_x * (x_pts[0] * f1[0] + x_pts[1] * f1[1] + x_pts[2] * f1[2]); - - if (fabs(I1 - I1_pre) > req_prec || rec_level < 5) + + if (fabs(I1 - I1_pre) > req_prec || rec_level < 5) I1 = Integrate_exp_rec_using_table (function, args, arg_to_integ, Itable, xmin, x_pts[2] * eta, eta, req_prec, rec_level + 1, max_rec_level, f1, outfile); - + DP I2_pre = dx_over_x_old * x_pts[4] * f1[4]; DP I2 = dx_over_x * (x_pts[3] * f1[3] + x_pts[4] * f1[4] + x_pts[5] * f1[5]); - + if (fabs(I2 - I2_pre) > req_prec || rec_level < 5) I2 = Integrate_exp_rec_using_table (function, args, arg_to_integ, Itable, x_pts[2] * eta, x_pts[5] * eta, eta, req_prec, rec_level + 1, max_rec_level, &f1[3], outfile); - + DP I3_pre = dx_over_x_old * f1[7]; DP I3 = dx_over_x * (x_pts[6] * f1[6] + x_pts[7] * f1[7] + x_pts[8] * f1[8]); - - if (fabs(I3 - I3_pre) > req_prec || rec_level < 5) + + if (fabs(I3 - I3_pre) > req_prec || rec_level < 5) I3 = Integrate_exp_rec_using_table (function, args, arg_to_integ, Itable, x_pts[5] * eta, xmax, eta, req_prec, rec_level + 1, max_rec_level, &f1[6], outfile); - + delete[] f1; - + return(I1 + I2 + I3); } - DP Integrate_exp_using_table (DP (*function) (Vect_DP, I_table), Vect_DP& args, int arg_to_integ, I_table Itable, + DP Integrate_exp_using_table (DP (*function) (Vect_DP, I_table), Vect_DP& args, int arg_to_integ, I_table Itable, DP xmin, DP xmax, DP req_prec, int max_rec_level, ofstream& outfile) { // This uses an exponential progression of sampling points. - if (xmin <= 0.0) JSCerror("Use xmin > 0.0 in Integrate_exp."); - if (xmax <= 0.0) JSCerror("Use xmax > 0.0 in Integrate_exp."); + if (xmin <= 0.0) ABACUSerror("Use xmin > 0.0 in Integrate_exp."); + if (xmax <= 0.0) ABACUSerror("Use xmax > 0.0 in Integrate_exp."); if (xmax < xmin) return(-Integrate_exp_using_table (function, args, arg_to_integ, Itable, xmax, xmin, req_prec, max_rec_level, outfile)); - + //cout << "Calling Integrate on argument " << arg_to_integ << " between " << xmin << " and " << xmax << " to prec " << req_prec << endl; - + DP* f = new DP[3]; DP eta = pow(xmax/xmin, 1.0/6.0); //DP dx_over_x = 0.5 * (eta - 1.0/eta); - + DP sum_fabs_f = 0.0; args[arg_to_integ] = xmin * eta; @@ -747,13 +746,13 @@ namespace JSC { sum_fabs_f += fabs(f[2]); DP req_prec_rec = sum_fabs_f > 1.0 ? sum_fabs_f * req_prec : req_prec; - + //cout << "In Integrate: sum_fabs_f = " << sum_fabs_f << endl; - - DP answer = Integrate_exp_rec_using_table (function, args, arg_to_integ, Itable, xmin, xmax, eta, req_prec_rec, 0, max_rec_level, f, outfile); - + + DP answer = Integrate_exp_rec_using_table (function, args, arg_to_integ, Itable, xmin, xmax, eta, req_prec_rec, 0, max_rec_level, f, outfile); + delete[] f; - + return(answer); } @@ -764,7 +763,7 @@ namespace JSC { std::ostream& operator<< (std::ostream& s, const Integral_result& res) { s << res.integ_est << "\t" << res.abs_prec << "\t" << res.rel_prec << "\t" << res.n_vals; - + return(s); } @@ -799,13 +798,13 @@ namespace JSC { integ_res.abs_prec = 0.0; for (int j = 0; j < 3; ++j) { abs_d2f_dx[j] = dx * fabs(data[3*j].f - 2.0 * data[3*j + 1].f + data[3*j + 2].f); - max_abs_d2f_dx = JSC::max(max_abs_d2f_dx, abs_d2f_dx[j]); + max_abs_d2f_dx = ABACUS::max(max_abs_d2f_dx, abs_d2f_dx[j]); integ_res.abs_prec += abs_d2f_dx[j]; } integ_res.rel_prec = integ_res.abs_prec/integ_res.integ_est; - //for (int in = 0; in < n_vals; ++in) + //for (int in = 0; in < n_vals; ++in) //cout << in << "\t" << data[in].x << "\t" << data[in].f << "\t" << data[in].dx << endl; } @@ -834,13 +833,13 @@ namespace JSC { integ_res.abs_prec = 0.0; for (int j = 0; j < 3; ++j) { abs_d2f_dx[j] = dx * fabs(data[3*j].f - 2.0 * data[3*j + 1].f + data[3*j + 2].f); - max_abs_d2f_dx = JSC::max(max_abs_d2f_dx, abs_d2f_dx[j]); + max_abs_d2f_dx = ABACUS::max(max_abs_d2f_dx, abs_d2f_dx[j]); integ_res.abs_prec += abs_d2f_dx[j]; } integ_res.rel_prec = integ_res.abs_prec/integ_res.integ_est; - //for (int in = 0; in < n_vals; ++in) + //for (int in = 0; in < n_vals; ++in) //cout << in << "\t" << data[in].x << "\t" << data[in].f << "\t" << data[in].dx << endl; } @@ -869,13 +868,13 @@ namespace JSC { integ_res.abs_prec = 0.0; for (int j = 0; j < 3; ++j) { abs_d2f_dx[j] = dx * fabs(data[3*j].f - 2.0 * data[3*j + 1].f + data[3*j + 2].f); - max_abs_d2f_dx = JSC::max(max_abs_d2f_dx, abs_d2f_dx[j]); + max_abs_d2f_dx = ABACUS::max(max_abs_d2f_dx, abs_d2f_dx[j]); integ_res.abs_prec += abs_d2f_dx[j]; } integ_res.rel_prec = integ_res.abs_prec/integ_res.integ_est; - //for (int in = 0; in < n_vals; ++in) + //for (int in = 0; in < n_vals; ++in) //cout << in << "\t" << data[in].x << "\t" << data[in].f << "\t" << data[in].dx << endl; } @@ -885,7 +884,7 @@ namespace JSC { outfile.seekp(0); int i = 0; while (i < integ_res.n_vals && !(data[i].x == 0.0 && data[i].f == 0.0)) { - outfile << setprecision(16) << data[i].x << "\t" << data[i].f << endl; + outfile << setprecision(16) << data[i].x << "\t" << data[i].f << endl; i++; } } @@ -911,10 +910,10 @@ namespace JSC { threei = 3 * i; if (abs_d2f_dx[i] <= 0.1 * max_abs_d2f_dx || index_new + integ_res.n_vals - threei > max_nr_pts) { - + // simply transfer the data points into new_data - new_abs_d2f_dx[index_new/3] = abs_d2f_dx[i]; - new_max_abs_d2f_dx = JSC::max(new_max_abs_d2f_dx, new_abs_d2f_dx[index_new/3]); + new_abs_d2f_dx[index_new/3] = abs_d2f_dx[i]; + new_max_abs_d2f_dx = ABACUS::max(new_max_abs_d2f_dx, new_abs_d2f_dx[index_new/3]); for (j = 0; j < 3; ++j) { new_data[index_new].x = data[threei + j].x; new_data[index_new].f = data[threei + j].f; @@ -965,12 +964,12 @@ namespace JSC { new_abs_d2f_dx[index_new/3 + 1] = fabs(new_data[index_new].dx * (new_data[index_new + 3].f - 2.0 * new_data[index_new + 4].f + new_data[index_new + 5].f)); new_abs_d2f_dx[index_new/3 + 2] = fabs(new_data[index_new].dx * (new_data[index_new + 6].f - 2.0 * new_data[index_new + 7].f + new_data[index_new + 8].f)); - new_max_abs_d2f_dx = JSC::max(new_max_abs_d2f_dx, new_abs_d2f_dx[index_new/3]); - new_max_abs_d2f_dx = JSC::max(new_max_abs_d2f_dx, new_abs_d2f_dx[index_new/3 + 1]); - new_max_abs_d2f_dx = JSC::max(new_max_abs_d2f_dx, new_abs_d2f_dx[index_new/3 + 2]); + new_max_abs_d2f_dx = ABACUS::max(new_max_abs_d2f_dx, new_abs_d2f_dx[index_new/3]); + new_max_abs_d2f_dx = ABACUS::max(new_max_abs_d2f_dx, new_abs_d2f_dx[index_new/3 + 1]); + new_max_abs_d2f_dx = ABACUS::max(new_max_abs_d2f_dx, new_abs_d2f_dx[index_new/3 + 2]); integ_res.integ_est += new_data[index_new].dx * (new_data[index_new].f + new_data[index_new + 1].f + new_data[index_new + 2].f - + new_data[index_new + 3].f + new_data[index_new + 4].f + new_data[index_new + 5].f + + new_data[index_new + 3].f + new_data[index_new + 4].f + new_data[index_new + 5].f + new_data[index_new + 6].f + new_data[index_new + 7].f + new_data[index_new + 8].f); integ_res.abs_prec += new_abs_d2f_dx[index_new/3] + new_abs_d2f_dx[index_new/3 + 1] + new_abs_d2f_dx[index_new/3 + 2]; @@ -1017,10 +1016,10 @@ namespace JSC { threei = 3 * i; if (abs_d2f_dx[i] <= 0.1 * max_abs_d2f_dx || index_new + integ_res.n_vals - threei > max_nr_pts) { - + // simply transfer the data points into new_data new_abs_d2f_dx[index_new/3] = abs_d2f_dx[i]; - new_max_abs_d2f_dx = JSC::max(new_max_abs_d2f_dx, new_abs_d2f_dx[index_new/3]); + new_max_abs_d2f_dx = ABACUS::max(new_max_abs_d2f_dx, new_abs_d2f_dx[index_new/3]); for (j = 0; j < 3; ++j) { new_data[index_new].x = data[threei + j].x; new_data[index_new].f = data[threei + j].f; @@ -1071,12 +1070,12 @@ namespace JSC { new_abs_d2f_dx[index_new/3 + 1] = fabs(new_data[index_new].dx * (new_data[index_new + 3].f - 2.0 * new_data[index_new + 4].f + new_data[index_new + 5].f)); new_abs_d2f_dx[index_new/3 + 2] = fabs(new_data[index_new].dx * (new_data[index_new + 6].f - 2.0 * new_data[index_new + 7].f + new_data[index_new + 8].f)); - new_max_abs_d2f_dx = JSC::max(new_max_abs_d2f_dx, new_abs_d2f_dx[index_new/3]); - new_max_abs_d2f_dx = JSC::max(new_max_abs_d2f_dx, new_abs_d2f_dx[index_new/3 + 1]); - new_max_abs_d2f_dx = JSC::max(new_max_abs_d2f_dx, new_abs_d2f_dx[index_new/3 + 2]); + new_max_abs_d2f_dx = ABACUS::max(new_max_abs_d2f_dx, new_abs_d2f_dx[index_new/3]); + new_max_abs_d2f_dx = ABACUS::max(new_max_abs_d2f_dx, new_abs_d2f_dx[index_new/3 + 1]); + new_max_abs_d2f_dx = ABACUS::max(new_max_abs_d2f_dx, new_abs_d2f_dx[index_new/3 + 2]); integ_res.integ_est += new_data[index_new].dx * (new_data[index_new].f + new_data[index_new + 1].f + new_data[index_new + 2].f - + new_data[index_new + 3].f + new_data[index_new + 4].f + new_data[index_new + 5].f + + new_data[index_new + 3].f + new_data[index_new + 4].f + new_data[index_new + 5].f + new_data[index_new + 6].f + new_data[index_new + 7].f + new_data[index_new + 8].f); integ_res.abs_prec += new_abs_d2f_dx[index_new/3] + new_abs_d2f_dx[index_new/3 + 1] + new_abs_d2f_dx[index_new/3 + 2]; @@ -1123,10 +1122,10 @@ namespace JSC { threei = 3 * i; if (abs_d2f_dx[i] <= 0.1 * max_abs_d2f_dx || index_new + integ_res.n_vals - threei > max_nr_pts) { - + // simply transfer the data points into new_data new_abs_d2f_dx[index_new/3] = abs_d2f_dx[i]; - new_max_abs_d2f_dx = JSC::max(new_max_abs_d2f_dx, new_abs_d2f_dx[index_new/3]); + new_max_abs_d2f_dx = ABACUS::max(new_max_abs_d2f_dx, new_abs_d2f_dx[index_new/3]); for (j = 0; j < 3; ++j) { new_data[index_new].x = data[threei + j].x; new_data[index_new].f = data[threei + j].f; @@ -1177,12 +1176,12 @@ namespace JSC { new_abs_d2f_dx[index_new/3 + 1] = fabs(new_data[index_new].dx * (new_data[index_new + 3].f - 2.0 * new_data[index_new + 4].f + new_data[index_new + 5].f)); new_abs_d2f_dx[index_new/3 + 2] = fabs(new_data[index_new].dx * (new_data[index_new + 6].f - 2.0 * new_data[index_new + 7].f + new_data[index_new + 8].f)); - new_max_abs_d2f_dx = JSC::max(new_max_abs_d2f_dx, new_abs_d2f_dx[index_new/3]); - new_max_abs_d2f_dx = JSC::max(new_max_abs_d2f_dx, new_abs_d2f_dx[index_new/3 + 1]); - new_max_abs_d2f_dx = JSC::max(new_max_abs_d2f_dx, new_abs_d2f_dx[index_new/3 + 2]); + new_max_abs_d2f_dx = ABACUS::max(new_max_abs_d2f_dx, new_abs_d2f_dx[index_new/3]); + new_max_abs_d2f_dx = ABACUS::max(new_max_abs_d2f_dx, new_abs_d2f_dx[index_new/3 + 1]); + new_max_abs_d2f_dx = ABACUS::max(new_max_abs_d2f_dx, new_abs_d2f_dx[index_new/3 + 2]); integ_res.integ_est += new_data[index_new].dx * (new_data[index_new].f + new_data[index_new + 1].f + new_data[index_new + 2].f - + new_data[index_new + 3].f + new_data[index_new + 4].f + new_data[index_new + 5].f + + new_data[index_new + 3].f + new_data[index_new + 4].f + new_data[index_new + 5].f + new_data[index_new + 6].f + new_data[index_new + 7].f + new_data[index_new + 8].f); integ_res.abs_prec += new_abs_d2f_dx[index_new/3] + new_abs_d2f_dx[index_new/3 + 1] + new_abs_d2f_dx[index_new/3 + 2]; @@ -1210,7 +1209,7 @@ namespace JSC { Integral_result Integrate_optimal (DP (*function) (Vect_DP), Vect_DP& args, int arg_to_integ, DP xmin, DP xmax, DP req_rel_prec, DP req_abs_prec, int max_nr_pts) { - if (xmax < xmin) JSCerror("Use xmax > xmin in Integrate."); + if (xmax < xmin) ABACUSerror("Use xmax > xmin in Integrate."); Integral_data integ_dat (function, args, arg_to_integ, xmin, xmax); @@ -1228,10 +1227,10 @@ namespace JSC { return(integ_dat.integ_res); } - Integral_result Integrate_optimal_using_table (DP (*function) (Vect_DP, I_table), Vect_DP& args, int arg_to_integ, + Integral_result Integrate_optimal_using_table (DP (*function) (Vect_DP, I_table), Vect_DP& args, int arg_to_integ, I_table Itable, DP xmin, DP xmax, DP req_rel_prec, DP req_abs_prec, int max_nr_pts) { - if (xmax < xmin) JSCerror("Use xmax > xmin in Integrate."); + if (xmax < xmin) ABACUSerror("Use xmax > xmin in Integrate."); Integral_data integ_dat (function, args, arg_to_integ, Itable, xmin, xmax); @@ -1243,10 +1242,10 @@ namespace JSC { return(integ_dat.integ_res); } - Integral_result Integrate_optimal_using_table (DP (*function) (Vect_DP, Integral_table), Vect_DP& args, int arg_to_integ, + Integral_result Integrate_optimal_using_table (DP (*function) (Vect_DP, Integral_table), Vect_DP& args, int arg_to_integ, Integral_table Itable, DP xmin, DP xmax, DP req_rel_prec, DP req_abs_prec, int max_nr_pts) { - if (xmax < xmin) JSCerror("Use xmax > xmin in Integrate."); + if (xmax < xmin) ABACUSerror("Use xmax > xmin in Integrate."); Integral_data integ_dat (function, args, arg_to_integ, Itable, xmin, xmax); @@ -1258,10 +1257,10 @@ namespace JSC { return(integ_dat.integ_res); } - Integral_result Integrate_optimal_using_table (DP (*function) (Vect_DP, I_table), Vect_DP& args, int arg_to_integ, + Integral_result Integrate_optimal_using_table (DP (*function) (Vect_DP, I_table), Vect_DP& args, int arg_to_integ, I_table Itable, DP xmin, DP xmax, DP req_rel_prec, DP req_abs_prec, int max_nr_pts, ofstream& outfile) { - if (xmax < xmin) JSCerror("Use xmax > xmin in Integrate."); + if (xmax < xmin) ABACUSerror("Use xmax > xmin in Integrate."); Integral_data integ_dat (function, args, arg_to_integ, Itable, xmin, xmax); @@ -1283,7 +1282,7 @@ namespace JSC { std::ostream& operator<< (std::ostream& s, const Integral_result_CX& res) { s << real(res.integ_est) << "\t" << imag(res.integ_est) << "\t" << res.abs_prec << "\t" << res.rel_prec << "\t" << res.n_vals; - + return(s); } @@ -1318,13 +1317,13 @@ namespace JSC { integ_res.abs_prec = 0.0; for (int j = 0; j < 3; ++j) { abs_d2f_dx[j] = dx * abs(data[3*j].f - 2.0 * data[3*j + 1].f + data[3*j + 2].f); - max_abs_d2f_dx = JSC::max(max_abs_d2f_dx, abs_d2f_dx[j]); + max_abs_d2f_dx = ABACUS::max(max_abs_d2f_dx, abs_d2f_dx[j]); integ_res.abs_prec += abs_d2f_dx[j]; } integ_res.rel_prec = integ_res.abs_prec/abs(integ_res.integ_est); - //for (int in = 0; in < n_vals; ++in) + //for (int in = 0; in < n_vals; ++in) //cout << in << "\t" << data[in].x << "\t" << data[in].f << "\t" << data[in].dx << endl; } @@ -1355,13 +1354,13 @@ namespace JSC { integ_res.abs_prec = 0.0; for (int j = 0; j < 3; ++j) { abs_d2f_dx[j] = dx * fabs(data[3*j].f - 2.0 * data[3*j + 1].f + data[3*j + 2].f); - max_abs_d2f_dx = JSC::max(max_abs_d2f_dx, abs_d2f_dx[j]); + max_abs_d2f_dx = ABACUS::max(max_abs_d2f_dx, abs_d2f_dx[j]); integ_res.abs_prec += abs_d2f_dx[j]; } integ_res.rel_prec = integ_res.abs_prec/integ_res.integ_est; - //for (int in = 0; in < n_vals; ++in) + //for (int in = 0; in < n_vals; ++in) //cout << in << "\t" << data[in].x << "\t" << data[in].f << "\t" << data[in].dx << endl; } */ @@ -1371,7 +1370,7 @@ namespace JSC { outfile.seekp(0); int i = 0; while (i < integ_res.n_vals && !(data[i].x == 0.0 && data[i].f == 0.0)) { - outfile << setprecision(16) << data[i].x << "\t" << data[i].f << endl; + outfile << setprecision(16) << data[i].x << "\t" << data[i].f << endl; i++; } } @@ -1397,10 +1396,10 @@ namespace JSC { threei = 3 * i; if (abs_d2f_dx[i] <= 0.1 * max_abs_d2f_dx || index_new + integ_res.n_vals - threei > max_nr_pts) { - + // simply transfer the data points into new_data - new_abs_d2f_dx[index_new/3] = abs_d2f_dx[i]; - new_max_abs_d2f_dx = JSC::max(new_max_abs_d2f_dx, new_abs_d2f_dx[index_new/3]); + new_abs_d2f_dx[index_new/3] = abs_d2f_dx[i]; + new_max_abs_d2f_dx = ABACUS::max(new_max_abs_d2f_dx, new_abs_d2f_dx[index_new/3]); for (j = 0; j < 3; ++j) { new_data[index_new].x = data[threei + j].x; new_data[index_new].f = data[threei + j].f; @@ -1451,12 +1450,12 @@ namespace JSC { new_abs_d2f_dx[index_new/3 + 1] = abs(new_data[index_new].dx * (new_data[index_new + 3].f - 2.0 * new_data[index_new + 4].f + new_data[index_new + 5].f)); new_abs_d2f_dx[index_new/3 + 2] = abs(new_data[index_new].dx * (new_data[index_new + 6].f - 2.0 * new_data[index_new + 7].f + new_data[index_new + 8].f)); - new_max_abs_d2f_dx = JSC::max(new_max_abs_d2f_dx, new_abs_d2f_dx[index_new/3]); - new_max_abs_d2f_dx = JSC::max(new_max_abs_d2f_dx, new_abs_d2f_dx[index_new/3 + 1]); - new_max_abs_d2f_dx = JSC::max(new_max_abs_d2f_dx, new_abs_d2f_dx[index_new/3 + 2]); + new_max_abs_d2f_dx = ABACUS::max(new_max_abs_d2f_dx, new_abs_d2f_dx[index_new/3]); + new_max_abs_d2f_dx = ABACUS::max(new_max_abs_d2f_dx, new_abs_d2f_dx[index_new/3 + 1]); + new_max_abs_d2f_dx = ABACUS::max(new_max_abs_d2f_dx, new_abs_d2f_dx[index_new/3 + 2]); integ_res.integ_est += new_data[index_new].dx * (new_data[index_new].f + new_data[index_new + 1].f + new_data[index_new + 2].f - + new_data[index_new + 3].f + new_data[index_new + 4].f + new_data[index_new + 5].f + + new_data[index_new + 3].f + new_data[index_new + 4].f + new_data[index_new + 5].f + new_data[index_new + 6].f + new_data[index_new + 7].f + new_data[index_new + 8].f); integ_res.abs_prec += new_abs_d2f_dx[index_new/3] + new_abs_d2f_dx[index_new/3 + 1] + new_abs_d2f_dx[index_new/3 + 2]; @@ -1505,10 +1504,10 @@ namespace JSC { threei = 3 * i; if (abs_d2f_dx[i] <= 0.1 * max_abs_d2f_dx || index_new + integ_res.n_vals - threei > max_nr_pts) { - + // simply transfer the data points into new_data new_abs_d2f_dx[index_new/3] = abs_d2f_dx[i]; - new_max_abs_d2f_dx = JSC::max(new_max_abs_d2f_dx, new_abs_d2f_dx[index_new/3]); + new_max_abs_d2f_dx = ABACUS::max(new_max_abs_d2f_dx, new_abs_d2f_dx[index_new/3]); for (j = 0; j < 3; ++j) { new_data[index_new].x = data[threei + j].x; new_data[index_new].f = data[threei + j].f; @@ -1559,12 +1558,12 @@ namespace JSC { new_abs_d2f_dx[index_new/3 + 1] = fabs(new_data[index_new].dx * (new_data[index_new + 3].f - 2.0 * new_data[index_new + 4].f + new_data[index_new + 5].f)); new_abs_d2f_dx[index_new/3 + 2] = fabs(new_data[index_new].dx * (new_data[index_new + 6].f - 2.0 * new_data[index_new + 7].f + new_data[index_new + 8].f)); - new_max_abs_d2f_dx = JSC::max(new_max_abs_d2f_dx, new_abs_d2f_dx[index_new/3]); - new_max_abs_d2f_dx = JSC::max(new_max_abs_d2f_dx, new_abs_d2f_dx[index_new/3 + 1]); - new_max_abs_d2f_dx = JSC::max(new_max_abs_d2f_dx, new_abs_d2f_dx[index_new/3 + 2]); + new_max_abs_d2f_dx = ABACUS::max(new_max_abs_d2f_dx, new_abs_d2f_dx[index_new/3]); + new_max_abs_d2f_dx = ABACUS::max(new_max_abs_d2f_dx, new_abs_d2f_dx[index_new/3 + 1]); + new_max_abs_d2f_dx = ABACUS::max(new_max_abs_d2f_dx, new_abs_d2f_dx[index_new/3 + 2]); integ_res.integ_est += new_data[index_new].dx * (new_data[index_new].f + new_data[index_new + 1].f + new_data[index_new + 2].f - + new_data[index_new + 3].f + new_data[index_new + 4].f + new_data[index_new + 5].f + + new_data[index_new + 3].f + new_data[index_new + 4].f + new_data[index_new + 5].f + new_data[index_new + 6].f + new_data[index_new + 7].f + new_data[index_new + 8].f); integ_res.abs_prec += new_abs_d2f_dx[index_new/3] + new_abs_d2f_dx[index_new/3 + 1] + new_abs_d2f_dx[index_new/3 + 2]; @@ -1591,10 +1590,10 @@ namespace JSC { } */ - Integral_result_CX Integrate_optimal (complex (*function) (Vect_DP), Vect_DP& args, int arg_to_integ, DP xmin, DP xmax, + Integral_result_CX Integrate_optimal (complex (*function) (Vect_DP), Vect_DP& args, int arg_to_integ, DP xmin, DP xmax, DP req_rel_prec, DP req_abs_prec, int max_nr_pts) { - if (xmax < xmin) JSCerror("Use xmax > xmin in Integrate."); + if (xmax < xmin) ABACUSerror("Use xmax > xmin in Integrate."); Integral_data_CX integ_dat (function, args, arg_to_integ, xmin, xmax); @@ -1608,10 +1607,10 @@ namespace JSC { // No implementation with I_table yet for complex... /* - Integral_result Integrate_optimal_using_table (DP (*function) (Vect_DP, I_table), Vect_DP& args, int arg_to_integ, + Integral_result Integrate_optimal_using_table (DP (*function) (Vect_DP, I_table), Vect_DP& args, int arg_to_integ, I_table Itable, DP xmin, DP xmax, DP req_rel_prec, DP req_abs_prec, int max_nr_pts) { - if (xmax < xmin) JSCerror("Use xmax > xmin in Integrate."); + if (xmax < xmin) ABACUSerror("Use xmax > xmin in Integrate."); Integral_data integ_dat (function, args, arg_to_integ, Itable, xmin, xmax); @@ -1626,10 +1625,10 @@ namespace JSC { // No implementation with I_table yet for complex... /* - Integral_result Integrate_optimal_using_table (DP (*function) (Vect_DP, I_table), Vect_DP& args, int arg_to_integ, + Integral_result Integrate_optimal_using_table (DP (*function) (Vect_DP, I_table), Vect_DP& args, int arg_to_integ, I_table Itable, DP xmin, DP xmax, DP req_rel_prec, DP req_abs_prec, int max_nr_pts, ofstream& outfile) { - if (xmax < xmin) JSCerror("Use xmax > xmin in Integrate."); + if (xmax < xmin) ABACUSerror("Use xmax > xmin in Integrate."); Integral_data integ_dat (function, args, arg_to_integ, Itable, xmin, xmax); @@ -1644,5 +1643,5 @@ namespace JSC { return(integ_dat.integ_res); } */ - -} // namespace JSC + +} // namespace ABACUS diff --git a/src/INTEG/Integration_par.cc b/src/INTEG/Integration_par.cc index d55a959..fa67471 100644 --- a/src/INTEG/Integration_par.cc +++ b/src/INTEG/Integration_par.cc @@ -2,7 +2,7 @@ This software is part of J.-S. Caux's C++ library. -Copyright (c) 2006. +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -10,16 +10,14 @@ Integration_par.cc Defines all functions to perform integration of functions, parallel (MPI). -LAST MODIFIED: 30/10/06 - ******************************************************************/ -#include "JSC.h" +#include "ABACUS.h" #include "mpi.h" using namespace std; -namespace JSC { +namespace ABACUS { void Improve_estimate_par (MPI_Comm comm, Integral_data& integdat, DP (*function) (Vect_DP, I_table), Vect_DP& args, int arg_to_integ, I_table Itable, int max_nr_pts) { @@ -44,10 +42,10 @@ namespace JSC { threei = 3 * i; if (integdat.abs_d2f_dx[i] <= 0.1 * integdat.max_abs_d2f_dx || index_new + integdat.integ_res.n_vals - threei > max_nr_pts) { - + // simply transfer the data points into new_data new_abs_d2f_dx[index_new/3] = integdat.abs_d2f_dx[i]; - new_max_abs_d2f_dx = JSC::max(new_max_abs_d2f_dx, new_abs_d2f_dx[index_new/3]); + new_max_abs_d2f_dx = ABACUS::max(new_max_abs_d2f_dx, new_abs_d2f_dx[index_new/3]); for (j = 0; j < 3; ++j) { new_data[index_new].x = integdat.data[threei + j].x; new_data[index_new].f = integdat.data[threei + j].f; @@ -98,12 +96,12 @@ namespace JSC { new_abs_d2f_dx[index_new/3 + 1] = fabs(new_data[index_new].dx * (new_data[index_new + 3].f - 2.0 * new_data[index_new + 4].f + new_data[index_new + 5].f)); new_abs_d2f_dx[index_new/3 + 2] = fabs(new_data[index_new].dx * (new_data[index_new + 6].f - 2.0 * new_data[index_new + 7].f + new_data[index_new + 8].f)); - new_max_abs_d2f_dx = JSC::max(new_max_abs_d2f_dx, new_abs_d2f_dx[index_new/3]); - new_max_abs_d2f_dx = JSC::max(new_max_abs_d2f_dx, new_abs_d2f_dx[index_new/3 + 1]); - new_max_abs_d2f_dx = JSC::max(new_max_abs_d2f_dx, new_abs_d2f_dx[index_new/3 + 2]); + new_max_abs_d2f_dx = ABACUS::max(new_max_abs_d2f_dx, new_abs_d2f_dx[index_new/3]); + new_max_abs_d2f_dx = ABACUS::max(new_max_abs_d2f_dx, new_abs_d2f_dx[index_new/3 + 1]); + new_max_abs_d2f_dx = ABACUS::max(new_max_abs_d2f_dx, new_abs_d2f_dx[index_new/3 + 2]); integdat.integ_res.integ_est += new_data[index_new].dx * (new_data[index_new].f + new_data[index_new + 1].f + new_data[index_new + 2].f - + new_data[index_new + 3].f + new_data[index_new + 4].f + new_data[index_new + 5].f + + new_data[index_new + 3].f + new_data[index_new + 4].f + new_data[index_new + 5].f + new_data[index_new + 6].f + new_data[index_new + 7].f + new_data[index_new + 8].f); integdat.integ_res.abs_prec += new_abs_d2f_dx[index_new/3] + new_abs_d2f_dx[index_new/3 + 1] + new_abs_d2f_dx[index_new/3 + 2]; @@ -130,10 +128,10 @@ namespace JSC { } - Integral_result Integrate_optimal_par_using_table (MPI_Comm comm, DP (*function) (Vect_DP, I_table), Vect_DP& args, int arg_to_integ, + Integral_result Integrate_optimal_par_using_table (MPI_Comm comm, DP (*function) (Vect_DP, I_table), Vect_DP& args, int arg_to_integ, I_table Itable, DP xmin, DP xmax, DP req_rel_prec, DP req_abs_prec, int max_nr_pts, ofstream& outfile) { - if (xmax < xmin) JSCerror("Use xmax > xmin in Integrate."); + if (xmax < xmin) ABACUSerror("Use xmax > xmin in Integrate."); Integral_data integ_dat (function, args, arg_to_integ, Itable, xmin, xmax); @@ -149,4 +147,4 @@ namespace JSC { } -} // namespace JSC +} // namespace ABACUS diff --git a/src/LIEBLIN/LiebLin_Bethe_State.cc b/src/LIEBLIN/LiebLin_Bethe_State.cc index b1f1758..e3318b4 100644 --- a/src/LIEBLIN/LiebLin_Bethe_State.cc +++ b/src/LIEBLIN/LiebLin_Bethe_State.cc @@ -2,7 +2,7 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -12,11 +12,11 @@ Purpose: Definitions for LiebLin_Bethe_State class. ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -namespace JSC { +namespace ABACUS { //*************************************************************************************************** @@ -24,27 +24,27 @@ namespace JSC { LiebLin_Bethe_State::LiebLin_Bethe_State () : c_int (0.0), L(0.0), cxL(0.0), N(0), - //OriginStateIxe(Vect(0,1)), + //OriginStateIxe(Vect(0,1)), Ix2_available(Vect(0, 1)), index_first_hole_to_right (Vect(0,1)), displacement (Vect(0,1)), Ix2(Vect(0, 1)), lambdaoc(Vect(0.0, 1)), //BE(Vect(0.0, 1)), S(Vect(0.0, 1)), dSdlambdaoc(Vect(0.0, 1)), diffsq(0.0), prec(ITER_REQ_PREC_LIEBLIN), conv(0), iter_Newton(0), E(0.0), iK(0), K(0.0), lnnorm(-100.0) { - stringstream Nout; Nout << N; label = Nout.str() + LABELSEP + JSCcoding[0] + LABELSEP;//"_0_"; + stringstream Nout; Nout << N; label = Nout.str() + LABELSEP + ABACUScoding[0] + LABELSEP;//"_0_"; } - LiebLin_Bethe_State::LiebLin_Bethe_State (DP c_int_ref, DP L_ref, int N_ref) + LiebLin_Bethe_State::LiebLin_Bethe_State (DP c_int_ref, DP L_ref, int N_ref) : c_int(c_int_ref), L(L_ref), cxL(c_int_ref * L_ref), N(N_ref), - //OriginStateIx2(Vect(0,N), + //OriginStateIx2(Vect(0,N), Ix2_available(Vect(0, 2)), index_first_hole_to_right (Vect(0,N)), displacement (Vect(0,N)), Ix2(Vect(0, N)), lambdaoc(Vect(0.0, N)), //BE(Vect(0.0, N)), S(Vect(0.0, N)), dSdlambdaoc(Vect(0.0, N)), - diffsq(0.0), prec(JSC::max(1.0, 1.0/(c_int * c_int)) * ITER_REQ_PREC_LIEBLIN), conv(0), iter_Newton(0), E(0.0), iK(0), K(0.0), lnnorm(-100.0) + diffsq(0.0), prec(ABACUS::max(1.0, 1.0/(c_int * c_int)) * ITER_REQ_PREC_LIEBLIN), conv(0), iter_Newton(0), E(0.0), iK(0), K(0.0), lnnorm(-100.0) { - if (c_int < 0.0) JSCerror("You must use a positive interaction parameter !"); - if (N < 0) JSCerror("Particle number must be strictly positive."); + if (c_int < 0.0) ABACUSerror("You must use a positive interaction parameter !"); + if (N < 0) ABACUSerror("Particle number must be strictly positive."); - stringstream Nout; Nout << N; label = Nout.str() + LABELSEP + JSCcoding[0] + LABELSEP;//+ "_0_"; + stringstream Nout; Nout << N; label = Nout.str() + LABELSEP + ABACUScoding[0] + LABELSEP;//+ "_0_"; // Set quantum numbers to ground-state configuration: for (int i = 0; i < N; ++i) Ix2[i] = -(N-1) + 2*i; @@ -91,12 +91,12 @@ namespace JSC { if (N != labeldata.M[0]) { cout << label_ref << endl; cout << labeldata.M << endl; - JSCerror("Trying to set an incorrect label on LiebLin_Bethe_State: N != M[0]."); + ABACUSerror("Trying to set an incorrect label on LiebLin_Bethe_State: N != M[0]."); } if (N != OriginStateIx2.size()) { cout << label_ref << endl; cout << labeldata.M << endl; - JSCerror("Trying to set an incorrect label on LiebLin_Bethe_State: N != OriginStateIx2.size()."); + ABACUSerror("Trying to set an incorrect label on LiebLin_Bethe_State: N != OriginStateIx2.size()."); } label = label_ref; @@ -136,7 +136,7 @@ namespace JSC { { // This function does not assume any ordering of the Ix2. - if (N != OriginStateIx2.size()) JSCerror("N != OriginStateIx2.size() in Set_Label_from_Ix2."); + if (N != OriginStateIx2.size()) ABACUSerror("N != OriginStateIx2.size() in Set_Label_from_Ix2."); //cout << "Setting label on Ix2 " << endl << Ix2 << endl; @@ -148,11 +148,11 @@ namespace JSC { for (int i = 0; i < N; ++i) if (!OriginStateIx2.includes(Ix2[i])) nexc_ref[0] += 1; Vect > Ix2old_ref(1); Vect > Ix2exc_ref(1); - Ix2old_ref[0] = Vect(JSC::max(nexc_ref[0],1)); - Ix2exc_ref[0] = Vect(JSC::max(nexc_ref[0],1)); + Ix2old_ref[0] = Vect(ABACUS::max(nexc_ref[0],1)); + Ix2exc_ref[0] = Vect(ABACUS::max(nexc_ref[0],1)); int nexccheck = 0; for (int i = 0; i < N; ++i) if (!OriginStateIx2.includes(Ix2[i])) Ix2exc_ref[0][nexccheck++] = Ix2[i]; - if (nexccheck != nexc_ref[0]) JSCerror("Counting excitations wrong (1) in LiebLin_Bethe_State::Set_Label_from_Ix2"); + if (nexccheck != nexc_ref[0]) ABACUSerror("Counting excitations wrong (1) in LiebLin_Bethe_State::Set_Label_from_Ix2"); nexccheck = 0; for (int i = 0; i < N; ++i) if (!Ix2.includes (OriginStateIx2[i])) Ix2old_ref[0][nexccheck++] = OriginStateIx2[i]; if (nexccheck != nexc_ref[0]) { @@ -162,7 +162,7 @@ namespace JSC { cout << nexc_ref[0] << endl; cout << Ix2old_ref[0] << endl; cout << Ix2exc_ref[0] << endl; - JSCerror("Counting excitations wrong (2) in LiebLin_Bethe_State::Set_Label_from_Ix2"); + ABACUSerror("Counting excitations wrong (2) in LiebLin_Bethe_State::Set_Label_from_Ix2"); } // Now order the Ix2old_ref and Ix2exc_ref: Ix2old_ref[0].QuickSort(); @@ -176,10 +176,10 @@ namespace JSC { /* void LiebLin_Bethe_State::Set_Label_from_Ix2 (const Vect& OriginStateIx2) { - // This function was deprecated since it assumed that the Ix2 of the state were + // This function was deprecated since it assumed that the Ix2 of the state were // in a particular order mirroring the indices of OriginStateIx2. - if (N != OriginStateIx2.size()) JSCerror("N != OriginStateIx2.size() in Set_Label_from_Ix2."); + if (N != OriginStateIx2.size()) ABACUSerror("N != OriginStateIx2.size() in Set_Label_from_Ix2."); Vect OriginStateIx2ordered = OriginStateIx2; OriginStateIx2ordered.QuickSort(); @@ -192,10 +192,10 @@ namespace JSC { for (int i = 0; i < N; ++i) if (Ix2[i] != OriginStateIx2ordered[i]) nexc_ref[0] += 1; Vect > Ix2old_ref(1); Vect > Ix2exc_ref(1); - Ix2old_ref[0] = Vect(JSC::max(nexc_ref[0],1)); - Ix2exc_ref[0] = Vect(JSC::max(nexc_ref[0],1)); + Ix2old_ref[0] = Vect(ABACUS::max(nexc_ref[0],1)); + Ix2exc_ref[0] = Vect(ABACUS::max(nexc_ref[0],1)); int nexccheck = 0; - for (int i = 0; i < N; ++i) + for (int i = 0; i < N; ++i) if (Ix2[i] != OriginStateIx2ordered[i]) { Ix2old_ref[0][nexccheck] = OriginStateIx2ordered[i]; Ix2exc_ref[0][nexccheck++] = Ix2[i]; @@ -209,9 +209,9 @@ namespace JSC { void LiebLin_Bethe_State::Set_Label_Internals_from_Ix2 (const Vect& OriginStateIx2) { - //JSCerror("LiebLin_Bethe_State::Set_Label_Internals_from_Ix2 deprecated 20110604"); + //ABACUSerror("LiebLin_Bethe_State::Set_Label_Internals_from_Ix2 deprecated 20110604"); - if (N != OriginStateIx2.size()) JSCerror("N != OriginStateIx2.size() in Set_Label_Internals_from_Ix2."); + if (N != OriginStateIx2.size()) ABACUSerror("N != OriginStateIx2.size() in Set_Label_Internals_from_Ix2."); Vect OriginStateIx2ordered = OriginStateIx2; OriginStateIx2ordered.QuickSort(); @@ -224,10 +224,10 @@ namespace JSC { for (int i = 0; i < N; ++i) if (!OriginStateIx2.includes(Ix2[i])) nexc_ref[0] += 1; Vect > Ix2old_ref(1); Vect > Ix2exc_ref(1); - Ix2old_ref[0] = Vect(JSC::max(nexc_ref[0],1)); - Ix2exc_ref[0] = Vect(JSC::max(nexc_ref[0],1)); + Ix2old_ref[0] = Vect(ABACUS::max(nexc_ref[0],1)); + Ix2exc_ref[0] = Vect(ABACUS::max(nexc_ref[0],1)); int nexccheck = 0; - for (int i = 0; i < N; ++i) + for (int i = 0; i < N; ++i) if (Ix2[i] != OriginStateIx2ordered[i]) { Ix2old_ref[0][nexccheck] = OriginStateIx2ordered[i]; Ix2exc_ref[0][nexccheck++] = Ix2[i]; @@ -238,13 +238,13 @@ namespace JSC { label = Return_State_Label (labeldata, OriginStateIx2); // Construct the Ix2_available vector: we give one more quantum number on left and right: - int navailable = 2 + (JSC::max(Ix2.max(), OriginStateIx2.max()) - JSC::min(Ix2.min(), OriginStateIx2.min()))/2 - N + 1; + int navailable = 2 + (ABACUS::max(Ix2.max(), OriginStateIx2.max()) - ABACUS::min(Ix2.min(), OriginStateIx2.min()))/2 - N + 1; Ix2_available = Vect(navailable); index_first_hole_to_right = Vect(N); // First set Ix2_available to all holes from left - for (int i = 0; i < Ix2_available.size(); ++i) Ix2_available[i] = JSC::min(Ix2.min(), OriginStateIx2.min()) - 2 + 2*i; - + for (int i = 0; i < Ix2_available.size(); ++i) Ix2_available[i] = ABACUS::min(Ix2.min(), OriginStateIx2.min()) - 2 + 2*i; + // Now shift according to Ix2 of OriginState: for (int j = 0; j < N; ++j) { int i = 0; @@ -255,7 +255,7 @@ namespace JSC { } // Ix2_available and index_first_hole_to_right are now fully defined. - // Now set displacement vector: + // Now set displacement vector: displacement = Vect(0, N); // Set displacement vector from the Ix2: for (int j = 0; j < N; ++j) { @@ -266,7 +266,7 @@ namespace JSC { //cout << j << "\t" << index_first_hole_to_right[j] << "\t" << displacement[j] << "\t" << Ix2_available[index_first_hole_to_right[j] + displacement[j] ] << endl; if (index_first_hole_to_right[j] + displacement[j] == 0) { cout << label << endl << j << endl << OriginStateIx2 << endl << Ix2 << endl << Ix2_available << endl << index_first_hole_to_right << endl << displacement << endl; - JSCerror("Going down too far in Set_Label_Internals..."); + ABACUSerror("Going down too far in Set_Label_Internals..."); } displacement[j]--; } @@ -279,13 +279,13 @@ namespace JSC { //cout << j << "\t" << index_first_hole_to_right[j] << "\t" << displacement[j] << "\t" << Ix2_available[index_first_hole_to_right[j] + displacement[j] ] << endl; if (index_first_hole_to_right[j] + displacement[j] == Ix2_available.size() - 1) { cout << label << endl << j << endl << OriginStateIx2 << endl << Ix2 << endl << Ix2_available << endl << index_first_hole_to_right << endl << displacement << endl; - JSCerror("Going up too far in Set_Label_Internals..."); + ABACUSerror("Going up too far in Set_Label_Internals..."); } displacement[j]++; } } } - //cout << "label " << label << endl; + //cout << "label " << label << endl; //cout << "Ix2: " << Ix2 << endl << "Ix2_available: " << Ix2_available << endl << "index...: " << index_first_hole_to_right << endl << "displacement: " << displacement << endl; //char a; cin >> a; @@ -352,7 +352,7 @@ namespace JSC { bool nonan = true; for (int j = 0; j < N; ++j) nonan *= !is_nan(lambdaoc[j]); - + return nonan; } @@ -363,7 +363,7 @@ namespace JSC { bool LiebLin_Bethe_State::Check_Symmetry () { - // Checks whether the I's are symmetrically distributed. + // Checks whether the I's are symmetrically distributed. bool symmetric_state = true; @@ -379,15 +379,15 @@ namespace JSC { void LiebLin_Bethe_State::Compute_lnnorm () { if (lnnorm == -100.0) { // else Gaudin part already calculated by Newton method - + SQMat_DP Gaudin_Red(N); (*this).Build_Reduced_Gaudin_Matrix(Gaudin_Red); - + lnnorm = real(lndet_LU_dstry(Gaudin_Red)); // Add the pieces outside of Gaudin determinant - + for (int j = 0; j < N - 1; ++j) for (int k = j+1; k < N; ++k) lnnorm += log(1.0 + 1.0/pow(lambdaoc[j] - lambdaoc[k], 2.0)); } @@ -408,14 +408,14 @@ namespace JSC { void LiebLin_Bethe_State::Set_Free_lambdaocs() { - if (cxL >= 1.0) + if (cxL >= 1.0) for (int a = 0; a < N; ++a) lambdaoc[a] = PI * Ix2[a]/cxL; // For small values of c, use better approximation using approximate zeroes of Hermite polynomials: see Gaudin eqn 4.71. if (cxL < 1.0) { //DP sqrtcL = pow(cxL, 0.5); DP oneoversqrtcLN = 1.0/pow(cxL * N, 0.5); - for (int a = 0; a < N; ++a) lambdaoc[a] = oneoversqrtcLN * PI * Ix2[a]; + for (int a = 0; a < N; ++a) lambdaoc[a] = oneoversqrtcLN * PI * Ix2[a]; //for (int a = 0; a < N; ++a) lambdaoc[a] = sqrtcL * PI * Ix2[a]; // wrong values, correct scaling with c //for (int a = 0; a < N; ++a) lambdaoc[a] = PI * Ix2[a]/(cxL + 2.0 * N); // set to minimal distance lattice @@ -430,12 +430,12 @@ namespace JSC { // does one step of simple iterations DP sumtheta = 0.0; - Vect_DP dlambdaoc (0.0, N); + Vect_DP dlambdaoc (0.0, N); for (int j = 0; j < N; ++j) { sumtheta = 0.0; - for (int k = 0; k < N; ++k) sumtheta += atan((lambdaoc[j] - lambdaoc[k])); + for (int k = 0; k < N; ++k) sumtheta += atan((lambdaoc[j] - lambdaoc[k])); sumtheta *= 2.0; dlambdaoc[j] = damping * ((PI*Ix2[j] - sumtheta)/cxL - lambdaoc[j]); @@ -456,7 +456,7 @@ namespace JSC { } diffsq /= DP(N); //diffsq /= sqrt(sumsq) * DP(N); - + return; } @@ -465,19 +465,19 @@ namespace JSC { // This is essentially Newton's method but only in one variable. // The logic is that the derivative of the LHS of the BE_j w/r to lambdaoc_j is much larger than with respect to lambdaoc_l with l != j. - Vect_DP dlambdaoc (0.0, N); + Vect_DP dlambdaoc (0.0, N); // Start by calculating S and dSdlambdaoc: for (int j = 0; j < N; ++j) { S[j] = 0.0; - for (int k = 0; k < N; ++k) S[j] += atan((lambdaoc[j] - lambdaoc[k])); + for (int k = 0; k < N; ++k) S[j] += atan((lambdaoc[j] - lambdaoc[k])); S[j] *= 2.0/cxL; dSdlambdaoc[j] = 0.0; - for (int k = 0; k < N; ++k) dSdlambdaoc[j] += 1.0/((lambdaoc[j] - lambdaoc[k]) * (lambdaoc[j] - lambdaoc[k]) + 1.0); + for (int k = 0; k < N; ++k) dSdlambdaoc[j] += 1.0/((lambdaoc[j] - lambdaoc[k]) * (lambdaoc[j] - lambdaoc[k]) + 1.0); dSdlambdaoc[j] *= 2.0/(PI * cxL); - + dlambdaoc[j] = (PI*Ix2[j]/cxL - S[j] + lambdaoc[j] * dSdlambdaoc[j])/(1.0 + dSdlambdaoc[j]) - lambdaoc[j]; } @@ -490,7 +490,7 @@ namespace JSC { else diffsq += cxL * cxL * dlambdaoc[i] * dlambdaoc[i]/(lambdaoc[i] * lambdaoc[i] + 1.0e-6); } diffsq /= DP(N); - + iter_Newton++; return; @@ -515,9 +515,9 @@ namespace JSC { sumtheta = 0.0; atanintshift = 0; for (int k = 0; k < N; ++k) - if (j != k) { // otherwise 0 + if (j != k) { // otherwise 0 if (fabs(lambdahere = lambdaoc[j] - lambdaoc[k]) < 1.0) { // use straight atan - sumtheta += atan(lambdahere); + sumtheta += atan(lambdahere); } else { // for large rapidities, use dual form of atan, extracting pi/2 factors atanintshift += sgn_DP(lambdahere); @@ -530,7 +530,7 @@ namespace JSC { RHSBAE[j] = cxL * lambdaoc[j] + sumtheta - PI*(Ix2[j] - atanintshift); } - + (*this).Build_Reduced_Gaudin_Matrix (Gaudin); for (int j = 0; j < N; ++j) dlambdaoc[j] = - RHSBAE[j]; @@ -553,17 +553,17 @@ namespace JSC { DP maxdlambdaoc = 0.0; do { ordering_still_changed = false; - if (dlambdaoc[0] < 0.0 && fabs(dlambdaoc[0]) > (maxdlambdaoc = 10.0*JSC::max(fabs(lambdaoc[0]), fabs(lambdaoc[N-1])))) + if (dlambdaoc[0] < 0.0 && fabs(dlambdaoc[0]) > (maxdlambdaoc = 10.0*ABACUS::max(fabs(lambdaoc[0]), fabs(lambdaoc[N-1])))) dlambdaoc[0] = -maxdlambdaoc; if (lambdaoc[0] + dlambdaoc[0] > lambdaoc[1] + dlambdaoc[1]) { dlambdaoc[0] = 0.25 * (lambdaoc[1] + dlambdaoc[1] - lambdaoc[0] ); // max quarter distance ordering_still_changed = true; //cout << "reason 1" << endl; } - if (dlambdaoc[N-1] > 0.0 && fabs(dlambdaoc[N-1]) > (maxdlambdaoc = 10.0*JSC::max(fabs(lambdaoc[0]), fabs(lambdaoc[N-1])))) + if (dlambdaoc[N-1] > 0.0 && fabs(dlambdaoc[N-1]) > (maxdlambdaoc = 10.0*ABACUS::max(fabs(lambdaoc[0]), fabs(lambdaoc[N-1])))) dlambdaoc[N-1] = maxdlambdaoc; if (lambdaoc[N-1] + dlambdaoc[N-1] < lambdaoc[N-2] + dlambdaoc[N-2]) { - dlambdaoc[N-1] = 0.25 * (lambdaoc[N-2] + dlambdaoc[N-2] - lambdaoc[N-1]); + dlambdaoc[N-1] = 0.25 * (lambdaoc[N-2] + dlambdaoc[N-2] - lambdaoc[N-1]); ordering_still_changed = true; //cout << "reason 2" << endl; } @@ -583,7 +583,7 @@ namespace JSC { } //if (ordering_changed) cout << "dlambdaoc post checking = " << dlambdaoc << endl; - + /* bool orderingchanged = false; //bool dlambdaexceedsmaxrapdiff = false; @@ -593,10 +593,10 @@ namespace JSC { orderingchanged = true; // We must damp the dlambda such that the ordering is unchanged: // the condition is lambdaoc[j] + damping*dlambdaoc[j] < lambdaoc[j+1] + damping*dlambdaoc[j+1] - damping_to_use = JSC::min(damping_to_use, 0.5 * (lambdaoc[j+1] - lambdaoc[j])/(dlambdaoc[j] - dlambdaoc[j+1])); + damping_to_use = ABACUS::min(damping_to_use, 0.5 * (lambdaoc[j+1] - lambdaoc[j])/(dlambdaoc[j] - dlambdaoc[j+1])); } */ - //for (int j = 0; j < N; ++j) + //for (int j = 0; j < N; ++j) //if (fabs(dlambdaoc[j]) > maxrapdiff) dlambdaexceedsmaxrapdiff = true; /* // The dlambdaoc must be smaller than the distance to neighbouring rapidities: @@ -663,11 +663,11 @@ namespace JSC { if (iK % 2) { cout << Ix2 << endl; cout << iK << "\t" << iK % 2 << endl; - JSCerror("Sum of Ix2 is not even: inconsistency."); + ABACUSerror("Sum of Ix2 is not even: inconsistency."); } iK /= 2; // sum of Ix2 is guaranteed even. - K = 2.0 * iK * PI/L; + K = 2.0 * iK * PI/L; } DP LiebLin_Bethe_State::Kernel (int a, int b) @@ -683,11 +683,11 @@ namespace JSC { void LiebLin_Bethe_State::Build_Reduced_Gaudin_Matrix (SQMat& Gaudin_Red) { - if (Gaudin_Red.size() != N) JSCerror("Passing matrix of wrong size in Build_Reduced_Gaudin_Matrix."); + if (Gaudin_Red.size() != N) ABACUSerror("Passing matrix of wrong size in Build_Reduced_Gaudin_Matrix."); DP sum_Kernel = 0.0; - for (int j = 0; j < N; ++j) + for (int j = 0; j < N; ++j) for (int k = 0; k < N; ++k) { if (j == k) { @@ -695,9 +695,9 @@ namespace JSC { for (int kp = 0; kp < N; ++kp) if (j != kp) sum_Kernel += Kernel (lambdaoc[j] - lambdaoc[kp]); Gaudin_Red[j][k] = cxL + sum_Kernel; } - + else Gaudin_Red[j][k] = - Kernel (lambdaoc[j] - lambdaoc[k]); - + } return; @@ -706,34 +706,34 @@ namespace JSC { void LiebLin_Bethe_State::Build_Reduced_BEC_Quench_Gaudin_Matrix (SQMat& Gaudin_Red) { // Passing a matrix of dimension N/2 - - if (N % 2 != 0) JSCerror("Choose a state with even numer of particles please"); - + + if (N % 2 != 0) ABACUSerror("Choose a state with even numer of particles please"); + // Check Parity invariant - + bool ck = true; - + for (int j = 0; j < N/2; ++j){ if(Ix2[j] != - Ix2[N-j-1]) ck = false;} - - if (!ck) JSCerror("Choose a parity invariant state please"); - - if (Gaudin_Red.size() != N/2) JSCerror("Passing matrix of wrong size in Build_Reduced_Gaudin_Matrix."); - + + if (!ck) ABACUSerror("Choose a parity invariant state please"); + + if (Gaudin_Red.size() != N/2) ABACUSerror("Passing matrix of wrong size in Build_Reduced_Gaudin_Matrix."); + DP sum_Kernel = 0.0; - + for (int j = 0; j < N/2; ++j) for (int k = 0; k < N/2; ++k) { - + if (j == k) { sum_Kernel = 0.0; for (int kp = N/2; kp < N; ++kp) if (j + N/2 != kp) sum_Kernel += Kernel (lambdaoc[j+N/2] - lambdaoc[kp]) + Kernel (lambdaoc[j+N/2] + lambdaoc[kp]); Gaudin_Red[j][k] = cxL + sum_Kernel; } - + else Gaudin_Red[j][k] = - (Kernel (lambdaoc[j+ N/2] - lambdaoc[k+ N/2]) + Kernel (lambdaoc[j+ N/2] + lambdaoc[k+ N/2]) ); - + } - + return; } @@ -748,9 +748,9 @@ namespace JSC { State_Label_Data currentdata = Read_State_Label ((*this).label, OriginStateIx2); //cout << "current Ix2old " << currentdata.Ix2old[0] << endl; //cout << "current Ix2exc " << currentdata.Ix2exc[0] << endl; - - if (ipart >= currentdata.nexc[0]) JSCerror("Particle label too large in LiebLin_Bethe_State::Annihilate_ph_pair."); - if (ihole >= currentdata.nexc[0]) JSCerror("Hole label too large in LiebLin_Bethe_State::Annihilate_ph_pair."); + + if (ipart >= currentdata.nexc[0]) ABACUSerror("Particle label too large in LiebLin_Bethe_State::Annihilate_ph_pair."); + if (ihole >= currentdata.nexc[0]) ABACUSerror("Hole label too large in LiebLin_Bethe_State::Annihilate_ph_pair."); // Simply remove the given pair: Vect type_new = currentdata.type; @@ -760,19 +760,19 @@ namespace JSC { int ntypespresent = 1; // only one type for LiebLin Vect > Ix2old_new(ntypespresent); Vect > Ix2exc_new(ntypespresent); - for (int it = 0; it < ntypespresent; ++it) Ix2old_new[it] = Vect(JSC::max(nexc_new[it],1)); - for (int it = 0; it < ntypespresent; ++it) Ix2exc_new[it] = Vect(JSC::max(nexc_new[it],1)); - + for (int it = 0; it < ntypespresent; ++it) Ix2old_new[it] = Vect(ABACUS::max(nexc_new[it],1)); + for (int it = 0; it < ntypespresent; ++it) Ix2exc_new[it] = Vect(ABACUS::max(nexc_new[it],1)); + // Copy earlier data in, leaving out ipart and ihole: for (int it = 0; it < ntypespresent; ++it) { for (int i = 0; i < nexc_new[it]; ++i) { - Ix2old_new[it][i] = currentdata.Ix2old[it][i + (i >= ihole)]; - Ix2exc_new[it][i] = currentdata.Ix2exc[it][i + (i >= ipart)]; + Ix2old_new[it][i] = currentdata.Ix2old[it][i + (i >= ihole)]; + Ix2exc_new[it][i] = currentdata.Ix2exc[it][i + (i >= ipart)]; } } //cout << "Ix2old_new " << Ix2old_new[0] << endl; //cout << "Ix2exc_new " << Ix2exc_new[0] << endl; - + State_Label_Data newdata (type_new, M_new, nexc_new, Ix2old_new, Ix2exc_new); (*this).Set_to_Label (Return_State_Label(newdata, OriginStateIx2)); @@ -793,7 +793,7 @@ namespace JSC { std::ostream& operator<< (std::ostream& s, const LiebLin_Bethe_State& state) { - s << endl << "******** State for c = " << state.c_int << " L = " << state.L << " N = " << state.N + s << endl << "******** State for c = " << state.c_int << " L = " << state.L << " N = " << state.N << " with label " << state.label << " ********" << endl; s << "Ix2:" << endl; for (int j = 0; j < state.N; ++j) s << state.Ix2[j] << " "; @@ -806,4 +806,4 @@ namespace JSC { } -} // namespace JSC +} // namespace ABACUS diff --git a/src/LIEBLIN/LiebLin_Chem_Pot.cc b/src/LIEBLIN/LiebLin_Chem_Pot.cc index 82c7883..70c40d6 100644 --- a/src/LIEBLIN/LiebLin_Chem_Pot.cc +++ b/src/LIEBLIN/LiebLin_Chem_Pot.cc @@ -2,7 +2,7 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -12,19 +12,19 @@ Purpose: calculates the chemical potential. ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -namespace JSC { +namespace ABACUS { - DP Chemical_Potential (LiebLin_Bethe_State& RefState) + DP Chemical_Potential (LiebLin_Bethe_State& RefState) { // RefState is used here to provide the c_int, L and N parameters. - LiebLin_Bethe_State Nplus1State(RefState.c_int, RefState.L, RefState.N + 1); - //LiebLin_Bethe_State NState(RefState.c_int, RefState.L, RefState.N); + LiebLin_Bethe_State Nplus1State(RefState.c_int, RefState.L, RefState.N + 1); + //LiebLin_Bethe_State NState(RefState.c_int, RefState.L, RefState.N); LiebLin_Bethe_State Nmin1State(RefState.c_int, RefState.L, RefState.N - 1); Nplus1State.Compute_All(true); @@ -35,4 +35,4 @@ namespace JSC { return(0.5 * (Nplus1State.E - Nmin1State.E)); } -} // namespace JSC +} // namespace ABACUS diff --git a/src/LIEBLIN/LiebLin_Matrix_Element_Contrib.cc b/src/LIEBLIN/LiebLin_Matrix_Element_Contrib.cc index 92278ec..39fee7c 100644 --- a/src/LIEBLIN/LiebLin_Matrix_Element_Contrib.cc +++ b/src/LIEBLIN/LiebLin_Matrix_Element_Contrib.cc @@ -2,7 +2,7 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -10,15 +10,14 @@ File: src/LIEBLIN/LiebLin_Matrix_Element_Contrib.cc Purpose: handles the generic call for a Lieb-Liniger matrix element contribution. - ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -namespace JSC { +namespace ABACUS { //DP Compute_Matrix_Element_Contrib (char whichDSF, bool fixed_iK, LiebLin_Bethe_State& LeftState, // LiebLin_Bethe_State& RefState, DP Chem_Pot, fstream& DAT_outfile) @@ -60,7 +59,7 @@ namespace JSC { ME_CX = exp(2.0* ln_Overlap_with_BEC (LeftState)); // overlap sq part ME = 0.0; } - else JSCerror("Wrong whichDSF in Compute_Matrix_Element_Contrib."); + else ABACUSerror("Wrong whichDSF in Compute_Matrix_Element_Contrib."); if (is_nan(ME)) ME = (whichDSF == 'Z') ? 1.0e+200 : 0.0; if (is_nan(norm(ME_CX))) ME_CX = -100.0; @@ -131,7 +130,7 @@ namespace JSC { /* // use omega * MEsq/iK^2 //data_value = (LeftState.E - RefState.E - (LeftState.N - RefState.N) * Chem_Pot) - // MEsq/JSC::max(1, (LeftState.iK - RefState.iK) * (LeftState.iK - RefState.iK)) + // MEsq/ABACUS::max(1, (LeftState.iK - RefState.iK) * (LeftState.iK - RefState.iK)) //: 0.0; */ // Careful: use fabs(E) since this must also work with Tgt0 or arbitrary RefState DEPRECATED ++G_1, USE abs_data_value @@ -143,7 +142,7 @@ namespace JSC { //data_value = ME * ME; // use omega * MEsq/iK^2 // Careful: use fabs(E) since this must also work with Tgt0 or arbitrary RefState DEPRECATED ++G_1, USE abs_data_value - data_value = (LeftState.E - RefState.E - (LeftState.N - RefState.N) * Chem_Pot) * ME * ME/JSC::max(1, (LeftState.iK - RefState.iK) * (LeftState.iK - RefState.iK)); + data_value = (LeftState.E - RefState.E - (LeftState.N - RefState.N) * Chem_Pot) * ME * ME/ABACUS::max(1, (LeftState.iK - RefState.iK) * (LeftState.iK - RefState.iK)); } else if (whichDSF == 'g' || whichDSF == 'o') { if (fixed_iK) @@ -182,4 +181,4 @@ namespace JSC { return(data_value); } -} // namespace JSC +} // namespace ABACUS diff --git a/src/LIEBLIN/LiebLin_State_Ensemble.cc b/src/LIEBLIN/LiebLin_State_Ensemble.cc index 9ad20d4..aaa3b5f 100644 --- a/src/LIEBLIN/LiebLin_State_Ensemble.cc +++ b/src/LIEBLIN/LiebLin_State_Ensemble.cc @@ -2,7 +2,7 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -10,15 +10,14 @@ File: LiebLin_State_Ensemble.cc Purpose: State ensembles for Lieb-Liniger - ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -namespace JSC { +namespace ABACUS { // Constructors: @@ -35,12 +34,12 @@ namespace JSC { LiebLin_Diagonal_State_Ensemble::LiebLin_Diagonal_State_Ensemble (const LiebLin_Bethe_State& RefState, int nstates_req, const Vect& weight_ref) : nstates(nstates_req), state(Vect(RefState, nstates_req)), weight(weight_ref) { - if (weight_ref.size() != nstates_req) JSCerror("Incompatible vector size in LiebLin_Diagonal_State_Ensemble constructor."); + if (weight_ref.size() != nstates_req) ABACUSerror("Incompatible vector size in LiebLin_Diagonal_State_Ensemble constructor."); } */ // Recursively go through all arbitrary-order type 2 descendents - void Generate_type_2_descendents (LiebLin_Bethe_State& ActualState, int* ndesc_ptr, const LiebLin_Bethe_State& OriginState) + void Generate_type_2_descendents (LiebLin_Bethe_State& ActualState, int* ndesc_ptr, const LiebLin_Bethe_State& OriginState) { int type_required = 3; Vect desc_label = Descendents (ActualState, OriginState, type_required); @@ -64,16 +63,16 @@ namespace JSC { } return; } - - - + + + //LiebLin_Diagonal_State_Ensemble::LiebLin_Diagonal_State_Ensemble (DP c_int, DP L, int N, const Root_Density& rho, int nstates_req) //: nstates(nstates_req) LiebLin_Diagonal_State_Ensemble::LiebLin_Diagonal_State_Ensemble (DP c_int, DP L, int N, const Root_Density& rho) { //version with 4 states in ensemble - + Root_Density x(rho.Npts, rho.lambdamax); for(int ix=0; ix Ix2_found(0.0, N); int Ix2_left, Ix2_right; Vect Ix2(N); - - + + LiebLin_Bethe_State rhostate(c_int, N, L); - + nstates = 4; state = Vect(rhostate, nstates); weight = Vect(nstates); @@ -105,10 +104,10 @@ namespace JSC { weight[1] = 1.0/nstates; weight[2] = 1.0/nstates; weight[3] = 1.0/nstates; - + int n_moves = 0; bool change = true; - + for (int i = 0; i < rho.Npts; ++i) { integral_prev = integral; integral += L * rho.value[i] * rho.dlambda[i]; @@ -116,24 +115,24 @@ namespace JSC { if (integral > Nfound + 0.5) { // Subtle error: if the rho is too discontinuous, i.e. if more than one rapidity is found, must correct for this. if (integral > Nfound + 1.5 && integral < Nfound + 2.5) { // found two rapidities - JSCerror("The distribution of particles is too discontinous for discretisation"); + ABACUSerror("The distribution of particles is too discontinous for discretisation"); } - + else { // few variables to clarify the computations, they do not need to be vectors, not used outside this loop //Ix2_found[Nfound] = 2.0 * L * (x.value[i] * (integral - Nfound - 0.5) + x.value[i-1] * (Nfound + 0.5 - integral_prev))/(integral - integral_prev); Ix2_found[Nfound] = 2.0 * L * x.Return_Value(rho.lambda[i]); - + Ix2_left = floor(Ix2_found[Nfound]); Ix2_left -= (Ix2_left + N + 1)%2 ? 1 : 0; //adjust parity - + Ix2_right = ceil(Ix2_found[Nfound]); Ix2_right += (Ix2_right + N + 1)%2 ? 1 : 0; //adjust parity - + int Ix2_in = (Ix2_found[Nfound] > 0 ? Ix2_left : Ix2_right); int Ix2_out = (Ix2_found[Nfound] > 0 ? Ix2_right : Ix2_left); cout << rho.lambda[i] << "\t" << x.Return_Value(rho.lambda[i]) << "\t" << Ix2_found[Nfound] << endl; - + //choose the saddle point state and remember the uncertain choices if(Ix2_found[Nfound] - Ix2_left < 0.5) { state[0].Ix2[Nfound] = Ix2_left; @@ -152,16 +151,16 @@ namespace JSC { state[1].Ix2[Nfound] = Ix2_out; state[2+change].Ix2[Nfound] = Ix2_left; state[2+!change].Ix2[Nfound] = Ix2_right; - change = !change; + change = !change; ++n_moves; } Nfound++; } } //cout << "\ti = " << i << "\tintegral = " << integral << "\tNfound = " << Nfound << endl; - } + } //cout << endl; - + //fix state[3] and state[4] for(int i=0; i Ix2_uncertain(0, N); Vect index_uncertain(0, N); int n_uncertain = 0, n_states_raw = 1; - + for (int i = 0; i < rho.Npts; ++i) { integral_prev = integral; integral += L * rho.value[i] * rho.dlambda[i]; @@ -249,21 +248,21 @@ namespace JSC { if (integral > Nfound + 0.5) { // Subtle error: if the rho is too discontinuous, i.e. if more than one rapidity is found, must correct for this. if (integral > Nfound + 1.5 && integral < Nfound + 2.5) { // found two rapidities - JSCerror("The distribution of particles is too discontinous for discretisation"); + ABACUSerror("The distribution of particles is too discontinous for discretisation"); } - + else { // few variables to clarify the computations, they do not need to be vectors, not used outside this loop Ix2_found[Nfound] = 2.0 * L * (x.value[i] * (integral - Nfound - 0.5) + x.value[i-1] * (Nfound + 0.5 - integral_prev))/(integral - integral_prev); - + Ix2_left = floor(Ix2_found[Nfound]); Ix2_left -= (Ix2_left + N + 1)%2 ? 1 : 0; //adjust parity - + Ix2_right = ceil(Ix2_found[Nfound]); Ix2_right += (Ix2_right + N + 1)%2 ? 1 : 0; //adjust parity - + //cout << Ix2_found[Nfound] << "\t"; - + //choose the saddle point state and remember the uncertain choices if(Ix2_found[Nfound] - Ix2_left < 1) { Ix2[Nfound] = Ix2_left; @@ -283,20 +282,20 @@ namespace JSC { n_states_raw *= 2; } } - else JSCerror("Cannot deduce a quantum number from x(lambda)"); + else ABACUSerror("Cannot deduce a quantum number from x(lambda)"); Nfound++; } } //cout << "\ti = " << i << "\tintegral = " << integral << "\tNfound = " << Nfound << endl; - } + } //cout << endl; - + //cout << Ix2 << endl; - + // create ensamble of states and compute its weights with respect to exact Ix2 saddle point Vect > Ix2states(Ix2, n_states_raw); Vect Ix2weight(0.0, n_states_raw); - + // Ix2states[0] = Ix2; // Ix2weight[0] = ; int n_states_proper = 0; @@ -311,7 +310,7 @@ namespace JSC { //check if it's a proper set of quantum numbers bool OK = true; for(int j=0; j index(0, n_states_raw); for (int nrs = 0; nrs < n_states_raw; ++nrs) index[nrs] = nrs; Ix2weight.QuickSort(index); - + //cut the number of states if above 21 <- arbitrary number for now nstates = min(n_states_proper, 21); cout << n_states_raw << "\t" << n_states_proper << "\t" << nstates << endl; - + //create ensamble of states with normalised weights and ordered accordingly LiebLin_Bethe_State rhostate(c_int, N, L); rhostate.Ix2 = Ix2; rhostate.Compute_All(true); - + state = Vect(rhostate, nstates); weight = Vect(nstates); - + DP sum_weight = 0.0; for(int i=0; i lambda_found(0.0, 2*N); - + for (int i = 0; i < rho.Npts; ++i) { integral_prev = integral; integral += L * rho.value[i] * rho.dlambda[i]; @@ -395,45 +394,45 @@ namespace JSC { //cout << "\ti = " << i << "\tintegral = " << integral << "\tNfound = " << Nfound << endl; } //cout << "rho: " << rho.Npts << " points" << endl << rho.value << endl; - //cout << "sym: " << rho.value[0] << " " << rho.value[rho.value.size() - 1] + //cout << "sym: " << rho.value[0] << " " << rho.value[rho.value.size() - 1] // << "\t" << rho.value[rho.value.size()/2] << " " << rho.value[rho.value.size()/2 + 1] << endl; //cout << "Found " << Nfound << " particles." << endl; //cout << "lambda_found = " << lambda_found << endl; Vect lambda(N); // Fill up the found rapidities: - for (int il = 0; il < JSC::min(N, Nfound); ++il) lambda[il] = lambda_found[il]; + for (int il = 0; il < ABACUS::min(N, Nfound); ++il) lambda[il] = lambda_found[il]; // If there are missing ones, put them at the end; ideally, this should never be called for (int il = Nfound; il < N; ++il) lambda[il] = lambda_found[Nfound-1] + (il - Nfound + 1) * (lambda_found[Nfound-1] - lambda_found[Nfound-2]); //cout << lambda << endl; -*/ +*/ //try a different method //first determine bins, that is intervals in lambda which contain a single rapidity -/* +/* Vect lambda_bin(0.0, N+1); integral = 0.0; Nfound = 0; - + lambda_bin[0] = 0; lambda_bin[N] = rho.Npts-1; for(int i=0; i Nfound + 1.0) lambda_bin[++Nfound] = i - (rho.lambda[i]>0); } - + //put rapidity at the mean value of the distribution inside the bin for(int ib=0; ib < N; ++ib) { lambda_found[ib] = 0.0; for(int i=lambda_bin[ib]; i Ix2(N); Vect holes(0.0, N); for(int i=0; i < N; ++i) { - if(Ix2_found[i] - Ix2_left[i] < 1) { + if(Ix2_found[i] - Ix2_left[i] < 1) { Ix2[i] = Ix2_left[i]; if(Ix2_found[i] - Ix2_left[i] > 0.75) holes[i] = -1; } @@ -470,29 +469,29 @@ namespace JSC { if(Ix2_right[i] - Ix2_found[i] > 0.75) holes[i] = 1; } } -*/ +*/ // cout << endl << Ix2 << endl; // cout << endl << holes << endl; -/* - //count number of possible states +/* + //count number of possible states int n = 0; for(int i=0; i < N; ++i) { if(holes[i] != 0) ++n; } int n_states_raw = 1; -*/ +*/ /* only symmetric modifications for(int i=0; i<0.5*n; ++i) n_states_raw *= 2.0; //we count only symmetric modiications Vect > Ix2states(Ix2, n_states_raw); - + Vect hole_position(0, 0.5*n); int hole_index = 0; for(int i=N/2 + N%2; i > Ix2states(Ix2, n_states_raw); - + Vect hole_position(0, n); int hole_index = 0; for(int i=0; i weight_raw(0.0, n_states_raw); */ -/* +/* DP energy_rho = 0; for (int i = 0; i < rho.Npts; ++i) { energy_rho += L * rho.value[i] * rho.dlambda[i] * rho.lambda[i] * rho.lambda[i]; } - + cout << energy_rho << endl; - + DP energy_discrete = 0; for (int i=0; i < N; ++i) { energy_discrete += lambda[i] * lambda[i]; @@ -578,27 +577,27 @@ namespace JSC { DP sum = 0; for(int j=0; j index(n_states_raw); for (int nrs = 0; nrs < n_states_raw; ++nrs) index[nrs] = nrs; weight_raw.QuickSort(index); - + //nstates = 0; //for(int i=0; i 0.01) ++nstates; - - nstates = JSC::min(n_states_raw, 21); - + + nstates = ABACUS::min(n_states_raw, 21); + cout << nstates << endl; - + state = Vect(rhostate, nstates); weight = Vect(nstates); - + DP sum_weight = 0.0; for(int i=0; i Ix2[i] + 2) nrstates1mod++; } - //if (nrstates1mod < nstates_req) JSCerror("nrstates1mod < nstates_req in LiebLin_Diagonal_State_Ensemble."); + //if (nrstates1mod < nstates_req) ABACUSerror("nrstates1mod < nstates_req in LiebLin_Diagonal_State_Ensemble."); nstates = nrstates1mod; Vect > Ix2states1mod(nrstates1mod); @@ -696,11 +695,11 @@ namespace JSC { state[ns].Set_Label_from_Ix2 (rhostate.Ix2); state[ns].Compute_All(true); } -*/ +*/ } - + /* LiebLin_Diagonal_State_Ensemble::LiebLin_Diagonal_State_Ensemble (DP c_int, DP L, int N, const Root_Density& rho, int nstates_req) : nstates(nstates_req) @@ -721,7 +720,7 @@ namespace JSC { DP integral_prev = 0.0; int Nfound = 0; Vect lambda_found(0.0, 2*N); - + for (int i = 0; i < rho.Npts; ++i) { integral_prev = integral; integral += L * rho.value[i] * rho.dlambda[i]; @@ -742,14 +741,14 @@ namespace JSC { //cout << "\ti = " << i << "\tintegral = " << integral << "\tNfound = " << Nfound << endl; } //cout << "rho: " << rho.Npts << " points" << endl << rho.value << endl; - //cout << "sym: " << rho.value[0] << " " << rho.value[rho.value.size() - 1] + //cout << "sym: " << rho.value[0] << " " << rho.value[rho.value.size() - 1] // << "\t" << rho.value[rho.value.size()/2] << " " << rho.value[rho.value.size()/2 + 1] << endl; //cout << "Found " << Nfound << " particles." << endl; //cout << "lambda_found = " << lambda_found << endl; Vect lambda(N); // Fill up the found rapidities: - for (int il = 0; il < JSC::min(N, Nfound); ++il) lambda[il] = lambda_found[il]; + for (int il = 0; il < ABACUS::min(N, Nfound); ++il) lambda[il] = lambda_found[il]; // If there are missing ones, put them at the end; ideally, this should never be called for (int il = Nfound; il < N; ++il) lambda[il] = lambda_found[Nfound-1] + (il - Nfound + 1) * (lambda_found[Nfound-1] - lambda_found[Nfound-2]); @@ -762,7 +761,7 @@ namespace JSC { for (int j = 0; j < N; ++j) sum += 2.0 * atan((lambda[i] - lambda[j])/c_int); Ix2_exact[i] = (L * lambda[i] + sum)/PI; //Ix2[i] = 2.0* int((L * lambda[i] + sum)/twoPI) + (N % 2) - 1; - // For N is even/odd, we want to round off to the nearest odd/even integer. + // For N is even/odd, we want to round off to the nearest odd/even integer. Ix2[i] = 2.0 * floor((L* lambda[i] + sum)/twoPI + 0.5 * (N%2 ? 1 : 2)) + (N%2) - 1; } //cout << "Found quantum numbers " << endl << Ix2 << endl; @@ -790,7 +789,7 @@ namespace JSC { if (i == 0 || Ix2[i-1] < Ix2[i] - 2) nrstates1mod++; if (i == N-1 || Ix2[i+1] > Ix2[i] + 2) nrstates1mod++; } - if (nrstates1mod < nstates_req) JSCerror("nrstates1mod < nstates_req in LiebLin_Diagonal_State_Ensemble."); + if (nrstates1mod < nstates_req) ABACUSerror("nrstates1mod < nstates_req in LiebLin_Diagonal_State_Ensemble."); Vect > Ix2states1mod(nrstates1mod); for (int nrs = 0; nrs < nrstates1mod; ++nrs) Ix2states1mod[nrs] = Vect (N); @@ -848,7 +847,7 @@ namespace JSC { return(*this); } - + void LiebLin_Diagonal_State_Ensemble::Load (DP c_int, DP L, int N, const char* ensfile_Cstr) { ifstream infile(ensfile_Cstr); @@ -871,7 +870,7 @@ namespace JSC { for (int ns = 0; ns < nstates; ++ns) { infile >> weight[ns] >> dummylabel; for (int i = 0; i < state[ns].N; ++i) infile >> state[ns].Ix2[i]; - } + } infile.close(); for (int ns = 0; ns < nstates; ++ns) { @@ -886,13 +885,13 @@ namespace JSC { outfile.open(ensfile_Cstr); - for (int ns = 0; ns < nstates; ++ns) { + for (int ns = 0; ns < nstates; ++ns) { if (ns > 0) outfile << endl; outfile << setprecision(16) << weight[ns] << "\t" << state[ns].label << "\t"; for (int i = 0; i < state[ns].N; ++i) outfile << " " << state[ns].Ix2[i]; } } - + //LiebLin_Diagonal_State_Ensemble LiebLin_Thermal_Saddle_Point_Ensemble (DP c_int, DP L, int N, DP kBT, int nstates_req) LiebLin_Diagonal_State_Ensemble LiebLin_Thermal_Saddle_Point_Ensemble (DP c_int, DP L, int N, DP kBT) @@ -911,7 +910,7 @@ namespace JSC { LiebLin_TBA_Solution TBAsol = LiebLin_TBA_Solution_fixed_nbar (c_int, N/L, kBT, 1.0e-4, 100); LiebLin_Diagonal_State_Ensemble ensemble(c_int, L, N, TBAsol.rho); - + cout << "nbar: " << TBAsol.nbar << endl; cout << "ebar: " << TBAsol.ebar << endl; @@ -920,10 +919,4 @@ namespace JSC { return(ensemble); } -} // namespace JSC - - - - - - +} // namespace ABACUS diff --git a/src/LIEBLIN/LiebLin_Sumrules.cc b/src/LIEBLIN/LiebLin_Sumrules.cc index da849d3..97bf38f 100644 --- a/src/LIEBLIN/LiebLin_Sumrules.cc +++ b/src/LIEBLIN/LiebLin_Sumrules.cc @@ -2,7 +2,7 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -11,15 +11,14 @@ File: src/LIEBLIN/LiebLin_Sumrules.cc Purpose: provides functions evaluating various sumrule factors for Lieb-Liniger. - ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -namespace JSC { +namespace ABACUS { //DP Sumrule_Factor (char whichDSF, LiebLin_Bethe_State& RefState, DP Chem_Pot, bool fixed_iK, int iKneeded) DP Sumrule_Factor (char whichDSF, LiebLin_Bethe_State& RefState, DP Chem_Pot, int iKmin, int iKmax) @@ -35,8 +34,8 @@ namespace JSC { // We sum up omega * MEsq/(iK^2) for all values of iKmin <= iK <= iKmax, discounting iK == 0 (where DSF vanishes) // We therefore have (N/L) x L^{-1} x (2\pi/L)^2 x (iKmax - iKmin + 1) = 4 \pi^2 x N x (iKmax - iKmin + 1)/L^4 // Discounting iK == 0 (where DSF vanishes), if iKmin <= 0 && iKmax >= 0 (in which case 0 is containted in [iKmin, iKmax]) - sumrule_factor = (iKmin <= 0 && iKmax >= 0) ? - (RefState.L * RefState.L * RefState.L * RefState.L)/(4.0 * PI * PI * RefState.N * (iKmax - iKmin)) + sumrule_factor = (iKmin <= 0 && iKmax >= 0) ? + (RefState.L * RefState.L * RefState.L * RefState.L)/(4.0 * PI * PI * RefState.N * (iKmax - iKmin)) : (RefState.L * RefState.L * RefState.L * RefState.L)/(4.0 * PI * PI * RefState.N * (iKmax - iKmin + 1)); /* @@ -53,7 +52,7 @@ namespace JSC { //else if (whichDSF == 'g') sumrule_factor = 1.0/((2.0 * RefState.Tableau[0].Ncols + 1.0)/RefState.L + RefState.N/RefState.L); // Assume that iKmin == 0 here: //else if (whichDSF == 'g') sumrule_factor = 1.0/(2.0* iKmax + 1.0)/RefState.L + RefState.N/RefState.L); - else if (whichDSF == 'g') + else if (whichDSF == 'g') sumrule_factor = 1.0/((abs(iKmax - iKmin) + 1.0)/RefState.L + RefState.N/RefState.L); //sumrule_factor = 1.0/((pow(twoPI * iKmax/RefState.L, 2.0) - Chem_Pot + 4.0 * RefState.c_int * RefState.N/RefState.L)/RefState.L); // For the one-body function, it's just the density: @@ -61,20 +60,20 @@ namespace JSC { else if (whichDSF == 'q') sumrule_factor = 1.0; else if (whichDSF == 'B') sumrule_factor = 1.0; else if (whichDSF == 'C') sumrule_factor = 1.0; - else JSCerror("whichDSF option not consistent in Sumrule_Factor"); + else ABACUSerror("whichDSF option not consistent in Sumrule_Factor"); } //else if (fixed_iK) { else if (iKmin == iKmax) { if (whichDSF == 'Z') sumrule_factor = 1.0; - else if (whichDSF == 'd' || whichDSF == '1') + else if (whichDSF == 'd' || whichDSF == '1') //// We sum up omega * MEsq/(iK^2): this should give (1/L) x (N/L) x k^2 = N x (2\pi)^2/L^4 //sumrule_factor = pow(RefState.L, 4.0)/(4.0 * PI * PI * RefState.N); // We sum up omega * MEsq //sumrule_factor = pow(RefState.L, 4.0)/(4.0 * PI * PI * iKneeded * iKneeded * RefState.N); sumrule_factor = pow(RefState.L, 4.0)/(4.0 * PI * PI * iKmax * iKmax * RefState.N); else if (whichDSF == 'g' || whichDSF == 'o') { - // We sum up omega * MEsq + // We sum up omega * MEsq //sumrule_factor = 1.0/((pow(twoPI * iKneeded/RefState.L, 2.0) - Chem_Pot + 4.0 * RefState.c_int * RefState.N/RefState.L)/RefState.L); sumrule_factor = 1.0/((pow(twoPI * iKmax/RefState.L, 2.0) - Chem_Pot + 4.0 * RefState.c_int * RefState.N/RefState.L)/RefState.L); } @@ -82,9 +81,9 @@ namespace JSC { else if (whichDSF == 'q') sumrule_factor = 1.0; else if (whichDSF == 'B') sumrule_factor = 1.0; else if (whichDSF == 'C') sumrule_factor = 1.0; - else JSCerror("whichDSF option not consistent in Sumrule_Factor"); + else ABACUSerror("whichDSF option not consistent in Sumrule_Factor"); } - + return(sumrule_factor); } @@ -95,12 +94,12 @@ namespace JSC { infile.open(RAW_Cstr); if(infile.fail()) { cout << "Filename RAW_Cstr = " << RAW_Cstr << endl; - JSCerror("Could not open input file in Evaluate_F_Sumrule(LiebLin...)."); + ABACUSerror("Could not open input file in Evaluate_F_Sumrule(LiebLin...)."); } // We run through the data file to check the f sumrule at each positive momenta: //int iK_UL = RefState.Tableau[0].Ncols; // this is iK_UL - //Vect Sum_omega_MEsq(0.0, iK_UL + 1); + //Vect Sum_omega_MEsq(0.0, iK_UL + 1); Vect_DP Sum_omega_MEsq (0.0, iKmax - iKmin + 1); Vect_DP Sum_abs_omega_MEsq (0.0, iKmax - iKmin + 1); @@ -128,7 +127,7 @@ namespace JSC { infile.close(); //cout << "Read " << nraw << " entries in raw file." << endl; - + ofstream outfile; outfile.open(FSR_Cstr); outfile.precision(16); @@ -136,23 +135,23 @@ namespace JSC { if (whichDSF == 'd' || whichDSF == '1') { /* outfile << 0 << "\t" << 1; // full saturation at k = 0 ! - for (int i = 1; i <= iK_UL; ++i) - outfile << endl << i << "\t" << Sum_omega_MEsq[i] * RefState.L * RefState.L + for (int i = 1; i <= iK_UL; ++i) + outfile << endl << i << "\t" << Sum_omega_MEsq[i] * RefState.L * RefState.L * RefState.L * RefState.L/(4.0 * PI * PI * i * i * RefState.N); */ for (int i = iKmin; i <= iKmax; ++i) { if (i > iKmin) outfile << endl; - //outfile << i << "\t" << Sum_omega_MEsq[i - iKmin] * pow(RefState.L, 4.0)/(pow(2.0 * PI * JSC::max(abs(i), 1), 2.0) * RefState.N); - outfile << i << "\t" << Sum_omega_MEsq[i - iKmin] * pow(RefState.L, 4.0)/(pow(2.0 * PI * JSC::max(abs(i), 1), 2.0) * RefState.N) + //outfile << i << "\t" << Sum_omega_MEsq[i - iKmin] * pow(RefState.L, 4.0)/(pow(2.0 * PI * ABACUS::max(abs(i), 1), 2.0) * RefState.N); + outfile << i << "\t" << Sum_omega_MEsq[i - iKmin] * pow(RefState.L, 4.0)/(pow(2.0 * PI * ABACUS::max(abs(i), 1), 2.0) * RefState.N) // Include average of result at +iK and -iK in a third column: iK is at index index(iK) = iK - iKmin - // so -iK is at index index(-iK) = -iK - iKmin + // so -iK is at index index(-iK) = -iK - iKmin // We can only use this index if it is >= 0 and < iKmax - iKmin + 1, otherwise third column is copy of second: - << "\t" << ((i + iKmin <= 0 && -i < iKmax + 1) ? - 0.5 * (Sum_omega_MEsq[i - iKmin] + Sum_omega_MEsq[-i - iKmin]) - : Sum_omega_MEsq[i - iKmin]) - * pow(RefState.L, 4.0)/(pow(2.0 * PI * JSC::max(abs(i), 1), 2.0) * RefState.N); + << "\t" << ((i + iKmin <= 0 && -i < iKmax + 1) ? + 0.5 * (Sum_omega_MEsq[i - iKmin] + Sum_omega_MEsq[-i - iKmin]) + : Sum_omega_MEsq[i - iKmin]) + * pow(RefState.L, 4.0)/(pow(2.0 * PI * ABACUS::max(abs(i), 1), 2.0) * RefState.N); } } else if (whichDSF == 'g' || whichDSF == 'o') { @@ -168,7 +167,7 @@ namespace JSC { ///((4.0 * PI * PI * i * i)/(RefState.L * RefState.L) - Chem_Pot + 4.0 * RefState.c_int * RefState.N/RefState.L); outfile << i << "\t" << Sum_omega_MEsq[i - iKmin] * RefState.L /((4.0 * PI * PI * i * i)/(RefState.L * RefState.L) - Chem_Pot + 4.0 * RefState.c_int * RefState.N/RefState.L) - << "\t" << ((i + iKmin <= 0 && -i < iKmax + 1) ? + << "\t" << ((i + iKmin <= 0 && -i < iKmax + 1) ? 0.5 * (Sum_omega_MEsq[i - iKmin] + Sum_omega_MEsq[-i - iKmin]) : Sum_omega_MEsq[i - iKmin]) * RefState.L/((4.0 * PI * PI * i * i)/(RefState.L * RefState.L) - Chem_Pot + 4.0 * RefState.c_int * RefState.N/RefState.L); } @@ -182,7 +181,7 @@ namespace JSC { { stringstream RAW_stringstream; string RAW_string; - RAW_stringstream << prefix << ".raw"; + RAW_stringstream << prefix << ".raw"; RAW_string = RAW_stringstream.str(); const char* RAW_Cstr = RAW_string.c_str(); stringstream FSR_stringstream; string FSR_string; @@ -224,9 +223,9 @@ namespace JSC { // Define the raw input file name: stringstream filenameprefix; - //Data_File_Name (filenameprefix, whichDSF, iKmin, iKmax, kBT, ensemble.state[ns], ensemble.state[ns], ensemble.state[ns].label); - Data_File_Name (filenameprefix, whichDSF, iKmin, iKmax, 0.0, ensemble.state[ns], ensemble.state[ns], ensemble.state[ns].label); - string prefix = filenameprefix.str(); + //Data_File_Name (filenameprefix, whichDSF, iKmin, iKmax, kBT, ensemble.state[ns], ensemble.state[ns], ensemble.state[ns].label); + Data_File_Name (filenameprefix, whichDSF, iKmin, iKmax, 0.0, ensemble.state[ns], ensemble.state[ns], ensemble.state[ns].label); + string prefix = filenameprefix.str(); stringstream RAW_stringstream; string RAW_string; RAW_stringstream << prefix << ".raw"; RAW_string = RAW_stringstream.str(); const char* RAW_Cstr = RAW_string.c_str(); @@ -235,7 +234,7 @@ namespace JSC { infile.open(RAW_Cstr); if(infile.fail()) { cout << "Filename RAW_Cstr = " << RAW_Cstr << endl; - JSCerror("Could not open input file in Evaluate_F_Sumrule(LiebLin...)."); + ABACUSerror("Could not open input file in Evaluate_F_Sumrule(LiebLin...)."); } while (infile.peek() != EOF) { @@ -258,21 +257,21 @@ namespace JSC { if (whichDSF == 'd' || whichDSF == '1') { /* outfile << 0 << "\t" << 1; // full saturation at k = 0 ! - for (int i = 1; i <= iK_UL; ++i) - outfile << endl << i << "\t" << Sum_omega_MEsq[i] * RefState.L * RefState.L + for (int i = 1; i <= iK_UL; ++i) + outfile << endl << i << "\t" << Sum_omega_MEsq[i] * RefState.L * RefState.L * RefState.L * RefState.L/(4.0 * PI * PI * i * i * RefState.N); */ for (int i = iKmin; i <= iKmax; ++i) { if (i > iKmin) outfile << endl; - //outfile << i << "\t" << Sum_omega_MEsq[i - iKmin] * pow(RefState.L, 4.0)/(pow(2.0 * PI * JSC::max(abs(i), 1), 2.0) * RefState.N); - outfile << i << "\t" << Sum_omega_MEsq[i - iKmin] * pow(RefState.L, 4.0)/(pow(2.0 * PI * JSC::max(abs(i), 1), 2.0) * RefState.N) + //outfile << i << "\t" << Sum_omega_MEsq[i - iKmin] * pow(RefState.L, 4.0)/(pow(2.0 * PI * ABACUS::max(abs(i), 1), 2.0) * RefState.N); + outfile << i << "\t" << Sum_omega_MEsq[i - iKmin] * pow(RefState.L, 4.0)/(pow(2.0 * PI * ABACUS::max(abs(i), 1), 2.0) * RefState.N) // Include average of result at +iK and -iK in a third column: iK is at index index(iK) = iK - iKmin - // so -iK is at index index(-iK) = -iK - iKmin + // so -iK is at index index(-iK) = -iK - iKmin // We can only use this index if it is >= 0 and < iKmax - iKmin + 1, otherwise third column is copy of second: - << "\t" << ((i + iKmin <= 0 && -i < iKmax + 1) ? - 0.5 * (Sum_omega_MEsq[i - iKmin] + Sum_omega_MEsq[-i - iKmin]) - : Sum_omega_MEsq[i - iKmin]) - * pow(RefState.L, 4.0)/(pow(2.0 * PI * JSC::max(abs(i), 1), 2.0) * RefState.N); + << "\t" << ((i + iKmin <= 0 && -i < iKmax + 1) ? + 0.5 * (Sum_omega_MEsq[i - iKmin] + Sum_omega_MEsq[-i - iKmin]) + : Sum_omega_MEsq[i - iKmin]) + * pow(RefState.L, 4.0)/(pow(2.0 * PI * ABACUS::max(abs(i), 1), 2.0) * RefState.N); } } else if (whichDSF == 'g' || whichDSF == 'o') { @@ -288,7 +287,7 @@ namespace JSC { ///((4.0 * PI * PI * i * i)/(RefState.L * RefState.L) - Chem_Pot + 4.0 * RefState.c_int * RefState.N/RefState.L); outfile << i << "\t" << Sum_omega_MEsq[i - iKmin] * RefState.L /((4.0 * PI * PI * i * i)/(RefState.L * RefState.L) - Chem_Pot + 4.0 * RefState.c_int * RefState.N/RefState.L) - << "\t" << ((i + iKmin <= 0 && -i < iKmax + 1) ? + << "\t" << ((i + iKmin <= 0 && -i < iKmax + 1) ? 0.5 * (Sum_omega_MEsq[i - iKmin] + Sum_omega_MEsq[-i - iKmin]) : Sum_omega_MEsq[i - iKmin]) * RefState.L/((4.0 * PI * PI * i * i)/(RefState.L * RefState.L) - Chem_Pot + 4.0 * RefState.c_int * RefState.N/RefState.L); } @@ -299,4 +298,4 @@ namespace JSC { } -} // namespace JSC +} // namespace ABACUS diff --git a/src/LIEBLIN/LiebLin_Tgt0.cc b/src/LIEBLIN/LiebLin_Tgt0.cc index f0ad8ae..aa122b8 100644 --- a/src/LIEBLIN/LiebLin_Tgt0.cc +++ b/src/LIEBLIN/LiebLin_Tgt0.cc @@ -2,7 +2,7 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -10,15 +10,14 @@ File: LiebLin_Tgt0.cc Purpose: Finite temperature correlations for Lieb-Liniger - ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -namespace JSC { +namespace ABACUS { /* @@ -47,16 +46,16 @@ namespace JSC { //xmax += 10.0* epsilon; //xmin -= 10.0* epsilon; - + DP dx = 0.1/RefState.L; - int Nptsx = int((xmax - xmin)/dx); + int Nptsx = int((xmax - xmin)/dx); Vect occupied (false, (Ix2max - Ix2min)/2 + 1); // whether there is a particle or not for (int i = 0; i < RefState.N; ++i) occupied[(RefState.Ix2[i] - Ix2min)/2] = true; Vect rho(0.0, Nptsx); Vect rhoh(0.0, Nptsx); - + //cout << xmin << "\t" << xmax << "\t" << dx << "\t" << Nptsx << endl; DP x; @@ -91,8 +90,8 @@ namespace JSC { complex entropy = 0.0; DP Deltax = log(RefState.L)/RefState.L; for (int ix = 0; ix < Nptsx; ++ix) - //entropy -= ln_Gamma (1.0 + rho[ix]) + ln_Gamma (2.0 - rho[ix]); // This is ln (\rho_tot choose \rho) with \rho_tot = 1. - entropy += ln_Gamma (RefState.L * (rho[ix] + rhoh[ix]) * Deltax + 1.0) - ln_Gamma(RefState.L * rho[ix] * Deltax + 1.0) - ln_Gamma (RefState.L * rhoh[ix] * Deltax + 1.0); // This is ln (\rho_tot choose \rho) with \rho_tot = 1. + //entropy -= ln_Gamma (1.0 + rho[ix]) + ln_Gamma (2.0 - rho[ix]); // This is ln (\rho_tot choose \rho) with \rho_tot = 1. + entropy += ln_Gamma (RefState.L * (rho[ix] + rhoh[ix]) * Deltax + 1.0) - ln_Gamma(RefState.L * rho[ix] * Deltax + 1.0) - ln_Gamma (RefState.L * rhoh[ix] * Deltax + 1.0); // This is ln (\rho_tot choose \rho) with \rho_tot = 1. entropy *= dx/Deltax; //cout << "Entropy found " << entropy << "\t" << real(entropy) << endl; @@ -107,18 +106,18 @@ namespace JSC { // This function calculates the discrete entropy of a finite Lieb-Liniger state, // counting the possible permutations within windows of fixed width. - // We assume that the quantum numbers are ordered. + // We assume that the quantum numbers are ordered. // Calculate a density \rho_\Delta (x) for x_j on the lattice: - int iK_UL = JSC::max(RefState.Ix2[0], RefState.Ix2[RefState.N - 1]); + int iK_UL = ABACUS::max(RefState.Ix2[0], RefState.Ix2[RefState.N - 1]); Vect rhoD(0.0, 2* iK_UL); - + int fourDeltasq = 4 * Delta * Delta; for (int ix = 0; ix < 2* iK_UL; ++ix) { // x = (-iK_UL + 1/2 + ix)/L - for (int i = 0; i < RefState.N; ++i) rhoD[ix] += 1.0/((-2*iK_UL + 1 + 2*ix -RefState.Ix2[i]) * (-2*iK_UL + 1 + 2*ix -RefState.Ix2[i]) + fourDeltasq); + for (int i = 0; i < RefState.N; ++i) rhoD[ix] += 1.0/((-2*iK_UL + 1 + 2*ix -RefState.Ix2[i]) * (-2*iK_UL + 1 + 2*ix -RefState.Ix2[i]) + fourDeltasq); rhoD[ix] *= 4.0 * Delta/PI; //cout << "x = " << (-iK_UL + 1/2 + ix)/RefState.L << "\trhoD = " << rhoD[ix] << endl; } @@ -137,7 +136,7 @@ namespace JSC { // This function calculates the discrete entropy of a finite Lieb-Liniger state, // counting the possible permutations within windows of fixed width. - // We assume that the quantum numbers are ordered. + // We assume that the quantum numbers are ordered. // Fill in vector of occupancies: int nrIs = (RefState.Ix2[RefState.N-1] - RefState.Ix2[0])/2 + 1 + 2*Delta; // assume Ix2 are ordered, leave space of Delta on both sides @@ -149,7 +148,7 @@ namespace JSC { //cout << "Check occupancy: " << endl << occupancy << endl; if (ncheck != RefState.N) { cout << ncheck << "\t" << RefState.N << endl; - JSCerror("Counting q numbers incorrectly in Entropy."); + ABACUSerror("Counting q numbers incorrectly in Entropy."); } // Define some useful numbers: @@ -172,7 +171,7 @@ namespace JSC { return(entropy); } - + DP Entropy (LiebLin_Bethe_State& RefState, int Delta) { // Perform an average of entropies for regulators from Delta to 2Delta: @@ -238,7 +237,7 @@ namespace JSC { convergedati = false; while (!convergedati) { - + convergedati = true; // set to false if we change anything Estay = spstate.E; @@ -259,7 +258,7 @@ namespace JSC { canfreeenup = Eup - kBT * Sup; } else canfreeenup = canfreeenstay + 1.0e-6; - + spstatedown = spstate; if (spstatedown.Ix2[i+1] > spstatedown.Ix2[i] + 2) { spstatedown.Ix2[i] += 2; @@ -272,11 +271,11 @@ namespace JSC { canfreeendown = Edown - kBT * Sdown; } else canfreeendown = canfreeenstay + 1.0e-6; - - //cout << "i = " << i << "\t" << spstate.Ix2[i] << "\t\t" << canfreeenstay << "\t" << canfreeenup << "\t" << canfreeendown + + //cout << "i = " << i << "\t" << spstate.Ix2[i] << "\t\t" << canfreeenstay << "\t" << canfreeenup << "\t" << canfreeendown // << "\t\t" << Estay << "\t" << Eup << "\t" << Edown << "\t\t" << Sstay << "\t" << Sup << "\t" << Sdown << endl; // Choose what to do: - if (canfreeenup < canfreeenstay && canfreeendown < canfreeenstay) + if (canfreeenup < canfreeenstay && canfreeendown < canfreeenstay) cout << canfreeenstay << "\t" << canfreeenup << "\t" << canfreeendown << "\tWarning: unclear option for minimization." << endl; else if (canfreeenup < canfreeenstay) { spstate = spstateup; @@ -340,14 +339,14 @@ namespace JSC { for (int i = 0; i < N/2 - 1; ++i) { - // Try to increase or decrease the quantum numbers at i , + // Try to increase or decrease the quantum numbers at i , // or do an (approximately) energy-preserving move with i+1 (and parity pairs) // giving 5 possible options: stay same, (\pm 1, 0), (+1, -1), (-1, +1) convergedati = false; while (!convergedati) { - + convergedati = true; // set to false if we change anything Estay = spstate.E; @@ -370,7 +369,7 @@ namespace JSC { canfreeenup = Eup - kBT * Sup; } else canfreeenup = canfreeenstay + 1.0e-6; - + spstatedown = spstate; if (spstatedown.Ix2[i+1] > spstatedown.Ix2[i] + 2) { spstatedown.Ix2[i] += 2; @@ -402,8 +401,8 @@ namespace JSC { else canfreeenin = canfreeenstay + 1.0e-6; spstateout = spstate; - if (i == 0 && spstateout.Ix2[1] + 2 < spstateout.Ix2[2] - || (i < N/2 - 1 && spstateout.Ix2[i] - 2 > spstateout.Ix2[i-1] + if (i == 0 && spstateout.Ix2[1] + 2 < spstateout.Ix2[2] + || (i < N/2 - 1 && spstateout.Ix2[i] - 2 > spstateout.Ix2[i-1] && spstateout.Ix2[i+1] + 2 < spstateout.Ix2[i+2])) { // can move them further apart spstateout.Ix2[i] -= 2; spstateout.Ix2[i+1] += 2; @@ -418,12 +417,12 @@ namespace JSC { canfreeenout = Eout - kBT * Sout; } else canfreeenout = canfreeenstay + 1.0e-6; - + //cout << setprecision(8) << "i = " << i << "\t" << spstate.Ix2[i] << "\t" << spstate.Ix2[i+1] << "\t\t" << canfreeenstay << "\t" << canfreeenup << "\t" << canfreeendown << "\t" << canfreeenin << "\t" << canfreeenout << endl; //cout << "\t\tE: " << Estay << "\t" << Eup << "\t" << Edown << "\t" << Ein << "\t" << Eout << endl; //cout << "\t\tS: " << Sstay << "\t" << Sup << "\t" << Sdown << "\t" << Sin << "\t" << Sout << endl; - // Choose what to do: find minimum, + // Choose what to do: find minimum, if (canfreeenstay < canfreeenup && canfreeenstay < canfreeendown && canfreeenstay < canfreeenin && canfreeenstay < canfreeenout) { // do nothing, convergetati is already true } @@ -491,14 +490,14 @@ namespace JSC { // This is obtained by rediscretizing the solution coming from TBA. - // ASSUMPTIONS: + // ASSUMPTIONS: // Periodic boundary conditions (the state which is output is forced to be symmetric Ix2 == -Ix2). // For zero temperature, return the ground state: if (fabs(kBT) < 1.0e-4) return(LiebLin_Bethe_State(c_int, L, N)); // Otherwise, return the discretized TBA saddle-point state: - LiebLin_TBA_Solution TBAsol = LiebLin_TBA_Solution_fixed_nbar (c_int, N/L, kBT, 1.0e-4, JSC::max(N/10, 10)); + LiebLin_TBA_Solution TBAsol = LiebLin_TBA_Solution_fixed_nbar (c_int, N/L, kBT, 1.0e-4, ABACUS::max(N/10, 10)); LiebLin_Bethe_State spstate = Discretized_LiebLin_Bethe_State (c_int, L, N, TBAsol.rho); @@ -513,7 +512,7 @@ namespace JSC { { LiebLin_Bethe_State ReturnState (RefState.c_int, RefState.L, RefState.N + 1); - // Add a quantum number in middle (explicitly: to right of index N/2) + // Add a quantum number in middle (explicitly: to right of index N/2) // and shift quantum numbers by half-integer away from added one: ReturnState.Ix2[RefState.N/2] = RefState.Ix2[RefState.N/2] - 1; for (int i = 0; i < RefState.N+1; ++i) @@ -533,4 +532,4 @@ namespace JSC { return(ReturnState); } -} // namespace JSC +} // namespace ABACUS diff --git a/src/LIEBLIN/LiebLin_Twisted_ln_Overlap.cc b/src/LIEBLIN/LiebLin_Twisted_ln_Overlap.cc index fe8b693..fde1f3c 100644 --- a/src/LIEBLIN/LiebLin_Twisted_ln_Overlap.cc +++ b/src/LIEBLIN/LiebLin_Twisted_ln_Overlap.cc @@ -2,7 +2,7 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -13,12 +13,12 @@ Purpose: Calculates Nikita Slavnov's determinant, case RHS is Bethe ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -namespace JSC { +namespace ABACUS { complex Kernel_Twisted (complex expbeta, complex lambdaoc) { @@ -29,7 +29,7 @@ namespace JSC { { return(1.0/(lambdaoc + II) - expbeta/(lambdaoc - II)); } - + complex Fn_V (int j, int sign, Vect >& lstate_lambdaoc, LiebLin_Bethe_State& rstate) { complex result_num = 1.0; @@ -49,7 +49,7 @@ namespace JSC { { // To match with Nikita's new conventions return(1.0/Fn_V (j, -sign, lstate_lambdaoc, rstate)); - } + } complex LiebLin_Twisted_ln_Overlap (DP expbeta, Vect lstate_lambdaoc, DP lstate_lnnorm, LiebLin_Bethe_State& rstate) { @@ -79,14 +79,14 @@ namespace JSC { Vplus_Nikita[a] = Fn_V_Nikita (a, 1, lstate_lambdaoc, rstate); Vminus_Nikita[a] = Fn_V_Nikita (a, -1, lstate_lambdaoc, rstate); Fn_Prod[a] = 1.0; - for (int m = 0; m < rstate.N; ++m) + for (int m = 0; m < rstate.N; ++m) if (m != a) Fn_Prod[a] *= (lstate_lambdaoc[m] - rstate.lambdaoc[a])/(rstate.lambdaoc[m] - rstate.lambdaoc[a]); //rKern[a] = rstate.Kernel (a, p); rKern[a] = Kernel_Twisted (expbeta, rstate.lambdaoc[p] - rstate.lambdaoc[a]); } - for (int a = 0; a < rstate.N; ++a) - for (int b = 0; b < rstate.N; ++b) + for (int a = 0; a < rstate.N; ++a) + for (int b = 0; b < rstate.N; ++b) one_plus_U[a][b] = (a == b ? 1.0 : 0.0) + ((lstate_lambdaoc[a] - rstate.lambdaoc[a])/(1.0/Vplus_Nikita[a] - 1.0/Vminus_Nikita[a])) * Fn_Prod[a] * (Kernel_Twisted(expbeta, rstate.lambdaoc[a] - rstate.lambdaoc[b]) - rKern[b]); @@ -97,13 +97,13 @@ namespace JSC { ln_prod_V -= 0.5 * rstate.N * log(expbeta); complex ln_prod_2 = 0.0; - for (int a = 0; a < rstate.N; ++a) - for (int b = 0; b < rstate.N; ++b) + for (int a = 0; a < rstate.N; ++a) + for (int b = 0; b < rstate.N; ++b) ln_prod_2 += log((lstate_lambdaoc[a] - rstate.lambdaoc[b] - II)/(rstate.lambdaoc[a] - lstate_lambdaoc[b])); //cout << endl << ln_ddalpha_sigma << "\t" << ln_prod_V << "\t" << ln_prod_2 << "\t" << - log(2.0 * II * imag(Vplus[p])) << endl; //cout << endl << ln_ddalpha_sigma << "\t" << ln_prod_V << "\t" << ln_prod_2 << "\t" << - log(Vplus[p] - Vminus[p]) << endl; - + ln_ddalpha_sigma += ln_prod_V + ln_prod_2 - log(Vplus_Nikita[p] - expbeta * Vminus_Nikita[p]); //cout << "shift = " << (complex(rstate.N) * (lstate_lambdaoc[0] - rstate.lambdaoc[0])/twoPI) << "\tKout = " << Kout << "\texp(-II*Kout) = " << exp(-II * Kout) diff --git a/src/LIEBLIN/LiebLin_Twisted_lnnorm.cc b/src/LIEBLIN/LiebLin_Twisted_lnnorm.cc index e5756e0..9701aa4 100644 --- a/src/LIEBLIN/LiebLin_Twisted_lnnorm.cc +++ b/src/LIEBLIN/LiebLin_Twisted_lnnorm.cc @@ -2,23 +2,23 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- File: LiebLin_Gaudin_lnnorm.cc Purpose: calculates the Gaudin norm of a vector of arbitrary - complex rapidities + complex rapidities ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -namespace JSC { +namespace ABACUS { DP LiebLin_Twisted_lnnorm (Vect >& lambdaoc, double cxL) { @@ -31,7 +31,7 @@ namespace JSC { complex sum_Kernel = 0.0; - for (int j = 0; j < N; ++j) + for (int j = 0; j < N; ++j) for (int k = 0; k < N; ++k) { if (j == k) { sum_Kernel = 0.0; @@ -49,4 +49,4 @@ namespace JSC { return(lnnorm); } -} // namespace JSC +} // namespace ABACUS diff --git a/src/LIEBLIN/LiebLin_Utils.cc b/src/LIEBLIN/LiebLin_Utils.cc index 8ab64c0..909c46c 100644 --- a/src/LIEBLIN/LiebLin_Utils.cc +++ b/src/LIEBLIN/LiebLin_Utils.cc @@ -2,7 +2,7 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -12,9 +12,11 @@ Purpose: Utilities for Lieb-Liniger gas ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" -namespace JSC { +using namespace std; + +namespace ABACUS { DP LiebLin_dE0_dc (DP c_int, DP L, int N) { @@ -30,7 +32,7 @@ namespace JSC { DP LiebLin_vs (DP c_int, DP L, int N) { - LiebLin_Bethe_State gstate (c_int, L, N); + LiebLin_Bethe_State gstate (c_int, L, N); gstate.Compute_All(true); DP Egs = gstate.E; @@ -40,7 +42,7 @@ namespace JSC { gstate.Compute_All(false); return((gstate.E - Egs) * L/twoPI); - + } DP LiebLin_Dressed_Charge_N (DP c_int, DP L, int N) @@ -57,23 +59,23 @@ namespace JSC { { // Calculates the momentum of the excitations on the right of Fermi // surface, discarding the rightmost excitation. - + int nr = 0; for (int i = ScanState.N - 2; i >= ScanState.N/2; --i) if (ScanState.Ix2[i] >= 0) nr += (ScanState.Ix2[i] + ScanState.N - 1 - 2*i)/2; - + return(nr); } - + int Momentum_Left_Excitations (LiebLin_Bethe_State& ScanState) { // Calculates the momentum of the excitations on the left of Fermi // surface, discarding the rightmost excitation. - + int nl = 0; for (int i = 0; i < ScanState.N/2; ++i) if (ScanState.Ix2[i] < 0) nl -= (ScanState.Ix2[i] + ScanState.N - 1 - 2*i)/2; - + return(nl); } @@ -82,25 +84,25 @@ namespace JSC { { int N = lambda.N; int L = lambda.L; - + DP c_int = lambda.c_int; // The overlap identically vanishes if the state is not parity invariant: - if (!lambda.Check_Symmetry()) return(-300.0); - + if (!lambda.Check_Symmetry()) return(-300.0); + SQMat_DP Gaudin( N); - + SQMat_DP Gaudin_Quench( N/2); - + lambda.Build_Reduced_Gaudin_Matrix ( Gaudin); lambda.Build_Reduced_BEC_Quench_Gaudin_Matrix (Gaudin_Quench); - + //DP ln_prefactor = N/2.0 * log(2./fabs(c_int*L) ) + 0.5 * (N*log(N) - N + 0.5*log(2. * PI * N)); - - DP ln_prefactor = N/2.0 * log(2./(c_int*L) ) + 0.5 * real(ln_Gamma(complex(N+1.0))); - + + DP ln_prefactor = N/2.0 * log(2./(c_int*L) ) + 0.5 * real(ln_Gamma(complex(N+1.0))); + for(int i =N/2; i Fn_V (int j, int sign, Vect >& lstate_lambdaoc, LiebLin_Bethe_State& rstate) { @@ -62,7 +62,7 @@ namespace JSC { Vect_CX ln_prod_ll_plus (0.0, rstate.N); // contains \prod_{a \neq k} (\lambdaoc_a - \lambdaoc_k + II) Vect_CX ln_prod_ll_minus (0.0, rstate.N); // contains \prod_{a \neq k} (\lambdaoc_a - \lambdaoc_k - II) - for (int j = 0; j < rstate.N; ++j) + for (int j = 0; j < rstate.N; ++j) for (int k = 0; k < rstate.N; ++k) { ln_prod_plus[k] += log(rstate.lambdaoc[j] - lstate_lambdaoc[k] + II); ln_prod_minus[k] += log(rstate.lambdaoc[j] - lstate_lambdaoc[k] - II); @@ -75,9 +75,9 @@ namespace JSC { // Build the matrix: SQMat_CX Omega (0.0, rstate.N); - for (int j = 0; j < rstate.N; ++j) + for (int j = 0; j < rstate.N; ++j) for (int k = 0; k < rstate.N; ++k) - //Omega[j][k] = exp(-II * rstate.cxL * lstate_lambdaoc[k] + ln_prod_plus[k] - ln_prod_ll_plus[k]) + //Omega[j][k] = exp(-II * rstate.cxL * lstate_lambdaoc[k] + ln_prod_plus[k] - ln_prod_ll_plus[k]) //* (II/((rstate.lambdaoc[j] - lstate_lambdaoc[k])*(rstate.lambdaoc[j] - lstate_lambdaoc[k] + II))) //- (II/((rstate.lambdaoc[j] - lstate_lambdaoc[k])*(rstate.lambdaoc[j] - lstate_lambdaoc[k] - II))) //* exp(ln_prod_minus[k] - ln_prod_ll_plus[k]); @@ -87,7 +87,7 @@ namespace JSC { //for (int j = 0; j < rstate.N; ++j) { - //for (int k = 0; k < rstate.N; ++k) + //for (int k = 0; k < rstate.N; ++k) //cout << Omega[j][k] << "\t"; //cout << endl; //} @@ -115,12 +115,12 @@ namespace JSC { for (int k = 0; k < rstate.N; ++k) ln_prod_plusminus += log((rstate.lambdaoc[j] - lstate_lambdaoc[k] + II)); - //cout << "ln_prod_mu " << ln_prod_mu << "\tln_prod_lambdaoc " << ln_prod_lambdaoc << "\tln_prod_plusminus " << ln_prod_plusminus + //cout << "ln_prod_mu " << ln_prod_mu << "\tln_prod_lambdaoc " << ln_prod_lambdaoc << "\tln_prod_plusminus " << ln_prod_plusminus // << "\texp1 " << exp(-ln_prod_mu - ln_prod_lambdaoc) << "\texp2 " << exp(ln_prod_plusminus) << endl; //if (real(ln_prod_d_mu + ln_prod_d_lambdaoc - ln_prod_mu + ln_prod_lambdaoc + lndetOmega - 0.5 * (lstate_lnnorm + rstate.lnnorm)) > 10.0) { //cout << ln_prod_d_mu << "\t" << ln_prod_d_lambdaoc << "\t" << -ln_prod_mu << "\t" << ln_prod_lambdaoc << "\t" << lndetOmega << "\t" << -0.5 * lstate_lnnorm << "\t" << -0.5 * rstate.lnnorm << endl; cout << ln_prod_d_mu + ln_prod_d_lambdaoc - ln_prod_mu + ln_prod_lambdaoc + lndetOmega - 0.5 * (lstate_lnnorm + rstate.lnnorm) << endl; - //JSCerror("Overlap exceeds 1."); + //ABACUSerror("Overlap exceeds 1."); //} //return(ln_prod_d_mu + ln_prod_d_lambdaoc - ln_prod_mu + ln_prod_lambdaoc + lndetOmega - 0.5 * (lstate_lnnorm + rstate.lnnorm)); @@ -150,13 +150,13 @@ namespace JSC { Vplus[a] = Fn_V (a, 1, lstate_lambdaoc, rstate); Vminus[a] = Fn_V (a, -1, lstate_lambdaoc, rstate); Fn_Prod[a] = 1.0; - for (int m = 0; m < rstate.N; ++m) + for (int m = 0; m < rstate.N; ++m) if (m != a) Fn_Prod[a] *= (lstate_lambdaoc[m] - rstate.lambdaoc[a])/(rstate.lambdaoc[m] - rstate.lambdaoc[a]); //rKern[a] = rstate.Kernel (a, p); } - for (int a = 0; a < rstate.N; ++a) - for (int b = 0; b < rstate.N; ++b) + for (int a = 0; a < rstate.N; ++a) + for (int b = 0; b < rstate.N; ++b) one_plus_U[a][b] = (a == b ? 1.0 : 0.0) + II * ((lstate_lambdaoc[a] - rstate.lambdaoc[a])/(Vplus[a] - Vminus[a])) * Fn_Prod[a] * rstate.Kernel(a,b); @@ -164,15 +164,15 @@ namespace JSC { complex ln_prod_V = 0.0; for (int a = 0; a < rstate.N; ++a) ln_prod_V += log(Vplus[a] - Vminus[a]); - + complex ln_prod_2 = 0.0; - for (int a = 0; a < rstate.N; ++a) - for (int b = 0; b < rstate.N; ++b) + for (int a = 0; a < rstate.N; ++a) + for (int b = 0; b < rstate.N; ++b) ln_prod_2 += log((rstate.lambdaoc[a] - rstate.lambdaoc[b] + II)/(lstate_lambdaoc[a] - rstate.lambdaoc[b])); //cout << endl << ln_ddalpha_sigma << "\t" << ln_prod_V << "\t" << ln_prod_2 << "\t" << - log(2.0 * II * imag(Vplus[p])) << endl; cout << endl << ln_ddalpha_sigma << "\t" << ln_prod_V << "\t" << ln_prod_2 << "\t" << 0.5 * lstate_lnnorm << "\t" << 0.5 * rstate.lnnorm << endl;//- log(Vplus[p] - Vminus[p]) << endl; - + ln_ddalpha_sigma += ln_prod_V + ln_prod_2;// - log(Vplus[p] - Vminus[p]); //cout << "shift = " << (complex(rstate.N) * (lstate_lambdaoc[0] - rstate.lambdaoc[0])/twoPI) << "\tKout = " << Kout << "\texp(-II*Kout) = " << exp(-II * Kout) @@ -183,4 +183,4 @@ namespace JSC { } */ -} // namespace JSC +} // namespace ABACUS diff --git a/src/LIEBLIN/ln_Density_ME.cc b/src/LIEBLIN/ln_Density_ME.cc index 3748c19..cc82157 100644 --- a/src/LIEBLIN/ln_Density_ME.cc +++ b/src/LIEBLIN/ln_Density_ME.cc @@ -2,7 +2,7 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -12,12 +12,12 @@ Purpose: Computes the density operator \rho(x = 0) matrix element ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -namespace JSC { +namespace ABACUS { complex Fn_V (int j, LiebLin_Bethe_State& lstate, LiebLin_Bethe_State& rstate) { @@ -52,7 +52,7 @@ namespace JSC { Vect_CX Vplus (0.0, lstate.N); // contains V^+_j; V^-_j is the conjugate //Vect_DP Fn_Prod (0.0, lstate.N); // product_{m\neq j} (\mu_m - \lambdaoc_j)/(\lambdaoc_m - \lambdaoc_j) // From ABACUS++G_3 onwards: use logs to stabilize numerical values at small c, at the cost of execution speed. - Vect_CX ln_Fn_Prod (0.0, lstate.N); // product_{m\neq j} (\mu_m - \lambdaoc_j)/(\lambdaoc_m - \lambdaoc_j) + Vect_CX ln_Fn_Prod (0.0, lstate.N); // product_{m\neq j} (\mu_m - \lambdaoc_j)/(\lambdaoc_m - \lambdaoc_j) Vect_DP rKern (0.0, lstate.N); // K(lambdaoc_j - lambdaoc_(p == arbitrary)) //int p = 0; @@ -64,14 +64,14 @@ namespace JSC { Vplus[a] = Fn_V (a, lstate, rstate); //Fn_Prod[a] = 1.0; ln_Fn_Prod[a] = 0.0;; - for (int m = 0; m < lstate.N; ++m) + for (int m = 0; m < lstate.N; ++m) //if (m != a) Fn_Prod[a] *= (lstate.lambdaoc[m] - rstate.lambdaoc[a])/(rstate.lambdaoc[m] - rstate.lambdaoc[a]); if (m != a) ln_Fn_Prod[a] += log(complex(lstate.lambdaoc[m] - rstate.lambdaoc[a])/(rstate.lambdaoc[m] - rstate.lambdaoc[a])); rKern[a] = rstate.Kernel (a, p); } - for (int a = 0; a < lstate.N; ++a) - for (int b = 0; b < lstate.N; ++b) + for (int a = 0; a < lstate.N; ++a) + for (int b = 0; b < lstate.N; ++b) one_plus_U[a][b] = (a == b ? 1.0 : 0.0) + 0.5 * ((lstate.lambdaoc[a] - rstate.lambdaoc[a])/imag(Vplus[a])) //* Fn_Prod[a] * (rstate.Kernel(a,b) - rKern[b]); * real(exp(ln_Fn_Prod[a])) * (rstate.Kernel(a,b) - rKern[b]); @@ -80,15 +80,15 @@ namespace JSC { complex ln_prod_V = 0.0; for (int a = 0; a < lstate.N; ++a) ln_prod_V += log(2.0 * II * imag(Vplus[a])); - + complex ln_prod_2 = 0.0; - for (int a = 0; a < lstate.N; ++a) - for (int b = 0; b < lstate.N; ++b) + for (int a = 0; a < lstate.N; ++a) + for (int b = 0; b < lstate.N; ++b) ln_prod_2 += log((rstate.lambdaoc[a] - rstate.lambdaoc[b] + II)/(lstate.lambdaoc[a] - rstate.lambdaoc[b])); //cout << "ln_Fn_Prod = " << ln_Fn_Prod << endl; //cout << endl << ln_ddalpha_sigma << "\t" << ln_prod_V << "\t" << ln_prod_2 << "\t" << - log(2.0 * II * imag(Vplus[p])) << "\t" << - 0.5 * (lstate.lnnorm + rstate.lnnorm) << "\t" << ln_ddalpha_sigma + ln_prod_V + ln_prod_2 - log(2.0 * II * imag(Vplus[p])) - 0.5 * (lstate.lnnorm + rstate.lnnorm) << endl; - + ln_ddalpha_sigma += ln_prod_V + ln_prod_2 - log(2.0 * II * imag(Vplus[p])); return (log(-II * Kout) + ln_ddalpha_sigma - 0.5 * (lstate.lnnorm + rstate.lnnorm)); diff --git a/src/LIEBLIN/ln_Psi_ME.cc b/src/LIEBLIN/ln_Psi_ME.cc index 851f748..bffb8e4 100644 --- a/src/LIEBLIN/ln_Psi_ME.cc +++ b/src/LIEBLIN/ln_Psi_ME.cc @@ -2,7 +2,7 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -12,12 +12,12 @@ Purpose: Computes the matrix element of \Psi (x = 0) ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -namespace JSC { +namespace ABACUS { complex Fn_V_Psi (int j, LiebLin_Bethe_State& lstate, LiebLin_Bethe_State& rstate) { @@ -26,10 +26,10 @@ namespace JSC { complex result_num = 1.0; complex result_den = 1.0; - for (int m = 0; m < lstate.N; ++m) + for (int m = 0; m < lstate.N; ++m) result_num *= (lstate.lambdaoc[m] - rstate.lambdaoc[j] + II); - for (int m = 0; m < rstate.N; ++m) + for (int m = 0; m < rstate.N; ++m) result_den *= (rstate.lambdaoc[m] - rstate.lambdaoc[j] + II); return(result_num/result_den); @@ -39,7 +39,7 @@ namespace JSC { { // Computes the log of the annihilation operator matrix element between lstate and rstate. - if (lstate.N + 1 != rstate.N) JSCerror("Wrong particle numbers in left and right states for Psi FF."); + if (lstate.N + 1 != rstate.N) ABACUSerror("Wrong particle numbers in left and right states for Psi FF."); SQMat_DP U_Psi (0.0, lstate.N); @@ -52,25 +52,25 @@ namespace JSC { for (int a = 0; a < lstate.N; ++a) { Vplus[a] = Fn_V_Psi (a, lstate, rstate); Fn_Prod[a] = (lstate.lambdaoc[a] - rstate.lambdaoc[a])/(rstate.lambdaoc[rstate.N - 1] - rstate.lambdaoc[a]); - for (int m = 0; m < lstate.N; ++m) + for (int m = 0; m < lstate.N; ++m) if (m != a) Fn_Prod[a] *= (lstate.lambdaoc[m] - rstate.lambdaoc[a])/(rstate.lambdaoc[m] - rstate.lambdaoc[a]); rKern[a] = rstate.Kernel (a, p); } - for (int a = 0; a < lstate.N; ++a) - for (int b = 0; b < lstate.N; ++b) + for (int a = 0; a < lstate.N; ++a) + for (int b = 0; b < lstate.N; ++b) U_Psi[a][b] = (a == b ? 2.0 * imag(Vplus[a]) : 0.0) + Fn_Prod[a] * (rstate.Kernel(a,b) - rKern[b]); complex ln_det_U_Psi = lndet_LU_dstry(U_Psi); complex ln_prod_lambdaocsq_plus_one = 0.0; - for (int a = 0; a < rstate.N - 1; ++a) - for (int b = a; b < rstate.N; ++b) + for (int a = 0; a < rstate.N - 1; ++a) + for (int b = a; b < rstate.N; ++b) ln_prod_lambdaocsq_plus_one += log(complex((rstate.lambdaoc[a] - rstate.lambdaoc[b]) * (rstate.lambdaoc[a] - rstate.lambdaoc[b])) + 1.0); complex ln_prod_lambdaoca_min_mub = 0.0; for (int a = 0; a < rstate.N; ++a) - for (int b = 0; b < lstate.N; ++b) + for (int b = 0; b < lstate.N; ++b) ln_prod_lambdaoca_min_mub += log(complex(rstate.lambdaoc[a] - lstate.lambdaoc[b])); //cout << endl << "Factors are " << ln_det_U_Psi << "\t" << ln_prod_lambdaocsq_plus_one << "\t" << ln_prod_lambdaoca_min_mub << endl; diff --git a/src/LIEBLIN/ln_g2_ME.cc b/src/LIEBLIN/ln_g2_ME.cc index a65d1a7..321516d 100644 --- a/src/LIEBLIN/ln_g2_ME.cc +++ b/src/LIEBLIN/ln_g2_ME.cc @@ -2,7 +2,7 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -12,62 +12,61 @@ Purpose: provides the matrix element of the second density moment g2(x = 0) NOTE: based on Lorenzo Piroli's expression of the matrix element - ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -namespace JSC { +namespace ABACUS { /* complex ln_g2_ME_old_jacopo (LiebLin_Bethe_State& mu, LiebLin_Bethe_State& lambda) - { - + { + if (mu.Ix2 == lambda.Ix2) return(-200.); - + DP c_int = mu.c_int; - + SQMat_CX G(lambda.N); SQMat_CX GpB(lambda.N); SQMat_CX B(lambda.N); - + complex log_themp; complex lnprefactor = 0. ; - + lnprefactor += 2.*log(c_int) ; - + for(int j=0; j < mu.N; ++j){ for(int k=0; k < j; ++k){ lnprefactor -= log((mu.lambdaoc[j] - mu.lambdaoc[k])); lnprefactor -= log((lambda.lambdaoc[j] - lambda.lambdaoc[k])); } } - - + + for(int j=0; j < mu.N; ++j){ for(int k=0; k sum_n =0.; for(int n=0; n < mu.N; ++n) { @@ -83,27 +82,27 @@ namespace JSC { } } } - + for (int a = 0; a < mu.N; ++a){ for (int b = 0; b < mu.N; ++b){ if(b == n){ B[a][b] = 0.; } - else{ + else{ B[a][b] = II*1.0/(mu.lambdaoc[b] - mu.lambdaoc[n] - II) ; } } - } - - for (int a = 0; a < mu.N; ++a){ + } + + for (int a = 0; a < mu.N; ++a){ for (int b = 0; b < mu.N; ++b){ GpB[a][b] = G[a][b] + B[a][b]; } - } + } //finally add sum_n += exp( lndet_LU_CX(GpB) ) - exp(lndet_LU_CX(G) ) ; } - + return(log(sum_n ) + lnprefactor - 0.5 * (mu.lnnorm + lambda.lnnorm)); } */ @@ -112,46 +111,46 @@ namespace JSC { //complex result_num = 1.0; //complex result_den = 1.0; complex result = 1.0; - + for (int m = 0; m < lstate.N; ++m) { //result_num *= (lstate.lambdaoc[m] - rstate.lambdaoc[j] + II); //result_den *= (rstate.lambdaoc[m] - rstate.lambdaoc[j] + II); result *= (lstate.lambdaoc[m] - rstate.lambdaoc[j] + II)/(rstate.lambdaoc[m] - rstate.lambdaoc[j] + II); } - + //return(result_num/result_den); return(result); } - + complex ln_g2_ME (LiebLin_Bethe_State& lstate, LiebLin_Bethe_State& rstate) { // Computes the log of the density operator \rho(x = 0) matrix element between lstate and rstate. - + // If we have lstate == rstate, density matrix element = 0: - - + + if (lstate.Ix2 == rstate.Ix2) return(-200.); - - - - + + + + SQMat_DP one_plus_U (0.0, lstate.N); - + Vect_CX Vplus (0.0, lstate.N); // contains V^+_j; V^-_j is the conjugate //Vect_DP Fn_Prod (0.0, lstate.N); // product_{m\neq j} (\mu_m - \lambdaoc_j)/(\lambdaoc_m - \lambdaoc_j) // From ABACUS++G_3 onwards: use logs to stabilize numerical values at small c, at the cost of execution speed. Vect_CX ln_Fn_Prod (0.0, lstate.N); // product_{m\neq j} (\mu_m - \lambdaoc_j)/(\lambdaoc_m - \lambdaoc_j) Vect_DP rKern (0.0, lstate.N); // K(lambdaoc_j - lambdaoc_(p == arbitrary)) - + //int p = 0; int p = rstate.N/2-1; // choice doesn't matter, see 1990_Slavnov_TMP_82 after (3.8). Choose rapidity around the middle. - - + + DP c_int = rstate.c_int; - + DP Eout = log(pow(lstate.E - rstate.E,2.)) - (2)*log(c_int) - log(2*lstate.N); - + for (int a = 0; a < lstate.N; ++a) { Vplus[a] = Fn_V_g2 (a, lstate, rstate); //Fn_Prod[a] = 1.0; @@ -161,33 +160,33 @@ namespace JSC { if (m != a) ln_Fn_Prod[a] += log(complex(lstate.lambdaoc[m] - rstate.lambdaoc[a])/(rstate.lambdaoc[m] - rstate.lambdaoc[a])); rKern[a] = rstate.Kernel (a, p); } - + for (int a = 0; a < lstate.N; ++a) for (int b = 0; b < lstate.N; ++b) one_plus_U[a][b] = (a == b ? 1.0 : 0.0) + 0.5 * 1./imag(Vplus[a]) //* Fn_Prod[a] * (rstate.Kernel(a,b) - rKern[b]); * ((lstate.lambdaoc[a] - rstate.lambdaoc[a])*real(exp(ln_Fn_Prod[a])) * (rstate.Kernel(a,b) - rKern[b]) + rKern[b]); - + complex ln_ddalpha_sigma = lndet_LU_dstry(one_plus_U); - + complex ln_prod_V = 0.0; for (int a = 0; a < lstate.N; ++a) ln_prod_V += log(2.0 * II * imag(Vplus[a])); - + complex ln_prod_2 = 0.0; for (int a = 0; a < lstate.N; ++a) for (int b = 0; b < lstate.N; ++b) ln_prod_2 += log((rstate.lambdaoc[a] - rstate.lambdaoc[b] + II)/(lstate.lambdaoc[a] - rstate.lambdaoc[b])); - + //cout << "ln_Fn_Prod = " << ln_Fn_Prod << endl; //cout << endl << ln_ddalpha_sigma << "\t" << ln_prod_V << "\t" << ln_prod_2 << "\t" << - log(2.0 * II * imag(Vplus[p])) << "\t" << - 0.5 * (lstate.lnnorm + rstate.lnnorm) << "\t" << ln_ddalpha_sigma + ln_prod_V + ln_prod_2 - log(2.0 * II * imag(Vplus[p])) - 0.5 * (lstate.lnnorm + rstate.lnnorm) << endl; - + ln_ddalpha_sigma += ln_prod_V + ln_prod_2 - log(2.0 * II * imag(Vplus[p])); - + return (log(II) + Eout + ln_ddalpha_sigma - 0.5 * (lstate.lnnorm + rstate.lnnorm)); } - - - - -} // namespace JSC + + + + +} // namespace ABACUS diff --git a/src/MATRIX/balanc.cc b/src/MATRIX/balanc.cc index a967b80..0955111 100644 --- a/src/MATRIX/balanc.cc +++ b/src/MATRIX/balanc.cc @@ -1,7 +1,7 @@ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -void JSC::balanc(SQMat_DP& a) +void ABACUS::balanc(SQMat_DP& a) { // Balancing of nonsymmetric matrix. See NR p.489. diff --git a/src/MATRIX/det_LU.cc b/src/MATRIX/det_LU.cc index 8fb600a..28728cc 100644 --- a/src/MATRIX/det_LU.cc +++ b/src/MATRIX/det_LU.cc @@ -1,7 +1,7 @@ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -DP JSC::det_LU (SQMat_DP a) +DP ABACUS::det_LU (SQMat_DP a) { // Returns the determinant of matrix a, through LU decomposition // In order to preserve the original matrix, it is copied first. @@ -12,7 +12,7 @@ DP JSC::det_LU (SQMat_DP a) DP d; - JSC::ludcmp (mat, indx, d); + ABACUS::ludcmp (mat, indx, d); for (int j = 0; j < mat.size(); j++) d *= mat[j][j]; diff --git a/src/MATRIX/det_LU_CX.cc b/src/MATRIX/det_LU_CX.cc index 3aa0510..2ab34e5 100644 --- a/src/MATRIX/det_LU_CX.cc +++ b/src/MATRIX/det_LU_CX.cc @@ -1,7 +1,7 @@ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -complex JSC::det_LU_CX (SQMat_CX a) +complex ABACUS::det_LU_CX (SQMat_CX a) { // Returns the determinant of matrix a, through LU decomposition @@ -11,11 +11,11 @@ complex JSC::det_LU_CX (SQMat_CX a) DP d; - JSC::ludcmp_CX (mat, indx, d); + ABACUS::ludcmp_CX (mat, indx, d); complex dd = d; for (int j = 0; j < mat.size(); j++) dd *= mat[j][j]; - + return(dd); } diff --git a/src/MATRIX/eigsrt.cc b/src/MATRIX/eigsrt.cc index 1ee9c93..60d92c7 100644 --- a/src/MATRIX/eigsrt.cc +++ b/src/MATRIX/eigsrt.cc @@ -1,6 +1,6 @@ -#include "JSC.h" +#include "ABACUS.h" -void JSC::eigsrt (Vect_DP& d, SQMat_DP& v) +void ABACUS::eigsrt (Vect_DP& d, SQMat_DP& v) { // This puts the eigenvalues in INCREASING order, not decreasing as in NR ! diff --git a/src/MATRIX/elmhes.cc b/src/MATRIX/elmhes.cc index 6b72ac2..3b987db 100644 --- a/src/MATRIX/elmhes.cc +++ b/src/MATRIX/elmhes.cc @@ -1,7 +1,7 @@ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -void JSC::elmhes(SQMat_DP& a) +void ABACUS::elmhes(SQMat_DP& a) { // Reduction to Hessenberg form by elimination method. NR p.490 diff --git a/src/MATRIX/gaussj.cc b/src/MATRIX/gaussj.cc index 8e1a53e..a4e3a99 100644 --- a/src/MATRIX/gaussj.cc +++ b/src/MATRIX/gaussj.cc @@ -1,7 +1,7 @@ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -void JSC::gaussj (SQMat_DP& a, SQMat_DP& b) +void ABACUS::gaussj (SQMat_DP& a, SQMat_DP& b) { int i, j, k, l, ll; int icol = 0; @@ -33,7 +33,7 @@ void JSC::gaussj (SQMat_DP& a, SQMat_DP& b) } indxr[i] = irow; indxc[i] = icol; - if (a[icol][icol] == 0.0) JSCerror("gaussj: singular matrix"); + if (a[icol][icol] == 0.0) ABACUSerror("gaussj: singular matrix"); pivinv = 1.0/a[icol][icol]; a[icol][icol] = 1.0; for (l = 0; l < n; l++) a[icol][l] *= pivinv; @@ -53,4 +53,3 @@ void JSC::gaussj (SQMat_DP& a, SQMat_DP& b) SWAP (a[k][indxr[l]], a[k][indxc[l]]); } } - diff --git a/src/MATRIX/hqr.cc b/src/MATRIX/hqr.cc index 5186d8a..f40bb03 100644 --- a/src/MATRIX/hqr.cc +++ b/src/MATRIX/hqr.cc @@ -1,7 +1,7 @@ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -void JSC::hqr(SQMat_DP& a, Vect_CX& wri) +void ABACUS::hqr(SQMat_DP& a, Vect_CX& wri) { // Finds all eigenvalues of an upper Hessenberg matrix @@ -14,7 +14,7 @@ void JSC::hqr(SQMat_DP& a, Vect_CX& wri) int n = a.size(); anorm = 0.0; for (i = 0; i < n; ++i) - for (j = JSC::max(i-1, 0); j < n; j++) anorm += fabs(a[i][j]); + for (j = ABACUS::max(i-1, 0); j < n; j++) anorm += fabs(a[i][j]); nn = n-1; t = 0.0; while (nn >= 0) { @@ -49,7 +49,7 @@ void JSC::hqr(SQMat_DP& a, Vect_CX& wri) } nn -=2; } else { - if (its == 30) JSCerror("Too many iterations in hqr."); + if (its == 30) ABACUSerror("Too many iterations in hqr."); if (its == 10 || its == 20) { t += x; for (i = 0; i < nn + 1; i++) a[i][i] -= x; @@ -127,5 +127,3 @@ void JSC::hqr(SQMat_DP& a, Vect_CX& wri) } while (l+1 < nn); } } - - diff --git a/src/MATRIX/jacobi.cc b/src/MATRIX/jacobi.cc index ca0690e..7d8442e 100644 --- a/src/MATRIX/jacobi.cc +++ b/src/MATRIX/jacobi.cc @@ -1,6 +1,6 @@ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; namespace { @@ -17,12 +17,12 @@ namespace { } -void JSC::jacobi (SQMat& a, Vect_DP& d, SQMat& v, int& nrot) +void ABACUS::jacobi (SQMat& a, Vect_DP& d, SQMat& v, int& nrot) { int i, j, ip, iq; DP tresh, theta, tau, t, sm, s, h, g, c; - int n = a.size(); // + int n = a.size(); // Vect_DP b(n), z(n); for (ip = 0; ip < n; ++ip) { // initialize to identity for (iq = 0; iq < n; ++iq) v[ip][iq] = 0.0; @@ -91,4 +91,3 @@ void JSC::jacobi (SQMat& a, Vect_DP& d, SQMat& v, int& nrot) } cout << "Too many iterations in routine jacobi." << endl; } - diff --git a/src/MATRIX/lndet_LU.cc b/src/MATRIX/lndet_LU.cc index c4dcd55..75fe38b 100644 --- a/src/MATRIX/lndet_LU.cc +++ b/src/MATRIX/lndet_LU.cc @@ -1,7 +1,7 @@ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -DP JSC::lndet_LU (SQMat_DP a) +DP ABACUS::lndet_LU (SQMat_DP a) { // Returns the ln of abs of determinant of matrix a, through LU decomposition @@ -11,7 +11,7 @@ DP JSC::lndet_LU (SQMat_DP a) DP d; - JSC::ludcmp (mat, indx, d); + ABACUS::ludcmp (mat, indx, d); DP logdet = log(DP(d)); for (int j = 0; j < mat.size(); j++) { diff --git a/src/MATRIX/lndet_LU_CX.cc b/src/MATRIX/lndet_LU_CX.cc index ecc40f1..84e0580 100644 --- a/src/MATRIX/lndet_LU_CX.cc +++ b/src/MATRIX/lndet_LU_CX.cc @@ -1,7 +1,7 @@ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -complex JSC::lndet_LU_CX (SQMat_CX a) +complex ABACUS::lndet_LU_CX (SQMat_CX a) { // Returns the ln of determinant of matrix a, through LU decomposition @@ -14,11 +14,11 @@ complex JSC::lndet_LU_CX (SQMat_CX a) complex logdet = 0.0; try { - - JSC::ludcmp_CX (mat, indx, d); - + + ABACUS::ludcmp_CX (mat, indx, d); + logdet = log(complex(d)); - + for (int j = 0; j < mat.size(); j++) { logdet += log(mat[j][j]); } diff --git a/src/MATRIX/lndet_LU_CX_dstry.cc b/src/MATRIX/lndet_LU_CX_dstry.cc index 4ec2ac2..9314ef0 100644 --- a/src/MATRIX/lndet_LU_CX_dstry.cc +++ b/src/MATRIX/lndet_LU_CX_dstry.cc @@ -1,7 +1,7 @@ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -complex JSC::lndet_LU_CX_dstry (SQMat_CX& a) +complex ABACUS::lndet_LU_CX_dstry (SQMat_CX& a) { // Returns the ln of determinant of matrix a, through LU decomposition // Does not preserve a, unlike lndet_LU_CX @@ -13,11 +13,11 @@ complex JSC::lndet_LU_CX_dstry (SQMat_CX& a) complex logdet = 0.0; try { - - JSC::ludcmp_CX (a, indx, d); - + + ABACUS::ludcmp_CX (a, indx, d); + logdet = log(complex(d)); - + for (int j = 0; j < a.size(); j++) { logdet += log(a[j][j]); } diff --git a/src/MATRIX/lndet_LU_dstry.cc b/src/MATRIX/lndet_LU_dstry.cc index 086b304..20d32cb 100644 --- a/src/MATRIX/lndet_LU_dstry.cc +++ b/src/MATRIX/lndet_LU_dstry.cc @@ -1,7 +1,7 @@ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -complex JSC::lndet_LU_dstry (SQMat_DP& a) +complex ABACUS::lndet_LU_dstry (SQMat_DP& a) { // Returns the ln of determinant of matrix a, through LU decomposition // Does not preserve a, unlike lndet_LU @@ -13,11 +13,11 @@ complex JSC::lndet_LU_dstry (SQMat_DP& a) complex logdet = 0.0; try { - - JSC::ludcmp (a, indx, d); - + + ABACUS::ludcmp (a, indx, d); + logdet = log(complex(d)); - + for (int j = 0; j < a.size(); j++) { logdet += log(complex(a[j][j])); } diff --git a/src/MATRIX/lubksb.cc b/src/MATRIX/lubksb.cc index 5fb33d0..6a007aa 100644 --- a/src/MATRIX/lubksb.cc +++ b/src/MATRIX/lubksb.cc @@ -1,7 +1,7 @@ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -void JSC::lubksb (SQMat_DP& a, Vect_INT& indx, Vect_DP& b) +void ABACUS::lubksb (SQMat_DP& a, Vect_INT& indx, Vect_DP& b) { int i, ii=0, ip, j; DP sum; @@ -13,7 +13,7 @@ void JSC::lubksb (SQMat_DP& a, Vect_INT& indx, Vect_DP& b) b[ip] = b[i]; if (ii != 0) for (j = ii-1; j < i; j++) sum -= a[i][j] * b[j]; - else if (sum != 0.0) + else if (sum != 0.0) ii = i + 1; b[i] = sum; } diff --git a/src/MATRIX/lubksb_CX.cc b/src/MATRIX/lubksb_CX.cc index 83be6c7..6a8e029 100644 --- a/src/MATRIX/lubksb_CX.cc +++ b/src/MATRIX/lubksb_CX.cc @@ -1,7 +1,7 @@ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -void JSC::lubksb_CX (SQMat_CX& a, Vect_INT& indx, Vect_CX& b) +void ABACUS::lubksb_CX (SQMat_CX& a, Vect_INT& indx, Vect_CX& b) { int i, ii=0, ip, j; complex sum; @@ -13,7 +13,7 @@ void JSC::lubksb_CX (SQMat_CX& a, Vect_INT& indx, Vect_CX& b) b[ip] = b[i]; if (ii != 0) for (j = ii-1; j < i; j++) sum -= a[i][j] * b[j]; - else if (sum != 0.0) + else if (sum != 0.0) ii = i + 1; b[i] = sum; } diff --git a/src/MATRIX/ludcmp.cc b/src/MATRIX/ludcmp.cc index 5eec43c..4f75833 100644 --- a/src/MATRIX/ludcmp.cc +++ b/src/MATRIX/ludcmp.cc @@ -1,7 +1,7 @@ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -void JSC::ludcmp (SQMat_DP& a, Vect_INT& indx, DP& d) +void ABACUS::ludcmp (SQMat_DP& a, Vect_INT& indx, DP& d) { const DP TINY = 1.0e-200; int i, j, k; @@ -9,14 +9,14 @@ void JSC::ludcmp (SQMat_DP& a, Vect_INT& indx, DP& d) DP big, dum, sum, temp; int n = a.size(); - if (n == 0) JSCerror("Zero-sized array in ludcmp"); + if (n == 0) ABACUSerror("Zero-sized array in ludcmp"); Vect_DP vv(n); d = 1.0; for (i = 0; i < n; i++) { big = 0.0; for (j = 0; j < n; j++) if ((temp = fabs(a[i][j])) > big) big = temp; - if (big == 0.0) throw Divide_by_zero(); //JSCerror("Singular matrix in routine ludcmp."); + if (big == 0.0) throw Divide_by_zero(); //ABACUSerror("Singular matrix in routine ludcmp."); vv[i] = 1.0/big; } for (j = 0; j < n; j++) { @@ -52,4 +52,3 @@ void JSC::ludcmp (SQMat_DP& a, Vect_INT& indx, DP& d) } } } - diff --git a/src/MATRIX/ludcmp_CX.cc b/src/MATRIX/ludcmp_CX.cc index 9fbe2f4..33f6308 100644 --- a/src/MATRIX/ludcmp_CX.cc +++ b/src/MATRIX/ludcmp_CX.cc @@ -1,7 +1,7 @@ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -void JSC::ludcmp_CX (SQMat_CX& a, Vect_INT& indx, DP& d) +void ABACUS::ludcmp_CX (SQMat_CX& a, Vect_INT& indx, DP& d) { const complex TINY = 1.0e-200; int i, j, k; @@ -10,7 +10,7 @@ void JSC::ludcmp_CX (SQMat_CX& a, Vect_INT& indx, DP& d) complex big, dum, sum, temp; int n = a.size(); - if (n == 0) JSCerror("Zero-sized array in ludcmp_CX"); + if (n == 0) ABACUSerror("Zero-sized array in ludcmp_CX"); Vect_CX vv(n); d = 1.0; for (i = 0; i < n; i++) { @@ -19,7 +19,7 @@ void JSC::ludcmp_CX (SQMat_CX& a, Vect_INT& indx, DP& d) // if ((temp = fabs(a[i][j])) > big) big = temp; if ((abs(temp = a[i][j])) > abs(big)) big = temp; //if ((norm(temp = a[i][j])) > norm(big)) big = temp; - if (big == 0.0) throw Divide_by_zero(); //JSCerror("Singular matrix in routine ludcmp."); + if (big == 0.0) throw Divide_by_zero(); //ABACUSerror("Singular matrix in routine ludcmp."); vv[i] = 1.0/big; } for (j = 0; j < n; j++) { @@ -57,4 +57,3 @@ void JSC::ludcmp_CX (SQMat_CX& a, Vect_INT& indx, DP& d) } } } - diff --git a/src/MATRIX/pythag.cc b/src/MATRIX/pythag.cc index 2f6a440..27ee97c 100644 --- a/src/MATRIX/pythag.cc +++ b/src/MATRIX/pythag.cc @@ -1,7 +1,7 @@ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -DP JSC::pythag(DP a, DP b) +DP ABACUS::pythag(DP a, DP b) { DP absa, absb; diff --git a/src/MATRIX/tqli.cc b/src/MATRIX/tqli.cc index 95076e9..0fc7b6f 100644 --- a/src/MATRIX/tqli.cc +++ b/src/MATRIX/tqli.cc @@ -1,8 +1,8 @@ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -void JSC::tqli(Vect_DP& d, Vect_DP& e, SQMat_DP& z) +void ABACUS::tqli(Vect_DP& d, Vect_DP& e, SQMat_DP& z) { int m, l, iter, i, k; DP s, r, p, g, f, dd, c, b; @@ -56,4 +56,3 @@ void JSC::tqli(Vect_DP& d, Vect_DP& e, SQMat_DP& z) } while (m != l); } } - diff --git a/src/MATRIX/tred2.cc b/src/MATRIX/tred2.cc index f57f6b2..c1350c2 100644 --- a/src/MATRIX/tred2.cc +++ b/src/MATRIX/tred2.cc @@ -1,7 +1,7 @@ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -void JSC::tred2 (SQMat_DP& a, Vect_DP& d, Vect_DP& e) +void ABACUS::tred2 (SQMat_DP& a, Vect_DP& d, Vect_DP& e) { int l, k, j, i; DP scale, hh, h, g, f; @@ -46,7 +46,7 @@ void JSC::tred2 (SQMat_DP& a, Vect_DP& d, Vect_DP& e) } d[0] = 0.0; e[0] = 0.0; - + for (i = 0; i < n; i++) { l = i; if (d[i] != 0.0) { diff --git a/src/NRG/NRG_DME_Matrix_Block_builder.cc b/src/NRG/NRG_DME_Matrix_Block_builder.cc index a080dfd..dab808a 100644 --- a/src/NRG/NRG_DME_Matrix_Block_builder.cc +++ b/src/NRG/NRG_DME_Matrix_Block_builder.cc @@ -2,7 +2,7 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -13,21 +13,21 @@ Purpose: calculate matrix elements of density operator between For collaboration with Robert Konik. ***********************************************************/ -#include "JSC.h" + +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -namespace JSC { +namespace ABACUS { - - void Build_DME_Matrix_Block_for_NRG (DP c_int, DP L, int N, int iKmin, int iKmax, int Nstates_required, bool symmetric_states, int iKmod, + void Build_DME_Matrix_Block_for_NRG (DP c_int, DP L, int N, int iKmin, int iKmax, int Nstates_required, bool symmetric_states, int iKmod, int weighing_option, int nrglabel_left_begin, int nrglabel_left_end, int nrglabel_right_begin, int nrglabel_right_end, int block_option, DP* DME_block_1, DP* DME_block_2, Vect_DP Kweight) { // Given a list of states produced by Select_States_for_NRG, this function // computes all the density form factors < lstate| \rho | rstate > - // for all id_left_begin <= id_left <= id_left_end (similarly for right states). + // for all id_left_begin <= id_left <= id_left_end (similarly for right states). // The block_option flag determines what kind of data is written in the 2 DME blocks. // If !symmetric_states, then only block 1 is filled. @@ -39,46 +39,46 @@ namespace JSC { // We assume the DME_blocks are already reserved in memory. // If !symmetric states, DME_block_2 doesn't need to be allocated. - if (nrglabel_left_begin < 0 || nrglabel_right_begin < 0) JSCerror("beginning nrglabels negative in Build_DME_Matrix_Block_for_NRG"); - if (nrglabel_left_end >= Nstates_required) JSCerror("nrglabel_left_end too large in Build_DME_Matric_Block_for_NRG"); - if (nrglabel_right_end >= Nstates_required) JSCerror("nrglabel_right_end too large in Build_DME_Matric_Block_for_NRG"); + if (nrglabel_left_begin < 0 || nrglabel_right_begin < 0) ABACUSerror("beginning nrglabels negative in Build_DME_Matrix_Block_for_NRG"); + if (nrglabel_left_end >= Nstates_required) ABACUSerror("nrglabel_left_end too large in Build_DME_Matric_Block_for_NRG"); + if (nrglabel_right_end >= Nstates_required) ABACUSerror("nrglabel_right_end too large in Build_DME_Matric_Block_for_NRG"); - if (nrglabel_left_begin > nrglabel_left_end) JSCerror("nrglabels of left states improperly chosen in DME block builder."); - if (nrglabel_right_begin > nrglabel_right_end) JSCerror("nrglabels of right states improperly chosen in DME block builder."); + if (nrglabel_left_begin > nrglabel_left_end) ABACUSerror("nrglabels of left states improperly chosen in DME block builder."); + if (nrglabel_right_begin > nrglabel_right_end) ABACUSerror("nrglabels of right states improperly chosen in DME block builder."); // DME_block is a pointer of size row_l * col_l, where int block_row_length = nrglabel_right_end - nrglabel_right_begin + 1; - int block_col_length = nrglabel_left_end - nrglabel_left_begin + 1; + int block_col_length = nrglabel_left_end - nrglabel_left_begin + 1; // iKmod is an integer specifying that we're only interested in momenta multiples of // a base unit. In other words, if the perturbation potential repeats itself iKmod times // on the periodic cycle on which the theory is defined, then we only need states such - // that iKl - iKr = (integer) * iKmod. We impose this constraint at the same time as + // that iKl - iKr = (integer) * iKmod. We impose this constraint at the same time as // the check on the weight of the state. // We start by reading off the list of selected states: stringstream NRG_stringstream; string NRG_string; - + NRG_stringstream << "States_"; - NRG_stringstream << "c_" << c_int << "_L_" << L << "_N_" << N - << "_iKmin_" << iKmin << "_iKmax_" << iKmax << "_Nstates_" << Nstates_required - << "_Sym_" << symmetric_states << "_iKmod_" << iKmod << "_wopt_" << weighing_option << ".nrg"; + NRG_stringstream << "c_" << c_int << "_L_" << L << "_N_" << N + << "_iKmin_" << iKmin << "_iKmax_" << iKmax << "_Nstates_" << Nstates_required + << "_Sym_" << symmetric_states << "_iKmod_" << iKmod << "_wopt_" << weighing_option << ".nrg"; NRG_string = NRG_stringstream.str(); const char* NRG_Cstr = NRG_string.c_str(); ifstream infile; infile.open(NRG_Cstr); - + if (infile.fail()) { cout << NRG_Cstr << endl; - JSCerror("The input file was not opened successfully in Build_DME_Matrix_between_Selected_States_for_NRG. "); + ABACUSerror("The input file was not opened successfully in Build_DME_Matrix_between_Selected_States_for_NRG. "); } // Read the whole data file: //const int MAXDATA = 5000000; - const int MAXDATA = JSC::max(nrglabel_left_end, nrglabel_right_end) + 10; // 10 for safety... + const int MAXDATA = ABACUS::max(nrglabel_left_end, nrglabel_right_end) + 10; // 10 for safety... int* nrglabel = new int[MAXDATA]; DP* omega = new DP[MAXDATA]; @@ -91,7 +91,7 @@ namespace JSC { while (((infile.peek()) != EOF) && (Ndata < MAXDATA)) { infile >> nrglabel[Ndata]; - if (nrglabel[Ndata] != Ndata) JSCerror("reading states nrglabels wrong in NRG_DME_Matrix_Block_builder"); + if (nrglabel[Ndata] != Ndata) ABACUSerror("reading states nrglabels wrong in NRG_DME_Matrix_Block_builder"); infile >> omega[Ndata]; infile >> iK[Ndata]; infile >> label[Ndata]; @@ -113,31 +113,31 @@ namespace JSC { // State list containing all the types of states Scan_State_List List_of_Basic_States ('Z', Scanstate); - + for (int nrglabel_left = nrglabel_left_begin; nrglabel_left <= nrglabel_left_end; ++nrglabel_left) { - + Scanstate = List_of_Basic_States.Return_State (Extract_Base_Label(label[nrglabel_left])); Scanstate.Set_to_Label (label[nrglabel_left]); - + Scanstate.Compute_All(true); - + Kept_States_left[nrglabel_left - nrglabel_left_begin] = Scanstate; - + if (!Scanstate.conv) cout << "State of label " << label[nrglabel_left] << " did not converge after " << Scanstate.iter_Newton - << " Newton step; diffsq = " << Scanstate.diffsq << endl; + << " Newton step; diffsq = " << Scanstate.diffsq << endl; } // for nrglabel_left - + for (int nrglabel_right = nrglabel_right_begin; nrglabel_right <= nrglabel_right_end; ++nrglabel_right) { - + Scanstate = List_of_Basic_States.Return_State (Extract_Base_Label(label[nrglabel_right])); Scanstate.Set_to_Label (label[nrglabel_right]); - + Scanstate.Compute_All(true); - + Kept_States_right[nrglabel_right - nrglabel_right_begin] = Scanstate; - + if (!Scanstate.conv) cout << "State of label " << label[nrglabel_right] << " did not converge after " << Scanstate.iter_Newton - << " Newton step; diffsq = " << Scanstate.diffsq << endl; + << " Newton step; diffsq = " << Scanstate.diffsq << endl; } // for nrglabel_left @@ -145,28 +145,28 @@ namespace JSC { for (int ll = 0; ll < block_col_length; ++ll) { for (int lr = 0; lr < block_row_length; ++lr) { - - if (Kept_States_left[ll].conv && Kept_States_right[lr].conv - //&& abs(Kept_States[il].iK - Kept_States[ir].iK) % iKmod == 0) + + if (Kept_States_left[ll].conv && Kept_States_right[lr].conv + //&& abs(Kept_States[il].iK - Kept_States[ir].iK) % iKmod == 0) && abs(Kept_States_left[ll].iK) % iKmod == 0 && abs(Kept_States_right[lr].iK) % iKmod == 0) { - + if (!symmetric_states) { - DME_block_1[ll* block_row_length + lr] = // By convention, put the lowest energy state to the left + DME_block_1[ll* block_row_length + lr] = // By convention, put the lowest energy state to the left Kweight[abs(Kept_States_left[ll].iK - Kept_States_right[lr].iK)] - * (Kept_States_left[ll].E <= Kept_States_right[lr].E + * (Kept_States_left[ll].E <= Kept_States_right[lr].E ? real(exp(ln_Density_ME (Kept_States_left[ll], Kept_States_right[lr]))) : real(exp(ln_Density_ME (Kept_States_right[lr], Kept_States_left[ll])))); // We don't do anything with block 2, we don't even assume it's been allocated. } - + else if (symmetric_states) { // Check parity of both states: bool Lstate_parity_inv = Kept_States_left[ll].Check_Symmetry(); bool Rstate_parity_inv = Kept_States_right[lr].Check_Symmetry(); - + if (Lstate_parity_inv && Rstate_parity_inv) { - DME_block_1[ll* block_row_length + lr] = Kweight[abs(Kept_States_left[ll].iK - Kept_States_right[lr].iK)] + DME_block_1[ll* block_row_length + lr] = Kweight[abs(Kept_States_left[ll].iK - Kept_States_right[lr].iK)] * real(exp(ln_Density_ME (Kept_States_left[ll], Kept_States_right[lr]))); if (block_option == 2) DME_block_2[ll* block_row_length + lr] = 0.0; } @@ -175,15 +175,15 @@ namespace JSC { PRstate.Parity_Flip(); if (block_option == 1) { - DME_block_1[ll* block_row_length + lr] = + DME_block_1[ll* block_row_length + lr] = (Kweight[abs(Kept_States_left[ll].iK - Kept_States_right[lr].iK)] * real(exp(ln_Density_ME (Kept_States_left[ll], Kept_States_right[lr]))) + Kweight[abs(Kept_States_left[ll].iK - PRstate.iK)] * real(exp(ln_Density_ME (Kept_States_left[ll], PRstate)))); // We don't do anything with block 2, we don't even assume it's been allocated. } else if (block_option == 2) { - DME_block_1[ll* block_row_length + lr] = + DME_block_1[ll* block_row_length + lr] = Kweight[abs(Kept_States_left[ll].iK - Kept_States_right[lr].iK)] * real(exp(ln_Density_ME (Kept_States_left[ll], Kept_States_right[lr]))); - DME_block_2[ll* block_row_length + lr] = + DME_block_2[ll* block_row_length + lr] = Kweight[abs(Kept_States_left[ll].iK - PRstate.iK)] * real(exp(ln_Density_ME (Kept_States_left[ll], PRstate))); } } @@ -193,16 +193,16 @@ namespace JSC { PRstate.Parity_Flip(); if (block_option == 1) { - DME_block_1[ll* block_row_length + lr] = sqrt(0.5) * + DME_block_1[ll* block_row_length + lr] = sqrt(0.5) * (Kweight[abs(Kept_States_left[ll].iK - Kept_States_right[lr].iK)] * real(exp(ln_Density_ME (Kept_States_left[ll], Kept_States_right[lr]))) + Kweight[abs(Kept_States_left[ll].iK - PRstate.iK)] * real(exp(ln_Density_ME (Kept_States_left[ll], PRstate)))); // We don't do anything with block 2, we don't even assume it's been allocated. } else if (block_option == 2) { - DME_block_1[ll* block_row_length + lr] = sqrt(0.5) * + DME_block_1[ll* block_row_length + lr] = sqrt(0.5) * Kweight[abs(Kept_States_left[ll].iK - Kept_States_right[lr].iK)] * real(exp(ln_Density_ME (Kept_States_left[ll], Kept_States_right[lr]))); - DME_block_2[ll* block_row_length + lr] = sqrt(0.5) * - Kweight[abs(Kept_States_left[ll].iK - PRstate.iK)] * real(exp(ln_Density_ME (Kept_States_left[ll], PRstate))); + DME_block_2[ll* block_row_length + lr] = sqrt(0.5) * + Kweight[abs(Kept_States_left[ll].iK - PRstate.iK)] * real(exp(ln_Density_ME (Kept_States_left[ll], PRstate))); } } @@ -211,15 +211,15 @@ namespace JSC { PLstate.Parity_Flip(); if (block_option == 1) { - DME_block_1[ll* block_row_length + lr] = sqrt(0.5) * + DME_block_1[ll* block_row_length + lr] = sqrt(0.5) * (Kweight[abs(Kept_States_left[ll].iK - Kept_States_right[lr].iK)] * real(exp(ln_Density_ME (Kept_States_left[ll], Kept_States_right[lr]))) + Kweight[abs(PLstate.iK - Kept_States_right[lr].iK)] * real(exp(ln_Density_ME (PLstate, Kept_States_right[lr])))); // We don't do anything with block 2, we don't even assume it's been allocated. } else if (block_option == 2) { - DME_block_1[ll* block_row_length + lr] = sqrt(0.5) * + DME_block_1[ll* block_row_length + lr] = sqrt(0.5) * Kweight[abs(Kept_States_left[ll].iK - Kept_States_right[lr].iK)] * real(exp(ln_Density_ME (Kept_States_left[ll], Kept_States_right[lr]))); - DME_block_2[ll* block_row_length + lr] = sqrt(0.5) * + DME_block_2[ll* block_row_length + lr] = sqrt(0.5) * Kweight[abs(PLstate.iK - Kept_States_right[lr].iK)] * real(exp(ln_Density_ME (PLstate, Kept_States_right[lr]))); } } @@ -238,7 +238,7 @@ namespace JSC { } // for ll return; - } + } -} // namespace JSC +} // namespace ABACUS diff --git a/src/NRG/NRG_K_Weight_integrand.cc b/src/NRG/NRG_K_Weight_integrand.cc index b5f4ccd..603938a 100644 --- a/src/NRG/NRG_K_Weight_integrand.cc +++ b/src/NRG/NRG_K_Weight_integrand.cc @@ -2,7 +2,7 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -13,12 +13,13 @@ Purpose: for NRG, this function specifies the momentum-dependent Collaboration with Robert Konik. ***********************************************************/ -#include "JSC.h" + +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -namespace JSC { +namespace ABACUS { // This function defines the integrand for momentum-dependent perturbation prefactor DP K_Weight_integrand (Vect_DP args) @@ -44,4 +45,4 @@ namespace JSC { -} // namespace JSC +} // namespace ABACUS diff --git a/src/NRG/NRG_State_Selector.cc b/src/NRG/NRG_State_Selector.cc index 904f929..94cb1d4 100644 --- a/src/NRG/NRG_State_Selector.cc +++ b/src/NRG/NRG_State_Selector.cc @@ -2,7 +2,7 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -12,15 +12,16 @@ Purpose: select states for numerical RG method, collaboration with Robert Konik. ***********************************************************/ -#include "JSC.h" + +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -namespace JSC { +namespace ABACUS { - DP Estimate_Contribution_of_Single_ph_Annihilation_Path_to_2nd_Order_PT (LiebLin_Bethe_State& TopState, - LiebLin_Bethe_State& GroundState, + DP Estimate_Contribution_of_Single_ph_Annihilation_Path_to_2nd_Order_PT (LiebLin_Bethe_State& TopState, + LiebLin_Bethe_State& GroundState, //Vect_DP Weight_integral) Vect >& FT_of_potential) { @@ -36,22 +37,22 @@ namespace JSC { State_Label_Data topdata = Read_State_Label (TopState.label, OriginIx2); int nphpairs = topdata.nexc[0]; - if (nphpairs == 0) JSCerror("Trying to annihilate ground state in Estimate_Contribution..."); + if (nphpairs == 0) ABACUSerror("Trying to annihilate ground state in Estimate_Contribution..."); DP densityME = real(exp(ln_Density_ME (GroundState, TopState))); if (is_nan(densityME)) { cout << "ME is nan: label = " << TopState.label << endl; - JSCerror("ME didn't return value."); + ABACUSerror("ME didn't return value."); } int nr_cont = 0; // Add first-order PT contribution, and 2nd order from ground state (V_{00} == 1) //contrib_estimate += Weight_integral[Weight_integral.size()/2 + (TopState.iK - GroundState.iK)] - //* (densityME/(GroundState.E - TopState.E)) * (1.0 - (GroundState.N/GroundState.L)/(GroundState.E - TopState.E)); + //* (densityME/(GroundState.E - TopState.E)) * (1.0 - (GroundState.N/GroundState.L)/(GroundState.E - TopState.E)); contrib_estimate += abs(FT_of_potential[FT_of_potential.size()/2 + (TopState.iK - GroundState.iK)] - * (densityME/(GroundState.E - TopState.E)) + * (densityME/(GroundState.E - TopState.E)) * (1.0 - (GroundState.N/GroundState.L)/(GroundState.E - TopState.E))); nr_cont++; @@ -77,7 +78,7 @@ namespace JSC { for (int ipart = 0; ipart < nphpairs; ++ipart) { for (int ihole = 0; ihole < nphpairs; ++ihole) { - + LiebLin_Bethe_State DescendedState = TopState; //cout << "Here 2a" << "\tipart " << ipart << "\tihole " << ihole << " out of " << nphpairs << " nphpairs, label " << TopState.label << endl; //cout << "TopState.Ix2 " << TopState.Ix2 << endl; @@ -85,10 +86,10 @@ namespace JSC { DescendedState.Annihilate_ph_pair(ipart, ihole, OriginIx2); DescendedState.Compute_All(true); //cout << "DescendedIx2 " << DescendedState.Ix2 << endl; - + DP densityME_top_desc = real(exp(ln_Density_ME (TopState, DescendedState))); DP densityME_desc_ground = real(exp(ln_Density_ME (DescendedState, GroundState))); - + //contrib_estimate += Weight_integral[Weight_integral.size()/2 + (TopState.iK - DescendedState.iK)] //* Weight_integral[Weight_integral.size()/2 + (DescendedState.iK - GroundState.iK)] //* densityME_top_desc * densityME_desc_ground @@ -102,7 +103,7 @@ namespace JSC { * FT_of_potential[FT_of_potential.size()/2 + (DescendedState.iK - GroundState.iK)] * densityME_top_desc * densityME_desc_ground /((GroundState.E - TopState.E) * (GroundState.E - DescendedState.E))); - + nr_cont++; } @@ -117,7 +118,7 @@ namespace JSC { DescendedState2.Compute_All(true); //cout << DescendedState2.Ix2 << endl; //cout << DescendedState2.lambdaoc << endl; - + DP densityME_top_desc2 = real(exp(ln_Density_ME (TopState, DescendedState2))); DP densityME_desc2_ground = real(exp(ln_Density_ME (DescendedState2, GroundState))); @@ -129,7 +130,7 @@ namespace JSC { // if intermediate state has momentum within allowable window, OK, otherwise discard contribution: if (abs(TopState.iK - DescendedState2.iK) < FT_of_potential.size()/2 && abs(DescendedState2.iK - GroundState.iK) < FT_of_potential.size()/2) { - + contrib_estimate += abs(FT_of_potential[FT_of_potential.size()/2 + (TopState.iK - DescendedState2.iK)] * FT_of_potential[FT_of_potential.size()/2 + (DescendedState2.iK - GroundState.iK)] * densityME_top_desc2 * densityME_desc2_ground @@ -141,17 +142,17 @@ namespace JSC { if (nphpairs >= 4) { // go one step further for (int ipart3 = ipart2; ipart3 < nphpairs - 2; ++ipart3) { for (int ihole3 = ihole2; ihole3 < nphpairs - 2; ++ihole3) { - + LiebLin_Bethe_State DescendedState3 = DescendedState2; //cout << "Here 4a" << "\tipart3 " << ipart3 << "\tihole3 " << ihole3 << endl; DescendedState3.Annihilate_ph_pair(ipart3, ihole3, OriginIx2); //cout << DescendedState3.Ix2 << endl; DescendedState3.Compute_All(true); //cout << DescendedState3.Ix2 << endl; - + DP densityME_top_desc3 = real(exp(ln_Density_ME (TopState, DescendedState3))); DP densityME_desc3_ground = real(exp(ln_Density_ME (DescendedState3, GroundState))); - + //contrib_estimate += Weight_integral[Weight_integral.size()/2 + (TopState.iK - DescendedState3.iK)] //* Weight_integral[Weight_integral.size()/2 + (DescendedState3.iK - GroundState.iK)] //* densityME_top_desc3 * densityME_desc3_ground @@ -160,12 +161,12 @@ namespace JSC { // if intermediate state has momentum within allowable window, OK, otherwise discard contribution: if (abs(TopState.iK - DescendedState3.iK) < FT_of_potential.size()/2 && abs(DescendedState3.iK - GroundState.iK) < FT_of_potential.size()/2) { - + contrib_estimate += abs(FT_of_potential[FT_of_potential.size()/2 + (TopState.iK - DescendedState3.iK)] * FT_of_potential[FT_of_potential.size()/2 + (DescendedState3.iK - GroundState.iK)] * densityME_top_desc3 * densityME_desc3_ground /((GroundState.E - TopState.E) * (GroundState.E - DescendedState3.E))); - + nr_cont++; } @@ -175,7 +176,7 @@ namespace JSC { } // for ihole2 } // for ipart2 } // if (nphpairs >= 3) - + } // for ihole } // for ipart } // if nphpairs >= 2 @@ -187,7 +188,7 @@ namespace JSC { } /* - DP Estimate_Contribution_of_Base_to_2nd_Order_PT (LiebLin_Bethe_State& ScanState, LiebLin_Bethe_State& GroundState, + DP Estimate_Contribution_of_Base_to_2nd_Order_PT (LiebLin_Bethe_State& ScanState, LiebLin_Bethe_State& GroundState, Vect_DP Weight_integral, LiebLin_States_and_Density_ME_of_Base& StatesBase) { // This function calculates the second-order perturbation theory contribution to @@ -196,7 +197,7 @@ namespace JSC { DP sum_contrib = 0.0; for (int i = 0; i <= StatesBase.maxid; ++i) - sum_contrib += Weight_integral[Weight_integral.size()/2 + (ScanState.iK - StatesBase.State[i].iK)] + sum_contrib += Weight_integral[Weight_integral.size()/2 + (ScanState.iK - StatesBase.State[i].iK)] * Weight_integral[Weight_integral.size()/2 + (StatesBase.State[i].iK - GroundState.iK)] * real(exp(ln_Density_ME (ScanState, StatesBase.State[i]))) * StatesBase.densityME[i] /((GroundState.E - StatesBase.State[i].E) * (GroundState.E - ScanState.E)); @@ -220,35 +221,35 @@ namespace JSC { stringstream filenameprefix; Data_File_Name (filenameprefix, 'Z', c_int, L, N, iKmin, iKmax, 0.0, 0.0, ""); - string prefix = filenameprefix.str(); + string prefix = filenameprefix.str(); stringstream RAW_stringstream; string RAW_string; RAW_stringstream << prefix << ".raw"; stringstream NRG_stringstream; string NRG_string; - NRG_stringstream << "States_c_" << c_int << "_L_" << L << "_N_" << N - << "_iKmin_" << iKmin << "_iKmax_" << iKmax << "_Nstates_" << Nstates_required - << "_Sym_" << symmetric_states << "_iKmod_" << iKmod << "_wopt_" << weighing_option << ".nrg"; - + NRG_stringstream << "States_c_" << c_int << "_L_" << L << "_N_" << N + << "_iKmin_" << iKmin << "_iKmax_" << iKmax << "_Nstates_" << Nstates_required + << "_Sym_" << symmetric_states << "_iKmod_" << iKmod << "_wopt_" << weighing_option << ".nrg"; + RAW_string = RAW_stringstream.str(); const char* RAW_Cstr = RAW_string.c_str(); - + NRG_string = NRG_stringstream.str(); const char* NRG_Cstr = NRG_string.c_str(); - + ifstream infile; infile.open(RAW_Cstr); - + if (infile.fail()) { cout << RAW_Cstr << endl; - JSCerror("The input file was not opened successfully in Select_States_for_NRG. "); + ABACUSerror("The input file was not opened successfully in Select_States_for_NRG. "); } ofstream NRG_outfile; - + NRG_outfile.open(NRG_Cstr); - if (NRG_outfile.fail()) JSCerror("Could not open NRG_outfile... "); - + if (NRG_outfile.fail()) ABACUSerror("Could not open NRG_outfile... "); + //NRG_outfile.setf(ios::scientific); NRG_outfile.precision(16); @@ -281,7 +282,7 @@ namespace JSC { //int* conv = new int[MAXDATA]; string* label = new string[MAXDATA]; bool* sym = new bool[MAXDATA]; - + int Ndata = 0; infile.close(); @@ -299,7 +300,7 @@ namespace JSC { infile.close(); // Define the ground state: - LiebLin_Bethe_State GroundState (c_int, L, N); + LiebLin_Bethe_State GroundState (c_int, L, N); GroundState.Compute_All(true); // Define OriginIx2 for labelling: @@ -314,7 +315,7 @@ namespace JSC { /* // DEPRECATED 25/1/2012: from now on (ABACUS++T_8 onwards), use FT of potential as argument to this function. - Vect_DP Weight_integral (0.0, 4* (iKmax - iKmin)); // we give a large window + Vect_DP Weight_integral (0.0, 4* (iKmax - iKmin)); // we give a large window //Vect_DP args(0.0, 2); DP req_rel_prec = 1.0e-6; @@ -325,7 +326,7 @@ namespace JSC { args_to_weight_integrand[1] = DP(iK); - Integral_result answer = Integrate_optimal (weight_integrand_fn, args_to_weight_integrand, + Integral_result answer = Integrate_optimal (weight_integrand_fn, args_to_weight_integrand, 0, 0.0, 0.5, req_rel_prec, req_abs_prec, max_nr_pts); Weight_integral[Weight_integral.size()/2 + iK] = answer.integ_est; @@ -344,7 +345,7 @@ namespace JSC { for (int i = 0; i < Ndata; ++i) { //cout << i << " out of " << Ndata << "\tlabel = " << label[i] << endl; - + if (abs(iK[i]) % iKmod != 0) { // if iK not a multiple of iKmod: give stupidly high weight. weight[i] = 1.0e+100; sym[i] = false; // doesn't matter @@ -359,41 +360,41 @@ namespace JSC { sym[i] = ScanState.Check_Symmetry(); //cout << "Setting state " << i << "\t to label " << label[i] << "\tsym: " << sym[i] << endl; - + // WEIGHING THE STATES: ********************************************** - + State_Label_Data currentdata = Read_State_Label (label[i], OriginIx2); if (currentdata.nexc[0] == 0) weight[i] = 0.0; - + else if (symmetric_states && iK[i] < 0 || iK[i] < iKmin || iK[i] > iKmax) weight[i] = 1.0e+100; - + //else if (symmetric_states && iK[i] == 0 && !ScanState.Check_Symmetry()) { else if (symmetric_states && iK[i] == 0 && !sym[i]) { - // This state is at zero momentum but not symmetric. we keep it only if + // This state is at zero momentum but not symmetric. we keep it only if // the first non-symmetric pair of quantum numbers is right-weighted: int icheck = 0; while (ScanState.Ix2[N-1-icheck] == -ScanState.Ix2[icheck]) icheck++; if (ScanState.Ix2[N-1-icheck] > -ScanState.Ix2[icheck]) { if (weighing_option == 0) weight[i] = E[i]; - else if (weighing_option == 1 || weighing_option == 2) - weight[i] = 1.0/(1.0e-100 + fabs(Estimate_Contribution_of_Single_ph_Annihilation_Path_to_2nd_Order_PT + else if (weighing_option == 1 || weighing_option == 2) + weight[i] = 1.0/(1.0e-100 + fabs(Estimate_Contribution_of_Single_ph_Annihilation_Path_to_2nd_Order_PT //(ScanState, GroundState, Weight_integral))); (ScanState, GroundState, FT_of_potential))); } else weight[i] = 1.0e+100; } - + else { if (weighing_option == 0) weight[i] = E[i]; - else if (weighing_option == 1 || weighing_option == 2) - weight[i] = 1.0/(1.0e-100 + fabs(Estimate_Contribution_of_Single_ph_Annihilation_Path_to_2nd_Order_PT + else if (weighing_option == 1 || weighing_option == 2) + weight[i] = 1.0/(1.0e-100 + fabs(Estimate_Contribution_of_Single_ph_Annihilation_Path_to_2nd_Order_PT //(ScanState, GroundState, Weight_integral))); (ScanState, GroundState, FT_of_potential))); } //cout << i << " out of " << Ndata << "\tlabel = " << label[i] << "\tweight = " << weight[i] << endl; } } // for i - + // Now order the states in increasing weight int* index = new int[Ndata]; @@ -413,7 +414,7 @@ namespace JSC { // Copy selected states into new vectors: - for (int i = 0; i < JSC::min(Ndata, Nstates_required); ++i) { + for (int i = 0; i < ABACUS::min(Ndata, Nstates_required); ++i) { E_kept[i] = E[index[i] ]; iK_kept[i] = iK[index[i] ]; //conv_kept[i] = conv[index[i] ]; @@ -434,8 +435,8 @@ namespace JSC { // Output selected states: for (int i = 0; i < Nstates_required; ++i) { if (i > 0) NRG_outfile << endl; - NRG_outfile << i << "\t" << E_kept[i] << "\t" << iK_kept[index_kept[i] ] - //<< "\t" << conv_kept[index_kept[i] ] + NRG_outfile << i << "\t" << E_kept[i] << "\t" << iK_kept[index_kept[i] ] + //<< "\t" << conv_kept[index_kept[i] ] << "\t" << label_kept[index_kept[i] ] << "\t" << sym_kept[index_kept[i] ] << "\t" << weight_kept[index_kept[i] ]; } @@ -458,4 +459,4 @@ namespace JSC { } -} // namespace JSC +} // namespace ABACUS diff --git a/src/ODSLF/ODSLF.cc b/src/ODSLF/ODSLF.cc index aca0852..c9d426b 100644 --- a/src/ODSLF/ODSLF.cc +++ b/src/ODSLF/ODSLF.cc @@ -1,8 +1,8 @@ /********************************************************** -This software is part of J.-S. Caux's ABACUS++ library. +This software is part of J.-S. Caux's ABACUS library. -Copyright (c) +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -10,14 +10,13 @@ File: src/1DSLF/1DSLF.cc Purpose: defines functions for 1d spinless fermion classes. - ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -namespace JSC { +namespace ABACUS { //*************************************************************************************************** @@ -26,7 +25,7 @@ namespace JSC { ODSLF_Base::ODSLF_Base () : Mdown(0), Nrap(Vect()), Nraptot(0), Ix2_infty(Vect()), Ix2_max(Vect()) {} ODSLF_Base::ODSLF_Base (const ODSLF_Base& RefBase) // copy constructor - : Mdown(RefBase.Mdown), Nrap(Vect(RefBase.Nrap.size())), Nraptot(RefBase.Nraptot), + : Mdown(RefBase.Mdown), Nrap(Vect(RefBase.Nrap.size())), Nraptot(RefBase.Nraptot), Ix2_infty(Vect(RefBase.Nrap.size())), Ix2_max(Vect(RefBase.Nrap.size())), id(RefBase.id) { @@ -35,9 +34,9 @@ namespace JSC { Ix2_infty[i] = RefBase.Ix2_infty[i]; Ix2_max[i] = RefBase.Ix2_max[i]; } - } + } - ODSLF_Base::ODSLF_Base (const Heis_Chain& RefChain, int M) + ODSLF_Base::ODSLF_Base (const Heis_Chain& RefChain, int M) : Mdown(M), Nrap(Vect(RefChain.Nstrings)), Nraptot(0), Ix2_infty(Vect(RefChain.Nstrings)), Ix2_max(Vect(RefChain.Nstrings)) { for (int i = 0; i < RefChain.Nstrings; ++i) Nrap[i] = 0; @@ -45,17 +44,17 @@ namespace JSC { Nraptot = 0; for (int i = 0; i < RefChain.Nstrings; ++i) Nraptot += Nrap[i]; - + // The id of this is zero by definition id = 0LL; // Now compute the Ix2_infty numbers - + (*this).Compute_Ix2_limits(RefChain); } - ODSLF_Base::ODSLF_Base (const Heis_Chain& RefChain, const Vect& Nrapidities) + ODSLF_Base::ODSLF_Base (const Heis_Chain& RefChain, const Vect& Nrapidities) : Mdown(0), Nrap(Nrapidities), Nraptot(0), Ix2_infty(Vect(RefChain.Nstrings)), Ix2_max(Vect(RefChain.Nstrings)), id (0LL) { @@ -63,16 +62,16 @@ namespace JSC { // Check consistency of Nrapidities vector with RefChain //if (RefChain.Nstrings != Nrapidities.size()) cout << "error: Nstrings = " << RefChain.Nstrings << "\tNrap.size = " << Nrapidities.size() << endl; - - if (RefChain.Nstrings != Nrapidities.size()) JSCerror("Incompatible Nrapidities vector used in ODSLF_Base constructor."); - + + if (RefChain.Nstrings != Nrapidities.size()) ABACUSerror("Incompatible Nrapidities vector used in ODSLF_Base constructor."); + int Mcheck = 0; for (int i = 0; i < RefChain.Nstrings; ++i) Mcheck += RefChain.Str_L[i] * Nrap[i]; Mdown = Mcheck; - + Nraptot = 0; for (int i = 0; i < RefChain.Nstrings; ++i) Nraptot += Nrap[i]; - + // Compute id id += Nrapidities[0]; long long int factor = 100000LL; @@ -84,10 +83,10 @@ namespace JSC { // Now compute the Ix2_infty numbers (*this).Compute_Ix2_limits(RefChain); - + } - ODSLF_Base::ODSLF_Base (const Heis_Chain& RefChain, long long int id_ref) + ODSLF_Base::ODSLF_Base (const Heis_Chain& RefChain, long long int id_ref) : Mdown(0), Nrap(Vect(RefChain.Nstrings)), Nraptot(0), Ix2_infty(Vect(RefChain.Nstrings)), Ix2_max(Vect(RefChain.Nstrings)), id (id_ref) { @@ -105,18 +104,18 @@ namespace JSC { //id = id_ref; //cout << "In ODSLF_Base constructor: id_ref = " << id_ref << " and Nrapidities = " << Nrap << endl; - + // Check consistency of Nrapidities vector with RefChain - //if (RefChain.Nstrings != Nrap.size()) JSCerror("Incompatible Nrapidities vector used in ODSLFBase constructor."); - + //if (RefChain.Nstrings != Nrap.size()) ABACUSerror("Incompatible Nrapidities vector used in ODSLFBase constructor."); + int Mcheck = 0; for (int i = 0; i < RefChain.Nstrings; ++i) Mcheck += RefChain.Str_L[i] * Nrap[i]; Mdown = Mcheck; - + Nraptot = 0; for (int i = 0; i < RefChain.Nstrings; ++i) Nraptot += Nrap[i]; - + // Now compute the Ix2_infty numbers (*this).Compute_Ix2_limits(RefChain); @@ -135,7 +134,7 @@ namespace JSC { } return(*this); } - + bool ODSLF_Base::operator== (const ODSLF_Base& RefBase) { bool answer = (Nrap == RefBase.Nrap); @@ -156,39 +155,39 @@ namespace JSC { if ((RefChain.Delta > 0.0) && (RefChain.Delta < 1.0)) { // Compute the Ix2_infty numbers - + DP sum1 = 0.0; DP sum2 = 0.0; - + for (int j = 0; j < RefChain.Nstrings; ++j) { - + sum1 = 0.0; - + for (int k = 0; k < RefChain.Nstrings; ++k) { - + sum2 = 0.0; - - sum2 += (RefChain.Str_L[j] == RefChain.Str_L[k]) ? 0.0 : 2.0 * atan(tan(0.25 * PI * (1.0 + RefChain.par[j] * RefChain.par[k]) + + sum2 += (RefChain.Str_L[j] == RefChain.Str_L[k]) ? 0.0 : 2.0 * atan(tan(0.25 * PI * (1.0 + RefChain.par[j] * RefChain.par[k]) - 0.5 * fabs(RefChain.Str_L[j] - RefChain.Str_L[k]) * RefChain.anis)); - sum2 += 2.0 * atan(tan(0.25 * PI * (1.0 + RefChain.par[j] * RefChain.par[k]) + sum2 += 2.0 * atan(tan(0.25 * PI * (1.0 + RefChain.par[j] * RefChain.par[k]) - 0.5 * (RefChain.Str_L[j] + RefChain.Str_L[k]) * RefChain.anis)); - - for (int a = 1; a < JSC::min(RefChain.Str_L[j], RefChain.Str_L[k]); ++a) - sum2 += 2.0 * 2.0 * atan(tan(0.25 * PI * (1.0 + RefChain.par[j] * RefChain.par[k]) + + for (int a = 1; a < ABACUS::min(RefChain.Str_L[j], RefChain.Str_L[k]); ++a) + sum2 += 2.0 * 2.0 * atan(tan(0.25 * PI * (1.0 + RefChain.par[j] * RefChain.par[k]) - 0.5 * (fabs(RefChain.Str_L[j] - RefChain.Str_L[k]) + 2.0*a) * RefChain.anis)); - + sum1 += (Nrap[k] - ((j == k) ? 1 : 0)) * sum2; } - - Ix2_infty[j] = (1.0/PI) * fabs(RefChain.Nsites * 2.0 * atan(tan(0.25 * PI * (1.0 + RefChain.par[j]) + + Ix2_infty[j] = (1.0/PI) * fabs(RefChain.Nsites * 2.0 * atan(tan(0.25 * PI * (1.0 + RefChain.par[j]) - 0.5 * RefChain.Str_L[j] * RefChain.anis)) - sum1); - + } // The Ix2_infty are now set. // Now compute the Ix2_max limits - + for (int j = 0; j < RefChain.Nstrings; ++j) { - + Ix2_max[j] = int(floor(Ix2_infty[j])); // sets basic integer // Reject formally infinite rapidities (i.e. if Delta is root of unity) @@ -202,11 +201,11 @@ namespace JSC { //if (!((Nrap[j] + Ix2_max[j]) % 2)) Ix2_max[j] -= 1; DEACTIVATED FOR ODSLF ! // For ODSLF: parity of quantum numbers is complicated: - // if (N-1 + M_j + (M + 1) n_j + (1 - nu_j) N/2) is even, q# are integers, so Ix2_max must be even (conversely, if odd, then odd). + // if (N-1 + M_j + (M + 1) n_j + (1 - nu_j) N/2) is even, q# are integers, so Ix2_max must be even (conversely, if odd, then odd). if ((Ix2_max[j] + RefChain.Nsites - 1 + Nrap[j] + (Nraptot + 1) * RefChain.Str_L[j] + (RefChain.par[j] == 1 ? 0 : RefChain.Nsites)) % 2) Ix2_max[j] -= 1; while (Ix2_max[j] > RefChain.Nsites) { - Ix2_max[j] -= 2; + Ix2_max[j] -= 2; } } } // if XXZ gapless @@ -214,41 +213,41 @@ namespace JSC { else if (RefChain.Delta == 1.0) { // Compute the Ix2_infty numbers - + int sum1 = 0; - + for (int j = 0; j < RefChain.Nstrings; ++j) { - + sum1 = 0; - + for (int k = 0; k < RefChain.Nstrings; ++k) { - - sum1 += Nrap[k] * (2 * JSC::min(RefChain.Str_L[j], RefChain.Str_L[k]) - ((j == k) ? 1 : 0)); + + sum1 += Nrap[k] * (2 * ABACUS::min(RefChain.Str_L[j], RefChain.Str_L[k]) - ((j == k) ? 1 : 0)); } - + //Ix2_infty[j] = (RefChain.Nsites - 1.0 + 2.0 * RefChain.Str_L[j] - sum1); Ix2_infty[j] = (RefChain.Nsites + 1.0 - sum1); // to get counting right... - + } // The Ix2_infty are now set. - + // Now compute the Ix2_max limits - + for (int j = 0; j < RefChain.Nstrings; ++j) { Ix2_max[j] = int(floor(Ix2_infty[j])); // sets basic integer // Give the correct parity to Ix2_max - + // If Nrap is even, Ix2_max must be odd. If odd, then even. //if (!((Nrap[j] + Ix2_max[j]) % 2)) Ix2_max[j] -= 1; DEACTIVATED FOR ODSLF ! // If Ix2_max equals Ix2_infty, we reduce it by 2: - + if (Ix2_max[j] == int(Ix2_infty[j])) Ix2_max[j] -= 2; - + while (Ix2_max[j] > RefChain.Nsites) { - Ix2_max[j] -= 2; + Ix2_max[j] -= 2; } } @@ -257,40 +256,40 @@ namespace JSC { else if (RefChain.Delta > 1.0) { // Compute the Ix2_infty numbers - + int sum1 = 0; - + for (int j = 0; j < RefChain.Nstrings; ++j) { - + sum1 = 0; - + for (int k = 0; k < RefChain.Nstrings; ++k) { - - sum1 += Nrap[k] * (2 * JSC::min(RefChain.Str_L[j], RefChain.Str_L[k]) - ((j == k) ? 1 : 0)); + + sum1 += Nrap[k] * (2 * ABACUS::min(RefChain.Str_L[j], RefChain.Str_L[k]) - ((j == k) ? 1 : 0)); } - + Ix2_infty[j] = (RefChain.Nsites - 1 + 2 * RefChain.Str_L[j] - sum1); - + } // The Ix2_infty are now set. - + // Now compute the Ix2_max limits - + for (int j = 0; j < RefChain.Nstrings; ++j) { - + Ix2_max[j] = int(floor(Ix2_infty[j])); // sets basic integer // Give the correct parity to Ix2_max - + // If Nrap is even, Ix2_max must be odd. If odd, then even. //if (!((Nrap[j] + Ix2_max[j]) % 2)) Ix2_max[j] -= 1; DEACTIVATED FOR ODSLF ! - + // If Ix2_max equals Ix2_infty, we reduce it by 2: //if (Ix2_max[j] == Ix2_infty[j]) Ix2_max[j] -= 2; while (Ix2_max[j] > RefChain.Nsites) { - Ix2_max[j] -= 2; + Ix2_max[j] -= 2; } // Fudge, for strings: @@ -305,7 +304,7 @@ namespace JSC { void ODSLF_Base::Scan_for_Possible_Types (Vect& possible_type_id, int& nfound, int base_level, Vect& Nexcitations) { if (base_level == 0) { - // We set all sectors 0, 1, 2, 3 + // We set all sectors 0, 1, 2, 3 int Nexc_max_0 = (Nrap[0] + 1)/2; // holes on R int Nexc_max_1 = Nrap[0]/2; @@ -317,14 +316,14 @@ namespace JSC { for (int i = 4; i < Nexcitations.size(); ++i) Nexc_above += Nexcitations[i]; for (int nphpairs = 0; nphpairs <= NEXC_MAX_HEIS/2 - Nexc_above; ++nphpairs) - for (int nexc0 = 0; nexc0 <= JSC::min(Nexc_max_0, nphpairs); ++nexc0) { + for (int nexc0 = 0; nexc0 <= ABACUS::min(Nexc_max_0, nphpairs); ++nexc0) { int nexc1 = nphpairs - nexc0; - for (int nexc2 = 0; nexc2 <= JSC::min(Nexc_max_2, nphpairs); ++nexc2) { + for (int nexc2 = 0; nexc2 <= ABACUS::min(Nexc_max_2, nphpairs); ++nexc2) { int nexc3 = nphpairs - nexc2; if (nexc1 >= 0 && nexc1 <= Nexc_max_1 && nexc3 >= 0 && nexc3 <= Nexc_max_3) { // acceptable type found - Nexcitations[0] = nexc0; Nexcitations[1] = nexc1; Nexcitations[2] = nexc2; Nexcitations[3] = nexc3; + Nexcitations[0] = nexc0; Nexcitations[1] = nexc1; Nexcitations[2] = nexc2; Nexcitations[3] = nexc3; possible_type_id[nfound] = Ix2_Offsets_type_id (Nexcitations); nfound++; } @@ -338,7 +337,7 @@ namespace JSC { // Count the number of slots available on R: //int Nexc_R_max = Ix2_max[base_level]/2 + 1; int Nexc_R_max = (Ix2_max[base_level] + 2)/2; // bug in earlier line: if Ix2_max < 0, must have Nexc_R_max == 0, not 1. - int Nexc_L_max = (Ix2_max[base_level] + 1)/2; + int Nexc_L_max = (Ix2_max[base_level] + 1)/2; for (int Nexcleft = 0; Nexcleft <= Nrap[base_level]; ++Nexcleft) if (Nexcleft <= Nexc_L_max && Nrap[base_level] - Nexcleft <= Nexc_R_max) { Nexcitations[2*base_level + 2] = Nrap[base_level] - Nexcleft; @@ -349,7 +348,7 @@ namespace JSC { } - Vect ODSLF_Base::Possible_Types () + Vect ODSLF_Base::Possible_Types () { // Given a base, this returns a vector of possible types @@ -375,7 +374,7 @@ namespace JSC { ODSLF_Ix2_Config::ODSLF_Ix2_Config () {} - ODSLF_Ix2_Config::ODSLF_Ix2_Config (const Heis_Chain& RefChain, int M) + ODSLF_Ix2_Config::ODSLF_Ix2_Config (const Heis_Chain& RefChain, int M) : Nstrings(1), Nrap(Vect(M,1)), Nraptot(M), Ix2(new int*[1]) // single type of string here //: Ix2 (Vect > (1)) { @@ -383,7 +382,7 @@ namespace JSC { //Ix2[0] = Vect (M); for (int j = 0; j < M; ++j) { - Ix2[0][j] = -(M - 1) + 2*j; + Ix2[0][j] = -(M - 1) + 2*j; /* cout << j << "\t" << Ix2[0][j] << endl; cout << "Here 1" << endl; @@ -401,11 +400,11 @@ namespace JSC { */ // Use simplification: Nrap[0] = M = Nraptot, Str_L[0] = 1, par = 1, so if ((Ix2[0][j] + RefChain.Nsites) % 2) Ix2[0][j] -= 1; - //OBSOLETE: 1 - (M % 2); // last term: correction for ODSLF + //OBSOLETE: 1 - (M % 2); // last term: correction for ODSLF } } - ODSLF_Ix2_Config::ODSLF_Ix2_Config (const Heis_Chain& RefChain, const ODSLF_Base& base) + ODSLF_Ix2_Config::ODSLF_Ix2_Config (const Heis_Chain& RefChain, const ODSLF_Base& base) : Nstrings(RefChain.Nstrings), Nrap(base.Nrap), Nraptot(base.Nraptot), Ix2(new int*[RefChain.Nstrings]) //: Ix2 (Vect > (RefChain.Nstrings)) { @@ -421,14 +420,14 @@ namespace JSC { } // ODSLF: put back correct parity of quantum nr: - for (int i = 0; i < RefChain.Nstrings; ++i) - for (int j = 0; j < base[i]; ++j) - if ((Ix2[i][j] + RefChain.Nsites - 1 + base.Nrap[i] + (base.Nraptot + 1) * RefChain.Str_L[i] + (RefChain.par[i] == 1 ? 0 : RefChain.Nsites)) % 2) + for (int i = 0; i < RefChain.Nstrings; ++i) + for (int j = 0; j < base[i]; ++j) + if ((Ix2[i][j] + RefChain.Nsites - 1 + base.Nrap[i] + (base.Nraptot + 1) * RefChain.Str_L[i] + (RefChain.par[i] == 1 ? 0 : RefChain.Nsites)) % 2) Ix2[i][j] -= 1; /* // New meaning of negative parity: - for (int j = 1; j < base.Nrap.size(); ++j) + for (int j = 1; j < base.Nrap.size(); ++j) if (RefChain.par[j] == -1) // we `invert' the meaning of the quantum numbers for (int alpha = 0; alpha < base[j]; ++alpha) { if (Ix2[j][alpha] >= 0) Ix2[j][alpha] -= 2*(base.Ix2_max[j]/2 + 1); @@ -459,7 +458,7 @@ namespace JSC { Ix2 = new int*[Nstrings]; Ix2[0] = new int[Nraptot]; for (int i = 1; i < Nstrings; ++i) Ix2[i] = Ix2[i-1] + Nrap[i-1]; - for (int i = 0; i < Nstrings; ++i) + for (int i = 0; i < Nstrings; ++i) for (int j = 0; j < Nrap[i]; ++j) Ix2[i][j] = RefConfig.Ix2[i][j]; } @@ -493,17 +492,17 @@ namespace JSC { ODSLF_Lambda::ODSLF_Lambda () {} - ODSLF_Lambda::ODSLF_Lambda (const Heis_Chain& RefChain, int M) + ODSLF_Lambda::ODSLF_Lambda (const Heis_Chain& RefChain, int M) : Nstrings(1), Nrap(Vect(M,1)), Nraptot(M), lambda(new DP*[1]) // single type of string here //: lambda(Vect > (1)) { lambda[0] = new DP[M]; //lambda[0] = Vect (M); - for (int j = 0; j < M; ++j) lambda[0][j] = 0.0; + for (int j = 0; j < M; ++j) lambda[0][j] = 0.0; } - ODSLF_Lambda::ODSLF_Lambda (const Heis_Chain& RefChain, const ODSLF_Base& base) + ODSLF_Lambda::ODSLF_Lambda (const Heis_Chain& RefChain, const ODSLF_Base& base) : Nstrings(RefChain.Nstrings), Nrap(base.Nrap), Nraptot(base.Nraptot), lambda(new DP*[RefChain.Nstrings]) //: lambda(Vect > (RefChain.Nstrings)) { @@ -511,7 +510,7 @@ namespace JSC { lambda[0] = new DP[base.Nraptot]; for (int i = 1; i < RefChain.Nstrings; ++i) lambda[i] = lambda[i-1] + base[i-1]; //for (int i = 0; i < RefChain.Nstrings; ++i) lambda[i] = Vect (base[i]); - + for (int i = 0; i < RefChain.Nstrings; ++i) { for (int j = 0; j < base[i]; ++j) lambda[i][j] = 0.0; } @@ -539,7 +538,7 @@ namespace JSC { lambda = new DP*[Nstrings]; lambda[0] = new DP[Nraptot]; for (int i = 1; i < Nstrings; ++i) lambda[i] = lambda[i-1] + Nrap[i-1]; - for (int i = 0; i < Nstrings; ++i) + for (int i = 0; i < Nstrings; ++i) for (int j = 0; j < Nrap[i]; ++j) lambda[i][j] = RefLambda.lambda[i][j]; } @@ -566,7 +565,7 @@ namespace JSC { for (int i = 0; i < 2 * base.Nrap.size() + 2; ++i) Tableau[i] = RefOffset.Tableau[i]; } - ODSLF_Ix2_Offsets::ODSLF_Ix2_Offsets (const ODSLF_Base& RefBase, long long int req_type_id) + ODSLF_Ix2_Offsets::ODSLF_Ix2_Offsets (const ODSLF_Base& RefBase, long long int req_type_id) // sets all tableaux to empty ones, with nparticles(req_type_id) at each level { // Build nparticles vector from req_type_id @@ -582,9 +581,9 @@ namespace JSC { // Check if we've got the right vector... long long int idcheck = Ix2_Offsets_type_id (nparticles); - if (idcheck != req_type_id) JSCerror("idcheck != req_type_id in Ix2_Offsets constructor."); + if (idcheck != req_type_id) ABACUSerror("idcheck != req_type_id in Ix2_Offsets constructor."); - (*this) = ODSLF_Ix2_Offsets(RefBase, nparticles); + (*this) = ODSLF_Ix2_Offsets(RefBase, nparticles); } ODSLF_Ix2_Offsets::ODSLF_Ix2_Offsets (const ODSLF_Base& RefBase, Vect nparticles) // sets all tableaux to empty ones, with nparticles at each level @@ -593,46 +592,46 @@ namespace JSC { // Checks on nparticles vector: - if (nparticles.size() != 2 * base.Nrap.size() + 2) JSCerror("Wrong nparticles.size in Ix2_Offsets constructor."); - - //if (base.Nrap[0] != (nparticles[3] + nparticles[2] + base.Mdown - nparticles[0] - nparticles[1])) JSCerror("Wrong Nrap[0] in Ix2_Offsets constructor."); + if (nparticles.size() != 2 * base.Nrap.size() + 2) ABACUSerror("Wrong nparticles.size in Ix2_Offsets constructor."); + + //if (base.Nrap[0] != (nparticles[3] + nparticles[2] + base.Mdown - nparticles[0] - nparticles[1])) ABACUSerror("Wrong Nrap[0] in Ix2_Offsets constructor."); if (nparticles[3] + nparticles[2] != nparticles[0] + nparticles[1]) { cout << nparticles[0] << "\t" << nparticles[1] << "\t" << nparticles[2] << "\t" << nparticles[3] << endl; - JSCerror("Wrong Npar[0-3] in Ix2_Offsets constructor."); + ABACUSerror("Wrong Npar[0-3] in Ix2_Offsets constructor."); } - for (int base_level = 1; base_level < base.Nrap.size(); ++ base_level) + for (int base_level = 1; base_level < base.Nrap.size(); ++ base_level) if (base.Nrap[base_level] != nparticles[2*base_level + 2] + nparticles[2*base_level + 3]) { cout << base_level << "\t" << base.Nrap[base_level] << "\t" << nparticles[2*base_level + 2] << "\t" << nparticles[2*base_level + 3] << endl; - JSCerror("Wrong Nrap[] in Ix2_Offsets constructor."); + ABACUSerror("Wrong Nrap[] in Ix2_Offsets constructor."); } // nparticles[0,1]: number of holes on R and L side in GS interval - if (nparticles[0] > (base.Nrap[0] + 1)/2) JSCerror("nparticles[0] too large in Ix2_Offsets constructor."); - if (nparticles[1] > base.Nrap[0]/2) JSCerror("nparticles[1] too large in Ix2_Offsets constructor."); + if (nparticles[0] > (base.Nrap[0] + 1)/2) ABACUSerror("nparticles[0] too large in Ix2_Offsets constructor."); + if (nparticles[1] > base.Nrap[0]/2) ABACUSerror("nparticles[1] too large in Ix2_Offsets constructor."); // nparticles[2,3]: number of particles of type 0 on R and L side out of GS interval - if (nparticles[2] > (base.Ix2_max[0] - base.Nrap[0] + 1)/2) JSCerror("nparticles[2] too large in Ix2_Offsets constructor."); - if (nparticles[3] > (base.Ix2_max[0] - base.Nrap[0] + 1)/2) JSCerror("nparticles[3] too large in Ix2_Offsets constructor."); + if (nparticles[2] > (base.Ix2_max[0] - base.Nrap[0] + 1)/2) ABACUSerror("nparticles[2] too large in Ix2_Offsets constructor."); + if (nparticles[3] > (base.Ix2_max[0] - base.Nrap[0] + 1)/2) ABACUSerror("nparticles[3] too large in Ix2_Offsets constructor."); for (int base_level = 1; base_level < base.Nrap.size(); ++ base_level) //if ((nparticles[2*base_level + 2] > 0 && nparticles[2*base_level + 2] > (base.Ix2_max[base_level] - ((base.Nrap[base_level] + 1) % 2) + 2)/2) if ((nparticles[2*base_level + 2] > 0 && nparticles[2*base_level + 2] > (base.Ix2_max[base_level] + 2)/2) // ODSLF modif //|| (nparticles[2*base_level + 3] > 0 && nparticles[2*base_level + 3] > (base.Ix2_max[base_level] - (base.Nrap[base_level] % 2) - 1)/2)) { - || (nparticles[2*base_level + 3] > 0 - //&& nparticles[2*base_level + 3] > base.Ix2_max[base_level] + 1 - (base.Ix2_max[base_level] - ((base.Nrap[base_level] + 1) % 2) + 2)/2)) + || (nparticles[2*base_level + 3] > 0 + //&& nparticles[2*base_level + 3] > base.Ix2_max[base_level] + 1 - (base.Ix2_max[base_level] - ((base.Nrap[base_level] + 1) % 2) + 2)/2)) && nparticles[2*base_level + 3] > (base.Ix2_max[base_level] + 1)/2)) // ODSLF modif { cout << base_level << "\t" << base.Ix2_max[base_level] << "\t" << base.Ix2_infty[base_level] << "\t" << nparticles[2*base_level + 2] << "\t" << (base.Ix2_max[base_level] - ((base.Nrap[base_level] + 1) % 2) + 2)/2 - << "\t" << nparticles[2*base_level + 3] << "\t" << (base.Ix2_max[base_level] - (base.Nrap[base_level] % 2) - 1)/2 + << "\t" << nparticles[2*base_level + 3] << "\t" << (base.Ix2_max[base_level] - (base.Nrap[base_level] % 2) - 1)/2 << "\t" << (nparticles[2*base_level + 2] > 0) << "\t" << (nparticles[2*base_level + 2] > (base.Ix2_max[base_level] - ((base.Nrap[base_level] + 1) % 2) + 2)/2) //<< "\t" << (nparticles[2*base_level + 3] > 0) << "\t" << (nparticles[2*base_level + 3] > (base.Ix2_max[base_level] - (base.Nrap[base_level] % 2) - 1)/2) - << "\t" << (nparticles[2*base_level + 3] > 0) << "\t" + << "\t" << (nparticles[2*base_level + 3] > 0) << "\t" << (nparticles[2*base_level + 3] > base.Ix2_max[base_level] + 1 - (base.Ix2_max[base_level] - ((base.Nrap[base_level] + 1) % 2) + 2)/2) << endl; - JSCerror("nparticles too large in Ix2_Offsets constructor."); + ABACUSerror("nparticles too large in Ix2_Offsets constructor."); } - + // Check sum of rapidities // Holes in GS interval @@ -642,14 +641,14 @@ namespace JSC { // Particles of type 0 out of GS interval Tableau[2] = Young_Tableau(nparticles[2], (base.Ix2_max[0] - base.Nrap[0] + 1)/2 - nparticles[2], Tableau[0]); Tableau[3] = Young_Tableau(nparticles[3], (base.Ix2_max[0] - base.Nrap[0] + 1)/2 - nparticles[3], Tableau[2]); - + // Tableaux of index i = 2,...: data about string type i/2-1. for (int base_level = 1; base_level < base.Nrap.size(); ++base_level) { - Tableau[2*base_level + 2] = Young_Tableau(nparticles[2*base_level + 2], + Tableau[2*base_level + 2] = Young_Tableau(nparticles[2*base_level + 2], //(base.Ix2_max[base_level] - ((base.Nrap[base_level]) % 2) + 2)/2 - nparticles[2*base_level + 2], Tableau[2]); //(base.Ix2_max[base_level] - base.Nrap[base_level] % 2 + 2)/2 - nparticles[2*base_level + 2], Tableau[2]); (base.Ix2_max[base_level] - ((base.Nrap[base_level] + 1) % 2))/2 + 1 - nparticles[2*base_level + 2], Tableau[2]); - Tableau[2*base_level + 3] = Young_Tableau(nparticles[2*base_level + 3], + Tableau[2*base_level + 3] = Young_Tableau(nparticles[2*base_level + 3], //(base.Ix2_max[base_level] - base.Nrap[base_level] % 2)/2 - nparticles[2*base_level + 3], Tableau[3]); (base.Ix2_max[base_level] - (base.Nrap[base_level] % 2) - 1)/2 + 1 - nparticles[2*base_level + 3], Tableau[3]); } @@ -685,11 +684,11 @@ namespace JSC { for (int level = 0; level < 4; ++level) { // check fundamental level only //for (int level = 0; level < 2 * base.Nrap.size() + 2; ++level) { // First check whether all rows which exist in both tableaux satisfy rule: - for (int tableau_level = 0; tableau_level < JSC::min(Tableau[level].Nrows, RefOffsets.Tableau[level].Nrows); ++tableau_level) - if (Tableau[level].Row_L[tableau_level] > RefOffsets.Tableau[level].Row_L[tableau_level]) + for (int tableau_level = 0; tableau_level < ABACUS::min(Tableau[level].Nrows, RefOffsets.Tableau[level].Nrows); ++tableau_level) + if (Tableau[level].Row_L[tableau_level] > RefOffsets.Tableau[level].Row_L[tableau_level]) answer = false; // Now check whether there exist extra rows violating rule: - for (int tableau_level = JSC::min(Tableau[level].Nrows, RefOffsets.Tableau[level].Nrows); tableau_level < Tableau[level].Nrows; ++tableau_level) + for (int tableau_level = ABACUS::min(Tableau[level].Nrows, RefOffsets.Tableau[level].Nrows); tableau_level < Tableau[level].Nrows; ++tableau_level) if (Tableau[level].Row_L[tableau_level] > 0) answer = false; } @@ -705,11 +704,11 @@ namespace JSC { for (int level = 0; level < 4; ++level) { // check fundamental level only //for (int level = 0; level < 2 * base.Nrap.size() + 2; ++level) { // First check whether all rows which exist in both tableaux satisfy rule: - for (int tableau_level = 0; tableau_level < JSC::min(Tableau[level].Nrows, RefOffsets.Tableau[level].Nrows); ++tableau_level) - if (Tableau[level].Row_L[tableau_level] < RefOffsets.Tableau[level].Row_L[tableau_level]) + for (int tableau_level = 0; tableau_level < ABACUS::min(Tableau[level].Nrows, RefOffsets.Tableau[level].Nrows); ++tableau_level) + if (Tableau[level].Row_L[tableau_level] < RefOffsets.Tableau[level].Row_L[tableau_level]) answer = false; // Now check whether there exist extra rows violating rule: - for (int tableau_level = JSC::min(Tableau[level].Nrows, RefOffsets.Tableau[level].Nrows); tableau_level < RefOffsets.Tableau[level].Nrows; ++tableau_level) + for (int tableau_level = ABACUS::min(Tableau[level].Nrows, RefOffsets.Tableau[level].Nrows); tableau_level < RefOffsets.Tableau[level].Nrows; ++tableau_level) if (RefOffsets.Tableau[level].Row_L[tableau_level] > 0) answer = false; } @@ -718,7 +717,7 @@ namespace JSC { void ODSLF_Ix2_Offsets::Set_to_id (long long int idnr) { - // The idnr of the Offset is given by + // The idnr of the Offset is given by // sub_id[0] + (total number of tableaux of type 0) * (sub_id[1] + (total number of tableaux of type 1) * (sub_id[2] + ... // + total number of tableaux of type (2*base.Nrap.size()) * sub_id[2*base.Nrap.size() + 1] @@ -726,7 +725,7 @@ namespace JSC { if (idnr > maxid) { cout << idnr << "\t" << maxid << endl; - JSCerror("idnr too large in offsets.Set_to_id."); + ABACUSerror("idnr too large in offsets.Set_to_id."); } id = idnr; @@ -753,7 +752,7 @@ namespace JSC { for (int i = 0; i <= 2*base.Nrap.size() + 1; ++i) { //cout << "level = " << i << " Tableau.id = " << sub_id[i] << endl; - if ((Tableau[i].Nrows * Tableau[i].Ncols == 0) && (sub_id[i] != 0)) JSCerror("index too large in offset.Set_to_id."); + if ((Tableau[i].Nrows * Tableau[i].Ncols == 0) && (sub_id[i] != 0)) ABACUSerror("index too large in offset.Set_to_id."); if (Tableau[i].id != sub_id[i]) Tableau[i].Set_to_id(sub_id[i]); } @@ -775,7 +774,7 @@ namespace JSC { void ODSLF_Ix2_Offsets::Compute_id () { long long int prod_maxid = 1LL; - + id = 0LL; for (int i = 0; i < 2*base.Nrap.size() + 2; ++i) { @@ -793,7 +792,7 @@ namespace JSC { ODSLF_Ix2_Offsets offsets_init(*this); // keep a copy in case it fails - if (Nboxes < 0) JSCerror("Can't use Nboxes < 0 in Add_Boxes_From_Lowest"); + if (Nboxes < 0) ABACUSerror("Can't use Nboxes < 0 in Add_Boxes_From_Lowest"); else if (Nboxes == 0) return(true); // nothing to do //cout << "Requesting Nboxes " << Nboxes << " in " << odd_sectors << " sectors." << endl; @@ -813,8 +812,8 @@ namespace JSC { if (Nboxes_put < Nboxes) (*this) = offsets_init; // reset ! else if (Nboxes_put > Nboxes) { cout << Nboxes_put << "\t" << Nboxes << endl; - JSCerror("Putting too many boxes in Ix2_Offsets::Add_Boxes_From_Lowest."); - } + ABACUSerror("Putting too many boxes in Ix2_Offsets::Add_Boxes_From_Lowest."); + } return(Nboxes_put == Nboxes); } @@ -832,12 +831,12 @@ namespace JSC { while (n < ndef && !(Ix2_Offsets_type_id_ref == Offsets[n].type_id && RefBase == Offsets[n].base)) n++; - if (n == ndef) { + if (n == ndef) { Offsets[n] = ODSLF_Ix2_Offsets (RefBase, nparticles); ndef++; } - if (ndef >= NBASESMAX) JSCerror("Ix2_Offsets_List: need bigger Offsets vector."); + if (ndef >= NBASESMAX) ABACUSerror("Ix2_Offsets_List: need bigger Offsets vector."); return(Offsets[n]); } @@ -849,12 +848,12 @@ namespace JSC { while (n < ndef && !(req_type_id == Offsets[n].type_id && RefBase == Offsets[n].base)) n++; - if (n == ndef) { + if (n == ndef) { Offsets[n] = ODSLF_Ix2_Offsets (RefBase, req_type_id); ndef++; } - if (ndef >= NBASESMAX) JSCerror("Ix2_Offsets_List: need bigger Offsets vector."); + if (ndef >= NBASESMAX) ABACUSerror("Ix2_Offsets_List: need bigger Offsets vector."); return(Offsets[n]); } @@ -865,7 +864,7 @@ namespace JSC { // Function definitions: class ODSLF_Bethe_State - ODSLF_Bethe_State::ODSLF_Bethe_State () + ODSLF_Bethe_State::ODSLF_Bethe_State () : chain(Heis_Chain()), base(ODSLF_Base()), offsets(ODSLF_Ix2_Offsets()), Ix2(ODSLF_Ix2_Config(chain, 1)), lambda(ODSLF_Lambda(chain, 1)), BE(ODSLF_Lambda(chain, 1)), diffsq(0.0), conv(0), iter(0), iter_Newton(0), E(0.0), iK(0), K(0.0), lnnorm(-100.0), base_id(0LL), type_id(0LL), id(0LL), maxid(0LL), nparticles(0) @@ -873,12 +872,12 @@ namespace JSC { }; ODSLF_Bethe_State::ODSLF_Bethe_State (const ODSLF_Bethe_State& RefState) // copy constructor - //: chain(RefState.chain), base(RefState.base), offsets(RefState.offsets), Ix2(Ix2_Config(RefState.chain, RefState.base.Mdown)), + //: chain(RefState.chain), base(RefState.base), offsets(RefState.offsets), Ix2(Ix2_Config(RefState.chain, RefState.base.Mdown)), // lambda(Lambda(RefState.chain, RefState.base.Mdown)), BE(Lambda(RefState.chain, RefState.base.Mdown)), - : chain(RefState.chain), base(RefState.base), offsets(RefState.offsets), Ix2(ODSLF_Ix2_Config(RefState.chain, RefState.base)), + : chain(RefState.chain), base(RefState.base), offsets(RefState.offsets), Ix2(ODSLF_Ix2_Config(RefState.chain, RefState.base)), lambda(ODSLF_Lambda(RefState.chain, RefState.base)), BE(ODSLF_Lambda(RefState.chain, RefState.base)), diffsq(RefState.diffsq), conv(RefState.conv), iter(RefState.iter), iter_Newton(RefState.iter_Newton), - E(RefState.E), iK(RefState.iK), K(RefState.K), lnnorm(RefState.lnnorm), + E(RefState.E), iK(RefState.iK), K(RefState.K), lnnorm(RefState.lnnorm), //id(RefState.id), maxid(RefState.maxid) base_id(RefState.base_id), type_id(RefState.type_id), id(RefState.id), maxid(RefState.maxid), nparticles(RefState.nparticles) @@ -901,12 +900,12 @@ namespace JSC { } //cout << "Heis constructor state OK" << endl; } - - ODSLF_Bethe_State::ODSLF_Bethe_State (const ODSLF_Bethe_State& RefState, long long int type_id_ref) - : chain(RefState.chain), base(RefState.base), offsets(ODSLF_Ix2_Offsets(RefState.base, type_id_ref)), - Ix2(ODSLF_Ix2_Config(RefState.chain, RefState.base)), lambda(ODSLF_Lambda(RefState.chain, RefState.base)), + + ODSLF_Bethe_State::ODSLF_Bethe_State (const ODSLF_Bethe_State& RefState, long long int type_id_ref) + : chain(RefState.chain), base(RefState.base), offsets(ODSLF_Ix2_Offsets(RefState.base, type_id_ref)), + Ix2(ODSLF_Ix2_Config(RefState.chain, RefState.base)), lambda(ODSLF_Lambda(RefState.chain, RefState.base)), BE(ODSLF_Lambda(RefState.chain, RefState.base)), diffsq(1.0), conv(0), iter(0), iter_Newton(0), - E(0.0), iK(0), K(0.0), lnnorm(-100.0), + E(0.0), iK(0), K(0.0), lnnorm(-100.0), //id(0LL), maxid(0LL) base_id(RefState.base_id), type_id(0LL), id(0LL), maxid(offsets.maxid), nparticles(0) { @@ -917,10 +916,10 @@ namespace JSC { (*this).Set_Ix2_Offsets (offsets); } - ODSLF_Bethe_State::ODSLF_Bethe_State (const Heis_Chain& RefChain, int M) - : chain(RefChain), base(RefChain, M), offsets(base, 0LL), Ix2(ODSLF_Ix2_Config(RefChain, M)), lambda(ODSLF_Lambda(RefChain, M)), + ODSLF_Bethe_State::ODSLF_Bethe_State (const Heis_Chain& RefChain, int M) + : chain(RefChain), base(RefChain, M), offsets(base, 0LL), Ix2(ODSLF_Ix2_Config(RefChain, M)), lambda(ODSLF_Lambda(RefChain, M)), BE(ODSLF_Lambda(RefChain, M)), diffsq(1.0), conv(0), iter(0), iter_Newton(0), - E(0.0), iK(0), K(0.0), lnnorm(-100.0), + E(0.0), iK(0), K(0.0), lnnorm(-100.0), //id(0LL), maxid(0LL) base_id(0LL), type_id(0LL), id(0LL), maxid(offsets.maxid), nparticles(0) { @@ -930,27 +929,27 @@ namespace JSC { //cout << "lambda OK" << endl; } - ODSLF_Bethe_State::ODSLF_Bethe_State (const Heis_Chain& RefChain, const ODSLF_Base& RefBase) - : chain(RefChain), base(RefBase), offsets(RefBase, 0LL), Ix2(ODSLF_Ix2_Config(RefChain, RefBase)), lambda(ODSLF_Lambda(RefChain, RefBase)), - BE(ODSLF_Lambda(RefChain, RefBase)), diffsq(1.0), conv(0), iter(0), iter_Newton(0), E(0.0), iK(0), K(0.0), lnnorm(-100.0), + ODSLF_Bethe_State::ODSLF_Bethe_State (const Heis_Chain& RefChain, const ODSLF_Base& RefBase) + : chain(RefChain), base(RefBase), offsets(RefBase, 0LL), Ix2(ODSLF_Ix2_Config(RefChain, RefBase)), lambda(ODSLF_Lambda(RefChain, RefBase)), + BE(ODSLF_Lambda(RefChain, RefBase)), diffsq(1.0), conv(0), iter(0), iter_Newton(0), E(0.0), iK(0), K(0.0), lnnorm(-100.0), //id(0LL), maxid(0LL) base_id(RefBase.id), type_id(0LL), id(0LL), maxid(offsets.maxid), nparticles(0) { // Check that the number of rapidities is consistent with Mdown - + //cout << "Here in Heis constructor chain base" << endl; //cout << "lambda " << lambda[0][0] << endl; //cout << "lambda OK" << endl; int Mcheck = 0; for (int i = 0; i < RefChain.Nstrings; ++i) Mcheck += base[i] * RefChain.Str_L[i]; - if (RefBase.Mdown != Mcheck) JSCerror("Wrong M from Nrapidities input vector, in ODSLF_Bethe_State constructor."); - + if (RefBase.Mdown != Mcheck) ABACUSerror("Wrong M from Nrapidities input vector, in ODSLF_Bethe_State constructor."); + } - ODSLF_Bethe_State::ODSLF_Bethe_State (const Heis_Chain& RefChain, long long int base_id_ref, long long int type_id_ref) - : chain(RefChain), base(ODSLF_Base(RefChain, base_id_ref)), offsets(base, type_id_ref), Ix2(ODSLF_Ix2_Config(RefChain, base)), lambda(ODSLF_Lambda(RefChain, base)), - BE(ODSLF_Lambda(RefChain, base)), diffsq(1.0), conv(0), iter(0), iter_Newton(0), E(0.0), iK(0), K(0.0), lnnorm(-100.0), + ODSLF_Bethe_State::ODSLF_Bethe_State (const Heis_Chain& RefChain, long long int base_id_ref, long long int type_id_ref) + : chain(RefChain), base(ODSLF_Base(RefChain, base_id_ref)), offsets(base, type_id_ref), Ix2(ODSLF_Ix2_Config(RefChain, base)), lambda(ODSLF_Lambda(RefChain, base)), + BE(ODSLF_Lambda(RefChain, base)), diffsq(1.0), conv(0), iter(0), iter_Newton(0), E(0.0), iK(0), K(0.0), lnnorm(-100.0), //id(0LL), maxid(0LL) base_id(base_id_ref), type_id(type_id_ref), id(0LL), maxid(offsets.maxid), nparticles(0) { @@ -961,24 +960,24 @@ namespace JSC { void ODSLF_Bethe_State::Set_Ix2_Offsets (const ODSLF_Ix2_Offsets& RefOffset) // sets the Ix2 to given offsets { - if (base != RefOffset.base) JSCerror("Offset with incompatible base used in ODSLF_Bethe_State::Set_Ix2_Offsets."); + if (base != RefOffset.base) ABACUSerror("Offset with incompatible base used in ODSLF_Bethe_State::Set_Ix2_Offsets."); /* // Check if total number of holes agrees with number of rapidities in higher particles int total_nr_holes = RefOffset.Tableau[0].Nrows + RefOffset.Tableau[1].Nrows; int total_nr_rap_in_particles = 0; - for (int offsets_level = 2; offsets_level < RefOffset.Tableau.size(); offsets_level += 2) + for (int offsets_level = 2; offsets_level < RefOffset.Tableau.size(); offsets_level += 2) total_nr_rap_in_particles += chain.Str_L[offsets_level/2 - 1] * (RefOffset.Tableau[offsets_level].Nrows + RefOffset.Tableau[offsets_level + 1].Nrows); cout << total_nr_holes << "\t" << total_nr_rap_in_particles << endl; - if (total_nr_holes != total_nr_rap_in_particles) JSCerror("Offset with incompatible Nparticles used in ODSLF_Bethe_State::Set_Ix2_Offsets."); - */ + if (total_nr_holes != total_nr_rap_in_particles) ABACUSerror("Offset with incompatible Nparticles used in ODSLF_Bethe_State::Set_Ix2_Offsets."); + */ // For each base_level, we make sure that the Ix2 are ordered: Ix2[0][j] < Ix2[0][k] if j < k. // Level 2: particles in R part outside GS interval for (int j = 0; j < RefOffset.Tableau[2].Nrows; ++j) { - Ix2[0][base.Nrap[0] - 1 - j] + Ix2[0][base.Nrap[0] - 1 - j] = base.Nrap[0] - 1 + 2* RefOffset.Tableau[2].Nrows - 2*j + 2*RefOffset.Tableau[2].Row_L[j]; //cout << "R pcles, j = " << base.Nrap[0] - 1 - j << " Ix2[j] = " << Ix2[0][base.Nrap[0] - 1 - j] << endl; //cout << "j = " << j << "\tbase.Nrap[0] " << base.Nrap[0] << "\t2*RefOffset.Tableau[2].Nrows " << 2*RefOffset.Tableau[2].Nrows << "\t2*RefOffset.Tableau[2].Row_L[j] " << 2*RefOffset.Tableau[2].Row_L[j] << endl; @@ -1000,7 +999,7 @@ namespace JSC { // Level 1: holes in L part of GS interval for (int j = 0; j < RefOffset.Tableau[1].Ncols; ++j) { - Ix2[0][base.Nrap[0] - 1 - RefOffset.Tableau[0].Ncols - RefOffset.Tableau[2].Nrows - j] + Ix2[0][base.Nrap[0] - 1 - RefOffset.Tableau[0].Ncols - RefOffset.Tableau[2].Nrows - j] = -1 - (base.Nrap[0] % 2) - 2* j - 2*RefOffset.Tableau[1].Col_L[RefOffset.Tableau[1].Ncols - 1 - j]; //cout << "L holes, j = " << base.Nrap[0] - 1 - RefOffset.Tableau[0].Ncols - RefOffset.Tableau[2].Nrows- j << " Ix2[j] = " << Ix2[0][base.Nrap[0] - 1 - RefOffset.Tableau[0].Ncols - RefOffset.Tableau[2].Nrows- j] << endl; } @@ -1010,7 +1009,7 @@ namespace JSC { // Level 3: particles in L part outside GS interval for (int j = 0; j < RefOffset.Tableau[3].Nrows; ++j) { - Ix2[0][base.Nrap[0] - 1 - RefOffset.Tableau[0].Ncols - RefOffset.Tableau[1].Ncols - RefOffset.Tableau[2].Nrows - j] + Ix2[0][base.Nrap[0] - 1 - RefOffset.Tableau[0].Ncols - RefOffset.Tableau[1].Ncols - RefOffset.Tableau[2].Nrows - j] = -(base.Nrap[0] + 1 + 2*j + 2*RefOffset.Tableau[3].Row_L[RefOffset.Tableau[3].Nrows - 1 - j]); //cout << "R pcles, j = " << base.Nrap[0] - 1 - RefOffset.Tableau[0].Ncols - RefOffset.Tableau[1].Ncols - RefOffset.Tableau[2].Nrows << " Ix2[j] = " << Ix2[0][base.Nrap[0] - 1 - RefOffset.Tableau[0].Ncols - RefOffset.Tableau[1].Ncols - RefOffset.Tableau[2].Nrows] << endl; } @@ -1021,14 +1020,14 @@ namespace JSC { // Subsequent levels: particles on R and L for (int base_level = 1; base_level < base.Nrap.size(); ++base_level) { - for (int j = 0; j < RefOffset.Tableau[2*base_level + 2].Nrows; ++j) - Ix2[base_level][base.Nrap[base_level] - 1 - j] + for (int j = 0; j < RefOffset.Tableau[2*base_level + 2].Nrows; ++j) + Ix2[base_level][base.Nrap[base_level] - 1 - j] = ((base.Nrap[base_level] + 1) % 2) + 2*(RefOffset.Tableau[2*base_level + 2].Nrows - 1) -2*j + 2*RefOffset.Tableau[2*base_level + 2].Row_L[j]; nparticles += RefOffset.Tableau[2*base_level + 2].Nrows; - for (int j = 0; j < RefOffset.Tableau[2*base_level + 3].Nrows; ++j) - Ix2[base_level][base.Nrap[base_level] - 1 - RefOffset.Tableau[2*base_level + 2].Nrows - j] + for (int j = 0; j < RefOffset.Tableau[2*base_level + 3].Nrows; ++j) + Ix2[base_level][base.Nrap[base_level] - 1 - RefOffset.Tableau[2*base_level + 2].Nrows - j] = -1 - ((base.Nrap[base_level]) % 2) -2*j - 2*RefOffset.Tableau[2*base_level + 3].Row_L[RefOffset.Tableau[2*base_level + 3].Nrows - 1 - j]; nparticles += RefOffset.Tableau[2*base_level + 3].Nrows; @@ -1039,9 +1038,9 @@ namespace JSC { //for (int j = 0; j < base.Nrap[0]; ++j) Ix2[0][j] += 1; WRONG!! // ODSLF: put back correct parity of quantum nr: - for (int j = 0; j < base.Nrap.size(); ++j) - for (int alpha = 0; alpha < base[j]; ++alpha) - if ((Ix2[j][alpha] + chain.Nsites - 1 + base.Nrap[j] + (base.Nraptot + 1) * chain.Str_L[j] + (chain.par[j] == 1 ? 0 : chain.Nsites)) % 2) + for (int j = 0; j < base.Nrap.size(); ++j) + for (int alpha = 0; alpha < base[j]; ++alpha) + if ((Ix2[j][alpha] + chain.Nsites - 1 + base.Nrap[j] + (base.Nraptot + 1) * chain.Str_L[j] + (chain.par[j] == 1 ? 0 : chain.Nsites)) % 2) Ix2[j][alpha] -= 1; //cout << "Here e" << endl; @@ -1053,7 +1052,7 @@ namespace JSC { /* // New meaning of negative parity: - for (int j = 1; j < base.Nrap.size(); ++j) + for (int j = 1; j < base.Nrap.size(); ++j) if (chain.par[j] == -1) // we `invert' the meaning of the quantum numbers for (int alpha = 0; alpha < base[j]; ++alpha) { if (Ix2[j][alpha] >= 0) Ix2[j][alpha] -= 2*(base.Ix2_max[j]/2 + 1); @@ -1083,7 +1082,7 @@ namespace JSC { bool ODSLF_Bethe_State::Check_Symmetry () { - // Checks whether the I's are symmetrically distributed. + // Checks whether the I's are symmetrically distributed. bool symmetric_state = true; int arg, test1, test3; @@ -1094,11 +1093,11 @@ namespace JSC { test1 = 0; test3 = 0; for (int alpha = 0; alpha < base[j]; ++alpha) { - arg = (Ix2[j][alpha] != chain.Nsites) ? Ix2[j][alpha] : 0; // since Ix2 = N is same as Ix2 = -N by periodicity, this is symmetric. + arg = (Ix2[j][alpha] != chain.Nsites) ? Ix2[j][alpha] : 0; // since Ix2 = N is same as Ix2 = -N by periodicity, this is symmetric. test1 += arg; test3 += arg * arg * arg; // to make sure that all I's are symmetrical... } - if (!(symmetric_state && (test1 == 0) && (test3 == 0))) symmetric_state = false; + if (!(symmetric_state && (test1 == 0) && (test3 == 0))) symmetric_state = false; } //} /* @@ -1109,12 +1108,12 @@ namespace JSC { test1 = 0; test3 = 0; for (int alpha = 0; alpha < base[j]; ++alpha) { - arg = (Ix2[j][alpha] != chain.Nsites - && abs(Ix2[j][alpha]) != base.Ix2_max[j]) ? Ix2[j][alpha] : 0; // since Ix2 = N is same as Ix2 = -N by periodicity, this is symmetric. + arg = (Ix2[j][alpha] != chain.Nsites + && abs(Ix2[j][alpha]) != base.Ix2_max[j]) ? Ix2[j][alpha] : 0; // since Ix2 = N is same as Ix2 = -N by periodicity, this is symmetric. test1 += arg; test3 += arg * arg * arg; // to make sure that all I's are symmetrical... } - if (!(symmetric_state && (test1 == 0) && (test3 == 0))) symmetric_state = false; + if (!(symmetric_state && (test1 == 0) && (test3 == 0))) symmetric_state = false; } } */ @@ -1126,9 +1125,9 @@ namespace JSC { { DP maxterm = 0.0; int jmax, alphamax; - + diffsq = 0.0; - for (int j = 0; j < chain.Nstrings; ++j) + for (int j = 0; j < chain.Nstrings; ++j) for (int alpha = 0; alpha < base[j]; ++alpha) { diffsq += pow(BE[j][alpha], 2.0); if (pow(BE[j][alpha], 2.0)/chain.Nsites > maxterm) { @@ -1144,7 +1143,7 @@ namespace JSC { { //DP lambda_old; for (int j = 0; j < chain.Nstrings; ++j) { - for (int alpha = 0; alpha < base[j]; ++alpha) + for (int alpha = 0; alpha < base[j]; ++alpha) { //lambda_old = lambda[j][alpha]; lambda[j][alpha] = Iterate_BAE (j, alpha); @@ -1155,7 +1154,7 @@ namespace JSC { iter++; - (*this).Compute_BE(); + (*this).Compute_BE(); (*this).Compute_diffsq(); } @@ -1164,8 +1163,8 @@ namespace JSC { // Re-solves for all rapidities lambda[j][alpha] such that BE[j][alpha]^2/N > max_allowed. // Assumes that BE[][] is up-to-date. - for (int j = 0; j < chain.Nstrings; ++j) - for (int alpha = 0; alpha < base[j]; ++alpha) + for (int j = 0; j < chain.Nstrings; ++j) + for (int alpha = 0; alpha < base[j]; ++alpha) if (pow(BE[j][alpha], 2.0)/chain.Nsites > max_allowed) (*this).Solve_BAE (j, alpha, max_allowed, 100); } @@ -1199,7 +1198,7 @@ namespace JSC { (*this).Build_Reduced_Gaudin_Matrix (Gaudin); int index = 0; - for (int j = 0; j < chain.Nstrings; ++j) + for (int j = 0; j < chain.Nstrings; ++j) for (int alpha = 0; alpha < base[j]; ++alpha) { dlambda[index] = - BE[j][alpha] * chain.Nsites; index++; @@ -1223,7 +1222,7 @@ namespace JSC { for (int i = 0; i < base.Nraptot; ++i) if (fabs(real(dlambda[i])) > 1.0) dlambda[i] = 0.0;//(real(dlambda[i]) > 0) ? 1.0 : -1.0; index = 0; - for (int j = 0; j < chain.Nstrings; ++j) + for (int j = 0; j < chain.Nstrings; ++j) for (int alpha = 0; alpha < base[j]; ++alpha) { lambda[j][alpha] = lambda_ref[j][alpha] + real(dlambda[index]); //cout << j << "\t" << alpha << "\t" << dlambda[index] << "\t" << lambda_ref[j][alpha] << "\t" << lambda[j][alpha] << endl; @@ -1272,7 +1271,7 @@ namespace JSC { diffsq = 1.0; - if (reset_rapidities) + if (reset_rapidities) (*this).Set_Free_lambdas(); (*this).Compute_BE(); @@ -1299,9 +1298,9 @@ namespace JSC { interp_start = clock(); iter_interp_start = iter; diffsq_interp_start = diffsq; - + if (diffsq > iter_prec) (*this).Solve_BAE_interp (iter_prec, 10); - + interp_stop = clock(); iter_interp_stop = iter; diffsq_interp_stop = diffsq; @@ -1310,7 +1309,7 @@ namespace JSC { //cout << "Interp: iter " << iter << "\tdiffsq " << diffsq << endl; - } while (diffsq > chain.prec && !is_nan(diffsq) && diffsq_interp_stop/diffsq_interp_start < 0.001); + } while (diffsq > chain.prec && !is_nan(diffsq) && diffsq_interp_stop/diffsq_interp_start < 0.001); // If we haven't even reached iter_prec, try normal iterations without extrapolations @@ -1348,10 +1347,10 @@ namespace JSC { } iter_prec *= 1.0e-4; - iter_prec = JSC::max(iter_prec, chain.prec); + iter_prec = ABACUS::max(iter_prec, chain.prec); } - + // Check convergence: //cout << "Check_Rapidities: " << (*this).Check_Rapidities() << endl; @@ -1388,7 +1387,7 @@ namespace JSC { for (int j = 0; j < chain.Nstrings; ++j) for (int alpha = 0; alpha < base[j]; ++alpha) lambda[j][alpha] = lambda_ref[j][alpha]; diffsq = diffsq_ref; } - + return; } @@ -1413,7 +1412,7 @@ namespace JSC { (*this).Iterate_BAE(); iter_done_here++; } - + if ((diffsq > diffsq_ref)) { // This procedure has failed. We reset everything to begin values. for (int j = 0; j < chain.Nstrings; ++j) for (int alpha = 0; alpha < base[j]; ++alpha) lambda[j][alpha] = lambda_ref[j][alpha]; @@ -1474,7 +1473,7 @@ namespace JSC { rap[3] = lambda4[j][alpha]; //rap[4] = lambda5[j][alpha]; - polint (oneoverP, rap, 0.0, lambda[j][alpha], deltalambda); + polint (oneoverP, rap, 0.0, lambda[j][alpha], deltalambda); //cout << j << "\t" << alpha << "\t" << rap << "\t" << lambda[j][alpha] << "\t" << deltalambda << endl; } @@ -1558,7 +1557,7 @@ namespace JSC { { if (iKboost == 0) return(true); // done - ODSLF_Ix2_Offsets offsets_here = offsets; + ODSLF_Ix2_Offsets offsets_here = offsets; bool success = false; @@ -1578,8 +1577,8 @@ namespace JSC { { // sends all the state data to output stream - s << endl << "******** Chain with Nsites = " << state.chain.Nsites << " Mdown (nr fermions) = " << state.base.Mdown - << ": eigenstate with base_id " << state.base_id << ", type_id " << state.type_id + s << endl << "******** Chain with Nsites = " << state.chain.Nsites << " Mdown (nr fermions) = " << state.base.Mdown + << ": eigenstate with base_id " << state.base_id << ", type_id " << state.type_id << " id " << state.id << " maxid " << state.offsets.maxid << endl << "E = " << state.E << " K = " << state.K << " iK = " << state.iK << " lnnorm = " << state.lnnorm << endl << "conv = " << state.conv << " iter = " << state.iter << " iter_Newton = " << state.iter_Newton << "\tdiffsq " << state.diffsq << endl; @@ -1613,4 +1612,4 @@ namespace JSC { -} // namespace JSC +} // namespace ABACUS diff --git a/src/ODSLF/ODSLF_Chem_Pot.cc b/src/ODSLF/ODSLF_Chem_Pot.cc index 4c304ae..b29dc13 100644 --- a/src/ODSLF/ODSLF_Chem_Pot.cc +++ b/src/ODSLF/ODSLF_Chem_Pot.cc @@ -1,8 +1,8 @@ /********************************************************** -This software is part of J.-S. Caux's ABACUS++ library. +This software is part of J.-S. Caux's ABACUS library. -Copyright (c) +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -10,20 +10,19 @@ File: src/ODSLF/ODSLF_Chem_Pot.cc Purpose: calculates the chemical potential. - ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" -namespace JSC { +namespace ABACUS { /* DP Ezero (DP Delta, int N, int M) { // Returns the energy of the ground state with M down spins - if (M < 0 || M > N/2) JSCerror("M out of bounds in Ezero."); - + if (M < 0 || M > N/2) ABACUSerror("M out of bounds in Ezero."); + DP E = -1.0; // sentinel value if (M == 0) E = N * Delta/4.0; @@ -31,13 +30,13 @@ namespace JSC { else { Heis_Chain BD1(1.0, Delta, 0.0, N); - + Vect_INT Nrapidities_groundstate(0, BD1.Nstrings); - + Nrapidities_groundstate[0] = M; - + ODSLF_Base baseconfig_groundstate(BD1, Nrapidities_groundstate); - + if ((Delta > 0.0) && (Delta < 1.0)) { ODSLF_XXZ_Bethe_State groundstate(BD1, baseconfig_groundstate); groundstate.Compute_All(true); @@ -49,14 +48,14 @@ namespace JSC { groundstate.Compute_All(true); E = groundstate.E; } - + else if (Delta > 1.0) { XXZ_gpd_Bethe_State groundstate(BD1, baseconfig_groundstate); groundstate.Compute_All(true); E = groundstate.E; } - else JSCerror("Anisotropy out of bounds in Ezero."); + else ABACUSerror("Anisotropy out of bounds in Ezero."); } return(E); @@ -68,7 +67,7 @@ namespace JSC { DP H = 0.0; - if (2*M == N) H = 0.0; + if (2*M == N) H = 0.0; else if (Delta <= 1.0) H = Ezero (Delta, N, M - 1) - Ezero (Delta, N, M); @@ -79,7 +78,7 @@ namespace JSC { { if (M < 0 || M > N/2 - 1) { cout << "M = " << M << endl; - JSCerror("M out of bounds in HZmin."); + ABACUSerror("M out of bounds in HZmin."); } if (Ezero_ref[M] == -1.0) Ezero_ref[M] = Ezero(Delta, N, M); @@ -92,7 +91,7 @@ namespace JSC { { // Returns the value of M for given field HZ - if (HZ < 0.0) JSCerror("Please use a positive field in M_vs_H."); + if (HZ < 0.0) ABACUSerror("Please use a positive field in M_vs_H."); else if (HZ == 0.0) return(N/2); @@ -110,7 +109,7 @@ namespace JSC { if (HZ >= 1.0 + Delta) M_actual = 0; // saturation else { - + HZmin_actual = HZmin (Delta, N, M_actual, Ezero); HZmax_actual = HZmin (Delta, N, M_actual - 1, Ezero); @@ -118,15 +117,15 @@ namespace JSC { if (HZmin_actual > HZ) M_actual += M_step; else if (HZmax_actual <= HZ) M_actual -= M_step; - + M_step = (M_step + 1)/2; HZmin_actual = HZmin (Delta, N, M_actual, Ezero); HZmax_actual = HZmin (Delta, N, M_actual - 1, Ezero); - M_found = (HZmin_actual < HZ && HZ <= HZmax_actual); + M_found = (HZmin_actual < HZ && HZ <= HZmax_actual); - //cout << "M_actual = " << M_actual << "\tM_step = " << M_step + //cout << "M_actual = " << M_actual << "\tM_step = " << M_step // << "\tHZmin_actual = " << HZmin_actual << "\tHZmax_actual = " << HZmax_actual << "\tHZ = " << HZ << "\t" << M_found << endl; } } diff --git a/src/ODSLF/ODSLF_Matrix_Element_Contrib.cc b/src/ODSLF/ODSLF_Matrix_Element_Contrib.cc index 1f18729..c87fbfe 100644 --- a/src/ODSLF/ODSLF_Matrix_Element_Contrib.cc +++ b/src/ODSLF/ODSLF_Matrix_Element_Contrib.cc @@ -1,8 +1,8 @@ /********************************************************** -This software is part of J.-S. Caux's ABACUS++ library. +This software is part of J.-S. Caux's ABACUS library. -Copyright (c) +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -10,15 +10,14 @@ File: src/ODSLF/ODSLF_Matrix_Element_Contrib.cc Purpose: handles the generic call for a matrix element. - ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -namespace JSC { +namespace ABACUS { //DP Compute_Matrix_Element_Contrib (char whichDSF, bool fixed_iK, ODSLF_XXZ_Bethe_State& LeftState, //ODSLF_XXZ_Bethe_State& RefState, DP Chem_Pot, fstream& DAT_outfile) @@ -46,7 +45,7 @@ namespace JSC { } else if (whichDSF == 'p') ME = exp(real(ln_Smin_ME (LeftState, RefState))); - else JSCerror("Wrong whichDSF in Compute_Matrix_Element_Contrib."); + else ABACUSerror("Wrong whichDSF in Compute_Matrix_Element_Contrib."); if (is_nan(ME)) ME = 0.0; @@ -85,4 +84,4 @@ namespace JSC { } -} // namespace JSC +} // namespace ABACUS diff --git a/src/ODSLF/ODSLF_Sumrules.cc b/src/ODSLF/ODSLF_Sumrules.cc index aee87a2..3a8480f 100644 --- a/src/ODSLF/ODSLF_Sumrules.cc +++ b/src/ODSLF/ODSLF_Sumrules.cc @@ -1,8 +1,8 @@ /********************************************************** -This software is part of J.-S. Caux's ABACUS++ library. +This software is part of J.-S. Caux's ABACUS library. -Copyright (c) +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -10,15 +10,14 @@ File: src/ODSLF/ODSLF_Sumrules.cc Purpose: defines sumrule factors for spinless fermions related to Heisenberg - ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" -using namespace JSC; +using namespace ABACUS; using namespace std; -namespace JSC { +namespace ABACUS { DP ODSLF_X_avg (char xyorz, DP Delta, int N, int M) @@ -26,27 +25,27 @@ namespace JSC { // Calculates \sum_j < S_j^a S_{j+1}^a >, a = x, y or z. DP eps_Delta = 0.00000001; - + // Define the chain: J, Delta, h, Nsites Heis_Chain chain(1.0, Delta, 0.0, N); - + // Define the base: chain, Mdown ODSLF_Base gbase(chain, M); // Define the chain: J, Delta, h, Nsites Heis_Chain chain2(1.0, Delta + eps_Delta, 0.0, N); - + // Define the base: chain, Mdown ODSLF_Base gbase2(chain2, M); - + DP E0_Delta = 0.0; - DP E0_Delta_eps = 0.0; + DP E0_Delta_eps = 0.0; if (Delta > 0.0 && Delta < 1.0) { // Define the ground state ODSLF_XXZ_Bethe_State gstate(chain, gbase); - + // Compute everything about the ground state gstate.Compute_All(true); @@ -54,7 +53,7 @@ namespace JSC { // Define the ground state ODSLF_XXZ_Bethe_State gstate2(chain2, gbase2); - + // Compute everything about the ground state gstate2.Compute_All(true); @@ -64,7 +63,7 @@ namespace JSC { else if (Delta == 1.0) { // Define the ground state XXX_Bethe_State gstate(chain, gbase); - + // Compute everything about the ground state gstate.Compute_All(true); @@ -72,7 +71,7 @@ namespace JSC { // Define the ground state XXZ_gpd_Bethe_State gstate2(chain2, gbase2); // need XXZ_gpd here - + // Compute everything about the ground state gstate2.Compute_All(true); @@ -82,7 +81,7 @@ namespace JSC { else if (Delta > 1.0) { // Define the ground state XXZ_gpd_Bethe_State gstate(chain, gbase); - + // Compute everything about the ground state gstate.Compute_All(true); @@ -90,14 +89,14 @@ namespace JSC { // Define the ground state XXZ_gpd_Bethe_State gstate2(chain2, gbase2); - + // Compute everything about the ground state gstate2.Compute_All(true); E0_Delta_eps = gstate2.E; } */ - else JSCerror("Wrong anisotropy in ODSLF_S1_sumrule_factor."); + else ABACUSerror("Wrong anisotropy in ODSLF_S1_sumrule_factor."); DP answer = 0.0; if (xyorz == 'x' || xyorz == 'y') answer = 0.5 * (E0_Delta - Delta * (E0_Delta_eps - E0_Delta)/eps_Delta); @@ -105,7 +104,7 @@ namespace JSC { // Careful for z ! Hamiltonian defined as S^z S^z - 1/4, so add back N/4: else if (xyorz == 'z') answer = (E0_Delta_eps - E0_Delta)/eps_Delta + 0.25 * N; - else JSCerror("option not implemented in ODSLF_X_avg."); + else ABACUSerror("option not implemented in ODSLF_X_avg."); return(answer); } @@ -126,7 +125,7 @@ namespace JSC { else if (mporz == 'a') sumrule = 1.0; else if (mporz == 'b') sumrule = 1.0; - else JSCerror("option not implemented in ODSLF_S1_sumrule_factor."); + else ABACUSerror("option not implemented in ODSLF_S1_sumrule_factor."); //return(1.0/sumrule); return(1.0/(sumrule + 1.0e-16)); // sumrule is 0 for iK == 0 or N @@ -148,7 +147,7 @@ namespace JSC { else if (mporz == 'a') sumrule = 1.0; else if (mporz == 'b') sumrule = 1.0; - else JSCerror("option not implemented in ODSLF_S1_sumrule_factor."); + else ABACUSerror("option not implemented in ODSLF_S1_sumrule_factor."); //return(1.0/sumrule); return(1.0/(sumrule + 1.0e-16)); // sumrule is 0 for iK == 0 or N @@ -161,7 +160,7 @@ namespace JSC { //if (!fixed_iK) { if (iKmin != iKmax) { if (whichDSF == 'Z') sumrule_factor = 1.0; - else if (whichDSF == 'm') + else if (whichDSF == 'm') sumrule_factor = 1.0/RefState.base.Mdown; else if (whichDSF == 'z') sumrule_factor = 1.0/(0.25 * RefState.chain.Nsites); else if (whichDSF == 'p') sumrule_factor = 1.0/(RefState.chain.Nsites - RefState.base.Mdown); @@ -169,32 +168,32 @@ namespace JSC { else if (whichDSF == 'b') sumrule_factor = 1.0; else if (whichDSF == 'q') sumrule_factor = 1.0; - else JSCerror("whichDSF option not consistent in Sumrule_Factor"); + else ABACUSerror("whichDSF option not consistent in Sumrule_Factor"); } //else if (fixed_iK) { else if (iKmin == iKmax) { if (whichDSF == 'Z') sumrule_factor = 1.0; - else if (whichDSF == 'm' || whichDSF == 'z' || whichDSF == 'p') + else if (whichDSF == 'm' || whichDSF == 'z' || whichDSF == 'p') //sumrule_factor = S1_sumrule_factor (whichDSF, RefState.chain.Delta, RefState.chain.Nsites, RefState.base.Mdown, iKneeded); sumrule_factor = ODSLF_S1_sumrule_factor (whichDSF, RefState.chain.Delta, RefState.chain.Nsites, RefState.base.Mdown, iKmax); else if (whichDSF == 'a') sumrule_factor = 1.0; else if (whichDSF == 'b') sumrule_factor = 1.0; else if (whichDSF == 'q') sumrule_factor = 1.0; - - else JSCerror("whichDSF option not consistent in Sumrule_Factor"); + + else ABACUSerror("whichDSF option not consistent in Sumrule_Factor"); } - + return(sumrule_factor); } - + //void Evaluate_F_Sumrule (char whichDSF, const ODSLF_Bethe_State& RefState, DP Chem_Pot, int iKmin, int iKmax, const char* FFsq_Cstr, const char* FSR_Cstr) void Evaluate_F_Sumrule (string prefix, char whichDSF, const ODSLF_Bethe_State& RefState, DP Chem_Pot, int iKmin, int iKmax) { stringstream RAW_stringstream; string RAW_string; - RAW_stringstream << prefix << ".raw"; + RAW_stringstream << prefix << ".raw"; RAW_string = RAW_stringstream.str(); const char* RAW_Cstr = RAW_string.c_str(); stringstream FSR_stringstream; string FSR_string; @@ -203,11 +202,11 @@ namespace JSC { ifstream infile; infile.open(RAW_Cstr); - if(infile.fail()) JSCerror("Could not open input file in Evaluate_F_Sumrule(ODSLF...)."); + if(infile.fail()) ABACUSerror("Could not open input file in Evaluate_F_Sumrule(ODSLF...)."); // We run through the data file to chech the f sumrule at each positive momenta: - //Vect Sum_omega_FFsq(0.0, RefState.chain.Nsites/2 + 1); // - Vect Sum_omega_FFsq(0.0, iKmax - iKmin + 1); // + //Vect Sum_omega_FFsq(0.0, RefState.chain.Nsites/2 + 1); // + Vect Sum_omega_FFsq(0.0, iKmax - iKmin + 1); // DP omega, FF; int iK, conv; @@ -229,7 +228,7 @@ namespace JSC { DP X_z = X_avg ('z', RefState.chain.Delta, RefState.chain.Nsites, RefState.base.Mdown); /* - outfile << 0 << "\t" << Sum_omega_FFsq[0] * S1_sumrule_factor (whichDSF, RefState.chain.Delta, RefState.chain.Nsites, X_x, X_z, 0); + outfile << 0 << "\t" << Sum_omega_FFsq[0] * S1_sumrule_factor (whichDSF, RefState.chain.Delta, RefState.chain.Nsites, X_x, X_z, 0); for (int i = 1; i <= RefState.chain.Nsites/2; ++i) outfile << endl << i << "\t" << Sum_omega_FFsq[i] * S1_sumrule_factor (whichDSF, RefState.chain.Delta, RefState.chain.Nsites, X_x, X_z, i); */ @@ -242,4 +241,4 @@ namespace JSC { outfile.close(); } -} // namespace JSC +} // namespace ABACUS diff --git a/src/ODSLF/ODSLF_XXZ_Bethe_State.cc b/src/ODSLF/ODSLF_XXZ_Bethe_State.cc index 009ec79..c38e3bc 100644 --- a/src/ODSLF/ODSLF_XXZ_Bethe_State.cc +++ b/src/ODSLF/ODSLF_XXZ_Bethe_State.cc @@ -1,17 +1,22 @@ -/**************************************************************** +/********************************************************** -ODSLF_XXZ_Bethe_State.cc +This software is part of J.-S. Caux's ABACUS library. -Defines all functions for ODSLF_XXZ_Bethe_State +Copyright (c) J.-S. Caux. +----------------------------------------------------------- -******************************************************************/ +File: src/ODSLF/ODSLF_XXZ_Bethe_State.cc -#include "JSC.h" +Purpose: defines Bethe states for 1d spinless fermions. + +***********************************************************/ + +#include "ABACUS.h" using namespace std; -namespace JSC { +namespace ABACUS { // Function prototypes @@ -25,12 +30,12 @@ namespace JSC { // Function definitions: class ODSLF_XXZ_Bethe_State - ODSLF_XXZ_Bethe_State::ODSLF_XXZ_Bethe_State () - : ODSLF_Bethe_State(), sinhlambda(ODSLF_Lambda(chain, 1)), coshlambda(ODSLF_Lambda(chain, 1)), tanhlambda(ODSLF_Lambda(chain, 1)) + ODSLF_XXZ_Bethe_State::ODSLF_XXZ_Bethe_State () + : ODSLF_Bethe_State(), sinhlambda(ODSLF_Lambda(chain, 1)), coshlambda(ODSLF_Lambda(chain, 1)), tanhlambda(ODSLF_Lambda(chain, 1)) {}; ODSLF_XXZ_Bethe_State::ODSLF_XXZ_Bethe_State (const ODSLF_XXZ_Bethe_State& RefState) // copy constructor - : ODSLF_Bethe_State(RefState), sinhlambda(ODSLF_Lambda(RefState.chain, RefState.base)), coshlambda(ODSLF_Lambda(RefState.chain, RefState.base)), + : ODSLF_Bethe_State(RefState), sinhlambda(ODSLF_Lambda(RefState.chain, RefState.base)), coshlambda(ODSLF_Lambda(RefState.chain, RefState.base)), tanhlambda(ODSLF_Lambda(RefState.chain, RefState.base)) { // copy arrays into new ones @@ -45,29 +50,29 @@ namespace JSC { } //cout << "Done calling XXZ state copy constructor." << endl; } - - ODSLF_XXZ_Bethe_State::ODSLF_XXZ_Bethe_State (const Heis_Chain& RefChain, int M) - : ODSLF_Bethe_State(RefChain, M), + + ODSLF_XXZ_Bethe_State::ODSLF_XXZ_Bethe_State (const Heis_Chain& RefChain, int M) + : ODSLF_Bethe_State(RefChain, M), sinhlambda(ODSLF_Lambda(RefChain, M)), coshlambda(ODSLF_Lambda(RefChain, M)), tanhlambda(ODSLF_Lambda(RefChain, M)) { //cout << "Here in XXZ BS constructor." << endl; //cout << (*this).lambda[0][0] << endl; //cout << "OK" << endl; - if ((RefChain.Delta <= -1.0) || (RefChain.Delta >= 1.0)) JSCerror("Delta out of range in ODSLF_XXZ_Bethe_State constructor"); + if ((RefChain.Delta <= -1.0) || (RefChain.Delta >= 1.0)) ABACUSerror("Delta out of range in ODSLF_XXZ_Bethe_State constructor"); } - - ODSLF_XXZ_Bethe_State::ODSLF_XXZ_Bethe_State (const Heis_Chain& RefChain, const ODSLF_Base& RefBase) - : ODSLF_Bethe_State(RefChain, RefBase), + + ODSLF_XXZ_Bethe_State::ODSLF_XXZ_Bethe_State (const Heis_Chain& RefChain, const ODSLF_Base& RefBase) + : ODSLF_Bethe_State(RefChain, RefBase), sinhlambda(ODSLF_Lambda(RefChain, RefBase)), coshlambda(ODSLF_Lambda(RefChain, RefBase)), tanhlambda(ODSLF_Lambda(RefChain, RefBase)) { - if ((RefChain.Delta <= -1.0) || (RefChain.Delta >= 1.0)) JSCerror("Delta out of range in ODSLF_XXZ_Bethe_State constructor"); + if ((RefChain.Delta <= -1.0) || (RefChain.Delta >= 1.0)) ABACUSerror("Delta out of range in ODSLF_XXZ_Bethe_State constructor"); } ODSLF_XXZ_Bethe_State::ODSLF_XXZ_Bethe_State (const Heis_Chain& RefChain, long long int base_id_ref, long long int type_id_ref) : ODSLF_Bethe_State(RefChain, base_id_ref, type_id_ref), sinhlambda(ODSLF_Lambda(chain, base)), coshlambda(ODSLF_Lambda(chain, base)), tanhlambda(ODSLF_Lambda(chain, base)) { - if ((RefChain.Delta <= -1.0) || (RefChain.Delta >= 1.0)) JSCerror("Delta out of range in ODSLF_XXZ_Bethe_State constructor"); + if ((RefChain.Delta <= -1.0) || (RefChain.Delta >= 1.0)) ABACUSerror("Delta out of range in ODSLF_XXZ_Bethe_State constructor"); } @@ -114,13 +119,13 @@ namespace JSC { if(chain.par[i] == 1) lambda[i][alpha] = (tan(chain.Str_L[i] * 0.5 * chain.anis) * tan(PI * 0.5 * Ix2[i][alpha]/chain.Nsites)); else if (chain.par[i] == -1) lambda[i][alpha] = (-tan((PI * 0.5 * Ix2[i][alpha])/chain.Nsites)/tan(chain.Str_L[i] * 0.5 * chain.anis)); - else JSCerror("Invalid parities in Set_Free_lambdas."); + else ABACUSerror("Invalid parities in Set_Free_lambdas."); // if (lambda[i][alpha] == 0.0) lambda[i][alpha] = 0.001 * (1.0 + i) * (1.0 + alpha) / chain.Nsites; // some arbitrary starting point here... } } - + return; } @@ -153,7 +158,7 @@ namespace JSC { bool ODSLF_XXZ_Bethe_State::Check_Admissibility(char option) { - // This function checks the admissibility of the Ix2's of a state: + // This function checks the admissibility of the Ix2's of a state: // returns false if there are higher strings with Ix2 = 0, a totally symmetric distribution of I's at each level, // and strings of equal length modulo 2 and parity with Ix2 = 0, meaning at least two equal roots in BAE. @@ -163,9 +168,9 @@ namespace JSC { bool higher_string_on_zero = false; for (int j = 0; j < chain.Nstrings; ++j) { // The following line puts answer to true if there is at least one higher string with zero Ix2 - for (int alpha = 0; alpha < base[j]; ++alpha) if ((Ix2[j][alpha] == 0) && (chain.Str_L[j] >= 2) /*&& !(chain.Str_L[j] % 2)*/) - higher_string_on_zero = true; - for (int alpha = 0; alpha < base[j]; ++alpha) if (Ix2[j][alpha] == 0) Zero_at_level[j] = true; + for (int alpha = 0; alpha < base[j]; ++alpha) if ((Ix2[j][alpha] == 0) && (chain.Str_L[j] >= 2) /*&& !(chain.Str_L[j] % 2)*/) + higher_string_on_zero = true; + for (int alpha = 0; alpha < base[j]; ++alpha) if (Ix2[j][alpha] == 0) Zero_at_level[j] = true; // NOTE: if base[j] == 0, Zero_at_level[j] remains false. } @@ -176,12 +181,12 @@ namespace JSC { bool string_coincidence = false; for (int j1 = 0; j1 < chain.Nstrings; ++j1) { for (int j2 = j1 + 1; j2 < chain.Nstrings; ++j2) - if (Zero_at_level[j1] && Zero_at_level[j2] && (chain.par[j1] == chain.par[j2]) && (!((chain.Str_L[j1] + chain.Str_L[j2])%2))) + if (Zero_at_level[j1] && Zero_at_level[j2] && (chain.par[j1] == chain.par[j2]) && (!((chain.Str_L[j1] + chain.Str_L[j2])%2))) string_coincidence = true; } bool M_odd_and_onep_on_zero = false; - if (option == 'z') { // for Sz, if M is odd, exclude symmetric states with a 1+ on zero + if (option == 'z') { // for Sz, if M is odd, exclude symmetric states with a 1+ on zero // (zero rapidities in left and right states, so FF det not defined). bool is_ground_state = base.Nrap[0] == base.Mdown && Ix2[0][0] == -(base.Mdown - 1) && Ix2[0][base.Mdown-1] == base.Mdown - 1; if (Zero_at_level[0] && (base.Mdown % 2) && !is_ground_state) M_odd_and_onep_on_zero = true; @@ -196,8 +201,8 @@ namespace JSC { // Now check that no Ix2 is equal to +N (since we take -N into account, and I + N == I by periodicity of exp) - for (int j = 0; j < chain.Nstrings; ++j) - for (int alpha = 0; alpha < base[j]; ++alpha) if ((Ix2[j][alpha] < -chain.Nsites) || (Ix2[j][alpha] >= chain.Nsites)) answer = false; + for (int j = 0; j < chain.Nstrings; ++j) + for (int alpha = 0; alpha < base[j]; ++alpha) if ((Ix2[j][alpha] < -chain.Nsites) || (Ix2[j][alpha] >= chain.Nsites)) answer = false; if (!answer) { E = 0.0; @@ -217,18 +222,18 @@ namespace JSC { DP sumtheta = 0.0; - for (int k = 0; k < chain.Nstrings; ++k) + for (int k = 0; k < chain.Nstrings; ++k) for (int beta = 0; beta < base[k]; ++beta) { - if ((chain.Str_L[j] == 1) && (chain.Str_L[k] == 1)) - sumtheta += (chain.par[j] == chain.par[k]) - ? atan((tanhlambda[j][alpha] - tanhlambda[k][beta])/((1.0 - tanhlambda[j][alpha] * tanhlambda[k][beta]) * chain.ta_n_anis_over_2[2])) - : - atan(((tanhlambda[j][alpha] - tanhlambda[k][beta])/(1.0 - tanhlambda[j][alpha] * tanhlambda[k][beta])) * chain.ta_n_anis_over_2[2]) ; - else sumtheta += 0.5 * ODSLF_Theta_XXZ((tanhlambda[j][alpha] - tanhlambda[k][beta])/(1.0 - tanhlambda[j][alpha] * tanhlambda[k][beta]), + if ((chain.Str_L[j] == 1) && (chain.Str_L[k] == 1)) + sumtheta += (chain.par[j] == chain.par[k]) + ? atan((tanhlambda[j][alpha] - tanhlambda[k][beta])/((1.0 - tanhlambda[j][alpha] * tanhlambda[k][beta]) * chain.ta_n_anis_over_2[2])) + : - atan(((tanhlambda[j][alpha] - tanhlambda[k][beta])/(1.0 - tanhlambda[j][alpha] * tanhlambda[k][beta])) * chain.ta_n_anis_over_2[2]) ; + else sumtheta += 0.5 * ODSLF_Theta_XXZ((tanhlambda[j][alpha] - tanhlambda[k][beta])/(1.0 - tanhlambda[j][alpha] * tanhlambda[k][beta]), chain.Str_L[j], chain.Str_L[k], chain.par[j], chain.par[k], chain.ta_n_anis_over_2); } sumtheta *= 2.0; - - BE[j][alpha] = ((chain.par[j] == 1) ? 2.0 * atan(tanhlambda[j][alpha]/chain.ta_n_anis_over_2[chain.Str_L[j]]) + + BE[j][alpha] = ((chain.par[j] == 1) ? 2.0 * atan(tanhlambda[j][alpha]/chain.ta_n_anis_over_2[chain.Str_L[j]]) : -2.0 * atan(tanhlambda[j][alpha] * chain.ta_n_anis_over_2[chain.Str_L[j]])) - (sumtheta + PI*Ix2[j][alpha])/chain.Nsites; } @@ -241,22 +246,22 @@ namespace JSC { DP sumtheta = 0.0; - for (int j = 0; j < chain.Nstrings; ++j) + for (int j = 0; j < chain.Nstrings; ++j) for (int alpha = 0; alpha < base[j]; ++alpha) { - + sumtheta = 0.0; - for (int k = 0; k < chain.Nstrings; ++k) + for (int k = 0; k < chain.Nstrings; ++k) for (int beta = 0; beta < base[k]; ++beta) { - if ((chain.Str_L[j] == 1) && (chain.Str_L[k] == 1)) - sumtheta += (chain.par[j] == chain.par[k]) - ? atan((tanhlambda[j][alpha] - tanhlambda[k][beta])/((1.0 - tanhlambda[j][alpha] * tanhlambda[k][beta]) * chain.ta_n_anis_over_2[2])) - : - atan(((tanhlambda[j][alpha] - tanhlambda[k][beta])/(1.0 - tanhlambda[j][alpha] * tanhlambda[k][beta])) * chain.ta_n_anis_over_2[2]) ; - else sumtheta += 0.5 * ODSLF_Theta_XXZ((tanhlambda[j][alpha] - tanhlambda[k][beta])/(1.0 - tanhlambda[j][alpha] * tanhlambda[k][beta]), + if ((chain.Str_L[j] == 1) && (chain.Str_L[k] == 1)) + sumtheta += (chain.par[j] == chain.par[k]) + ? atan((tanhlambda[j][alpha] - tanhlambda[k][beta])/((1.0 - tanhlambda[j][alpha] * tanhlambda[k][beta]) * chain.ta_n_anis_over_2[2])) + : - atan(((tanhlambda[j][alpha] - tanhlambda[k][beta])/(1.0 - tanhlambda[j][alpha] * tanhlambda[k][beta])) * chain.ta_n_anis_over_2[2]) ; + else sumtheta += 0.5 * ODSLF_Theta_XXZ((tanhlambda[j][alpha] - tanhlambda[k][beta])/(1.0 - tanhlambda[j][alpha] * tanhlambda[k][beta]), chain.Str_L[j], chain.Str_L[k], chain.par[j], chain.par[k], chain.ta_n_anis_over_2); } sumtheta *= 2.0; - - BE[j][alpha] = ((chain.par[j] == 1) ? 2.0 * atan(tanhlambda[j][alpha]/chain.ta_n_anis_over_2[chain.Str_L[j]]) + + BE[j][alpha] = ((chain.par[j] == 1) ? 2.0 * atan(tanhlambda[j][alpha]/chain.ta_n_anis_over_2[chain.Str_L[j]]) : -2.0 * atan(tanhlambda[j][alpha] * chain.ta_n_anis_over_2[chain.Str_L[j]])) - (sumtheta + PI*Ix2[j][alpha])/chain.Nsites; //if (is_nan(BE[j][alpha])) cout << "BE nan: " << j << "\t" << alpha << "\t" << lambda[j][alpha] << "\t" << tanhlambda[j][alpha] << endl; @@ -265,55 +270,55 @@ namespace JSC { DP ODSLF_XXZ_Bethe_State::Iterate_BAE (int j, int alpha) { - // Returns a new iteration value for lambda[j][alpha] given tanhlambda and BE Lambdas + // Returns a new iteration value for lambda[j][alpha] given tanhlambda and BE Lambdas // Assumes that tanhlambda[][] and BE[][] have been computed. DP new_lambda = 0.0; DP arg = 0.0; - if (chain.par[j] == 1) arg = chain.ta_n_anis_over_2[chain.Str_L[j]] - * tan(0.5 * + if (chain.par[j] == 1) arg = chain.ta_n_anis_over_2[chain.Str_L[j]] + * tan(0.5 * //(PI * Ix2[j][alpha] + sumtheta)/chain.Nsites (2.0 * atan(tanhlambda[j][alpha]/chain.ta_n_anis_over_2[chain.Str_L[j]]) - BE[j][alpha]) ); - - else if (chain.par[j] == -1) arg = -tan(0.5 * + + else if (chain.par[j] == -1) arg = -tan(0.5 * //(PI * Ix2[j][alpha] + sumtheta)/chain.Nsites) (-2.0 * atan(tanhlambda[j][alpha] * chain.ta_n_anis_over_2[chain.Str_L[j]]) - BE[j][alpha])) /chain.ta_n_anis_over_2[chain.Str_L[j]]; - + if (fabs(arg) < 1.0) { new_lambda = atanh(arg); } - + else { new_lambda = lambda[j][alpha]; // back to drawing board... - int block = 0; // counter to prevent runaway while loop + int block = 0; // counter to prevent runaway while loop DP new_tanhlambda = 0.0; DP sumtheta = 0.0; - arg = 10.0; // reset value to start while loop + arg = 10.0; // reset value to start while loop while ((fabs(arg) > 1.0) && (block++ < 100)) { // recompute the diverging root on its own... new_lambda *= 1.01; // try to go slowly towards infinity... new_tanhlambda = tanh(new_lambda); sumtheta = 0.0; for (int k = 0; k < chain.Nstrings; ++k) { - for (int beta = 0; beta < base[k]; ++beta) - if ((chain.Str_L[j] == 1) && (chain.Str_L[k] == 1)) - sumtheta += (chain.par[j] == chain.par[k]) - ? atan((new_tanhlambda - tanhlambda[k][beta])/((1.0 - new_tanhlambda * tanhlambda[k][beta]) * chain.ta_n_anis_over_2[2])) - : - atan(((new_tanhlambda - tanhlambda[k][beta])/(1.0 - new_tanhlambda * tanhlambda[k][beta])) * chain.ta_n_anis_over_2[2]) ; - else sumtheta += 0.5 * ODSLF_Theta_XXZ((new_tanhlambda - tanhlambda[k][beta])/(1.0 - new_tanhlambda * tanhlambda[k][beta]), + for (int beta = 0; beta < base[k]; ++beta) + if ((chain.Str_L[j] == 1) && (chain.Str_L[k] == 1)) + sumtheta += (chain.par[j] == chain.par[k]) + ? atan((new_tanhlambda - tanhlambda[k][beta])/((1.0 - new_tanhlambda * tanhlambda[k][beta]) * chain.ta_n_anis_over_2[2])) + : - atan(((new_tanhlambda - tanhlambda[k][beta])/(1.0 - new_tanhlambda * tanhlambda[k][beta])) * chain.ta_n_anis_over_2[2]) ; + else sumtheta += 0.5 * ODSLF_Theta_XXZ((new_tanhlambda - tanhlambda[k][beta])/(1.0 - new_tanhlambda * tanhlambda[k][beta]), chain.Str_L[j], chain.Str_L[k], chain.par[j], chain.par[k], chain.ta_n_anis_over_2); } sumtheta *= 2.0; if (chain.par[j] == 1) arg = chain.ta_n_anis_over_2[chain.Str_L[j]] * tan(0.5 * (PI * Ix2[j][alpha] + sumtheta)/chain.Nsites); - + else if (chain.par[j] == -1) arg = -tan(0.5 * (PI * Ix2[j][alpha] + sumtheta)/chain.Nsites)/chain.ta_n_anis_over_2[chain.Str_L[j]]; - - else JSCerror("Invalid parities in Iterate_BAE."); + + else ABACUSerror("Invalid parities in Iterate_BAE."); } - + //cout << "Rapidity blows up !\t" << lambda[j][alpha] << "\t" << new_lambda << endl; } @@ -326,14 +331,14 @@ namespace JSC { for (int j = 0; j < chain.Nstrings; ++j) for (int alpha = 0; alpha < base[j]; ++alpha) nonan *= !is_nan(lambda[j][alpha]); - + return nonan; } void ODSLF_XXZ_Bethe_State::Compute_Energy () { DP sum = 0.0; - + for (int j = 0; j < chain.Nstrings; ++j) { for (int alpha = 0; alpha < base[j]; ++alpha) { sum += sin(chain.Str_L[j] * chain.anis) / (chain.par[j] * cosh(2.0 * lambda[j][alpha]) - cos(chain.Str_L[j] * chain.anis)); @@ -341,7 +346,7 @@ namespace JSC { } sum *= - chain.J * sin(chain.anis); - + E = sum; return; @@ -376,7 +381,7 @@ namespace JSC { void ODSLF_XXZ_Bethe_State::Build_Reduced_Gaudin_Matrix (SQMat >& Gaudin_Red) { - if (Gaudin_Red.size() != base.Nraptot) JSCerror("Passing matrix of wrong size in Build_Reduced_Gaudin_Matrix."); + if (Gaudin_Red.size() != base.Nraptot) ABACUSerror("Passing matrix of wrong size in Build_Reduced_Gaudin_Matrix."); int index_jalpha; int index_kbeta; @@ -401,26 +406,26 @@ namespace JSC { for (int kp = 0; kp < chain.Nstrings; ++kp) { for (int betap = 0; betap < base[kp]; ++betap) { - if (!((j == kp) && (alpha == betap))) - sum_hbar_XXZ - += ODSLF_ddlambda_Theta_XXZ (lambda[j][alpha] - lambda[kp][betap], chain.Str_L[j], chain.Str_L[kp], chain.par[j], chain.par[kp], + if (!((j == kp) && (alpha == betap))) + sum_hbar_XXZ + += ODSLF_ddlambda_Theta_XXZ (lambda[j][alpha] - lambda[kp][betap], chain.Str_L[j], chain.Str_L[kp], chain.par[j], chain.par[kp], chain.si_n_anis_over_2); } } - Gaudin_Red[index_jalpha][index_kbeta] + Gaudin_Red[index_jalpha][index_kbeta] = complex ( chain.Nsites * ODSLF_hbar_XXZ (lambda[j][alpha], chain.Str_L[j], chain.par[j], chain.si_n_anis_over_2) - sum_hbar_XXZ); } else { - if ((chain.Str_L[j] == 1) && (chain.Str_L[k] == 1)) - Gaudin_Red[index_jalpha][index_kbeta] = - complex ((chain.par[j] * chain.par[k] == 1) - ? chain.si_n_anis_over_2[4]/(pow(sinhlambda[j][alpha] * coshlambda[k][beta] + if ((chain.Str_L[j] == 1) && (chain.Str_L[k] == 1)) + Gaudin_Red[index_jalpha][index_kbeta] = + complex ((chain.par[j] * chain.par[k] == 1) + ? chain.si_n_anis_over_2[4]/(pow(sinhlambda[j][alpha] * coshlambda[k][beta] - coshlambda[j][alpha] * sinhlambda[k][beta], 2.0) + sinzetasq) - : chain.si_n_anis_over_2[4]/(-pow(coshlambda[j][alpha] * coshlambda[k][beta] + : chain.si_n_anis_over_2[4]/(-pow(coshlambda[j][alpha] * coshlambda[k][beta] - sinhlambda[j][alpha] * sinhlambda[k][beta], 2.0) + sinzetasq) ); - else + else Gaudin_Red[index_jalpha][index_kbeta] = complex (ODSLF_ddlambda_Theta_XXZ (lambda[j][alpha] - lambda[k][beta], chain.Str_L[j], chain.Str_L[k], chain.par[j], chain.par[k], chain.si_n_anis_over_2)); } @@ -445,7 +450,7 @@ namespace JSC { else if (par == -1) result = -2.0 * atan(tanhlambda * tannzetaover2); - else JSCerror("Faulty parity in ODSLF_fbar_XXZ."); + else ABACUSerror("Faulty parity in ODSLF_fbar_XXZ."); return (result); } @@ -455,12 +460,12 @@ namespace JSC { DP result = 0.0; if ((nj == 1) && (nk == 1)) result = ODSLF_fbar_XXZ(tanhlambda, parj*park, tannzetaover2[2]); - + else { result = (nj == nk) ? 0.0 : ODSLF_fbar_XXZ(tanhlambda, parj*park, tannzetaover2[fabs(nj - nk)]); - for (int a = 1; a < JSC::min(nj, nk); ++a) result += 2.0 * ODSLF_fbar_XXZ(tanhlambda, parj*park, tannzetaover2[fabs(nj - nk) + 2*a]); + for (int a = 1; a < ABACUS::min(nj, nk); ++a) result += 2.0 * ODSLF_fbar_XXZ(tanhlambda, parj*park, tannzetaover2[fabs(nj - nk) + 2*a]); result += ODSLF_fbar_XXZ(tanhlambda, parj*park, tannzetaover2[nj + nk]); } @@ -476,21 +481,21 @@ namespace JSC { else if (par == -1) result = si_n_anis_over_2[2*n]/(-pow(cosh(lambda), 2.0) + pow(si_n_anis_over_2[n], 2.0)); - else JSCerror("Faulty parity in ODSLF_hbar_XXZ."); + else ABACUSerror("Faulty parity in ODSLF_hbar_XXZ."); return (result); } - + DP ODSLF_ddlambda_Theta_XXZ (DP lambda, int nj, int nk, int parj, int park, DP* si_n_anis_over_2) { DP result = (nj == nk) ? 0.0 : ODSLF_hbar_XXZ(lambda, fabs(nj - nk), parj*park, si_n_anis_over_2); - for (int a = 1; a < JSC::min(nj, nk); ++a) result += 2.0 * ODSLF_hbar_XXZ(lambda, fabs(nj - nk) + 2*a, parj*park, si_n_anis_over_2); + for (int a = 1; a < ABACUS::min(nj, nk); ++a) result += 2.0 * ODSLF_hbar_XXZ(lambda, fabs(nj - nk) + 2*a, parj*park, si_n_anis_over_2); result += ODSLF_hbar_XXZ(lambda, nj + nk, parj*park, si_n_anis_over_2); return (result); } - -} // namespace JSC + +} // namespace ABACUS diff --git a/src/ODSLF/ln_Smin_ME_ODSLF_XXZ.cc b/src/ODSLF/ln_Smin_ME_ODSLF_XXZ.cc index dbf99ce..746c7ef 100644 --- a/src/ODSLF/ln_Smin_ME_ODSLF_XXZ.cc +++ b/src/ODSLF/ln_Smin_ME_ODSLF_XXZ.cc @@ -1,8 +1,22 @@ -#include "JSC.h" +/********************************************************** -using namespace JSC; +This software is part of J.-S. Caux's ABACUS library. -namespace JSC { +Copyright (c) J.-S. Caux. + +----------------------------------------------------------- + +File: ln_Smin_ME_ODSLF_XXZ.cc + +Purpose: S^- matrix element + +***********************************************************/ + +#include "ABACUS.h" + +using namespace ABACUS; + +namespace ABACUS { inline complex ln_Fn_F (ODSLF_XXZ_Bethe_State& B, int k, int beta, int b) { @@ -25,19 +39,19 @@ inline complex ln_Fn_F (ODSLF_XXZ_Bethe_State& B, int k, int beta, int b) arg = B.chain.Str_L[j] - B.chain.Str_L[k] - 2 * (a - b); absarg = abs(arg); - /* + /* prod_temp *= 0.5 * //done later... - ((B.sinhlambda[j][alpha] * B.coshlambda[k][beta] - B.coshlambda[j][alpha] * B.sinhlambda[k][beta]) - * (B.chain.co_n_anis_over_2[absarg] * (1.0 + B.chain.par[j] * B.chain.par[k]) + ((B.sinhlambda[j][alpha] * B.coshlambda[k][beta] - B.coshlambda[j][alpha] * B.sinhlambda[k][beta]) + * (B.chain.co_n_anis_over_2[absarg] * (1.0 + B.chain.par[j] * B.chain.par[k]) - sgn_int(arg) * B.chain.si_n_anis_over_2[absarg] * (B.chain.par[k] - B.chain.par[j])) - + II * (B.coshlambda[j][alpha] * B.coshlambda[k][beta] - B.sinhlambda[j][alpha] * B.sinhlambda[k][beta]) + + II * (B.coshlambda[j][alpha] * B.coshlambda[k][beta] - B.sinhlambda[j][alpha] * B.sinhlambda[k][beta]) * (sgn_int(arg) * B.chain.si_n_anis_over_2[absarg] * (1.0 + B.chain.par[j] * B.chain.par[k]) + B.chain.co_n_anis_over_2[absarg] * (B.chain.par[k] - B.chain.par[j])) ); */ - prod_temp *= ((B.sinhlambda[j][alpha] * B.coshlambda[k][beta] - B.coshlambda[j][alpha] * B.sinhlambda[k][beta]) + prod_temp *= ((B.sinhlambda[j][alpha] * B.coshlambda[k][beta] - B.coshlambda[j][alpha] * B.sinhlambda[k][beta]) * (B.chain.co_n_anis_over_2[absarg] * par_comb_1 - sgn_int(arg) * B.chain.si_n_anis_over_2[absarg] * par_comb_2) - + II * (B.coshlambda[j][alpha] * B.coshlambda[k][beta] - B.sinhlambda[j][alpha] * B.sinhlambda[k][beta]) + + II * (B.coshlambda[j][alpha] * B.coshlambda[k][beta] - B.sinhlambda[j][alpha] * B.sinhlambda[k][beta]) * (sgn_int(arg) * B.chain.si_n_anis_over_2[absarg] * par_comb_1 + B.chain.co_n_anis_over_2[absarg] * par_comb_2)); } @@ -73,16 +87,16 @@ inline complex ln_Fn_G (ODSLF_XXZ_Bethe_State& A, ODSLF_XXZ_Bethe_State& B, absarg = abs(arg); /* prod_temp *= 0.5 * //done later... - ((A.sinhlambda[j][alpha] * B.coshlambda[k][beta] - A.coshlambda[j][alpha] * B.sinhlambda[k][beta]) + ((A.sinhlambda[j][alpha] * B.coshlambda[k][beta] - A.coshlambda[j][alpha] * B.sinhlambda[k][beta]) * (A.chain.co_n_anis_over_2[absarg] * (1.0 + A.chain.par[j] * B.chain.par[k]) - sgn_int(arg) * A.chain.si_n_anis_over_2[absarg] * (B.chain.par[k] - A.chain.par[j])) - + II * (A.coshlambda[j][alpha] * B.coshlambda[k][beta] - A.sinhlambda[j][alpha] * B.sinhlambda[k][beta]) + + II * (A.coshlambda[j][alpha] * B.coshlambda[k][beta] - A.sinhlambda[j][alpha] * B.sinhlambda[k][beta]) * (sgn_int(arg) * A.chain.si_n_anis_over_2[absarg] * (1.0 + A.chain.par[j] * B.chain.par[k]) + A.chain.co_n_anis_over_2[absarg] * (B.chain.par[k] - A.chain.par[j])) ); */ - prod_temp *= ((A.sinhlambda[j][alpha] * B.coshlambda[k][beta] - A.coshlambda[j][alpha] * B.sinhlambda[k][beta]) + prod_temp *= ((A.sinhlambda[j][alpha] * B.coshlambda[k][beta] - A.coshlambda[j][alpha] * B.sinhlambda[k][beta]) * (A.chain.co_n_anis_over_2[absarg] * par_comb_1 - sgn_int(arg) * A.chain.si_n_anis_over_2[absarg] * par_comb_2) - + II * (A.coshlambda[j][alpha] * B.coshlambda[k][beta] - A.sinhlambda[j][alpha] * B.sinhlambda[k][beta]) + + II * (A.coshlambda[j][alpha] * B.coshlambda[k][beta] - A.sinhlambda[j][alpha] * B.sinhlambda[k][beta]) * (sgn_int(arg) * A.chain.si_n_anis_over_2[absarg] * par_comb_1 + A.chain.co_n_anis_over_2[absarg] * par_comb_2)); if (counter++ > 100) { // we do at most 100 products before taking a log @@ -103,17 +117,17 @@ inline complex Fn_K (ODSLF_XXZ_Bethe_State& A, int j, int alpha, int a, ODSL int absarg2 = abs(arg2); return(4.0/( - ((A.sinhlambda[j][alpha] * B.coshlambda[k][beta] - A.coshlambda[j][alpha] * B.sinhlambda[k][beta]) + ((A.sinhlambda[j][alpha] * B.coshlambda[k][beta] - A.coshlambda[j][alpha] * B.sinhlambda[k][beta]) * (A.chain.co_n_anis_over_2[absarg1] * (1.0 + A.chain.par[j] * B.chain.par[k]) - sgn_int(arg1) * A.chain.si_n_anis_over_2[absarg1] * (B.chain.par[k] - A.chain.par[j])) - + II * (A.coshlambda[j][alpha] * B.coshlambda[k][beta] - A.sinhlambda[j][alpha] * B.sinhlambda[k][beta]) + + II * (A.coshlambda[j][alpha] * B.coshlambda[k][beta] - A.sinhlambda[j][alpha] * B.sinhlambda[k][beta]) * (sgn_int(arg1) * A.chain.si_n_anis_over_2[absarg1] * (1.0 + A.chain.par[j] * B.chain.par[k]) + A.chain.co_n_anis_over_2[absarg1] * (B.chain.par[k] - A.chain.par[j])) ) * - ((A.sinhlambda[j][alpha] * B.coshlambda[k][beta] - A.coshlambda[j][alpha] * B.sinhlambda[k][beta]) + ((A.sinhlambda[j][alpha] * B.coshlambda[k][beta] - A.coshlambda[j][alpha] * B.sinhlambda[k][beta]) * (A.chain.co_n_anis_over_2[absarg2] * (1.0 + A.chain.par[j] * B.chain.par[k]) - sgn_int(arg2) * A.chain.si_n_anis_over_2[absarg2] * (B.chain.par[k] - A.chain.par[j])) - + II * (A.coshlambda[j][alpha] * B.coshlambda[k][beta] - A.sinhlambda[j][alpha] * B.sinhlambda[k][beta]) + + II * (A.coshlambda[j][alpha] * B.coshlambda[k][beta] - A.sinhlambda[j][alpha] * B.sinhlambda[k][beta]) * (sgn_int(arg2) * A.chain.si_n_anis_over_2[absarg2] * (1.0 + A.chain.par[j] * B.chain.par[k]) + A.chain.co_n_anis_over_2[absarg2] * (B.chain.par[k] - A.chain.par[j])) ) )); @@ -123,8 +137,8 @@ inline complex Fn_K (ODSLF_XXZ_Bethe_State& A, int j, int alpha, int a, ODSL inline complex Fn_L (ODSLF_XXZ_Bethe_State& A, int j, int alpha, int a, ODSLF_XXZ_Bethe_State& B, int k, int beta, int b) { return (sinh(2.0 * (A.lambda[j][alpha] - B.lambda[k][beta] - + 0.5 * II * B.chain.anis * (A.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b - 0.5)) - + 0.25 * II * PI * complex(-A.chain.par[j] + B.chain.par[k]))) + + 0.5 * II * B.chain.anis * (A.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b - 0.5)) + + 0.25 * II * PI * complex(-A.chain.par[j] + B.chain.par[k]))) * pow(Fn_K (A, j, alpha, a, B, k, beta, b), 2.0)); } @@ -135,11 +149,11 @@ complex ln_Smin_ME (ODSLF_XXZ_Bethe_State& A, ODSLF_XXZ_Bethe_State& B) // Check that the two states are compatible - if (A.chain != B.chain) JSCerror("Incompatible ODSLF_XXZ_Chains in Smin matrix element."); + if (A.chain != B.chain) ABACUSerror("Incompatible ODSLF_XXZ_Chains in Smin matrix element."); - // Check that A and B are Mdown-compatible: + // Check that A and B are Mdown-compatible: - if (A.base.Mdown != B.base.Mdown + 1) JSCerror("Incompatible Mdown between the two states in Smin matrix element!"); + if (A.base.Mdown != B.base.Mdown + 1) ABACUSerror("Incompatible Mdown between the two states in Smin matrix element!"); // Compute the sinh and cosh of rapidities @@ -162,13 +176,13 @@ complex ln_Smin_ME (ODSLF_XXZ_Bethe_State& A, ODSLF_XXZ_Bethe_State& B) complex ln_prod3 = 0.0; complex ln_prod4 = 0.0; - for (int i = 0; i < A.chain.Nstrings; ++i) + for (int i = 0; i < A.chain.Nstrings; ++i) for (int alpha = 0; alpha < A.base.Nrap[i]; ++alpha) for (int a = 1; a <= A.chain.Str_L[i]; ++a) ln_prod1 += log(norm(sinh(A.lambda[i][alpha] + 0.5 * II * A.chain.anis * (A.chain.Str_L[i] + 1.0 - 2.0 * a - 1.0) + 0.25 * II * PI * (1.0 - A.chain.par[i])))); - for (int i = 0; i < B.chain.Nstrings; ++i) + for (int i = 0; i < B.chain.Nstrings; ++i) for (int alpha = 0; alpha < B.base.Nrap[i]; ++alpha) for (int a = 1; a <= B.chain.Str_L[i]; ++a) if (norm(sinh(B.lambda[i][alpha] + 0.5 * II * B.chain.anis * (B.chain.Str_L[i] + 1.0 - 2.0 * a - 1.0) @@ -195,7 +209,7 @@ complex ln_Smin_ME (ODSLF_XXZ_Bethe_State& A, ODSLF_XXZ_Bethe_State& B) for (int j = 0; j < A.chain.Nstrings; ++j) for (int alpha = 0; alpha < A.base.Nrap[j]; ++alpha) - for (int a = 1; a <= A.chain.Str_L[j]; ++a) + for (int a = 1; a <= A.chain.Str_L[j]; ++a) ln_prod3 += ln_Fn_F(A, j, alpha, a - 1); // assume only one-strings here ln_prod3 -= A.base.Mdown * log(abs(sin(A.chain.anis))); @@ -206,7 +220,7 @@ complex ln_Smin_ME (ODSLF_XXZ_Bethe_State& A, ODSLF_XXZ_Bethe_State& B) if (b == 1) ln_prod4 += re_ln_Fn_F_B_0[k][beta]; else if (b > 1) ln_prod4 += ln_Fn_F(B, k, beta, b - 1); } - + ln_prod4 -= B.base.Mdown * log(abs(sin(B.chain.anis))); // Now proceed to build the Hm matrix @@ -228,11 +242,11 @@ complex ln_Smin_ME (ODSLF_XXZ_Bethe_State& A, ODSLF_XXZ_Bethe_State& B) for (int j = 0; j < A.chain.Nstrings; ++j) { for (int alpha = 0; alpha < A.base.Nrap[j]; ++alpha) { for (int a = 1; a <= A.chain.Str_L[j]; ++a) { - + index_b = 0; - + one_over_A_sinhlambda_sq_plus_sinzetaover2sq = 1.0/((sinh(A.lambda[j][alpha] + 0.5 * II * A.chain.anis * (A.chain.Str_L[j] + 1.0 - 2.0 * a) - + 0.25 * II * PI * (1.0 - A.chain.par[j]))) + + 0.25 * II * PI * (1.0 - A.chain.par[j]))) * (sinh(A.lambda[j][alpha] + 0.5 * II * A.chain.anis * (A.chain.Str_L[j] + 1.0 - 2.0 * a) + 0.25 * II * PI * (1.0 - A.chain.par[j]))) + pow(sin(0.5*A.chain.anis), 2.0)); @@ -245,12 +259,12 @@ complex ln_Smin_ME (ODSLF_XXZ_Bethe_State& A, ODSLF_XXZ_Bethe_State& B) // use simplified code for one-string here: original form of Hm matrix - Fn_K_0_G_0 = Fn_K (A, j, alpha, a, B, k, beta, 0) * + Fn_K_0_G_0 = Fn_K (A, j, alpha, a, B, k, beta, 0) * exp(re_ln_Fn_G_0[k][beta] + II * im_ln_Fn_G_0[k][beta] - re_ln_Fn_F_B_0[k][beta] + logabssinzeta); - Fn_K_1_G_2 = Fn_K (A, j, alpha, a, B, k, beta, 1) * + Fn_K_1_G_2 = Fn_K (A, j, alpha, a, B, k, beta, 1) * exp(re_ln_Fn_G_2[k][beta] + II * im_ln_Fn_G_2[k][beta] - re_ln_Fn_F_B_0[k][beta] + logabssinzeta); - Prod_powerN = pow( B.chain.par[k] == 1 ? + Prod_powerN = pow( B.chain.par[k] == 1 ? (B.sinhlambda[k][beta] * B.chain.co_n_anis_over_2[1] + II * B.coshlambda[k][beta] * B.chain.si_n_anis_over_2[1]) /(B.sinhlambda[k][beta] * B.chain.co_n_anis_over_2[1] - II * B.coshlambda[k][beta] * B.chain.si_n_anis_over_2[1]) : @@ -262,60 +276,60 @@ complex ln_Smin_ME (ODSLF_XXZ_Bethe_State& A, ODSLF_XXZ_Bethe_State& B) Prod_powerN * Fn_K_1_G_2; } // if (B.chain.Str_L == 1) - + else { if (b <= B.chain.Str_L[k] - 1) Hm[index_a][index_b] = Fn_K(A, j, alpha, a, B, k, beta, b); else if (b == B.chain.Str_L[k]) { - + Vect_CX ln_FunctionF(B.chain.Str_L[k] + 2); for (int i = 0; i < B.chain.Str_L[k] + 2; ++i) ln_FunctionF[i] = ln_Fn_F (B, k, beta, i); - + Vect_CX ln_FunctionG(B.chain.Str_L[k] + 2); for (int i = 0; i < B.chain.Str_L[k] + 2; ++i) ln_FunctionG[i] = ln_Fn_G (A, B, k, beta, i); - + sum1 = 0.0; - + sum1 += Fn_K (A, j, alpha, a, B, k, beta, 0) * exp(ln_FunctionG[0] + ln_FunctionG[1] - ln_FunctionF[0] - ln_FunctionF[1]); - + sum1 += (1.0 - 2.0 * (B.base.Mdown % 2)) * // MODIF from XXZ - Fn_K (A, j, alpha, a, B, k, beta, B.chain.Str_L[k]) - * exp(ln_FunctionG[B.chain.Str_L[k]] + ln_FunctionG[B.chain.Str_L[k] + 1] + Fn_K (A, j, alpha, a, B, k, beta, B.chain.Str_L[k]) + * exp(ln_FunctionG[B.chain.Str_L[k]] + ln_FunctionG[B.chain.Str_L[k] + 1] - ln_FunctionF[B.chain.Str_L[k]] - ln_FunctionF[B.chain.Str_L[k] + 1]); - - for (int jsum = 1; jsum < B.chain.Str_L[k]; ++jsum) - + + for (int jsum = 1; jsum < B.chain.Str_L[k]; ++jsum) + sum1 -= Fn_L (A, j, alpha, a, B, k, beta, jsum) * exp(ln_FunctionG[jsum] + ln_FunctionG[jsum + 1] - ln_FunctionF[jsum] - ln_FunctionF[jsum + 1]); - + /* sum2 = 0.0; - + for (int jsum = 1; jsum <= B.chain.Str_L[k]; ++jsum) sum2 += exp(ln_FunctionG[jsum] - ln_FunctionF[jsum]); - + */ prod_num = exp(II * im_ln_Fn_F_B_0[k][beta] + ln_FunctionF[1] - ln_FunctionG[B.chain.Str_L[k]] + logabssinzeta); - for (int jsum = 2; jsum <= B.chain.Str_L[k]; ++jsum) - prod_num *= exp(ln_FunctionG[jsum] - real(ln_Fn_F(B, k, beta, jsum - 1)) + logabssinzeta); + for (int jsum = 2; jsum <= B.chain.Str_L[k]; ++jsum) + prod_num *= exp(ln_FunctionG[jsum] - real(ln_Fn_F(B, k, beta, jsum - 1)) + logabssinzeta); // include all string contributions F_B_0 in this term Hm[index_a][index_b] = prod_num * sum1; } // else if (b == B.chain.Str_L[k]) - } // else + } // else index_b++; }}} // sums over k, beta, b // now define the elements Hm[a][M] - Hm[index_a][B.base.Mdown] = one_over_A_sinhlambda_sq_plus_sinzetaover2sq; + Hm[index_a][B.base.Mdown] = one_over_A_sinhlambda_sq_plus_sinzetaover2sq; index_a++; }}} // sums over j, alpha, a - complex ln_ME_sq = log(1.0 * A.chain.Nsites) + real(ln_prod1 - ln_prod2) - real(ln_prod3) + real(ln_prod4) + complex ln_ME_sq = log(1.0 * A.chain.Nsites) + real(ln_prod1 - ln_prod2) - real(ln_prod3) + real(ln_prod4) + 2.0 * real(lndet_LU_CX_dstry(Hm)) + logabssinzeta - A.lnnorm - B.lnnorm; //return(ln_ME_sq); @@ -323,4 +337,4 @@ complex ln_Smin_ME (ODSLF_XXZ_Bethe_State& A, ODSLF_XXZ_Bethe_State& B) } -} // namespace JSC +} // namespace ABACUS diff --git a/src/ODSLF/ln_Sz_ME_ODSLF_XXZ.cc b/src/ODSLF/ln_Sz_ME_ODSLF_XXZ.cc index 971c2b2..6ccd7c9 100644 --- a/src/ODSLF/ln_Sz_ME_ODSLF_XXZ.cc +++ b/src/ODSLF/ln_Sz_ME_ODSLF_XXZ.cc @@ -1,8 +1,22 @@ -#include "JSC.h" +/********************************************************** -using namespace JSC; +This software is part of J.-S. Caux's ABACUS library. -namespace JSC { +Copyright (c) J.-S. Caux. + +----------------------------------------------------------- + +File: ln_Sz_ME_ODSLF_XXZ.cc + +Purpose: S^z matrix element + +***********************************************************/ + +#include "ABACUS.h" + +using namespace ABACUS; + +namespace ABACUS { inline complex ln_Fn_F (ODSLF_XXZ_Bethe_State& B, int k, int beta, int b) { @@ -27,18 +41,18 @@ inline complex ln_Fn_F (ODSLF_XXZ_Bethe_State& B, int k, int beta, int b) arg = B.chain.Str_L[j] - B.chain.Str_L[k] - 2 * (a - b); absarg = abs(arg); /* - prod_temp *= 0.5 * - ((B.sinhlambda[j][alpha] * B.coshlambda[k][beta] - B.coshlambda[j][alpha] * B.sinhlambda[k][beta]) + prod_temp *= 0.5 * + ((B.sinhlambda[j][alpha] * B.coshlambda[k][beta] - B.coshlambda[j][alpha] * B.sinhlambda[k][beta]) * (B.chain.co_n_anis_over_2[absarg] * (1.0 + B.chain.par[j] * B.chain.par[k]) - sgn_int(arg) * B.chain.si_n_anis_over_2[absarg] * (B.chain.par[k] - B.chain.par[j])) - + II * (B.coshlambda[j][alpha] * B.coshlambda[k][beta] - B.sinhlambda[j][alpha] * B.sinhlambda[k][beta]) - * (sgn_int(arg) + + II * (B.coshlambda[j][alpha] * B.coshlambda[k][beta] - B.sinhlambda[j][alpha] * B.sinhlambda[k][beta]) + * (sgn_int(arg) * B.chain.si_n_anis_over_2[absarg] * (1.0 + B.chain.par[j] * B.chain.par[k]) + B.chain.co_n_anis_over_2[absarg] * (B.chain.par[k] - B.chain.par[j])) ); */ - prod_temp *= ((B.sinhlambda[j][alpha] * B.coshlambda[k][beta] - B.coshlambda[j][alpha] * B.sinhlambda[k][beta]) + prod_temp *= ((B.sinhlambda[j][alpha] * B.coshlambda[k][beta] - B.coshlambda[j][alpha] * B.sinhlambda[k][beta]) * (B.chain.co_n_anis_over_2[absarg] * par_comb_1 - sgn_int(arg) * B.chain.si_n_anis_over_2[absarg] * par_comb_2) - + II * (B.coshlambda[j][alpha] * B.coshlambda[k][beta] - B.sinhlambda[j][alpha] * B.sinhlambda[k][beta]) + + II * (B.coshlambda[j][alpha] * B.coshlambda[k][beta] - B.sinhlambda[j][alpha] * B.sinhlambda[k][beta]) * (sgn_int(arg) * B.chain.si_n_anis_over_2[absarg] * par_comb_1 + B.chain.co_n_anis_over_2[absarg] * par_comb_2)); } @@ -76,17 +90,17 @@ inline complex ln_Fn_G (ODSLF_XXZ_Bethe_State& A, ODSLF_XXZ_Bethe_State& B, absarg = abs(arg); /* - prod_temp *= 0.5 * - ((A.sinhlambda[j][alpha] * B.coshlambda[k][beta] - A.coshlambda[j][alpha] * B.sinhlambda[k][beta]) + prod_temp *= 0.5 * + ((A.sinhlambda[j][alpha] * B.coshlambda[k][beta] - A.coshlambda[j][alpha] * B.sinhlambda[k][beta]) * (A.chain.co_n_anis_over_2[absarg] * (1.0 + A.chain.par[j] * B.chain.par[k]) - sgn_int(arg) * A.chain.si_n_anis_over_2[absarg] * (B.chain.par[k] - A.chain.par[j])) - + II * (A.coshlambda[j][alpha] * B.coshlambda[k][beta] - A.sinhlambda[j][alpha] * B.sinhlambda[k][beta]) + + II * (A.coshlambda[j][alpha] * B.coshlambda[k][beta] - A.sinhlambda[j][alpha] * B.sinhlambda[k][beta]) * (sgn_int(arg) * A.chain.si_n_anis_over_2[absarg] * (1.0 + A.chain.par[j] * B.chain.par[k]) + A.chain.co_n_anis_over_2[absarg] * (B.chain.par[k] - A.chain.par[j])) ); */ - prod_temp *= ((A.sinhlambda[j][alpha] * B.coshlambda[k][beta] - A.coshlambda[j][alpha] * B.sinhlambda[k][beta]) + prod_temp *= ((A.sinhlambda[j][alpha] * B.coshlambda[k][beta] - A.coshlambda[j][alpha] * B.sinhlambda[k][beta]) * (A.chain.co_n_anis_over_2[absarg] * par_comb_1 - sgn_int(arg) * A.chain.si_n_anis_over_2[absarg] * par_comb_2) - + II * (A.coshlambda[j][alpha] * B.coshlambda[k][beta] - A.sinhlambda[j][alpha] * B.sinhlambda[k][beta]) + + II * (A.coshlambda[j][alpha] * B.coshlambda[k][beta] - A.sinhlambda[j][alpha] * B.sinhlambda[k][beta]) * (sgn_int(arg) * A.chain.si_n_anis_over_2[absarg] * par_comb_1 + A.chain.co_n_anis_over_2[absarg] * par_comb_2)); if (counter++ > 100) { // we do at most 100 products before taking a log @@ -107,17 +121,17 @@ inline complex Fn_K (ODSLF_XXZ_Bethe_State& A, int j, int alpha, int a, ODSL int absarg2 = abs(arg2); return(4.0/( - ((A.sinhlambda[j][alpha] * B.coshlambda[k][beta] - A.coshlambda[j][alpha] * B.sinhlambda[k][beta]) + ((A.sinhlambda[j][alpha] * B.coshlambda[k][beta] - A.coshlambda[j][alpha] * B.sinhlambda[k][beta]) * (A.chain.co_n_anis_over_2[absarg1] * (1.0 + A.chain.par[j] * B.chain.par[k]) - sgn_int(arg1) * A.chain.si_n_anis_over_2[absarg1] * (B.chain.par[k] - A.chain.par[j])) - + II * (A.coshlambda[j][alpha] * B.coshlambda[k][beta] - A.sinhlambda[j][alpha] * B.sinhlambda[k][beta]) + + II * (A.coshlambda[j][alpha] * B.coshlambda[k][beta] - A.sinhlambda[j][alpha] * B.sinhlambda[k][beta]) * (sgn_int(arg1) * A.chain.si_n_anis_over_2[absarg1] * (1.0 + A.chain.par[j] * B.chain.par[k]) + A.chain.co_n_anis_over_2[absarg1] * (B.chain.par[k] - A.chain.par[j])) ) * - ((A.sinhlambda[j][alpha] * B.coshlambda[k][beta] - A.coshlambda[j][alpha] * B.sinhlambda[k][beta]) + ((A.sinhlambda[j][alpha] * B.coshlambda[k][beta] - A.coshlambda[j][alpha] * B.sinhlambda[k][beta]) * (A.chain.co_n_anis_over_2[absarg2] * (1.0 + A.chain.par[j] * B.chain.par[k]) - sgn_int(arg2) * A.chain.si_n_anis_over_2[absarg2] * (B.chain.par[k] - A.chain.par[j])) - + II * (A.coshlambda[j][alpha] * B.coshlambda[k][beta] - A.sinhlambda[j][alpha] * B.sinhlambda[k][beta]) + + II * (A.coshlambda[j][alpha] * B.coshlambda[k][beta] - A.sinhlambda[j][alpha] * B.sinhlambda[k][beta]) * (sgn_int(arg2) * A.chain.si_n_anis_over_2[absarg2] * (1.0 + A.chain.par[j] * B.chain.par[k]) + A.chain.co_n_anis_over_2[absarg2] * (B.chain.par[k] - A.chain.par[j])) ) )); @@ -127,8 +141,8 @@ inline complex Fn_K (ODSLF_XXZ_Bethe_State& A, int j, int alpha, int a, ODSL inline complex Fn_L (ODSLF_XXZ_Bethe_State& A, int j, int alpha, int a, ODSLF_XXZ_Bethe_State& B, int k, int beta, int b) { return (sinh(2.0 * (A.lambda[j][alpha] - B.lambda[k][beta] - + 0.5 * II * B.chain.anis * (A.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b - 0.5)) - + 0.25 * II * PI * complex(-A.chain.par[j] + B.chain.par[k]))) + + 0.5 * II * B.chain.anis * (A.chain.Str_L[j] - B.chain.Str_L[k] - 2.0 * (a - b - 0.5)) + + 0.25 * II * PI * complex(-A.chain.par[j] + B.chain.par[k]))) * pow(Fn_K (A, j, alpha, a, B, k, beta, b), 2.0)); } @@ -139,11 +153,11 @@ complex ln_Sz_ME (ODSLF_XXZ_Bethe_State& A, ODSLF_XXZ_Bethe_State& B) // Check that the two states refer to the same XXZ_Chain - if (A.chain != B.chain) JSCerror("Incompatible ODSLF_XXZ_Chains in Sz matrix element."); + if (A.chain != B.chain) ABACUSerror("Incompatible ODSLF_XXZ_Chains in Sz matrix element."); // Check that A and B are compatible: same Mdown - if (A.base.Mdown != B.base.Mdown) JSCerror("Incompatible Mdown between the two states in Sz matrix element!"); + if (A.base.Mdown != B.base.Mdown) ABACUSerror("Incompatible Mdown between the two states in Sz matrix element!"); // Compute the sinh and cosh of rapidities @@ -166,13 +180,13 @@ complex ln_Sz_ME (ODSLF_XXZ_Bethe_State& A, ODSLF_XXZ_Bethe_State& B) complex ln_prod3 = 0.0; complex ln_prod4 = 0.0; - for (int i = 0; i < A.chain.Nstrings; ++i) + for (int i = 0; i < A.chain.Nstrings; ++i) for (int alpha = 0; alpha < A.base.Nrap[i]; ++alpha) for (int a = 1; a <= A.chain.Str_L[i]; ++a) ln_prod1 += log(norm(sinh(A.lambda[i][alpha] + 0.5 * II * A.chain.anis * (A.chain.Str_L[i] + 1.0 - 2.0 * a - 1.0) + 0.25 * II * PI * (1.0 - A.chain.par[i])))); - for (int i = 0; i < B.chain.Nstrings; ++i) + for (int i = 0; i < B.chain.Nstrings; ++i) for (int alpha = 0; alpha < B.base.Nrap[i]; ++alpha) for (int a = 1; a <= B.chain.Str_L[i]; ++a) if (norm(sinh(B.lambda[i][alpha] + 0.5 * II * B.chain.anis * (B.chain.Str_L[i] + 1.0 - 2.0 * a - 1.0) @@ -211,7 +225,7 @@ complex ln_Sz_ME (ODSLF_XXZ_Bethe_State& A, ODSLF_XXZ_Bethe_State& B) if (b == 1) ln_prod4 += re_ln_Fn_F_B_0[k][beta]; else if (b > 1) ln_prod4 += ln_Fn_F(B, k, beta, b - 1); } - + ln_prod4 -= B.base.Mdown * log(abs(sin(B.chain.anis))); // Now proceed to build the Hm2P matrix @@ -233,15 +247,15 @@ complex ln_Sz_ME (ODSLF_XXZ_Bethe_State& A, ODSLF_XXZ_Bethe_State& B) for (int j = 0; j < A.chain.Nstrings; ++j) { for (int alpha = 0; alpha < A.base.Nrap[j]; ++alpha) { for (int a = 1; a <= A.chain.Str_L[j]; ++a) { - + index_b = 0; two_over_A_sinhlambda_sq_plus_sinzetaover2sq = 2.0/((sinh(A.lambda[j][alpha] + 0.5 * II * A.chain.anis * (A.chain.Str_L[j] + 1.0 - 2.0 * a) - + 0.25 * II * PI * (1.0 - A.chain.par[j]))) + + 0.25 * II * PI * (1.0 - A.chain.par[j]))) * (sinh(A.lambda[j][alpha] + 0.5 * II * A.chain.anis * (A.chain.Str_L[j] + 1.0 - 2.0 * a) - + 0.25 * II * PI * (1.0 - A.chain.par[j]))) + + 0.25 * II * PI * (1.0 - A.chain.par[j]))) + pow(sin(0.5*A.chain.anis), 2.0)); - + for (int k = 0; k < B.chain.Nstrings; ++k) { for (int beta = 0; beta < B.base.Nrap[k]; ++beta) { for (int b = 1; b <= B.chain.Str_L[k]; ++b) { @@ -250,12 +264,12 @@ complex ln_Sz_ME (ODSLF_XXZ_Bethe_State& A, ODSLF_XXZ_Bethe_State& B) // use simplified code for one-string here: original form of Hm2P matrix - Fn_K_0_G_0 = Fn_K (A, j, alpha, a, B, k, beta, 0) * + Fn_K_0_G_0 = Fn_K (A, j, alpha, a, B, k, beta, 0) * exp(re_ln_Fn_G_0[k][beta] + II * im_ln_Fn_G_0[k][beta] - re_ln_Fn_F_B_0[k][beta] + logabssinzeta); Fn_K_1_G_2 = Fn_K (A, j, alpha, a, B, k, beta, 1) * exp(re_ln_Fn_G_2[k][beta] + II * im_ln_Fn_G_2[k][beta] - re_ln_Fn_F_B_0[k][beta] + logabssinzeta); - Prod_powerN = pow( B.chain.par[k] == 1 ? + Prod_powerN = pow( B.chain.par[k] == 1 ? (B.sinhlambda[k][beta] * B.chain.co_n_anis_over_2[1] + II * B.coshlambda[k][beta] * B.chain.si_n_anis_over_2[1]) /(B.sinhlambda[k][beta] * B.chain.co_n_anis_over_2[1] - II * B.coshlambda[k][beta] * B.chain.si_n_anis_over_2[1]) : @@ -268,63 +282,63 @@ complex ln_Sz_ME (ODSLF_XXZ_Bethe_State& A, ODSLF_XXZ_Bethe_State& B) * exp(II*im_ln_Fn_F_B_0[k][beta] + logabssinzeta); } - + else { if (b <= B.chain.Str_L[k] - 1) Hm2P[index_a][index_b] = Fn_K(A, j, alpha, a, B, k, beta, b); else if (b == B.chain.Str_L[k]) { - + Vect_CX ln_FunctionF(B.chain.Str_L[k] + 2); for (int i = 0; i < B.chain.Str_L[k] + 2; ++i) ln_FunctionF[i] = ln_Fn_F (B, k, beta, i); - + Vect_CX ln_FunctionG(B.chain.Str_L[k] + 2); for (int i = 0; i < B.chain.Str_L[k] + 2; ++i) ln_FunctionG[i] = ln_Fn_G (A, B, k, beta, i); - + sum1 = 0.0; - + sum1 += Fn_K (A, j, alpha, a, B, k, beta, 0) * exp(ln_FunctionG[0] + ln_FunctionG[1] - ln_FunctionF[0] - ln_FunctionF[1]); - + sum1 += (-1.0 + 2.0 * (B.base.Mdown % 2)) * // MODIF from XXZ - Fn_K (A, j, alpha, a, B, k, beta, B.chain.Str_L[k]) - * exp(ln_FunctionG[B.chain.Str_L[k]] + ln_FunctionG[B.chain.Str_L[k] + 1] + Fn_K (A, j, alpha, a, B, k, beta, B.chain.Str_L[k]) + * exp(ln_FunctionG[B.chain.Str_L[k]] + ln_FunctionG[B.chain.Str_L[k] + 1] - ln_FunctionF[B.chain.Str_L[k]] - ln_FunctionF[B.chain.Str_L[k] + 1]); - - for (int jsum = 1; jsum < B.chain.Str_L[k]; ++jsum) - + + for (int jsum = 1; jsum < B.chain.Str_L[k]; ++jsum) + sum1 -= Fn_L (A, j, alpha, a, B, k, beta, jsum) * exp(ln_FunctionG[jsum] + ln_FunctionG[jsum + 1] - ln_FunctionF[jsum] - ln_FunctionF[jsum + 1]); - + sum2 = 0.0; - + for (int jsum = 1; jsum <= B.chain.Str_L[k]; ++jsum) sum2 += exp(ln_FunctionG[jsum] - ln_FunctionF[jsum]); - + prod_num = exp(II * im_ln_Fn_F_B_0[k][beta] + ln_FunctionF[1] - ln_FunctionG[B.chain.Str_L[k]] + logabssinzeta); - for (int jsum = 2; jsum <= B.chain.Str_L[k]; ++jsum) - prod_num *= exp(ln_FunctionG[jsum] - real(ln_FunctionF[jsum - 1]) + logabssinzeta); + for (int jsum = 2; jsum <= B.chain.Str_L[k]; ++jsum) + prod_num *= exp(ln_FunctionG[jsum] - real(ln_FunctionF[jsum - 1]) + logabssinzeta); // include all string contributions F_B_0 in this term Hm2P[index_a][index_b] = prod_num * (sum1 - sum2 * two_over_A_sinhlambda_sq_plus_sinzetaover2sq); } // else if (b == B.chain.Str_L[k]) - } // else - + } // else + index_b++; }}} // sums over k, beta, b index_a++; }}} // sums over j, alpha, a DP re_ln_det = real(lndet_LU_CX_dstry(Hm2P)); - + complex ln_ME_sq = log(0.25 * A.chain.Nsites) + real(ln_prod1 - ln_prod2) - real(ln_prod3) + real(ln_prod4) + 2.0 * /*real(lndet_LU_CX_dstry(Hm2P))*/ re_ln_det - A.lnnorm - B.lnnorm; - - //cout << endl << ln_prod1 << "\t" << ln_prod2 << "\t" << ln_prod3 << "\t" << ln_prod4 << "\t" << A.lnnorm << "\t" << B.lnnorm + + //cout << endl << ln_prod1 << "\t" << ln_prod2 << "\t" << ln_prod3 << "\t" << ln_prod4 << "\t" << A.lnnorm << "\t" << B.lnnorm // << "\t" << re_ln_det << "\t" << ln_ME_sq << endl; - + //return(ln_ME_sq); return(0.5 * ln_ME_sq); // Return ME, not MEsq } -} // namespace JSC +} // namespace ABACUS diff --git a/src/RICHARDSON/Richardson.cc b/src/RICHARDSON/Richardson.cc index 4f3d13b..b39d095 100644 --- a/src/RICHARDSON/Richardson.cc +++ b/src/RICHARDSON/Richardson.cc @@ -1,27 +1,26 @@ /********************************************************** -This software is part of J.-S. Caux's ABACUS++ library. +This software is part of J.-S. Caux's ABACUS library. -Copyright (c) +Copyright (c) J.-S. Caux. ----------------------------------------------------------- File: src/RICHARDSON/Rischardson.cc -Purpose: Richardson model - +Purpose: Richardson model ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -namespace JSC { +namespace ABACUS { - bool Solve_Richardson_Quad_S (DP g_int, const Vect_DP epsilon, const Vect_DP sumoneovereps, + bool Solve_Richardson_Quad_S (DP g_int, const Vect_DP epsilon, const Vect_DP sumoneovereps, const Vect_CX S, const Vect_CX sumSovereps, int j, complex& Sjleft, complex& Sjright) { // This solves the equation @@ -46,7 +45,7 @@ namespace JSC { */ complex discr = sqrt((1.0/g_int + sumoneovereps[j]) * (1.0/g_int + sumoneovereps[j]) - 4.0 * sumSovereps[j]); - //complex discr = sqrt(JSC::max(0.0, real((1.0/g_int + sumoneovereps[j]) * (1.0/g_int + sumoneovereps[j]) - 4.0 * sumSovereps[j]))); + //complex discr = sqrt(ABACUS::max(0.0, real((1.0/g_int + sumoneovereps[j]) * (1.0/g_int + sumoneovereps[j]) - 4.0 * sumSovereps[j]))); Sjleft = 0.5 * (1.0/g_int + sumoneovereps[j] - discr); Sjright = 0.5 * (1.0/g_int + sumoneovereps[j] + discr); return(true); @@ -100,11 +99,11 @@ namespace JSC { else S[jmax] = damping * Sright + (1.0 - damping) * S[jmax]; } else { - JSCerror("Complex jmax root."); + ABACUSerror("Complex jmax root."); } cout << " to " << S[jmax] << endl; - // Re-solve also for a random j, given by + // Re-solve also for a random j, given by //int jrand = int(maxabsLHSRE * 1.0e+6) % Nlevels; int jrand = rand() % Nlevels; cout << "identified jrand = " << jrand << endl; @@ -117,7 +116,7 @@ namespace JSC { else S[jrand] = damping * Sright + (1.0 - damping) * S[jrand]; } else { - JSCerror("Complex jrand root."); + ABACUSerror("Complex jrand root."); } cout << " to " << S[jrand] << endl; @@ -128,7 +127,7 @@ namespace JSC { else S[j] = damping * Sright + (1.0 - damping) * S[j]; } else { - JSCerror("Complex root."); + ABACUSerror("Complex root."); } } */ @@ -138,7 +137,7 @@ namespace JSC { sumSovereps[j] = 0.0; for (int i = 0; i < Nlevels; ++i) if (i != j) sumSovereps[j] += S[i]/(epsilon[j] - epsilon[i]); } - + } while (maxabsLHSRE > req_prec); return(true); @@ -147,21 +146,21 @@ namespace JSC { -} // namespace JSC +} // namespace ABACUS int main () { DP g_int = 0.1; - + int Nlevels = 10; - + Vect_DP epsilon (Nlevels); for (int i = 0; i < Nlevels; ++i) epsilon[i] = -0.5 * (Nlevels - 1.0) + i; - + DP req_prec = 1.0e-10; - + Vect_CX S (2.0, Nlevels); // Initial conditions: @@ -182,7 +181,7 @@ int main () Vect leftroot (true, Nlevels); - + //for (int j = Nlevels/2; j < Nlevels; ++j) leftroot[j] = true; leftroot[0] = 0; @@ -202,9 +201,6 @@ int main () cout << leftroot << endl; for (int j = 0; j < Nlevels; ++j) S[j] *= g_int; cout << S << endl; - + return(0); } - - - diff --git a/src/SCAN/Descendents.cc b/src/SCAN/Descendents.cc index 0cc3dd2..d1f3ee2 100644 --- a/src/SCAN/Descendents.cc +++ b/src/SCAN/Descendents.cc @@ -2,30 +2,30 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- File: Descendents.cc -Purpose: New implementation of state scanning: +Purpose: New implementation of state scanning: functions to descend down hierarchy of states. - + ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -namespace JSC { +namespace ABACUS { Vect Descendent_States_with_iK_Stepped_Up (string ScanIx2_label, const Vect >& OriginIx2, const Vect >& BaseScanIx2, const Vect& Ix2_min, const Vect& Ix2_max, bool disperse_only_current_exc, bool preserve_nexc) { //cout << "Up start" << endl; // Given an OriginIx2 and a BaseScanIx2 (by which we mean a set of Ix2 providing a basis for scanning), - // this function returns a vector of the labels of the states obtained by each allowable + // this function returns a vector of the labels of the states obtained by each allowable // one-step increase of the quantum numbers. // Rules for moving quantum numbers: @@ -47,9 +47,9 @@ namespace JSC { do { exclevel++; if (exclevel == ScanIx2.size()) { // there isn't a single right-moving quantum number in ScanIx2 - break; + break; } - for (int alpha = 0; alpha < ScanIx2[exclevel].size(); ++alpha) + for (int alpha = 0; alpha < ScanIx2[exclevel].size(); ++alpha) if (ScanIx2[exclevel][alpha] > BaseScanIx2[exclevel][alpha]) { excindex = alpha; excfound = true; @@ -61,20 +61,20 @@ namespace JSC { //cout << "exclevel = " << exclevel << endl; //cout << "excindex = " << excindex << endl; - // The quantum numbers which we can move right are thus those + // The quantum numbers which we can move right are thus those // with (j < exclevel) and (j == exclelev and alpha <= excindex) int ndesc_possible = 1; if (!disperse_only_current_exc) { ndesc_possible = 0; - for (int j = 0; j <= JSC::min(exclevel, ScanIx2.size() -1); ++j) ndesc_possible += ScanIx2[j].size(); + for (int j = 0; j <= ABACUS::min(exclevel, ScanIx2.size() -1); ++j) ndesc_possible += ScanIx2[j].size(); } // Now construct the actual descendents: Vect desclabelfound (ndesc_possible); int ndesc_found = 0; - if (!disperse_only_current_exc && !preserve_nexc) + if (!disperse_only_current_exc && !preserve_nexc) // List descendents with a new excitation at a lower level: // this can only create an additional ph pair for (int j = 0; j < exclevel; ++j) @@ -89,7 +89,7 @@ namespace JSC { ndesc_found++; } } - + // List descendents with a new excitation at exclevel: if (exclevel < ScanIx2.size()) { // excfound == true, excindex is now guaranteed < ScanIx2[exclevel].size() int alphamin = (disperse_only_current_exc ? excindex : 0); @@ -107,8 +107,8 @@ namespace JSC { // The descendent is acceptable if disperse_only_current_exc == true, // or if preserve_nexc == true and nexc labels match, // or if preserve_nexc == false and nexc labels don't match: - //if (!disperse_only_current_exc && (BaseScanIx2[exclevel].includes(ScanIx2[exclevel][alpha] + 2) != (Extract_nexc_Label(desclabelfound[ndesc_found]).compare(Extract_nexc_Label(ScanIx2_label)) == 0))) JSCerror("Inconsistency in check in Descendents"); - if (disperse_only_current_exc + //if (!disperse_only_current_exc && (BaseScanIx2[exclevel].includes(ScanIx2[exclevel][alpha] + 2) != (Extract_nexc_Label(desclabelfound[ndesc_found]).compare(Extract_nexc_Label(ScanIx2_label)) == 0))) ABACUSerror("Inconsistency in check in Descendents"); + if (disperse_only_current_exc //|| (preserve_nexc == BaseScanIx2[exclevel].includes(ScanIx2[exclevel][alpha] + 2))) || (preserve_nexc == (Extract_nexc_Label(desclabelfound[ndesc_found]).compare(Extract_nexc_Label(ScanIx2_label)) == 0))) ndesc_found++; @@ -133,7 +133,7 @@ namespace JSC { { //cout << "Down start" << endl; // Given an OriginIx2 and a BaseScanIx2 (by which we mean a set of Ix2 providing a basis for scanning), - // this function returns a vector of the labels of the states obtained by each allowable + // this function returns a vector of the labels of the states obtained by each allowable // one-step decrease of the quantum numbers. // Rules for moving quantum numbers: @@ -157,9 +157,9 @@ namespace JSC { do { exclevel++; if (exclevel == ScanIx2.size()) { // there isn't a single left-moving quantum number in ScanIx2 - break; + break; } - for (int alpha = ScanIx2[exclevel].size() - 1; alpha >= 0; --alpha) { + for (int alpha = ScanIx2[exclevel].size() - 1; alpha >= 0; --alpha) { //cout << exclevel << "\t" << alpha << "\t" << ScanIx2[exclevel][alpha] << "\t" << BaseScanIx2[exclevel][alpha] << "\t" << (ScanIx2[exclevel][alpha] < BaseScanIx2[exclevel][alpha]) << endl; if (ScanIx2[exclevel][alpha] < BaseScanIx2[exclevel][alpha]) { excindex = alpha; @@ -169,26 +169,26 @@ namespace JSC { } } while (!excfound); // If we haven't found an excitation, then exclevel == ScanIx2.size() and excindex = 0; - //if (!excfound) excindex = ScanIx2[exclevel].size() - 1; + //if (!excfound) excindex = ScanIx2[exclevel].size() - 1; //cout << "exclevel = " << exclevel << endl; //cout << "excindex = " << excindex << endl; - // The quantum numbers which we can move left are thus those + // The quantum numbers which we can move left are thus those // with (j < exclevel) and (j == exclelev and alpha >= excindex) - + int ndesc_possible = 1; if (!disperse_only_current_exc) { ndesc_possible = 0; - for (int j = 0; j <= JSC::min(exclevel, ScanIx2.size() - 1); ++j) ndesc_possible += ScanIx2[j].size(); + for (int j = 0; j <= ABACUS::min(exclevel, ScanIx2.size() - 1); ++j) ndesc_possible += ScanIx2[j].size(); } // Now construct the actual descendents: Vect desclabelfound (ndesc_possible); int ndesc_found = 0; - if (!disperse_only_current_exc && !preserve_nexc) + if (!disperse_only_current_exc && !preserve_nexc) // List descendents with a new excitation at a lower level: for (int j = 0; j < exclevel; ++j) for (int alpha = 0; alpha < ScanIx2[j].size(); ++alpha) { @@ -202,7 +202,7 @@ namespace JSC { ndesc_found++; } } - + // List descendents with a new excitation at exclevel: if (exclevel < ScanIx2.size()) { // excfound == true, excindex is now guaranteed < ScanIx2[exclevel].size() int alphamin = (disperse_only_current_exc ? excindex : excindex + 1); @@ -216,7 +216,7 @@ namespace JSC { desclabelfound[ndesc_found] = Return_State_Label (ScanIx2, OriginIx2); ScanIx2[exclevel][alpha] += 2; //cout << "\tTesting .compare: " << Extract_nexc_Label(desclabelfound[ndesc_found]) << "\t" << Extract_nexc_Label(ScanIx2_label) << "\t" << (Extract_nexc_Label(desclabelfound[ndesc_found]).compare(Extract_nexc_Label(ScanIx2_label)) == 0) << "\tpreserve_nexc: " << preserve_nexc << endl; - if (disperse_only_current_exc + if (disperse_only_current_exc //|| (preserve_nexc == BaseScanIx2[exclevel].includes(ScanIx2[exclevel][alpha] - 2))) || (preserve_nexc == (Extract_nexc_Label(desclabelfound[ndesc_found]).compare(Extract_nexc_Label(ScanIx2_label)) == 0))) //|| (preserve_nexc == strcmp(Extract_nexc_Label(desclabelfound[ndesc_found]), Extract_nexc_Label(ScanIx2_label)))) @@ -229,7 +229,7 @@ namespace JSC { Vect desclabelfound_resized(ndesc_found); for (int idesc = 0; idesc < ndesc_found; ++idesc) desclabelfound_resized[idesc] = desclabelfound[idesc]; - + //cout << "Down done" << endl; //return(descIx2found); //return(desclabelfound); @@ -255,8 +255,8 @@ namespace JSC { // For symmetric state descending: - Vect Descendent_States_with_iK_Stepped_Up_rightIx2only - (string ScanIx2_label, const Vect >& OriginIx2, const Vect >& BaseScanIx2, + Vect Descendent_States_with_iK_Stepped_Up_rightIx2only + (string ScanIx2_label, const Vect >& OriginIx2, const Vect >& BaseScanIx2, const Vect& Ix2_min, const Vect& Ix2_max, bool disperse_only_current_exc, bool preserve_nexc) { // This function raises an Ix2 in the right half of ScanIx2, and does the symmetric lowering in the lower half. @@ -276,9 +276,9 @@ namespace JSC { do { exclevel++; if (exclevel == ScanIx2.size()) { // there isn't a single right-moving quantum number in ScanIx2 - break; + break; } - for (int alpha = (ScanIx2[exclevel].size() + 1)/2; alpha < ScanIx2[exclevel].size(); ++alpha) + for (int alpha = (ScanIx2[exclevel].size() + 1)/2; alpha < ScanIx2[exclevel].size(); ++alpha) if (ScanIx2[exclevel][alpha] > BaseScanIx2[exclevel][alpha]) { excindex = alpha; excfound = true; @@ -289,20 +289,20 @@ namespace JSC { //cout << "exclevel = " << exclevel << "\t" << "excindex = " << excindex << endl; - // The quantum numbers which we can move right are thus those + // The quantum numbers which we can move right are thus those // with (j < exclevel) and (j == exclelev and alpha <= excindex) int ndesc_possible = 1; if (!disperse_only_current_exc) { ndesc_possible = 0; - for (int j = 0; j <= JSC::min(exclevel, ScanIx2.size() -1); ++j) ndesc_possible += ScanIx2[j].size(); + for (int j = 0; j <= ABACUS::min(exclevel, ScanIx2.size() -1); ++j) ndesc_possible += ScanIx2[j].size(); } // Now construct the actual descendents: Vect desclabelfound (ndesc_possible); int ndesc_found = 0; - if (!disperse_only_current_exc && !preserve_nexc) + if (!disperse_only_current_exc && !preserve_nexc) // List descendents with a new excitation at a lower level: // this can only create an additional ph pair for (int j = 0; j < exclevel; ++j) @@ -323,7 +323,7 @@ namespace JSC { // List descendents with a new excitation at exclevel: if (exclevel < ScanIx2.size()) { // excfound == true, excindex is now guaranteed < ScanIx2[exclevel].size() int alphamin = (disperse_only_current_exc ? excindex : 0); - alphamin = JSC::max((ScanIx2[exclevel].size() + 1)/2, alphamin); + alphamin = ABACUS::max((ScanIx2[exclevel].size() + 1)/2, alphamin); int alphamax = (disperse_only_current_exc ? excindex : excindex - 1); //for (int alpha = 0; alpha <= excindex; ++alpha) { //cout << "alphamin = " << alphamin << "\talphamax = " << alphamax << endl; @@ -344,8 +344,8 @@ namespace JSC { // The descendent is acceptable if disperse_only_current_exc == true, // or if preserve_nexc == true and nexc labels match, // or if preserve_nexc == false and nexc labels don't match: - //if (!disperse_only_current_exc && (BaseScanIx2[exclevel].includes(ScanIx2[exclevel][alpha] + 2) != (Extract_nexc_Label(desclabelfound[ndesc_found]).compare(Extract_nexc_Label(ScanIx2_label)) == 0))) JSCerror("Inconsistency in check in Descendents"); - if (disperse_only_current_exc + //if (!disperse_only_current_exc && (BaseScanIx2[exclevel].includes(ScanIx2[exclevel][alpha] + 2) != (Extract_nexc_Label(desclabelfound[ndesc_found]).compare(Extract_nexc_Label(ScanIx2_label)) == 0))) ABACUSerror("Inconsistency in check in Descendents"); + if (disperse_only_current_exc //|| (preserve_nexc == BaseScanIx2[exclevel].includes(ScanIx2[exclevel][alpha] + 2))) || (preserve_nexc == (Extract_nexc_Label(desclabelfound[ndesc_found]).compare(Extract_nexc_Label(ScanIx2_label)) == 0))) ndesc_found++; @@ -368,8 +368,8 @@ namespace JSC { } - Vect Descendent_States_with_iK_Stepped_Down_rightIx2only - (string ScanIx2_label, const Vect >& OriginIx2, const Vect >& BaseScanIx2, + Vect Descendent_States_with_iK_Stepped_Down_rightIx2only + (string ScanIx2_label, const Vect >& OriginIx2, const Vect >& BaseScanIx2, const Vect& Ix2_min, const Vect& Ix2_max, bool disperse_only_current_exc, bool preserve_nexc) { Vect > ScanIx2 = Return_Ix2_from_Label (ScanIx2_label, OriginIx2); @@ -383,9 +383,9 @@ namespace JSC { do { exclevel++; if (exclevel == ScanIx2.size()) { // there isn't a single left-moving quantum number in ScanIx2 - break; + break; } - for (int alpha = ScanIx2[exclevel].size() - 1; alpha >= (ScanIx2[exclevel].size() + 1)/2 ; --alpha) { + for (int alpha = ScanIx2[exclevel].size() - 1; alpha >= (ScanIx2[exclevel].size() + 1)/2 ; --alpha) { //cout << exclevel << "\t" << alpha << "\t" << ScanIx2[exclevel][alpha] << "\t" << BaseScanIx2[exclevel][alpha] << "\t" << (ScanIx2[exclevel][alpha] < BaseScanIx2[exclevel][alpha]) << endl; if (ScanIx2[exclevel][alpha] < BaseScanIx2[exclevel][alpha]) { excindex = alpha; @@ -395,26 +395,26 @@ namespace JSC { } } while (!excfound); // If we haven't found an excitation, then exclevel == ScanIx2.size() and excindex = 0; - //if (!excfound) excindex = ScanIx2[exclevel].size() - 1; + //if (!excfound) excindex = ScanIx2[exclevel].size() - 1; //cout << "exclevel = " << exclevel << endl; //cout << "excindex = " << excindex << endl; - // The quantum numbers which we can move left are thus those + // The quantum numbers which we can move left are thus those // with (j < exclevel) and (j == exclevel and alpha >= excindex) - + int ndesc_possible = 1; if (!disperse_only_current_exc) { ndesc_possible = 0; - for (int j = 0; j <= JSC::min(exclevel, ScanIx2.size() - 1); ++j) ndesc_possible += ScanIx2[j].size(); + for (int j = 0; j <= ABACUS::min(exclevel, ScanIx2.size() - 1); ++j) ndesc_possible += ScanIx2[j].size(); } // Now construct the actual descendents: Vect desclabelfound (ndesc_possible); int ndesc_found = 0; - if (!disperse_only_current_exc && !preserve_nexc) + if (!disperse_only_current_exc && !preserve_nexc) // List descendents with a new excitation at a lower level: for (int j = 0; j < exclevel; ++j) for (int alpha = (ScanIx2[j].size() + 1)/2; alpha < ScanIx2[j].size(); ++alpha) { @@ -430,11 +430,11 @@ namespace JSC { ndesc_found++; } } - + // List descendents with a new excitation at exclevel: if (exclevel < ScanIx2.size()) { // excfound == true, excindex is now guaranteed < ScanIx2[exclevel].size() int alphamin = (disperse_only_current_exc ? excindex : excindex + 1); - alphamin = JSC::max((ScanIx2[exclevel].size() + 1)/2, alphamin); + alphamin = ABACUS::max((ScanIx2[exclevel].size() + 1)/2, alphamin); int alphamax = (disperse_only_current_exc ? excindex : ScanIx2[exclevel].size() - 1); //for (int alpha = ScanIx2[exclevel].size() - 1; alpha >= excindex; --alpha) { for (int alpha = alphamax; alpha >= alphamin; --alpha) { @@ -447,7 +447,7 @@ namespace JSC { ScanIx2[exclevel][alpha] += 2; ScanIx2[exclevel][ScanIx2[exclevel].size() - 1 - alpha] -= 2; //cout << "\tTesting .compare: " << Extract_nexc_Label(desclabelfound[ndesc_found]) << "\t" << Extract_nexc_Label(ScanIx2_label) << "\t" << (Extract_nexc_Label(desclabelfound[ndesc_found]).compare(Extract_nexc_Label(ScanIx2_label)) == 0) << "\tpreserve_nexc: " << preserve_nexc << endl; - if (disperse_only_current_exc + if (disperse_only_current_exc //|| (preserve_nexc == BaseScanIx2[exclevel].includes(ScanIx2[exclevel][alpha] - 2))) || (preserve_nexc == (Extract_nexc_Label(desclabelfound[ndesc_found]).compare(Extract_nexc_Label(ScanIx2_label)) == 0))) //|| (preserve_nexc == strcmp(Extract_nexc_Label(desclabelfound[ndesc_found]), Extract_nexc_Label(ScanIx2_label)))) @@ -460,7 +460,7 @@ namespace JSC { Vect desclabelfound_resized(ndesc_found); for (int idesc = 0; idesc < ndesc_found; ++idesc) desclabelfound_resized[idesc] = desclabelfound[idesc]; - + //cout << "Down done" << endl; //return(descIx2found); //return(desclabelfound); @@ -526,7 +526,7 @@ namespace JSC { } // Specialization for Lieb-Liniger case: - Vect Descendent_States_with_iK_Stepped_Up_rightIx2only + Vect Descendent_States_with_iK_Stepped_Up_rightIx2only (string ScanIx2_label, const LiebLin_Bethe_State& OriginState, bool disperse_only_current_exc, bool preserve_nexc) { Vect > OriginIx2here(1); @@ -542,7 +542,7 @@ namespace JSC { return(Descendent_States_with_iK_Stepped_Up_rightIx2only (ScanIx2_label, OriginIx2here, BaseScanIx2here, Ix2_min, Ix2_max, disperse_only_current_exc, preserve_nexc)); } - Vect Descendent_States_with_iK_Stepped_Down_rightIx2only + Vect Descendent_States_with_iK_Stepped_Down_rightIx2only (string ScanIx2_label, const LiebLin_Bethe_State& OriginState, bool disperse_only_current_exc, bool preserve_nexc) { Vect > OriginIx2here(1); @@ -560,101 +560,101 @@ namespace JSC { // Specializations for Heis states: - Vect Descendent_States_with_iK_Stepped_Up + Vect Descendent_States_with_iK_Stepped_Up (string ScanIx2_label, const Heis_Bethe_State& OriginState, bool disperse_only_current_exc, bool preserve_nexc) { return(Descendent_States_with_iK_Stepped_Up (ScanIx2_label, OriginState.Ix2, OriginState.Ix2, OriginState.base.Ix2_min, OriginState.base.Ix2_max, disperse_only_current_exc, preserve_nexc)); } - Vect Descendent_States_with_iK_Stepped_Down + Vect Descendent_States_with_iK_Stepped_Down (string ScanIx2_label, const Heis_Bethe_State& OriginState, bool disperse_only_current_exc, bool preserve_nexc) { return(Descendent_States_with_iK_Stepped_Down (ScanIx2_label, OriginState.Ix2, OriginState.Ix2, OriginState.base.Ix2_min, OriginState.base.Ix2_max, disperse_only_current_exc, preserve_nexc)); } - Vect Descendent_States_with_iK_Preserved + Vect Descendent_States_with_iK_Preserved (string ScanIx2_label, const Heis_Bethe_State& OriginState, bool disperse_only_current_exc_up, bool preserve_nexc_up, bool disperse_only_current_exc_down, bool preserve_nexc_down) { return(Descendent_States_with_iK_Preserved (ScanIx2_label, OriginState.Ix2, OriginState.Ix2, OriginState.base.Ix2_min, OriginState.base.Ix2_max, disperse_only_current_exc_up, preserve_nexc_up, disperse_only_current_exc_down, preserve_nexc_down)); } - Vect Descendent_States_with_iK_Stepped_Up_rightIx2only + Vect Descendent_States_with_iK_Stepped_Up_rightIx2only (string ScanIx2_label, const Heis_Bethe_State& OriginState, bool disperse_only_current_exc, bool preserve_nexc) { return(Descendent_States_with_iK_Stepped_Up_rightIx2only (ScanIx2_label, OriginState.Ix2, OriginState.Ix2, OriginState.base.Ix2_min, OriginState.base.Ix2_max, disperse_only_current_exc, preserve_nexc)); } - Vect Descendent_States_with_iK_Stepped_Down_rightIx2only + Vect Descendent_States_with_iK_Stepped_Down_rightIx2only (string ScanIx2_label, const Heis_Bethe_State& OriginState, bool disperse_only_current_exc, bool preserve_nexc) { return(Descendent_States_with_iK_Stepped_Down_rightIx2only (ScanIx2_label, OriginState.Ix2, OriginState.Ix2, OriginState.base.Ix2_min, OriginState.base.Ix2_max, disperse_only_current_exc, preserve_nexc)); } - + Vect Is_Good_New_Hole_Position (const Vect >& OriginIx2, State_Label_Data currentdata, int exclevel_newph) { // Given a state, returns the acceptable new hole positions. - - + + // Define the objects for the newstatedata: Vect type_new = currentdata.type; Vect M_new = currentdata.M; Vect nexc_new = currentdata.nexc; - nexc_new[exclevel_newph] += 1; // we drill one more particle-hole pair at this level + nexc_new[exclevel_newph] += 1; // we drill one more particle-hole pair at this level int index_new = (currentdata.nexc[exclevel_newph] + 1)/2; // we put the new p-h pair at index index_new. - + //int ntypespresent = ScanIx2.size(); int ntypespresent = currentdata.type.size(); Vect > Ix2old_new(ntypespresent); Vect > Ix2exc_new(ntypespresent); - for (int it = 0; it < ntypespresent; ++it) Ix2old_new[it] = Vect(JSC::max(nexc_new[it],1)); - for (int it = 0; it < ntypespresent; ++it) Ix2exc_new[it] = Vect(JSC::max(nexc_new[it],1)); - + for (int it = 0; it < ntypespresent; ++it) Ix2old_new[it] = Vect(ABACUS::max(nexc_new[it],1)); + for (int it = 0; it < ntypespresent; ++it) Ix2exc_new[it] = Vect(ABACUS::max(nexc_new[it],1)); + // Copy earlier data in: for (int it = 0; it < ntypespresent; ++it) { for (int i = 0; i < currentdata.nexc[it]; ++i) { - Ix2old_new[it][i + (it == exclevel_newph && i >= index_new)] = currentdata.Ix2old[it][i]; - Ix2exc_new[it][i + (it == exclevel_newph && i >= index_new)] = currentdata.Ix2exc[it][i]; + Ix2old_new[it][i + (it == exclevel_newph && i >= index_new)] = currentdata.Ix2old[it][i]; + Ix2exc_new[it][i + (it == exclevel_newph && i >= index_new)] = currentdata.Ix2exc[it][i]; } } - + //cout << "Here 1" << endl; - + State_Label_Data descdatanewph (type_new, M_new, nexc_new, Ix2old_new, Ix2exc_new); - + // We now look for all possible hole positions, // the allowable ones being either at the edge of a block, or next to an existing hole excitation, // under the condition of obeying the `towards the block center' rule. - Vect isgoodnewholepos(false, OriginIx2[descdatanewph.type[exclevel_newph] ].size()); - + Vect isgoodnewholepos(false, OriginIx2[descdatanewph.type[exclevel_newph] ].size()); + for (int ih = 0; ih < OriginIx2[descdatanewph.type[exclevel_newph] ].size(); ++ih) { - + int candidateIx2old = OriginIx2[descdatanewph.type[exclevel_newph] ][ih]; - + // candidateIx2old is an acceptable position for the new hole provided the following conditions are fulfilled: // A- it is in OriginIx2 - // B- it follows the ordering rule, i.e. it sits in the middle of previous particle excitations, + // B- it follows the ordering rule, i.e. it sits in the middle of previous particle excitations, // namely between Ix2old[index_new - 1] (if this exists) and Ix2old[index_new] (if this exists) - // C- it is next to an OriginIx2 vacancy or immediately right of Ix2old[index_new - 1] (if this exists) - // or immediately left of Ix2old[index_new] (if this exists) - // D- it does not break the `towards the center' rule - // (it will break the rule at this point if it is created away from an OriginIx2 boundary (and thus next to a preexisting excitation), + // C- it is next to an OriginIx2 vacancy or immediately right of Ix2old[index_new - 1] (if this exists) + // or immediately left of Ix2old[index_new] (if this exists) + // D- it does not break the `towards the center' rule + // (it will break the rule at this point if it is created away from an OriginIx2 boundary (and thus next to a preexisting excitation), // and if this excitation and it are not in the same sideblock (in other words: if there is a sideblock boundary between them) - + //cout << "candidateIx2old " << candidateIx2old << " being tested" << endl; // A if (!OriginIx2[descdatanewph.type[exclevel_newph] ].includes (candidateIx2old)) { // is not contained in OriginIx2 //cout << "candidateIx2old " << candidateIx2old << " rejected for reason A" << endl; - continue; + continue; } - + // B1 - if (currentdata.nexc[exclevel_newph] > 0 + if (currentdata.nexc[exclevel_newph] > 0 && candidateIx2old <= currentdata.Ix2old[exclevel_newph][index_new - 1]) { // there is at least one hole exc to the left, and the candidate position isn't right of Ix2old[index_new - 1] //cout << "candidateIx2old " << candidateIx2old << " rejected for reason B1" << endl; continue; } - + // B2 if (currentdata.nexc[exclevel_newph] > 1 && candidateIx2old >= currentdata.Ix2old[exclevel_newph][index_new]) { @@ -663,12 +663,12 @@ namespace JSC { continue; } - // C- it is next to an OriginIx2 vacancy or immediately right of Ix2old[index_new - 1] (if this exists) - // or immediately left of Ix2old[index_new] (if this exists) - if (!(!OriginIx2[descdatanewph.type[exclevel_newph] ].includes (candidateIx2old + 2) || !OriginIx2[descdatanewph.type[exclevel_newph] ].includes (candidateIx2old - 2)) + // C- it is next to an OriginIx2 vacancy or immediately right of Ix2old[index_new - 1] (if this exists) + // or immediately left of Ix2old[index_new] (if this exists) + if (!(!OriginIx2[descdatanewph.type[exclevel_newph] ].includes (candidateIx2old + 2) || !OriginIx2[descdatanewph.type[exclevel_newph] ].includes (candidateIx2old - 2)) // doesn't sit next to an OriginIx2 vacancy && (currentdata.nexc[exclevel_newph] == 0 || candidateIx2old != currentdata.Ix2old[exclevel_newph][index_new - 1] + 2) - // doesn't sit immediately right of first hole excitation to the left + // doesn't sit immediately right of first hole excitation to the left && (currentdata.nexc[exclevel_newph] <= 1 || candidateIx2old != currentdata.Ix2old[exclevel_newph][index_new] - 2) // doesn't sit immediately left of first hole excitation to the right ) { @@ -677,9 +677,9 @@ namespace JSC { } // D- it does not break the `towards the center' rule - // In other words, if created away from a block boundary but next to a preexisting hole, + // In other words, if created away from a block boundary but next to a preexisting hole, // must be in same sideblock as this particle: - + // Determine the size of the block of OriginIx2 in which this hole sits: int nroccupiedtoleft = 0; while (OriginIx2[descdatanewph.type[exclevel_newph] ].includes (candidateIx2old -2*(nroccupiedtoleft + 1))) @@ -687,40 +687,40 @@ namespace JSC { int nroccupiedtoright = 0; while (OriginIx2[descdatanewph.type[exclevel_newph] ].includes (candidateIx2old +2*(nroccupiedtoright + 1))) nroccupiedtoright++; - + // We can determine whether the new hole would be left- or right-moving bool hole_candidate_is_left_moving = nroccupiedtoleft >= nroccupiedtoright; bool hole_candidate_is_right_moving = nroccupiedtoleft < nroccupiedtoright; - - if (hole_candidate_is_left_moving + + if (hole_candidate_is_left_moving && (currentdata.nexc[exclevel_newph] > 0 && candidateIx2old == currentdata.Ix2old[exclevel_newph][index_new - 1] + 2) // it is created to the right of a preexisting hole excitation && OriginIx2[descdatanewph.type[exclevel_newph] ].includes (candidateIx2old + 2) // and is not sitting at the boundary && (currentdata.nexc[exclevel_newph] <= 1 || candidateIx2old != currentdata.Ix2old[exclevel_newph][index_new] - 2) // and is not sitting just left of another preexisting hole excitation which is also left moving - ) + ) { //cout << "candidateIx2old " << candidateIx2old << " rejected for reason D1" << endl; continue; - } - - if (hole_candidate_is_right_moving + } + + if (hole_candidate_is_right_moving && (currentdata.nexc[exclevel_newph] > 1 && candidateIx2old == currentdata.Ix2old[exclevel_newph][index_new] - 2) // it is created to the left of a preexisting hole excitation && OriginIx2[descdatanewph.type[exclevel_newph] ].includes (candidateIx2old - 2) // and is not sitting at the boundary && (currentdata.nexc[exclevel_newph] == 0 || candidateIx2old != currentdata.Ix2old[exclevel_newph][index_new - 1] + 2) // and is not sitting just right of another preexisting hole excitation which is also right moving - ) + ) { //cout << "candidateIx2old " << candidateIx2old << " rejected for reason D2" << endl; continue; - } - - + } + + // If we have reached this point, candidateIx2old is acceptable. - + isgoodnewholepos[ih] = true; - + } // for (int ih return(isgoodnewholepos); @@ -731,7 +731,7 @@ namespace JSC { //Vect Descendents (const Bethe_State& ScanState, string type_required) - Vect Descendents (string ScanStateLabel, const Vect >& ScanIx2, const Vect >& OriginIx2, + Vect Descendents (string ScanStateLabel, const Vect >& ScanIx2, const Vect >& OriginIx2, const Vect& Ix2_min, const Vect& Ix2_max, int type_required) { // This generates descendents for a fixed base. @@ -749,23 +749,23 @@ namespace JSC { //cout << "\tCalling Descendents for type = " << type_required << endl; bool cinbreaks = false; - - // Number of descendents: + + // Number of descendents: //int ndesc_possible = (type_required == 0 ? 1 : ScanState.base.charge * 2); // upper bound guess; should be refined. //int ndesc_possible = (type_required == 0 ? 1 : 2* ScanIx2[0].size() * 2 * ScanIx2[0].size()); // upper bound guess; should be refined int ndesc_possible = 1; if (type_required == 1 || type_required == 2) { for (int i = 0; i < ScanIx2.size(); ++i) - ndesc_possible = JSC::max (ndesc_possible, 2* ScanIx2[i].size() * 2 * ScanIx2[i].size()); // inexact, should be refined + ndesc_possible = ABACUS::max (ndesc_possible, 2* ScanIx2[i].size() * 2 * ScanIx2[i].size()); // inexact, should be refined } //cout << "ndesc_possible = " << ndesc_possible << endl; - + //cout << "OriginIx2.size() = " << OriginIx2.size() << endl; //for (int i = 0; i < OriginIx2.size(); ++i) cout << "i = " << i << "\tOriginIx2[i].size() = " << OriginIx2[i].size() << endl; //for (int i = 0; i < OriginIx2.size(); ++i) cout << "i = " << i << "\tOriginIx2[i] = " << OriginIx2[i] << endl; //cout << "OriginIx2 = " << endl; //cout << OriginIx2 << endl; - + Vect desclabelfound (ndesc_possible); Vect desctypefound (ndesc_possible); int ndesc_found = 0; @@ -790,9 +790,9 @@ namespace JSC { if (type_required == 0) { - // We move the inner(right)most hole of the highest excited level one more step towards + // We move the inner(right)most hole of the highest excited level one more step towards // the center of the block of Ix2 vacancies in which it sits. - + // Is there already an excitation at level 0? If so, move inner(right)most particle one step further. if (currentdata.nexc[0] > 0) { @@ -816,7 +816,7 @@ namespace JSC { if (newholepos != currentdata.Ix2old[exclevel][innerindex] // we have successfully moved the hole && !currentdata.Ix2old[exclevel].includes(newholepos) // new hole position is not already taken - ) + ) { // we have found a descendent descdata.Ix2old[exclevel][innerindex] = newholepos; desclabelfound[ndesc_found] = Return_State_Label (descdata, OriginIx2); @@ -844,9 +844,9 @@ namespace JSC { //cout << "exclevel = " << exclevel << endl; //cout << "currentdata.nexc[exclevel] = " << currentdata.nexc[exclevel] << endl; - // We move the inner(right)most particle of the highest excited level one more step towards + // We move the inner(right)most particle of the highest excited level one more step towards // the center of the block of Ix2 vacancies in which it sits. - + // Is there already an excitation at level 0? If so, move inner(right)most particle one step further. if (currentdata.nexc[exclevel] > 0) { @@ -868,7 +868,7 @@ namespace JSC { if (partpos_is_right_of_all_OriginIx2) nremptytoright = (Ix2_max[descdata.type[exclevel] ] - partpos)/2; else while (!OriginIx2[descdata.type[exclevel] ].includes (partpos +2*(nremptytoright + 1))) nremptytoright++; - + if (!partpos_is_left_of_all_OriginIx2 && (partpos_is_right_of_all_OriginIx2 || nremptytoleft - nremptytoright + 2 < 0)) partpos += 2; else if (!partpos_is_right_of_all_OriginIx2 && (partpos_is_left_of_all_OriginIx2 || nremptytoleft - nremptytoright - 2 >= 0)) partpos -= 2; @@ -877,7 +877,7 @@ namespace JSC { && !currentdata.Ix2exc[exclevel].includes(partpos) // new particle position is not already taken && partpos >= Ix2_min[descdata.type[exclevel] ] && partpos <= Ix2_max[descdata.type[exclevel] ] - ) + ) { // we have found a descendent descdata.Ix2exc[exclevel][innerindex] = partpos; desclabelfound[ndesc_found] = Return_State_Label (descdata, OriginIx2); @@ -895,12 +895,12 @@ namespace JSC { if (cinbreaks) { char a; cin >> a;} } - } // if (currentdata.nexc[exclevel] > 0) + } // if (currentdata.nexc[exclevel] > 0) } // if (type_required == 1) - + if (type_required == 2) { // Now add a new p-h pair at the inner(right)most position, at each level from exclevel upwards, @@ -917,21 +917,21 @@ namespace JSC { Vect type_new = currentdata.type; Vect M_new = currentdata.M; Vect nexc_new = currentdata.nexc; - nexc_new[exclevel_newph] += 1; // we drill one more particle-hole pair at this level + nexc_new[exclevel_newph] += 1; // we drill one more particle-hole pair at this level int index_new = (currentdata.nexc[exclevel_newph] + 1)/2; // we put the new p-h pair at index index_new. - + //int ntypespresent = ScanIx2.size(); int ntypespresent = currentdata.type.size(); Vect > Ix2old_new(ntypespresent); Vect > Ix2exc_new(ntypespresent); - for (int it = 0; it < ntypespresent; ++it) Ix2old_new[it] = Vect(JSC::max(nexc_new[it],1)); - for (int it = 0; it < ntypespresent; ++it) Ix2exc_new[it] = Vect(JSC::max(nexc_new[it],1)); + for (int it = 0; it < ntypespresent; ++it) Ix2old_new[it] = Vect(ABACUS::max(nexc_new[it],1)); + for (int it = 0; it < ntypespresent; ++it) Ix2exc_new[it] = Vect(ABACUS::max(nexc_new[it],1)); // Copy earlier data in: for (int it = 0; it < ntypespresent; ++it) { for (int i = 0; i < currentdata.nexc[it]; ++i) { - Ix2old_new[it][i + (it == exclevel_newph && i >= index_new)] = currentdata.Ix2old[it][i]; - Ix2exc_new[it][i + (it == exclevel_newph && i >= index_new)] = currentdata.Ix2exc[it][i]; + Ix2old_new[it][i + (it == exclevel_newph && i >= index_new)] = currentdata.Ix2old[it][i]; + Ix2exc_new[it][i + (it == exclevel_newph && i >= index_new)] = currentdata.Ix2exc[it][i]; } } @@ -942,23 +942,23 @@ namespace JSC { // We now look for all possible hole positions, // the allowable ones being either at the edge of a block, or next to an existing hole excitation, // under the condition of obeying the `towards the block center' rule. - + Vect isgoodnewholepos = Is_Good_New_Hole_Position (OriginIx2, currentdata, exclevel_newph); - /* The function call above replaces the whole block here: - Vect isgoodnewholepos(false, OriginIx2[descdatanewph.type[exclevel_newph] ].size()); + /* The function call above replaces the whole block here: + Vect isgoodnewholepos(false, OriginIx2[descdatanewph.type[exclevel_newph] ].size()); for (int ih = 0; ih < OriginIx2[descdatanewph.type[exclevel_newph] ].size(); ++ih) { - + int candidateIx2old = OriginIx2[descdatanewph.type[exclevel_newph] ][ih]; // candidateIx2old is an acceptable position for the new hole provided the following conditions are fulfilled: // A- it is in OriginIx2 - // B- it follows the ordering rule, i.e. it sits in the middle of previous particle excitations, + // B- it follows the ordering rule, i.e. it sits in the middle of previous particle excitations, // namely between Ix2old[index_new - 1] (if this exists) and Ix2old[index_new] (if this exists) - // C- it is next to an OriginIx2 vacancy or immediately right of Ix2old[index_new - 1] (if this exists) - // or immediately left of Ix2old[index_new] (if this exists) - // D- it does not break the `towards the center' rule - // (it will break the rule at this point if it is created away from an OriginIx2 boundary (and thus next to a preexisting excitation), + // C- it is next to an OriginIx2 vacancy or immediately right of Ix2old[index_new - 1] (if this exists) + // or immediately left of Ix2old[index_new] (if this exists) + // D- it does not break the `towards the center' rule + // (it will break the rule at this point if it is created away from an OriginIx2 boundary (and thus next to a preexisting excitation), // and if this excitation and it are not in the same sideblock (in other words: if there is a sideblock boundary between them) //cout << "candidateIx2old " << candidateIx2old << " being tested" << endl; @@ -966,17 +966,17 @@ namespace JSC { if (!OriginIx2[descdatanewph.type[exclevel_newph] ].includes (candidateIx2old)) { // is not contained in OriginIx2 //cout << "candidateIx2old " << candidateIx2old << " rejected for reason A" << endl; - continue; + continue; } - + // B1 - if (currentdata.nexc[exclevel_newph] > 0 + if (currentdata.nexc[exclevel_newph] > 0 && candidateIx2old <= currentdata.Ix2old[exclevel_newph][index_new - 1]) { // there is at least one hole exc to the left, and the candidate position isn't right of Ix2old[index_new - 1] //cout << "candidateIx2old " << candidateIx2old << " rejected for reason B1" << endl; continue; } - + // B2 if (currentdata.nexc[exclevel_newph] > 1 && candidateIx2old >= currentdata.Ix2old[exclevel_newph][index_new]) { @@ -984,22 +984,22 @@ namespace JSC { //cout << "candidateIx2old " << candidateIx2old << " rejected for reason B2" << endl; continue; } - - // C- it is next to an OriginIx2 vacancy or immediately right of Ix2old[index_new - 1] (if this exists) - // or immediately left of Ix2old[index_new] (if this exists) - if (!(!OriginIx2[descdatanewph.type[exclevel_newph] ].includes (candidateIx2old + 2) || !OriginIx2[descdatanewph.type[exclevel_newph] ].includes (candidateIx2old - 2)) + + // C- it is next to an OriginIx2 vacancy or immediately right of Ix2old[index_new - 1] (if this exists) + // or immediately left of Ix2old[index_new] (if this exists) + if (!(!OriginIx2[descdatanewph.type[exclevel_newph] ].includes (candidateIx2old + 2) || !OriginIx2[descdatanewph.type[exclevel_newph] ].includes (candidateIx2old - 2)) // doesn't sit next to an OriginIx2 vacancy && (currentdata.nexc[exclevel_newph] == 0 || candidateIx2old != currentdata.Ix2old[exclevel_newph][index_new - 1] + 2) - // doesn't sit immediately right of first hole excitation to the left + // doesn't sit immediately right of first hole excitation to the left && (currentdata.nexc[exclevel_newph] <= 1 || candidateIx2old != currentdata.Ix2old[exclevel_newph][index_new] - 2) // doesn't sit immediately left of first hole excitation to the right ) { //cout << "candidateIx2old " << candidateIx2old << " rejected for reason C" << endl; continue; } - + // D- it does not break the `towards the center' rule - // In other words, if created away from a block boundary but next to a preexisting hole, + // In other words, if created away from a block boundary but next to a preexisting hole, // must be in same sideblock as this particle: // Determine the size of the block of OriginIx2 in which this hole sits: @@ -1014,40 +1014,40 @@ namespace JSC { bool hole_candidate_is_left_moving = nroccupiedtoleft >= nroccupiedtoright; bool hole_candidate_is_right_moving = nroccupiedtoleft < nroccupiedtoright; - if (hole_candidate_is_left_moving + if (hole_candidate_is_left_moving && (currentdata.nexc[exclevel_newph] > 0 && candidateIx2old == currentdata.Ix2old[exclevel_newph][index_new - 1] + 2) // it is created to the right of a preexisting hole excitation && OriginIx2[descdatanewph.type[exclevel_newph] ].includes (candidateIx2old + 2) // and is not sitting at the boundary && (currentdata.nexc[exclevel_newph] <= 1 || candidateIx2old != currentdata.Ix2old[exclevel_newph][index_new] - 2) // and is not sitting just left of another preexisting hole excitation which is also left moving - ) + ) { //cout << "candidateIx2old " << candidateIx2old << " rejected for reason D1" << endl; continue; - } + } - if (hole_candidate_is_right_moving + if (hole_candidate_is_right_moving && (currentdata.nexc[exclevel_newph] > 1 && candidateIx2old == currentdata.Ix2old[exclevel_newph][index_new] - 2) // it is created to the left of a preexisting hole excitation && OriginIx2[descdatanewph.type[exclevel_newph] ].includes (candidateIx2old - 2) // and is not sitting at the boundary && (currentdata.nexc[exclevel_newph] == 0 || candidateIx2old != currentdata.Ix2old[exclevel_newph][index_new - 1] + 2) // and is not sitting just right of another preexisting hole excitation which is also right moving - ) + ) { //cout << "candidateIx2old " << candidateIx2old << " rejected for reason D2" << endl; continue; - } + } // If we have reached this point, candidateIx2old is acceptable. - + isgoodnewholepos[ih] = true; } // for (int ih */ - - + + //cout << "Here 2" << endl; //cout << "\tisgoodnewholdpos = " << isgoodnewholepos << endl; @@ -1061,34 +1061,34 @@ namespace JSC { // cout << currentdata.Ix2exc[exclevel_newph] << endl; //} - // We now look for all possible particle positions, + // We now look for all possible particle positions, // the allowable ones being either at the edge of a block, or next to an existing particle excitation, // under the condition of obeying the `towards the block center' rule. - + // Determine range of possible Ix2exc: int Ix2excmin = ScanIx2[descdatanewph.type[exclevel_newph] ].min() - 2; - if (currentdata.nexc[exclevel_newph] > 0) - Ix2excmin = JSC::min (Ix2excmin, currentdata.Ix2exc[exclevel_newph][index_new - 1] + 2); - Ix2excmin = JSC::max (Ix2excmin, Ix2_min[descdatanewph.type[exclevel_newph] ]); + if (currentdata.nexc[exclevel_newph] > 0) + Ix2excmin = ABACUS::min (Ix2excmin, currentdata.Ix2exc[exclevel_newph][index_new - 1] + 2); + Ix2excmin = ABACUS::max (Ix2excmin, Ix2_min[descdatanewph.type[exclevel_newph] ]); int Ix2excmax = ScanIx2[descdatanewph.type[exclevel_newph] ].max() + 2; - if (currentdata.nexc[exclevel_newph] > 1) - Ix2excmax = JSC::max (Ix2excmax, currentdata.Ix2exc[exclevel_newph][index_new] - 2); - Ix2excmax = JSC::min (Ix2excmax, Ix2_max[descdatanewph.type[exclevel_newph] ]); - + if (currentdata.nexc[exclevel_newph] > 1) + Ix2excmax = ABACUS::max (Ix2excmax, currentdata.Ix2exc[exclevel_newph][index_new] - 2); + Ix2excmax = ABACUS::min (Ix2excmax, Ix2_max[descdatanewph.type[exclevel_newph] ]); + Vect isgoodnewpartpos(false, (Ix2excmax - Ix2excmin)/2 + 1); - + for (int candidateIx2exc = Ix2excmin; candidateIx2exc <= Ix2excmax; candidateIx2exc += 2) { //cout << "Here a" << endl; // candidateIx2exc is an acceptable position for the new particle provided the following conditions are fulfilled: // A- it is not in OriginIx2 - // B- it follows the ordering rule, i.e. it sits in the middle of previous particle excitations, + // B- it follows the ordering rule, i.e. it sits in the middle of previous particle excitations, // namely between Ix2exc[index_new - 1] (if this exists) and Ix2exc[index_new] (if this exists) - // C- it is next to an OriginIx2 or immediately right of Ix2exc[index_new - 1] (if this exists) - // or immediately left of Ix2exc[index_new] (if this exists) - // D- it does not break the `towards the center' rule - // (it will break the rule at this point if it is created away from an OriginIx2 boundary (and thus next to a preexisting excitation), + // C- it is next to an OriginIx2 or immediately right of Ix2exc[index_new - 1] (if this exists) + // or immediately left of Ix2exc[index_new] (if this exists) + // D- it does not break the `towards the center' rule + // (it will break the rule at this point if it is created away from an OriginIx2 boundary (and thus next to a preexisting excitation), // and if this excitation and it are not in the same sideblock (in other words: if there is a sideblock boundary between them) //cout << "candidateIx2exc " << candidateIx2exc << " being tested" << endl; @@ -1096,19 +1096,19 @@ namespace JSC { if (OriginIx2[descdatanewph.type[exclevel_newph] ].includes (candidateIx2exc)) { // is contained in OriginIx2 //cout << "candidateIx2exc " << candidateIx2exc << " rejected for reason A" << endl; - continue; + continue; } - + //cout << "Here b" << endl; // B1 - if (currentdata.nexc[exclevel_newph] > 0 + if (currentdata.nexc[exclevel_newph] > 0 && candidateIx2exc <= currentdata.Ix2exc[exclevel_newph][index_new - 1]) { // there is at least one particle exc to the left, and the candidate position isn't right of Ix2exc[index_new - 1] //cout << "candidateIx2exc " << candidateIx2exc << " rejected for reason B1" << endl; continue; } - + //cout << "Here c" << endl; // B2 @@ -1118,26 +1118,26 @@ namespace JSC { //cout << "candidateIx2exc " << candidateIx2exc << " rejected for reason B2" << endl; continue; } - + //cout << "Here d" << endl; - // C- it is next to an OriginIx2 or immediately right of Ix2exc[index_new - 1] (if this exists) - // or immediately left of Ix2exc[index_new] (if this exists) - if (!(OriginIx2[descdatanewph.type[exclevel_newph] ].includes (candidateIx2exc + 2) || OriginIx2[descdatanewph.type[exclevel_newph] ].includes (candidateIx2exc - 2)) + // C- it is next to an OriginIx2 or immediately right of Ix2exc[index_new - 1] (if this exists) + // or immediately left of Ix2exc[index_new] (if this exists) + if (!(OriginIx2[descdatanewph.type[exclevel_newph] ].includes (candidateIx2exc + 2) || OriginIx2[descdatanewph.type[exclevel_newph] ].includes (candidateIx2exc - 2)) // doesn't sit next to an OriginIx2 && (currentdata.nexc[exclevel_newph] == 0 || candidateIx2exc != currentdata.Ix2exc[exclevel_newph][index_new - 1] + 2) - // doesn't sit immediately right of first particle excitation to the left + // doesn't sit immediately right of first particle excitation to the left && (currentdata.nexc[exclevel_newph] <= 1 || candidateIx2exc != currentdata.Ix2exc[exclevel_newph][index_new] - 2) // doesn't sit immediately left of first particle excitation to the right ) { //cout << "candidateIx2exc " << candidateIx2exc << " rejected for reason C" << endl; continue; } - + //cout << "Here e" << endl; // D- it does not break the `towards the center' rule - // In other words, if created away from a block boundary but next to a preexisting particle, + // In other words, if created away from a block boundary but next to a preexisting particle, // must be in same sideblock as this particle: // Determine the size of the block of OriginIx2 vacancies in which this particle sits: @@ -1152,54 +1152,54 @@ namespace JSC { else while (!OriginIx2[descdatanewph.type[exclevel_newph] ].includes (candidateIx2exc +2*(nremptytoright + 1))) nremptytoright++; // We can determine whether the new particle would be left- or right-moving - bool candidate_is_left_moving = candidate_is_left_of_all_OriginIx2 + bool candidate_is_left_moving = candidate_is_left_of_all_OriginIx2 || (!candidate_is_right_of_all_OriginIx2 && nremptytoleft >= nremptytoright); - bool candidate_is_right_moving = candidate_is_right_of_all_OriginIx2 + bool candidate_is_right_moving = candidate_is_right_of_all_OriginIx2 || (!candidate_is_left_of_all_OriginIx2 && nremptytoleft < nremptytoright); // Consistency checks: - if (candidate_is_left_moving && candidate_is_right_moving) JSCerror("New particle moving left and right at same time"); - if (!candidate_is_left_moving && !candidate_is_right_moving) JSCerror("New particle not moving either left or right"); + if (candidate_is_left_moving && candidate_is_right_moving) ABACUSerror("New particle moving left and right at same time"); + if (!candidate_is_left_moving && !candidate_is_right_moving) ABACUSerror("New particle not moving either left or right"); //cout << "Here f" << endl; - if (candidate_is_left_moving + if (candidate_is_left_moving && (currentdata.nexc[exclevel_newph] > 0 && candidateIx2exc == currentdata.Ix2exc[exclevel_newph][index_new - 1] + 2) // it is created to the right of a preexisting particle excitation && !OriginIx2[descdatanewph.type[exclevel_newph] ].includes (candidateIx2exc + 2) // and is not sitting at the boundary && (currentdata.nexc[exclevel_newph] <= 1 || candidateIx2exc != currentdata.Ix2exc[exclevel_newph][index_new] - 2) // and is not sitting just left of another preexisting particle excitation which is also left moving - ) + ) { //cout << "candidateIx2exc " << candidateIx2exc << " rejected for reason D1" << endl; continue; - } + } //cout << "Here g" << endl; - if (candidate_is_right_moving + if (candidate_is_right_moving && (currentdata.nexc[exclevel_newph] > 1 && candidateIx2exc == currentdata.Ix2exc[exclevel_newph][index_new] - 2) // it is created to the left of a preexisting particle excitation && !OriginIx2[descdatanewph.type[exclevel_newph] ].includes (candidateIx2exc - 2) // and is not sitting at the boundary && (currentdata.nexc[exclevel_newph] == 0 || candidateIx2exc != currentdata.Ix2exc[exclevel_newph][index_new - 1] + 2) // and is not sitting just right of another preexisting particle excitation which is also right moving - ) + ) { //cout << "candidateIx2exc " << candidateIx2exc << " rejected for reason D2" << endl; continue; - } + } //cout << "\tFound a possible exc position at " << candidateIx2exc << endl; // If we have reached this point, candidateIx2exc is acceptable. // Immediately construct all descendents with this part position: - + //cout << "Here h" << endl; // We now select the hole position closest to left or right: int ihclosestleft = -1; int ihclosestright = -1; - for (int ih = 0; ih < OriginIx2[descdatanewph.type[exclevel_newph] ].size(); ++ih) - if (isgoodnewholepos[ih]) + for (int ih = 0; ih < OriginIx2[descdatanewph.type[exclevel_newph] ].size(); ++ih) + if (isgoodnewholepos[ih]) { /* //cout << "Here alpha" << endl; @@ -1227,12 +1227,12 @@ namespace JSC { if (OriginIx2[descdatanewph.type[exclevel_newph] ][ih] - candidateIx2exc < 0) // new hole is left of new particle if (ihclosestleft == -1 // we hadn't found a hole previously || ihclosestleft >= 0 // we had aleady found a new hole to the left - && OriginIx2[descdatanewph.type[exclevel_newph] ][ih] > OriginIx2[descdatanewph.type[exclevel_newph] ][ihclosestleft]) // + && OriginIx2[descdatanewph.type[exclevel_newph] ][ih] > OriginIx2[descdatanewph.type[exclevel_newph] ][ihclosestleft]) // ihclosestleft = ih; if (OriginIx2[descdatanewph.type[exclevel_newph] ][ih] - candidateIx2exc > 0) // new hole is right of new particle if (ihclosestright == -1 // we hadn't found a hole previously || ihclosestright >= 0 // we had aleady found a new hole to the right - && OriginIx2[descdatanewph.type[exclevel_newph] ][ih] < OriginIx2[descdatanewph.type[exclevel_newph] ][ihclosestright]) // + && OriginIx2[descdatanewph.type[exclevel_newph] ][ih] < OriginIx2[descdatanewph.type[exclevel_newph] ][ihclosestright]) // ihclosestright = ih; } // if (isgoodnewholepos[ih]) // for ih @@ -1244,7 +1244,7 @@ namespace JSC { desctypefound[ndesc_found] = 2; ndesc_found++; } - + if (ihclosestright >= 0) { // Found a descendent with new hole to right of new particle descdatanewph.Ix2old[exclevel_newph][index_new] = OriginIx2[descdatanewph.type[exclevel_newph] ][ihclosestright]; descdatanewph.Ix2exc[exclevel_newph][index_new] = candidateIx2exc; @@ -1259,7 +1259,7 @@ namespace JSC { } // for (int exclevel_newph) - } // if (type_required == 2) + } // if (type_required == 2) if (type_required == 3) { @@ -1286,7 +1286,7 @@ namespace JSC { // Start by finding the possible hole positions of the state without the innermost p-h pair: Vect nexc_new = currentdata.nexc; - if (currentdata.nexc[exclevel] < 1) JSCerror("Should not call type 3 descendent if there are no ph exc at exclevel"); + if (currentdata.nexc[exclevel] < 1) ABACUSerror("Should not call type 3 descendent if there are no ph exc at exclevel"); nexc_new[exclevel] -= 1; // we remove the innermost ph pair int innerindex = currentdata.nexc[exclevel]/2; // index of ph pair we remove @@ -1294,19 +1294,19 @@ namespace JSC { int ntypespresent = currentdata.type.size(); Vect > Ix2old_new(ntypespresent); Vect > Ix2exc_new(ntypespresent); - for (int it = 0; it < ntypespresent; ++it) Ix2old_new[it] = Vect(JSC::max(nexc_new[it],1)); - for (int it = 0; it < ntypespresent; ++it) Ix2exc_new[it] = Vect(JSC::max(nexc_new[it],1)); - + for (int it = 0; it < ntypespresent; ++it) Ix2old_new[it] = Vect(ABACUS::max(nexc_new[it],1)); + for (int it = 0; it < ntypespresent; ++it) Ix2exc_new[it] = Vect(ABACUS::max(nexc_new[it],1)); + // Copy earlier data in: for (int it = 0; it < ntypespresent; ++it) { for (int i = 0; i < nexc_new[it]; ++i) { - Ix2old_new[it][i] = currentdata.Ix2old[it][i + (it == exclevel && i >= innerindex)]; - Ix2exc_new[it][i] = currentdata.Ix2exc[it][i + (it == exclevel && i >= innerindex)]; + Ix2old_new[it][i] = currentdata.Ix2old[it][i + (it == exclevel && i >= innerindex)]; + Ix2exc_new[it][i] = currentdata.Ix2exc[it][i + (it == exclevel && i >= innerindex)]; } } State_Label_Data data_latest_ph_removed (currentdata.type, currentdata.M, nexc_new, Ix2old_new, Ix2exc_new); - + Vect isgoodnewholepos = Is_Good_New_Hole_Position (OriginIx2, data_latest_ph_removed, exclevel); // Move hole further away from its corresponding particle, preserving the direction @@ -1359,7 +1359,7 @@ namespace JSC { // Specialization for LiebLin gas: Vect Descendents (const LiebLin_Bethe_State& ScanState, const LiebLin_Bethe_State& OriginState, int type_required) - //string ScanStateLabel, const Vect >& ScanIx2, const Vect >& OriginIx2, + //string ScanStateLabel, const Vect >& ScanIx2, const Vect >& OriginIx2, // const Vect& Ix2_min, const Vect& Ix2_max, int type_required) { Vect > ScanIx2here(1); @@ -1372,7 +1372,7 @@ namespace JSC { Ix2_max[0] = LIEBLIN_Ix2_MAX; Vect desc_found; - // If the state is an outer skeleton, we use a slightly modified OriginIx2 (in which the outermost + // If the state is an outer skeleton, we use a slightly modified OriginIx2 (in which the outermost // rapidities at level zero are put to the outer skeleton position convention) for computing the descendents. //if (ScanState.Is_Outer_Skeleton()) { // since the state is an outer skeleton, we first modify the OriginIx2 @@ -1383,7 +1383,7 @@ namespace JSC { OriginIx2here[0][0] = LIEBLIN_Ix2_MIN + (ScanState.N % 2) + 3; // The OriginIx2here endpoints are set one step internally next to the Skeleton position conventions OriginIx2here[0][OriginState.N - 1] = LIEBLIN_Ix2_MAX - (ScanState.N % 2) - 3; // Obtain the descendends using this modified OriginIx2: - Vect desc_mod = Descendents (ScanState.label, ScanIx2here, OriginIx2here, Ix2_min, Ix2_max, type_required); + Vect desc_mod = Descendents (ScanState.label, ScanIx2here, OriginIx2here, Ix2_min, Ix2_max, type_required); // Translate the obtained descendends into ones corresponding to OriginIx2: LiebLin_Bethe_State LabellingState = ScanState; for (int idesc = 0; idesc < desc_mod.size(); ++idesc) { @@ -1395,7 +1395,7 @@ namespace JSC { return(desc_mod); */ // Construct and descend a state with 2 less particles: - if (ScanState.N < 3) JSCerror("Skeleton descendent logic at fixed iK not implemented for N < 3."); + if (ScanState.N < 3) ABACUSerror("Skeleton descendent logic at fixed iK not implemented for N < 3."); LiebLin_Bethe_State ReducedScanState (ScanState.c_int, ScanState.L, ScanState.N - 2); LiebLin_Bethe_State ReducedOriginState (ScanState.c_int, ScanState.L, ScanState.N - 2); for (int i = 0; i < ScanState.N - 2; ++i) { @@ -1403,8 +1403,8 @@ namespace JSC { ReducedOriginState.Ix2[i] = OriginState.Ix2[i+1]; } ReducedScanState.Set_Label_from_Ix2 (ReducedOriginState.Ix2); - Vect desc_mod = Descendents (ReducedScanState, ReducedOriginState, type_required); - // Now translate results back to ScanState: we return outer skeleton states + Vect desc_mod = Descendents (ReducedScanState, ReducedOriginState, type_required); + // Now translate results back to ScanState: we return outer skeleton states LiebLin_Bethe_State LabellingState = ScanState; for (int idesc = 0; idesc < desc_mod.size(); ++idesc) { ReducedScanState.Set_to_Label (desc_mod[idesc], ReducedOriginState.Ix2); @@ -1422,9 +1422,9 @@ namespace JSC { } // If not outer skeleton, just return straight descendents - else desc_found = Descendents (ScanState.label, ScanIx2here, OriginIx2here, Ix2_min, Ix2_max, type_required); + else desc_found = Descendents (ScanState.label, ScanIx2here, OriginIx2here, Ix2_min, Ix2_max, type_required); - //return(Descendents (ScanState.label, ScanIx2here, OriginIx2here, Ix2_min, Ix2_max, type_required)); + //return(Descendents (ScanState.label, ScanIx2here, OriginIx2here, Ix2_min, Ix2_max, type_required)); return(desc_found); } @@ -1447,7 +1447,7 @@ namespace JSC { //Descendent_Data Descendents (const LiebLin_Bethe_State& ScanState, const LiebLin_Bethe_State& OriginState, int type_required) { - // THESE EXPLANATIONS ARE DEPRECATED + // THESE EXPLANATIONS ARE DEPRECATED // A given state is labeled by pairs (Ix2old, Ix2exc) of modified quantum numbers, // say (Ix2old[0][0], Ix2exc[0][0]) ... (Ix2old[0][nexc[0] ], Ix2exc[0][nexc[0] ]) at level 0 @@ -1469,7 +1469,7 @@ namespace JSC { // IMPORTANT NOTE: THE IMPLEMENTATION IS FOR NOW ONLY VALID FOR LIEB-LINIGER. // The logic is however extensible to the case of multiple base levels. - // Number of descendents: + // Number of descendents: int ndesc_possible = (type_required == 0 ? 1 : ScanState.N * 2); // upper bound guess; should be refined. Vect desclabelfound (ndesc_possible); Vect desctypefound (ndesc_possible); @@ -1497,22 +1497,22 @@ namespace JSC { int nroccupiedtoleft = 0; while (OriginState.Ix2.includes (currentdata.Ix2old[0][innerindex] -2*(nroccupiedtoleft + 1))) //while (ScanState.Ix2.includes (currentdata.Ix2old[0][innerindex] -2*(nroccupiedtoleft + 1))) - //while (OriginState.Ix2.includes (currentdata.Ix2old[0][innerindex] -2*(nroccupiedtoleft + 1)) + //while (OriginState.Ix2.includes (currentdata.Ix2old[0][innerindex] -2*(nroccupiedtoleft + 1)) //&& ScanState.Ix2.includes (currentdata.Ix2old[0][innerindex] -2*(nroccupiedtoleft + 1))) - ////&& !currentdata.Ix2old[0].includes(currentdata.Ix2old[0][innerindex] -2*(nroccupiedtoleft + 1))) + ////&& !currentdata.Ix2old[0].includes(currentdata.Ix2old[0][innerindex] -2*(nroccupiedtoleft + 1))) nroccupiedtoleft++; int nroccupiedtoright = 0; while (OriginState.Ix2.includes (currentdata.Ix2old[0][innerindex] +2*(nroccupiedtoright + 1))) //while (ScanState.Ix2.includes (currentdata.Ix2old[0][innerindex] +2*(nroccupiedtoright + 1))) //while (OriginState.Ix2.includes (currentdata.Ix2old[0][innerindex] +2*(nroccupiedtoright + 1)) // && ScanState.Ix2.includes (currentdata.Ix2old[0][innerindex] +2*(nroccupiedtoright + 1))) - ////&& !currentdata.Ix2old[0].includes(currentdata.Ix2old[0][innerindex] +2*(nroccupiedtoright + 1))) + ////&& !currentdata.Ix2old[0].includes(currentdata.Ix2old[0][innerindex] +2*(nroccupiedtoright + 1))) nroccupiedtoright++; //cout << "Here b" << endl; //cout << "holeIx2 = " << currentdata.Ix2old[0][innerindex] << "\tnroccupiedtoleft = " << nroccupiedtoleft << "\tnroccupiedtoright = " << nroccupiedtoright << endl; - // Move the hole further in: + // Move the hole further in: // Requirements for end configuration: hole must be further near middle, so // if nroccupiedtoleft < nroccupiedtoright, move towards the right. // if nroccupiedtoleft > nroccupiedtoright, move towards the left. @@ -1527,7 +1527,7 @@ namespace JSC { if (newholepos != currentdata.Ix2old[0][innerindex] // we have successfully moved the hole && !currentdata.Ix2old[0].includes(newholepos) // new hole position is not already taken - ) + ) { // we have found a descendent descdata.Ix2old[0][innerindex] = newholepos; desclabelfound[ndesc_found] = Return_State_Label (descdata, OriginState.Ix2); @@ -1579,9 +1579,9 @@ namespace JSC { // Move until we get a consistent new configuration: // First, this quantum number was not already occupied // Second, this quantum number does not annihilate one of the holes: - //while (ScanState.Ix2.includes(newpartpos) || currentdata.Ix2old[0].includes(newpartpos)) + //while (ScanState.Ix2.includes(newpartpos) || currentdata.Ix2old[0].includes(newpartpos)) // newpartpos += (currentdata.Ix2exc[0][innerindex] > currentdata.Ix2old[0][innerindex] ? 2 : -2); - + // If this new particle position is to the right of the Ix2exc of one index lower, we've got a descendent: //if (innerindex == 0 || newpartpos > currentdata.Ix2exc[0][innerindex - 1] // //&& abs(newpartpos) <= 13 // TEMPORARY LIMIT: INDUCE FINITE NR OF STATES @@ -1593,13 +1593,13 @@ namespace JSC { //desclabelfound[ndesc_found] = Return_State_Label (descdata, OriginState.Ix2); //desctypefound[ndesc_found++] = 1; //} - + } //if (currentdata.nexc[0] > 0) } // if (type_required == 1) if (type_required == 2) { - // Now add a new p-h pair at the inner(right)most position, scanning the hole position immediately + // Now add a new p-h pair at the inner(right)most position, scanning the hole position immediately // but putting the particle to the first available left and right positions (if any). // type_required == 2 means that the hole must be either at the edge of an OriginIx2 domain, or next to an existing hole. @@ -1610,33 +1610,33 @@ namespace JSC { Vect nexc_new = currentdata.nexc; nexc_new[0] += 1; // we drill one more particle-hole pair at level 0 int index_new = (currentdata.nexc[0] + 1)/2; // we put the new p-h pair at index index_new. - + int ntypespresent = 1; // only one type for LiebLin Vect > Ix2old_new(ntypespresent); Vect > Ix2exc_new(ntypespresent); - for (int it = 0; it < ntypespresent; ++it) Ix2old_new[it] = Vect(JSC::max(nexc_new[it],1)); - for (int it = 0; it < ntypespresent; ++it) Ix2exc_new[it] = Vect(JSC::max(nexc_new[it],1)); - + for (int it = 0; it < ntypespresent; ++it) Ix2old_new[it] = Vect(ABACUS::max(nexc_new[it],1)); + for (int it = 0; it < ntypespresent; ++it) Ix2exc_new[it] = Vect(ABACUS::max(nexc_new[it],1)); + // Copy earlier data in: for (int it = 0; it < ntypespresent; ++it) { for (int i = 0; i < currentdata.nexc[it]; ++i) { - Ix2old_new[it][i + (i >= index_new)] = currentdata.Ix2old[it][i]; - Ix2exc_new[it][i + (i >= index_new)] = currentdata.Ix2exc[it][i]; + Ix2old_new[it][i + (i >= index_new)] = currentdata.Ix2old[it][i]; + Ix2exc_new[it][i + (i >= index_new)] = currentdata.Ix2exc[it][i]; } //cout << "current Ix2old: " << currentdata.Ix2old[0] << endl; //cout << "current Ix2exc: " << currentdata.Ix2exc[0] << endl; //cout << "allocated new Ix2old: " << Ix2old_new[0] << endl; //cout << "allocated new Ix2exc: " << Ix2exc_new[0] << endl; } - + State_Label_Data descdatanewph (type_new, M_new, nexc_new, Ix2old_new, Ix2exc_new); - + //cout << "\ttype: " << descdatanewph.type << endl; //cout << "\tM: " << descdatanewph.M << endl; //cout << "\tnexc: " << descdatanewph.nexc << endl; //cout << "\tIx2old: " << descdatanewph.Ix2old[0] << endl; //cout << "\tIx2new: " << descdatanewph.Ix2exc[0] << endl; - + // Now find all the possible positions for the new hole: // The new hole should be between Ix2old_new[0][innerindex - 1] and Ix2old_new[0][innerindex + 1] // if those exist (i.e., modulo lack of constraint at the left/right boundaries). @@ -1656,22 +1656,22 @@ namespace JSC { || ScanState.Ix2[i] > currentdata.Ix2old[0][index_new - 1]) && (currentdata.nexc[0] <= 1 // at most one p-h in state so no right boundary for new hole; index_new <= 1 || ScanState.Ix2[i] < currentdata.Ix2old[0][index_new]) - //&& (currentdata.nexc[0] == 0 || !currentdata.Ix2exc[0].includes(ScanState.Ix2[i])) + //&& (currentdata.nexc[0] == 0 || !currentdata.Ix2exc[0].includes(ScanState.Ix2[i])) // new hole is not one of the already existing p excitations // FULFILLED BY ABOVE CONDITIONS IF EXC ARE ORDERED - //&& (!ScanState.Ix2.includes(ScanState.Ix2[i] - 2) || !ScanState.Ix2.includes(ScanState.Ix2[i] + 2)) + //&& (!ScanState.Ix2.includes(ScanState.Ix2[i] - 2) || !ScanState.Ix2.includes(ScanState.Ix2[i] + 2)) && ( - // New hole must be created on the boundary of an OriginState Ix2 domain, + // New hole must be created on the boundary of an OriginState Ix2 domain, // or next to a preexisting hole in the domain. - (!OriginState.Ix2.includes(ScanState.Ix2[i] - 2)) + (!OriginState.Ix2.includes(ScanState.Ix2[i] - 2)) // new hole is on the left boundary of an OriginState Ix2 domain. - || !OriginState.Ix2.includes(ScanState.Ix2[i] + 2) + || !OriginState.Ix2.includes(ScanState.Ix2[i] + 2) // new hole is on the right boundary of an OriginState Ix2 domain. //|| (currentdata.nexc[0] > 0 && ScanState.Ix2[i] == currentdata.Ix2old[0][index_new - 1] + 2) - || type_required == 2 && (currentdata.nexc[0] > 0 && nroccupiedtoleft < nroccupiedtoright + || type_required == 2 && (currentdata.nexc[0] > 0 && nroccupiedtoleft < nroccupiedtoright && ScanState.Ix2[i] == currentdata.Ix2old[0][index_new - 1] + 2) // new hole is in a left domain and immediately to the right of first hole to its left //|| (currentdata.nexc[0] > 1 && ScanState.Ix2[i] == currentdata.Ix2old[0][index_new] - 2) - || type_required == 2 && (currentdata.nexc[0] > 1 && nroccupiedtoleft >= nroccupiedtoright + || type_required == 2 && (currentdata.nexc[0] > 1 && nroccupiedtoleft >= nroccupiedtoright && ScanState.Ix2[i] == currentdata.Ix2old[0][index_new] - 2) // new hole is in a right domain and immediately to the left of first hole to its right ) @@ -1688,7 +1688,7 @@ namespace JSC { int nroccupiedtoright = 0; while (OriginState.Ix2.includes (ScanState.Ix2[i] +2*(nroccupiedtoright + 1))) nroccupiedtoright++; - + // The hole is unacceptable if it breaks the `towards the block center' rule: if (nroccupiedtoleft < nroccupiedtoright // new hole would be in left part of block && OriginState.Ix2.includes(ScanState.Ix2[i] - 2) // and is not at the boundary @@ -1703,21 +1703,21 @@ namespace JSC { if (acceptable_hole) { //cout << "Found a possible hole position at index " << i << " and Ix2 " << ScanState.Ix2[i] << endl; - + // ScanState.Ix2[i] is an allowable new hole position. - // We now look for all possible particle positions, + // We now look for all possible particle positions, // the allowable ones being either at the edge of a block, or next to an existing particle: // Find the first available particle position to the left: newpartpos = ScanState.Ix2[i] - 2; // This must be lower than the Ix2exc of one index higher (if any): - if (currentdata.nexc[0] >= 2) newpartpos = JSC::min(newpartpos, currentdata.Ix2exc[0][index_new] - 2); - // The new particle position must not already be occupied in ScanState, + if (currentdata.nexc[0] >= 2) newpartpos = ABACUS::min(newpartpos, currentdata.Ix2exc[0][index_new] - 2); + // The new particle position must not already be occupied in ScanState, // and must not be at one of the already specified holes - while (ScanState.Ix2.includes(newpartpos) + while (ScanState.Ix2.includes(newpartpos) || (currentdata.nexc[0] > 0 && currentdata.Ix2old[0].includes(newpartpos))) newpartpos -= 2; // If this new particle position is to the right of the Ix2exc of one index lower (if any), we've got a descendent: if (currentdata.nexc[0] == 0 || newpartpos > currentdata.Ix2exc[0][index_new - 1]) { @@ -1738,10 +1738,10 @@ namespace JSC { // Now find the first particle position to the right: newpartpos = ScanState.Ix2[i] + 2; // This must be higher than the Ix2exc of one index lower (if any): - if (index_new > 0) newpartpos = JSC::max(newpartpos, currentdata.Ix2exc[0][index_new - 1] + 2); - // The new particle position must not already be occupied in ScanState, + if (index_new > 0) newpartpos = ABACUS::max(newpartpos, currentdata.Ix2exc[0][index_new - 1] + 2); + // The new particle position must not already be occupied in ScanState, // and must not be at one of the already specified holes - while (ScanState.Ix2.includes(newpartpos) + while (ScanState.Ix2.includes(newpartpos) || (currentdata.nexc[0] > 0 && currentdata.Ix2old[0].includes(newpartpos))) newpartpos += 2; // If this new particle position is to the left of the Ix2exc of one index higher (if any), we've got a descendent: if (currentdata.nexc[0] <= 1 || newpartpos < currentdata.Ix2exc[0][index_new]) { @@ -1784,7 +1784,7 @@ namespace JSC { //descdata.label = desclabelfoundresized; //descdata.type = desctypefoundresized; - + return(desclabelfoundresized); //return(descdata); } @@ -1795,11 +1795,10 @@ namespace JSC { //Descendent_Data Descendents (const Heis_Bethe_State& ScanState, const Heis_Bethe_State& OriginState, int type_required); { // NOT IMPLEMENTED YET - JSCerror("Descendents for Heis not implemented yet."); + ABACUSerror("Descendents for Heis not implemented yet."); return(Vect()); } */ -} // namespace JSC - +} // namespace ABACUS diff --git a/src/SCAN/General_Scan.cc b/src/SCAN/General_Scan.cc index 822e740..bd9a6d1 100644 --- a/src/SCAN/General_Scan.cc +++ b/src/SCAN/General_Scan.cc @@ -2,7 +2,7 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -17,10 +17,12 @@ NOTE: since templated functions have to be in the same file, ***********************************************************/ -#include "JSC.h" +#include +#include "ABACUS.h" + using namespace std; -using namespace JSC; +using namespace ABACUS; string LABEL_TO_CHECK = "bla"; @@ -28,7 +30,7 @@ string LABEL_TO_CHECK = "bla"; //string LABEL_TO_CHECK = "6_2_22y32"; -namespace JSC { +namespace ABACUS { // Types of descendents: // 14 == iK stepped up, leading exc one step further (can lead to ph recombination) @@ -459,10 +461,10 @@ namespace JSC { cout << "paralevel = " << paralevel << "\trank.size() = " << rank.size() << "\tnr_processors.size() = " << nr_processors.size() << endl; cout << "rank = " << rank << endl; cout << "nr_processors = " << nr_processors << endl; - JSCerror("Inconsistent paralevel, rank or nr_processors in General_Scan."); + ABACUSerror("Inconsistent paralevel, rank or nr_processors in General_Scan."); } - if (in_parallel && !refine) JSCerror("Must refine when using parallel ABACUS++"); + if (in_parallel && !refine) ABACUSerror("Must refine when using parallel ABACUS"); DP ph_cost = Particle_Hole_Excitation_Cost (whichDSF, AveragingState); // expected cost on data_value of adding a particle-hole excitation. @@ -526,38 +528,38 @@ namespace JSC { else RAW_outfile.open(RAW_Cstr, fstream::out | fstream::app); if (RAW_outfile.fail()) { cout << RAW_Cstr << endl; - JSCerror("Could not open RAW_outfile... "); + ABACUSerror("Could not open RAW_outfile... "); } RAW_outfile.precision(16); fstream INADM_outfile; if (!refine || in_parallel) INADM_outfile.open(INADM_Cstr, fstream::out | fstream::trunc); else INADM_outfile.open(INADM_Cstr, fstream::out | fstream::app); - if (INADM_outfile.fail()) JSCerror("Could not open INADM_outfile... "); + if (INADM_outfile.fail()) ABACUSerror("Could not open INADM_outfile... "); INADM_outfile.precision(16); fstream CONV0_outfile; if (!refine || in_parallel) CONV0_outfile.open(CONV0_Cstr, fstream::out | fstream::trunc); else CONV0_outfile.open(CONV0_Cstr, fstream::out | fstream::app); - if (CONV0_outfile.fail()) JSCerror("Could not open CONV0_outfile... "); + if (CONV0_outfile.fail()) ABACUSerror("Could not open CONV0_outfile... "); CONV0_outfile.precision(16); fstream STAT_outfile; if (!refine || in_parallel) STAT_outfile.open(STAT_Cstr, fstream::out | fstream::trunc); else STAT_outfile.open(STAT_Cstr, fstream::out | fstream::app); - if (STAT_outfile.fail()) JSCerror("Could not open STAT_outfile... "); + if (STAT_outfile.fail()) ABACUSerror("Could not open STAT_outfile... "); STAT_outfile.precision(8); ofstream LOG_outfile; if (!in_parallel) { if (!refine) LOG_outfile.open(LOG_Cstr, fstream::out | fstream::trunc); else LOG_outfile.open(LOG_Cstr, fstream::out | fstream::app); - if (LOG_outfile.fail()) JSCerror("Could not open LOG_outfile... "); + if (LOG_outfile.fail()) ABACUSerror("Could not open LOG_outfile... "); LOG_outfile.precision(16); } else { // in_parallel LOG_outfile.open(LOG_Cstr, fstream::out | fstream::trunc); - if (LOG_outfile.fail()) JSCerror("Could not open LOG_outfile... "); + if (LOG_outfile.fail()) ABACUSerror("Could not open LOG_outfile... "); LOG_outfile.precision(16); //LOG_outfile << endl; } @@ -699,7 +701,7 @@ namespace JSC { //if (Force_Descent(whichDSF, ScanState, AveragingState, iKmod, Chem_Pot) && ScanState.iK - AveragingState.iK < iKmax && Sca nState.iK - AveragingState.iK > iKmin) //if (Force_Descent(whichDSF, ScanState, AveragingState, iKmod, Chem_Pot)) for (int itype = 0; itype < 15; ++itype) { - DP data_value_used = 0.1* exp(-paused_thread_data.logscale * JSC::min(0, paused_thread_data.lowest_il_with_nthreads_neq_0)); + DP data_value_used = 0.1* exp(-paused_thread_data.logscale * ABACUS::min(0, paused_thread_data.lowest_il_with_nthreads_neq_0)); if (Force_Descent(whichDSF, ScanState, AveragingState, itype, iKmod, Chem_Pot)) //data_value = 0.1* exp(-paused_thread_data.logscale * paused_thread_data.lowest_il_with_nthreads_neq_0); data_value = data_value_used; @@ -1212,7 +1214,7 @@ namespace JSC { LOG_outfile << "Latest threshold level " << paused_thread_data.lowest_il_with_nthreads_neq_0 << " " << std::scientific << setprecision(3) << exp(-paused_thread_data.logscale * paused_thread_data.lowest_il_with_nthreads_neq_0) << endl; LOG_outfile << "Resulting info: " << scan_info << endl; } - LOG_outfile << "Code version " << JSC_VERSION << ", copyright J.-S. Caux." << endl << endl; + LOG_outfile << "Code version " << ABACUS_VERSION << ", copyright J.-S. Caux." << endl << endl; LOG_outfile.close(); } @@ -1295,7 +1297,7 @@ namespace JSC { if (refine) spsfile.open(SPS_Cstr, fstream::in); else spsfile.open(SPS_Cstr, fstream::out | fstream::trunc); if (spsfile.fail()) { - cout << SPS_Cstr << endl; JSCerror("Could not open spsfile."); + cout << SPS_Cstr << endl; ABACUSerror("Could not open spsfile."); } LiebLin_Bethe_State spstate; @@ -1309,7 +1311,7 @@ namespace JSC { spsfile >> Nspsread; if (Nspsread != N) { cout << Nspsread << "\t" << N << endl; - JSCerror("Wrong number of Ix2 in saddle-point state."); + ABACUSerror("Wrong number of Ix2 in saddle-point state."); } spstate = LiebLin_Bethe_State (c_int, L, N); for (int i = 0; i < N; ++i) spsfile >> spstate.Ix2[i]; @@ -1341,7 +1343,7 @@ namespace JSC { spsfile >> Nsspsread; if (Nsspsread != Nscan) { cout << Nsspsread << "\t" << Nscan << endl; - JSCerror("Wrong number of Ix2 in scan saddle-point state."); + ABACUSerror("Wrong number of Ix2 in scan saddle-point state."); } SeedScanState = LiebLin_Bethe_State (c_int, L, Nscan); for (int i = 0; i < Nscan; ++i) spsfile >> SeedScanState.Ix2[i]; @@ -1487,7 +1489,7 @@ namespace JSC { if (whichDSF == 'Z' || whichDSF == 'z') SeedScanState = AveragingState; else if (whichDSF == 'm') SeedScanState = Remove_Particle_at_Center (AveragingState); else if (whichDSF == 'p') SeedScanState = Add_Particle_at_Center (AveragingState); - else JSCerror("Unknown whichDSF in Scan_Heis."); + else ABACUSerror("Unknown whichDSF in Scan_Heis."); //cout << "In General_Scan: SeedScanState = " << SeedScanState << endl; @@ -1512,7 +1514,7 @@ namespace JSC { if (whichDSF == 'Z' || whichDSF == 'z') SeedScanState = AveragingState; else if (whichDSF == 'm') SeedScanState = Remove_Particle_at_Center (AveragingState); else if (whichDSF == 'p') SeedScanState = Add_Particle_at_Center (AveragingState); - else JSCerror("Unknown whichDSF in Scan_Heis."); + else ABACUSerror("Unknown whichDSF in Scan_Heis."); // Now the scan itself General_Scan (whichDSF, iKmin, iKmax, AveragingState.chain.Nsites, 0.0, AveragingState, SeedScanState, defaultScanStatename, Max_Secs, target_sumrule, refine, paralevel, rank, nr_processors); @@ -1535,7 +1537,7 @@ namespace JSC { if (whichDSF == 'Z' || whichDSF == 'z') SeedScanState = AveragingState; else if (whichDSF == 'm') SeedScanState = Remove_Particle_at_Center (AveragingState); else if (whichDSF == 'p') SeedScanState = Add_Particle_at_Center (AveragingState); - else JSCerror("Unknown whichDSF in Scan_Heis."); + else ABACUSerror("Unknown whichDSF in Scan_Heis."); // Now the scan itself General_Scan (whichDSF, iKmin, iKmax, AveragingState.chain.Nsites, 0.0, AveragingState, SeedScanState, defaultScanStatename, Max_Secs, target_sumrule, refine, paralevel, rank, nr_processors); @@ -1577,7 +1579,7 @@ namespace JSC { if (whichDSF == 'Z' || whichDSF == 'z') SeedScanState = GroundState; else if (whichDSF == 'm') SeedScanState = XXZ_Bethe_State(GroundState.chain, M - 1); else if (whichDSF == 'p') SeedScanState = XXZ_Bethe_State(GroundState.chain, M + 1); - else JSCerror("Unknown whichDSF in Scan_Heis."); + else ABACUSerror("Unknown whichDSF in Scan_Heis."); // Now the scan itself General_Scan (whichDSF, iKmin, iKmax, N, 0.0, GroundState, SeedScanState, "", Max_Secs, target_sumrule, refine, paralevel, rank, nr_processors); @@ -1595,7 +1597,7 @@ namespace JSC { else if (whichDSF == 'm') SeedScanState = XXX_Bethe_State(GroundState.chain, M - 1); else if (whichDSF == 'p') SeedScanState = XXX_Bethe_State(GroundState.chain, M + 1); else if (whichDSF == 'c') SeedScanState = XXX_Bethe_State(GroundState.chain, M - 2); - else JSCerror("Unknown whichDSF in Scan_Heis."); + else ABACUSerror("Unknown whichDSF in Scan_Heis."); // Now the scan itself General_Scan (whichDSF, iKmin, iKmax, N, 0.0, GroundState, SeedScanState, "", Max_Secs, target_sumrule, refine, paralevel, rank, nr_processors); @@ -1611,13 +1613,13 @@ namespace JSC { if (whichDSF == 'Z' || whichDSF == 'z') SeedScanState = GroundState; else if (whichDSF == 'm') SeedScanState = XXZ_gpd_Bethe_State(GroundState.chain, M - 1); else if (whichDSF == 'p') SeedScanState = XXZ_gpd_Bethe_State(GroundState.chain, M + 1); - else JSCerror("Unknown whichDSF in Scan_Heis."); + else ABACUSerror("Unknown whichDSF in Scan_Heis."); // Now the scan itself General_Scan (whichDSF, iKmin, iKmax, N, 0.0, GroundState, SeedScanState, "", Max_Secs, target_sumrule, refine, paralevel, rank, nr_processors); } - else JSCerror("Delta out of range in Heis_Structure_Factor"); + else ABACUSerror("Delta out of range in Heis_Structure_Factor"); return; } @@ -1711,7 +1713,7 @@ namespace JSC { } */ /* - else JSCerror("Delta out of range in ODSLF Structure Factor"); + else ABACUSerror("Delta out of range in ODSLF Structure Factor"); return; } @@ -1779,7 +1781,7 @@ namespace JSC { if ((Delta > 0.0) && (Delta < 1.0)) { - JSCerror("Geometric quench not yet implemented for XXZ."); + ABACUSerror("Geometric quench not yet implemented for XXZ."); } else if (Delta == 1.0) { @@ -1801,13 +1803,13 @@ namespace JSC { } else if (Delta > 1.0) { - JSCerror("Geometric quench not yet implemented for XXZ_gpd."); + ABACUSerror("Geometric quench not yet implemented for XXZ_gpd."); } - else JSCerror("Delta out of range in Heis_Structure_Factor"); + else ABACUSerror("Delta out of range in Heis_Structure_Factor"); return; } */ -} // namespace JSC +} // namespace ABACUS diff --git a/src/SCAN/General_Scan_Parallel.cc b/src/SCAN/General_Scan_Parallel.cc index bcfea62..62bad54 100644 --- a/src/SCAN/General_Scan_Parallel.cc +++ b/src/SCAN/General_Scan_Parallel.cc @@ -2,31 +2,30 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- File: src/SCAN/General_Scan_Parallel.cc -Purpose: universal implementation of state scanning: +Purpose: universal implementation of state scanning: functions to descend down hierarchy of intermediate states. Parallel implementation using MPI. -NOTE: since templated functions have to be in the same file, +NOTE: since templated functions have to be in the same file, we put all scanning functions here. The externally-used functions are defined at the end of this file. - ***********************************************************/ //#include "mpi.h" -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -namespace JSC { +namespace ABACUS { //*******************************************************************// // Functions applicable to all calculations: @@ -38,14 +37,14 @@ namespace JSC { stringstream THRDIR_stringstream; string THRDIR_string; THRDIR_stringstream << prefix << "_thrdir"; - THRDIR_string = THRDIR_stringstream.str(); + THRDIR_string = THRDIR_stringstream.str(); // Load all the info about the threads, in particular the nthreads_total vector: Scan_Thread_Data thr_data(THRDIR_string, true); thr_data.Load(); // Create the different directories: - Vect THRDIRS_stringstream(nr_processors_at_newlevel); + Vect THRDIRS_stringstream(nr_processors_at_newlevel); for (int rank = 0; rank < nr_processors_at_newlevel; ++rank) { THRDIRS_stringstream[rank] << prefix << "_" << rank << "_" << nr_processors_at_newlevel << "_thrdir"; mkdir((THRDIRS_stringstream[rank].str()).c_str(), S_IRWXU | S_IRWXG | S_IRWXO); @@ -115,8 +114,8 @@ namespace JSC { SRC_string = SRC_stringstream.str(); const char* SRC_Cstr = SRC_string.c_str(); FSR_string = FSR_stringstream.str(); const char* FSR_Cstr = FSR_string.c_str(); SUM_string = SUM_stringstream.str(); const char* SUM_Cstr = SUM_string.c_str(); - - // We open and close these files (except for SUM, which we fill with a zero-valued scan_info + + // We open and close these files (except for SUM, which we fill with a zero-valued scan_info fstream RAW_file; RAW_file.open(RAW_Cstr); RAW_file.close(); fstream INADM_file; INADM_file.open(INADM_Cstr); INADM_file.close(); fstream CONV0_file; CONV0_file.open(CONV0_Cstr); CONV0_file.close(); @@ -132,20 +131,20 @@ namespace JSC { void Merge_raw_Files (string prefix, char whichDSF, int nr_processors_at_newlevel) { - // Open the original raw file: + // Open the original raw file: stringstream RAW_stringstream; string RAW_string; - //RAW_stringstream << prefix; + //RAW_stringstream << prefix; //if (whichDSF == 'Z') RAW_stringstream << ".dat"; //else RAW_stringstream << ".raw"; - RAW_stringstream << prefix << ".raw"; + RAW_stringstream << prefix << ".raw"; RAW_string = RAW_stringstream.str(); const char* RAW_Cstr = RAW_string.c_str(); fstream RAW_outfile; RAW_outfile.open(RAW_Cstr, fstream::out | fstream::app); // NB: we append !! - if (RAW_outfile.fail()) JSCerror("Could not open RAW_outfile... "); + if (RAW_outfile.fail()) ABACUSerror("Could not open RAW_outfile... "); RAW_outfile.precision(16); - // Append all other raw files to original one + // Append all other raw files to original one for (int rank = 0; rank < nr_processors_at_newlevel; ++rank) { stringstream RAW_in_stringstream; string RAW_in_string; RAW_in_stringstream << prefix << "_" << rank << "_" << nr_processors_at_newlevel << ".raw"; @@ -155,9 +154,9 @@ namespace JSC { RAW_infile.open(RAW_in_Cstr); if (RAW_infile.fail()) { //cout << RAW_in_Cstr << endl; - //JSCerror ("Could not open file."); + //ABACUSerror ("Could not open file."); continue; // if file isn't there, just continue... - } + } DP omega; int iK; @@ -192,11 +191,11 @@ namespace JSC { stringstream THRDIR_stringstream; string THRDIR_string; THRDIR_stringstream << prefix << "_thrdir"; - THRDIR_string = THRDIR_stringstream.str(); + THRDIR_string = THRDIR_stringstream.str(); Scan_Thread_Data thr_data(THRDIR_string, true); - Vect THRDIRS_stringstream(nr_processors_at_newlevel); + Vect THRDIRS_stringstream(nr_processors_at_newlevel); for (int rank = 0; rank < nr_processors_at_newlevel; ++rank) THRDIRS_stringstream[rank] << prefix << "_" << rank << "_" << nr_processors_at_newlevel << "_thrdir"; @@ -215,8 +214,8 @@ namespace JSC { thr_data.Include_Thread (il, next_threads[it].label, next_threads[it].type); } if (il == thr_data_par[rank].nlists - 1) break; - } - } + } + } // all thr_data_par are now empty // remove the nthreads.dat files from original threads directory: for (int rank = 0; rank < nr_processors_at_newlevel; ++rank) { @@ -228,7 +227,7 @@ namespace JSC { } thr_data.Save(); - + return; } @@ -237,11 +236,11 @@ namespace JSC { { Scan_State_List ScanStateList (whichDSF, SeedScanState); - ScanStateList.Populate_List(whichDSF, SeedScanState); + ScanStateList.Populate_List(whichDSF, SeedScanState); - // Open the original file: + // Open the original file: stringstream SUM_stringstream; string SUM_string; - SUM_stringstream << prefix << ".sum"; + SUM_stringstream << prefix << ".sum"; SUM_string = SUM_stringstream.str(); const char* SUM_Cstr = SUM_string.c_str(); // Load the original info: @@ -257,7 +256,7 @@ namespace JSC { if (!file_exists(SUM_in_Cstr)) continue; ScanStateList.Load_Info (SUM_in_Cstr); - + // Delete file remove(SUM_in_Cstr); @@ -274,15 +273,15 @@ namespace JSC { { // This also deletes any .fsr files at the newlevel. - // Open the original src file: + // Open the original src file: stringstream SRC_stringstream; string SRC_string; - SRC_stringstream << prefix << ".src"; + SRC_stringstream << prefix << ".src"; SRC_string = SRC_stringstream.str(); const char* SRC_Cstr = SRC_string.c_str(); // Load original info: Scan_Info scan_info; // If file is there, load it: - if (file_exists(SRC_Cstr)) scan_info.Load(SRC_Cstr); + if (file_exists(SRC_Cstr)) scan_info.Load(SRC_Cstr); Scan_Info scan_info_before = scan_info; // Load all other info: @@ -308,11 +307,11 @@ namespace JSC { // Load content of all other inadm files into main inadm: stringstream INADM_stringstream; string INADM_string; - INADM_stringstream << prefix << ".inadm"; + INADM_stringstream << prefix << ".inadm"; INADM_string = INADM_stringstream.str(); const char* INADM_Cstr = INADM_string.c_str(); ofstream INADM_outfile; INADM_outfile.open(INADM_Cstr, fstream::out | fstream::app); - if (INADM_outfile.fail()) JSCerror("Could not open INADM_outfile... "); + if (INADM_outfile.fail()) ABACUSerror("Could not open INADM_outfile... "); INADM_outfile.precision(16); for (int rank = 0; rank < nr_processors_at_newlevel; ++rank) { @@ -343,13 +342,13 @@ namespace JSC { // Load content of all other conv0 files into main inadm: stringstream CONV0_stringstream; string CONV0_string; - CONV0_stringstream << prefix << ".conv0"; + CONV0_stringstream << prefix << ".conv0"; CONV0_string = CONV0_stringstream.str(); const char* CONV0_Cstr = CONV0_string.c_str(); ofstream CONV0_outfile; CONV0_outfile.open(CONV0_Cstr, fstream::out | fstream::app); - if (CONV0_outfile.fail()) JSCerror("Could not open CONV0_outfile... "); + if (CONV0_outfile.fail()) ABACUSerror("Could not open CONV0_outfile... "); CONV0_outfile.precision(16); - + for (int rank = 0; rank < nr_processors_at_newlevel; ++rank) { stringstream CONV0_in_stringstream; string CONV0_in_string; CONV0_in_stringstream << prefix << "_" << rank << "_" << nr_processors_at_newlevel << ".conv0"; @@ -378,13 +377,13 @@ namespace JSC { // Load content of all other stat files into main: stringstream STAT_stringstream; string STAT_string; - STAT_stringstream << prefix << ".stat"; + STAT_stringstream << prefix << ".stat"; STAT_string = STAT_stringstream.str(); const char* STAT_Cstr = STAT_string.c_str(); ofstream STAT_outfile; STAT_outfile.open(STAT_Cstr, fstream::out | fstream::app); - if (STAT_outfile.fail()) JSCerror("Could not open STAT_outfile... "); + if (STAT_outfile.fail()) ABACUSerror("Could not open STAT_outfile... "); STAT_outfile.precision(16); - + for (int rank = 0; rank < nr_processors_at_newlevel; ++rank) { stringstream STAT_in_stringstream; string STAT_in_string; STAT_in_stringstream << prefix << "_" << rank << "_" << nr_processors_at_newlevel << ".stat"; @@ -417,11 +416,11 @@ namespace JSC { scan_info_refinement = scan_info; scan_info_refinement -= scan_info_before; stringstream LOG_stringstream; string LOG_string; - LOG_stringstream << prefix << ".log"; + LOG_stringstream << prefix << ".log"; LOG_string = LOG_stringstream.str(); const char* LOG_Cstr = LOG_string.c_str(); ofstream LOG_outfile; LOG_outfile.open(LOG_Cstr, fstream::out | fstream::app); - if (LOG_outfile.fail()) JSCerror("Could not open LOG_outfile... "); + if (LOG_outfile.fail()) ABACUSerror("Could not open LOG_outfile... "); LOG_outfile.precision(16); // Load content of all other log files into main log: @@ -458,10 +457,10 @@ namespace JSC { remove(FSR_in_Cstr); } - LOG_outfile << "Refining in parallel mode using " << nr_processors_at_newlevel << " processors." - << endl << "Refining info: " << scan_info_refinement + LOG_outfile << "Refining in parallel mode using " << nr_processors_at_newlevel << " processors." + << endl << "Refining info: " << scan_info_refinement << endl << "Resulting info: " << scan_info << endl; - LOG_outfile << "Code version " << JSC_VERSION << ", copyright J.-S. Caux." << endl; + LOG_outfile << "Code version " << ABACUS_VERSION << ", copyright J.-S. Caux." << endl; LOG_outfile.close(); return; @@ -471,25 +470,25 @@ namespace JSC { //****************************************************************************// // Model-specific functions: - //void Prepare_Parallel_Scan_LiebLin (char whichDSF, DP c_int, DP L, int N, int iK_UL, bool fixed_iK, int iKneeded, + //void Prepare_Parallel_Scan_LiebLin (char whichDSF, DP c_int, DP L, int N, int iK_UL, bool fixed_iK, int iKneeded, void Prepare_Parallel_Scan_LiebLin (char whichDSF, DP c_int, DP L, int N, int iKmin, int iKmax, DP kBT, - string defaultScanStatename, - //int Max_Secs, bool refine, int rank, + string defaultScanStatename, + //int Max_Secs, bool refine, int rank, int paralevel, Vect rank_lower_paralevels, Vect nr_processors_lower_paralevels, int nr_processors_at_newlevel) { - // From an existing scan, this function splits the threads into + // From an existing scan, this function splits the threads into // nr_processors_at_newlevel separate files, from which the parallel process // can be launched. - LiebLin_Bethe_State GroundState (c_int, L, N); + LiebLin_Bethe_State GroundState (c_int, L, N); // Define file name stringstream filenameprefix; - //Data_File_Name (filenameprefix, whichDSF, fixed_iK, iKneeded, GroundState, GroundState); - Data_File_Name (filenameprefix, whichDSF, iKmin, iKmax, kBT, GroundState, GroundState, defaultScanStatename); + //Data_File_Name (filenameprefix, whichDSF, fixed_iK, iKneeded, GroundState, GroundState); + Data_File_Name (filenameprefix, whichDSF, iKmin, iKmax, kBT, GroundState, GroundState, defaultScanStatename); for (int i = 0; i < paralevel - 1; ++i) filenameprefix << "_" << rank_lower_paralevels[i] << "_" << nr_processors_lower_paralevels[i]; - string prefix = filenameprefix.str(); + string prefix = filenameprefix.str(); Split_thr_Files (prefix, whichDSF, nr_processors_at_newlevel); @@ -498,16 +497,16 @@ namespace JSC { return; } - //void Wrapup_Parallel_Scan_LiebLin (char whichDSF, DP c_int, DP L, int N, int iK_UL, bool fixed_iK, int iKneeded, + //void Wrapup_Parallel_Scan_LiebLin (char whichDSF, DP c_int, DP L, int N, int iK_UL, bool fixed_iK, int iKneeded, void Wrapup_Parallel_Scan_LiebLin (char whichDSF, DP c_int, DP L, int N, int iKmin, int iKmax, DP kBT, string defaultScanStatename, - //int Max_Secs, bool refine, int rank, + //int Max_Secs, bool refine, int rank, int paralevel, Vect rank_lower_paralevels, Vect nr_processors_lower_paralevels, int nr_processors_at_newlevel) { //DP epsilon = log(L)/L; - //LiebLin_Bethe_State GroundState (c_int, L, N); + //LiebLin_Bethe_State GroundState (c_int, L, N); //LiebLin_Bethe_State spstate = Canonical_Saddle_Point_State (c_int, L, N, kBT, epsilon); //LiebLin_Bethe_State spstate = Canonical_Saddle_Point_State (c_int, L, N, kBT); @@ -522,21 +521,21 @@ namespace JSC { LiebLin_Bethe_State spstate; if (file_exists(SPS_Cstr)) { - + fstream spsfile; - spsfile.open(SPS_Cstr, fstream::in); + spsfile.open(SPS_Cstr, fstream::in); int Nspsread; - spsfile >> Nspsread; + spsfile >> Nspsread; if (Nspsread != N) { cout << Nspsread << "\t" << N << endl; - JSCerror("Wrong number of Ix2 in saddle-point state."); + ABACUSerror("Wrong number of Ix2 in saddle-point state."); } spstate = LiebLin_Bethe_State (c_int, L, N); for (int i = 0; i < N; ++i) spsfile >> spstate.Ix2[i]; - + spsfile.close(); - + spstate.Compute_All(true); } @@ -552,10 +551,10 @@ namespace JSC { // Define file name stringstream filenameprefix; - //Data_File_Name (filenameprefix, whichDSF, fixed_iK, iKneeded, GroundState, GroundState); - Data_File_Name (filenameprefix, whichDSF, iKmin, iKmax, kBT, spstate, SeedScanState, defaultScanStatename); + //Data_File_Name (filenameprefix, whichDSF, fixed_iK, iKneeded, GroundState, GroundState); + Data_File_Name (filenameprefix, whichDSF, iKmin, iKmax, kBT, spstate, SeedScanState, defaultScanStatename); for (int i = 0; i < paralevel - 1; ++i) filenameprefix << "_" << rank_lower_paralevels[i] << "_" << nr_processors_lower_paralevels[i]; - string prefix = filenameprefix.str(); + string prefix = filenameprefix.str(); // Merge raw files @@ -574,7 +573,7 @@ namespace JSC { // Evaluate f-sumrule: /* stringstream RAW_stringstream; string RAW_string; - RAW_stringstream << prefix << ".raw"; + RAW_stringstream << prefix << ".raw"; RAW_string = RAW_stringstream.str(); const char* RAW_Cstr = RAW_string.c_str(); stringstream FSR_stringstream; string FSR_string; @@ -596,55 +595,55 @@ namespace JSC { // Heisenberg: void Prepare_Parallel_Scan_Heis (char whichDSF, DP Delta, int N, int M, int iKmin, int iKmax, - //int Max_Secs, bool refine, int rank, + //int Max_Secs, bool refine, int rank, int paralevel, Vect rank_lower_paralevels, Vect nr_processors_lower_paralevels, int nr_processors_at_newlevel) { - // From an existing scan, this function splits the threads into + // From an existing scan, this function splits the threads into // nr_processors separate files, from which the parallel process // can be launched. Heis_Chain BD1(1.0, Delta, 0.0, N); Vect_INT Nrapidities_groundstate(0, BD1.Nstrings); - + Nrapidities_groundstate[0] = M; - + Heis_Base baseconfig_groundstate(BD1, Nrapidities_groundstate); - + //Ix2_Offsets baseoffsets(baseconfig_groundstate, 0ULL); // Define file name stringstream filenameprefix; if ((Delta > 0.0) && (Delta < 1.0)) { - + XXZ_Bethe_State GroundState(BD1, baseconfig_groundstate); - Data_File_Name (filenameprefix, whichDSF, iKmin, iKmax, 0.0, GroundState, GroundState, ""); + Data_File_Name (filenameprefix, whichDSF, iKmin, iKmax, 0.0, GroundState, GroundState, ""); } - + else if (Delta == 1.0) { XXX_Bethe_State GroundState(BD1, baseconfig_groundstate); - Data_File_Name (filenameprefix, whichDSF, iKmin, iKmax, 0.0, GroundState, GroundState, ""); + Data_File_Name (filenameprefix, whichDSF, iKmin, iKmax, 0.0, GroundState, GroundState, ""); } else if (Delta > 1.0) { XXZ_gpd_Bethe_State GroundState(BD1, baseconfig_groundstate); - Data_File_Name (filenameprefix, whichDSF, iKmin, iKmax, 0.0, GroundState, GroundState, ""); + Data_File_Name (filenameprefix, whichDSF, iKmin, iKmax, 0.0, GroundState, GroundState, ""); } - else JSCerror("Delta out of range in Prepare_Parallel_Scan_Heis"); + else ABACUSerror("Delta out of range in Prepare_Parallel_Scan_Heis"); for (int i = 0; i < paralevel - 1; ++i) filenameprefix << "_" << rank_lower_paralevels[i] << "_" << nr_processors_lower_paralevels[i]; - string prefix = filenameprefix.str(); + string prefix = filenameprefix.str(); Split_thr_Files (prefix, whichDSF, nr_processors_at_newlevel); - + return; } @@ -653,18 +652,18 @@ namespace JSC { int paralevel, Vect rank_lower_paralevels, Vect nr_processors_lower_paralevels, int nr_processors_at_newlevel) { - // From an existing scan, this function splits the threads into + // From an existing scan, this function splits the threads into // nr_processors separate files, from which the parallel process // can be launched. Heis_Chain BD1(1.0, Delta, 0.0, N); Vect_INT Nrapidities_groundstate(0, BD1.Nstrings); - + Nrapidities_groundstate[0] = M; - + Heis_Base baseconfig_groundstate(BD1, Nrapidities_groundstate); - + //Ix2_Offsets baseoffsets(baseconfig_groundstate, 0ULL); // Define file name @@ -672,38 +671,38 @@ namespace JSC { string prefix; if ((Delta > 0.0) && (Delta < 1.0)) { - + XXZ_Bethe_State GroundState(BD1, baseconfig_groundstate); XXZ_Bethe_State SeedScanState; if (whichDSF == 'Z' || whichDSF == 'z') SeedScanState = GroundState; else if (whichDSF == 'm') SeedScanState = XXZ_Bethe_State(GroundState.chain, M - 1); else if (whichDSF == 'p') SeedScanState = XXZ_Bethe_State(GroundState.chain, M + 1); - else JSCerror("Unknown whichDSF in Scan_Heis."); + else ABACUSerror("Unknown whichDSF in Scan_Heis."); - Data_File_Name (filenameprefix, whichDSF, iKmin, iKmax, 0.0, GroundState, SeedScanState, ""); + Data_File_Name (filenameprefix, whichDSF, iKmin, iKmax, 0.0, GroundState, SeedScanState, ""); for (int i = 0; i < paralevel - 1; ++i) filenameprefix << "_" << rank_lower_paralevels[i] << "_" << nr_processors_lower_paralevels[i]; - prefix = filenameprefix.str(); + prefix = filenameprefix.str(); // Merge sum files Merge_sum_Files (SeedScanState, prefix, whichDSF, nr_processors_at_newlevel); // Merge raw files Merge_raw_Files (prefix, whichDSF, nr_processors_at_newlevel); - + // Merge thr files Merge_thr_Files (prefix, whichDSF, nr_processors_at_newlevel); - + // Merge src files Merge_inadm_conv0_src_stat_log_Files (prefix, whichDSF, nr_processors_at_newlevel); // This also puts some digested info in log file. - + // Evaluate f-sumrule: DP Chem_Pot = Chemical_Potential (GroundState); if (iKmin != iKmax) if (whichDSF != 'q') Evaluate_F_Sumrule (prefix, whichDSF, GroundState, Chem_Pot, iKmin, iKmax); - + } - + else if (Delta == 1.0) { XXX_Bethe_State GroundState(BD1, baseconfig_groundstate); @@ -713,65 +712,65 @@ namespace JSC { else if (whichDSF == 'm') SeedScanState = XXX_Bethe_State(GroundState.chain, M - 1); else if (whichDSF == 'p') SeedScanState = XXX_Bethe_State(GroundState.chain, M + 1); else if (whichDSF == 'c') SeedScanState = XXX_Bethe_State(GroundState.chain, M - 2); - else JSCerror("Unknown whichDSF in Scan_Heis."); + else ABACUSerror("Unknown whichDSF in Scan_Heis."); - Data_File_Name (filenameprefix, whichDSF, iKmin, iKmax, 0.0, GroundState, SeedScanState, ""); + Data_File_Name (filenameprefix, whichDSF, iKmin, iKmax, 0.0, GroundState, SeedScanState, ""); for (int i = 0; i < paralevel - 1; ++i) filenameprefix << "_" << rank_lower_paralevels[i] << "_" << nr_processors_lower_paralevels[i]; - prefix = filenameprefix.str(); + prefix = filenameprefix.str(); // Merge sum files Merge_sum_Files (SeedScanState, prefix, whichDSF, nr_processors_at_newlevel); // Merge raw files Merge_raw_Files (prefix, whichDSF, nr_processors_at_newlevel); - + // Merge thr files Merge_thr_Files (prefix, whichDSF, nr_processors_at_newlevel); - + // Merge src files Merge_inadm_conv0_src_stat_log_Files (prefix, whichDSF, nr_processors_at_newlevel); // This also puts some digested info in log file. - + // Evaluate f-sumrule: DP Chem_Pot = Chemical_Potential (GroundState); if (iKmin != iKmax) if (whichDSF != 'q') Evaluate_F_Sumrule (prefix, whichDSF, GroundState, Chem_Pot, iKmin, iKmax); } - + else if (Delta > 1.0) { - + XXZ_gpd_Bethe_State GroundState(BD1, baseconfig_groundstate); - + XXZ_gpd_Bethe_State SeedScanState; if (whichDSF == 'Z' || whichDSF == 'z') SeedScanState = GroundState; else if (whichDSF == 'm') SeedScanState = XXZ_gpd_Bethe_State(GroundState.chain, M - 1); else if (whichDSF == 'p') SeedScanState = XXZ_gpd_Bethe_State(GroundState.chain, M + 1); - else JSCerror("Unknown whichDSF in Scan_Heis."); + else ABACUSerror("Unknown whichDSF in Scan_Heis."); - Data_File_Name (filenameprefix, whichDSF, iKmin, iKmax, 0.0, GroundState, SeedScanState, ""); + Data_File_Name (filenameprefix, whichDSF, iKmin, iKmax, 0.0, GroundState, SeedScanState, ""); for (int i = 0; i < paralevel - 1; ++i) filenameprefix << "_" << rank_lower_paralevels[i] << "_" << nr_processors_lower_paralevels[i]; - prefix = filenameprefix.str(); - + prefix = filenameprefix.str(); + // Merge sum files Merge_sum_Files (SeedScanState, prefix, whichDSF, nr_processors_at_newlevel); - + // Merge raw files Merge_raw_Files (prefix, whichDSF, nr_processors_at_newlevel); - + // Merge thr files Merge_thr_Files (prefix, whichDSF, nr_processors_at_newlevel); - + // Merge src files Merge_inadm_conv0_src_stat_log_Files (prefix, whichDSF, nr_processors_at_newlevel); // This also puts some digested info in log file. - + // Evaluate f-sumrule: DP Chem_Pot = Chemical_Potential (GroundState); if (iKmin != iKmax) if (whichDSF != 'q') Evaluate_F_Sumrule (prefix, whichDSF, GroundState, Chem_Pot, iKmin, iKmax); - + } - else JSCerror("Delta out of range in Prepare_Parallel_Scan_Heis"); + else ABACUSerror("Delta out of range in Prepare_Parallel_Scan_Heis"); // ... and we're done. @@ -779,4 +778,4 @@ namespace JSC { return; } -} // namespace JSC +} // namespace ABACUS diff --git a/src/SCAN/Particle_Hole_Excitation_Cost.cc b/src/SCAN/Particle_Hole_Excitation_Cost.cc index 20d7e3f..38fe964 100644 --- a/src/SCAN/Particle_Hole_Excitation_Cost.cc +++ b/src/SCAN/Particle_Hole_Excitation_Cost.cc @@ -2,7 +2,7 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -12,28 +12,28 @@ Purpose: defines the expected cost of adding a p-h pair. Used in General_Scan. ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -namespace JSC { +namespace ABACUS { DP Particle_Hole_Excitation_Cost (char whichDSF, LiebLin_Bethe_State& AveragingState) { // Estimates the cost of adding a particle-hole excitation to an intermediate state DP ph_cost = 1.0; - //if (whichDSF == 'd') ph_cost = JSC::min(0.1, 1.0/sqrt(AveragingState.c_int)); - //if (whichDSF == 'd') ph_cost = JSC::min(0.1, 1.0/AveragingState.c_int); - if (whichDSF == 'd') ph_cost = JSC::min(0.01, 0.1/AveragingState.c_int); - //if (whichDSF == 'd') ph_cost = JSC::min(0.001, 0.01/AveragingState.c_int); + //if (whichDSF == 'd') ph_cost = ABACUS::min(0.1, 1.0/sqrt(AveragingState.c_int)); + //if (whichDSF == 'd') ph_cost = ABACUS::min(0.1, 1.0/AveragingState.c_int); + if (whichDSF == 'd') ph_cost = ABACUS::min(0.01, 0.1/AveragingState.c_int); + //if (whichDSF == 'd') ph_cost = ABACUS::min(0.001, 0.01/AveragingState.c_int); else if (whichDSF == 'o') ph_cost = 0.01; else if (whichDSF == 'g') ph_cost = 0.01; else if (whichDSF == 'Z') ph_cost = 1.0; else if (whichDSF == 'B') ph_cost = 0.1; else if (whichDSF == 'C') ph_cost = 0.1; - else JSCerror("whichDSF option not implemented in Particle_Hole_Excitation_Cost for LiebLin."); + else ABACUSerror("whichDSF option not implemented in Particle_Hole_Excitation_Cost for LiebLin."); return(ph_cost); } @@ -47,10 +47,9 @@ namespace JSC { else if (whichDSF == 'm') ph_cost = 0.01; else if (whichDSF == 'p') ph_cost = 0.01; else if (whichDSF == 'Z') ph_cost = 1.0; - else JSCerror("whichDSF option not implemented in Particle_Hole_Excitation_Cost for HEIS."); + else ABACUSerror("whichDSF option not implemented in Particle_Hole_Excitation_Cost for HEIS."); return(ph_cost); } -} // namespace JSC - +} // namespace ABACUS diff --git a/src/SCAN/Scan_Info.cc b/src/SCAN/Scan_Info.cc index 8d79261..49fdaea 100644 --- a/src/SCAN/Scan_Info.cc +++ b/src/SCAN/Scan_Info.cc @@ -1,24 +1,23 @@ /********************************************************** -This software is part of J.-S. Caux's ABACUS++ library. +This software is part of J.-S. Caux's ABACUS library. -Copyright (c) +Copyright (c) J.-S. Caux. ----------------------------------------------------------- File: Scan_Info.cc Purpose: defines all functions for Scan_Info class. - ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -namespace JSC { +namespace ABACUS { Scan_Info::Scan_Info() : //sumrule_obtained(0.0), Nfull(0LL), Ninadm(0LL), Ndata(0LL), Ndata_conv(0LL), Ndata_conv0(0LL), CPU_ticks(0LL), CPU_ticks_TOT(0LL) {} @@ -33,16 +32,16 @@ namespace JSC { void Scan_Info::Save (const char* outfile_Cstr) { ofstream outfile; - + outfile.open(outfile_Cstr); - if (outfile.fail()) JSCerror("Could not open outfile... "); - + if (outfile.fail()) ABACUSerror("Could not open outfile... "); + //outfile.setf(ios::fixed); //outfile.setf(ios::showpoint); outfile.precision(16); int TT_hr = int(TT/3600); - int TT_min = int((TT - 3600.0*TT_hr)/60); + int TT_min = int((TT - 3600.0*TT_hr)/60); outfile << setw(25) << setprecision(16) << sumrule_obtained << setw(25) << Nfull << setw(16) << Ninadm << setw(16) << Ndata << setw(16) << Ndata_conv << setw(16) << Ndata_conv0 //<< "\t" << CPU_ticks/CLOCKS_PER_SEC << "\t" << CPU_ticks_TOT/CLOCKS_PER_SEC << endl; @@ -61,7 +60,7 @@ namespace JSC { infile.open(infile_Cstr); if(infile.fail()) { cout << endl << infile_Cstr << endl; - JSCerror("Could not open input file in Scan_Info::Load."); + ABACUSerror("Could not open input file in Scan_Info::Load."); } int TT_hr, TT_min; @@ -84,8 +83,8 @@ namespace JSC { std::ostream& operator<< (std::ostream& s, const Scan_Info& info) { s.ios::unsetf(ios::scientific); - return s << " sr " << setprecision(14) << info.sumrule_obtained - << "\tNfull " << std::fixed << setprecision(0) << info.Nfull << "\t Ninadm " << info.Ninadm << " Ndata " << info.Ndata + return s << " sr " << setprecision(14) << info.sumrule_obtained + << "\tNfull " << std::fixed << setprecision(0) << info.Nfull << "\t Ninadm " << info.Ninadm << " Ndata " << info.Ndata << "\t_conv " << info.Ndata_conv << " _conv0 " << info.Ndata_conv0 //<< " t " << info.CPU_ticks/CLOCKS_PER_SEC << "s" //<< " TT " << info.CPU_ticks_TOT/CLOCKS_PER_SEC; @@ -94,4 +93,4 @@ namespace JSC { } -} // namespace JSC +} // namespace ABACUS diff --git a/src/SCAN/Scan_Thread_Data.cc b/src/SCAN/Scan_Thread_Data.cc index 04fa290..ca4d9c2 100644 --- a/src/SCAN/Scan_Thread_Data.cc +++ b/src/SCAN/Scan_Thread_Data.cc @@ -2,23 +2,22 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- File: Scan_Thread_Data.cc Purpose: defines all functions for Scan_Thread_Data class. - ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -namespace JSC { +namespace ABACUS { Scan_Thread::Scan_Thread() { @@ -47,8 +46,8 @@ namespace JSC { lowest_il_with_nthreads_neq_0 = nlists - 1; dim = Vect (nlists); // size of the memory vector - label = Vect > (nlists); - type = Vect > (nlists); + label = Vect > (nlists); + type = Vect > (nlists); // Give starting values to all: for (int il = 0; il < nlists; ++il) { @@ -64,7 +63,7 @@ namespace JSC { for (int il = 0; il < nlists; ++il) { stringstream filename_strstream; filename_strstream << thrdir_name << "/" << il << ".thr"; - filename[il] = filename_strstream.str(); + filename[il] = filename_strstream.str(); if (!refine) remove(filename[il].c_str()); // the file is deleted to make sure we don't interfere with a previous (failed) computation //file_is_open[il] = false; } @@ -89,7 +88,7 @@ namespace JSC { bool Scan_Thread_Data::Increase_Memory_Size (int il, int nr_to_add) { - if (il < 0 || il > nlists) JSCerror("ilist out of bounds in Scan_Thread_Data::Increase_Memory_Size"); + if (il < 0 || il > nlists) ABACUSerror("ilist out of bounds in Scan_Thread_Data::Increase_Memory_Size"); dim[il] += nr_to_add; @@ -100,13 +99,13 @@ namespace JSC { catch (bad_alloc) { cout << "dim[il] " << dim[il] << "\tnr_to_add " << nr_to_add << endl; - JSCerror("Memory allocation failed in Scan_Thread_Data::Increase_Memory_Size."); + ABACUSerror("Memory allocation failed in Scan_Thread_Data::Increase_Memory_Size."); } return(true); } - void Scan_Thread_Data::Include_Thread (DP abs_data_value_ref, string label_ref, int type_ref) + void Scan_Thread_Data::Include_Thread (DP abs_data_value_ref, string label_ref, int type_ref) { if (abs_data_value_ref <= 0.0) abs_data_value_ref = 1.0e-200; // safety // Determine which ilist index is to be used: @@ -121,7 +120,7 @@ namespace JSC { { //cout << "Calling Include_Threads..." << endl; - if (il < 0 || il > nlists - 1) JSCerror("il out of range in Scan_Thread_Data::Include_Thread."); + if (il < 0 || il > nlists - 1) ABACUSerror("il out of range in Scan_Thread_Data::Include_Thread."); //cout << "\t\tIncluding thread " << label_ref << "\t" << type_ref << " in list with il = " << il << endl; @@ -129,19 +128,19 @@ namespace JSC { // append to file //if (!file_is_open[il]) { - //file[il] = new fstream(filename[il].c_str(), fstream::out); + //file[il] = new fstream(filename[il].c_str(), fstream::out); //file_is_open[il] = true; //} //*file[il] << label_ref << "\t" << type_ref << endl; // Keep in memory for now: - if (nthreads_in_memory[il] > dim[il] - 10) { + if (nthreads_in_memory[il] > dim[il] - 10) { (*this).Increase_Memory_Size (il, dim[il]); } label[il][nthreads_in_memory[il] ] = label_ref; type[il][nthreads_in_memory[il] ] = type_ref; nthreads_in_memory[il]++; - + nthreads_total[il]++; // We save the threads to disk if there are sufficiently many: @@ -152,7 +151,7 @@ namespace JSC { outfile << label[il][it] << "\t" << type[il][it] << endl; outfile.close(); nthreads_on_disk[il] += nthreads_in_memory[il]; - + // We then reset these memory buffers dim[il] = 100; nthreads_in_memory[il] = 0; @@ -182,7 +181,7 @@ namespace JSC { // Copy the in-memory threads for (int it = 0; it < nthreads_in_memory[il_used]; ++it) { next_in_line[it] = Scan_Thread(label[il_used][it], type[il_used][it]); - } + } // Copy the on-disk threads if (nthreads_on_disk[il_used] > 0) { @@ -207,9 +206,9 @@ namespace JSC { type[il_used] = Vect (dim[il_used]); remove(filename[il_used].c_str()); - /* Moved to Include_Thread + /* Moved to Include_Thread // We save the higher-index in-memory threads to files if they are big enough: - for (int il = il_used + 1; il < nlists; ++il) + for (int il = il_used + 1; il < nlists; ++il) //if (nthreads_in_memory[il] > 0) { if (nthreads_in_memory[il] > 1000) { fstream outfile; @@ -234,7 +233,7 @@ namespace JSC { break; } } while (nthreads_total[lowest_il_with_nthreads_neq_0] == 0); - + //cout << "Set lowest_il_with_nthreads_neq_0 to " << lowest_il_with_nthreads_neq_0 << endl; //cin >> a; @@ -259,7 +258,7 @@ namespace JSC { void Scan_Thread_Data::Flush_to_Disk (int il) { - if (il < 0 || il > nlists - 1) JSCerror("il out of range in Scan_Thread_Data::Flush_to_Disk."); + if (il < 0 || il > nlists - 1) ABACUSerror("il out of range in Scan_Thread_Data::Flush_to_Disk."); if (nthreads_in_memory[il] > 0) { fstream outfile; @@ -268,13 +267,13 @@ namespace JSC { outfile << label[il][it] << "\t" << type[il][it] << endl; outfile.close(); nthreads_on_disk[il] += nthreads_in_memory[il]; - + // We then reset these memory buffers dim[il] = 100; nthreads_in_memory[il] = 0; label[il] = Vect (dim[il]); type[il] = Vect (dim[il]); - } + } } void Scan_Thread_Data::Save() @@ -287,19 +286,19 @@ namespace JSC { stringstream nthreads_outfile_strstream; nthreads_outfile_strstream << thrdir_name << "/nthreads.dat"; string nthreads_outfile_str = nthreads_outfile_strstream.str(); - + nthreads_outfile.open(nthreads_outfile_str.c_str()); - if (nthreads_outfile.fail()) JSCerror("Could not open outfile in Scan_Thread_Data::Save... "); + if (nthreads_outfile.fail()) ABACUSerror("Could not open outfile in Scan_Thread_Data::Save... "); //cout << "Saving threads: nthreads_tot vector is" << endl; for (int il = 0; il < nlists; ++il) { - if (nthreads_total[il] != nthreads_in_memory[il] + nthreads_on_disk[il]) - JSCerror("nthreads_total neq _in_memory + _on_disk in Scan_Threads_Data::Save"); + if (nthreads_total[il] != nthreads_in_memory[il] + nthreads_on_disk[il]) + ABACUSerror("nthreads_total neq _in_memory + _on_disk in Scan_Threads_Data::Save"); if (nthreads_total[il] > 0) nthreads_outfile << endl << il << "\t" << nthreads_total[il]; } nthreads_outfile.close(); - + return; } @@ -310,9 +309,9 @@ namespace JSC { stringstream nthreads_infile_strstream; nthreads_infile_strstream << thrdir_name << "/nthreads.dat"; string nthreads_infile_str = nthreads_infile_strstream.str(); - + nthreads_infile.open(nthreads_infile_str.c_str()); - if (nthreads_infile.fail()) JSCerror("Could not open infile in Scan_Thread_Data::Load... "); + if (nthreads_infile.fail()) ABACUSerror("Could not open infile in Scan_Thread_Data::Load... "); // Read the number of elements in each list: @@ -335,4 +334,4 @@ namespace JSC { return; } -} // namespace JSC +} // namespace ABACUS diff --git a/src/TBA/Root_Density.cc b/src/TBA/Root_Density.cc index 4b81c20..7aa1625 100644 --- a/src/TBA/Root_Density.cc +++ b/src/TBA/Root_Density.cc @@ -2,7 +2,7 @@ This software is part of J.-S. Caux's C++ library. -Copyright (c) 2008. +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -10,19 +10,14 @@ File: Root_Density.cc Purpose: defines Root_Density & Root_Density_Set, and their member functions -Last modified: 27/09/08 - -Chronology: -08 10 28: created - ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -namespace JSC { +namespace ABACUS { /************************************/ /* @@ -56,7 +51,7 @@ Root_Density::Root_Density () { } -Root_Density::Root_Density (int Npts_ref, DP lambdamax_ref) +Root_Density::Root_Density (int Npts_ref, DP lambdamax_ref) : Npts(Npts_ref), lambdamax(lambdamax_ref), lambda(Vect_DP(Npts)), dlambda(Vect_DP(0.0, Npts)), value(Vect_DP(0.0, Npts)), prev_value(Vect_DP(0.0, Npts)), diff(1.0e+6), value_infty_set(false), value_infty(0.0) { @@ -69,7 +64,7 @@ Root_Density::Root_Density (int Npts_ref, DP lambdamax_ref) Root_Density& Root_Density::operator= (const Root_Density& RefDensity) { if (this != &RefDensity) { - Npts = RefDensity.Npts; + Npts = RefDensity.Npts; lambdamax = RefDensity.lambdamax; lambda = RefDensity.lambda; dlambda = RefDensity.dlambda; @@ -90,14 +85,14 @@ DP Root_Density::Return_Value (DP lambda_ref) // Degree 3 polynomical also programmed in, but commented out: no improvement. DP answer = 0.0; - if (fabs(lambda_ref) >= fabs(lambda[0])) { + if (fabs(lambda_ref) >= fabs(lambda[0])) { if (value_infty_set) answer = value_infty; - else JSCerror("Need to set asymptotics of Root_Density !"); + else ABACUSerror("Need to set asymptotics of Root_Density !"); } else { // try to find the i such that lambda[i] <= lambda_ref < lambda[i+1] - int index = (Npts - 1)/2; + int index = (Npts - 1)/2; int indexstep = (Npts - 1)/4 + 1; while (indexstep >= 1) { @@ -112,8 +107,8 @@ DP Root_Density::Return_Value (DP lambda_ref) index -= indexstep; } - index = JSC::max(0, index); - index = JSC::min(Npts - 2, index); + index = ABACUS::max(0, index); + index = ABACUS::min(Npts - 2, index); if (indexstep == 1) indexstep--; else indexstep = (indexstep + 1)/2; @@ -122,11 +117,11 @@ DP Root_Density::Return_Value (DP lambda_ref) if (index < 0 || index >= Npts || lambda[index] > lambda_ref || lambda[index + 1] < lambda_ref) { cout << "Seeking index: " << index << "\t" << lambda[index] << "\t <=? " << lambda_ref << "\t Npts - 3) - answer = ((value[index] * (lambda[index+1] - lambda_ref) + answer = ((value[index] * (lambda[index+1] - lambda_ref) + value[index + 1] * (lambda_ref - lambda[index]))/(lambda[index+1] - lambda[index])); /* else { @@ -151,17 +146,17 @@ void Root_Density::Set_Asymptotics (DP value_infty_ref) } Root_Density Root_Density::Compress_and_Match_Densities (DP comp_factor) -{ +{ // Returns a 'compressed' version of the density, using 1/comp_factor as many points. - // PROBLEM: this implementation can lead to numerical instabilities. + // PROBLEM: this implementation can lead to numerical instabilities. - //Root_Density compressed_density(Npts/comp_factor, lambdamax); + //Root_Density compressed_density(Npts/comp_factor, lambdamax); // Rather: use this implementation: int Npts_used = int(2.0 * lambdamax/(dlambda[0] * comp_factor)); - Root_Density compressed_density(Npts_used, lambdamax); + Root_Density compressed_density(Npts_used, lambdamax); compressed_density.Set_Asymptotics (value_infty); @@ -226,7 +221,7 @@ Root_Density_Set::Root_Density_Set (int ntypes_ref, int Npts_ref, DP lambdamax_r Root_Density_Set::Root_Density_Set (int ntypes_ref, Vect_INT Npts_ref, Vect_DP lambdamax_ref) : ntypes(ntypes_ref), epsilon(Vect (ntypes_ref)), Npts_total(Npts_ref.sum()), diff(1.0e+6) { - if (Npts_ref.size() != ntypes_ref || lambdamax_ref.size() != ntypes_ref) JSCerror("Wrong vector sizes in Root_Density_Set."); + if (Npts_ref.size() != ntypes_ref || lambdamax_ref.size() != ntypes_ref) ABACUSerror("Wrong vector sizes in Root_Density_Set."); for (int n = 0; n < ntypes; ++n) epsilon[n] = Root_Density(Npts_ref[n], lambdamax_ref[n]); } @@ -251,13 +246,13 @@ void Root_Density_Set::Insert_new_function (DP asymptotic_value) //Updated_Set.epsilon[ntypes] = Root_Density (epsilon[ntypes - 1].Npts, epsilon[ntypes - 1].lambdamax); Updated_Set.epsilon[ntypes] = Root_Density (50, epsilon[ntypes - 1].lambdamax); Updated_Set.epsilon[ntypes].Set_Asymptotics (asymptotic_value); - + for (int i = 0; i < Updated_Set.epsilon[ntypes].Npts; ++i) Updated_Set.epsilon[ntypes].value[i] = Updated_Set.epsilon[ntypes].value_infty; ntypes = Updated_Set.ntypes; epsilon = Updated_Set.epsilon; - Npts_total+= Updated_Set.epsilon[ntypes - 1].Npts; + Npts_total+= Updated_Set.epsilon[ntypes - 1].Npts; } void Root_Density_Set::Extend_limits (Vect need_to_extend_limit) @@ -267,7 +262,7 @@ void Root_Density_Set::Extend_limits (Vect need_to_extend_limit) // The function extends the limits by 10% on both sides, putting the // extra values to value_infty. - if (need_to_extend_limit.size() != epsilon.size()) JSCerror("Wrong size need_to_extend_limit boolean in Extend_limits."); + if (need_to_extend_limit.size() != epsilon.size()) ABACUSerror("Wrong size need_to_extend_limit boolean in Extend_limits."); Vect_INT nr_new_points_needed(0, ntypes); int total_nr_new_points_added = 0; @@ -281,7 +276,7 @@ void Root_Density_Set::Extend_limits (Vect need_to_extend_limit) dlambda_used = epsilon[n].dlambda[0]; // How many new points do we add ? Say 5\% on each side: - nr_new_points_needed[n] = JSC::max(1, epsilon[n].Npts/20); + nr_new_points_needed[n] = ABACUS::max(1, epsilon[n].Npts/20); epsilon[n] = Root_Density(epsilon_n_before_update.Npts + 2* nr_new_points_needed[n], epsilon_n_before_update.lambdamax + nr_new_points_needed[n] * dlambda_used); epsilon[n].Set_Asymptotics(epsilon_n_before_update.value_infty); @@ -299,7 +294,7 @@ void Root_Density_Set::Extend_limits (Vect need_to_extend_limit) } for (int i = 0; i < nr_new_points_needed[n]; ++i) { - epsilon[n].lambda[i + epsilon_n_before_update.Npts + nr_new_points_needed[n] ] + epsilon[n].lambda[i + epsilon_n_before_update.Npts + nr_new_points_needed[n] ] = epsilon_n_before_update.lambda[epsilon_n_before_update.Npts - 1] + (i+1.0) * dlambda_used; epsilon[n].dlambda[i + epsilon_n_before_update.Npts + nr_new_points_needed[n] ] = dlambda_used; epsilon[n].value[i + epsilon_n_before_update.Npts + nr_new_points_needed[n] ] = epsilon_n_before_update.value_infty; @@ -328,8 +323,8 @@ void Root_Density_Set::Insert_new_points (Vect > need_new_point_aroun Vect_INT nr_new_points_needed(0, ntypes); int total_nr_new_points_needed = 0; for (int n = 0; n < ntypes; ++n) { - if (need_new_point_around[n].size() != epsilon[n].Npts) JSCerror("Wrong size need_new_point_around boolean in Insert_new_points."); - for (int i = 0; i < epsilon[n].Npts; ++i) + if (need_new_point_around[n].size() != epsilon[n].Npts) ABACUSerror("Wrong size need_new_point_around boolean in Insert_new_points."); + for (int i = 0; i < epsilon[n].Npts; ++i) if (need_new_point_around[n][i]) nr_new_points_needed[n]++; total_nr_new_points_needed += nr_new_points_needed[n]; } @@ -339,7 +334,7 @@ void Root_Density_Set::Insert_new_points (Vect > need_new_point_aroun Root_Density epsilon_n_before_update = epsilon[n]; epsilon[n] = Root_Density(epsilon_n_before_update.Npts + nr_new_points_needed[n], epsilon_n_before_update.lambdamax); epsilon[n].Set_Asymptotics(epsilon_n_before_update.value_infty); - for (int i = 0; i < epsilon[n].Npts; ++i) + for (int i = 0; i < epsilon[n].Npts; ++i) epsilon[n].value[i] = epsilon_n_before_update.Return_Value(epsilon[n].lambda[i]); } */ @@ -361,26 +356,26 @@ void Root_Density_Set::Insert_new_points (Vect > need_new_point_aroun else if (need_new_point_around[n][i]) { epsilon[n].lambda[i + nr_pts_added_n] = epsilon_n_before_update.lambda[i] - 0.25 * epsilon_n_before_update.dlambda[i]; epsilon[n].dlambda[i + nr_pts_added_n] = 0.5 * epsilon_n_before_update.dlambda[i]; - epsilon[n].value[i + nr_pts_added_n] = epsilon_n_before_update.Return_Value(epsilon[n].lambda[i + nr_pts_added_n]); + epsilon[n].value[i + nr_pts_added_n] = epsilon_n_before_update.Return_Value(epsilon[n].lambda[i + nr_pts_added_n]); nr_pts_added_n++; epsilon[n].lambda[i + nr_pts_added_n] = epsilon_n_before_update.lambda[i] + 0.25 * epsilon_n_before_update.dlambda[i]; epsilon[n].dlambda[i + nr_pts_added_n] = 0.5 * epsilon_n_before_update.dlambda[i]; - epsilon[n].value[i + nr_pts_added_n] = epsilon_n_before_update.Return_Value(epsilon[n].lambda[i + nr_pts_added_n]); + epsilon[n].value[i + nr_pts_added_n] = epsilon_n_before_update.Return_Value(epsilon[n].lambda[i + nr_pts_added_n]); } } if (nr_pts_added_n != nr_new_points_needed[n]) { cout << nr_pts_added_n << "\t" << nr_new_points_needed[n] << endl; - JSCerror("Wrong counting of new points in Insert_new_points."); + ABACUSerror("Wrong counting of new points in Insert_new_points."); } // Check: //for (int i = 0; i < epsilon[n].Npts - 1; ++i) //if (fabs(epsilon[n].lambda[i] + 0.5 *(epsilon[n].dlambda[i] + epsilon[n].dlambda[i+1]) - epsilon[n].lambda[i+1]) > 1.0e-13) //{ - // cout << "Error at level " << n << "\ti " << i << "\t" << epsilon[n].lambda[i] << "\t" << epsilon[n].dlambda[i] - // << "\t" << epsilon[n].lambda[i+1] << "\t" << epsilon[n].dlambda[i+1] + // cout << "Error at level " << n << "\ti " << i << "\t" << epsilon[n].lambda[i] << "\t" << epsilon[n].dlambda[i] + // << "\t" << epsilon[n].lambda[i+1] << "\t" << epsilon[n].dlambda[i+1] // << "\t" << epsilon[n].lambda[i] + 0.5 *(epsilon[n].dlambda[i] + epsilon[n].dlambda[i+1]) - epsilon[n].lambda[i+1] << endl; - // JSCerror("..."); + // ABACUSerror("..."); //} } // for n @@ -412,8 +407,8 @@ DP Root_Density_Set::Return_Value (int n_ref, DP lambda_ref) Root_Density_Set Root_Density_Set::Return_Compressed_and_Matched_Set (DP comp_factor) { // Returns a set with 1/comp_factor as many points at each level - if (comp_factor >= 2.0) - JSCerror("Compression factor too large in Return_Compressed_and_Matched_Set, numerical instability will occur."); + if (comp_factor >= 2.0) + ABACUSerror("Compression factor too large in Return_Compressed_and_Matched_Set, numerical instability will occur."); Vect_INT nrpts_comp (ntypes); Vect_DP lambdamax_comp (ntypes); @@ -424,7 +419,7 @@ Root_Density_Set Root_Density_Set::Return_Compressed_and_Matched_Set (DP comp_fa Root_Density_Set Compressed_and_Matched_Set (ntypes, nrpts_comp, lambdamax_comp); - for (int n = 0; n < ntypes; ++n) + for (int n = 0; n < ntypes; ++n) Compressed_and_Matched_Set.epsilon[n] = (*this).epsilon[n].Compress_and_Match_Densities (comp_factor); return(Compressed_and_Matched_Set); @@ -433,7 +428,7 @@ Root_Density_Set Root_Density_Set::Return_Compressed_and_Matched_Set (DP comp_fa void Root_Density_Set::Match_Densities (Root_Density_Set& RefSet) { // matched densities to those in RefSet - for (int n = 0; n < ntypes; ++n) + for (int n = 0; n < ntypes; ++n) for (int i = 0; i < epsilon[n].Npts; ++i) epsilon[n].value[i] = RefSet.epsilon[n].Return_Value(epsilon[n].lambda[i]); } @@ -446,12 +441,12 @@ void Root_Density_Set::Save (const char* outfile_Cstr) // Determine what the maximal nr of pts is: int Npts_n_max = 0; - for (int n = 0; n < ntypes; ++n) Npts_n_max = JSC::max(Npts_n_max, epsilon[n].Npts); + for (int n = 0; n < ntypes; ++n) Npts_n_max = ABACUS::max(Npts_n_max, epsilon[n].Npts); for (int i = 0; i < Npts_n_max; ++i) { if (i > 0) outfile << endl; - for (int n = 0; n < ntypes; ++n) (i < epsilon[n].Npts) ? - (outfile << epsilon[n].lambda[i] << "\t" << epsilon[n].value[i] << "\t") + for (int n = 0; n < ntypes; ++n) (i < epsilon[n].Npts) ? + (outfile << epsilon[n].lambda[i] << "\t" << epsilon[n].value[i] << "\t") : (outfile << 0 << "\t" << 0 << "\t"); } @@ -459,4 +454,4 @@ void Root_Density_Set::Save (const char* outfile_Cstr) } -} // namespace JSC +} // namespace ABACUS diff --git a/src/TBA/TBA_2CBG.cc b/src/TBA/TBA_2CBG.cc index b7c6ba6..09f743a 100644 --- a/src/TBA/TBA_2CBG.cc +++ b/src/TBA/TBA_2CBG.cc @@ -2,7 +2,7 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -10,15 +10,14 @@ File: TBA_2CBG.cc Purpose: solves the TBA equations for the 2-component Bose gas - ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -namespace JSC { +namespace ABACUS { /********************* 2CBG specific *******************/ @@ -35,30 +34,30 @@ void Set_2CBG_Asymptotics (Root_Density_Set& TBA_Set, DP mu, DP Omega, DP kBT) //DP epsilon_infty = 0.0; TBA_Set.epsilon[0].Set_Asymptotics (pow(TBA_Set.epsilon[0].lambdamax, 2.0) - mu - Omega); for (int n = 1; n < TBA_Set.ntypes; ++n) { - //epsilon_infty = 2.0 * Omega * n + kBT * + //epsilon_infty = 2.0 * Omega * n + kBT * //log(pow((1.0 - exp(-2.0 * (n + 1.0) * Omega/kBT))/(1.0 - exp(-2.0 * Omega/kBT)), 2.0) - exp(-2.0 * n * Omega/kBT)); //TBA_Set.epsilon[n].Set_Asymptotics (epsilon_infty); TBA_Set.epsilon[n].Set_Asymptotics (Asymptotic_2CBG_epsilon(n, Omega, kBT)); - //cout << "Set asymptotics of " << n << " to " << setprecision(16) << TBA_Set.epsilon[n].value_infty + //cout << "Set asymptotics of " << n << " to " << setprecision(16) << TBA_Set.epsilon[n].value_infty // << "\t" << 2.0 * Omega * n + 2.0 * kBT * log((1.0 - exp(-2.0 * (n + 1) * Omega/kBT))/(1.0 - exp(-2.0 * Omega/kBT))) - TBA_Set.epsilon[n].value_infty << endl; - } + } } void Set_2CBG_deps_dchempot_Asymptotics (int option, const Root_Density_Set& Set, Root_Density_Set& DSet, DP mu, DP Omega, DP kBT) { - // option == 0: deps/dmu + // option == 0: deps/dmu // option == 1: deps/dOmega - //DSet.epsilon[0].Set_Asymptotics (-1.0); - DP zeroasymptote = -1.0; + //DSet.epsilon[0].Set_Asymptotics (-1.0); + DP zeroasymptote = -1.0; DP em2OoT = exp(-2.0 * Omega/kBT); for (int n = 1; n < DSet.ntypes; ++n) { if (option == 0) DSet.epsilon[n].Set_Asymptotics (0.0); - else if (option == 1) - DSet.epsilon[n].Set_Asymptotics (2.0 * (1.0 - pow(em2OoT, n+1.0)) + else if (option == 1) + DSet.epsilon[n].Set_Asymptotics (2.0 * (1.0 - pow(em2OoT, n+1.0)) * (n * (1.0 - pow(em2OoT, n+2.0)) - (n + 2.0) * em2OoT * (1.0 - pow(em2OoT, DP(n)))) /((1.0 - em2OoT) * (1.0 - pow(em2OoT, DP(n))) * (1.0 - pow(em2OoT, n + 2.0)))); - //cout << "Set asymptotics for option " << option << " at level " << n << " to " << DSet.epsilon[n].value_infty << endl; + //cout << "Set asymptotics for option " << option << " at level " << n << " to " << DSet.epsilon[n].value_infty << endl; zeroasymptote += DSet.epsilon[n].value_infty * exp(-Set.epsilon[n].value_infty/kBT)/(1.0 + exp(-Set.epsilon[n].value_infty/kBT)); } // For n > nmax sum in RHS of BE for epsilon, assuming epsilon_n = epsilon_n^\infty in those cases: @@ -97,10 +96,10 @@ void Iterate_2CBG_TBAE (Root_Density_Set& Set, Vect >& a_n_dlambda Vect >& fplus_dlambda, DP c_int, DP mu, DP Omega, DP kBT) { // Produces a new Root_Density_Set from a previous iteration. - // Does NOT add types or change Npts, lambdamax values. + // Does NOT add types or change Npts, lambdamax values. //DP oneoverc = 1.0/c_int; - //DP twoovernc = 2.0/c_int; + //DP twoovernc = 2.0/c_int; // First define some useful functions: Vect Tln1plusemineps(Set.ntypes); @@ -112,8 +111,8 @@ void Iterate_2CBG_TBAE (Root_Density_Set& Set, Vect >& a_n_dlambda for (int i = 0; i < Set.epsilon[n].Npts; ++i) { Tln1plusemineps[n][i] = Set.epsilon[n].value[i] > 0.0 ? - kBT * (Set.epsilon[n].value[i] < 24.0 * kBT ? log(1.0 + exp(-Set.epsilon[n].value[i]/kBT)) : exp(-Set.epsilon[n].value[i]/kBT)) - : + kBT * (Set.epsilon[n].value[i] < 24.0 * kBT ? log(1.0 + exp(-Set.epsilon[n].value[i]/kBT)) : exp(-Set.epsilon[n].value[i]/kBT)) + : -Set.epsilon[n].value[i] + kBT * (-Set.epsilon[n].value[i] < 24.0 * kBT ? log (1.0 + exp(Set.epsilon[n].value[i]/kBT)) : exp(Set.epsilon[n].value[i]/kBT)); // Keep previous rapidities: Set.epsilon[n].prev_value[i] = Set.epsilon[n].value[i]; @@ -135,14 +134,14 @@ void Iterate_2CBG_TBAE (Root_Density_Set& Set, Vect >& a_n_dlambda a_n_Tln_conv[n][i] = 0.0; for (int j = 0; j < Set.epsilon[n].Npts; ++j) a_n_Tln_conv[n][i] += Tln1plusemineps[n][j] * a_n_dlambda[i][n][j]; - // Add alpha curvature terms: VERY COSTLY + // Add alpha curvature terms: VERY COSTLY /* for (int j = 1; j < Set.epsilon[n].Npts - 1; ++j) - a_n_Tln_conv[n][i] += (1.0/12.0) * pow(Set.epsilon[n].dlambda[j], 3.0) + a_n_Tln_conv[n][i] += (1.0/12.0) * pow(Set.epsilon[n].dlambda[j], 3.0) * ((Tln1plusemineps[n][j+1] * a_n_dlambda[i][n][j+1] - Tln1plusemineps[n][j] * a_n_dlambda[i][n][j])/(Set.epsilon[n].lambda[j+1] - Set.epsilon[n].lambda[j]) - (Tln1plusemineps[n][j] * a_n_dlambda[i][n][j] - Tln1plusemineps[n][j-1] * a_n_dlambda[i][n][j-1])/(Set.epsilon[n].lambda[j] - Set.epsilon[n].lambda[j-1])) /(Set.epsilon[n].lambda[j+1] - Set.epsilon[n].lambda[j-1]); - */ + */ } // for (int i ... } // for (int n... We now have all the a_n * Tln... at our disposal. @@ -158,40 +157,40 @@ void Iterate_2CBG_TBAE (Root_Density_Set& Set, Vect >& a_n_dlambda for (int n = Set.ntypes - 1; n < Set.ntypes; ++n) { for (int j = 0; j < Set.epsilon[n].Npts; ++j) a_n_Tln_conv_0_integ[n] += Tln1plusemineps[n][j] * a_n_dlambda[Set.epsilon[0].Npts/2][n][j]; // Add asymptotic parts: not necessary - a_n_Tln_conv_0_integ[n] += Tln1pluseminepsinfty[n] + a_n_Tln_conv_0_integ[n] += Tln1pluseminepsinfty[n] * (1.0 - (atan((Set.epsilon[n].lambdamax - Set.epsilon[0].lambda[Set.epsilon[0].Npts/2])/(0.5 * n * c_int)) + atan((Set.epsilon[n].lambdamax + Set.epsilon[0].lambda[Set.epsilon[0].Npts/2])/(0.5 * n * c_int)))/PI); // Prediction based on value_infty: integ_target[n] = -kBT * log(1.0 - pow(sinh(Omega/kBT)/sinh((n + 1.0) * Omega/kBT), 2.0)); integ_target[n] = -kBT * log(1.0 - pow((1.0 - exp(-2.0*Omega/kBT))/(1.0 - exp(-2.0*(n + 1.0)*Omega/kBT)), 2.0) * exp(-2.0 * n * Omega/kBT)); - cout << n << " " << Set.epsilon[n].value[0] << " " << Set.epsilon[n].value_infty << " " << " " << Set.epsilon[n].value[Set.epsilon[n].Npts/2] - << " " << Tln1plusemineps[n][0] << " " << Tln1plusemineps[n][Set.epsilon[n].Npts/2] << " " << Tln1pluseminepsinfty[n] + cout << n << " " << Set.epsilon[n].value[0] << " " << Set.epsilon[n].value_infty << " " << " " << Set.epsilon[n].value[Set.epsilon[n].Npts/2] + << " " << Tln1plusemineps[n][0] << " " << Tln1plusemineps[n][Set.epsilon[n].Npts/2] << " " << Tln1pluseminepsinfty[n] << " " << a_n_Tln_conv_0_integ[n] << " " << integ_target[n] << "\t"; } cout << endl; - //JSCerror("Stop..."); + //ABACUSerror("Stop..."); */ // Reconstruct the epsilon[0] function: for (int i = 0; i < Set.epsilon[0].Npts; ++i) { Set.epsilon[0].value[i] = pow(Set.epsilon[0].lambda[i], 2.0) - mu - Omega; // Add the convolutions: - for (int n = 0; n < Set.ntypes; ++n) + for (int n = 0; n < Set.ntypes; ++n) //if (n <= 1) // REMOVE Set.epsilon[0].value[i] -= a_n_Tln_conv[n][i]; // Add the asymptotic parts of convolutions: for (int n = 1; n < Set.ntypes; ++n) //if (n <= 1) // REMOVE - Set.epsilon[0].value[i] -= Tln1pluseminepsinfty[n] + Set.epsilon[0].value[i] -= Tln1pluseminepsinfty[n] * (1.0 - (atan((Set.epsilon[n].lambdamax - Set.epsilon[0].lambda[i])/(0.5 * n * c_int)) - + atan((Set.epsilon[n].lambdamax + Set.epsilon[0].lambda[i])/(0.5 * n * c_int)))/PI); + + atan((Set.epsilon[n].lambdamax + Set.epsilon[0].lambda[i])/(0.5 * n * c_int)))/PI); // Add the leftover summation for species n > nmax, assuming epsilon_n = epsilon_n^\infty in those cases: - Set.epsilon[0].value[i] -= Smaxsum; + Set.epsilon[0].value[i] -= Smaxsum; - //cout << "i " << i << "\tlambda " << Set.epsilon[0].lambda[i] << "\te[0][i] " << Set.epsilon[0].value[i] << "\tprev " << Set.epsilon[0].prev_value[i] - // << "\tlambda^2 " << pow(Set.epsilon[0].lambda[i], 2.0) << "\ta_n_Tln_conv[0] " << a_n_Tln_conv[0][i] << "\ta_n_Tln_conv[1] " << a_n_Tln_conv[1][i] + //cout << "i " << i << "\tlambda " << Set.epsilon[0].lambda[i] << "\te[0][i] " << Set.epsilon[0].value[i] << "\tprev " << Set.epsilon[0].prev_value[i] + // << "\tlambda^2 " << pow(Set.epsilon[0].lambda[i], 2.0) << "\ta_n_Tln_conv[0] " << a_n_Tln_conv[0][i] << "\ta_n_Tln_conv[1] " << a_n_Tln_conv[1][i] // << endl; //cout << a_n_dlambda[i][1] << endl << endl; @@ -211,37 +210,37 @@ void Iterate_2CBG_TBAE (Root_Density_Set& Set, Vect >& a_n_dlambda Vect_DP f_Tln_conv_plus (0.0, Set.epsilon[n].Npts); // 'up' convolution // For n = ntypes, need: - //DP Tln1pluseepsntypesinfty = 2.0 * Omega * Set.ntypes - //+ 2.0 * kBT * + //DP Tln1pluseepsntypesinfty = 2.0 * Omega * Set.ntypes + //+ 2.0 * kBT * //((Set.ntypes * Omega/kBT < 24.0 ? log(1.0 - exp(-2.0 * (Set.ntypes + 1) * Omega/kBT)) : - exp(-2.0 * (Set.ntypes + 1) * Omega/kBT)) // - (2.0 * Omega/kBT < 24.0 ? log(1.0 - exp(-2.0 * Omega/kBT)) : - exp(-2.0 * Omega/kBT))); - + Vect_DP fmin(0.0, Set.epsilon[n-1].Npts); - Vect_DP fplus(0.0, Set.epsilon[JSC::min(n+1, Set.ntypes - 1)].Npts); + Vect_DP fplus(0.0, Set.epsilon[ABACUS::min(n+1, Set.ntypes - 1)].Npts); for (int i = 0; i < Set.epsilon[n].Npts; ++i) { f_Tln_conv_min[i] = 0.0; f_Tln_conv_plus[i] = 0.0; // 'down' convolutions - if (n == 1) - for (int j = 0; j < Set.epsilon[0].Npts; ++j) + if (n == 1) + for (int j = 0; j < Set.epsilon[0].Npts; ++j) f_Tln_conv_min[i] += Tln1plusemineps[0][j] * fmin_dlambda[n][i][j]; - else for (int j = 0; j < Set.epsilon[n - 1].Npts; ++j) + else for (int j = 0; j < Set.epsilon[n - 1].Npts; ++j) f_Tln_conv_min[i] += (Set.epsilon[n-1].prev_value[j] - Set.epsilon[n-1].value_infty + Tln1plusemineps[n-1][j] - Tln1pluseminepsinfty[n-1]) * fmin_dlambda[n][i][j]; // 'up' convolutions if (n < Set.ntypes - 1) - for (int j = 0; j < Set.epsilon[n+1].Npts; ++j) + for (int j = 0; j < Set.epsilon[n+1].Npts; ++j) f_Tln_conv_plus[i] += (Set.epsilon[n+1].prev_value[j] - Set.epsilon[n+1].value_infty + Tln1plusemineps[n+1][j] - Tln1pluseminepsinfty[n+1]) * fplus_dlambda[n][i][j]; else f_Tln_conv_plus[i] = 0.0; // Do some damping: - Set.epsilon[n].value[i] = 0.1 * Set.epsilon[n].prev_value[i] + Set.epsilon[n].value[i] = 0.1 * Set.epsilon[n].prev_value[i] + 0.9 * (Set.epsilon[n].value_infty + f_Tln_conv_min[i] + f_Tln_conv_plus[i]); // Force boundary values to asymptotes: force boundary 10 points on each side if (i < 10) @@ -251,11 +250,11 @@ void Iterate_2CBG_TBAE (Root_Density_Set& Set, Vect >& a_n_dlambda /* if (i == 0 && n < 2) { cout << "epsilon[" << n << "][0]: " << Set.epsilon[n].value[i] << "\t" << Set.epsilon[n].prev_value[i] << "\t" - << Set.epsilon[n].value_infty << "\t" << f_Tln_conv_min[i] << "\t" << f_Tln_conv_plus[i] + << Set.epsilon[n].value_infty << "\t" << f_Tln_conv_min[i] << "\t" << f_Tln_conv_plus[i] //<< "\tepsilon[" << n << "][1]: " << Set.epsilon[n].value[1] << "\t" << Set.epsilon[n].prev_value[1] << "\t" - // << Set.epsilon[n].value_infty << "\t" << f_Tln_conv_min[1] << "\t" << f_Tln_conv_plus[1] + // << Set.epsilon[n].value_infty << "\t" << f_Tln_conv_min[1] << "\t" << f_Tln_conv_plus[1] << "\tepsilon[" << n << "][10]: " << Set.epsilon[n].value[10] << "\t" << Set.epsilon[n].prev_value[10] << "\t" - << Set.epsilon[n].value_infty << "\t" << f_Tln_conv_min[10] << "\t" << f_Tln_conv_plus[10] + << Set.epsilon[n].value_infty << "\t" << f_Tln_conv_min[10] << "\t" << f_Tln_conv_plus[10] << endl; } */ @@ -268,14 +267,14 @@ void Iterate_2CBG_TBAE (Root_Density_Set& Set, Vect >& a_n_dlambda /* if (fabs(1.0 - Set.epsilon[n].value[i]/Set.epsilon[n].prev_value[i]) > 0.1) { cout << n << "\t" << i << "\t" << setprecision(8) << Set.epsilon[n].lambda[i] << "\t" << Set.epsilon[n].prev_value[i] << "\t" << Set.epsilon[n].value[i] << "\t" - << Set.epsilon[n].value_infty << "\t" << setprecision(16) << f_Tln_conv_min[i] << "\t" << f_Tln_conv_plus[i] + << Set.epsilon[n].value_infty << "\t" << setprecision(16) << f_Tln_conv_min[i] << "\t" << f_Tln_conv_plus[i] << endl; cout << Set.epsilon[n+1].prev_value << endl << endl << Tln1plusemineps[n+1] << endl << endl; cout << "dlambda: " << Set.epsilon[n+1].dlambda << endl << endl; - for (int j = 0; j < Set.epsilon[n+1].Npts; ++j) + for (int j = 0; j < Set.epsilon[n+1].Npts; ++j) cout << fplus_dlambda[n][i][j]/Set.epsilon[n+1].dlambda[j] << " "; cout << endl << endl; - for (int j = 0; j < Set.epsilon[n+1].Npts; ++j) + for (int j = 0; j < Set.epsilon[n+1].Npts; ++j) cout << Set.epsilon[n+1].prev_value[j] - Set.epsilon[n+1].value_infty + Tln1plusemineps[n+1][j] - Tln1pluseminepsinfty[n+1] << " "; cout << endl << endl; } @@ -288,7 +287,7 @@ void Iterate_2CBG_TBAE (Root_Density_Set& Set, Vect >& a_n_dlambda // All functions have now been iterated. // Now calculate diff: - + DP eps0i = 0.0; DP eps1i = 0.0; @@ -299,46 +298,46 @@ void Iterate_2CBG_TBAE (Root_Density_Set& Set, Vect >& a_n_dlambda //sum_N += Set.epsilon[n].Npts; for (int i = 0; i < Set.epsilon[n].Npts; ++i) { //Set.epsilon[n].diff += pow((Set.epsilon[n].value[i] - Set.epsilon[n].prev_value[i]) - // /JSC::max(1.0, fabs(Set.epsilon[n].value[i] + Set.epsilon[n].prev_value[i])), 2.0); + // /ABACUS::max(1.0, fabs(Set.epsilon[n].value[i] + Set.epsilon[n].prev_value[i])), 2.0); //Set.epsilon[n].diff += fabs((Set.epsilon[n].value[i] - Set.epsilon[n].prev_value[i]) - // /JSC::max(1.0, fabs(Set.epsilon[n].value[i] + Set.epsilon[n].prev_value[i]))); + // /ABACUS::max(1.0, fabs(Set.epsilon[n].value[i] + Set.epsilon[n].prev_value[i]))); //Set.epsilon[n].diff += fabs(kBT * log((1.0 + exp(-fabs(Set.epsilon[n].value[i])/kBT))/(1.0 + exp(-fabs(Set.epsilon[n].prev_value[i])/kBT)))); /* // This one was used in working version before delta f measure: Set.epsilon[n].diff += Set.epsilon[n].dlambda[i] * fabs(Set.epsilon[n].value[i] > 0.0 ? kBT * log((1.0 + exp(-Set.epsilon[n].value[i]/kBT))/(1.0 + exp(-Set.epsilon[n].prev_value[i]/kBT))) - : (-Set.epsilon[n].value[i] + kBT * log(1.0 + exp(Set.epsilon[n].value[i]/kBT))) + : (-Set.epsilon[n].value[i] + kBT * log(1.0 + exp(Set.epsilon[n].value[i]/kBT))) - (-Set.epsilon[n].prev_value[i] + kBT * log(1.0 + exp(Set.epsilon[n].prev_value[i]/kBT)))); */ // Measure based on delta f/delta epsilon: if (n == 0) - Set.epsilon[n].diff += Set.epsilon[n].dlambda[i] * - //(Set.epsilon[0].value[i] > 0.0 ? exp(-Set.epsilon[0].value[i]/kBT)/(1.0 + exp(-Set.epsilon[0].value[i]/kBT)) - // : 1.0/(1.0 + exp(Set.epsilon[0].value[i]/kBT))) - //pow(Set.epsilon[0].value[i] > 0.0 ? + Set.epsilon[n].diff += Set.epsilon[n].dlambda[i] * + //(Set.epsilon[0].value[i] > 0.0 ? exp(-Set.epsilon[0].value[i]/kBT)/(1.0 + exp(-Set.epsilon[0].value[i]/kBT)) + // : 1.0/(1.0 + exp(Set.epsilon[0].value[i]/kBT))) + //pow(Set.epsilon[0].value[i] > 0.0 ? // exp(-Set.epsilon[0].value[i]/kBT)/(1.0 + exp(-Set.epsilon[0].value[i]/kBT)) : 1.0/(1.0 + exp(Set.epsilon[0].value[i]/kBT)), 2.0) //* fabs(Set.epsilon[n].value[i] - Set.epsilon[n].prev_value[i]); - (Set.epsilon[0].value[i] > 0.0 ? + (Set.epsilon[0].value[i] > 0.0 ? exp(-Set.epsilon[0].value[i]/kBT)/(1.0 + exp(-Set.epsilon[0].value[i]/kBT)) : 1.0/(1.0 + exp(Set.epsilon[0].value[i]/kBT))) * fabs(Set.epsilon[n].value[i] - Set.epsilon[n].prev_value[i]); else { eps0i = Set.epsilon[0].Return_Value(Set.epsilon[n].lambda[i]); eps1i = Set.epsilon[1].Return_Value(Set.epsilon[n].lambda[i]); - Set.epsilon[n].diff += Set.epsilon[n].dlambda[i] * + Set.epsilon[n].diff += Set.epsilon[n].dlambda[i] * // Logic: simple 1/2 cascade - (eps0i > 0.0 ? exp(-eps0i/kBT)/(1.0 + exp(-eps0i/kBT)) : 1.0/(1.0 + exp(eps0i/kBT))) + (eps0i > 0.0 ? exp(-eps0i/kBT)/(1.0 + exp(-eps0i/kBT)) : 1.0/(1.0 + exp(eps0i/kBT))) * pow(0.5, n) //* (exp(-eps1i/kBT)/(1.0 + exp(-eps1i/kBT))) * fabs(Set.epsilon[n].value[i] - Set.epsilon[n].prev_value[i]); } - //if (n == 0) cout << i << "\t" << Set.epsilon[n].value[i] << "\t" << Set.epsilon[n].prev_value[i] + //if (n == 0) cout << i << "\t" << Set.epsilon[n].value[i] << "\t" << Set.epsilon[n].prev_value[i] // << "\t" << Set.epsilon[n].value[i] - Set.epsilon[n].prev_value[i] << "\t"; //if (n == 0 && i == Set.epsilon[n].Npts - 1) cout << endl; /* - fabs(kBT * ((Set.epsilon[n].value[i] < 24.0 * kBT ? log(1.0 + exp(-Set.epsilon[n].value[i]/kBT)) + fabs(kBT * ((Set.epsilon[n].value[i] < 24.0 * kBT ? log(1.0 + exp(-Set.epsilon[n].value[i]/kBT)) : exp(-fabs(Set.epsilon[n].value[i])/kBT)) - - (fabs(Set.epsilon[n].prev_value[i]) < 24.0 * kBT ? log(1.0 + exp(-fabs(Set.epsilon[n].prev_value[i])/kBT)) - : exp(-fabs(Set.epsilon[n].prev_value[i])/kBT)))); + - (fabs(Set.epsilon[n].prev_value[i]) < 24.0 * kBT ? log(1.0 + exp(-fabs(Set.epsilon[n].prev_value[i])/kBT)) + : exp(-fabs(Set.epsilon[n].prev_value[i])/kBT)))); */ } //Set.epsilon[n].diff /= Set.epsilon[n].Npts; @@ -351,10 +350,10 @@ void Iterate_2CBG_TBAE (Root_Density_Set& Set, Vect >& a_n_dlambda return; } -void Iterate_and_Extrapolate_2CBG_TBAE (Root_Density_Set& Set, Vect& IterSet, Vect >& a_n_dlambda, +void Iterate_and_Extrapolate_2CBG_TBAE (Root_Density_Set& Set, Vect& IterSet, Vect >& a_n_dlambda, Vect >& fmin_dlambda, Vect >& fplus_dlambda, DP c_int, DP mu, DP Omega, DP kBT) { - // + // int nfit = IterSet.size(); @@ -371,7 +370,7 @@ void Iterate_and_Extrapolate_2CBG_TBAE (Root_Density_Set& Set, Vect 0.0 ? - kBT * (Set.epsilon[n].value[i] < 24.0 * kBT ? log(1.0 + exp(-Set.epsilon[n].value[i]/kBT)) : exp(-Set.epsilon[n].value[i]/kBT)) + kBT * (Set.epsilon[n].value[i] < 24.0 * kBT ? log(1.0 + exp(-Set.epsilon[n].value[i]/kBT)) : exp(-Set.epsilon[n].value[i]/kBT)) : -Set.epsilon[n].value[i] + kBT * log (1.0 + exp(Set.epsilon[n].value[i]/kBT)); } - Tln1pluseminepsinfty[n] = kBT * (Set.epsilon[n].value_infty < 24.0 * kBT ? + Tln1pluseminepsinfty[n] = kBT * (Set.epsilon[n].value_infty < 24.0 * kBT ? log(1.0 + exp(-Set.epsilon[n].value_infty/kBT)) : exp(-Set.epsilon[n].value_infty/kBT)); } @@ -413,7 +412,7 @@ DP Refine_2CBG_Set (Root_Density_Set& Set, DP c_int, DP mu, DP Omega, DP kBT, DP Vect tni(Set.ntypes); Vect tni_ex(Set.ntypes); - //Vect_DP delta_tni_dlambda(0.0, Set.Npts_total); + //Vect_DP delta_tni_dlambda(0.0, Set.Npts_total); //int delta_tni_counter = 0; DP measure_factor = 0.0; @@ -422,7 +421,7 @@ DP Refine_2CBG_Set (Root_Density_Set& Set, DP c_int, DP mu, DP Omega, DP kBT, DP for (int n = 0; n < Set.ntypes; ++n) { - tni[n] = Vect_DP (0.0, Set.epsilon[n].Npts); + tni[n] = Vect_DP (0.0, Set.epsilon[n].Npts); tni_ex[n] = Vect_DP (0.0, Set.epsilon[n].Npts); // extrapolation from adjacent points, to compare to obtained value for (int i = 1; i < Set.epsilon[n].Npts - 1; ++i) { @@ -433,9 +432,9 @@ DP Refine_2CBG_Set (Root_Density_Set& Set, DP c_int, DP mu, DP Omega, DP kBT, DP if (n == 0) { /* tni[n][i] = Set.epsilon[n].value[i] - pow(Set.epsilon[n].lambda[i], 2.0) + mu + Omega + Tln1plusemineps[n][i] - Tln1pluseminepsinfty[n]; - tni_ex[n][i] = ((Set.epsilon[n].value[i-1] - pow(Set.epsilon[n].lambda[i-1], 2.0) + mu + Omega + + tni_ex[n][i] = ((Set.epsilon[n].value[i-1] - pow(Set.epsilon[n].lambda[i-1], 2.0) + mu + Omega + Tln1plusemineps[n][i-1] - Tln1pluseminepsinfty[n]) * (Set.epsilon[n].lambda[i+1] - Set.epsilon[n].lambda[i]) - + (Set.epsilon[n].value[i+1] - pow(Set.epsilon[n].lambda[i+1], 2.0) + mu + Omega + + + (Set.epsilon[n].value[i+1] - pow(Set.epsilon[n].lambda[i+1], 2.0) + mu + Omega + Tln1plusemineps[n][i+1] - Tln1pluseminepsinfty[n]) * (Set.epsilon[n].lambda[i] - Set.epsilon[n].lambda[i-1])) /(Set.epsilon[n].lambda[i+1] - Set.epsilon[n].lambda[i-1]); */ @@ -447,20 +446,20 @@ DP Refine_2CBG_Set (Root_Density_Set& Set, DP c_int, DP mu, DP Omega, DP kBT, DP /(Set.epsilon[n].lambda[i+1] - Set.epsilon[n].lambda[i-1]); */ // Measure based on delta f/delta epsilon: - //measure_factor = Set.epsilon[0].value[i] > 0.0 ? + //measure_factor = Set.epsilon[0].value[i] > 0.0 ? //exp(-Set.epsilon[0].value[i]/kBT)/(1.0 + exp(-Set.epsilon[0].value[i]/kBT)) : 1.0/(1.0 + exp(Set.epsilon[0].value[i]/kBT)); - //measure_factor = pow(Set.epsilon[0].value[i] > 0.0 ? exp(-Set.epsilon[0].value[i]/kBT)/(1.0 + exp(-Set.epsilon[0].value[i]/kBT)) + //measure_factor = pow(Set.epsilon[0].value[i] > 0.0 ? exp(-Set.epsilon[0].value[i]/kBT)/(1.0 + exp(-Set.epsilon[0].value[i]/kBT)) // : 1.0/(1.0 + exp(Set.epsilon[0].value[i]/kBT)), 2.0); - measure_factor = (Set.epsilon[0].value[i] > 0.0 ? exp(-Set.epsilon[0].value[i]/kBT)/(1.0 + exp(-Set.epsilon[0].value[i]/kBT)) + measure_factor = (Set.epsilon[0].value[i] > 0.0 ? exp(-Set.epsilon[0].value[i]/kBT)/(1.0 + exp(-Set.epsilon[0].value[i]/kBT)) : 1.0/(1.0 + exp(Set.epsilon[0].value[i]/kBT))); } else { /* // This is the more natural choice, since delta(epsilon[n]) gets transferred more or less linearly to delta(epsilon[0]): tni[n][i] = Set.epsilon[n].value[i] - Set.epsilon[n].value_infty + Tln1plusemineps[n][i] - Tln1pluseminepsinfty[n]; - tni_ex[n][i] = ((Set.epsilon[n].value[i-1] - Set.epsilon[n].value_infty + Tln1plusemineps[n][i-1] - Tln1pluseminepsinfty[n]) + tni_ex[n][i] = ((Set.epsilon[n].value[i-1] - Set.epsilon[n].value_infty + Tln1plusemineps[n][i-1] - Tln1pluseminepsinfty[n]) * (Set.epsilon[n].lambda[i+1] - Set.epsilon[n].lambda[i]) - + (Set.epsilon[n].value[i+1] - Set.epsilon[n].value_infty + Tln1plusemineps[n][i+1] - Tln1pluseminepsinfty[n]) + + (Set.epsilon[n].value[i+1] - Set.epsilon[n].value_infty + Tln1plusemineps[n][i+1] - Tln1pluseminepsinfty[n]) * (Set.epsilon[n].lambda[i] - Set.epsilon[n].lambda[i-1])) /(Set.epsilon[n].lambda[i+1] - Set.epsilon[n].lambda[i-1]); */ @@ -474,8 +473,8 @@ DP Refine_2CBG_Set (Root_Density_Set& Set, DP c_int, DP mu, DP Omega, DP kBT, DP eps0i = Set.epsilon[0].Return_Value(Set.epsilon[n].lambda[i]); eps1i = Set.epsilon[1].Return_Value(Set.epsilon[n].lambda[i]); - measure_factor = (eps0i > 0.0 ? exp(-eps0i/kBT)/(1.0 + exp(-eps0i/kBT)) : 1.0/(1.0 + exp(eps0i/kBT))) - // Logic: simple 1/2 per level cascade down + measure_factor = (eps0i > 0.0 ? exp(-eps0i/kBT)/(1.0 + exp(-eps0i/kBT)) : 1.0/(1.0 + exp(eps0i/kBT))) + // Logic: simple 1/2 per level cascade down //* (exp(-eps1i/kBT)/(1.0 + exp(-eps1i/kBT))) * pow(0.5, n); @@ -486,9 +485,9 @@ DP Refine_2CBG_Set (Root_Density_Set& Set, DP c_int, DP mu, DP Omega, DP kBT, DP + Set.epsilon[n].value[i+1] * (Set.epsilon[n].lambda[i] - Set.epsilon[n].lambda[i-1])) /(Set.epsilon[n].lambda[i+1] - Set.epsilon[n].lambda[i-1]); - max_delta_tni_dlambda = JSC::max(max_delta_tni_dlambda, fabs(tni[n][i] - tni_ex[n][i]) * Set.epsilon[n].dlambda[i]); - if (n == Set.ntypes - 1) - max_delta_tni_dlambda_toplevel = JSC::max(max_delta_tni_dlambda_toplevel, fabs(tni[n][i] - tni_ex[n][i]) * Set.epsilon[n].dlambda[i]); + max_delta_tni_dlambda = ABACUS::max(max_delta_tni_dlambda, fabs(tni[n][i] - tni_ex[n][i]) * Set.epsilon[n].dlambda[i]); + if (n == Set.ntypes - 1) + max_delta_tni_dlambda_toplevel = ABACUS::max(max_delta_tni_dlambda_toplevel, fabs(tni[n][i] - tni_ex[n][i]) * Set.epsilon[n].dlambda[i]); sum_delta_tni_dlambda += fabs(tni[n][i] - tni_ex[n][i]) * Set.epsilon[n].dlambda[i]; } } @@ -527,7 +526,7 @@ DP Refine_2CBG_Set (Root_Density_Set& Set, DP c_int, DP mu, DP Omega, DP kBT, DP if (exp(-Set.epsilon[0].value[0]/kBT) > 0.001 * max_delta_tni_dlambda) need_to_extend_limit[0] = true; } - else + else //if (fabs(Set.epsilon[n].value[0]/Set.epsilon[n].value_infty - 1.0) * Set.epsilon[n].dlambda[0] > (1.0 - refine_fraction) * max_delta_tni_dlambda) //if (fabs(Set.epsilon[n].value[0]/Set.epsilon[n].value_infty - 1.0) > (1.0 - refine_fraction) * max_delta_tni_dlambda) // Used in working version: @@ -538,25 +537,25 @@ DP Refine_2CBG_Set (Root_Density_Set& Set, DP c_int, DP mu, DP Omega, DP kBT, DP } // Check if we need to add a level - bool need_new_epsilon_n_function = false; + bool need_new_epsilon_n_function = false; - // We add new levels if the integral a_n * Tln1plusemineps at the highest level differs too much from + // We add new levels if the integral a_n * Tln1plusemineps at the highest level differs too much from // the asymptotic value. Since such integrals appear for each point of the epsilon[0] function, these // errors should be compared to the individual delta_tni factors. DP a_2_Tln_conv_0_integ = 0.0; DP oneoverpi = 1.0/PI; DP twoovernc = 2.0/((Set.ntypes - 1) * c_int); int i0 = Set.epsilon[0].Npts/2; - for (int j = 0; j < Set.epsilon[Set.ntypes - 1].Npts; ++j) - a_2_Tln_conv_0_integ += (Tln1plusemineps[Set.ntypes - 1][j] - Tln1pluseminepsinfty[Set.ntypes - 1]) + for (int j = 0; j < Set.epsilon[Set.ntypes - 1].Npts; ++j) + a_2_Tln_conv_0_integ += (Tln1plusemineps[Set.ntypes - 1][j] - Tln1pluseminepsinfty[Set.ntypes - 1]) * oneoverpi * (atan(twoovernc * (Set.epsilon[0].lambda[i0] - Set.epsilon[Set.ntypes - 1].lambda[j] + 0.5 * Set.epsilon[Set.ntypes - 1].dlambda[j])) - - atan(twoovernc * (Set.epsilon[0].lambda[i0] - Set.epsilon[Set.ntypes - 1].lambda[j] - 0.5 * Set.epsilon[Set.ntypes - 1].dlambda[j]))); + - atan(twoovernc * (Set.epsilon[0].lambda[i0] - Set.epsilon[Set.ntypes - 1].lambda[j] - 0.5 * Set.epsilon[Set.ntypes - 1].dlambda[j]))); // Add asymptotic parts: not necessary, identically 0 - //a_2_Tln_conv_0_integ += Tln1pluseminepsinfty[Set.ntypes - 1] + //a_2_Tln_conv_0_integ += Tln1pluseminepsinfty[Set.ntypes - 1] //* (1.0 - (atan((Set.epsilon[Set.ntypes - 1].lambdamax - Set.epsilon[0].lambda[i0])/(0.5 * (Set.ntypes - 1) * c_int)) // + atan((Set.epsilon[Set.ntypes - 1].lambdamax + Set.epsilon[0].lambda[i0])/(0.5 * (Set.ntypes - 1) * c_int)))/PI); - // Compare to prediction for this integral based on value_infty, which is simply 0. + // Compare to prediction for this integral based on value_infty, which is simply 0. // Count this difference Set.ntypes times over, since it cascades down all levels if (fabs(a_2_Tln_conv_0_integ) * Set.ntypes > max_delta_tni_dlambda) need_new_epsilon_n_function = true; @@ -564,7 +563,7 @@ DP Refine_2CBG_Set (Root_Density_Set& Set, DP c_int, DP mu, DP Omega, DP kBT, DP // << "\tmax tni = " << max_delta_tni_dlambda << "\tbool: " << (fabs(a_2_Tln_conv_0_integ) * Set.ntypes > max_delta_tni_dlambda) << endl; // Additionally, if the highest level needs updating, we automatically add new functions: - for (int i = 0; i < Set.epsilon[Set.ntypes - 1].Npts; ++i) + for (int i = 0; i < Set.epsilon[Set.ntypes - 1].Npts; ++i) if (need_new_point_around[Set.ntypes - 1][i] || need_to_extend_limit[Set.ntypes - 1]) need_new_epsilon_n_function = true; // Finally, we also add functions if epsilon[n] itself is too different from epsilon[n](infty), @@ -572,27 +571,27 @@ DP Refine_2CBG_Set (Root_Density_Set& Set, DP c_int, DP mu, DP Omega, DP kBT, DP //if (fabs(Set.epsilon[Set.ntypes - 1].value[Set.epsilon[Set.ntypes - 1].Npts/2] - Set.epsilon[Set.ntypes - 1].value_infty) // Next expression: replaced by following one //* exp(-(Set.epsilon[0].value[Set.epsilon[0].Npts/2] + Set.epsilon[Set.ntypes - 1].value[Set.epsilon[Set.ntypes - 1].Npts/2])/kBT) - ///(1.0 + exp(-Set.epsilon[Set.ntypes - 1].value[Set.epsilon[Set.ntypes - 1].Npts/2]/kBT)) + ///(1.0 + exp(-Set.epsilon[Set.ntypes - 1].value[Set.epsilon[Set.ntypes - 1].Npts/2]/kBT)) //* exp(-Set.epsilon[Set.ntypes - 1].value[Set.epsilon[Set.ntypes - 1].Npts/2]/kBT) // /((1.0 + exp(Set.epsilon[0].value[Set.epsilon[0].Npts/2]/kBT)) * (1.0 + exp(-Set.epsilon[Set.ntypes - 1].value[Set.epsilon[Set.ntypes - 1].Npts/2]/kBT))) // Logic: simple 1/2 factor cascade - //* pow(0.5, Set.ntypes) + //* pow(0.5, Set.ntypes) //* exp(-Set.epsilon[1].value[Set.epsilon[1].Npts/2]/kBT) ///((1.0 + exp(Set.epsilon[0].value[Set.epsilon[0].Npts/2]/kBT)) * (1.0 + exp(-Set.epsilon[1].value[Set.epsilon[1].Npts/2]/kBT))) // > max_delta_tni_dlambda) need_new_epsilon_n_function = true; /* cout << "New level ? " << fabs(Set.epsilon[Set.ntypes - 1].value[Set.epsilon[Set.ntypes - 1].Npts/2] - Set.epsilon[Set.ntypes - 1].value_infty) << "\t" << pow(0.5, Set.ntypes) << "\t" << fabs(Set.epsilon[Set.ntypes - 1].value[Set.epsilon[Set.ntypes - 1].Npts/2] - Set.epsilon[Set.ntypes - 1].value_infty) - * pow(0.5, Set.ntypes) << "\t" << max_delta_tni_dlambda + * pow(0.5, Set.ntypes) << "\t" << max_delta_tni_dlambda << "\t" << (fabs(Set.epsilon[Set.ntypes - 1].value[Set.epsilon[Set.ntypes - 1].Npts/2] - Set.epsilon[Set.ntypes - 1].value_infty) * pow(0.5, Set.ntypes) > max_delta_tni_dlambda) - << "\t" << need_new_epsilon_n_function - << "\t" + << "\t" << need_new_epsilon_n_function + << "\t" //<< endl; ; */ //if (max_delta_tni_dlambda_toplevel > pow(0.5, Set.ntypes) * max_delta_tni_dlambda && Set.ntypes < 100) need_new_epsilon_n_function = true; - //cout << "New level above top level ? " << max_delta_tni_dlambda_toplevel << "\t" << max_delta_tni_dlambda << "\t" + //cout << "New level above top level ? " << max_delta_tni_dlambda_toplevel << "\t" << max_delta_tni_dlambda << "\t" // << (max_delta_tni_dlambda_toplevel > 0.01 * max_delta_tni_dlambda) << endl; // Now insert the new points between existing points: @@ -627,12 +626,12 @@ DP Calculate_Gibbs_Free_Energy (const Root_Density_Set& Set, DP c_int, DP mu, DP DP sum_g_check = 0.0; Vect_DP gcheck(0.0, Set.epsilon[0].Npts); for (int i = 0; i < Set.epsilon[0].Npts; ++i) { - f[i] = (Set.epsilon[0].value[i] > 0.0 ? kBT* log(1.0 + exp(-Set.epsilon[0].value[i]/kBT)) + f[i] = (Set.epsilon[0].value[i] > 0.0 ? kBT* log(1.0 + exp(-Set.epsilon[0].value[i]/kBT)) : -Set.epsilon[0].value[i] + kBT * log(1.0 + exp(Set.epsilon[0].value[i]/kBT))); sum_f += Set.epsilon[0].dlambda[i] * f[i]; - fcheck[i] = kBT * log(1.0 + exp(-(Set.epsilon[0].lambda[i] * Set.epsilon[0].lambda[i] - mu - Omega)/kBT)); + fcheck[i] = kBT * log(1.0 + exp(-(Set.epsilon[0].lambda[i] * Set.epsilon[0].lambda[i] - mu - Omega)/kBT)); sum_f_check += Set.epsilon[0].dlambda[i] * fcheck[i]; - gcheck[i] = exp(-(Set.epsilon[0].lambda[i] * Set.epsilon[0].lambda[i])/kBT); + gcheck[i] = exp(-(Set.epsilon[0].lambda[i] * Set.epsilon[0].lambda[i])/kBT); sum_g_check += Set.epsilon[0].dlambda[i] * gcheck[i]; } @@ -646,13 +645,13 @@ DP Calculate_Gibbs_Free_Energy (const Root_Density_Set& Set, DP c_int, DP mu, DP DP sum_gcorralphacheck = 0.0; Vect_DP gcorr_alpha_check(0.0, Set.epsilon[0].Npts); for (int i = 1; i < Set.epsilon[0].Npts - 1; ++i) { - //gcorr_alpha_check[i] = (pow(Set.epsilon[0].lambda[i+1] - Set.epsilon[0].lambda[i], 3.0) - pow(Set.epsilon[0].lambda[i] - Set.epsilon[0].lambda[i-1], 3.0)) - //* ((gcheck[i+1] - gcheck[i]) * (Set.epsilon[0].lambda[i] - Set.epsilon[0].lambda[i-1]) + //gcorr_alpha_check[i] = (pow(Set.epsilon[0].lambda[i+1] - Set.epsilon[0].lambda[i], 3.0) - pow(Set.epsilon[0].lambda[i] - Set.epsilon[0].lambda[i-1], 3.0)) + //* ((gcheck[i+1] - gcheck[i]) * (Set.epsilon[0].lambda[i] - Set.epsilon[0].lambda[i-1]) // - (gcheck[i] - gcheck[i-1]) * (Set.epsilon[0].lambda[i+1] - Set.epsilon[0].lambda[i])) ///(24.0 * (Set.epsilon[0].lambda[i+1] - Set.epsilon[0].lambda[i-1]) * (Set.epsilon[0].lambda[i+1] - Set.epsilon[0].lambda[i]) //* (Set.epsilon[0].lambda[i] - Set.epsilon[0].lambda[i-1])); - gcorr_alpha_check[i] = (1.0/12.0) * pow(Set.epsilon[0].dlambda[i], 3.0) - * ((gcheck[i+1] - gcheck[i]) * (Set.epsilon[0].lambda[i] - Set.epsilon[0].lambda[i-1]) + gcorr_alpha_check[i] = (1.0/12.0) * pow(Set.epsilon[0].dlambda[i], 3.0) + * ((gcheck[i+1] - gcheck[i]) * (Set.epsilon[0].lambda[i] - Set.epsilon[0].lambda[i-1]) - (gcheck[i] - gcheck[i-1]) * (Set.epsilon[0].lambda[i+1] - Set.epsilon[0].lambda[i])) /((Set.epsilon[0].lambda[i+1] - Set.epsilon[0].lambda[i-1]) * (Set.epsilon[0].lambda[i+1] - Set.epsilon[0].lambda[i]) * (Set.epsilon[0].lambda[i] - Set.epsilon[0].lambda[i-1])); @@ -665,9 +664,9 @@ DP Calculate_Gibbs_Free_Energy (const Root_Density_Set& Set, DP c_int, DP mu, DP // Original version: DP sum_f = 0.0; for (int i = 0; i < Set.epsilon[0].Npts; ++i) { - sum_f += Set.epsilon[0].dlambda[i] * (Set.epsilon[0].value[i] > 0.0 ? kBT* log(1.0 + exp(-Set.epsilon[0].value[i]/kBT)) + sum_f += Set.epsilon[0].dlambda[i] * (Set.epsilon[0].value[i] > 0.0 ? kBT* log(1.0 + exp(-Set.epsilon[0].value[i]/kBT)) : -Set.epsilon[0].value[i] + kBT * log(1.0 + exp(Set.epsilon[0].value[i]/kBT))); - //cout << Set.epsilon[0].lambda[i] << "\t" << Set.epsilon[0].value[i] << "\t" << (Set.epsilon[0].value[i] > 0.0 ? kBT * log(1.0 + exp(-Set.epsilon[0].value[i]/kBT)) + //cout << Set.epsilon[0].lambda[i] << "\t" << Set.epsilon[0].value[i] << "\t" << (Set.epsilon[0].value[i] > 0.0 ? kBT * log(1.0 + exp(-Set.epsilon[0].value[i]/kBT)) //: -Set.epsilon[0].value[i] + kBT * log(1.0 + exp(Set.epsilon[0].value[i]/kBT))) << endl; } */ @@ -688,7 +687,7 @@ DP Calculate_Gibbs_Free_Energy (const Root_Density_Set& Set, DP c_int, DP mu, DP //cout << "Test1: " << Npts_test << "\t" << lambdamax_test << "\t" << -testsum/twoPI << "\t" << testgauss/sqrt(PI * kBT) << endl; /* - cout << setprecision(16) << "Npts = " << Set.epsilon[0].Npts << "\tlambdamax = " << Set.epsilon[0].lambdamax + cout << setprecision(16) << "Npts = " << Set.epsilon[0].Npts << "\tlambdamax = " << Set.epsilon[0].lambdamax << "\tf = " << -sum_f/twoPI << "\tGaussian: " << sum_g_check/sqrt(PI * kBT) << "\ttestGauss = " << testgauss/sqrt(PI * kBT) << endl; cout << setprecision(16) << Set.epsilon[0].dlambda.sum() << "\t" << Set.epsilon[0].lambdamax * 2.0 << endl; cout << gcheck << endl << endl; @@ -777,16 +776,16 @@ DP Calculate_Gibbs_Free_Energy (const Root_Density_Set& Set, DP c_int, DP mu, DP return(-sum_f/twoPI); } -DP Calculate_dGibbs_dchempot (const Root_Density_Set& DSet, const Root_Density_Set& Set, DP c_int, DP mu, DP Omega, DP kBT) +DP Calculate_dGibbs_dchempot (const Root_Density_Set& DSet, const Root_Density_Set& Set, DP c_int, DP mu, DP Omega, DP kBT) { // This calculates the derivative of the Gibbs free energy with respect to either of the two chemical potential, - // given the fundametal set Set for eps and DSet for either deps_du or deps_dOmega. + // given the fundametal set Set for eps and DSet for either deps_du or deps_dOmega. DP sum_f = 0.0; Vect_DP f(0.0, Set.epsilon[0].Npts); for (int i = 0; i < Set.epsilon[0].Npts; ++i) { - f[i] = DSet.epsilon[0].value[i] * (Set.epsilon[0].value[i] > 0.0 ? exp(-Set.epsilon[0].value[i]/kBT)/(1.0 + exp(-Set.epsilon[0].value[i]/kBT)) + f[i] = DSet.epsilon[0].value[i] * (Set.epsilon[0].value[i] > 0.0 ? exp(-Set.epsilon[0].value[i]/kBT)/(1.0 + exp(-Set.epsilon[0].value[i]/kBT)) : 1.0/(1.0 + exp(Set.epsilon[0].value[i]/kBT))); sum_f += DSet.epsilon[0].dlambda[i] * f[i]; } @@ -807,7 +806,7 @@ Vect > Build_a_n_dlambda (const Root_Density_Set& Set, DP c_int, D DP oneoverc = 1.0/c_int; //DP oneovertwoc = 0.5/c_int; //DP oneovercsq = oneoverc * oneoverc; - DP twoovernc = 2.0/c_int; + DP twoovernc = 2.0/c_int; //DP oneovernc; //DP oneoverncsq; @@ -841,13 +840,13 @@ Vect > Build_a_n_dlambda (const Root_Density_Set& Set, DP c_int, D //a_n_dlambda[i][0] = Vect_DP (0.0, Set.epsilon[0].Npts); /* a_n_dlambda[i][0][0] = Set.epsilon[0].dlambda[0] * oneoverpi * c_int/(pow(Set.epsilon[0].lambda[i] - Set.epsilon[0].lambda[0], 2.0) + c_int*c_int); - a_n_dlambda[i][0][Set.epsilon[0].Npts - 1] = Set.epsilon[0].dlambda[Set.epsilon[0].Npts - 1] * oneoverpi + a_n_dlambda[i][0][Set.epsilon[0].Npts - 1] = Set.epsilon[0].dlambda[Set.epsilon[0].Npts - 1] * oneoverpi * c_int/(pow(Set.epsilon[0].lambda[i] - Set.epsilon[0].lambda[Set.epsilon[0].Npts - 1], 2.0) + c_int*c_int); for (int j = 1; j < Set.epsilon[0].Npts - 1; ++j) //a_n_dlambda[i][0][j] = oneoverpi * (atan((Set.epsilon[0].lambda[i] - midlambdaleft[0][j]) * oneoverc) // - atan((Set.epsilon[0].lambda[i] - midlambdaleft[0][j+1]) * oneoverc)); a_n_dlambda[i][0][j] = oneoverpi * atan(oneovertwoc * (Set.epsilon[0].lambda[j+1] - Set.epsilon[0].lambda[j-1]) - /(1.0 + oneovercsq * (Set.epsilon[0].lambda[i] - midlambdaleft[0][j]) + /(1.0 + oneovercsq * (Set.epsilon[0].lambda[i] - midlambdaleft[0][j]) * (Set.epsilon[0].lambda[i] - midlambdaleft[0][j+1]))); */ for (int j = 0; j < Set.epsilon[0].Npts; ++j) @@ -858,16 +857,16 @@ Vect > Build_a_n_dlambda (const Root_Density_Set& Set, DP c_int, D a_n_dlambda[i][0][j] = oneoverpi * (atan(oneoverc * (Set.epsilon[0].lambda[i] - Set.epsilon[0].lambda[j] + 0.5 * Set.epsilon[0].dlambda[j])) - atan(oneoverc * (Set.epsilon[0].lambda[i] - Set.epsilon[0].lambda[j] - 0.5 * Set.epsilon[0].dlambda[j]))); - //if (fabs(a_n_dlambda[i][0].sum() - 1.0) > 1.0e-12) cout << "Error in sum a_n for n = " << 0 << " i = " << i << "\tsum = " + //if (fabs(a_n_dlambda[i][0].sum() - 1.0) > 1.0e-12) cout << "Error in sum a_n for n = " << 0 << " i = " << i << "\tsum = " // << a_n_dlambda[i][0].sum() << endl << endl << a_n_dlambda[i][0] << endl << endl; // Now do n > 0: for (int n = 1; n < Set.ntypes; ++n) { //a_n_dlambda[i][n] = Vect_DP (0.0, Set.epsilon[n].Npts); - //a_n_dlambda[i][n][0] = Set.epsilon[n].dlambda[0] * 0.5 * n * oneoverpi * c_int + //a_n_dlambda[i][n][0] = Set.epsilon[n].dlambda[0] * 0.5 * n * oneoverpi * c_int ///(pow(Set.epsilon[0].lambda[i] - Set.epsilon[n].lambda[0], 2.0) + 0.25 * n * n * c_int*c_int); - //a_n_dlambda[i][n][Set.epsilon[n].Npts - 1] = Set.epsilon[n].dlambda[Set.epsilon[n].Npts - 1] * 0.5 * n * oneoverpi * c_int + //a_n_dlambda[i][n][Set.epsilon[n].Npts - 1] = Set.epsilon[n].dlambda[Set.epsilon[n].Npts - 1] * 0.5 * n * oneoverpi * c_int // /(pow(Set.epsilon[0].lambda[i] - Set.epsilon[n].lambda[Set.epsilon[n].Npts - 1], 2.0) + 0.25 * n * n * c_int*c_int); twoovernc = 2.0/(n * c_int); //oneovernc = 1.0/(n * c_int); @@ -884,32 +883,32 @@ Vect > Build_a_n_dlambda (const Root_Density_Set& Set, DP c_int, D - atan(twoovernc * (Set.epsilon[0].lambda[i] - Set.epsilon[n].lambda[j] - 0.5 * Set.epsilon[n].dlambda[j]))); } } // for (int n - } // for (int i + } // for (int i return(a_n_dlambda); -} +} //void Build_fmin_dlambda (Vect >& fmin_dlambda, const Root_Density_Set& Set, DP c_int, DP mu, DP Omega, DP kBT) Vect > Build_fmin_dlambda (const Root_Density_Set& Set, DP c_int, DP mu, DP Omega, DP kBT) { DP oneoverpi = 1.0/PI; //DP oneoverc = 1.0/c_int; - //DP twoovernc = 2.0/c_int; + //DP twoovernc = 2.0/c_int; DP pioverc = PI/c_int; DP twopioverc = 2.0*PI/c_int; DP piovertwoc = 0.5 * pioverc; - Vect > fmin_dlambda(Set.ntypes); + Vect > fmin_dlambda(Set.ntypes); for (int n = 0; n < Set.ntypes; ++n) { fmin_dlambda[n] = Vect (Set.epsilon[n].Npts); for (int i = 0; i < Set.epsilon[n].Npts; ++i) - fmin_dlambda[n][i] = Vect_DP (0.0, Set.epsilon[JSC::max(n-1, 0)].Npts); + fmin_dlambda[n][i] = Vect_DP (0.0, Set.epsilon[ABACUS::max(n-1, 0)].Npts); } for (int n = 1; n < Set.ntypes; ++n) { for (int i = 0; i < Set.epsilon[n].Npts; ++i) { /* - fmin_dlambda[n][i][0] = (Set.epsilon[n-1].dlambda[0]/c_int) + fmin_dlambda[n][i][0] = (Set.epsilon[n-1].dlambda[0]/c_int) * (Set.epsilon[n].lambda[i] - Set.epsilon[n-1].lambda[0] > 0.0 ? exp(-pioverc * (Set.epsilon[n].lambda[i] - Set.epsilon[n-1].lambda[0])) /(1.0 + exp(-twopioverc * (Set.epsilon[n].lambda[i] - Set.epsilon[n-1].lambda[0]))) @@ -918,7 +917,7 @@ Vect > Build_fmin_dlambda (const Root_Density_Set& Set, DP c_int, /(1.0 + exp(twopioverc * (Set.epsilon[n].lambda[i] - Set.epsilon[n-1].lambda[0])))); //cosh(pioverc * (Set.epsilon[n].lambda[i] - Set.epsilon[n-1].lambda[0]))); - fmin_dlambda[n][i][Set.epsilon[n-1].Npts - 1] = (Set.epsilon[n-1].dlambda[Set.epsilon[n-1].Npts - 1]/c_int) + fmin_dlambda[n][i][Set.epsilon[n-1].Npts - 1] = (Set.epsilon[n-1].dlambda[Set.epsilon[n-1].Npts - 1]/c_int) * (Set.epsilon[n].lambda[i] - Set.epsilon[n-1].lambda[Set.epsilon[n-1].Npts - 1] > 0.0 ? exp(-pioverc * (Set.epsilon[n].lambda[i] - Set.epsilon[n-1].lambda[Set.epsilon[n-1].Npts - 1])) /(1.0 + exp(-twopioverc * (Set.epsilon[n].lambda[i] - Set.epsilon[n-1].lambda[Set.epsilon[n-1].Npts - 1]))) @@ -927,15 +926,15 @@ Vect > Build_fmin_dlambda (const Root_Density_Set& Set, DP c_int, /(1.0 + exp(twopioverc * (Set.epsilon[n].lambda[i] - Set.epsilon[n-1].lambda[Set.epsilon[n-1].Npts - 1])))); ///(c_int * cosh(pioverc * (Set.epsilon[n].lambda[i] - Set.epsilon[n-1].lambda[Set.epsilon[n-1].Npts - 1]))); for (int j = 1; j < Set.epsilon[n-1].Npts - 1; ++j) { - if (Set.epsilon[n].lambda[i] >= Set.epsilon[n-1].lambda[j]) + if (Set.epsilon[n].lambda[i] >= Set.epsilon[n-1].lambda[j]) fmin_dlambda[n][i][j] = oneoverpi * atan((exp(pioverc * (-Set.epsilon[n].lambda[i] + 0.5 * (Set.epsilon[n-1].lambda[j] + Set.epsilon[n-1].lambda[j+1]))) - exp(pioverc * (-Set.epsilon[n].lambda[i] + 0.5 * (Set.epsilon[n-1].lambda[j] + Set.epsilon[n-1].lambda[j-1])))) - /(1.0 + exp(pioverc * (-2.0 * Set.epsilon[n].lambda[i] + Set.epsilon[n-1].lambda[j] + /(1.0 + exp(pioverc * (-2.0 * Set.epsilon[n].lambda[i] + Set.epsilon[n-1].lambda[j] + 0.5 * (Set.epsilon[n-1].lambda[j-1] + Set.epsilon[n-1].lambda[j+1]))))); - else + else fmin_dlambda[n][i][j] = oneoverpi * atan((exp(pioverc * (Set.epsilon[n].lambda[i] - 0.5 * (Set.epsilon[n-1].lambda[j] + Set.epsilon[n-1].lambda[j-1]))) - exp(pioverc * (Set.epsilon[n].lambda[i] - 0.5 * (Set.epsilon[n-1].lambda[j] + Set.epsilon[n-1].lambda[j+1])))) - /(1.0 + exp(pioverc * (2.0 * Set.epsilon[n].lambda[i] - Set.epsilon[n-1].lambda[j] + /(1.0 + exp(pioverc * (2.0 * Set.epsilon[n].lambda[i] - Set.epsilon[n-1].lambda[j] - 0.5 * (Set.epsilon[n-1].lambda[j-1] + Set.epsilon[n-1].lambda[j+1]))))); } @@ -951,8 +950,8 @@ Vect > Build_fmin_dlambda (const Root_Density_Set& Set, DP c_int, //fmin_dlambda[n][i][j] = oneoverpi * atan(exp(pioverc * (Set.epsilon[n].lambda[i] - Set.epsilon[n-1].lambda[j] - 0.5 * Set.epsilon[n-1].dlambda[j]))); */ - for (int j = 0; j < Set.epsilon[n-1].Npts; ++j) - fmin_dlambda[n][i][j] = oneoverpi * atan(exp(-pioverc * fabs(Set.epsilon[n].lambda[i] - Set.epsilon[n-1].lambda[j])) + for (int j = 0; j < Set.epsilon[n-1].Npts; ++j) + fmin_dlambda[n][i][j] = oneoverpi * atan(exp(-pioverc * fabs(Set.epsilon[n].lambda[i] - Set.epsilon[n-1].lambda[j])) * 2.0 * sinh(piovertwoc * Set.epsilon[n-1].dlambda[j]) /(1.0 + exp(-twopioverc * fabs(Set.epsilon[n].lambda[i] - Set.epsilon[n-1].lambda[j])))); @@ -960,29 +959,29 @@ Vect > Build_fmin_dlambda (const Root_Density_Set& Set, DP c_int, } // for n return(fmin_dlambda); -} +} //void Build_fplus_dlambda (Vect >& fplus_dlambda, const Root_Density_Set& Set, DP c_int, DP mu, DP Omega, DP kBT) Vect > Build_fplus_dlambda (const Root_Density_Set& Set, DP c_int, DP mu, DP Omega, DP kBT) { DP oneoverpi = 1.0/PI; //DP oneoverc = 1.0/c_int; - //DP twoovernc = 2.0/c_int; + //DP twoovernc = 2.0/c_int; DP pioverc = PI/c_int; DP twopioverc = 2.0*PI/c_int; DP piovertwoc = 0.5 * pioverc; - + Vect > fplus_dlambda(Set.ntypes); for (int n = 0; n < Set.ntypes; ++n) { fplus_dlambda[n] = Vect (Set.epsilon[n].Npts); for (int i = 0; i < Set.epsilon[n].Npts; ++i) - fplus_dlambda[n][i] = Vect_DP (0.0, Set.epsilon[JSC::min(n+1, Set.ntypes - 1)].Npts); + fplus_dlambda[n][i] = Vect_DP (0.0, Set.epsilon[ABACUS::min(n+1, Set.ntypes - 1)].Npts); } for (int n = 0; n < Set.ntypes - 1; ++n) { for (int i = 0; i < Set.epsilon[n].Npts; ++i) { /* - fplus_dlambda[n][i][0] = (Set.epsilon[n+1].dlambda[0]/c_int) + fplus_dlambda[n][i][0] = (Set.epsilon[n+1].dlambda[0]/c_int) * (Set.epsilon[n].lambda[i] - Set.epsilon[n+1].lambda[0] > 0.0 ? exp(-pioverc * (Set.epsilon[n].lambda[i] - Set.epsilon[n+1].lambda[0])) /(1.0 + exp(-twopioverc * (Set.epsilon[n].lambda[i] - Set.epsilon[n+1].lambda[0]))) @@ -990,7 +989,7 @@ Vect > Build_fplus_dlambda (const Root_Density_Set& Set, DP c_int, exp(pioverc * (Set.epsilon[n].lambda[i] - Set.epsilon[n+1].lambda[0])) /(1.0 + exp(twopioverc * (Set.epsilon[n].lambda[i] - Set.epsilon[n+1].lambda[0])))); //cosh(pioverc * (Set.epsilon[n].lambda[i] - Set.epsilon[n+1].lambda[0]))); - fplus_dlambda[n][i][Set.epsilon[n+1].Npts - 1] = (Set.epsilon[n+1].dlambda[Set.epsilon[n+1].Npts - 1]/c_int) + fplus_dlambda[n][i][Set.epsilon[n+1].Npts - 1] = (Set.epsilon[n+1].dlambda[Set.epsilon[n+1].Npts - 1]/c_int) * (Set.epsilon[n].lambda[i] - Set.epsilon[n+1].lambda[Set.epsilon[n+1].Npts - 1] > 0.0 ? exp(-pioverc * (Set.epsilon[n].lambda[i] - Set.epsilon[n+1].lambda[Set.epsilon[n+1].Npts - 1])) /(1.0 + exp(-twopioverc * (Set.epsilon[n].lambda[i] - Set.epsilon[n+1].lambda[Set.epsilon[n+1].Npts - 1]))) @@ -999,17 +998,17 @@ Vect > Build_fplus_dlambda (const Root_Density_Set& Set, DP c_int, /(1.0 + exp(twopioverc * (Set.epsilon[n].lambda[i] - Set.epsilon[n+1].lambda[Set.epsilon[n+1].Npts - 1])))); ///(c_int * cosh(pioverc * (Set.epsilon[n].lambda[i] - Set.epsilon[n+1].lambda[Set.epsilon[n+1].Npts - 1]))); for (int j = 1; j < Set.epsilon[n+1].Npts - 1; ++j) { - if (Set.epsilon[n].lambda[i] >= Set.epsilon[n+1].lambda[j]) + if (Set.epsilon[n].lambda[i] >= Set.epsilon[n+1].lambda[j]) fplus_dlambda[n][i][j] = oneoverpi * atan((exp(pioverc * (-Set.epsilon[n].lambda[i] + 0.5 * (Set.epsilon[n+1].lambda[j] + Set.epsilon[n+1].lambda[j+1]))) - exp(pioverc * (-Set.epsilon[n].lambda[i] + 0.5 * (Set.epsilon[n+1].lambda[j] + Set.epsilon[n+1].lambda[j-1])))) - /(1.0 + exp(pioverc * (-2.0 * Set.epsilon[n].lambda[i] + Set.epsilon[n+1].lambda[j] + /(1.0 + exp(pioverc * (-2.0 * Set.epsilon[n].lambda[i] + Set.epsilon[n+1].lambda[j] + 0.5 * (Set.epsilon[n+1].lambda[j-1] + Set.epsilon[n+1].lambda[j+1]))))); - else + else fplus_dlambda[n][i][j] = oneoverpi * atan((exp(pioverc * (Set.epsilon[n].lambda[i] - 0.5 * (Set.epsilon[n+1].lambda[j] + Set.epsilon[n+1].lambda[j-1]))) - exp(pioverc * (Set.epsilon[n].lambda[i] - 0.5 * (Set.epsilon[n+1].lambda[j] + Set.epsilon[n+1].lambda[j+1])))) - /(1.0 + exp(pioverc * (2.0 * Set.epsilon[n].lambda[i] - Set.epsilon[n+1].lambda[j] + /(1.0 + exp(pioverc * (2.0 * Set.epsilon[n].lambda[i] - Set.epsilon[n+1].lambda[j] - 0.5 * (Set.epsilon[n+1].lambda[j-1] + Set.epsilon[n+1].lambda[j+1]))))); - } + } // Boundary points: to ensure stability, make sure that \int_{-\infty}^{\infty} fmin_dlambda(., ., lambda) = 1/2. // For j == 0, assume lambda[j-1] = -infinity: @@ -1021,15 +1020,15 @@ Vect > Build_fplus_dlambda (const Root_Density_Set& Set, DP c_int, fplus_dlambda[n][i][j] = oneoverpi * atan(exp(pioverc * (Set.epsilon[n].lambda[i] - 0.5 * (Set.epsilon[n+1].lambda[j] + Set.epsilon[n+1].lambda[j-1])))); //fplus_dlambda[n][i][j] = oneoverpi * atan(exp(pioverc * (Set.epsilon[n].lambda[i] - Set.epsilon[n+1].lambda[j] - 0.5 * Set.epsilon[n+1].dlambda[j]))); */ - for (int j = 0; j < Set.epsilon[n+1].Npts; ++j) - fplus_dlambda[n][i][j] = oneoverpi * atan(exp(-pioverc * fabs(Set.epsilon[n].lambda[i] - Set.epsilon[n+1].lambda[j])) + for (int j = 0; j < Set.epsilon[n+1].Npts; ++j) + fplus_dlambda[n][i][j] = oneoverpi * atan(exp(-pioverc * fabs(Set.epsilon[n].lambda[i] - Set.epsilon[n+1].lambda[j])) * 2.0 * sinh(piovertwoc * Set.epsilon[n+1].dlambda[j]) /(1.0 + exp(-twopioverc * fabs(Set.epsilon[n].lambda[i] - Set.epsilon[n+1].lambda[j])))); } } return(fplus_dlambda); -} +} //void Solve_2CBG_TBAE_via_refinements (Root_Density_Set& TBA_Set, DP c_int, DP mu, DP Omega, DP kBT, int Max_Secs, ofstream& LOG_outfile) Root_Density_Set Solve_2CBG_TBAE_via_refinements (DP c_int, DP mu, DP Omega, DP kBT, int Max_Secs, ofstream& LOG_outfile, bool Save_data) @@ -1049,30 +1048,30 @@ Root_Density_Set Solve_2CBG_TBAE_via_refinements (DP c_int, DP mu, DP Omega, DP // Set basic number of types needed: int ntypes_needed = int(kBT * log(kBT/1.0e-14)/Omega); - int ntypes = JSC::max(ntypes_needed, 1); - ntypes = JSC::min(ntypes, 10); + int ntypes = ABACUS::max(ntypes_needed, 1); + ntypes = ABACUS::min(ntypes, 10); //cout << "ntypes = " << ntypes << endl; if (Save_data) if (ntypes >= 10) LOG_outfile << "WARNING: ntypes needs to be quite high for c_int = " << c_int << " mu = " << mu << " Omega = " << Omega - << " kBT = " << kBT << ". Set to " << ntypes << ", ideally needed: " + << " kBT = " << kBT << ". Set to " << ntypes << ", ideally needed: " << ntypes_needed << ". Accuracy might be incorrectly evaluated." << endl; - DP lambdamax = 10.0 + sqrt(JSC::max(1.0, kBT * 36.0 + mu + Omega)); // such that exp(-(lambdamax^2 - mu - Omega)/T) <~ machine_eps + DP lambdamax = 10.0 + sqrt(ABACUS::max(1.0, kBT * 36.0 + mu + Omega)); // such that exp(-(lambdamax^2 - mu - Omega)/T) <~ machine_eps int Npts = 50; - //int Npts = JSC::max(200, int(2 * lambdamax)); // For stability, we need *all* dlambda < 2. Choose max(dlambda) = 1 here for safety. - //if (Npts < int(2 * lambdamax)) + //int Npts = ABACUS::max(200, int(2 * lambdamax)); // For stability, we need *all* dlambda < 2. Choose max(dlambda) = 1 here for safety. + //if (Npts < int(2 * lambdamax)) //LOG_outfile << "WARNING: dlambda = " << 2.0 * lambdamax/Npts << " might be too large to ensure numerical stability of iterations." << endl; Vect_INT Npts_init(Npts, ntypes); //Vect_DP lambdamax_init(c_int * 10.0, ntypes); // such that exp(-pi *lambdamax/c) <~ machine_eps // We let the number of points fall off with increasing level n: - //for (int n = 1; n < ntypes; ++n) Npts_init[n] = JSC::max(100, 2*int(Npts/(n+1.0))); // DON'T !! Unstable. + //for (int n = 1; n < ntypes; ++n) Npts_init[n] = ABACUS::max(100, 2*int(Npts/(n+1.0))); // DON'T !! Unstable. if (Save_data) LOG_outfile << "Npts (basic) set to " << Npts_init << endl; Vect_DP lambdamax_init(lambdamax, ntypes); // such that exp(-pi *lambdamax/c) <~ machine_eps Npts_init[0] = 1 * Npts; // give more precision to lowest level - lambdamax_init[0] = 10.0 + sqrt(JSC::max(1.0, kBT * 36.0 + mu + Omega)); // such that exp(-(lambdamax^2 - mu - Omega)/T) <~ machine_eps + lambdamax_init[0] = 10.0 + sqrt(ABACUS::max(1.0, kBT * 36.0 + mu + Omega)); // such that exp(-(lambdamax^2 - mu - Omega)/T) <~ machine_eps Root_Density_Set TBA_Set (ntypes, Npts_init, lambdamax_init); //TBA_Set = Root_Density_Set(ntypes, Npts, lambdamax); @@ -1122,8 +1121,8 @@ Root_Density_Set Solve_2CBG_TBAE_via_refinements (DP c_int, DP mu, DP Omega, DP // For extrapolations: Vect IterSet(4); - - do { + + do { //TBA_Set.Save("Test2.dat"); @@ -1134,16 +1133,16 @@ Root_Density_Set Solve_2CBG_TBAE_via_refinements (DP c_int, DP mu, DP Omega, DP //Iterate_2CBG_TBAE (TBA_Set, c_int, mu, Omega, kBT); Iterate_2CBG_TBAE (TBA_Set, a_n_dlambda, fmin_dlambda, fplus_dlambda, c_int, mu, Omega, kBT); //cout << "iteration " << niter << "\tepsilon[0](0) = " << TBA_Set.epsilon[0].value[TBA_Set.epsilon[0].Npts/2] - // << "\tdelta epsilon[0](0) = " << TBA_Set.epsilon[0].value[TBA_Set.epsilon[0].Npts/2] - TBA_Set.epsilon[0].prev_value[TBA_Set.epsilon[0].Npts/2] - // << "\tdiff[0] = " << TBA_Set.epsilon[0].diff << "\tdiff[1] = " << TBA_Set.epsilon[1].diff + // << "\tdelta epsilon[0](0) = " << TBA_Set.epsilon[0].value[TBA_Set.epsilon[0].Npts/2] - TBA_Set.epsilon[0].prev_value[TBA_Set.epsilon[0].Npts/2] + // << "\tdiff[0] = " << TBA_Set.epsilon[0].diff << "\tdiff[1] = " << TBA_Set.epsilon[1].diff // << "\tdiff[ntypes - 1] = " << TBA_Set.epsilon[TBA_Set.ntypes - 1].diff << "\tdiff = " << TBA_Set.diff << endl; niter++; } - else { + else { Iterate_and_Extrapolate_2CBG_TBAE (TBA_Set, IterSet, a_n_dlambda, fmin_dlambda, fplus_dlambda, c_int, mu, Omega, kBT); //cout << "extrap it " << niter << "\tepsilon[0](0) = " << TBA_Set.epsilon[0].value[TBA_Set.epsilon[0].Npts/2] - // << "\tdelta epsilon[0](0) = " - // << TBA_Set.epsilon[0].value[TBA_Set.epsilon[0].Npts/2] - TBA_Set.epsilon[0].prev_value[TBA_Set.epsilon[0].Npts/2] + // << "\tdelta epsilon[0](0) = " + // << TBA_Set.epsilon[0].value[TBA_Set.epsilon[0].Npts/2] - TBA_Set.epsilon[0].prev_value[TBA_Set.epsilon[0].Npts/2] // << "\tdiff = " << TBA_Set.diff << endl; niter += 6; } @@ -1160,12 +1159,12 @@ Root_Density_Set Solve_2CBG_TBAE_via_refinements (DP c_int, DP mu, DP Omega, DP //} while (niter < 20 || niter < niter_max && TBA_Set.diff > 1.0e-10 * TBA_Set.Npts_total && CPU_ticks < Max_CPU_ticks); } while (niter < 5 || niter < niter_max && TBA_Set.diff > 0.1 * running_prec && CPU_ticks < Max_CPU_ticks); - if (Save_data) { - LOG_outfile << "ncycles = " << ncycles << "\trunning_prec = " << running_prec << "\t niter = " << niter + if (Save_data) { + LOG_outfile << "ncycles = " << ncycles << "\trunning_prec = " << running_prec << "\t niter = " << niter << "\tntypes = " << TBA_Set.ntypes << "\tNpts "; for (int n = 0; n < TBA_Set.ntypes; ++n) LOG_outfile << TBA_Set.epsilon[n].Npts << " "; //for (int n = 0; n < TBA_Set.ntypes; ++n) LOG_outfile << TBA_Set.epsilon[n].value_infty << " "; - LOG_outfile << "\tNpts_total = " << TBA_Set.Npts_total << endl + LOG_outfile << "\tNpts_total = " << TBA_Set.Npts_total << endl << "\tdiff = " << TBA_Set.diff << "\tGSE = " << Calculate_Gibbs_Free_Energy (TBA_Set, c_int, mu, Omega, kBT) << endl; } @@ -1173,18 +1172,18 @@ Root_Density_Set Solve_2CBG_TBAE_via_refinements (DP c_int, DP mu, DP Omega, DP niter_tot += niter; if (niter == niter_max) { - if (Save_data) LOG_outfile << "Not able to improve functions enough after " << niter_max << " iterations." << endl; + if (Save_data) LOG_outfile << "Not able to improve functions enough after " << niter_max << " iterations." << endl; //break; } Cycle_StopTime = clock(); - } while (CPU_ticks < Max_CPU_ticks - 2.0*(Cycle_StopTime - Cycle_StartTime)); + } while (CPU_ticks < Max_CPU_ticks - 2.0*(Cycle_StopTime - Cycle_StartTime)); // Allow a new cycle only if there is time, assuming new cycle time < 2* last one if (Save_data) { - LOG_outfile << "c_int " << c_int << "\tmu " << mu << "\tOmega " << Omega << "\tkBT " << kBT - << "\tncycles = " << ncycles << "\trunning_prec = " << running_prec << "\t niter_tot = " << niter_tot + LOG_outfile << "c_int " << c_int << "\tmu " << mu << "\tOmega " << Omega << "\tkBT " << kBT + << "\tncycles = " << ncycles << "\trunning_prec = " << running_prec << "\t niter_tot = " << niter_tot << "\tntypes = " << TBA_Set.ntypes << "\tdiff = " << TBA_Set.diff << endl << "\tNpts "; for (int n = 0; n < TBA_Set.ntypes; ++n) LOG_outfile << TBA_Set.epsilon[n].Npts << " "; //for (int n = 0; n < TBA_Set.ntypes; ++n) LOG_outfile << TBA_Set.epsilon[n].value_infty << " "; @@ -1197,15 +1196,15 @@ Root_Density_Set Solve_2CBG_TBAE_via_refinements (DP c_int, DP mu, DP Omega, DP // Iterative procedures for deps/dmu or /dOmega: -void Iterate_2CBG_deps_dchempot (int option, Root_Density_Set& DSet, const Root_Density_Set& Set, +void Iterate_2CBG_deps_dchempot (int option, Root_Density_Set& DSet, const Root_Density_Set& Set, Vect >& a_n_dlambda, Vect >& fmin_dlambda, Vect >& fplus_dlambda, DP c_int, DP mu, DP Omega, DP kBT) { // Produces a new Root_Density_Set for depsilon/dmu (option == 0) or depsilon/dOmega (option == 1) from a previous iteration. - // Does NOT add types or change Npts, lambdamax values. + // Does NOT add types or change Npts, lambdamax values. //DP oneoverc = 1.0/c_int; - //DP twoovernc = 2.0/c_int; + //DP twoovernc = 2.0/c_int; // First define some useful functions: Vect depsover1plusemineps(Set.ntypes); @@ -1219,10 +1218,10 @@ void Iterate_2CBG_deps_dchempot (int option, Root_Density_Set& DSet, const Root_ depsover1plusepluseps[n] = Vect_DP (0.0, Set.epsilon[n].Npts); for (int i = 0; i < Set.epsilon[n].Npts; ++i) { - depsover1plusemineps[n][i] = Set.epsilon[n].value[i] > 0.0 ? - DSet.epsilon[n].value[i]/(1.0 + exp(-Set.epsilon[n].value[i]/kBT)) : + depsover1plusemineps[n][i] = Set.epsilon[n].value[i] > 0.0 ? + DSet.epsilon[n].value[i]/(1.0 + exp(-Set.epsilon[n].value[i]/kBT)) : DSet.epsilon[n].value[i] * exp(Set.epsilon[n].value[i]/kBT)/(1.0 + exp(Set.epsilon[n].value[i]/kBT)); - depsover1plusepluseps[n][i] = Set.epsilon[n].value[i] > 0.0 ? + depsover1plusepluseps[n][i] = Set.epsilon[n].value[i] > 0.0 ? DSet.epsilon[n].value[i] * exp(-Set.epsilon[n].value[i]/kBT)/(1.0 + exp(-Set.epsilon[n].value[i]/kBT)) : DSet.epsilon[n].value[i]/(1.0 + exp(Set.epsilon[n].value[i]/kBT)); @@ -1255,7 +1254,7 @@ void Iterate_2CBG_deps_dchempot (int option, Root_Density_Set& DSet, const Root_ } // for (int n... We now have all the a_n * deps... at our disposal. // For n > nmax sum in RHS of BE for epsilon, assuming epsilon_n = epsilon_n^\infty in those cases: - // Remember: nmax = Set.ntypes - 1 + // Remember: nmax = Set.ntypes - 1 DP Smaxsum = option == 0 ? 0.0 : 2.0 * ((Set.ntypes + 1.0) * exp(-2.0 * (Set.ntypes + 1.0) * Omega/kBT)/(1.0 - exp(-2.0 * (Set.ntypes + 1.0) * Omega/kBT)) - Set.ntypes * exp(-2.0 * Set.ntypes * Omega/kBT)/(1.0 - exp(-2.0 * Set.ntypes * Omega/kBT))); @@ -1264,22 +1263,22 @@ void Iterate_2CBG_deps_dchempot (int option, Root_Density_Set& DSet, const Root_ DSet.epsilon[0].value[i] = -1.0; // Add the convolutions: - for (int n = 0; n < Set.ntypes; ++n) + for (int n = 0; n < Set.ntypes; ++n) DSet.epsilon[0].value[i] += a_n_depsover_conv[n][i]; // Add the asymptotic parts of convolutions: n == 0 part is zero because of 1 + exp[epsilon[0] ] in denominator for (int n = 1; n < Set.ntypes; ++n) - DSet.epsilon[0].value[i] += depsover1pluseplusepsinfty[n] + DSet.epsilon[0].value[i] += depsover1pluseplusepsinfty[n] * (1.0 - (atan((DSet.epsilon[n].lambdamax - DSet.epsilon[0].lambda[i])/(0.5 * n * c_int)) + atan((DSet.epsilon[n].lambdamax + DSet.epsilon[0].lambda[i])/(0.5 * n * c_int)))/PI); - + // Add the leftover summation for species n > nmax, assuming epsilon_n = epsilon_n^\infty in those cases: - DSet.epsilon[0].value[i] -= Smaxsum; + DSet.epsilon[0].value[i] -= Smaxsum; /* if (DSet.epsilon[0].value[i] >= 0.0) { cout << "Warning: eps[0][" << i << "] >= 0.0, " << DSet.epsilon[0].prev_value[i] << "\t" << DSet.epsilon[0].value[i] << endl; DSet.epsilon[0].value[i] = DSet.epsilon[0].prev_value[i]; } - else + else */ // Include some damping: DSet.epsilon[0].value[i] = 0.1 * DSet.epsilon[0].prev_value[i] + 0.9 * DSet.epsilon[0].value[i]; @@ -1302,12 +1301,12 @@ void Iterate_2CBG_deps_dchempot (int option, Root_Density_Set& DSet, const Root_ // For n = ntypes, need: //DP em2OoT = exp(-2.0 * Omega/kBT); //int ntypes = DSet.ntypes; - //DP depsover1pluseepsntypesinfty = option == 0 ? 0.0 : 2.0 * (1.0 - pow(em2OoT, ntypes+1.0)) + //DP depsover1pluseepsntypesinfty = option == 0 ? 0.0 : 2.0 * (1.0 - pow(em2OoT, ntypes+1.0)) //* (ntypes * (1.0 - pow(em2OoT, ntypes+2.0)) - (ntypes + 2.0) * em2OoT * (1.0 - pow(em2OoT, DP(ntypes)))) ///((1.0 - em2OoT) * (1.0 - pow(em2OoT, DP(ntypes))) * (1.0 - pow(em2OoT, ntypes + 2.0))) MISSING 1/1+exp...part - + Vect_DP fmin(0.0, Set.epsilon[n-1].Npts); - Vect_DP fplus(0.0, Set.epsilon[JSC::min(n+1, Set.ntypes - 1)].Npts); + Vect_DP fplus(0.0, Set.epsilon[ABACUS::min(n+1, Set.ntypes - 1)].Npts); for (int i = 0; i < Set.epsilon[n].Npts; ++i) { f_depsover_conv_min[i] = 0.0; @@ -1318,13 +1317,13 @@ void Iterate_2CBG_deps_dchempot (int option, Root_Density_Set& DSet, const Root_ if (n == 1) { for (int j = 0; j < Set.epsilon[0].Npts; ++j) { - fmin[j] = depsover1plusepluseps[0][j] + fmin[j] = depsover1plusepluseps[0][j] * fmin_dlambda[n][i][j]; f_depsover_conv_min[i] -= fmin[j]; // Careful ! - sign here } - //if (i == 0 || i == 1) + //if (i == 0 || i == 1) //cout << "i = " << i << ": " << endl << endl << fmin << endl << endl - // << depsover1plusepluseps[0] << endl << endl << fmin_dlambda[n][i] + // << depsover1plusepluseps[0] << endl << endl << fmin_dlambda[n][i] //if (i < 10) cout << "Sum of fmin_dlambda[n][" << i << "]: " << fmin_dlambda[n][i].sum() << endl; } // if (n == 1) @@ -1337,7 +1336,7 @@ void Iterate_2CBG_deps_dchempot (int option, Root_Density_Set& DSet, const Root_ } } // if (n != 1) - + // 'up' convolutions if (n < Set.ntypes - 1) { @@ -1354,7 +1353,7 @@ void Iterate_2CBG_deps_dchempot (int option, Root_Density_Set& DSet, const Root_ //Set.epsilon[n].value[i] = Set.epsilon[n].value_infty + f_Tln_conv_min[i] + f_Tln_conv_plus[i]; // Do some damping: - DSet.epsilon[n].value[i] = 0.1 * DSet.epsilon[n].prev_value[i] + DSet.epsilon[n].value[i] = 0.1 * DSet.epsilon[n].prev_value[i] + 0.9 * (DSet.epsilon[n].value_infty + f_depsover_conv_min[i] + f_depsover_conv_plus[i]); // Force boundary values to asymptotes: force boundary 10 points on each side if (i < 10) @@ -1366,11 +1365,11 @@ void Iterate_2CBG_deps_dchempot (int option, Root_Density_Set& DSet, const Root_ /* if (i == 0 && n < 2) { cout << "epsilon[" << n << "][0]: " << DSet.epsilon[n].value[i] << "\t" << DSet.epsilon[n].prev_value[i] << "\t" - << DSet.epsilon[n].value_infty << "\t" << f_depsover_conv_min[i] << "\t" << f_depsover_conv_plus[i] + << DSet.epsilon[n].value_infty << "\t" << f_depsover_conv_min[i] << "\t" << f_depsover_conv_plus[i] //<< "\tepsilon[" << n << "][1]: " << DSet.epsilon[n].value[1] << "\t" << DSet.epsilon[n].prev_value[1] << "\t" - // << DSet.epsilon[n].value_infty << "\t" << f_depsover_conv_min[1] << "\t" << f_depsover_conv_plus[1] + // << DSet.epsilon[n].value_infty << "\t" << f_depsover_conv_min[1] << "\t" << f_depsover_conv_plus[1] << "\tepsilon[" << n << "][10]: " << DSet.epsilon[n].value[10] << "\t" << DSet.epsilon[n].prev_value[10] << "\t" - << DSet.epsilon[n].value_infty << "\t" << f_depsover_conv_min[10] << "\t" << f_depsover_conv_plus[10] + << DSet.epsilon[n].value_infty << "\t" << f_depsover_conv_min[10] << "\t" << f_depsover_conv_plus[10] << endl; } */ @@ -1383,7 +1382,7 @@ void Iterate_2CBG_deps_dchempot (int option, Root_Density_Set& DSet, const Root_ // All functions have now been iterated. // Now calculate diff: - + DSet.diff = 0.0; for (int n = 0; n < DSet.ntypes; ++n) { @@ -1391,12 +1390,12 @@ void Iterate_2CBG_deps_dchempot (int option, Root_Density_Set& DSet, const Root_ //sum_N += Set.epsilon[n].Npts; for (int i = 0; i < DSet.epsilon[n].Npts; ++i) { //Set.epsilon[n].diff += pow((Set.epsilon[n].value[i] - Set.epsilon[n].prev_value[i]) - // /JSC::max(1.0, fabs(Set.epsilon[n].value[i] + Set.epsilon[n].prev_value[i])), 2.0); + // /ABACUS::max(1.0, fabs(Set.epsilon[n].value[i] + Set.epsilon[n].prev_value[i])), 2.0); //Set.epsilon[n].diff += fabs((Set.epsilon[n].value[i] - Set.epsilon[n].prev_value[i]) - // /JSC::max(1.0, fabs(Set.epsilon[n].value[i] + Set.epsilon[n].prev_value[i]))); - //DSet.epsilon[n].diff += fabs(((DSet.epsilon[n].value[i] - DSet.epsilon[n].prev_value[i])/(DSet.epsilon[n].value[i] + DSet.epsilon[n].prev_value[i])) + // /ABACUS::max(1.0, fabs(Set.epsilon[n].value[i] + Set.epsilon[n].prev_value[i]))); + //DSet.epsilon[n].diff += fabs(((DSet.epsilon[n].value[i] - DSet.epsilon[n].prev_value[i])/(DSet.epsilon[n].value[i] + DSet.epsilon[n].prev_value[i])) // * depsover1plusepluseps[n][i]); - DSet.epsilon[n].diff += DSet.epsilon[n].dlambda[i] * + DSet.epsilon[n].diff += DSet.epsilon[n].dlambda[i] * fabs((DSet.epsilon[n].value[i] - DSet.epsilon[n].prev_value[i]) * depsover1plusepluseps[n][i]); } //DSet.epsilon[n].diff /= DSet.epsilon[n].Npts; @@ -1410,7 +1409,7 @@ void Iterate_2CBG_deps_dchempot (int option, Root_Density_Set& DSet, const Root_ } /* IMPROVED VERSION BELOW -Root_Density_Set Solve_2CBG_deps_dchempot (int option, const Root_Density_Set& TBA_Set, DP c_int, DP mu, DP Omega, DP kBT, +Root_Density_Set Solve_2CBG_deps_dchempot (int option, const Root_Density_Set& TBA_Set, DP c_int, DP mu, DP Omega, DP kBT, int Max_Secs, ofstream& LOG_outfile, bool Save_data) { // This solves the 2CBG deps/dmu (option == 0) or deps/dOmega (option == 1). @@ -1422,7 +1421,7 @@ Root_Density_Set Solve_2CBG_deps_dchempot (int option, const Root_Density_Set& T // Set basic precision needed: DP running_prec = TBA_Set.diff; - Root_Density_Set DSet = TBA_Set; // use same number of functions and points + Root_Density_Set DSet = TBA_Set; // use same number of functions and points // Set the asymptotics of the TBA_fns: @@ -1443,8 +1442,8 @@ Root_Density_Set Solve_2CBG_deps_dchempot (int option, const Root_Density_Set& T int niter = 0; int niter_min = 20; int niter_max = 2000; - - do { + + do { StartTime = clock(); Iterate_2CBG_deps_dchempot (option, DSet, TBA_Set, a_n_dlambda, fmin_dlambda, fplus_dlambda, c_int, mu, Omega, kBT); niter++; @@ -1455,14 +1454,14 @@ Root_Density_Set Solve_2CBG_deps_dchempot (int option, const Root_Density_Set& T if (Save_data) { LOG_outfile << "deps_dchempot, option == " << option << endl; - LOG_outfile << "c_int " << c_int << "\tmu " << mu << "\tOmega " << Omega << "\tkBT " << kBT - << "\trunning_prec " << running_prec << " niter_tot " << niter + LOG_outfile << "c_int " << c_int << "\tmu " << mu << "\tOmega " << Omega << "\tkBT " << kBT + << "\trunning_prec " << running_prec << " niter_tot " << niter << "\tntypes " << DSet.ntypes << "\tdiff " << DSet.diff << endl; } return(DSet); } */ -Root_Density_Set Solve_2CBG_deps_dchempot (int option, Root_Density_Set& TBA_Set, DP c_int, DP mu, DP Omega, DP kBT, +Root_Density_Set Solve_2CBG_deps_dchempot (int option, Root_Density_Set& TBA_Set, DP c_int, DP mu, DP Omega, DP kBT, int Max_Secs, ofstream& LOG_outfile, bool Save_data) { // This solves the 2CBG deps/dmu (option == 0) or deps/dOmega (option == 1). @@ -1515,12 +1514,12 @@ Root_Density_Set Solve_2CBG_deps_dchempot (int option, Root_Density_Set& TBA_Set int niter_comp = 0; - do { + do { //DSet_comp.Save("comp_a.dat"); StartTime = clock(); - Iterate_2CBG_deps_dchempot (option, DSet_comp, TBA_Set_comp, + Iterate_2CBG_deps_dchempot (option, DSet_comp, TBA_Set_comp, a_n_dlambda_comp, fmin_dlambda_comp, fplus_dlambda_comp, c_int, mu, Omega, kBT); niter_comp++; StopTime = clock(); @@ -1533,7 +1532,7 @@ Root_Density_Set Solve_2CBG_deps_dchempot (int option, Root_Density_Set& TBA_Set //} while (niter < niter_min || niter < niter_max && DSet.diff > running_prec && CPU_ticks < Max_CPU_ticks); //cout << niter << "\t" << DSet_eighth.diff << "\t"; - //} while (CPU_ticks < Max_CPU_ticks/2 && (DSet_comp.diff > running_prec || niter < 100)); + //} while (CPU_ticks < Max_CPU_ticks/2 && (DSet_comp.diff > running_prec || niter < 100)); } while (CPU_ticks < Max_CPU_ticks/2 && (niter_comp < 100 || DSet_comp.diff > running_prec)); // use at most half the time, keep rest for later. //cout << endl; //cout << "c_int = " << c_int << "\tmu = " << mu << "\teighth: niter = " << niter << "\tdiff = " << DSet_eighth.diff << endl << endl; @@ -1552,7 +1551,7 @@ Root_Density_Set Solve_2CBG_deps_dchempot (int option, Root_Density_Set& TBA_Set int niter = 0; - do { + do { StartTime = clock(); Iterate_2CBG_deps_dchempot (option, DSet, TBA_Set, a_n_dlambda, fmin_dlambda, fplus_dlambda, c_int, mu, Omega, kBT); niter++; @@ -1560,8 +1559,8 @@ Root_Density_Set Solve_2CBG_deps_dchempot (int option, Root_Density_Set& TBA_Set CPU_ticks += StopTime - StartTime; //} while (niter < niter_min || niter < niter_max && DSet.diff > running_prec && CPU_ticks < Max_CPU_ticks); //cout << niter << "\t" << DSet.diff << "\t"; - //} while (CPU_ticks < Max_CPU_ticks/2 && DSet.diff > running_prec); - } while (CPU_ticks < Max_CPU_ticks && DSet_comp.diff > 1.0e-4 * running_prec); + //} while (CPU_ticks < Max_CPU_ticks/2 && DSet.diff > running_prec); + } while (CPU_ticks < Max_CPU_ticks && DSet_comp.diff > 1.0e-4 * running_prec); //cout << endl; //cout << "c_int = " << c_int << "\tmu = " << mu << "\tfull: niter = " << niter << "\tdiff = " << DSet.diff << endl << endl; @@ -1571,8 +1570,8 @@ Root_Density_Set Solve_2CBG_deps_dchempot (int option, Root_Density_Set& TBA_Set if (Save_data) { LOG_outfile << "deps_dchempot, option == " << option << endl; - LOG_outfile << "c_int " << c_int << "\tmu " << mu << "\tOmega " << Omega << "\tkBT " << kBT - << "\trunning_prec " << running_prec << " niter_comp " << niter_comp << " niter_full " << niter + LOG_outfile << "c_int " << c_int << "\tmu " << mu << "\tOmega " << Omega << "\tkBT " << kBT + << "\trunning_prec " << running_prec << " niter_comp " << niter_comp << " niter_full " << niter << "\tntypes " << DSet.ntypes << "\tdiff " << DSet.diff << endl; } @@ -1611,13 +1610,13 @@ TBA_Data_2CBG Solve_2CBG_TBAE_via_refinements (DP c_int, DP mu, DP Omega, DP kBT TBA_string = TBA_stringstream.str(); const char* TBA_Cstr = TBA_string.c_str(); - + Dmu_string = Dmu_stringstream.str(); const char* Dmu_Cstr = Dmu_string.c_str(); - + DOmega_string = DOmega_stringstream.str(); const char* DOmega_Cstr = DOmega_string.c_str(); - + LOG_string = LOG_stringstream.str(); const char* LOG_Cstr = LOG_string.c_str(); @@ -1630,7 +1629,7 @@ TBA_Data_2CBG Solve_2CBG_TBAE_via_refinements (DP c_int, DP mu, DP Omega, DP kBT if (Save_data) { LOG_outfile.open(LOG_Cstr); LOG_outfile.precision(6); - + GFE_outfile.open(GFE_Cstr); GFE_outfile.precision(16); } @@ -1652,7 +1651,7 @@ TBA_Data_2CBG Solve_2CBG_TBAE_via_refinements (DP c_int, DP mu, DP Omega, DP kBT DP dfdmu = Calculate_dGibbs_dchempot (DSet_dmu, TBA_Set, c_int, mu, Omega, kBT); DP dfdOm = Calculate_dGibbs_dchempot (DSet_dOmega, TBA_Set, c_int, mu, Omega, kBT); - if (Save_data) + if (Save_data) GFE_outfile << f << "\t" << TBA_Set.diff << "\t" << dfdmu << "\t" << dfdOm << "\t" << 0.5 * (-dfdmu - dfdOm) << "\t" << 0.5 * (-dfdmu + dfdOm) << endl; @@ -1685,9 +1684,9 @@ void GFE_muscan_2CBG (DP c_int, DP mu_min, DP mu_max, DP Omega, DP kBT, int Npts stringstream GFE_stringstream; string GFE_string; - LOG_stringstream << "GFE_2CBG_c_" << c_int << "_mu_min_" << mu_min << "_mu_max_" << mu_max + LOG_stringstream << "GFE_2CBG_c_" << c_int << "_mu_min_" << mu_min << "_mu_max_" << mu_max << "_Npts_mu_" << Npts_mu << "_Omega_" << Omega << "_kBT_" << kBT << "_Secs_" << Max_Secs << ".log"; - GFE_stringstream << "GFE_2CBG_c_" << c_int << "_mu_min_" << mu_min << "_mu_max_" << mu_max + GFE_stringstream << "GFE_2CBG_c_" << c_int << "_mu_min_" << mu_min << "_mu_max_" << mu_max << "_Npts_mu_" << Npts_mu << "_Omega_" << Omega << "_kBT_" << kBT << "_Secs_" << Max_Secs << ".dat"; LOG_string = LOG_stringstream.str(); @@ -1701,7 +1700,7 @@ void GFE_muscan_2CBG (DP c_int, DP mu_min, DP mu_max, DP Omega, DP kBT, int Npts LOG_outfile.open(LOG_Cstr); LOG_outfile.precision(6); - + GFE_outfile.open(GFE_Cstr); GFE_outfile.precision(16); @@ -1720,7 +1719,7 @@ void GFE_muscan_2CBG (DP c_int, DP mu_min, DP mu_max, DP Omega, DP kBT, int Npts Scan_dSet_dmu = Solve_2CBG_deps_dchempot (0, Scan_Set, c_int, mu, Omega, kBT, Max_Secs_per_mu_pt/3, LOG_outfile, Save_data); Scan_dSet_dOmega = Solve_2CBG_deps_dchempot (1, Scan_Set, c_int, mu, Omega, kBT, Max_Secs_per_mu_pt/3, LOG_outfile, Save_data); - + DP dfdmu = Calculate_dGibbs_dchempot (Scan_dSet_dmu, Scan_Set, c_int, mu, Omega, kBT); DP dfdOm = Calculate_dGibbs_dchempot (Scan_dSet_dOmega, Scan_Set, c_int, mu, Omega, kBT); @@ -1735,4 +1734,4 @@ void GFE_muscan_2CBG (DP c_int, DP mu_min, DP mu_max, DP Omega, DP kBT, int Npts return; } -} // namespace JSC +} // namespace ABACUS diff --git a/src/TBA/TBA_LiebLin.cc b/src/TBA/TBA_LiebLin.cc index f274539..5f322db 100644 --- a/src/TBA/TBA_LiebLin.cc +++ b/src/TBA/TBA_LiebLin.cc @@ -2,7 +2,7 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -10,15 +10,14 @@ File: TBA_LiebLin.cc Purpose: TBA for Lieb-Liniger - ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -namespace JSC { +namespace ABACUS { // T = 0 functions @@ -40,21 +39,21 @@ namespace JSC { // First, calculate the convolution conv = 0.0; for (int j = 0; j < rho_GS.Npts; ++j) - conv += fabs(rho_GS.lambda[j]) > k_F ? 0.0 : - LiebLin_a2_kernel (c_int, rho_GS.lambda[i] - rho_GS.lambda[j]) + conv += fabs(rho_GS.lambda[j]) > k_F ? 0.0 : + LiebLin_a2_kernel (c_int, rho_GS.lambda[i] - rho_GS.lambda[j]) * rho_GS.prev_value[j] * rho_GS.dlambda[j]; rho_GS.value[i] = fabs(rho_GS.lambda[i]) < k_F ? 1.0/twoPI + conv : 0.0; - } + } // Calculate the sum of differences: rho_GS.diff = 0.0; - for (int i = 0; i < rho_GS.Npts; ++i) + for (int i = 0; i < rho_GS.Npts; ++i) rho_GS.diff += fabs(rho_GS.value[i] - rho_GS.prev_value[i]); return; } - Root_Density LiebLin_rho_GS (DP c_int, DP k_F, DP lambdamax, int Npts, DP req_prec) + Root_Density LiebLin_rho_GS (DP c_int, DP k_F, DP lambdamax, int Npts, DP req_prec) { // This function returns a Root_Density object corresponding to the ground state @@ -79,7 +78,7 @@ namespace JSC { return(n); } - DP k_F_given_n (DP c_int, DP n, DP lambdamax, int Npts, DP req_prec) + DP k_F_given_n (DP c_int, DP n, DP lambdamax, int Npts, DP req_prec) { DP k_F = 1.0; DP dk_F = k_F; @@ -93,7 +92,7 @@ namespace JSC { //cout << "k_F " << k_F << "\tn_found " << n_found << endl; - } while (fabs(dk_F) > req_prec && dk_F > 1.0/Npts + } while (fabs(dk_F) > req_prec && dk_F > 1.0/Npts && fabs(n - n_found) > req_prec && fabs(n - n_found) > 1.0/Npts); return(k_F); @@ -112,21 +111,21 @@ namespace JSC { // First, calculate the convolution conv = 0.0; for (int j = 0; j < Z_GS.Npts; ++j) - conv += fabs(Z_GS.lambda[j]) > k_F ? 0.0 : - LiebLin_a2_kernel (c_int, Z_GS.lambda[i] - Z_GS.lambda[j]) + conv += fabs(Z_GS.lambda[j]) > k_F ? 0.0 : + LiebLin_a2_kernel (c_int, Z_GS.lambda[i] - Z_GS.lambda[j]) * Z_GS.prev_value[j] * Z_GS.dlambda[j]; Z_GS.value[i] = 1.0 + conv; - } + } // Calculate the sum of differences: Z_GS.diff = 0.0; - for (int i = 0; i < Z_GS.Npts; ++i) + for (int i = 0; i < Z_GS.Npts; ++i) Z_GS.diff += fabs(Z_GS.value[i] - Z_GS.prev_value[i]); return; } - Root_Density LiebLin_Z_GS (DP c_int, DP k_F, DP lambdamax, int Npts, DP req_prec) + Root_Density LiebLin_Z_GS (DP c_int, DP k_F, DP lambdamax, int Npts, DP req_prec) { // This function returns a Root_Density object corresponding to the ground state @@ -156,21 +155,21 @@ namespace JSC { // First, calculate the convolution conv = 0.0; for (int j = 0; j < F_GS.Npts; ++j) - conv += fabs(F_GS.lambda[j]) > k_F ? 0.0 : - LiebLin_a2_kernel (c_int, F_GS.lambda[i] - F_GS.lambda[j]) + conv += fabs(F_GS.lambda[j]) > k_F ? 0.0 : + LiebLin_a2_kernel (c_int, F_GS.lambda[i] - F_GS.lambda[j]) * F_GS.prev_value[j] * F_GS.dlambda[j]; F_GS.value[i] = 0.5 + atan((F_GS.lambda[i] - lambda)/c_int)/PI + conv; - } + } // Calculate the sum of differences: F_GS.diff = 0.0; - for (int i = 0; i < F_GS.Npts; ++i) + for (int i = 0; i < F_GS.Npts; ++i) F_GS.diff += fabs(F_GS.value[i] - F_GS.prev_value[i]); return; } - Root_Density LiebLin_Fbackflow_GS (DP c_int, DP k_F, DP lambdamax, DP lambda, int Npts, DP req_prec) + Root_Density LiebLin_Fbackflow_GS (DP c_int, DP k_F, DP lambdamax, DP lambda, int Npts, DP req_prec) { // This function returns a Root_Density object corresponding to the ground state @@ -190,8 +189,8 @@ namespace JSC { // Finite T functions: - /* - // from JSC_TBA.h + /* + // from ABACUS_TBA.h struct LiebLin_TBA_Solution { @@ -208,7 +207,7 @@ namespace JSC { }; */ - LiebLin_TBA_Solution::LiebLin_TBA_Solution (DP c_int_ref, DP mu_ref, DP kBT_ref, DP req_diff, int Max_Secs) + LiebLin_TBA_Solution::LiebLin_TBA_Solution (DP c_int_ref, DP mu_ref, DP kBT_ref, DP req_diff, int Max_Secs) : c_int(c_int_ref), mu(mu_ref), kBT(kBT_ref) { epsilon = LiebLin_epsilon_TBA (c_int, mu, kBT, req_diff, Max_Secs); @@ -220,7 +219,7 @@ namespace JSC { sbar = LiebLin_sbar_TBA (rho, rhoh); } /* - LiebLin_TBA_Solution::LiebLin_TBA_Solution (DP c_int_ref, DP mu_ref, DP kBT_ref, int Npts_ref, DP req_diff, int Max_Secs, const LiebLin_TBA_Solution& prev_sol) + LiebLin_TBA_Solution::LiebLin_TBA_Solution (DP c_int_ref, DP mu_ref, DP kBT_ref, int Npts_ref, DP req_diff, int Max_Secs, const LiebLin_TBA_Solution& prev_sol) : c_int(c_int_ref), mu(mu_ref), kBT(kBT_ref) { epsilon = LiebLin_epsilon_TBA (c_int, mu, kBT, Npts_ref, req_diff, Max_Secs, prev_sol.epsilon); @@ -235,8 +234,8 @@ namespace JSC { LiebLin_TBA_Solution LiebLin_TBA_Solution_fixed_nbar_ebar (DP c_int, DP nbar_required, DP ebar_required, DP req_diff, int Max_Secs) { // This function finds the TBA solution for a required nbar and ebar (mean energy). - // We here try to triangulate the temperature; the chemical potential is triangulated - // using the function LiebLin_TBA_Solution_fixed_nbar. + // We here try to triangulate the temperature; the chemical potential is triangulated + // using the function LiebLin_TBA_Solution_fixed_nbar. // FIRST VERSION DP lnkBT = 1.0; @@ -252,7 +251,7 @@ namespace JSC { tbasol = LiebLin_TBA_Solution_fixed_nbar (c_int, nbar_required, exp(lnkBT), req_diff, Max_Secs); int niter = 1; - while (fabs(tbasol.ebar - ebar_required) > req_diff) { + while (fabs(tbasol.ebar - ebar_required) > req_diff) { dlnkBT_prev = dlnkBT; lnkBT_prev = lnkBT; @@ -262,10 +261,10 @@ namespace JSC { dlnkBT = (ebar_required - tbasol.ebar)/debardlnkBT; if (fabs(dlnkBT) > fabs(dlnkBT_prev)) dlnkBT *= fabs(dlnkBT_prev/dlnkBT); // make sure we don't blow up. lnkBT += dlnkBT; - tbasol = LiebLin_TBA_Solution_fixed_nbar(c_int, nbar_required, exp(lnkBT), req_diff, Max_Secs); + tbasol = LiebLin_TBA_Solution_fixed_nbar(c_int, nbar_required, exp(lnkBT), req_diff, Max_Secs); niter++; //cout << setprecision(16) << "kBT: niter " << niter << "\tebar = " << tbasol.ebar << "\trequired = " << ebar_required << "\tlnkBT = " << lnkBT << "\tdlnkBT = " << dlnkBT << endl; - } + } // FIRST VERSION /* SECOND VERSION @@ -280,7 +279,7 @@ namespace JSC { DP nbar_prev = tbasol.nbar; DP lnkBT_prev = lnkBT; DP ebar_prev = LiebLin_ebar_TBA (tbasol.rho); - + DP dmu_prev, dnbardmu; DP dlnkBT_prev, debardlnkBT; */ // SECOND VERSION @@ -318,13 +317,13 @@ namespace JSC { // Similarly, int iT_below = int(log(kBT * 16.0)/log(2.0)); - igamma_below = JSC::max(igamma_below, 0); - igamma_below = JSC::min(igamma_below, ndata - 1); - iT_below = JSC::max(iT_below, 0); - iT_below = JSC::min(iT_below, ndata - 1); + igamma_below = ABACUS::max(igamma_below, 0); + igamma_below = ABACUS::min(igamma_below, ndata - 1); + iT_below = ABACUS::max(iT_below, 0); + iT_below = ABACUS::min(iT_below, ndata - 1); // We use indices igamma_below, igamma_below + 1, iT_below, iT_below + 1 to guess mu: // do a four-point extrapolation, - DP mu = ((gamma[igamma_below + 1] - gamma_required) * (T[iT_below + 1] - kBT) * mudata[igamma_below][iT_below] + DP mu = ((gamma[igamma_below + 1] - gamma_required) * (T[iT_below + 1] - kBT) * mudata[igamma_below][iT_below] + (gamma_required - gamma[igamma_below]) * (T[iT_below + 1] - kBT) * mudata[igamma_below + 1][iT_below] + (gamma[igamma_below + 1] - gamma_required) * (kBT - T[iT_below]) * mudata[igamma_below][iT_below + 1] + (gamma_required - gamma[igamma_below]) * (kBT - T[iT_below]) * mudata[igamma_below + 1][iT_below + 1]) @@ -342,14 +341,14 @@ namespace JSC { LiebLin_TBA_Solution tbasol = LiebLin_TBA_Solution(c_int, mu, kBT, req_diff, Max_Secs); DP mu_prev = mu; DP nbar_prev = tbasol.nbar; - + DP dmu_prev, dnbardmu; mu += dmu; tbasol = LiebLin_TBA_Solution(c_int, mu, kBT, req_diff, Max_Secs); int niter = 1; - while (fabs(tbasol.nbar - nbar_required) > req_diff) { + while (fabs(tbasol.nbar - nbar_required) > req_diff) { dmu_prev = dmu; mu_prev = mu; @@ -359,10 +358,10 @@ namespace JSC { dmu = (nbar_required - tbasol.nbar)/dnbardmu; if (fabs(dmu) > 2.0 * fabs(dmu_prev)) dmu = 2.0*dmu * fabs(dmu_prev/dmu); // make sure we don't blow up. mu += dmu; - tbasol = LiebLin_TBA_Solution(c_int, mu, kBT, req_diff, Max_Secs); + tbasol = LiebLin_TBA_Solution(c_int, mu, kBT, req_diff, Max_Secs); niter++; //cout << setprecision(16) << "\tmu: niter " << niter << "\tnbar = " << tbasol.nbar << "\trequired = " << nbar_required<< "\tmu = " << mu << "\tdmu = " << dmu << endl; - } + } return(tbasol); } @@ -372,29 +371,29 @@ namespace JSC { { // This function replaces Set by a new set with more points, where // Tln(...) needs to be evaluated more precisely. - + // The return value is the max of delta_tni found. - + // First, calculate the needed Tln... Vect Tln1plusemineps(epsilon.Npts); - + for (int i = 0; i < epsilon.Npts; ++i) { Tln1plusemineps[i] = epsilon.value[i] > 0.0 ? - kBT * (epsilon.value[i] < 24.0 * kBT ? log(1.0 + exp(-epsilon.value[i]/kBT)) : exp(-epsilon.value[i]/kBT)) + kBT * (epsilon.value[i] < 24.0 * kBT ? log(1.0 + exp(-epsilon.value[i]/kBT)) : exp(-epsilon.value[i]/kBT)) : -epsilon.value[i] + kBT * log (1.0 + exp(epsilon.value[i]/kBT)); } - + // Now find the achieved delta_tni DP max_delta_tni_dlambda = 0.0; DP sum_delta_tni_dlambda = 0.0; - + Vect tni(0.0, epsilon.Npts); Vect tni_ex(0.0, epsilon.Npts); - + DP measure_factor = 0.0; - + for (int i = 1; i < epsilon.Npts - 1; ++i) { - measure_factor = (epsilon.value[i] > 0.0 ? exp(-epsilon.value[i]/kBT)/(1.0 + exp(-epsilon.value[i]/kBT)) + measure_factor = (epsilon.value[i] > 0.0 ? exp(-epsilon.value[i]/kBT)/(1.0 + exp(-epsilon.value[i]/kBT)) : 1.0/(1.0 + exp(epsilon.value[i]/kBT))); tni[i] = measure_factor * epsilon.value[i]; @@ -402,15 +401,15 @@ namespace JSC { + epsilon.value[i+1] * (epsilon.lambda[i] - epsilon.lambda[i-1])) /(epsilon.lambda[i+1] - epsilon.lambda[i-1]); - max_delta_tni_dlambda = JSC::max(max_delta_tni_dlambda, fabs(tni[i] - tni_ex[i]) * epsilon.dlambda[i]); - + max_delta_tni_dlambda = ABACUS::max(max_delta_tni_dlambda, fabs(tni[i] - tni_ex[i]) * epsilon.dlambda[i]); + sum_delta_tni_dlambda += fabs(tni[i] - tni_ex[i]) * epsilon.dlambda[i]; } - + // We now determine the locations where we need to add points Vect need_new_point_around(false, epsilon.Npts); int nr_new_points_needed = 0; - + for (int i = 1; i < epsilon.Npts - 1; ++i) { if (fabs(tni[i] - tni_ex[i]) * epsilon.dlambda[i] > (1.0 - refine_fraction) * max_delta_tni_dlambda) { need_new_point_around[i] = true; @@ -418,14 +417,14 @@ namespace JSC { need_new_point_around[epsilon.Npts - 1 - i] = true; } } - for (int i = 0; i < epsilon.Npts; ++i) + for (int i = 0; i < epsilon.Npts; ++i) if (need_new_point_around[i]) nr_new_points_needed++; - + // Now insert the new points between existing points: // Update all data via interpolation: Root_Density epsilon_before_update = epsilon; epsilon = Root_Density(epsilon_before_update.Npts + nr_new_points_needed, epsilon_before_update.lambdamax); - + int nr_pts_added = 0; for (int i = 0; i < epsilon_before_update.Npts; ++i) { if (!need_new_point_around[i]) { @@ -436,18 +435,18 @@ namespace JSC { else if (need_new_point_around[i]) { epsilon.lambda[i + nr_pts_added] = epsilon_before_update.lambda[i] - 0.25 * epsilon_before_update.dlambda[i]; epsilon.dlambda[i + nr_pts_added] = 0.5 * epsilon_before_update.dlambda[i]; - epsilon.value[i + nr_pts_added] = epsilon_before_update.Return_Value(epsilon.lambda[i + nr_pts_added]); + epsilon.value[i + nr_pts_added] = epsilon_before_update.Return_Value(epsilon.lambda[i + nr_pts_added]); nr_pts_added++; epsilon.lambda[i + nr_pts_added] = epsilon_before_update.lambda[i] + 0.25 * epsilon_before_update.dlambda[i]; epsilon.dlambda[i + nr_pts_added] = 0.5 * epsilon_before_update.dlambda[i]; - epsilon.value[i + nr_pts_added] = epsilon_before_update.Return_Value(epsilon.lambda[i + nr_pts_added]); + epsilon.value[i + nr_pts_added] = epsilon_before_update.Return_Value(epsilon.lambda[i + nr_pts_added]); } } if (nr_pts_added != nr_new_points_needed) { cout << nr_pts_added << "\t" << nr_new_points_needed << endl; - JSCerror("Wrong counting of new points in Insert_new_points."); + ABACUSerror("Wrong counting of new points in Insert_new_points."); } - + // Check boundary values; if too different from value_infty, extend limits if (exp(-epsilon.value[0]/kBT) > 0.001 * max_delta_tni_dlambda) { @@ -483,16 +482,16 @@ namespace JSC { // epsilon for a given mu: Root_Density LiebLin_epsilon_TBA (DP c_int, DP mu, DP kBT, DP req_diff, int Max_Secs) { - + clock_t StartTime = clock(); int Max_CPU_ticks = 98 * (Max_Secs - 0) * CLOCKS_PER_SEC/100; // give 30 seconds to wrap up, assume we time to 2% accuracy. - + // Set basic precision needed: DP running_prec = 1.0; - + DP refine_fraction = 0.5; // value fraction of points to be refined - - DP lambdamax_init = 10.0 * sqrt(JSC::max(1.0, kBT + mu)); // such that exp(-(lambdamax^2 - mu - Omega)/T) <~ machine_eps + + DP lambdamax_init = 10.0 * sqrt(ABACUS::max(1.0, kBT + mu)); // such that exp(-(lambdamax^2 - mu - Omega)/T) <~ machine_eps int Npts = 50; @@ -505,9 +504,9 @@ namespace JSC { } clock_t StopTime = clock(); - + int CPU_ticks = StopTime - StartTime; - + int ncycles = 0; int niter_tot = 0; DP previous_running_prec; @@ -516,7 +515,7 @@ namespace JSC { DP oneoverc = 1.0/c_int; do { - + StartTime = clock(); // The running precision is an estimate of the accuracy of the free energy integral. @@ -524,7 +523,7 @@ namespace JSC { previous_running_prec = running_prec; running_prec = Refine_LiebLin_epsilon_TBA (epsilon, c_int, mu, kBT, refine_fraction); //cout << "ncycles = " << ncycles << "\trunning_prec = " << running_prec << endl; - running_prec = JSC::min(running_prec, previous_running_prec); + running_prec = ABACUS::min(running_prec, previous_running_prec); // Now iterate to convergence for given discretization int niter = 0; @@ -538,31 +537,31 @@ namespace JSC { Vect Tln1plusemineps(epsilon.Npts); for (int i = 0; i < epsilon.Npts; ++i) { Tln1plusemineps[i] = epsilon.value[i] > 0.0 ? - kBT * (epsilon.value[i] < 24.0 * kBT ? log(1.0 + exp(-epsilon.value[i]/kBT)) : exp(-epsilon.value[i]/kBT) * (1.0 - 0.5 * exp(-epsilon.value[i]/kBT))) + kBT * (epsilon.value[i] < 24.0 * kBT ? log(1.0 + exp(-epsilon.value[i]/kBT)) : exp(-epsilon.value[i]/kBT) * (1.0 - 0.5 * exp(-epsilon.value[i]/kBT))) //kBT * log(1.0 + exp(-epsilon.value[i]/kBT)) - : + : -epsilon.value[i] + kBT * (-epsilon.value[i] < 24.0 * kBT ? log (1.0 + exp(epsilon.value[i]/kBT)) : exp(epsilon.value[i]/kBT) * (1.0 - 0.5 * exp(epsilon.value[i]/kBT))); //-epsilon.value[i] + kBT * log (1.0 + exp(epsilon.value[i]/kBT)); // Keep previous rapidities: epsilon.prev_value[i] = epsilon.value[i]; } - + Vect a_2_Tln_conv(epsilon.Npts); - + for (int i = 0; i < epsilon.Npts; ++i) { a_2_Tln_conv[i] = 0.0; - + for (int j = 0; j < epsilon.Npts; ++j) a_2_Tln_conv[i] += oneoverpi * (atan(oneoverc * (epsilon.lambda[i] - epsilon.lambda[j] + 0.5 * epsilon.dlambda[j])) - atan(oneoverc * (epsilon.lambda[i] - epsilon.lambda[j] - 0.5 * epsilon.dlambda[j]))) * Tln1plusemineps[j]; - + } // a_2_Tln_conv is now calculated // Reconstruct the epsilon function: for (int i = 0; i < epsilon.Npts; ++i) { epsilon.value[i] = pow(epsilon.lambda[i], 2.0) - mu; - + // Add the convolution: epsilon.value[i] -= a_2_Tln_conv[i]; - + // Include some damping: //epsilon.value[i] = 0.1 * epsilon.prev_value[i] + 0.9 * epsilon.value[i]; epsilon.value[i] = 0.1 * epsilon.prev_value[i] + 0.9 * epsilon.value[i]; @@ -575,14 +574,14 @@ namespace JSC { // Calculate the diff: epsilon.diff = 0.0; for (int i = 0; i < epsilon.Npts; ++i) - epsilon.diff += epsilon.dlambda[i] * - (epsilon.value[i] > 0.0 ? + epsilon.diff += epsilon.dlambda[i] * + (epsilon.value[i] > 0.0 ? exp(-epsilon.value[i]/kBT)/(1.0 + exp(-epsilon.value[i]/kBT)) : 1.0/(1.0 + exp(epsilon.value[i]/kBT))) * fabs(epsilon.value[i] - epsilon.prev_value[i]); - + StopTime = clock(); CPU_ticks += StopTime - StartTime; - + //cout << "epsilon: niter = " << niter << "\tdiff = " << epsilon.diff << endl; //cout << epsilon.lambda[0] << "\t" << epsilon.dlambda[0] << endl; //cout << "a_2_Tln_conv[0] = " << a_2_Tln_conv[0] << "\tTln1plusemineps[0] = " << Tln1plusemineps[0] << endl; @@ -602,12 +601,12 @@ namespace JSC { // depsilon/dmu for a given mu Root_Density LiebLin_depsilon_dmu_TBA (DP c_int, DP mu, DP kBT, DP req_diff, int Max_Secs, const Root_Density& epsilon) { - + clock_t StartTime = clock(); int Max_CPU_ticks = 98 * (Max_Secs - 0) * CLOCKS_PER_SEC/100; // give 30 seconds to wrap up, assume we time to 2% accuracy. - + Root_Density depsilon_dmu = epsilon; - + // Initiate the functions: for (int i = 0; i < depsilon_dmu.Npts; ++i) { depsilon_dmu.value[i] = -1.0; @@ -615,39 +614,39 @@ namespace JSC { } clock_t StopTime = clock(); - + int CPU_ticks = StopTime - StartTime; - + int niter = 0; int niter_max = 1000; DP oneoverpi = 1.0/PI; DP oneoverc = 1.0/c_int; - + do { - + StartTime = clock(); - + // Iterate the TBA equation for depsilon_dmu: Vect depsover1plusepluseps(depsilon_dmu.Npts); for (int i = 0; i < depsilon_dmu.Npts; ++i) { - depsover1plusepluseps[i] = epsilon.value[i] > 0.0 ? + depsover1plusepluseps[i] = epsilon.value[i] > 0.0 ? depsilon_dmu.value[i] * exp(-epsilon.value[i]/kBT)/(1.0 + exp(-epsilon.value[i]/kBT)) : depsilon_dmu.value[i]/(1.0 + exp(epsilon.value[i]/kBT)); // Keep previous rapidities: depsilon_dmu.prev_value[i] = depsilon_dmu.value[i]; } - + Vect a_2_depsover1plusepluseps_conv(depsilon_dmu.Npts); - + for (int i = 0; i < depsilon_dmu.Npts; ++i) { a_2_depsover1plusepluseps_conv[i] = 0.0; - - for (int j = 0; j < depsilon_dmu.Npts; ++j) + + for (int j = 0; j < depsilon_dmu.Npts; ++j) a_2_depsover1plusepluseps_conv[i] += oneoverpi * (atan(oneoverc * (epsilon.lambda[i] - epsilon.lambda[j] + 0.5 * epsilon.dlambda[j])) - atan(oneoverc * (epsilon.lambda[i] - epsilon.lambda[j] - 0.5 * epsilon.dlambda[j]))) * depsover1plusepluseps[j]; } - + // Reconstruct the depsilon_dmu function: for (int i = 0; i < epsilon.Npts; ++i) { depsilon_dmu.value[i] = -1.0; @@ -671,7 +670,7 @@ namespace JSC { //cout << "depsilon_dmu: niter = " << niter << "\tdiff = " << depsilon_dmu.diff << endl; } while (niter < 5 || niter < niter_max && CPU_ticks < Max_CPU_ticks && depsilon_dmu.diff > req_diff); - + return(depsilon_dmu); } @@ -679,8 +678,8 @@ namespace JSC { { Root_Density rho = epsilon; for (int i = 0; i < epsilon.Npts; ++i) - rho.value[i] = -(1.0/twoPI) * depsilon_dmu.value[i] - * (epsilon.value[i] > 0.0 ? + rho.value[i] = -(1.0/twoPI) * depsilon_dmu.value[i] + * (epsilon.value[i] > 0.0 ? exp(-epsilon.value[i]/kBT)/(1.0 + exp(-epsilon.value[i]/kBT)) : 1.0/(1.0 + exp(epsilon.value[i]/kBT))); @@ -691,8 +690,8 @@ namespace JSC { { Root_Density rhoh = epsilon; for (int i = 0; i < epsilon.Npts; ++i) - rhoh.value[i] = -(1.0/twoPI) * depsilon_dmu.value[i] - * (epsilon.value[i] > 0.0 ? + rhoh.value[i] = -(1.0/twoPI) * depsilon_dmu.value[i] + * (epsilon.value[i] > 0.0 ? 1.0/(1.0 + exp(-epsilon.value[i]/kBT)) : exp(epsilon.value[i]/kBT)/(1.0 + exp(epsilon.value[i]/kBT))); @@ -725,7 +724,7 @@ namespace JSC { LiebLin_Bethe_State Discretized_LiebLin_Bethe_State (DP c_int, DP L, int N, const Root_Density& rho) { - // This function returns the Bethe state at finite size which is + // This function returns the Bethe state at finite size which is // the closest approximation to the continuum density rho(lambda) // Each time N \int_{-\infty}^\lambda d\lambda' \rho(\lambda') crosses a half integer, add a particle: @@ -733,7 +732,7 @@ namespace JSC { DP integral_prev = 0.0; int Nfound = 0; Vect lambda_found(0.0, 2*N); - + for (int i = 0; i < rho.Npts; ++i) { integral_prev = integral; integral += L * rho.value[i] * rho.dlambda[i]; @@ -754,14 +753,14 @@ namespace JSC { //cout << "\ti = " << i << "\tintegral = " << integral << "\tNfound = " << Nfound << endl; } //cout << "rho: " << rho.Npts << " points" << endl << rho.value << endl; - //cout << "sym: " << rho.value[0] << " " << rho.value[rho.value.size() - 1] + //cout << "sym: " << rho.value[0] << " " << rho.value[rho.value.size() - 1] // << "\t" << rho.value[rho.value.size()/2] << " " << rho.value[rho.value.size()/2 + 1] << endl; //cout << "Found " << Nfound << " particles." << endl; //cout << "lambda_found = " << lambda_found << endl; Vect lambda(N); // Fill up the found rapidities: - for (int il = 0; il < JSC::min(N, Nfound); ++il) lambda[il] = lambda_found[il]; + for (int il = 0; il < ABACUS::min(N, Nfound); ++il) lambda[il] = lambda_found[il]; // If there are missing ones, put them at the end; ideally, this should never be called for (int il = Nfound; il < N; ++il) lambda[il] = lambda_found[Nfound-1] + (il - Nfound + 1) * (lambda_found[Nfound-1] - lambda_found[Nfound-2]); @@ -772,7 +771,7 @@ namespace JSC { DP sum = 0.0; for (int j = 0; j < N; ++j) sum += 2.0 * atan((lambda[i] - lambda[j])/c_int); //Ix2[i] = 2.0* int((L * lambda[i] + sum)/twoPI) + (N % 2) - 1; - // For N is even/odd, we want to round off to the nearest odd/even integer. + // For N is even/odd, we want to round off to the nearest odd/even integer. Ix2[i] = 2.0 * floor((L* lambda[i] + sum)/twoPI + 0.5 * (N%2 ? 1 : 2)) + (N%2) - 1; } //cout << "Found quantum numbers " << endl << Ix2 << endl; @@ -796,4 +795,4 @@ namespace JSC { } -} // namespace JSC +} // namespace ABACUS diff --git a/src/TBA/TBA_XXZ.cc b/src/TBA/TBA_XXZ.cc index 468c55e..a0a50ac 100755 --- a/src/TBA/TBA_XXZ.cc +++ b/src/TBA/TBA_XXZ.cc @@ -1,8 +1,8 @@ /********************************************************** -This software is part of J.-S. Caux's ABACUS++ library. +This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -10,16 +10,14 @@ File: TBA_XXZ.cc Purpose: TBA for the gapless XXZ antiferromagnet. - - ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -namespace JSC { +namespace ABACUS { // First, define some useful kernels: @@ -33,31 +31,31 @@ namespace JSC { return(2.0 * atan(tanh(lambda)/tan(zeta))); } - DP XXZ_a1_kernel (DP sinzeta, DP coszeta, DP lambda) + DP XXZ_a1_kernel (DP sinzeta, DP coszeta, DP lambda) { DP expmin2abslambda = exp(-2.0 * fabs(lambda)); - + DP answer = sinzeta * expmin2abslambda /(PI * (0.5 * (1.0 + expmin2abslambda * expmin2abslambda) - coszeta * expmin2abslambda)); return(answer); } - DP XXZ_da1dlambda_kernel (DP sinzeta, DP coszeta, DP lambda) + DP XXZ_da1dlambda_kernel (DP sinzeta, DP coszeta, DP lambda) { DP expmin2abslambda = exp(-2.0 * fabs(lambda)); DP signlambda = lambda >= 0.0 ? 1.0 : -1.0; DP answer = -sinzeta * signlambda * expmin2abslambda * (1.0 - expmin2abslambda * expmin2abslambda) - /(PI * pow((0.5 * (1.0 + expmin2abslambda * expmin2abslambda) + /(PI * pow((0.5 * (1.0 + expmin2abslambda * expmin2abslambda) - coszeta * expmin2abslambda), 2.0)); return(answer); } - DP XXZ_a2_kernel (DP sin2zeta, DP cos2zeta, DP lambda) + DP XXZ_a2_kernel (DP sin2zeta, DP cos2zeta, DP lambda) { DP expmin2abslambda = exp(-2.0 * fabs(lambda)); - + DP answer = sin2zeta * expmin2abslambda /(PI * (0.5 * (1.0 + expmin2abslambda * expmin2abslambda) - cos2zeta * expmin2abslambda)); @@ -79,28 +77,28 @@ namespace JSC { DP cos2zeta = cos(2.0*zeta); for (int i = 0; i < rhotot_GS.Npts; ++i) { // First, calculate the convolution - conv = 0.0; + conv = 0.0; for (int j = 0; j < rhotot_GS.Npts; ++j) - conv += fabs(rhotot_GS.lambda[j]) > B ? 0.0 : + conv += fabs(rhotot_GS.lambda[j]) > B ? 0.0 : XXZ_a2_kernel (sin2zeta, cos2zeta, rhotot_GS.lambda[i] - rhotot_GS.lambda[j]) * rhotot_GS.prev_value[j] * rhotot_GS.dlambda[j]; rhotot_GS.value[i] = XXZ_a1_kernel(sinzeta, coszeta, rhotot_GS.lambda[i]) - conv; - } + } // Calculate the sum of differences: rhotot_GS.diff = 0.0; - for (int i = 0; i < rhotot_GS.Npts; ++i) + for (int i = 0; i < rhotot_GS.Npts; ++i) rhotot_GS.diff += fabs(rhotot_GS.value[i] - rhotot_GS.prev_value[i]); return; } - Root_Density XXZ_rhotot_GS (DP Delta, DP B, DP lambdamax, int Npts, DP req_prec) + Root_Density XXZ_rhotot_GS (DP Delta, DP B, DP lambdamax, int Npts, DP req_prec) { // This function returns a Root_Density object corresponding to the ground state // root distribution of the XXZ model. - if (Delta >= 1.0 || Delta <= 0.0) JSCerror("Delta out of bounds in XXZ_rhotot_GS."); + if (Delta >= 1.0 || Delta <= 0.0) ABACUSerror("Delta out of bounds in XXZ_rhotot_GS."); DP zeta = acos(Delta); @@ -145,28 +143,28 @@ namespace JSC { // First, calculate the convolution conv = 0.0; for (int j = 0; j < eps_GS.Npts; ++j) - conv += eps_GS.prev_value[j] > 0.0 ? 0.0 : - XXZ_a2_kernel (sin2zeta, cos2zeta, eps_GS.lambda[i] - eps_GS.lambda[j]) + conv += eps_GS.prev_value[j] > 0.0 ? 0.0 : + XXZ_a2_kernel (sin2zeta, cos2zeta, eps_GS.lambda[i] - eps_GS.lambda[j]) * eps_GS.prev_value[j] * eps_GS.dlambda[j]; eps_GS.value[i] = Hz - PI * sinzeta * XXZ_a1_kernel(sinzeta, coszeta, eps_GS.lambda[i]) - conv; //cout << i << "\t" << eps_GS.lambda[i] << "\t" << eps_GS.value[i] << "\t" << conv << endl; - } + } // Calculate the sum of differences: eps_GS.diff = 0.0; - for (int i = 0; i < eps_GS.Npts; ++i) + for (int i = 0; i < eps_GS.Npts; ++i) eps_GS.diff += fabs(eps_GS.value[i] - eps_GS.prev_value[i]); return; } - Root_Density XXZ_eps_GS (DP Delta, DP Hz, DP lambdamax, int Npts, DP req_prec) + Root_Density XXZ_eps_GS (DP Delta, DP Hz, DP lambdamax, int Npts, DP req_prec) { // This function returns a Root_Density object corresponding to the ground state // epsilon function of the XXZ model. - if (Delta >= 1.0 || Delta <= 0.0) JSCerror("Delta out of bounds in XXZ_eps_GS."); + if (Delta >= 1.0 || Delta <= 0.0) ABACUSerror("Delta out of bounds in XXZ_eps_GS."); DP zeta = acos(Delta); @@ -203,27 +201,27 @@ namespace JSC { // First, calculate the convolution conv = 0.0; for (int j = 0; j < depsdlambda_GS.Npts; ++j) - conv += fabs(depsdlambda_GS.lambda[j]) > B ? 0.0 : - XXZ_a2_kernel (sin2zeta, cos2zeta, depsdlambda_GS.lambda[i] - depsdlambda_GS.lambda[j]) + conv += fabs(depsdlambda_GS.lambda[j]) > B ? 0.0 : + XXZ_a2_kernel (sin2zeta, cos2zeta, depsdlambda_GS.lambda[i] - depsdlambda_GS.lambda[j]) * depsdlambda_GS.prev_value[j] * depsdlambda_GS.dlambda[j]; depsdlambda_GS.value[i] = -PI * sinzeta * XXZ_da1dlambda_kernel(sinzeta, coszeta, depsdlambda_GS.lambda[i]) - conv; - } + } // Calculate the sum of differences: depsdlambda_GS.diff = 0.0; - for (int i = 0; i < depsdlambda_GS.Npts; ++i) + for (int i = 0; i < depsdlambda_GS.Npts; ++i) depsdlambda_GS.diff += fabs(depsdlambda_GS.value[i] - depsdlambda_GS.prev_value[i]); return; } - Root_Density XXZ_depsdlambda_GS (DP Delta, DP B, DP lambdamax, int Npts, DP req_prec) + Root_Density XXZ_depsdlambda_GS (DP Delta, DP B, DP lambdamax, int Npts, DP req_prec) { // This function returns a Root_Density object corresponding to the ground state // (d/d\lambda) epsilon function of the XXZ model. - if (Delta >= 1.0 || Delta <= 0.0) JSCerror("Delta out of bounds in XXZ_rho_GS."); + if (Delta >= 1.0 || Delta <= 0.0) ABACUSerror("Delta out of bounds in XXZ_rho_GS."); DP zeta = acos(Delta); @@ -259,28 +257,28 @@ namespace JSC { // First, calculate the convolution conv = 0.0; for (int j = 0; j < b2BB.Npts; ++j) - conv += fabs(b2BB.lambda[j]) > B ? 0.0 : - XXZ_a2_kernel (sin2zeta, cos2zeta, b2BB.lambda[i] - b2BB.lambda[j]) + conv += fabs(b2BB.lambda[j]) > B ? 0.0 : + XXZ_a2_kernel (sin2zeta, cos2zeta, b2BB.lambda[i] - b2BB.lambda[j]) * b2BB.prev_value[j] * b2BB.dlambda[j]; - b2BB.value[i] = -XXZ_a2_kernel(sin2zeta, cos2zeta, b2BB.lambda[i] - B) + b2BB.value[i] = -XXZ_a2_kernel(sin2zeta, cos2zeta, b2BB.lambda[i] - B) - conv; - } + } } // Calculate the sum of differences: b2BB.diff = 0.0; - for (int i = 0; i < b2BB.Npts; ++i) + for (int i = 0; i < b2BB.Npts; ++i) b2BB.diff += fabs(b2BB.value[i] - b2BB.prev_value[i]); return; } - Root_Density XXZ_b2BB_lambda_B (DP Delta, DP B, DP lambdamax, int Npts, DP req_prec) + Root_Density XXZ_b2BB_lambda_B (DP Delta, DP B, DP lambdamax, int Npts, DP req_prec) { // This function returns a Root_Density object corresponding to the inverse // kernel b2BB (lambda, B) used in Kbar function. - if (Delta >= 1.0 || Delta <= 0.0) JSCerror("Delta out of bounds in XXZ_Kbackflow_GS."); + if (Delta >= 1.0 || Delta <= 0.0) ABACUSerror("Delta out of bounds in XXZ_Kbackflow_GS."); DP zeta = acos(Delta); @@ -317,28 +315,28 @@ namespace JSC { // First, calculate the convolution conv = 0.0; for (int j = 0; j < b2BB.Npts; ++j) - conv += fabs(b2BB.lambda[j]) > B ? 0.0 : - XXZ_a2_kernel (sin2zeta, cos2zeta, b2BB.lambda[i] - b2BB.lambda[j]) + conv += fabs(b2BB.lambda[j]) > B ? 0.0 : + XXZ_a2_kernel (sin2zeta, cos2zeta, b2BB.lambda[i] - b2BB.lambda[j]) * b2BB.prev_value[j] * b2BB.dlambda[j]; - b2BB.value[i] = -XXZ_a2_kernel(sin2zeta, cos2zeta, b2BB.lambda[i] - lambdap) + b2BB.value[i] = -XXZ_a2_kernel(sin2zeta, cos2zeta, b2BB.lambda[i] - lambdap) - conv; - } + } } // Calculate the sum of differences: b2BB.diff = 0.0; - for (int i = 0; i < b2BB.Npts; ++i) + for (int i = 0; i < b2BB.Npts; ++i) b2BB.diff += fabs(b2BB.value[i] - b2BB.prev_value[i]); return; } - Root_Density XXZ_b2BB_lambda_lambdap (DP Delta, DP B, DP lambdap, DP lambdamax, int Npts, DP req_prec) + Root_Density XXZ_b2BB_lambda_lambdap (DP Delta, DP B, DP lambdap, DP lambdamax, int Npts, DP req_prec) { // This function returns a Root_Density object corresponding to the inverse // kernel b2BB (lambda, lambdap) used in Kbar function. - if (Delta >= 1.0 || Delta <= 0.0) JSCerror("Delta out of bounds in XXZ_Kbackflow_GS."); + if (Delta >= 1.0 || Delta <= 0.0) ABACUSerror("Delta out of bounds in XXZ_Kbackflow_GS."); DP zeta = acos(Delta); @@ -376,29 +374,29 @@ namespace JSC { // First, calculate the convolution conv = 0.0; for (int j = 0; j < Kbackflow_GS.Npts; ++j) - conv += fabs(Kbackflow_GS.lambda[j]) > B ? 0.0 : - //(Kbackflow_GS.lambda[i] < -B || Kbackflow_GS.lambda[i] > lambda_p + lambda_h + B) ? 0.0 : - XXZ_a2_kernel (sin2zeta, cos2zeta, Kbackflow_GS.lambda[i] - Kbackflow_GS.lambda[j]) + conv += fabs(Kbackflow_GS.lambda[j]) > B ? 0.0 : + //(Kbackflow_GS.lambda[i] < -B || Kbackflow_GS.lambda[i] > lambda_p + lambda_h + B) ? 0.0 : + XXZ_a2_kernel (sin2zeta, cos2zeta, Kbackflow_GS.lambda[i] - Kbackflow_GS.lambda[j]) * Kbackflow_GS.prev_value[j] * Kbackflow_GS.dlambda[j]; - Kbackflow_GS.value[i] = -XXZ_a2_kernel(sin2zeta, cos2zeta, Kbackflow_GS.lambda[i] - lambda_p) + Kbackflow_GS.value[i] = -XXZ_a2_kernel(sin2zeta, cos2zeta, Kbackflow_GS.lambda[i] - lambda_p) + XXZ_a2_kernel(sin2zeta, cos2zeta, Kbackflow_GS.lambda[i] - lambda_h) - conv; - } + } } // Calculate the sum of differences: Kbackflow_GS.diff = 0.0; - for (int i = 0; i < Kbackflow_GS.Npts; ++i) + for (int i = 0; i < Kbackflow_GS.Npts; ++i) Kbackflow_GS.diff += fabs(Kbackflow_GS.value[i] - Kbackflow_GS.prev_value[i]); return; } - Root_Density XXZ_Kbackflow_GS (DP Delta, DP B, DP lambdamax, DP lambda_p, DP lambda_h, int Npts, DP req_prec) + Root_Density XXZ_Kbackflow_GS (DP Delta, DP B, DP lambdamax, DP lambda_p, DP lambda_h, int Npts, DP req_prec) { // This function returns a Root_Density object corresponding to the ground state // backflow function of the XXZ model. - if (Delta >= 1.0 || Delta <= 0.0) JSCerror("Delta out of bounds in XXZ_Kbackflow_GS."); + if (Delta >= 1.0 || Delta <= 0.0) ABACUSerror("Delta out of bounds in XXZ_Kbackflow_GS."); DP zeta = acos(Delta); @@ -435,28 +433,28 @@ namespace JSC { // First, calculate the convolution conv = 0.0; for (int j = 0; j < Fbackflow_GS.Npts; ++j) - conv += fabs(Fbackflow_GS.lambda[j]) > B ? 0.0 : - XXZ_a2_kernel (sin2zeta, cos2zeta, Fbackflow_GS.lambda[i] - Fbackflow_GS.lambda[j]) + conv += fabs(Fbackflow_GS.lambda[j]) > B ? 0.0 : + XXZ_a2_kernel (sin2zeta, cos2zeta, Fbackflow_GS.lambda[i] - Fbackflow_GS.lambda[j]) * Fbackflow_GS.prev_value[j] * Fbackflow_GS.dlambda[j]; - Fbackflow_GS.value[i] = (-XXZ_phi2_kernel(zeta, Fbackflow_GS.lambda[i] - lambda_p) + Fbackflow_GS.value[i] = (-XXZ_phi2_kernel(zeta, Fbackflow_GS.lambda[i] - lambda_p) + XXZ_phi2_kernel(zeta, Fbackflow_GS.lambda[i] - lambda_h))/twoPI - conv; - } + } } // Calculate the sum of differences: Fbackflow_GS.diff = 0.0; - for (int i = 0; i < Fbackflow_GS.Npts; ++i) + for (int i = 0; i < Fbackflow_GS.Npts; ++i) Fbackflow_GS.diff += fabs(Fbackflow_GS.value[i] - Fbackflow_GS.prev_value[i]); return; } - Root_Density XXZ_Fbackflow_GS (DP Delta, DP B, DP lambdamax, DP lambda_p, DP lambda_h, int Npts, DP req_prec) + Root_Density XXZ_Fbackflow_GS (DP Delta, DP B, DP lambdamax, DP lambda_p, DP lambda_h, int Npts, DP req_prec) { // This function returns a Root_Density object corresponding to the ground state // F backflow function of the XXZ model. - if (Delta >= 1.0 || Delta <= 0.0) JSCerror("Delta out of bounds in XXZ_Fbackflow_GS."); + if (Delta >= 1.0 || Delta <= 0.0) ABACUSerror("Delta out of bounds in XXZ_Fbackflow_GS."); DP zeta = acos(Delta); @@ -491,27 +489,27 @@ namespace JSC { // First, calculate the convolution conv = 0.0; for (int j = 0; j < Z_GS.Npts; ++j) - conv += fabs(Z_GS.lambda[j]) > B ? 0.0 : - XXZ_a2_kernel (sin2zeta, cos2zeta, Z_GS.lambda[i] - Z_GS.lambda[j]) + conv += fabs(Z_GS.lambda[j]) > B ? 0.0 : + XXZ_a2_kernel (sin2zeta, cos2zeta, Z_GS.lambda[i] - Z_GS.lambda[j]) * Z_GS.prev_value[j] * Z_GS.dlambda[j]; Z_GS.value[i] = 1.0 - conv; - } + } // Calculate the sum of differences: Z_GS.diff = 0.0; - for (int i = 0; i < Z_GS.Npts; ++i) + for (int i = 0; i < Z_GS.Npts; ++i) Z_GS.diff += fabs(Z_GS.value[i] - Z_GS.prev_value[i]); return; } - Root_Density XXZ_Z_GS (DP Delta, DP B, DP lambdamax, int Npts, DP req_prec) + Root_Density XXZ_Z_GS (DP Delta, DP B, DP lambdamax, int Npts, DP req_prec) { // This function returns a Root_Density object corresponding to the ground state // dressed charge function of the XXZ model. - if (Delta >= 1.0 || Delta <= 0.0) JSCerror("Delta out of bounds in XXZ_Z_GS."); + if (Delta >= 1.0 || Delta <= 0.0) ABACUSerror("Delta out of bounds in XXZ_Z_GS."); DP zeta = acos(Delta); @@ -535,17 +533,17 @@ namespace JSC { // Define the base: chain, Mdown Heis_Base gbase(chain, M); - + // Define the ground state XXZ_Bethe_State gstate(chain, gbase); - + // Compute everything about the ground state gstate.Compute_All(true); - + // Define the number of rapidities for an excited state Vect_INT Nrapidities(0, chain.Nstrings); Nrapidities[0] = M; - + Vect_INT Nexcitations(0, 2* chain.Nstrings + 2); Nexcitations[0] = 0; Nexcitations[1] = 1; @@ -554,19 +552,19 @@ namespace JSC { // Define a base configuration for this set of rapidity numbers Heis_Base ebase (chain, Nrapidities); - - // Define the excited state + + // Define the excited state XXZ_Bethe_State estate(chain, ebase); - + // Define an offset from a base and a number of holes Ix2_Offsets offsets(ebase, Nexcitations); - + // Set the offset to the desired id offsets.Set_to_id (id); - + // Set the offset data into the quantum numbers estate.Set_Ix2_Offsets(offsets); - + // Compute everything about this eigenstate estate.Compute_All(true); @@ -598,11 +596,11 @@ namespace JSC { } if (B_eps == 0.0) { cout << "Delta = " << Delta << "\tN = " << N << "\tM = " << M << "\tHz_N = " << Hz_N << "\tid = " << id << endl; - JSCerror("B not found."); + ABACUSerror("B not found."); } if (B_eps > 0.5 * lambdamax) { cout << "Delta = " << Delta << "\tN = " << N << "\tM = " << M << "\tHz_N = " << Hz_N << "\tid = " << id << endl; - JSCerror("Use a higher value of lambdamax."); + ABACUSerror("Use a higher value of lambdamax."); } //DP lambdamax = lambdamax_eps; //DP lambdamax = 2.0 * fabs(gstate.lambda[0][0]); // window of definition of Kbackflow is covered @@ -637,12 +635,12 @@ namespace JSC { DP conv = 0.0; DP zeta = acos(Delta); for (int l = 0; l < rhotot_GS.Npts; ++l) { - conv += fabs(rhotot_GS.lambda[l]) > B ? 0.0 : - (XXZ_phi2_kernel(zeta, lambdap - rhotot_GS.lambda[l]) + conv += fabs(rhotot_GS.lambda[l]) > B ? 0.0 : + (XXZ_phi2_kernel(zeta, lambdap - rhotot_GS.lambda[l]) - XXZ_phi2_kernel(zeta, lambdah - rhotot_GS.lambda[l])) * rhotot_GS.value[l] * rhotot_GS.dlambda[l]; } - DP k_ext_TBA = -XXZ_phi1_kernel (zeta, lambdap) + XXZ_phi1_kernel (zeta, lambdah) + conv; + DP k_ext_TBA = -XXZ_phi1_kernel (zeta, lambdap) + XXZ_phi1_kernel (zeta, lambdah) + conv; // Energy: conv = 0.0; DP sinzeta = sin(zeta); @@ -669,45 +667,45 @@ namespace JSC { for (int alpha = 0; alpha < M; ++alpha) rhoGS_N[iout] += exp(-(gstate.lambda[0][alpha] - lambdaout) * (gstate.lambda[0][alpha] - lambdaout)/gwidthsq); rhoGS_N[iout] /= N * sqrt(PI) * gwidth; - for (int alpha = 1; alpha < estate.base[0]; ++alpha) + for (int alpha = 1; alpha < estate.base[0]; ++alpha) rhoexc_N[iout] += exp(-(estate.lambda[0][alpha] - lambdaout) * (estate.lambda[0][alpha] - lambdaout)/gwidthsq); rhoexc_N[iout] /= N * sqrt(PI) * gwidth; - + Kflow_N[iout] = N * (rhoexc_N[iout] - rhoGS_N[iout] + (1.0/N) * exp(-(lambdah - lambdaout) * (lambdah - lambdaout)/gwidthsq)/(sqrt(PI) * gwidth)); } // for iout cout << "Here 1" << endl; // Now produce a file with the density flow: stringstream flo_stringstream; - flo_stringstream << "Flow_D_" << Delta << "_N_" << N << "_M_" << M << "_base_id_" << estate.base_id << "_type_id_" << estate.type_id + flo_stringstream << "Flow_D_" << Delta << "_N_" << N << "_M_" << M << "_base_id_" << estate.base_id << "_type_id_" << estate.type_id << "_id_" << estate.id << ".flo"; string flo_string = flo_stringstream.str(); const char* flo_Cstr = flo_string.c_str(); - + ofstream outfile_flo; outfile_flo.open(flo_Cstr); outfile_flo.precision(16); - for (int iout = 0; iout < Npts; ++iout) - outfile_flo << rhotot_GS.lambda[iout] << "\t" << rhotot_GS.value[iout] << "\t" << rhoGS_N[iout] << "\t" - << rhoexc_N[iout] << "\t" << Kbackflow_GS.value[iout] << "\t" - << (fabs(Kbackflow_GS.lambda[iout]) > B ? 0.0 : Kbackflow_GS.value[iout]) - b2BB_lambda_B.value[iout] * Fbackflow_GS.value[iB_eps] + for (int iout = 0; iout < Npts; ++iout) + outfile_flo << rhotot_GS.lambda[iout] << "\t" << rhotot_GS.value[iout] << "\t" << rhoGS_N[iout] << "\t" + << rhoexc_N[iout] << "\t" << Kbackflow_GS.value[iout] << "\t" + << (fabs(Kbackflow_GS.lambda[iout]) > B ? 0.0 : Kbackflow_GS.value[iout]) - b2BB_lambda_B.value[iout] * Fbackflow_GS.value[iB_eps] + b2BB_lambda_B.value[b2BB_lambda_B.Npts - 1 - iout] * Fbackflow_GS.value[Fbackflow_GS.Npts - 1 - iB_eps] << "\t" << Kflow_N[iout] << endl; outfile_flo.close(); // ... and a file with the remainder of the data: stringstream dat_stringstream; - dat_stringstream << "Flow_D_" << Delta << "_N_" << N << "_M_" << M << "_base_id_" << estate.base_id << "_type_id_" << estate.type_id + dat_stringstream << "Flow_D_" << Delta << "_N_" << N << "_M_" << M << "_base_id_" << estate.base_id << "_type_id_" << estate.type_id << "_id_" << estate.id << ".dat"; string dat_string = dat_stringstream.str(); const char* dat_Cstr = dat_string.c_str(); - + ofstream outfile_dat; outfile_dat.open(dat_Cstr); outfile_dat.precision(16); - outfile_dat << "lambdap\tlambdah\tk_ext_N\tk_ext_TBA\tomega_N\tomega_TBA" + outfile_dat << "lambdap\tlambdah\tk_ext_N\tk_ext_TBA\tomega_N\tomega_TBA" << lambdap << "\t" << lambdah << "\t" << k_ext_N << "\t" << k_ext_TBA << "\t" << omega_N << "\t" << omega_TBA << endl; outfile_dat.close(); @@ -716,7 +714,4 @@ namespace JSC { } */ -} // namespace JSC - - - +} // namespace ABACUS diff --git a/src/UTILS/Data_File_Name.cc b/src/UTILS/Data_File_Name.cc index 67dfba3..bcf2260 100644 --- a/src/UTILS/Data_File_Name.cc +++ b/src/UTILS/Data_File_Name.cc @@ -2,23 +2,23 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- File: src/SCAN/Data_File_Name.cc -Purpose: defines functions returning stringstreams for +Purpose: defines functions returning stringstreams for standardised file names. ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -namespace JSC { +namespace ABACUS { // For each model, two functions are given: the first uses physical parameters as arguments, // and can be called with functions `knowing' which model is dealt with. @@ -39,13 +39,13 @@ namespace JSC { else if (whichDSF == '1') name << "Type_I_Exp_Data"; else if (whichDSF == 'B') name << "BECg2"; else if (whichDSF == 'C') name << "BECoverlap"; - else JSCerror("Option not implemented in Data_File_Name"); + else ABACUSerror("Option not implemented in Data_File_Name"); name << "_c_" << c_int << "_L_" << L << "_N_" << N; //if (fixed_iK) name << "_iK_" << iKneeded; if (defaultScanStatename == "") name << "_" << N << "_0_"; // simulates label of ground state else name << "_" << defaultScanStatename; - if (iKmin == iKmax) name << "_iK_" << iKmin; + if (iKmin == iKmax) name << "_iK_" << iKmin; else name << "_iKmin_" << iKmin << "_iKmax_" << iKmax; if (kBT > 0.0) name << "_kBT_" << kBT; if (whichDSF == 'q') name << "_L2_" << L2; @@ -65,7 +65,7 @@ namespace JSC { else if (whichDSF == '1') name << "Type_I_Exp_Data"; else if (whichDSF == 'B') name << "BECg2"; else if (whichDSF == 'C') name << "BECoverlap"; - else JSCerror("Option not implemented in Data_File_Name"); + else ABACUSerror("Option not implemented in Data_File_Name"); name << "_c_" << State.c_int << "_L_" << State.L << "_N_" << State.N; //if (fixed_iK) name << "_iK_" << iKneeded; @@ -95,7 +95,7 @@ namespace JSC { else if (whichDSF == 'q') name << "GeomQuench"; else { cout << "Option tried (1): " << whichDSF << endl; - JSCerror("Option not implemented in Data_File_Name"); + ABACUSerror("Option not implemented in Data_File_Name"); } name << "_D_" << Delta << "_N_" << N << "_M_"; @@ -113,7 +113,7 @@ namespace JSC { //if (iKmin == iKmax) name << "_iK_" << iKmin; else name << "_iKmin_" << iKmin << "_iKmax_" << iKmax; if (kBT > 0.0) name << "_kBT_" << kBT; if (whichDSF == 'q') name << "_N2_" << N2; - + return; } @@ -131,7 +131,7 @@ namespace JSC { else if (whichDSF == 'q') name << "GeomQuench"; else { cout << "Option tried (2): " << whichDSF << endl; - JSCerror("Option not implemented in Data_File_Name"); + ABACUSerror("Option not implemented in Data_File_Name"); } name << "_D_" << State.chain.Delta << "_N_" << State.chain.Nsites << "_M_"; @@ -165,7 +165,7 @@ namespace JSC { else if (whichDSF == 'z') name << "zz"; else if (whichDSF == 'p') name << "c_cdag"; else if (whichDSF == 'q') name << "GeomQuench"; - else JSCerror("Option not implemented in Data_File_Name"); + else ABACUSerror("Option not implemented in Data_File_Name"); name << "_D_" << Delta << "_N_" << N << "_M_"; for (int i = 0; i < int(log10(DP(N/2))) - int(log10(DP(M))); ++i) name << "0"; @@ -174,7 +174,7 @@ namespace JSC { if (iKmin == iKmax) name << "_iK_" << iKmin; else name << "_iKmin_" << iKmin << "_iKmax_" << iKmax; if (kBT > 0.0) name << "_kBT_" << kBT; if (whichDSF == 'q') name << "_N2_" << N2; - + return; } @@ -189,7 +189,7 @@ namespace JSC { //else if (whichDSF == 'a') name << "SzSz"; //else if (whichDSF == 'b') name << "SzSm"; //else if (whichDSF == 'q') name << "GeomQuench"; - else JSCerror("Option not implemented in Data_File_Name"); + else ABACUSerror("Option not implemented in Data_File_Name"); name << "_D_" << State.chain.Delta << "_N_" << State.chain.Nsites << "_M_"; for (int i = 0; i < int(log10(DP(State.chain.Nsites/2))) - int(log10(DP(State.base.Mdown))); ++i) name << "0"; @@ -207,4 +207,4 @@ namespace JSC { } */ -} // namespace JSC +} // namespace ABACUS diff --git a/src/UTILS/K_and_Omega_Files.cc b/src/UTILS/K_and_Omega_Files.cc index 53f8fc1..3b5e4b8 100644 --- a/src/UTILS/K_and_Omega_Files.cc +++ b/src/UTILS/K_and_Omega_Files.cc @@ -2,7 +2,7 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -12,22 +12,25 @@ Purpose: Utilities: momentum and frequency files. ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" -namespace JSC { +using namespace std; + + +namespace ABACUS { void Write_K_File (DP Length, int iKmin, int iKmax) { stringstream K_file; string K_file_string; - K_file << "K_Length_" << Length << "_iKmin_" << iKmin << "_iKmax_" << iKmax << ".dat"; + K_file << "K_Length_" << Length << "_iKmin_" << iKmin << "_iKmax_" << iKmax << ".dat"; K_file_string = K_file.str(); const char* K_file_Cstr = K_file_string.c_str(); - + ofstream outfile_K; - + outfile_K.open(K_file_Cstr); - + outfile_K.setf(ios::fixed); outfile_K.setf(ios::showpoint); outfile_K.precision(16); @@ -43,14 +46,14 @@ namespace JSC { { stringstream w_file; string w_file_string; - w_file << "Omega_ommin_" << omegamin << "_ommax_" << omegamax << "_Nom_" << Nout_omega << ".dat"; + w_file << "Omega_ommin_" << omegamin << "_ommax_" << omegamax << "_Nom_" << Nout_omega << ".dat"; w_file_string = w_file.str(); const char* w_file_Cstr = w_file_string.c_str(); - + ofstream outfile_w; - + outfile_w.open(w_file_Cstr); - + outfile_w.setf(ios::fixed); outfile_w.setf(ios::showpoint); outfile_w.precision(16); @@ -62,4 +65,4 @@ namespace JSC { return; } -} // namespace JSC +} // namespace ABACUS diff --git a/src/UTILS/Smoothen_RAW_into_SF.cc b/src/UTILS/Smoothen_RAW_into_SF.cc index 3ac6d7d..638ddbf 100644 --- a/src/UTILS/Smoothen_RAW_into_SF.cc +++ b/src/UTILS/Smoothen_RAW_into_SF.cc @@ -1,25 +1,25 @@ /********************************************************** -This software is part of J.-S. Caux's ABACUS++ library. +This software is part of J.-S. Caux's ABACUS library. -Copyright (c) +Copyright (c) J.-S. Caux. ----------------------------------------------------------- File: Smoothen_RAW_into_SF.cc Purpose: from a .raw file, produces .dsf (dynamical sf) and .ssf (static sf) files. - + ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -namespace JSC { +namespace ABACUS { - DP Smoothen_RAW_into_SF (string prefix, int iKmin, int iKmax, int DiK, + DP Smoothen_RAW_into_SF (string prefix, int iKmin, int iKmax, int DiK, DP ommin, DP ommax, int Nom, DP gwidth, DP normalization, DP denom_sum_K) { // ommax is omega max for .dsf file, Nom is the number of omega slots used. @@ -29,19 +29,19 @@ namespace JSC { // DiK is the (half-)window in iK which is averaged over. Averaging over a single iK means DiK == 0. - // Open the original raw file: + // Open the original raw file: stringstream RAW_stringstream; string RAW_string; - RAW_stringstream << prefix << ".raw"; + RAW_stringstream << prefix << ".raw"; RAW_string = RAW_stringstream.str(); const char* RAW_Cstr = RAW_string.c_str(); ifstream RAW_infile; RAW_infile.open(RAW_Cstr); if (RAW_infile.fail()) { cout << RAW_Cstr << endl; - JSCerror("Could not open RAW_infile... "); + ABACUSerror("Could not open RAW_infile... "); } - if (iKmax - iKmin + 1 < 0) JSCerror("Improper iKmin, iKmax in Smoothen_RAW_into_SF"); + if (iKmax - iKmin + 1 < 0) ABACUSerror("Improper iKmin, iKmax in Smoothen_RAW_into_SF"); RecMat DSF(Nom, iKmax - iKmin + 1); Vect_DP SSF(0.0, iKmax - iKmin + 1); Vect_DP ASF(0.0, Nom); @@ -54,7 +54,7 @@ namespace JSC { string label; // Momenta: average over 2*DiK + 1 entries. Weigh them linearly decreasing away from central one. - // Setting central one to value 1 + DiK, + // Setting central one to value 1 + DiK, // total weight is 1 + DiK + 2* \sum_1^DiK n = 1 + DiK + DiK (DiK + 1) = (DiK + 1)^2. // Weight given is thus abs(DiK + 1 - (iK - iK'))/(DiK + 1)^2 for abs(iK - iK') <= DiK. Vect_DP Kweight(DiK + 1); @@ -109,7 +109,7 @@ namespace JSC { DSF_stringstream << prefix; //if (iKmax != iKmin) DSF_stringstream << "_iKmin_" << iKmin << "_iKmax_" << iKmax; if (DiK > 0) DSF_stringstream << "_DiK_" << DiK; - DSF_stringstream << "_ommin_"<< ommin << "_ommax_" << ommax << "_Nom_" << Nom << "_w_" << gwidth << ".dsf"; + DSF_stringstream << "_ommin_"<< ommin << "_ommax_" << ommax << "_Nom_" << Nom << "_w_" << gwidth << ".dsf"; DSF_string = DSF_stringstream.str(); const char* DSF_Cstr = DSF_string.c_str(); ofstream DSF_outfile; @@ -127,9 +127,9 @@ namespace JSC { SSF_stringstream << prefix; //if (iKmin != iKmax) SSF_stringstream << "_iKmin_" << iKmin << "_iKmax_" << iKmax; if (DiK > 0) SSF_stringstream << "_DiK_" << DiK; - SSF_stringstream << ".ssf"; + SSF_stringstream << ".ssf"; SSF_string = SSF_stringstream.str(); const char* SSF_Cstr = SSF_string.c_str(); - + ofstream SSF_outfile; SSF_outfile.open(SSF_Cstr); SSF_outfile.precision(12); @@ -144,7 +144,7 @@ namespace JSC { stringstream ASF_stringstream; string ASF_string; ASF_stringstream << prefix; //if (iKmax != iKmin) DSF_stringstream << "_iKmin_" << iKmin << "_iKmax_" << iKmax; - ASF_stringstream << "_ommin_"<< ommin << "_ommax_" << ommax << "_Nom_" << Nom << "_w_" << gwidth << ".asf"; + ASF_stringstream << "_ommin_"<< ommin << "_ommax_" << ommax << "_Nom_" << Nom << "_w_" << gwidth << ".asf"; ASF_string = ASF_stringstream.str(); const char* ASF_Cstr = ASF_string.c_str(); ofstream ASF_outfile; @@ -174,7 +174,7 @@ namespace JSC { } // This is the same function as above, but now using data for a diagonal ensemble of states - DP Smoothen_RAW_into_SF (string prefix, Vect rawfilename, Vect weight, int iKmin, int iKmax, int DiK, + DP Smoothen_RAW_into_SF (string prefix, Vect rawfilename, Vect weight, int iKmin, int iKmax, int DiK, DP ommin, DP ommax, int Nom, DP gwidth, DP normalization, DP denom_sum_K) { // ommax is omega max for .dsf file, Nom is the number of omega slots used. @@ -184,7 +184,7 @@ namespace JSC { // DiK is the (half-)window in iK which is averaged over. Averaging over a single iK means DiK == 0. - if (iKmax - iKmin + 1 < 0) JSCerror("Improper iKmin, iKmax in Smoothen_RAW_into_SF"); + if (iKmax - iKmin + 1 < 0) ABACUSerror("Improper iKmin, iKmax in Smoothen_RAW_into_SF"); RecMat DSF(Nom, iKmax - iKmin + 1); Vect_DP SSF(0.0, iKmax - iKmin + 1); Vect_DP ASF(0.0, Nom); @@ -197,7 +197,7 @@ namespace JSC { string label; // Momenta: average over 2*DiK + 1 entries. Weigh them linearly decreasing away from central one. - // Setting central one to value 1 + DiK, + // Setting central one to value 1 + DiK, // total weight is 1 + DiK + 2* \sum_1^DiK n = 1 + DiK + DiK (DiK + 1) = (DiK + 1)^2. // Weight given is thus abs(DiK + 1 - (iK - iK'))/(DiK + 1)^2 for abs(iK - iK') <= DiK. Vect_DP Kweight(DiK + 1); @@ -213,10 +213,10 @@ namespace JSC { for (int ns = 0; ns < weight.size(); ++ns) { - // Open the original raw file: + // Open the original raw file: //stringstream RAW_stringstream; string RAW_string; - //RAW_stringstream << prefix << ".raw"; - //RAW_string = RAW_stringstream.str(); + //RAW_stringstream << prefix << ".raw"; + //RAW_string = RAW_stringstream.str(); //const char* RAW_Cstr = RAW_string.c_str(); const char* RAW_Cstr = rawfilename[ns].c_str(); @@ -224,9 +224,9 @@ namespace JSC { RAW_infile.open(RAW_Cstr); if (RAW_infile.fail()) { cout << RAW_Cstr << endl; - JSCerror("Could not open RAW_infile... "); + ABACUSerror("Could not open RAW_infile... "); } - + while (RAW_infile.peek() != EOF) { //RAW_infile >> omega >> iK >> FF >> conv >> label; RAW_infile >> omega >> iK >> FF >> dev >> label; @@ -267,7 +267,7 @@ namespace JSC { //if (iKmax != iKmin) DSF_stringstream << "_iKmin_" << iKmin << "_iKmax_" << iKmax; DSF_stringstream << "_ns_" << weight.size(); if (DiK > 0) DSF_stringstream << "_DiK_" << DiK; - DSF_stringstream << "_ommin_"<< ommin << "_ommax_" << ommax << "_Nom_" << Nom << "_w_" << gwidth << ".dsf"; + DSF_stringstream << "_ommin_"<< ommin << "_ommax_" << ommax << "_Nom_" << Nom << "_w_" << gwidth << ".dsf"; DSF_string = DSF_stringstream.str(); const char* DSF_Cstr = DSF_string.c_str(); ofstream DSF_outfile; @@ -285,9 +285,9 @@ namespace JSC { SSF_stringstream << prefix; //if (iKmin != iKmax) SSF_stringstream << "_iKmin_" << iKmin << "_iKmax_" << iKmax; SSF_stringstream << "_ns_" << weight.size(); - SSF_stringstream << ".ssf"; + SSF_stringstream << ".ssf"; SSF_string = SSF_stringstream.str(); const char* SSF_Cstr = SSF_string.c_str(); - + ofstream SSF_outfile; SSF_outfile.open(SSF_Cstr); SSF_outfile.precision(12); @@ -303,7 +303,7 @@ namespace JSC { ASF_stringstream << prefix; //if (iKmax != iKmin) DSF_stringstream << "_iKmin_" << iKmin << "_iKmax_" << iKmax; ASF_stringstream << "_ns_" << weight.size(); - ASF_stringstream << "_ommin_"<< ommin << "_ommax_" << ommax << "_Nom_" << Nom << "_w_" << gwidth << ".asf"; + ASF_stringstream << "_ommin_"<< ommin << "_ommax_" << ommax << "_Nom_" << Nom << "_w_" << gwidth << ".asf"; ASF_string = ASF_stringstream.str(); const char* ASF_Cstr = ASF_string.c_str(); ofstream ASF_outfile; @@ -335,7 +335,7 @@ namespace JSC { - DP Smoothen_RAW_into_ASF (string prefix, int iKmin, int iKmax, DP ommin, DP ommax, int Nom, DP gwidth, + DP Smoothen_RAW_into_ASF (string prefix, int iKmin, int iKmax, DP ommin, DP ommax, int Nom, DP gwidth, DP normalization, DP denom_sum_K) { // ommax is omega max for .asf file, Nom is the number of omega slots used. @@ -343,19 +343,19 @@ namespace JSC { // gwidth is the width of the smoothing Gaussian, defined as // exp(-omega^2/(2 * gwidth^2)) - // Open the original raw file: + // Open the original raw file: stringstream RAW_stringstream; string RAW_string; - RAW_stringstream << prefix << ".raw"; + RAW_stringstream << prefix << ".raw"; RAW_string = RAW_stringstream.str(); const char* RAW_Cstr = RAW_string.c_str(); ifstream RAW_infile; RAW_infile.open(RAW_Cstr); if (RAW_infile.fail()) { cout << RAW_Cstr << endl; - JSCerror("Could not open RAW_infile... "); + ABACUSerror("Could not open RAW_infile... "); } - if (iKmax - iKmin + 1 < 0) JSCerror("Improper iKmin, iKmax in Smoothen_RAW_into_ASF"); + if (iKmax - iKmin + 1 < 0) ABACUSerror("Improper iKmin, iKmax in Smoothen_RAW_into_ASF"); Vect_DP ASF(Nom); DP omega; @@ -388,13 +388,13 @@ namespace JSC { normalization_used /= denom_sum_K; for (int iomega = 0; iomega < Nom; ++iomega) ASF[iomega] *= normalization_used; - + // Output to .asf file stringstream ASF_stringstream; string ASF_string; ASF_stringstream << prefix; //if (iKmax != iKmin) DSF_stringstream << "_iKmin_" << iKmin << "_iKmax_" << iKmax; - ASF_stringstream << "_ommin_"<< ommin << "_ommax_" << ommax << "_Nom_" << Nom << "_w_" << gwidth << ".asf"; + ASF_stringstream << "_ommin_"<< ommin << "_ommax_" << ommax << "_Nom_" << Nom << "_w_" << gwidth << ".asf"; ASF_string = ASF_stringstream.str(); const char* ASF_Cstr = ASF_string.c_str(); ofstream ASF_outfile; @@ -416,4 +416,4 @@ namespace JSC { return(sumasf); } -} // namespace JSC +} // namespace ABACUS diff --git a/src/UTILS/Smoothen_RAW_into_SF_LiebLin_Scaled.cc b/src/UTILS/Smoothen_RAW_into_SF_LiebLin_Scaled.cc index e3ea934..2853a32 100644 --- a/src/UTILS/Smoothen_RAW_into_SF_LiebLin_Scaled.cc +++ b/src/UTILS/Smoothen_RAW_into_SF_LiebLin_Scaled.cc @@ -2,7 +2,7 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -10,17 +10,17 @@ File: Smoothen_RAW_into_SF_LiebLin_Scaled.cc Purpose: from a .raw file, produces .dsf (dynamical sf) file with gaussian width a function of momentum, and a .ssf (static sf) file. - + ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -namespace JSC { +namespace ABACUS { - DP Smoothen_RAW_into_SF_LiebLin_Scaled (string prefix, DP L, int N, int iKmin, int iKmax, int DiK, + DP Smoothen_RAW_into_SF_LiebLin_Scaled (string prefix, DP L, int N, int iKmin, int iKmax, int DiK, DP ommin, DP ommax, int Nom, DP width, DP normalization) { // DiK is the (half-)window in iK which is averaged over. A single iK means DiK == 0. @@ -32,19 +32,19 @@ namespace JSC { // gwidth is the width of the smoothing Gaussian, defined as // exp(-omega^2/(2 * gwidth^2)) - // Open the original raw file: + // Open the original raw file: stringstream RAW_stringstream; string RAW_string; - RAW_stringstream << prefix << ".raw"; + RAW_stringstream << prefix << ".raw"; RAW_string = RAW_stringstream.str(); const char* RAW_Cstr = RAW_string.c_str(); ifstream RAW_infile; RAW_infile.open(RAW_Cstr); if (RAW_infile.fail()) { cout << RAW_Cstr << endl; - JSCerror("Could not open RAW_infile... "); + ABACUSerror("Could not open RAW_infile... "); } - if (iKmax - iKmin + 1 < 0) JSCerror("Improper iKmin, iKmax in Smoothen_RAW_into_SF_LiebLin_Scaled"); + if (iKmax - iKmin + 1 < 0) ABACUSerror("Improper iKmin, iKmax in Smoothen_RAW_into_SF_LiebLin_Scaled"); RecMat DSFS(Nom, iKmax - iKmin + 1); Vect_DP SSF(0.0, iKmax - iKmin + 1); @@ -56,7 +56,7 @@ namespace JSC { string label; // Momenta: average over 2*DiK + 1 entries. Weigh them linearly decreasing away from central one. - // Setting central one to value 1 + DiK, + // Setting central one to value 1 + DiK, // total weight is 1 + DiK + 2* \sum_1^DiK n = 1 + DiK + DiK (DiK + 1) = (DiK + 1)^2. // Weight given is thus abs(DiK + 1 - (iK - iK'))/(DiK + 1)^2 for abs(iK - iK') <= DiK. Vect_DP Kweight(DiK + 1); @@ -76,9 +76,9 @@ namespace JSC { // For iK > N, there are N states. for (iK = iKmin; iK <= iKmax; ++iK) - //gwidth[iK - iKmin] = width * 2.0 * JSC::min( pow(twoPI * JSC::max(abs(iK),1)/L, 2.0), pow(twoPI * N/L, 2.0))/JSC::min(N, JSC::max(abs(iK), 1)); + //gwidth[iK - iKmin] = width * 2.0 * ABACUS::min( pow(twoPI * ABACUS::max(abs(iK),1)/L, 2.0), pow(twoPI * N/L, 2.0))/ABACUS::min(N, ABACUS::max(abs(iK), 1)); // Make sure the width does not become lower than the omegaout raster: - gwidth[iK - iKmin] = JSC::max(2.0 * (ommax - ommin)/Nom, width * 2.0 * JSC::min( pow(twoPI * JSC::max(abs(iK),1)/L, 2.0), pow(twoPI * N/L, 2.0))/JSC::min(N, JSC::max(abs(iK), 1))); + gwidth[iK - iKmin] = ABACUS::max(2.0 * (ommax - ommin)/Nom, width * 2.0 * ABACUS::min( pow(twoPI * ABACUS::max(abs(iK),1)/L, 2.0), pow(twoPI * N/L, 2.0))/ABACUS::min(N, ABACUS::max(abs(iK), 1))); Vect_DP big_gwidth_used (iKmax - iKmin + 1); @@ -105,7 +105,7 @@ namespace JSC { //DSF[iomega][iK - iKmin] += FF * FF * normalization_used[iK - iKmin] * exp(-d_omega*d_omega * oneovertwowidthsq[iK - iKmin]); for (int deltaiK = -DiK; deltaiK <= DiK; ++deltaiK) if (iK + deltaiK >= iKmin && iK + deltaiK <= iKmax) - DSFS[iomega][iK + deltaiK - iKmin] += Kweight[abs(deltaiK)] * FFsq * normalization_used[iK + deltaiK - iKmin] + DSFS[iomega][iK + deltaiK - iKmin] += Kweight[abs(deltaiK)] * FFsq * normalization_used[iK + deltaiK - iKmin] * exp(-d_omega*d_omega * oneovertwowidthsq[iK + deltaiK - iKmin]); } } @@ -119,14 +119,14 @@ namespace JSC { //for (int iomega = 0; iomega < Nom; ++iomega) //DSF[iomega][iK] *= normalization_used; } - + // Output to .dsfs and .ssf files stringstream DSFS_stringstream; string DSFS_string; DSFS_stringstream << prefix; //if (iKmax != iKmin) DSF_stringstream << "_iKmin_" << iKmin << "_iKmax_" << iKmax; if (DiK > 0) DSFS_stringstream << "_DiK_" << DiK; - DSFS_stringstream << "_ommin_"<< ommin << "_ommax_" << ommax << "_Nom_" << Nom << "_w_" << width << ".dsfs"; + DSFS_stringstream << "_ommin_"<< ommin << "_ommax_" << ommax << "_Nom_" << Nom << "_w_" << width << ".dsfs"; DSFS_string = DSFS_stringstream.str(); const char* DSFS_Cstr = DSFS_string.c_str(); ofstream DSFS_outfile; @@ -144,9 +144,9 @@ namespace JSC { stringstream SSF_stringstream; string SSF_string; SSF_stringstream << prefix; //if (iKmin != iKmax) SSF_stringstream << "_iKmin_" << iKmin << "_iKmax_" << iKmax; - SSF_stringstream << ".ssf"; + SSF_stringstream << ".ssf"; SSF_string = SSF_stringstream.str(); const char* SSF_Cstr = SSF_string.c_str(); - + ofstream SSF_outfile; SSF_outfile.open(SSF_Cstr); SSF_outfile.precision(12); @@ -172,4 +172,4 @@ namespace JSC { } -} // namespace JSC +} // namespace ABACUS diff --git a/src/UTILS/Sort_RAW_File.cc b/src/UTILS/Sort_RAW_File.cc index 297b79a..3d4ffe1 100644 --- a/src/UTILS/Sort_RAW_File.cc +++ b/src/UTILS/Sort_RAW_File.cc @@ -1,8 +1,8 @@ /********************************************************** -This software is part of J.-S. Caux's ABACUS++ library. +This software is part of J.-S. Caux's ABACUS library. -Copyright (c) +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -10,14 +10,15 @@ File: Sort_RAW_File.cc Purpose: orders the file in form factor or energy. - ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" -namespace JSC { +using namespace std; +namespace ABACUS { + void Sort_RAW_File (const char ffsq_file[], char optionchar) { Sort_RAW_File (ffsq_file, optionchar, 'a'); // dummy whichDSF, doesn't matter @@ -28,7 +29,7 @@ namespace JSC { { // Sorts FF in decreasing order for 'f' option, or energies in increasing order for option 'e', and writes .dat_srt file - if (!(optionchar == 'e' || optionchar == 'f')) JSCerror("Wrong option in Sort_FF"); + if (!(optionchar == 'e' || optionchar == 'f')) ABACUSerror("Wrong option in Sort_FF"); // Check size of threads file: struct stat statbuf; @@ -41,7 +42,7 @@ namespace JSC { //const int MAXDATA = 50000000; const int MAXDATA = filesize/entry_size + 10; - + DP* omega = new DP[MAXDATA]; int* iK = new int[MAXDATA]; DP* ff = new DP[MAXDATA]; @@ -53,7 +54,7 @@ namespace JSC { ifstream infile; infile.open(ff_file); - if (infile.fail()) JSCerror("The input file was not opened successfully in Sort_RAW_File. "); + if (infile.fail()) ABACUSerror("The input file was not opened successfully in Sort_RAW_File. "); stringstream outfilename; string outfilename_string; @@ -97,7 +98,7 @@ namespace JSC { outfile << omega[index[Ndata - 1 - i] ] << "\t" << iK[index[Ndata - 1 - i] ]; if (whichDSF != 'Z') outfile << "\t" << ff[index[Ndata - 1 - i] ]; if (whichDSF == 'q') outfile << "\t" << ff_im[index[Ndata - 1 - i] ]; - outfile << "\t" //<< conv[index[Ndata - 1 - i] ] << "\t" + outfile << "\t" //<< conv[index[Ndata - 1 - i] ] << "\t" << dev[index[Ndata - 1 - i] ] << "\t" << label[index[Ndata - 1 - i] ]; } @@ -105,14 +106,14 @@ namespace JSC { outfile << omega[i] << "\t" << iK[index[i] ]; if (whichDSF != 'Z') outfile << "\t" << ff[index[i] ]; if (whichDSF == 'q') outfile << "\t" << ff_im[index[i] ]; - outfile << "\t" //<< conv[index[i] ] << "\t" + outfile << "\t" //<< conv[index[i] ] << "\t" << dev[index[i] ] << "\t" << label[index[i] ]; } } outfile.close(); - + delete[] omega; delete[] iK; delete[] ff; @@ -127,4 +128,4 @@ namespace JSC { return; } -} // namespace JSC +} // namespace ABACUS diff --git a/src/UTILS/State_Label.cc b/src/UTILS/State_Label.cc index b9e68ab..d2d0874 100644 --- a/src/UTILS/State_Label.cc +++ b/src/UTILS/State_Label.cc @@ -2,44 +2,43 @@ This software is part of J.-S. Caux's ABACUS library. -Copyright (c). +Copyright (c) J.-S. Caux. ----------------------------------------------------------- File: src/UTILS/State_Label.cc -Purpose: universal implementation of state labels for ABACUS++ - +Purpose: universal implementation of state labels for ABACUS ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -using namespace JSC; +using namespace ABACUS; -namespace JSC { +namespace ABACUS { // The label of a state is built as follows: - + // M0[|type1:M1|type2:M2...]_nexc0[|nexc1|nexc2...]_type0Ix2old@type0Ix2new[:...][|type1Ix2old@type1Ix2new...] - - // A label is always relative to another label reference state, in practise + + // A label is always relative to another label reference state, in practise // the seed state used in the scanning for correlations (or otherwise by default: the ground state). - + // The first part of the label (before the first _ ) labels the particle content (the "base"). - // The second part (between the two _ ) specifies the number of quantum numbers + // The second part (between the two _ ) specifies the number of quantum numbers // excited to a position different from the configuration of the label reference state. - // The third part gives, for each excitation, the moved quantum number, and - // (after the @) the quantum number it has been moved to. - + // The third part gives, for each excitation, the moved quantum number, and + // (after the @) the quantum number it has been moved to. + // The second part is redundant (it could be read off the third part), but is kept since it is human-readable. - - // Example: - + + // Example: + // 300|2:23|5:4_3|2|1_-21@-43:11@-21:299@341|0@-24:4@12|5@35 - - // labels a state with + + // labels a state with // 300 particles of type 0, 23 of type 2 and 4 of type 5 // 3 type 0 particles displaced (Ix2 = -21 displaced to Ix2 = -43, 11 to -21 and 299 at 341) // 2 type 2 particles displaced (Ix2 = 0 to -24 and 4 to 12) @@ -50,7 +49,7 @@ namespace JSC { string Extract_Base_Label (string label) { string::size_type i1 = label.find(LABELSEP); - + //cout << "Extracting Base_Label from label " << label << endl; string baselabel = label.substr(0, i1); //cout << "Extracted Base_Label " << baselabel << endl; @@ -67,40 +66,40 @@ namespace JSC { } // For compressed labels: conversions between integers and char/strings. - // This is done according to the following data (in JSC_Scan.h): look for JSCcoding. + // This is done according to the following data (in ABACUS_Scan.h): look for ABACUScoding. - string Convert_POSINT_to_STR (int int_to_convert) + string Convert_POSINT_to_STR (int int_to_convert) { - // Converts a positive integer into a string according to the coding defined by global constant array JSCcoding. - if (int_to_convert < 0) JSCerror("Trying to convert a negative integer to a string."); + // Converts a positive integer into a string according to the coding defined by global constant array ABACUScoding. + if (int_to_convert < 0) ABACUSerror("Trying to convert a negative integer to a string."); int remainder = int_to_convert; stringstream result_strstrm; do { - //cout << "remainder = " << remainder << "\tnext index = " << remainder - JSCcodingsize * (remainder/JSCcodingsize) << endl; - result_strstrm << JSCcoding[remainder - JSCcodingsize * (remainder/JSCcodingsize)]; - remainder /= JSCcodingsize; + //cout << "remainder = " << remainder << "\tnext index = " << remainder - ABACUScodingsize * (remainder/ABACUScodingsize) << endl; + result_strstrm << ABACUScoding[remainder - ABACUScodingsize * (remainder/ABACUScodingsize)]; + remainder /= ABACUScodingsize; } while (remainder > 0); - + return(result_strstrm.str()); } int Convert_CHAR_to_POSINT (char char_to_convert) { - // Converts a char into an int according to the coding defined by global constant array JSCcoding. - for (int i = 0; i < JSCcodingsize; ++i) - if (char_to_convert == JSCcoding[i]) return(i); + // Converts a char into an int according to the coding defined by global constant array ABACUScoding. + for (int i = 0; i < ABACUScodingsize; ++i) + if (char_to_convert == ABACUScoding[i]) return(i); cout << "char to convert: " << char_to_convert << endl; - JSCerror("Failed to convert char to posint: char not in JSCcoding set."); + ABACUSerror("Failed to convert char to posint: char not in ABACUScoding set."); return(-1); } int Convert_STR_to_POSINT (string str_to_convert) { - // Converts a string into a positive integer according to the coding defined by global constant array JSCcoding. + // Converts a string into a positive integer according to the coding defined by global constant array ABACUScoding. int result = 0; for (unsigned int i = 0; i < str_to_convert.size(); ++i) { - result = JSCcodingsize * result + Convert_CHAR_to_POSINT(str_to_convert[str_to_convert.size() - 1 - i]); + result = ABACUScodingsize * result + Convert_CHAR_to_POSINT(str_to_convert[str_to_convert.size() - 1 - i]); } return(result); } @@ -149,7 +148,7 @@ namespace JSC { else { // ntypes > 1 // Read off M[0]: string::size_type i1 = baselabel.find(TYPESEP); // M0 is always present, without type specifier - string M0 = baselabel.substr(0, i1); + string M0 = baselabel.substr(0, i1); istringstream M0buffer(M0); M0buffer >> M[0]; @@ -157,7 +156,7 @@ namespace JSC { string baselabelremaining = baselabel; for (int itype = 1; itype < ntypes - 1; ++itype) { // Remove everything up to leftmost TYPESEP in baselabelremaining - string::size_type i1 = baselabelremaining.find(TYPESEP); // M0 is always present, without type specifier + string::size_type i1 = baselabelremaining.find(TYPESEP); // M0 is always present, without type specifier baselabelremaining = baselabelremaining.substr(i1+1); string::size_type i2 = baselabelremaining.find(EXCSEP); string::size_type i3 = baselabelremaining.find(TYPESEP); @@ -171,7 +170,7 @@ namespace JSC { // Read off M[ntypes - 1] { - string::size_type i1 = baselabelremaining.find(TYPESEP); // M0 is always present, without type specifier + string::size_type i1 = baselabelremaining.find(TYPESEP); // M0 is always present, without type specifier baselabelremaining = baselabelremaining.substr(i1+1); string::size_type i2 = baselabelremaining.find(EXCSEP); string typeread = baselabelremaining.substr(0, i2); @@ -242,7 +241,7 @@ namespace JSC { else { // ntypes > 1 // Read off M[0]: string::size_type i1 = baselabel.find(TYPESEP); // M0 is always present, without type specifier - string M0 = baselabel.substr(0, i1); + string M0 = baselabel.substr(0, i1); istringstream M0buffer(M0); M0buffer >> M[0]; @@ -250,7 +249,7 @@ namespace JSC { string baselabelremaining = baselabel; for (int itype = 1; itype < ntypes - 1; ++itype) { // Remove everything up to leftmost TYPESEP in baselabelremaining - string::size_type i1 = baselabelremaining.find(TYPESEP); // M0 is always present, without type specifier + string::size_type i1 = baselabelremaining.find(TYPESEP); // M0 is always present, without type specifier baselabelremaining = baselabelremaining.substr(i1+1); string::size_type i2 = baselabelremaining.find(EXCSEP); string::size_type i3 = baselabelremaining.find(TYPESEP); @@ -264,7 +263,7 @@ namespace JSC { // Read off M[ntypes - 1] { - string::size_type i1 = baselabelremaining.find(TYPESEP); // M0 is always present, without type specifier + string::size_type i1 = baselabelremaining.find(TYPESEP); // M0 is always present, without type specifier baselabelremaining = baselabelremaining.substr(i1+1); string::size_type i2 = baselabelremaining.find(EXCSEP); string typeread = baselabelremaining.substr(0, i2); @@ -289,8 +288,8 @@ namespace JSC { else { // ntypes > 1 // Read off nexc[0]: - string::size_type i1 = nexclabel.find(TYPESEP); - string nexc0 = nexclabel.substr(0, i1); + string::size_type i1 = nexclabel.find(TYPESEP); + string nexc0 = nexclabel.substr(0, i1); istringstream nexc0buffer(nexc0); nexc0buffer >> nexc[0]; @@ -298,7 +297,7 @@ namespace JSC { string nexclabelremaining = nexclabel; for (int itype = 1; itype < ntypes - 1; ++itype) { // Remove everything up to leftmost TYPESEP in nexclabelremaining - string::size_type i1 = nexclabelremaining.find(TYPESEP); + string::size_type i1 = nexclabelremaining.find(TYPESEP); nexclabelremaining = nexclabelremaining.substr(i1+1); string::size_type i2 = nexclabelremaining.find(TYPESEP); string nexcread = nexclabelremaining.substr(0, i2); @@ -308,7 +307,7 @@ namespace JSC { // Read off nexc[ntypes - 1] { - string::size_type i1 = nexclabelremaining.find(TYPESEP); + string::size_type i1 = nexclabelremaining.find(TYPESEP); nexclabelremaining = nexclabelremaining.substr(i1+1); istringstream nexcreadbuffer (nexclabelremaining); nexcreadbuffer >> nexc[ntypes - 1]; @@ -326,10 +325,10 @@ namespace JSC { // Now read off the (compressed) jexc and Ix2exc vectors of vectors: Vect > Ix2old(ntypes); // which Ix2 will be excited Vect > Ix2exc(ntypes); // which Ix2 the excitation has shifted to - + for (int itype = 0; itype < ntypes; ++itype) { - Ix2old[itype] = Vect (JSC::max(nexc[itype],1)); - Ix2exc[itype] = Vect (JSC::max(nexc[itype],1)); + Ix2old[itype] = Vect (ABACUS::max(nexc[itype],1)); + Ix2exc[itype] = Vect (ABACUS::max(nexc[itype],1)); } string Ix2exclabelremaining = Ix2exclabel; @@ -337,7 +336,7 @@ namespace JSC { // Read off the Ix2old, Ix2exc: if (nexc[itype] == 0) { // careful here, need to remove a TYPESEP string::size_type i2 = Ix2exclabelremaining.find(TYPESEP); - Ix2exclabelremaining = Ix2exclabelremaining.substr(i2+1); + Ix2exclabelremaining = Ix2exclabelremaining.substr(i2+1); } for (int iexc = 0; iexc < nexc[itype]; ++iexc) { //string::size_type i1 = Ix2exclabelremaining.find(INEXCSEP); @@ -385,10 +384,10 @@ namespace JSC { // Now read off the last pair: int Ix2excID = Convert_STR_to_POSINT(Ix2exclabelremaining); - Ix2old[ntypes - 1][JSC::max(nexc[ntypes - 1] - 1,0)] = OriginIx2[type[ntypes - 1] ][Ix2excID - M[ntypes - 1] * (Ix2excID/M[ntypes - 1])]; // index is remainder w/r to nr of strings of this type + Ix2old[ntypes - 1][ABACUS::max(nexc[ntypes - 1] - 1,0)] = OriginIx2[type[ntypes - 1] ][Ix2excID - M[ntypes - 1] * (Ix2excID/M[ntypes - 1])]; // index is remainder w/r to nr of strings of this type // Convention: if remainder is even, moving left. If odd, moving right. - //Ix2exc[ntypes - 1][JSC::max(nexc[ntypes - 1] - 1,0)] = Ix2old[ntypes - 1][nexc[ntypes - 1] - 1] + (Ix2excID/M[ntypes - 1] % 2 ? 2 : -2) * (Ix2excID/(2 * M[ntypes - 1]) + 0); - Ix2exc[ntypes - 1][JSC::max(nexc[ntypes - 1] - 1,0)] = Ix2old[ntypes - 1][nexc[ntypes - 1] - 1] + (Ix2excID/M[ntypes - 1] % 2 ? 2 : -2) * (Ix2excID/(2 * M[ntypes - 1]) + 1); // ABACUS++T_8 onwards + //Ix2exc[ntypes - 1][ABACUS::max(nexc[ntypes - 1] - 1,0)] = Ix2old[ntypes - 1][nexc[ntypes - 1] - 1] + (Ix2excID/M[ntypes - 1] % 2 ? 2 : -2) * (Ix2excID/(2 * M[ntypes - 1]) + 0); + Ix2exc[ntypes - 1][ABACUS::max(nexc[ntypes - 1] - 1,0)] = Ix2old[ntypes - 1][nexc[ntypes - 1] - 1] + (Ix2excID/M[ntypes - 1] % 2 ? 2 : -2) * (Ix2excID/(2 * M[ntypes - 1]) + 1); // ABACUS++T_8 onwards //string::size_type ilast = Ix2exclabelremaining.find(INEXCSEP); //string Ix2oldread = Ix2exclabelremaining.substr(0,ilast); @@ -479,19 +478,19 @@ namespace JSC { // ID % data.M[itype] gives the index of the hole position in OriginIx2. // We now define remainder1 == ID - (ID % data.M[itype]). // remainder1 is interpreted as: remainder1 even/odd means displacement to left/right - // remainder1/2 + 1 gives then the displacement in units of quantum nr. + // remainder1/2 + 1 gives then the displacement in units of quantum nr. // The +1 is to start labeling displacement from 0 (so 0 means displace by one unit). for (int itype = 0; itype < data.M.size(); ++itype) { if (itype > 0) label += TYPESEP; for (int iexc = 0; iexc < data.nexc[itype]; ++iexc) { if (iexc > 0) label += EXCSEP; - int excID = abs(data.Ix2exc[itype][iexc] - data.Ix2old[itype][iexc]) - 2; // necessarily even and >= 0 + int excID = abs(data.Ix2exc[itype][iexc] - data.Ix2old[itype][iexc]) - 2; // necessarily even and >= 0 if (data.Ix2exc[itype][iexc] > data.Ix2old[itype][iexc]) excID += 1; // make odd if displacement is to the right int holeindex = -1; do { holeindex++; } while (OriginIx2[data.type[itype] ][holeindex] != data.Ix2old[itype][iexc] && holeindex < OriginIx2[data.type[itype] ].size() - 1); - if (holeindex == OriginIx2[data.type[itype] ].size()) JSCerror("Going out of bounds in Compress_Label."); + if (holeindex == OriginIx2[data.type[itype] ].size()) ABACUSerror("Going out of bounds in Compress_Label."); excID = excID * data.M[itype] + holeindex; label += Convert_POSINT_to_STR(excID); } // for iexc @@ -513,12 +512,12 @@ namespace JSC { { // This function does not assume any ordering of the Ix2. - if (ScanIx2.size() != OriginIx2.size()) JSCerror("ScanIx2.size() != OriginIx2.size() in Find_Label."); - for (int i = 0; i < ScanIx2.size(); ++i) if (ScanIx2[i].size() != OriginIx2[i].size()) JSCerror("ScanIx2[i].size() != OriginIx2[i].size() in Find_Label."); + if (ScanIx2.size() != OriginIx2.size()) ABACUSerror("ScanIx2.size() != OriginIx2.size() in Find_Label."); + for (int i = 0; i < ScanIx2.size(); ++i) if (ScanIx2[i].size() != OriginIx2[i].size()) ABACUSerror("ScanIx2[i].size() != OriginIx2[i].size() in Find_Label."); // Set the state ulabel: // Count the number of types present: - int ntypespresent = 0; + int ntypespresent = 0; for (int is = 0; is < ScanIx2.size(); ++is) if (is == 0 || ScanIx2[is].size() > 0) ntypespresent++; // type 0 is by default always present Vect type_ref(ntypespresent); @@ -531,19 +530,19 @@ namespace JSC { type_ref[ntypespresentcheck] = is; M_ref[ntypespresentcheck++] = ScanIx2[is].size(); } - if (ntypespresentcheck != ntypespresent) JSCerror("Counting types present wrong in Return_Label."); + if (ntypespresentcheck != ntypespresent) ABACUSerror("Counting types present wrong in Return_Label."); // Count nr of particle-holes: for (int it = 0; it < ntypespresent; ++it) for (int i = 0; i < M_ref[it]; ++i) if (!OriginIx2[type_ref[it] ].includes(ScanIx2[type_ref[it] ][i])) nexc_ref[it] += 1; Vect > Ix2old_ref(ntypespresent); Vect > Ix2exc_ref(ntypespresent); - for (int it = 0; it < ntypespresent; ++it) Ix2old_ref[it] = Vect(JSC::max(nexc_ref[it],1)); - for (int it = 0; it < ntypespresent; ++it) Ix2exc_ref[it] = Vect(JSC::max(nexc_ref[it],1)); + for (int it = 0; it < ntypespresent; ++it) Ix2old_ref[it] = Vect(ABACUS::max(nexc_ref[it],1)); + for (int it = 0; it < ntypespresent; ++it) Ix2exc_ref[it] = Vect(ABACUS::max(nexc_ref[it],1)); for (int it = 0; it < ntypespresent; ++it) { int nexccheck = 0; for (int i = 0; i < M_ref[it]; ++i) if (!OriginIx2[type_ref[it] ].includes(ScanIx2[type_ref[it] ][i])) Ix2exc_ref[it][nexccheck++] = ScanIx2[type_ref[it] ][i]; - if (nexccheck != nexc_ref[it]) JSCerror("Counting excitations wrong (1) in Return_State_Label"); + if (nexccheck != nexc_ref[it]) ABACUSerror("Counting excitations wrong (1) in Return_State_Label"); nexccheck = 0; for (int i = 0; i < M_ref[it]; ++i) if (!ScanIx2[type_ref[it] ].includes(OriginIx2[type_ref[it] ][i])) Ix2old_ref[it][nexccheck++] = OriginIx2[type_ref[it] ][i]; if (nexccheck != nexc_ref[it]) { @@ -551,7 +550,7 @@ namespace JSC { cout << ScanIx2 << endl; cout << nexc_ref[it] << endl; cout << Ix2exc_ref[it] << endl; - JSCerror("Counting excitations wrong (2) in Return_State_Label"); + ABACUSerror("Counting excitations wrong (2) in Return_State_Label"); } // Now order the Ix2old_ref and Ix2exc_ref: Ix2old_ref[it].QuickSort(); @@ -589,7 +588,7 @@ namespace JSC { // Now set the excitations: for (int it = 0; it < labeldata.type.size(); ++it) for (int iexc = 0; iexc < labeldata.nexc[it]; ++iexc) - for (int i = 0; i < labeldata.M[it]; ++i) + for (int i = 0; i < labeldata.M[it]; ++i) if (Ix2[labeldata.type[it] ][i] == labeldata.Ix2old[it][iexc]) { Ix2[labeldata.type[it] ][i] = labeldata.Ix2exc[it][iexc]; } @@ -616,7 +615,7 @@ namespace JSC { // Conversion from one to the other: string Compress_Ulabel (string ulabel_ref, const Vect >& OriginIx2) { - // From a normal label, return a compressed one. + // From a normal label, return a compressed one. State_Label_Data data = Read_State_Ulabel (ulabel_ref); return(Return_State_Label(data, OriginIx2)); @@ -625,7 +624,7 @@ namespace JSC { string Compress_Ulabel (string ulabel_ref, const Vect& OriginIx2) // if there is only one type { - // From a normal label, return a compressed one. + // From a normal label, return a compressed one. Vect > OriginIx2here(1); OriginIx2here[0] = OriginIx2; @@ -655,4 +654,4 @@ namespace JSC { } */ -} // namespace JSC +} // namespace ABACUS diff --git a/src/XXX_h0/SF_4p_client.cc b/src/XXX_VOA/SF_4p_client.cc similarity index 95% rename from src/XXX_h0/SF_4p_client.cc rename to src/XXX_VOA/SF_4p_client.cc index a204f7f..7c83a6f 100755 --- a/src/XXX_h0/SF_4p_client.cc +++ b/src/XXX_VOA/SF_4p_client.cc @@ -2,7 +2,7 @@ This software is part of J.-S. Caux's C++ library. -Copyright (c) 2006. +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -11,24 +11,22 @@ File: SF_4p_client.cc Purpose: 4 spinon contrib to S(k, omega) for XXX_h0, parallel code using MPICH. Client part. -Last modified: 13/10/06 - ***********************************************************/ #include "mpi.h" -#include "JSC.h" +#include "ABACUS.h" -namespace JSC { +namespace ABACUS { void SF_4p_opt_client (MPI_Comm comm, I_table Itable) - { + { int server = 0; - int rank; + int rank; MPI_Status status; int client_request_size = 7; - DP client_request[client_request_size]; + DP client_request[client_request_size]; // this is: // ik // iomega @@ -37,7 +35,7 @@ namespace JSC { // req_prec // Npts_K // Npts_W - int client_result_size = 8; + int client_result_size = 8; DP client_result[client_result_size]; // as above, + SF_4p MPI_Comm_rank (comm, &rank); @@ -58,11 +56,11 @@ namespace JSC { client_result[4] = client_request[4]; client_result[5] = client_request[5]; client_result[6] = client_request[6]; - client_result[7] = SF_4p_opt (client_request[2], client_request[3], client_request[4], + client_result[7] = SF_4p_opt (client_request[2], client_request[3], client_request[4], int(client_request[5]), int(client_request[6]), Itable); MPI_Send (client_result, client_result_size, MPI_DOUBLE, server, status.MPI_TAG, comm); //cout << "Client of rank " << rank << " sending complete" << endl; - + // Wait for subsequent request from server MPI_Recv (client_request, client_request_size, MPI_DOUBLE, server, MPI_ANY_TAG, comm, &status); //cout << "Client of rank " << rank << ": received request "; @@ -75,9 +73,9 @@ namespace JSC { } /* void SF_4p_kwKW_alpha_client (MPI_Comm comm, DP req_prec, int max_rec, I_table Itable) - { + { int server = 0; - int rank; + int rank; MPI_Status status; @@ -109,7 +107,7 @@ namespace JSC { MPI_Send (client_result, client_result_size, MPI_DOUBLE, server, status.MPI_TAG, comm); //cout << "Client of rank " << rank << " sending complete" << endl; - + // Wait for subsequent request from server MPI_Recv (client_request, client_request_size, MPI_DOUBLE, server, MPI_ANY_TAG, comm, &status); //cout << "Client of rank " << rank << ": received request "; @@ -122,9 +120,9 @@ namespace JSC { } void SF_4p_kwKW_alpha_opt_client (MPI_Comm comm, DP req_prec, int Npts_K, int Npts_W, I_table Itable) - { + { int server = 0; - int rank; + int rank; MPI_Status status; @@ -157,7 +155,7 @@ namespace JSC { MPI_Send (client_result, client_result_size, MPI_DOUBLE, server, status.MPI_TAG, comm); //cout << "Client of rank " << rank << " sending complete" << endl; - + // Wait for subsequent request from server MPI_Recv (client_request, client_request_size, MPI_DOUBLE, server, MPI_ANY_TAG, comm, &status); //cout << "Client of rank " << rank << ": received request "; @@ -169,4 +167,4 @@ namespace JSC { return; } */ -} // namespace JSC +} // namespace ABACUS diff --git a/src/XXX_h0/SF_4p_server.cc b/src/XXX_VOA/SF_4p_server.cc similarity index 94% rename from src/XXX_h0/SF_4p_server.cc rename to src/XXX_VOA/SF_4p_server.cc index f592d1c..ce21480 100755 --- a/src/XXX_h0/SF_4p_server.cc +++ b/src/XXX_VOA/SF_4p_server.cc @@ -2,7 +2,7 @@ This software is part of J.-S. Caux's C++ library. -Copyright (c) 2006. +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -11,17 +11,15 @@ File: SF_4p_server.cc Purpose: 4 spinon contrib to S(k, omega) for XXX_h0, parallel code using MPICH. Server part. -Last modified: 13/10/06 - ***********************************************************/ #include "mpi.h" -#include "JSC.h" +#include "ABACUS.h" -namespace JSC { +namespace ABACUS { - void SF_4p_opt_server (MPI_Comm comm, int N, DP omegamax, int Nomega, DP req_prec, int Npts_K, int Npts_W, I_table Itable, + void SF_4p_opt_server (MPI_Comm comm, int N, DP omegamax, int Nomega, DP req_prec, int Npts_K, int Npts_W, I_table Itable, int Max_Secs, bool refine) { double Start_Time_MPI = MPI_Wtime(); @@ -31,15 +29,15 @@ namespace JSC { stringstream SF_stringstream; string SF_string; - SF_stringstream << "SF_4p_N_" << N << "_No_" << Nomega << "_omax_" << omegamax + SF_stringstream << "SF_4p_N_" << N << "_No_" << Nomega << "_omax_" << omegamax << "_prec_" << req_prec << "_Npts_K_" << Npts_K << "_Npts_W_" << Npts_W << ".dat"; SF_string = SF_stringstream.str(); const char* SF_Cstr = SF_string.c_str(); - + fstream SF_outfile; if (!refine) SF_outfile.open(SF_Cstr, fstream::out | fstream::trunc); - else SF_outfile.open(SF_Cstr, fstream::in | fstream::out); - if (SF_outfile.fail()) JSCerror("Could not open SF_outfile... "); + else SF_outfile.open(SF_Cstr, fstream::in | fstream::out); + if (SF_outfile.fail()) ABACUSerror("Could not open SF_outfile... "); SF_outfile.precision(10); @@ -60,7 +58,7 @@ namespace JSC { SF_outfile >> SF_4p[dim_k * iomega + ik]; if (SF_4p[dim_k * iomega + ik] == 0.0) total_nr_req++; //cout << ik << "\t" << iomega << "\t" << SF_4p[dim_k * iomega + ik] << "\t" << (SF_4p[dim_k * iomega + ik] == 0.0) << "\t" << total_nr_req << endl; - + // We only load the LHS of the BZ, so we load N/2 empty values... } for (int ibuff = 0; ibuff < N/2; ++ibuff) SF_outfile >> buff; @@ -74,7 +72,7 @@ namespace JSC { int* needed_iomega = new int[total_nr_req]; int index = 0; - for (int iomega = 0; iomega < Nomega; ++iomega) + for (int iomega = 0; iomega < Nomega; ++iomega) for (int ik = 0; ik < dim_k; ++ik) { if (SF_4p[dim_k * iomega + ik] == 0) { needed_ik[index] = ik; @@ -87,11 +85,11 @@ namespace JSC { if (index != total_nr_req) { cout << total_nr_req << "\t" << index << endl; - JSCerror("Not counting total_nr_req correctly in SF_4p_opt_server"); + ABACUSerror("Not counting total_nr_req correctly in SF_4p_opt_server"); } //ofstream SFsrc_outfile; //SFsrc_outfile.open(SFsrc_Cstr); - + //DP omegamin_used = 0.5 * wmin_4p (k); // Correct for factor of 2 in E between me & Bougourzi //DP omegamax_used = 0.5 * wmax_4p (k); @@ -140,7 +138,7 @@ namespace JSC { DP Actual_Time_MPI = MPI_Wtime(); - //while (nr_returned < total_nr_req) { + //while (nr_returned < total_nr_req) { while (nr_returned < nr_sent_out) { //cout << "Server: waiting for answers... " << endl; @@ -169,7 +167,7 @@ namespace JSC { cout << endl << "Server saving file..." << endl; - // Output all data: double up to full [0, 2pi] interval in k with symmetry + // Output all data: double up to full [0, 2pi] interval in k with symmetry SF_outfile.seekp(0); for (int iomega = 0; iomega < Nomega; ++iomega) { for (int ik = 0; ik < dim_k; ++ik) SF_outfile << SF_4p[dim_k * iomega + ik] << "\t"; @@ -178,7 +176,7 @@ namespace JSC { } SF_outfile.close(); - + cout << endl << "Done !" << endl; // Send term signal to clients @@ -195,7 +193,7 @@ namespace JSC { *********************************************************/ /* - void SF_4p_opt_server (MPI_Comm comm, DP k_needed, DP omegamax, int Nomega, DP req_prec, int Npts_K, int Npts_W, I_table Itable, + void SF_4p_opt_server (MPI_Comm comm, DP k_needed, DP omegamax, int Nomega, DP req_prec, int Npts_K, int Npts_W, I_table Itable, int Max_Secs, bool refine) { double Start_Time_MPI = MPI_Wtime(); @@ -204,15 +202,15 @@ namespace JSC { stringstream SF_stringstream; string SF_string; - SF_stringstream << "SF_4p_k_" << k_needed << "_No_" << Nomega << "_omax_" << omegamax + SF_stringstream << "SF_4p_k_" << k_needed << "_No_" << Nomega << "_omax_" << omegamax << "_prec_" << req_prec << "_Npts_K_" << Npts_K << "_Npts_W_" << Npts_W << ".dat"; SF_string = SF_stringstream.str(); const char* SF_Cstr = SF_string.c_str(); - + fstream SF_outfile; if (!refine) SF_outfile.open(SF_Cstr, fstream::out | fstream::trunc); - else SF_outfile.open(SF_Cstr, fstream::in | fstream::out); - if (SF_outfile.fail()) JSCerror("Could not open SF_outfile... "); + else SF_outfile.open(SF_Cstr, fstream::in | fstream::out); + if (SF_outfile.fail()) ABACUSerror("Could not open SF_outfile... "); SF_outfile.precision(12); @@ -233,7 +231,7 @@ namespace JSC { SF_outfile >> SF_4p[dim_k * iomega + ik]; if (SF_4p[dim_k * iomega + ik] == 0.0) total_nr_req++; //cout << ik << "\t" << iomega << "\t" << SF_4p[dim_k * iomega + ik] << "\t" << (SF_4p[dim_k * iomega + ik] == 0.0) << "\t" << total_nr_req << endl; - + // We only load the LHS of the BZ, so we load N/2 empty values... } for (int ibuff = 0; ibuff < N/2; ++ibuff) SF_outfile >> buff; @@ -247,7 +245,7 @@ namespace JSC { int* needed_iomega = new int[total_nr_req]; int index = 0; - for (int iomega = 0; iomega < Nomega; ++iomega) + for (int iomega = 0; iomega < Nomega; ++iomega) for (int ik = 0; ik < dim_k; ++ik) { if (SF_4p[dim_k * iomega + ik] == 0) { needed_ik[index] = ik; @@ -260,11 +258,11 @@ namespace JSC { if (index != total_nr_req) { cout << total_nr_req << "\t" << index << endl; - JSCerror("Not counting total_nr_req correctly in SF_4p_opt_server"); + ABACUSerror("Not counting total_nr_req correctly in SF_4p_opt_server"); } //ofstream SFsrc_outfile; //SFsrc_outfile.open(SFsrc_Cstr); - + //DP omegamin_used = 0.5 * wmin_4p (k); // Correct for factor of 2 in E between me & Bougourzi //DP omegamax_used = 0.5 * wmax_4p (k); @@ -313,7 +311,7 @@ namespace JSC { DP Actual_Time_MPI = MPI_Wtime(); - //while (nr_returned < total_nr_req) { + //while (nr_returned < total_nr_req) { while (nr_returned < nr_sent_out) { //cout << "Server: waiting for answers... " << endl; @@ -342,14 +340,14 @@ namespace JSC { cout << endl << "Server saving file..." << endl; - // Output all data: + // Output all data: SF_outfile.seekp(0); for (int iomega = 0; iomega < Nomega; ++iomega) { SF_outfile << omega[iomega] << "\t" << SF_4p[iomega] << endl; } SF_outfile.close(); - + cout << endl << "Done !" << endl; // Send term signal to clients @@ -371,24 +369,24 @@ namespace JSC { SFraw_stringstream << "SF_4p_k_" << k << "_prec_" << req_prec << "_max_rec_w_" << max_rec_w << "_max_rec_" << max_rec << ".raw"; SFraw_string = SFraw_stringstream.str(); const char* SFraw_Cstr = SFraw_string.c_str(); - + stringstream SF_stringstream; string SF_string; SF_stringstream << "SF_4p_k_" << k << "_prec_" << req_prec << "_max_rec_w_" << max_rec_w << "_max_rec_" << max_rec << ".dat"; SF_string = SF_stringstream.str(); const char* SF_Cstr = SF_string.c_str(); - + stringstream SFsrc_stringstream; string SFsrc_string; SFsrc_stringstream << "SF_4p_k_" << k << "_prec_" << req_prec << "_max_rec_w_" << max_rec_w << "_max_rec_" << max_rec << ".src"; SFsrc_string = SFsrc_stringstream.str(); const char* SFsrc_Cstr = SFsrc_string.c_str(); - + ofstream SFraw_outfile; SFraw_outfile.open(SFraw_Cstr); //ofstream SFsrc_outfile; //SFsrc_outfile.open(SFsrc_Cstr); - + //DP omegamin_used = 0.5 * wmin_4p (k); // Correct for factor of 2 in E between me & Bougourzi //DP omegamax_used = 0.5 * wmax_4p (k); @@ -429,7 +427,7 @@ namespace JSC { } while (nr_returned < total_nr_req) { - + //cout << "Server: waiting for answers... " << endl; MPI_Recv (client_result, client_result_size, MPI_DOUBLE, MPI_ANY_SOURCE, MPI_ANY_TAG, comm, &status); nr_returned++; @@ -454,15 +452,15 @@ namespace JSC { MPI_Send (client_request, client_request_size, MPI_DOUBLE, i, scanning_completed, comm); SFraw_outfile.close(); - + //SFsrc_outfile << answer << endl; //SFsrc_outfile.close(); - + // Translate raw data into SF_4p (k,omega) data - + //Translate_raw_4p_data (k, max_rec_w, SFraw_Cstr, SF_Cstr, SFsrc_Cstr, Itable); Translate_raw_4p_data (k, int(pow(3.0, max_rec_w + 2)), SFraw_Cstr, SF_Cstr, SFsrc_Cstr, Itable); - + return; } @@ -473,24 +471,24 @@ namespace JSC { SFraw_stringstream << "SF_4p_k_" << k << "_prec_" << req_prec << "_Npts_" << Npts_w << "_" << Npts_K << "_" << Npts_W << ".raw"; SFraw_string = SFraw_stringstream.str(); const char* SFraw_Cstr = SFraw_string.c_str(); - + stringstream SF_stringstream; string SF_string; SF_stringstream << "SF_4p_k_" << k << "_prec_" << req_prec << "_Npts_" << Npts_w << "_" << Npts_K << "_" << Npts_W << ".dat"; SF_string = SF_stringstream.str(); const char* SF_Cstr = SF_string.c_str(); - + stringstream SFsrc_stringstream; string SFsrc_string; SFsrc_stringstream << "SF_4p_k_" << k << "_prec_" << req_prec << "_Npts_" << Npts_w << "_" << Npts_K << "_" << Npts_W << ".src"; SFsrc_string = SFsrc_stringstream.str(); const char* SFsrc_Cstr = SFsrc_string.c_str(); - + ofstream SFraw_outfile; SFraw_outfile.open(SFraw_Cstr); //ofstream SFsrc_outfile; //SFsrc_outfile.open(SFsrc_Cstr); - + //DP omegamin_used = 0.5 * wmin_4p (k); // Correct for factor of 2 in E between me & Bougourzi //DP omegamax_used = 0.5 * wmax_4p (k); @@ -531,7 +529,7 @@ namespace JSC { } while (nr_returned < total_nr_req) { - + //cout << "Server: waiting for answers... " << endl; MPI_Recv (client_result, client_result_size, MPI_DOUBLE, MPI_ANY_SOURCE, MPI_ANY_TAG, comm, &status); nr_returned++; @@ -556,17 +554,17 @@ namespace JSC { MPI_Send (client_request, client_request_size, MPI_DOUBLE, i, scanning_completed, comm); SFraw_outfile.close(); - + //SFsrc_outfile << answer << endl; //SFsrc_outfile.close(); - + // Translate raw data into SF_4p (k,omega) data - + //Translate_raw_4p_data (k, max_rec_w, SFraw_Cstr, SF_Cstr, SFsrc_Cstr, Itable); Translate_raw_4p_data (k, Npts_w, SFraw_Cstr, SF_Cstr, SFsrc_Cstr, Itable); - + return; } */ -} // namespace JSC +} // namespace ABACUS diff --git a/src/XXX_h0/XXX_h0.cc b/src/XXX_VOA/XXX_VOA.cc similarity index 91% rename from src/XXX_h0/XXX_h0.cc rename to src/XXX_VOA/XXX_VOA.cc index 8e3ad75..143a6d6 100755 --- a/src/XXX_h0/XXX_h0.cc +++ b/src/XXX_VOA/XXX_VOA.cc @@ -1,29 +1,33 @@ /**************************************************************** -XXX_h0.cc +This software is part of J.-S. Caux's C++ library. + +Copyright (c) J.-S. Caux. + +----------------------------------------------------------- + +File: XXX_VOA.cc Defines all class procedures used for the XXX chain in zero field. -LAST MODIFIED: 12/10/06 - ******************************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -namespace JSC { +namespace ABACUS { DP I_integral (DP rho, DP req_prec) { DP t1 = 1.0; // delimiter between two integrals - DP tinf = 24.0; // such that exp(-2tinf) << machine_eps + DP tinf = 24.0; // such that exp(-2tinf) << machine_eps DP Euler_Mascheroni = 0.577215664901532860606; - + DP rho_used = fabs(rho); - if (rho_used > 10000.0) return(-PI * rho_used - 2.0 * Euler_Mascheroni); // CHECK THIS - + if (rho_used > 10000.0) return(-PI * rho_used - 2.0 * Euler_Mascheroni); // CHECK THIS + Vect_DP args(2); args[0] = 0.0; args[1] = rho_used; @@ -44,217 +48,217 @@ namespace JSC { /********************* TWO SPINONS ********************/ - + DP SF_2p (DP k, DP omega, I_table Itable) { // Careful ! This is S(k, omega) = S (k, w) |dw/domega| = 2 S(k, w) - + DP w = 2.0 * omega; // Rescale energies by factor 2 because of definitions of H_XXX (omega: S.S; w: 0.5 * sigma.sigma = 2 S.S) - + DP wu = twoPI * sin(0.5 * k); DP wl = PI * fabs(sin(k)); - + // Factor of 2: return S(k, omega), not S(k, w) // 0.25 factor: 1/4 * 2 * 1/2, where 1/4 comes from Bougourzi, 2 is the Jacobian |dw/domega| and 1/2 is S^{zz} = 1/2 * S^{+-} return(w < wu && w > wl ? 2.0 * 0.5 * exp(-Itable.Return_val (acosh(sqrt((wu * wu - wl * wl)/(w * w - wl * wl)))/PI))/sqrt(wu * wu - w * w) : 0.0); - + } - + DP SF_2p (Vect_DP args, I_table Itable) { // Careful ! This is S(k, w) ! - + // This uses args[0] = k, args[1] = w. - + DP wu = twoPI * sin(0.5 * args[0]); DP wl = PI * fabs(sin(args[0])); - + // 0.5 factor: 1 from Bougourzi, and 1/2 is S^{zz} = 1/2 * S^{+-} - return(args[1] < wu && args[1] > wl ? + return(args[1] < wu && args[1] > wl ? 0.5 * exp(-Itable.Return_val (acosh(sqrt((wu * wu - wl * wl)/(args[1] * args[1] - wl * wl)))/PI))/sqrt(wu * wu - args[1] * args[1]) : 0.0); } - + DP SF_2p_alt (Vect_DP args, I_table Itable) { // Careful ! This is S(k, w) ! - + // This uses args[0] = k, args[1] = alpha. - + DP wu = twoPI * sin(0.5 * args[0]); DP wl = PI * fabs(sin(args[0])); - + //DP w = wu * cos(args[1]); //DP factor = 1.0; DP w = wl * cosh(args[1]); - + if (w >= wu || w <= wl) return(0.0); - + DP factor = sqrt((w * w - wl * wl)/(wu * wu - w * w)); - + // 0.5 factor: 1 from Bougourzi, and 1/2 is S^{zz} = 1/2 * S^{+-} return(factor * 0.5 * exp(-Itable.Return_val (acosh(sqrt((wu * wu - wl * wl)/(w * w - wl * wl)))/PI))); } - + DP SF_2p_w (Vect_DP args, I_table Itable) { return(args[1] * SF_2p (args, Itable)); } - + DP SF_2p_w_alt (Vect_DP args, I_table Itable) { DP wu = twoPI * sin(0.5 * args[0]); DP wl = PI * fabs(sin(args[0])); - + //DP w = wu * cos(args[1]); //DP factor = 1.0; DP w = wl * cosh(args[1]); DP factor = sqrt((w * w - wl * wl)/(wu * wu - w * w)); - + // 0.5 factor: 1 from Bougourzi, and 1/2 is S^{zz} = 1/2 * S^{+-} return(w * factor * 0.5 * exp(-Itable.Return_val (acosh(sqrt((wu * wu - wl * wl)/(w * w - wl * wl)))/PI))); } - + DP SF_2p_intw (Vect_DP args, I_table Itable) { // This returns \int_0^2PI dw/2PI S(k, w) - + DP k = args[0]; DP req_prec = args[1]; int max_rec = int(args[2]); - + DP wu = twoPI * sin(0.5 * k); DP wl = PI * fabs(sin(k)); - + Vect_DP args_to_SF_2p(2); args_to_SF_2p[0] = k; args_to_SF_2p[1] = 0.0; // this will be w - args_to_SF_2p[2] = JSC::max(1.0e-14, 0.01 * req_prec); - + args_to_SF_2p[2] = ABACUS::max(1.0e-14, 0.01 * req_prec); + return(Integrate_rec_using_table (SF_2p, args_to_SF_2p, 1, Itable, wl, wu, req_prec, max_rec)/twoPI); } - + DP SF_2p_intw_alt (Vect_DP args, I_table Itable) { // This returns \int_0^2PI dw/2PI S(k, w) - + DP k = args[0]; DP req_prec = args[1]; int max_rec = int(args[2]); - + DP wu = twoPI * sin(0.5 * k); DP wl = PI * fabs(sin(k)); - + Vect_DP args_to_SF_2p(2); args_to_SF_2p[0] = k; args_to_SF_2p[1] = 0.0; // this will be w - args_to_SF_2p[2] = JSC::max(1.0e-14, 0.01 * req_prec); - + args_to_SF_2p[2] = ABACUS::max(1.0e-14, 0.01 * req_prec); + //return(Integrate_rec_using_table (SF_2p_alt, args_to_SF_2p, 1, Itable, 0.0, acos(wl/wu), req_prec, max_rec)/twoPI); return(Integrate_rec_using_table (SF_2p_alt, args_to_SF_2p, 1, Itable, 0.0, acosh(wu/wl), req_prec, max_rec)/twoPI); } - + DP SF_2p_check_sumrule (DP req_prec, int max_rec, I_table Itable) { // It's better to use the ..._alt function below. - + Vect_DP args_to_SF_2p_intw (3); - + args_to_SF_2p_intw[0] = 0.0; // this will be k - args_to_SF_2p_intw[1] = JSC::max(1.0e-14, 0.01 * req_prec); + args_to_SF_2p_intw[1] = ABACUS::max(1.0e-14, 0.01 * req_prec); args_to_SF_2p_intw[2] = DP(max_rec); - + // Factor 2: int[0, 2PI] = 2 int[0, PI] return(4.0 * 2.0 * Integrate_rec_using_table (SF_2p_intw, args_to_SF_2p_intw, 0, Itable, 0.0, PI, req_prec, max_rec)/twoPI); // 4 : because full integral gives 1/4, return value here is sr fraction obtained. } - + DP SF_2p_check_sumrule_alt (DP req_prec, int max_rec, I_table Itable) { // This is the preferred version. - + Vect_DP args_to_SF_2p_intw (3); - + args_to_SF_2p_intw[0] = 0.0; // this will be k - args_to_SF_2p_intw[1] = JSC::max(1.0e-14, 0.01 * req_prec); + args_to_SF_2p_intw[1] = ABACUS::max(1.0e-14, 0.01 * req_prec); args_to_SF_2p_intw[2] = DP(max_rec); - + // Factor 2: int[0, 2PI] = 2 int[0, PI] return(4.0 * 2.0 * Integrate_rec_using_table (SF_2p_intw_alt, args_to_SF_2p_intw, 0, Itable, 0.0, PI, req_prec, max_rec)/twoPI); // 4 : because full integral gives 1/4, return value here is sr fraction obtained. } - + DP Fixed_k_sumrule_w (DP k) { // This is K_1 (k) = \int dw/2PI w S(k, w) = 2 K_1^{KarbachPRB55} (k) = 4 E_G (1-cosk)/3N with E_G = -N(ln2 - 1/4). return(4.0 * (log(2.0) - 0.25) * (1.0 - cos(k))/3.0); } - + DP Fixed_k_sumrule_omega (DP k) { return(0.5 * Fixed_k_sumrule_w(k)); } - + DP SF_2p_check_fixed_k_sumrule (DP k, DP req_prec, int max_rec, I_table Itable) { // It's better to use the ..._alt function below. - + DP wu = twoPI * sin(0.5 * k); DP wl = PI * fabs(sin(k)); - + Vect_DP args_to_SF_2p(2); args_to_SF_2p[0] = k; args_to_SF_2p[1] = 0.0; // this will be w - args_to_SF_2p[2] = JSC::max(1.0e-14, 0.01 * req_prec); - + args_to_SF_2p[2] = ABACUS::max(1.0e-14, 0.01 * req_prec); + return((Integrate_rec_using_table (SF_2p_w, args_to_SF_2p, 1, Itable, wl, wu, req_prec, max_rec)/twoPI)/Fixed_k_sumrule_w(k)); } - + DP SF_2p_check_fixed_k_sumrule_alt (DP k, DP req_prec, int max_rec, I_table Itable) { // This is the preferred version. - + DP wu = twoPI * sin(0.5 * k); DP wl = PI * fabs(sin(k)); - + Vect_DP args_to_SF_2p(2); args_to_SF_2p[0] = k; args_to_SF_2p[1] = 0.0; // this will be alpha - args_to_SF_2p[2] = JSC::max(1.0e-14, 0.01 * req_prec); - + args_to_SF_2p[2] = ABACUS::max(1.0e-14, 0.01 * req_prec); + return((Integrate_rec_using_table (SF_2p_w_alt, args_to_SF_2p, 1, Itable, 0.0, acosh(wu/wl), req_prec, max_rec)/twoPI)/Fixed_k_sumrule_w(k)); } DP SF_2p_check_fixed_k_sumrule_opt (DP k, DP req_prec, int Npts, I_table Itable) { // This is the preferred version. - + DP wu = twoPI * sin(0.5 * k); DP wl = PI * fabs(sin(k)); - + Vect_DP args_to_SF_2p(2); args_to_SF_2p[0] = k; args_to_SF_2p[1] = 0.0; // this will be alpha - args_to_SF_2p[2] = JSC::max(1.0e-14, 0.01 * req_prec); - + args_to_SF_2p[2] = ABACUS::max(1.0e-14, 0.01 * req_prec); + return(((Integrate_optimal_using_table (SF_2p_w_alt, args_to_SF_2p, 1, Itable, 0.0, acosh(wu/wl), req_prec, 1.0e-32, Npts)).integ_est/twoPI)/Fixed_k_sumrule_w(k)); } /********************** FOUR SPINONS **********************/ - - + + DP Sum_norm_gl (Vect_DP rho, DP req_prec) { complex g[4]; for (int l = 0; l < 4; ++l) g[l] = 0.0; - + //DP prefactor = 256.0 * pow(PI, 14.0); //DP prefactor = 1.0; // All factors taken into account later - + complex Plm[4]; complex Pm[4]; - + DP den = 0.0; for (int j = 0; j < 4; ++j) { Pm[j] = cosh(twoPI * rho[j]); @@ -262,19 +266,19 @@ namespace JSC { for (int i = 0; i < 4; ++i) if (i != j) den *= sinh(PI * (rho[j] - rho[i])); Pm[j] /= den; } - + complex irhoj0[4]; complex irhoj1[4]; complex irhoj2[4]; complex irhoj3[4]; - + for (int j = 0; j < 4; ++j) { irhoj0[j] = II * (rho[j] - rho[0]); irhoj1[j] = II * (rho[j] - rho[1]); irhoj2[j] = II * (rho[j] - rho[2]); irhoj3[j] = II * (rho[j] - rho[3]); } - + // Do m = 0 terms: /* Pm[0] *= Gamma_min_0p5 * exp(ln_Gamma(-0.5 + irhoj1[0]) - ln_Gamma(1.0 + irhoj1[0]) @@ -305,12 +309,12 @@ namespace JSC { /((-0.5 + irhoj0[j]) * (-0.5 + irhoj1[j]) * (-0.5 + irhoj2[j]) * (-0.5 + irhoj3[j])); for (int l = 0; l < 4; ++l) { - + Plm[j] = 1.0; for (int i = 0; i < 4; ++i) if (i != l) Plm[j] *= ((l > i ? -0.5 : 0.0) + II * (rho[j] - rho[i])); - + if (j <= l) g[l] += Plm[j] * Pm[j]; // otherwise no m = 0 term - + //cout << "j = " << j << "\tl = " << l << "\tPlm[j] = " << Plm[j] << "\tPm[j] = " << Pm[j] << "\tprod = " << Plm[j] * Pm[j] << endl; } } @@ -326,16 +330,16 @@ namespace JSC { DP sum_norm_gl = norm(g[0]) + norm(g[1]) + norm(g[2]) + norm(g[3]); DP old_sum_norm_gl = sum_norm_gl; - - //cout << "|g1|^2 = " << prefactor * norm(g[0]) << "\t2 " << prefactor * norm(g[1]) << "\t3 " << prefactor * norm(g[2]) << "\t4 " << prefactor * norm(g[3]) << endl; - + + //cout << "|g1|^2 = " << prefactor * norm(g[0]) << "\t2 " << prefactor * norm(g[1]) << "\t3 " << prefactor * norm(g[2]) << "\t4 " << prefactor * norm(g[3]) << endl; + // Do m = 1, 2, ... terms: - + int m = 1; int m_to_reach = 1; do { - + old_sum_norm_gl = sum_norm_gl; // We increase m by ten steps before checking sum_norm @@ -345,15 +349,15 @@ namespace JSC { do { for (int j = 0; j < 4; ++j) { - - Pm[j] *= (m - 1.5 + irhoj0[j]) * (m - 1.5 + irhoj1[j]) * (m - 1.5 + irhoj2[j]) * (m - 1.5 + irhoj3[j]) + + Pm[j] *= (m - 1.5 + irhoj0[j]) * (m - 1.5 + irhoj1[j]) * (m - 1.5 + irhoj2[j]) * (m - 1.5 + irhoj3[j]) / ((DP(m) + irhoj0[j]) * (DP(m) + irhoj1[j]) * (DP(m) + irhoj2[j]) * (DP(m) + irhoj3[j])); //for (int l = 0; l < 4; ++l) { - + //Plm[j] = 1.0; //for (int i = 0; i < 4; ++i) if (i != l) Plm[j] *= m - (l > i ? 0.5 : 0.0) + II * (rho[j] - rho[i]); - + //g[l] += Plm[j] * Pm[j]; //} @@ -382,15 +386,15 @@ namespace JSC { /* // Also unwrap j loop: - Pm[0] *= (m - 1.5 + irhoj0[0]) * (m - 1.5 + irhoj1[0]) * (m - 1.5 + irhoj2[0]) * (m - 1.5 + irhoj3[0]) + Pm[0] *= (m - 1.5 + irhoj0[0]) * (m - 1.5 + irhoj1[0]) * (m - 1.5 + irhoj2[0]) * (m - 1.5 + irhoj3[0]) / ((DP(m) + irhoj0[0]) * (DP(m) + irhoj1[0]) * (DP(m) + irhoj2[0]) * (DP(m) + irhoj3[0])); - Pm[1] *= (m - 1.5 + irhoj0[1]) * (m - 1.5 + irhoj1[1]) * (m - 1.5 + irhoj2[1]) * (m - 1.5 + irhoj3[1]) + Pm[1] *= (m - 1.5 + irhoj0[1]) * (m - 1.5 + irhoj1[1]) * (m - 1.5 + irhoj2[1]) * (m - 1.5 + irhoj3[1]) / ((DP(m) + irhoj0[1]) * (DP(m) + irhoj1[1]) * (DP(m) + irhoj2[1]) * (DP(m) + irhoj3[1])); - Pm[2] *= (m - 1.5 + irhoj0[2]) * (m - 1.5 + irhoj1[2]) * (m - 1.5 + irhoj2[2]) * (m - 1.5 + irhoj3[2]) + Pm[2] *= (m - 1.5 + irhoj0[2]) * (m - 1.5 + irhoj1[2]) * (m - 1.5 + irhoj2[2]) * (m - 1.5 + irhoj3[2]) / ((DP(m) + irhoj0[2]) * (DP(m) + irhoj1[2]) * (DP(m) + irhoj2[2]) * (DP(m) + irhoj3[2])); - Pm[3] *= (m - 1.5 + irhoj0[3]) * (m - 1.5 + irhoj1[3]) * (m - 1.5 + irhoj2[3]) * (m - 1.5 + irhoj3[3]) + Pm[3] *= (m - 1.5 + irhoj0[3]) * (m - 1.5 + irhoj1[3]) * (m - 1.5 + irhoj2[3]) * (m - 1.5 + irhoj3[3]) / ((DP(m) + irhoj0[3]) * (DP(m) + irhoj1[3]) * (DP(m) + irhoj2[3]) * (DP(m) + irhoj3[3])); - + g[0] += ((DP(m) + irhoj1[0]) * (DP(m) + irhoj2[0]) * (DP(m) + irhoj3[0])) * Pm[0] + ((DP(m)) * (DP(m) + irhoj2[1]) * (DP(m) + irhoj3[1])) * Pm[1] + ((DP(m) + irhoj1[2]) * (DP(m)) * (DP(m) + irhoj3[0])) * Pm[2] @@ -413,46 +417,46 @@ namespace JSC { */ m++; - } while (m < m_to_reach); - + } while (m < m_to_reach); + sum_norm_gl = norm(g[0]) + norm(g[1]) + norm(g[2]) + norm(g[3]); - + } while (m < 10 || sum_norm_gl/old_sum_norm_gl - 1.0 > req_prec && m < 100000); - + //cout << "g converged using " << m << " terms." << endl; - + //cout << "|g1|^2 = " << prefactor * norm(g[0]) << "\t2 " << prefactor * norm(g[1]) << "\t3 " << prefactor * norm(g[2]) << "\t4 " << prefactor * norm(g[3]) << endl; - + //return(prefactor * (norm(g[0]) + norm(g[1]) + norm(g[2]) + norm(g[3]))); return(norm(g[0]) + norm(g[1]) + norm(g[2]) + norm(g[3])); - + } - + DP Compute_C4 (DP req_prec) { Vect_DP args(2); - + DP answer = exp(-8.0 * real(ln_Gamma (0.25)) - 9.0 * log(2.0) + 8.0 * Integrate_rec (Integrand_A, args, 0, 0.0, 50.0, req_prec, 16))/3.0; //DP answer = exp(-8.0 * real(ln_Gamma (0.25)) - 21.0 * log(2.0) - 14.0 * log(PI) + 8.0 * Integrate_rec (Integrand_A, args, 0, 0.0, 100.0, req_prec, 16))/3.0; - - //cout << "|A|^2 = " << exp(-2.0 * Integrate_rec (Integrand_A, args, 0, 0.0, 100.0, req_prec)) + + //cout << "|A|^2 = " << exp(-2.0 * Integrate_rec (Integrand_A, args, 0, 0.0, 100.0, req_prec)) // << "\t Gamma (1/4) = " << exp ((ln_Gamma(0.25))) << endl; //cout << "NPB: " << exp(-8.0 * real(ln_Gamma (0.25)) - 9.0 * log(2.0) + 8.0 * Integrate_rec (Integrand_A, args, 0, 0.0, 50.0, req_prec))/3.0 << endl; //cout << "c-m: " << exp(-8.0 * real(ln_Gamma (0.25)) - 21.0 * log(2.0) - 14.0 * log(PI) + 8.0 * Integrate_rec (Integrand_A, args, 0, 0.0, 50.0, req_prec))/3.0 << endl; - + return(answer); } - - DP SF_contrib (Vect_DP p, DP req_prec, I_table Itable) + + DP SF_contrib (Vect_DP p, DP req_prec, I_table Itable) { Vect_DP rho(4); DP W, Wu, sum_I_integrals, sum_norm_g; - + for (int i = 0; i < 4; ++i) rho[i] = asinh(1.0/tan(p[i]))/twoPI; - + Wu = twoPI* fabs(sin(0.5*(p[0] + p[1]))); W = -PI* (sin(p[0]) + sin(p[1])); - + sum_I_integrals = 0.0; for (int i1 = 0; i1 < 3; ++i1) for (int i2 = i1+1; i2 < 4; ++i2) { //cout << "rho_ij = " << rho[i1] - rho[i2] << "\tI(rho_ij) = " << Itable.Return_val (rho[i1] - rho[i2]) << "\t" << I_integral (rho[i1] - rho[i2], req_prec) << endl; @@ -460,106 +464,106 @@ namespace JSC { sum_I_integrals += Itable.Return_val (rho[i1] - rho[i2]); } //cout << "sum_I_integrals = " << sum_I_integrals << "\texp(-sum) = " << exp(-sum_I_integrals) << endl; - + //sum_norm_g = 0.0; //for (int i = 0; i < 4; ++i) sum_norm_g += norm(g(i, rho)); sum_norm_g = Sum_norm_gl (rho, req_prec); - + //cout << "sum_norm_g = " << sum_norm_g << "\t sqrt() = " << sqrt(Wu * Wu - W * W) << endl; - + return(exp(-sum_I_integrals) * sum_norm_g/sqrt(Wu * Wu - W * W)); } - + DP J_fn (Vect_DP p, DP req_prec, I_table Itable) { Vect_DP rho(4); DP sum_I_integrals, sum_norm_g; - + for (int i = 0; i < 4; ++i) rho[i] = asinh(1.0/tan(p[i]))/twoPI; - + sum_I_integrals = 0.0; for (int i1 = 0; i1 < 3; ++i1) for (int i2 = i1+1; i2 < 4; ++i2) { if (fabs(rho[i1] - rho[i2]) < 1.0e-10 || fabs(rho[i1] - rho[i2]) >= 1000.0) return(0.0); // safety here sum_I_integrals += Itable.Return_val (rho[i1] - rho[i2]); } - + sum_norm_g = Sum_norm_gl (rho, req_prec); - + return(exp(-sum_I_integrals) * sum_norm_g); } - + bool Set_p_given_kwKW (DP k, DP w, DP K, DP W, Vect_DP& p) { // Returns false if any of the p_i are out of -PI, 0 - + DP argacos1, argacos2; - + if (fabs(argacos1 = W/(twoPI * sin(0.5*K))) > 1.0 || fabs(argacos2 = (w - W)/(twoPI * sin (0.5 * fabs(k - K)))) > 1.0) return(false); - + DP acos1 = acos(argacos1); DP acos2 = acos(argacos2); - + p[0] = -0.5 * K + acos1; p[1] = -0.5 * K - acos1; - + if (K <= k) { p[2] = 0.5 * (K-k) + acos2; p[3] = 0.5 * (K-k) - acos2; } - + else { p[2] = 0.5 * (K-k) - PI + acos2; p[3] = 0.5 * (K-k) - PI - acos2; } - - for (int i = 0; i < 4; ++i) if (p[i] < -PI || p[i] > 0.0) return(false); // { cout << k << "\t" << w << "\t" << K << "\t" << W << "\t" << p; JSCerror("p out of bounds"); } - + + for (int i = 0; i < 4; ++i) if (p[i] < -PI || p[i] > 0.0) return(false); // { cout << k << "\t" << w << "\t" << K << "\t" << W << "\t" << p; ABACUSerror("p out of bounds"); } + return(true); } - - DP G_fn (Vect_DP args_to_G, I_table Itable) + + DP G_fn (Vect_DP args_to_G, I_table Itable) { Vect_DP p(4); - + if (!Set_p_given_kwKW (args_to_G[0], args_to_G[1], args_to_G[2], args_to_G[3], p)) return(0.0); - + DP answer = Jacobian_p3p4_KW (args_to_G[0], args_to_G[1], args_to_G[2], args_to_G[3]) * SF_contrib (p, args_to_G[4], Itable); - + // cout << "kwKW = " << args_to_G[0] << " " << args_to_G[1] << " " << args_to_G[2] << " " << args_to_G[3] << "\tp = " << p << "Jac = " << Jacobian_p3p4_KW (args_to_G[0], args_to_G[1], args_to_G[2], args_to_G[3]) << "\tG = " << answer << endl; - + //return(Jacobian_p3p4_KW (args_to_G[0], args_to_G[1], args_to_G[2], args_to_G[3]) * SF_contrib (p, 0.01 * args_to_G[4], Itable)); return(answer); } - + DP G1_fn (Vect_DP args_to_G, I_table Itable) { Vect_DP p(4); - + DP W = twoPI * sin(0.5*args_to_G[2]) * cos(args_to_G[3]); - + if (!Set_p_given_kwKW (args_to_G[0], args_to_G[1], args_to_G[2], W, p)) return(0.0); - + return(J_fn (p, args_to_G[4], Itable)/sqrt(pow(twoPI * sin(0.5*(args_to_G[0] - args_to_G[2])), 2.0) - pow(args_to_G[1] - W, 2.0))); } - + DP G2_fn (Vect_DP args_to_G, I_table Itable) { Vect_DP p(4); - + DP W = args_to_G[1] - twoPI * fabs(sin(0.5*(args_to_G[0] - args_to_G[2]))) * cos(args_to_G[3]); - + if (!Set_p_given_kwKW (args_to_G[0], args_to_G[1], args_to_G[2], W, p)) return(0.0); - + return(J_fn (p, args_to_G[4], Itable)/sqrt(pow(twoPI * sin(0.5*args_to_G[2]), 2.0) - W * W)); } - + DP G1_fn_mid (Vect_DP args_to_G, I_table Itable) { // Called by H_fn_mid. - + // For the lower half of W interval - + // Translation of arguments to G: // args_to_G[0] = k; // args_to_G[1] = w; @@ -571,175 +575,175 @@ namespace JSC { // args_to_G[7] = Wmax_used; // args_to_G[8] = Wu_sq; // args_to_G[9] = Wut_sq; - + Vect_DP p(4); - - DP W = args_to_G[6] * (args_to_G[3] > 1.0e-4 ? 1.0 - cos(args_to_G[3]) : 2.0 * pow(sin(0.5 * args_to_G[3]), 2)); - // W = Wmid (1 - cos(alpha)), ensure some precision if alpha small - + + DP W = args_to_G[6] * (args_to_G[3] > 1.0e-4 ? 1.0 - cos(args_to_G[3]) : 2.0 * pow(sin(0.5 * args_to_G[3]), 2)); + // W = Wmid (1 - cos(alpha)), ensure some precision if alpha small + if (!Set_p_given_kwKW (args_to_G[0], args_to_G[1], args_to_G[2], W, p)) return(0.0); - + DP answer = J_fn (p, args_to_G[4], Itable) * sqrt(W * (2.0 * args_to_G[6] - W) /((args_to_G[8] - W * W) * (args_to_G[9] - pow(args_to_G[1] - W, 2.0)))); - + if (is_nan(answer)) { cerr << setprecision(10) << "args_to_G1_fn_mid = " << args_to_G << "G1 = " << answer << "\tPut to zero..." << endl; - //JSCerror("non !"); + //ABACUSerror("non !"); answer = 0.0; } return(answer); } - + DP G2_fn_mid (Vect_DP args_to_G, I_table Itable) { // Called by H_fn_mid. - + // For the upper half of W interval - + // See above for translation of arguments to G. - + Vect_DP p(4); - + DP W = args_to_G[7] * cos(args_to_G[3]); // W = Wmax cos(alpha) - + if (!Set_p_given_kwKW (args_to_G[0], args_to_G[1], args_to_G[2], W, p)) return(0.0); - - DP answer = J_fn (p, args_to_G[4], Itable) + + DP answer = J_fn (p, args_to_G[4], Itable) //* sqrt((args_to_G[7] * args_to_G[7] - W * W)/((args_to_G[8] - W * W) * (args_to_G[9] - pow(args_to_G[1] - W, 2.0)))); * args_to_G[7] * sin(args_to_G[3]) /sqrt((args_to_G[8] - W * W) * (args_to_G[9] - pow(args_to_G[1] - W, 2.0))); - + if (is_nan(answer)) { cerr << setprecision(10) << "args_to_G2_fn_mid = " << args_to_G << "G2 = " << answer << endl; cerr << W << "\t" << (args_to_G[7] * args_to_G[7] - W * W) << "\t" << (args_to_G[8] - W * W) << "\t" << (args_to_G[9] - pow(args_to_G[1] - W, 2.0)) << endl; - //JSCerror("non !"); + //ABACUSerror("non !"); answer = 0.0; } return(answer); } - - + + DP G_fn_alt (Vect_DP args_to_G, I_table Itable) { Vect_DP p(4); - + DP Wmin = args_to_G[4]; DP W = Wmin * cosh(args_to_G[3]); - + if (!Set_p_given_kwKW (args_to_G[0], args_to_G[1], args_to_G[2], W, p)) return(0.0); - + DP Wu1 = args_to_G[6]; DP Wu2 = args_to_G[7]; - + return(J_fn (p, args_to_G[8], Itable) * sqrt((W * W - Wmin * Wmin)/((Wu1 * Wu1 - W * W) * (Wu2 * Wu2 - (args_to_G[1] - W) * (args_to_G[1] - W))))); } - - DP H_fn (Vect_DP args_to_H, I_table Itable) + + DP H_fn (Vect_DP args_to_H, I_table Itable) { // Translate arguments to more readable form DP k = args_to_H[0]; DP w = args_to_H[1]; DP K = args_to_H[2]; - DP req_prec = JSC::max(1.0e-14, args_to_H[3]); + DP req_prec = ABACUS::max(1.0e-14, args_to_H[3]); int max_rec = int(args_to_H[4]); - + Vect_DP args_to_G(6); args_to_G[0] = k; args_to_G[1] = w; args_to_G[2] = K; args_to_G[3] = 0.0; - args_to_G[4] = JSC::max(1.0e-14, 0.01 * req_prec); + args_to_G[4] = ABACUS::max(1.0e-14, 0.01 * req_prec); args_to_G[5] = DP(max_rec); - + DP Wmin_used = Wmin (k, w, K); DP Wmax_used = Wmax (k, w, K); - - return(Wmax_used > Wmin_used ? Integrate_rec_using_table (G_fn, args_to_G, 3, Itable, Wmin_used, Wmax_used, req_prec, max_rec) : 0.0); - //return(Riemann_Integrate_rec_using_table (G_fn, args_to_G, 3, Itable, 0.0, 10.0, 500)); + + return(Wmax_used > Wmin_used ? Integrate_rec_using_table (G_fn, args_to_G, 3, Itable, Wmin_used, Wmax_used, req_prec, max_rec) : 0.0); + //return(Riemann_Integrate_rec_using_table (G_fn, args_to_G, 3, Itable, 0.0, 10.0, 500)); } - + DP H2_fn (Vect_DP args_to_H, I_table Itable) { // Translate arguments to more readable form DP k = args_to_H[0]; DP w = args_to_H[1]; DP K = args_to_H[2]; - DP req_prec = JSC::max(1.0e-14, args_to_H[3]); + DP req_prec = ABACUS::max(1.0e-14, args_to_H[3]); int max_rec = int(args_to_H[4]); - + DP Wmin_used = Wmin (k, w, K); DP Wmax_used = Wmax (k, w, K); - + if (Wmax_used <= Wmin_used) return(0.0); - + Vect_DP args_to_G(6); args_to_G[0] = k; args_to_G[1] = w; args_to_G[2] = K; args_to_G[3] = 0.0; // this will be the alpha parameter - args_to_G[4] = JSC::max(1.0e-14, 0.01 * req_prec); + args_to_G[4] = ABACUS::max(1.0e-14, 0.01 * req_prec); args_to_G[5] = DP(max_rec); - + DP Wmid = 0.5 * (Wmin_used + Wmax_used); - + DP answer = 0.0; - - DP alpha_L1 = acos(JSC::min(1.0, Wmax_used/(twoPI * sin(0.5*K)))); // to prevent nan + + DP alpha_L1 = acos(ABACUS::min(1.0, Wmax_used/(twoPI * sin(0.5*K)))); // to prevent nan DP alpha_U1 = acos(Wmid/(twoPI * sin(0.5*K))); - DP alpha_L2 = acos(JSC::min(1.0, (w - Wmin_used)/(twoPI * fabs(sin(0.5*(k - K)))))); + DP alpha_L2 = acos(ABACUS::min(1.0, (w - Wmin_used)/(twoPI * fabs(sin(0.5*(k - K)))))); DP alpha_U2 = acos((w - Wmid)/(twoPI * fabs(sin(0.5*(k - K))))); - + answer += Integrate_rec_using_table (G1_fn, args_to_G, 3, Itable, alpha_L1, alpha_U1, req_prec, max_rec); answer += Integrate_rec_using_table (G2_fn, args_to_G, 3, Itable, alpha_L2, alpha_U2, req_prec, max_rec); - + return(answer); } - + DP H_fn_mid (Vect_DP args_to_H, I_table Itable) { // For W in [Wmin, Wmid] we use the parametrization W = Wmid sin(alpha), alpha in [0, PI/2] // such that dW = Wmid cos(alpha) dalpha is approx. 0 around alpha = PI/2 (W = 0). // For W in [Wmid, Wmax] we use W = Wmax cos(alpha), alpha in [0, acos(Wmid/Wmax)] // such that dW = -Wmax sin(alpha) dalpha is approx 0 around alpha = 0 (W = Wmax). - + // Translation of args_to_H: // args_to_H[0] = k; // args_to_H[1] = w; // args_to_H[2] = K; <------ integrated over, so newly set here // args_to_H[3] = req_prec; // args_to_H[4] = max_rec; - + DP Wmin_used = Wmin (args_to_H[0], args_to_H[1], args_to_H[2]); DP Wmax_used = Wmax (args_to_H[0], args_to_H[1], args_to_H[2]); - + DP Wu_sq = pow(twoPI * sin(0.5 * args_to_H[2]), 2.0); DP Wut_sq = pow(twoPI * sin(0.5 * (args_to_H[0] - args_to_H[2])), 2.0); - + if (Wmax_used <= Wmin_used) return(0.0); - + DP Wmid = 0.5 * (Wmin_used + Wmax_used); - + Vect_DP args_to_G(10); args_to_G[0] = args_to_H[0]; args_to_G[1] = args_to_H[1]; args_to_G[2] = args_to_H[2]; args_to_G[3] = 0.0; // this will be the alpha parameter - args_to_G[4] = JSC::max(1.0e-14, 0.01 * args_to_H[3]); + args_to_G[4] = ABACUS::max(1.0e-14, 0.01 * args_to_H[3]); args_to_G[5] = args_to_H[4]; args_to_G[6] = Wmid; args_to_G[7] = Wmax_used; args_to_G[8] = Wu_sq; args_to_G[9] = Wut_sq; - + DP answer = 0.0; - + DP alpha_L1 = 0.0; DP alpha_U1 = 0.5 * PI; DP alpha_L2 = 0.0; DP alpha_U2 = acos(Wmid/Wmax_used); - + answer += Integrate_rec_using_table (G1_fn_mid, args_to_G, 3, Itable, alpha_L1, alpha_U1, args_to_H[3], int(args_to_H[4])); answer += Integrate_rec_using_table (G2_fn_mid, args_to_G, 3, Itable, alpha_L2, alpha_U2, args_to_H[3], int(args_to_H[4])); - + return(answer); } @@ -749,63 +753,63 @@ namespace JSC { // such that dW = Wmid cos(alpha) dalpha is approx. 0 around alpha = PI/2 (W = 0). // For W in [Wmid, Wmax] we use W = Wmax cos(alpha), alpha in [0, acos(Wmid/Wmax)] // such that dW = -Wmax sin(alpha) dalpha is approx 0 around alpha = 0 (W = Wmax). - + // Translation of args_to_H: // args_to_H[0] = k; // args_to_H[1] = w; // args_to_H[2] = K; <------ integrated over, so newly set here // args_to_H[3] = req_prec; // args_to_H[4] = Npts; - + DP Wmin_used = Wmin (args_to_H[0], args_to_H[1], args_to_H[2]); DP Wmax_used = Wmax (args_to_H[0], args_to_H[1], args_to_H[2]); - + DP Wu_sq = pow(twoPI * sin(0.5 * args_to_H[2]), 2.0); DP Wut_sq = pow(twoPI * sin(0.5 * (args_to_H[0] - args_to_H[2])), 2.0); - + if (Wmax_used <= Wmin_used) return(0.0); - + DP Wmid = 0.5 * (Wmin_used + Wmax_used); - + Vect_DP args_to_G(10); args_to_G[0] = args_to_H[0]; args_to_G[1] = args_to_H[1]; args_to_G[2] = args_to_H[2]; args_to_G[3] = 0.0; // this will be the alpha parameter - args_to_G[4] = JSC::max(1.0e-14, 0.01 * args_to_H[3]); + args_to_G[4] = ABACUS::max(1.0e-14, 0.01 * args_to_H[3]); args_to_G[5] = args_to_H[4]; args_to_G[6] = Wmid; args_to_G[7] = Wmax_used; args_to_G[8] = Wu_sq; args_to_G[9] = Wut_sq; - + DP answer = 0.0; - + DP alpha_L1 = 0.0; DP alpha_U1 = 0.5 * PI; DP alpha_L2 = 0.0; DP alpha_U2 = acos(Wmid/Wmax_used); - + answer += (Integrate_optimal_using_table (G1_fn_mid, args_to_G, 3, Itable, alpha_L1, alpha_U1, args_to_H[3], 1.0e-32, int(args_to_H[4]))).integ_est; answer += (Integrate_optimal_using_table (G2_fn_mid, args_to_G, 3, Itable, alpha_L2, alpha_U2, args_to_H[3], 1.0e-32, int(args_to_H[4]))).integ_est; - + return(answer); } - - DP H_fn_alt (Vect_DP args_to_H, I_table Itable) + + DP H_fn_alt (Vect_DP args_to_H, I_table Itable) { // Translate arguments to more readable form DP k = args_to_H[0]; DP w = args_to_H[1]; DP K = args_to_H[2]; - DP req_prec = JSC::max(1.0e-14, args_to_H[3]); + DP req_prec = ABACUS::max(1.0e-14, args_to_H[3]); int max_rec = int(args_to_H[4]); - + DP Wmin_used = Wmin (k, w, K); DP Wmax_used = Wmax (k, w, K); - + if (Wmax_used <= Wmin_used) return(0.0); - + Vect_DP args_to_G(10); args_to_G[0] = k; args_to_G[1] = w; @@ -815,13 +819,13 @@ namespace JSC { args_to_G[5] = Wmax_used; args_to_G[6] = twoPI * fabs(sin(0.5*args_to_G[2])); // Wu1 args_to_G[7] = twoPI * fabs(sin(0.5*(args_to_G[0] - args_to_G[2]))); // Wu2 - args_to_G[8] = JSC::max(1.0e-14, 0.01 * req_prec); + args_to_G[8] = ABACUS::max(1.0e-14, 0.01 * req_prec); args_to_G[9] = DP(max_rec); - - return(Integrate_rec_using_table (G_fn_alt, args_to_G, 3, Itable, 0.0, acosh(Wmax_used/Wmin_used), req_prec, max_rec)); - //return(Riemann_Integrate_rec_using_table (G_fn, args_to_G, 3, Itable, 0.0, 10.0, 500)); + + return(Integrate_rec_using_table (G_fn_alt, args_to_G, 3, Itable, 0.0, acosh(Wmax_used/Wmin_used), req_prec, max_rec)); + //return(Riemann_Integrate_rec_using_table (G_fn, args_to_G, 3, Itable, 0.0, 10.0, 500)); } - + //DP SF_4p_kwKW (DP k, DP omega, DP req_prec, int max_rec, I_table Itable) DP SF_4p_kwKW (Vect_DP args, I_table Itable) { @@ -834,46 +838,46 @@ namespace JSC { DP omega = args[1]; DP req_prec = args[2]; int max_rec = int(args[3]); - + Vect_DP args_to_H(5); - args_to_H[0] = k; // shift of PI in Bougourzi: because they do FM case. + args_to_H[0] = k; // shift of PI in Bougourzi: because they do FM case. // We want AFM, so SF_4p (k, omega) is correctly obtained directly from the RHS of their formula. DP w = 2.0 * omega; // Rescale energies by factor 2 because of definitions of H_XXX (omega: S.S; w: 0.5 * sigma.sigma = 2 S.S) - args_to_H[1] = w; + args_to_H[1] = w; args_to_H[2] = 0.0; // this is K - args_to_H[3] = JSC::max(1.0e-14, 0.01 * req_prec); + args_to_H[3] = ABACUS::max(1.0e-14, 0.01 * req_prec); args_to_H[4] = DP(max_rec); - + if (w > wmax_4p(k) || w < wmin_4p(k)) { - //cout << "w out of bounds in SF_4p: " << "wmin = " << PI * sin(k) << " wmax = " << 4.0 * PI * sin(0.25 * k) << " w = " << w << endl; + //cout << "w out of bounds in SF_4p: " << "wmin = " << PI * sin(k) << " wmax = " << 4.0 * PI * sin(0.25 * k) << " w = " << w << endl; return(0.0); } - + DP prefactor = 2.0 * 0.5 * 4.0 * Compute_C4 (req_prec); // 4 comes from using p1 > p2 & p3 > p4 instead of whole interval. // 2 from Jacobian |dw/domega| // 0.5 from S^{zz} = S^{pm}/2 //DP prefactor = 4.0; - + // Define the K integral domain Domain Kdomain; - + // First, the inclusions: if (w <= twoPI * sin(0.5*k)) Kdomain.Include (0.0, twoPI); - + else { if (w < 4.0*PI * sin(0.25 * k)) { DP K1bm = 0.5 * k - 2.0 * acos (w/(4.0*PI * sin(0.25 * k))); DP K1bp = 0.5 * k + 2.0 * acos (w/(4.0*PI * sin(0.25 * k))); - Kdomain.Include (K1bm, K1bp); + Kdomain.Include (K1bm, K1bp); } - + if (w < 4.0*PI * cos(0.25 * k)) { DP K1am = 0.5 * k + PI - 2.0 * acos (w/(4.0*PI * cos(0.25 * k))); DP K1ap = 0.5 * k + PI + 2.0 * acos (w/(4.0*PI * cos(0.25 * k))); Kdomain.Include (K1am, K1ap); } } - + // Now the exclusions: if (w < twoPI * sin(0.5*k)) { DP K2dm = 0.5 * k - acos (w/(twoPI * sin (0.5 * k))); @@ -883,7 +887,7 @@ namespace JSC { DP K3cp = K2dp + PI; Kdomain.Exclude (K3cm, K3cp); } - + if (w < twoPI * cos(0.5*k)) { DP K2cm = 0.5 * k + asin(w/(twoPI * cos(0.5*k))); DP K2cp = 0.5 * k + PI - asin(w/(twoPI * cos(0.5*k))); @@ -892,30 +896,30 @@ namespace JSC { DP K3ep = K2cp + PI; Kdomain.Exclude (K3em, K3ep); } - + //cout << "Kdomain: " << endl << Kdomain << endl; - + // Use (K,W) -> (k-K, w-W) symmetry to restrict to K in [k/2, k/2+PI] Kdomain.Exclude (0.0, 0.5 * k); Kdomain.Exclude (0.5 * k + PI, twoPI); //Kdomain.Exclude (0.5 * k, 0.5 * k + PI); prefactor *= 2.0; - + //cout << "Kdomain restricted: " << endl << Kdomain << endl; - + DP answer = 0.0; - + for (int idom = 0; idom < Kdomain.Ndomains(); ++idom) //answer += Integrate_rec_using_table (H_fn, args_to_H, 2, Itable, Kdomain.xmin(idom), Kdomain.xmax(idom), req_prec, max_rec); //answer += Integrate_rec_using_table (H2_fn, args_to_H, 2, Itable, Kdomain.xmin(idom), Kdomain.xmax(idom), req_prec, max_rec); //answer += Integrate_rec_using_table (H_fn_alt, args_to_H, 2, Itable, Kdomain.xmin(idom), Kdomain.xmax(idom), req_prec, max_rec); answer += Integrate_rec_using_table (H_fn_mid, args_to_H, 2, Itable, Kdomain.xmin(idom), Kdomain.xmax(idom), req_prec, max_rec); - + //return(prefactor * Integrate_rec_using_table (H_fn, args_to_H, 2, Itable, 0.0, twoPI, req_prec, max_rec)); //return(prefactor * Riemann_Integrate_rec_using_table (H_fn, args_to_H, 2, Itable, 0.0, twoPI, 500)); return (prefactor * answer); } - + DP SF_4p_kwKW_opt (Vect_DP args, I_table Itable) { // Translate: @@ -930,46 +934,46 @@ namespace JSC { DP req_prec = args[2]; int Npts_K = int(args[3]); int Npts_W = int(args[4]); - + Vect_DP args_to_H(5); - args_to_H[0] = k; // shift of PI in Bougourzi: because they do FM case. + args_to_H[0] = k; // shift of PI in Bougourzi: because they do FM case. // We want AFM, so SF_4p (k, omega) is correctly obtained directly from the RHS of their formula. DP w = 2.0 * omega; // Rescale energies by factor 2 because of definitions of H_XXX (omega: S.S; w: 0.5 * sigma.sigma = 2 S.S) - args_to_H[1] = w; + args_to_H[1] = w; args_to_H[2] = 0.0; // this is K - args_to_H[3] = JSC::max(1.0e-14, 0.01 * req_prec); + args_to_H[3] = ABACUS::max(1.0e-14, 0.01 * req_prec); args_to_H[4] = DP(Npts_W); - + if (w > wmax_4p(k) || w < wmin_4p(k)) { - //cout << "w out of bounds in SF_4p: " << "wmin = " << PI * sin(k) << " wmax = " << 4.0 * PI * sin(0.25 * k) << " w = " << w << endl; + //cout << "w out of bounds in SF_4p: " << "wmin = " << PI * sin(k) << " wmax = " << 4.0 * PI * sin(0.25 * k) << " w = " << w << endl; return(0.0); } - + DP prefactor = 2.0 * 0.5 * 4.0 * Compute_C4 (req_prec); // 4 comes from using p1 > p2 & p3 > p4 instead of whole interval. // 2 from Jacobian |dw/domega| // 0.5 from S^{zz} = S^{pm}/2 //DP prefactor = 4.0; - + // Define the K integral domain Domain Kdomain; - + // First, the inclusions: if (w <= twoPI * sin(0.5*k)) Kdomain.Include (0.0, twoPI); - + else { if (w < 4.0*PI * sin(0.25 * k)) { DP K1bm = 0.5 * k - 2.0 * acos (w/(4.0*PI * sin(0.25 * k))); DP K1bp = 0.5 * k + 2.0 * acos (w/(4.0*PI * sin(0.25 * k))); - Kdomain.Include (K1bm, K1bp); + Kdomain.Include (K1bm, K1bp); } - + if (w < 4.0*PI * cos(0.25 * k)) { DP K1am = 0.5 * k + PI - 2.0 * acos (w/(4.0*PI * cos(0.25 * k))); DP K1ap = 0.5 * k + PI + 2.0 * acos (w/(4.0*PI * cos(0.25 * k))); Kdomain.Include (K1am, K1ap); } } - + // Now the exclusions: if (w < twoPI * sin(0.5*k)) { DP K2dm = 0.5 * k - acos (w/(twoPI * sin (0.5 * k))); @@ -979,7 +983,7 @@ namespace JSC { DP K3cp = K2dp + PI; Kdomain.Exclude (K3cm, K3cp); } - + if (w < twoPI * cos(0.5*k)) { DP K2cm = 0.5 * k + asin(w/(twoPI * cos(0.5*k))); DP K2cp = 0.5 * k + PI - asin(w/(twoPI * cos(0.5*k))); @@ -988,19 +992,19 @@ namespace JSC { DP K3ep = K2cp + PI; Kdomain.Exclude (K3em, K3ep); } - + //cout << "Kdomain: " << endl << Kdomain << endl; - + // Use (K,W) -> (k-K, w-W) symmetry to restrict to K in [k, k+PI] Kdomain.Exclude (0.0, 0.5 * k); Kdomain.Exclude (0.5 * k + PI, twoPI); //Kdomain.Exclude (0.5 * k, 0.5 * k + PI); prefactor *= 2.0; - + //cout << "Kdomain restricted: " << endl << Kdomain << endl; - + DP answer = 0.0; - + for (int idom = 0; idom < Kdomain.Ndomains(); ++idom) //answer += Integrate_rec_using_table (H_fn, args_to_H, 2, Itable, Kdomain.xmin(idom), Kdomain.xmax(idom), req_prec, max_rec); //answer += Integrate_rec_using_table (H2_fn, args_to_H, 2, Itable, Kdomain.xmin(idom), Kdomain.xmax(idom), req_prec, max_rec); @@ -1008,85 +1012,85 @@ namespace JSC { //answer += Integrate_rec_using_table (H_fn_mid, args_to_H, 2, Itable, Kdomain.xmin(idom), Kdomain.xmax(idom), req_prec, max_rec); //answer += Integrate_rec_using_table (H_fn_mid, args_to_H, 2, Itable, Kdomain.xmin(idom), Kdomain.xmax(idom), req_prec, 1); answer += (Integrate_optimal_using_table (H_fn_mid_opt, args_to_H, 2, Itable, Kdomain.xmin(idom), Kdomain.xmax(idom), req_prec, 1.0e-32, Npts_K)).integ_est; - + //return(prefactor * Integrate_rec_using_table (H_fn, args_to_H, 2, Itable, 0.0, twoPI, req_prec, max_rec)); //return(prefactor * Riemann_Integrate_rec_using_table (H_fn, args_to_H, 2, Itable, 0.0, twoPI, 500)); return (prefactor * answer); } - + DP SF_4p_kwKW_alpha (Vect_DP args, I_table Itable) { // Better version for fixed k sum rule - + // Translate: // args[0] = k; // args[1] = alpha; <-- integration variable, omega = omegamin + (omegamax - omegamin) (1-cos(alpha)) // args[2] = req_prec; // args[3] = max_rec; - + Vect_DP args_to_SF_4p_kwKW = args; DP omegamin = 0.5 * wmin_4p (args[0]); DP omegamax = 0.5 * wmax_4p (args[0]); - + args_to_SF_4p_kwKW[1] = omegamin + (omegamax - omegamin) * (1.0 - cos(args[1])); - + return((omegamax - omegamin) * sin(args[1]) * SF_4p_kwKW (args_to_SF_4p_kwKW, Itable)); } DP SF_4p_kwKW_alpha_opt (Vect_DP args, I_table Itable) { // Better version for fixed k sum rule - + // Translate: // args[0] = k; // args[1] = alpha; <-- integration variable, omega = omegamin + (omegamax - omegamin) (1-cos(alpha)) // args[2] = req_prec; // args[3] = Npts_K; // args[4] = Npts_W; - + Vect_DP args_to_SF_4p_kwKW = args; DP omegamin = 0.5 * wmin_4p (args[0]); DP omegamax = 0.5 * wmax_4p (args[0]); - + args_to_SF_4p_kwKW[1] = omegamin + (omegamax - omegamin) * (1.0 - cos(args[1])); - + return((omegamax - omegamin) * sin(args[1]) * SF_4p_kwKW_opt (args_to_SF_4p_kwKW, Itable)); } DP SF_4p_kwKW_cosh_alpha_opt (Vect_DP args, I_table Itable) { // Better version for fixed k sum rule - + // Translate: // args[0] = k; // args[1] = alpha; <-- integration variable, omega = omegamin * cosh(alpha) // args[2] = req_prec; // args[3] = Npts_K; // args[4] = Npts_W; - + Vect_DP args_to_SF_4p_kwKW = args; DP omegamin = 0.5 * wmin_4p (args[0]); //DP omegamax = 0.5 * wmax_4p (args[0]); - + args_to_SF_4p_kwKW[1] = omegamin * cosh(args[1]); - + //return((omegamax - omegamin) * sin(args[1]) * SF_4p_kwKW_opt (args_to_SF_4p_kwKW, Itable)); return(omegamin * sinh(args[1]) * SF_4p_kwKW_opt (args_to_SF_4p_kwKW, Itable)); } - + /******************************************************************************************/ - + // Interface to used version: DP SF_4p_rec (DP k, DP omega, DP req_prec, int max_rec, I_table Itable) { // CAREFUL !! This is S(k, omega) = 2 S(k, w) - + Vect_DP args_to_SF(4); args_to_SF[0] = k; args_to_SF[1] = omega; args_to_SF[2] = req_prec; args_to_SF[3] = DP(max_rec); - + return(2.0 * SF_4p_kwKW (args_to_SF, Itable)); } @@ -1100,93 +1104,93 @@ namespace JSC { DP SF_4p_opt (DP k, DP omega, DP req_prec, int Npts_K, int Npts_W, I_table Itable) { // CAREFUL !! This is S(k, omega) = 2 S(k, w) - + Vect_DP args_to_SF(5); args_to_SF[0] = k; args_to_SF[1] = omega; args_to_SF[2] = req_prec; args_to_SF[3] = DP(Npts_K); args_to_SF[4] = DP(Npts_W); - + return(2.0 * SF_4p_kwKW_opt (args_to_SF, Itable)); } - + /******************************************************************************************/ void Translate_raw_4p_data (DP k, int dim_w, const char* SFraw_Cstr, const char* SF_Cstr, const char* SFsrc_Cstr, I_table Itable) { DP omegamin = 0.5 * wmin_4p (k); // Correct for factor of 2 in E between me & Bougourzi DP omegamax = 0.5 * wmax_4p (k); - + DP alpha_in; DP SF_in; DP alpha_in_old = -1.0; DP SF_in_old = -1.0; - + //int dim_w = int(pow(3.0, max_rec_w + 2)); DP* alpha = new DP[dim_w]; DP* omega = new DP[dim_w]; DP* SF_4p_dat = new DP[dim_w]; DP* SF_2p_dat = new DP[dim_w]; int* index = new int[dim_w]; - + ifstream SFraw; SFraw.open(SFraw_Cstr); - if (SFraw.fail()) JSCerror("Couldn't open SFraw file in Translate."); - + if (SFraw.fail()) ABACUSerror("Couldn't open SFraw file in Translate."); + int i = 0; for (i = 0; i < dim_w; ++i) { - - if (SFraw.peek() == EOF) JSCerror("Not enough data points in file..."); - + + if (SFraw.peek() == EOF) ABACUSerror("Not enough data points in file..."); + index[i] = i; - + SFraw >> alpha_in >> SF_in; - + alpha[i] = alpha_in; omega[i] = omegamin + (omegamax - omegamin) * (1.0 - cos(alpha_in)); - + // CAREFUL !!! SF_in is S (k, w), and we want S (k, omega) = 2 S(k, w) SF_4p_dat[i] = 2.0 * SF_in/((omegamax - omegamin) * sin(alpha_in)); - + SF_2p_dat[i] = SF_2p (k, omega[i], Itable); // This already is S(k, omega) - + alpha_in_old = alpha_in; SF_in_old = SF_in; } - + SFraw.close(); - + if (i != dim_w) { - JSCerror("Incorrect number of data points in file."); + ABACUSerror("Incorrect number of data points in file."); } - + QuickSort (omega, index, 0, dim_w - 1); - + //for (int j = 0; j < dim_w; ++j) cout << j << "\t" << omega[j] << "\t" << index[j] << endl; - + DP fixed_k_sr_2p = 0.0; DP fixed_k_sr_4p = 0.0; DP full_sr_2p = 0.0; DP full_sr_4p = 0.0; DP Jac_dalpha = 0.0; // This is domega = (omegamax - omegamin) sin alpha dalpha - + ofstream SF; SF.open(SF_Cstr); - + for (int j = 0; j < dim_w; ++j) - SF << setprecision(16) << omega[j] << "\t" << SF_4p_dat[index[j] ] << "\t" << SF_2p_dat[index[j] ] << "\t" + SF << setprecision(16) << omega[j] << "\t" << SF_4p_dat[index[j] ] << "\t" << SF_2p_dat[index[j] ] << "\t" << SF_4p_dat[index[j] ] + SF_2p_dat[index[j] ] << endl; - + SF.close(); - + // Compute first moment sum rule Jac_dalpha = (omegamax - omegamin) * sin(alpha[index[1] ]) * 0.5 * (alpha[index[2] ] - alpha[index[0] ]); fixed_k_sr_4p += Jac_dalpha * (omega[0] * SF_4p_dat[index[0] ] + omega[1] * SF_4p_dat[index[1] ]); fixed_k_sr_2p += Jac_dalpha * (omega[0] * SF_2p_dat[index[0] ] + omega[1] * SF_2p_dat[index[1] ]); full_sr_4p += Jac_dalpha * (SF_4p_dat[index[0] ] + SF_4p_dat[index[1] ]); full_sr_2p += Jac_dalpha * (SF_2p_dat[index[0] ] + SF_2p_dat[index[1] ]); - + for (int i = 2; i < dim_w - 2; ++i) { Jac_dalpha = (omegamax - omegamin) * sin(alpha[index[i] ]) * 0.5 * (alpha[index[i + 1] ] - alpha[index[i - 1] ]); fixed_k_sr_4p += Jac_dalpha * omega[i] * SF_4p_dat[index[i] ]; @@ -1194,39 +1198,39 @@ namespace JSC { full_sr_4p += Jac_dalpha * SF_4p_dat[index[i] ]; full_sr_2p += Jac_dalpha * SF_2p_dat[index[i] ]; } - + Jac_dalpha = (omegamax - omegamin) * sin(alpha[index[dim_w - 2] ]) * 0.5 * (alpha[index[dim_w - 1] ] - alpha[index[dim_w - 3] ]); fixed_k_sr_4p += Jac_dalpha * (omega[dim_w - 2] * SF_4p_dat[index[dim_w - 2] ] + omega[dim_w - 1] * SF_4p_dat[index[dim_w - 1] ]); fixed_k_sr_2p += Jac_dalpha * (omega[dim_w - 2] * SF_2p_dat[index[dim_w - 2] ] + omega[dim_w - 1] * SF_2p_dat[index[dim_w - 1] ]); full_sr_4p += Jac_dalpha * (SF_4p_dat[index[dim_w - 2] ] + SF_4p_dat[index[dim_w - 1] ]); full_sr_2p += Jac_dalpha * (SF_2p_dat[index[dim_w - 2] ] + SF_2p_dat[index[dim_w - 1] ]); - + ofstream SFsrc; SFsrc.open(SFsrc_Cstr); - + // Reintroduce 1/PI since \int domega/2PI full_sr_4p /= twoPI; full_sr_2p /= twoPI; fixed_k_sr_4p /= twoPI; fixed_k_sr_2p /= twoPI; - - SFsrc << setprecision(16) << fixed_k_sr_4p << "\t" - << fixed_k_sr_2p << "\t" - << fixed_k_sr_4p + fixed_k_sr_2p << "\t" - << fixed_k_sr_4p/Fixed_k_sumrule_omega(k) << "\t" + + SFsrc << setprecision(16) << fixed_k_sr_4p << "\t" + << fixed_k_sr_2p << "\t" + << fixed_k_sr_4p + fixed_k_sr_2p << "\t" + << fixed_k_sr_4p/Fixed_k_sumrule_omega(k) << "\t" << fixed_k_sr_2p/Fixed_k_sumrule_omega(k) << "\t" << (fixed_k_sr_4p + fixed_k_sr_2p)/Fixed_k_sumrule_omega(k) << endl; - + SFsrc << setprecision(16) << full_sr_4p << "\t" << full_sr_2p << "\t" << full_sr_4p + full_sr_2p << "\t" << 0.25 * full_sr_4p << "\t" << 0.25 * full_sr_2p << "\t" << 0.25 * (full_sr_4p + full_sr_2p) << endl; - + SFsrc.close(); - + delete[] omega; delete[] SF_4p_dat; delete[] SF_2p_dat; delete[] index; - + return; } @@ -1236,72 +1240,72 @@ namespace JSC { DP omegamin = 0.5 * wmin_4p (k); // Correct for factor of 2 in E between me & Bougourzi //DP omegamax = 0.5 * wmax_4p (k); - + DP alpha_in; DP SF_in; DP alpha_in_old = -1.0; DP SF_in_old = -1.0; - + //int dim_w = int(pow(3.0, max_rec_w + 2)); DP* alpha = new DP[dim_w]; DP* omega = new DP[dim_w]; DP* SF_4p_dat = new DP[dim_w]; DP* SF_2p_dat = new DP[dim_w]; int* index = new int[dim_w]; - + ifstream SFraw; SFraw.open(SFraw_Cstr); - if (SFraw.fail()) JSCerror("Couldn't open SFraw file in Translate."); - + if (SFraw.fail()) ABACUSerror("Couldn't open SFraw file in Translate."); + int i = 0; for (i = 0; i < dim_w; ++i) { - - if (SFraw.peek() == EOF) JSCerror("Not enough data points in file..."); - + + if (SFraw.peek() == EOF) ABACUSerror("Not enough data points in file..."); + index[i] = i; - + SFraw >> alpha_in >> SF_in; - + alpha[i] = alpha_in; //omega[i] = omegamin + (omegamax - omegamin) * (1.0 - cos(alpha_in)); omega[i] = omegamin * cosh(alpha_in); - + // CAREFUL !!! SF_in is S (k, w), and we want S (k, omega) = 2 S(k, w) //SF_4p_dat[i] = 2.0 * SF_in/((omegamax - omegamin) * sin(alpha_in)); SF_4p_dat[i] = 2.0 * SF_in/(omegamin * sinh(alpha_in)); - + SF_2p_dat[i] = SF_2p (k, omega[i], Itable); // This already is S(k, omega) - + alpha_in_old = alpha_in; SF_in_old = SF_in; } - + SFraw.close(); - + if (i != dim_w) { - JSCerror("Incorrect number of data points in file."); + ABACUSerror("Incorrect number of data points in file."); } - + QuickSort (omega, index, 0, dim_w - 1); - + //for (int j = 0; j < dim_w; ++j) cout << j << "\t" << omega[j] << "\t" << index[j] << endl; - + DP fixed_k_sr_2p = 0.0; DP fixed_k_sr_4p = 0.0; DP full_sr_2p = 0.0; DP full_sr_4p = 0.0; //DP Jac_dalpha = 0.0; // This is domega = (omegamax - omegamin) sin alpha dalpha DP Jac_dalpha = 0.0; // This is domega = omegamin sinh alpha dalpha - + ofstream SF; SF.open(SF_Cstr); - + for (int j = 0; j < dim_w; ++j) - SF << setprecision(16) << omega[j] << "\t" << SF_4p_dat[index[j] ] << "\t" << SF_2p_dat[index[j] ] << "\t" + SF << setprecision(16) << omega[j] << "\t" << SF_4p_dat[index[j] ] << "\t" << SF_2p_dat[index[j] ] << "\t" << SF_4p_dat[index[j] ] + SF_2p_dat[index[j] ] << endl; - + SF.close(); - + // Compute first moment sum rule //Jac_dalpha = (omegamax - omegamin) * sin(alpha[index[1] ]) * 0.5 * (alpha[index[2] ] - alpha[index[0] ]); Jac_dalpha = omegamin * sinh(alpha[index[1] ]) * 0.5 * (alpha[index[2] ] - alpha[index[0] ]); @@ -1309,7 +1313,7 @@ namespace JSC { fixed_k_sr_2p += Jac_dalpha * (omega[0] * SF_2p_dat[index[0] ] + omega[1] * SF_2p_dat[index[1] ]); full_sr_4p += Jac_dalpha * (SF_4p_dat[index[0] ] + SF_4p_dat[index[1] ]); full_sr_2p += Jac_dalpha * (SF_2p_dat[index[0] ] + SF_2p_dat[index[1] ]); - + for (int i = 2; i < dim_w - 2; ++i) { //Jac_dalpha = (omegamax - omegamin) * sin(alpha[index[i] ]) * 0.5 * (alpha[index[i + 1] ] - alpha[index[i - 1] ]); Jac_dalpha = omegamin * sinh(alpha[index[i] ]) * 0.5 * (alpha[index[i + 1] ] - alpha[index[i - 1] ]); @@ -1318,44 +1322,44 @@ namespace JSC { full_sr_4p += Jac_dalpha * SF_4p_dat[index[i] ]; full_sr_2p += Jac_dalpha * SF_2p_dat[index[i] ]; } - + //Jac_dalpha = (omegamax - omegamin) * sin(alpha[index[dim_w - 2] ]) * 0.5 * (alpha[index[dim_w - 1] ] - alpha[index[dim_w - 3] ]); Jac_dalpha = omegamin * sinh(alpha[index[dim_w - 2] ]) * 0.5 * (alpha[index[dim_w - 1] ] - alpha[index[dim_w - 3] ]); fixed_k_sr_4p += Jac_dalpha * (omega[dim_w - 2] * SF_4p_dat[index[dim_w - 2] ] + omega[dim_w - 1] * SF_4p_dat[index[dim_w - 1] ]); fixed_k_sr_2p += Jac_dalpha * (omega[dim_w - 2] * SF_2p_dat[index[dim_w - 2] ] + omega[dim_w - 1] * SF_2p_dat[index[dim_w - 1] ]); full_sr_4p += Jac_dalpha * (SF_4p_dat[index[dim_w - 2] ] + SF_4p_dat[index[dim_w - 1] ]); full_sr_2p += Jac_dalpha * (SF_2p_dat[index[dim_w - 2] ] + SF_2p_dat[index[dim_w - 1] ]); - + ofstream SFsrc; SFsrc.open(SFsrc_Cstr); - + // Reintroduce 1/PI since \int domega/2PI full_sr_4p /= twoPI; full_sr_2p /= twoPI; fixed_k_sr_4p /= twoPI; fixed_k_sr_2p /= twoPI; - - SFsrc << setprecision(16) << fixed_k_sr_4p << "\t" - << fixed_k_sr_2p << "\t" - << fixed_k_sr_4p + fixed_k_sr_2p << "\t" - << fixed_k_sr_4p/Fixed_k_sumrule_omega(k) << "\t" + + SFsrc << setprecision(16) << fixed_k_sr_4p << "\t" + << fixed_k_sr_2p << "\t" + << fixed_k_sr_4p + fixed_k_sr_2p << "\t" + << fixed_k_sr_4p/Fixed_k_sumrule_omega(k) << "\t" << fixed_k_sr_2p/Fixed_k_sumrule_omega(k) << "\t" << (fixed_k_sr_4p + fixed_k_sr_2p)/Fixed_k_sumrule_omega(k) << endl; - + SFsrc << setprecision(16) << full_sr_4p << "\t" << full_sr_2p << "\t" << full_sr_4p + full_sr_2p << "\t" << 0.25 * full_sr_4p << "\t" << 0.25 * full_sr_2p << "\t" << 0.25 * (full_sr_4p + full_sr_2p) << endl; - + SFsrc.close(); - + delete[] omega; delete[] SF_4p_dat; delete[] SF_2p_dat; delete[] index; - + return; } - - + + // Function producing a fixed k scan, with data file DP SF_4p_rec (DP k, DP req_prec, int max_rec_w, int max_rec, I_table Itable) { @@ -1364,46 +1368,46 @@ namespace JSC { SFraw_stringstream << "SF_4p_k_" << k << "_prec_" << req_prec << "_max_rec_w_" << max_rec_w << "_max_rec_" << max_rec << ".raw"; SFraw_string = SFraw_stringstream.str(); const char* SFraw_Cstr = SFraw_string.c_str(); - + stringstream SF_stringstream; string SF_string; SF_stringstream << "SF_4p_k_" << k << "_prec_" << req_prec << "_max_rec_w_" << max_rec_w << "_max_rec_" << max_rec << ".dat"; SF_string = SF_stringstream.str(); const char* SF_Cstr = SF_string.c_str(); - + stringstream SFsrc_stringstream; string SFsrc_string; SFsrc_stringstream << "SF_4p_k_" << k << "_prec_" << req_prec << "_max_rec_w_" << max_rec_w << "_max_rec_" << max_rec << ".src"; SFsrc_string = SFsrc_stringstream.str(); const char* SFsrc_Cstr = SFsrc_string.c_str(); - + ofstream SFraw_outfile; SFraw_outfile.open(SFraw_Cstr); ofstream SFsrc_outfile; SFsrc_outfile.open(SFsrc_Cstr, ofstream::app); - + //DP omegamin_used = 0.5 * wmin_4p (k); // Correct for factor of 2 in E between me & Bougourzi //DP omegamax_used = 0.5 * wmax_4p (k); - + Vect_DP args_to_SF(4); args_to_SF[0] = k; args_to_SF[1] = 0.0; // integration variable args_to_SF[2] = req_prec; args_to_SF[3] = DP(max_rec); - + //DP answer = Integrate_rec_using_table (SF_4p_kwKW, args_to_SF, 1, Itable, omegamin_used, omegamax_used, req_prec, max_rec, SF_outfile); // Version using omega = omegamin + (omegamax - omegamin) * (1-cos(alpha)) DP answer = Integrate_rec_using_table (SF_4p_kwKW_alpha, args_to_SF, 1, Itable, 0.0, 0.5*PI, req_prec, max_rec_w, SFraw_outfile)/twoPI; - + SFraw_outfile.close(); - + SFsrc_outfile << answer << endl; SFsrc_outfile.close(); - + // Translate raw data into SF_4p (k,omega) data - + Translate_raw_4p_data (k, int(pow(3.0, max_rec_w + 2)), SFraw_Cstr, SF_Cstr, SFsrc_Cstr, Itable); - + return(answer); } @@ -1415,36 +1419,36 @@ namespace JSC { //SFraw_stringstream << "SF_4p_k_" << k << "_prec_" << req_prec << "_Npts_" << Npts_w << "_" << Npts_K << "_" << Npts_W << "_ch.raw"; SFraw_string = SFraw_stringstream.str(); const char* SFraw_Cstr = SFraw_string.c_str(); - + stringstream SF_stringstream; string SF_string; SF_stringstream << "SF_4p_k_" << k << "_prec_" << req_prec << "_Npts_" << Npts_w << "_" << Npts_K << "_" << Npts_W << ".dat"; //SF_stringstream << "SF_4p_k_" << k << "_prec_" << req_prec << "_Npts_" << Npts_w << "_" << Npts_K << "_" << Npts_W << "_ch.dat"; SF_string = SF_stringstream.str(); const char* SF_Cstr = SF_string.c_str(); - + stringstream SFsrc_stringstream; string SFsrc_string; SFsrc_stringstream << "SF_4p_k_" << k << "_prec_" << req_prec << "_Npts_" << Npts_w << "_" << Npts_K << "_" << Npts_W << ".src"; //SFsrc_stringstream << "SF_4p_k_" << k << "_prec_" << req_prec << "_Npts_" << Npts_w << "_" << Npts_K << "_" << Npts_W << "_ch.src"; SFsrc_string = SFsrc_stringstream.str(); const char* SFsrc_Cstr = SFsrc_string.c_str(); - + ofstream SFraw_outfile; SFraw_outfile.open(SFraw_Cstr); ofstream SFsrc_outfile; SFsrc_outfile.open(SFsrc_Cstr); - + //DP omegamin_used = 0.5 * wmin_4p (k); // Correct for factor of 2 in E between me & Bougourzi //DP omegamax_used = 0.5 * wmax_4p (k); - + Vect_DP args_to_SF(5); args_to_SF[0] = k; args_to_SF[1] = 0.0; // integration variable args_to_SF[2] = req_prec; args_to_SF[3] = DP(Npts_K); args_to_SF[4] = DP(Npts_W); - + // Version using omega = omegamin + (omegamax - omegamin) * (1-cos(alpha)) Integral_result answer = Integrate_optimal_using_table (SF_4p_kwKW_alpha_opt, args_to_SF, 1, Itable, 0.0, 0.5*PI, req_prec, 1.0e-32, Npts_w, SFraw_outfile); // Version using omega = omegamin * cosh(alpha) @@ -1453,15 +1457,15 @@ namespace JSC { answer.abs_prec /= twoPI; SFraw_outfile.close(); - + SFsrc_outfile << answer << endl; SFsrc_outfile.close(); - + // Translate raw data into SF_4p (k,omega) data - + Translate_raw_4p_data (k, answer.n_vals, SFraw_Cstr, SF_Cstr, SFsrc_Cstr, Itable); //Translate_raw_4p_data_cosh (k, answer.n_vals, SFraw_Cstr, SF_Cstr, SFsrc_Cstr, Itable); - + return(answer); } @@ -1474,49 +1478,49 @@ namespace JSC { { return(SF_4p_opt (k, req_prec, Npts, Npts, Npts, Itable)); } - + //******************************** Functions to produce files similar to ABACUS ********************************** - + void Produce_SF_2p_file (int N, int Nomega, DP omegamax, I_table Itable) { - // IMPORTANT NOTE: this produces a file with Szz !! - + // IMPORTANT NOTE: this produces a file with Szz !! + DP ABACUS_factor = 1.0; - - if (N % 2) JSCerror("Please use N even in Produce_SF_2p_file."); - + + if (N % 2) ABACUSerror("Please use N even in Produce_SF_2p_file."); + stringstream SF_stringstream; string SF_string; SF_stringstream << "SF_2p_N_" << N << "_Nw_" << Nomega << "_wmax_" << omegamax << ".dat"; SF_string = SF_stringstream.str(); const char* SF_Cstr = SF_string.c_str(); - + Write_K_File (N, 0, N); Write_Omega_File (Nomega, 0.0, omegamax); - + int dim_K = N/2 + 1; DP* K = new DP[dim_K]; for (int iK = 0; iK < dim_K; ++iK) K[iK] = (twoPI * iK)/N; - + DP* omega = new DP[Nomega]; for (int iw = 0; iw < Nomega; ++iw) omega[iw] = omegamax * (iw + 0.5)/Nomega; - + DP* SF_2p_dat = new DP[dim_K * Nomega]; - + DP srtot = 0.0; Vect_DP sr1(0.0, dim_K); - for (int iK = 0; iK < dim_K; ++iK) + for (int iK = 0; iK < dim_K; ++iK) for (int iw = 0; iw < Nomega; ++iw) { SF_2p_dat[dim_K * iw + iK] = ABACUS_factor * SF_2p (K[iK], omega[iw], Itable); srtot += (iK == N/2 ? 1.0 : 2.0) * SF_2p_dat[dim_K * iw + iK]; sr1[iK] += omega[iw] * SF_2p_dat[dim_K * iw + iK]; } - + ofstream SF_outfile; SF_outfile.open(SF_Cstr); SF_outfile.precision(14); - + for (int iw = 0; iw < Nomega; ++iw) { for (int iK = 0; iK < dim_K; ++iK) SF_outfile << SF_2p_dat[dim_K * iw + iK] << "\t"; @@ -1524,9 +1528,9 @@ namespace JSC { SF_outfile << SF_2p_dat[dim_K * iw + iKt] << "\t"; SF_outfile << endl; } - + SF_outfile.close(); - + // Do sum rule files: stringstream SRC_stringstream; @@ -1554,56 +1558,56 @@ namespace JSC { SR1_outfile.precision(14); for (int iK = 1; iK < dim_K; ++iK) - SR1_outfile << iK << "\t" << K[iK] << "\t" << sr1[iK] * omegamax/(twoPI * Nomega) - << "\t" << -((1.0 - cos(K[iK])) * 2.0 * (0.25 - log(2.0))/3.0) << "\t" + SR1_outfile << iK << "\t" << K[iK] << "\t" << sr1[iK] * omegamax/(twoPI * Nomega) + << "\t" << -((1.0 - cos(K[iK])) * 2.0 * (0.25 - log(2.0))/3.0) << "\t" << -sr1[iK] * omegamax/(twoPI * Nomega)/((1.0 - cos(K[iK])) * 2.0 * (0.25 - log(2.0))/3.0) << endl; SR1_outfile.close(); return; } - + void Produce_SF_4p_file (int N, int Nomega, DP omegamax, DP req_prec, int max_rec, I_table Itable) { // IMPORTANT NOTE: this produces a file with the same normalization as Smp from ABACUS, // so we use a factor of 2 (for Szz -> Smp) and 2PI. - + DP ABACUS_factor = 1.0; - - if (N % 2) JSCerror("Please use N even in Produce_SF_2p_file."); - + + if (N % 2) ABACUSerror("Please use N even in Produce_SF_2p_file."); + stringstream SF_stringstream; string SF_string; SF_stringstream << "SF_4p_N_" << N << "_Nw_" << Nomega << "_wmax_" << omegamax << "_prec_" << req_prec << "_max_rec_" << max_rec << ".dat"; SF_string = SF_stringstream.str(); const char* SF_Cstr = SF_string.c_str(); - + Write_K_File (N, 0, N); Write_Omega_File (Nomega, 0.0, omegamax); - + int dim_K = N/2 + 1; DP* K = new DP[dim_K]; for (int iK = 0; iK < dim_K; ++iK) K[iK] = (twoPI * iK)/N; - + DP* omega = new DP[Nomega]; for (int iw = 0; iw < Nomega; ++iw) omega[iw] = omegamax * (iw + 0.5)/Nomega; - + DP* SF_4p_dat = new DP[dim_K * Nomega]; - + DP srtot = 0.0; Vect_DP sr1(0.0, dim_K); - for (int iK = 0; iK < dim_K; ++iK) + for (int iK = 0; iK < dim_K; ++iK) for (int iw = 0; iw < Nomega; ++iw) { SF_4p_dat[dim_K * iw + iK] = ABACUS_factor * SF_4p_rec (K[iK], omega[iw], req_prec, max_rec, Itable); srtot += (iK == N/2 ? 1.0 : 2.0) * SF_4p_dat[dim_K * iw + iK]; sr1[iK] += omega[iw] * SF_4p_dat[dim_K * iw + iK]; } - + ofstream SF_outfile; SF_outfile.open(SF_Cstr); SF_outfile.precision(14); - + for (int iw = 0; iw < Nomega; ++iw) { for (int iK = 0; iK < dim_K; ++iK) SF_outfile << SF_4p_dat[dim_K * iw + iK] << "\t"; @@ -1611,14 +1615,14 @@ namespace JSC { SF_outfile << SF_4p_dat[dim_K * iw + iKt] << "\t"; SF_outfile << endl; } - + SF_outfile.close(); - + // Do sum rule files: stringstream SRC_stringstream; string SRC_string; - SRC_stringstream << "SF_4p_N_" << N << "_Nw_" << Nomega << "_wmax_" << omegamax << "_prec_" << req_prec + SRC_stringstream << "SF_4p_N_" << N << "_Nw_" << Nomega << "_wmax_" << omegamax << "_prec_" << req_prec << "_max_rec_" << max_rec << ".src"; SRC_string = SRC_stringstream.str(); const char* SRC_Cstr = SRC_string.c_str(); @@ -1633,7 +1637,7 @@ namespace JSC { stringstream SR1_stringstream; string SR1_string; - SR1_stringstream << "SF_4p_N_" << N << "_Nw_" << Nomega << "_wmax_" << omegamax << "_prec_" << req_prec + SR1_stringstream << "SF_4p_N_" << N << "_Nw_" << Nomega << "_wmax_" << omegamax << "_prec_" << req_prec << "_max_rec_" << max_rec << ".sr1"; SR1_string = SR1_stringstream.str(); const char* SR1_Cstr = SR1_string.c_str(); @@ -1643,58 +1647,58 @@ namespace JSC { SR1_outfile.precision(14); for (int iK = 1; iK < dim_K; ++iK) - SR1_outfile << iK << "\t" << K[iK] << "\t" << sr1[iK] * omegamax/(twoPI * Nomega) - << "\t" << -((1.0 - cos(K[iK])) * 2.0 * (0.25 - log(2.0))/3.0) << "\t" + SR1_outfile << iK << "\t" << K[iK] << "\t" << sr1[iK] * omegamax/(twoPI * Nomega) + << "\t" << -((1.0 - cos(K[iK])) * 2.0 * (0.25 - log(2.0))/3.0) << "\t" << -sr1[iK] * omegamax/(twoPI * Nomega)/((1.0 - cos(K[iK])) * 2.0 * (0.25 - log(2.0))/3.0) << endl; SR1_outfile.close(); return; } - + void Produce_SF_4p_file (int N, int Nomega, DP omegamax, DP req_prec, int Npts_K, int Npts_W, I_table Itable) { // IMPORTANT NOTE: this produces a file with the same normalization as Smp from ABACUS, // so we use a factor of 2 (for Szz -> Smp) and 2PI. - + DP ABACUS_factor = 1.0; - - if (N % 2) JSCerror("Please use N even in Produce_SF_2p_file."); - + + if (N % 2) ABACUSerror("Please use N even in Produce_SF_2p_file."); + stringstream SF_stringstream; string SF_string; - SF_stringstream << "SF_4p_N_" << N << "_Nw_" << Nomega << "_wmax_" << omegamax << "_prec_" << req_prec + SF_stringstream << "SF_4p_N_" << N << "_Nw_" << Nomega << "_wmax_" << omegamax << "_prec_" << req_prec << "_Npts_K_" << Npts_K << "_Npts_W_" << Npts_W << ".dat"; SF_string = SF_stringstream.str(); const char* SF_Cstr = SF_string.c_str(); - + Write_K_File (N, 0, N); Write_Omega_File (Nomega, 0.0, omegamax); - + int dim_K = N/2 + 1; DP* K = new DP[dim_K]; for (int iK = 0; iK < dim_K; ++iK) K[iK] = (twoPI * iK)/N; - + DP* omega = new DP[Nomega]; for (int iw = 0; iw < Nomega; ++iw) omega[iw] = omegamax * (iw + 0.5)/Nomega; - + DP* SF_4p_dat = new DP[dim_K * Nomega]; - + DP srtot = 0.0; Vect_DP sr1(0.0, dim_K); - for (int iK = 0; iK < dim_K; ++iK) + for (int iK = 0; iK < dim_K; ++iK) for (int iw = 0; iw < Nomega; ++iw) { SF_4p_dat[dim_K * iw + iK] = ABACUS_factor * SF_4p_opt (K[iK], omega[iw], req_prec, Npts_K, Npts_W, Itable); srtot += (iK == N/2 ? 1.0 : 2.0) * SF_4p_dat[dim_K * iw + iK]; sr1[iK] += omega[iw] * SF_4p_dat[dim_K * iw + iK]; } - // Output SF: + // Output SF: ofstream SF_outfile; SF_outfile.open(SF_Cstr); SF_outfile.precision(14); - + for (int iw = 0; iw < Nomega; ++iw) { for (int iK = 0; iK < dim_K; ++iK) SF_outfile << SF_4p_dat[dim_K * iw + iK] << "\t"; @@ -1702,14 +1706,14 @@ namespace JSC { SF_outfile << SF_4p_dat[dim_K * iw + iKt] << "\t"; SF_outfile << endl; } - + SF_outfile.close(); - + // Do sum rule files: stringstream SRC_stringstream; string SRC_string; - SRC_stringstream << "SF_4p_N_" << N << "_Nw_" << Nomega << "_wmax_" << omegamax << "_prec_" << req_prec + SRC_stringstream << "SF_4p_N_" << N << "_Nw_" << Nomega << "_wmax_" << omegamax << "_prec_" << req_prec << "_Npts_K_" << Npts_K << "_Npts_W_" << Npts_W << ".src"; SRC_string = SRC_stringstream.str(); const char* SRC_Cstr = SRC_string.c_str(); @@ -1724,7 +1728,7 @@ namespace JSC { stringstream SR1_stringstream; string SR1_string; - SR1_stringstream << "SF_4p_N_" << N << "_Nw_" << Nomega << "_wmax_" << omegamax << "_prec_" << req_prec + SR1_stringstream << "SF_4p_N_" << N << "_Nw_" << Nomega << "_wmax_" << omegamax << "_prec_" << req_prec << "_Npts_K_" << Npts_K << "_Npts_W_" << Npts_W << ".sr1"; SR1_string = SR1_stringstream.str(); const char* SR1_Cstr = SR1_string.c_str(); @@ -1734,19 +1738,17 @@ namespace JSC { SR1_outfile.precision(14); for (int iK = 1; iK < dim_K; ++iK) - SR1_outfile << iK << "\t" << K[iK] << "\t" << sr1[iK] * omegamax/(twoPI * Nomega) - << "\t" << -((1.0 - cos(K[iK])) * 2.0 * (0.25 - log(2.0))/3.0) << "\t" + SR1_outfile << iK << "\t" << K[iK] << "\t" << sr1[iK] * omegamax/(twoPI * Nomega) + << "\t" << -((1.0 - cos(K[iK])) * 2.0 * (0.25 - log(2.0))/3.0) << "\t" << -sr1[iK] * omegamax/(twoPI * Nomega)/((1.0 - cos(K[iK])) * 2.0 * (0.25 - log(2.0))/3.0) << endl; SR1_outfile.close(); return; } - -} // namespace JSC - +} // namespace ABACUS diff --git a/src/XXX_h0/XXX_h0_par.cc b/src/XXX_VOA/XXX_VOA_par.cc similarity index 95% rename from src/XXX_h0/XXX_h0_par.cc rename to src/XXX_VOA/XXX_VOA_par.cc index 4751020..1a0224a 100755 --- a/src/XXX_h0/XXX_h0_par.cc +++ b/src/XXX_VOA/XXX_VOA_par.cc @@ -2,24 +2,22 @@ This software is part of J.-S. Caux's C++ library. -Copyright (c) 2006. +Copyright (c) J.-S. Caux. ----------------------------------------------------------- -XXX_h0_par.cc +XXX_VOA_par.cc Zero field structure factor for XXX, 4 spinons, parallel (MPI). -LAST MODIFIED: 01/11/06 - ******************************************************************/ #include "mpi.h" -#include "JSC.h" +#include "ABACUS.h" using namespace std; -namespace JSC { +namespace ABACUS { // ***************** THIS IS NOT FINISHED !!!!!!!!!!!!!!!!!!!! @@ -32,36 +30,36 @@ namespace JSC { //SFraw_stringstream << "SF_4p_k_" << k << "_prec_" << req_prec << "_Npts_" << Npts_w << "_" << Npts_K << "_" << Npts_W << "_ch.raw"; SFraw_string = SFraw_stringstream.str(); const char* SFraw_Cstr = SFraw_string.c_str(); - + stringstream SF_stringstream; string SF_string; SF_stringstream << "SF_4p_k_" << k << "_prec_" << req_prec << "_Npts_" << Npts_w << "_" << Npts_K << "_" << Npts_W << ".dat"; //SF_stringstream << "SF_4p_k_" << k << "_prec_" << req_prec << "_Npts_" << Npts_w << "_" << Npts_K << "_" << Npts_W << "_ch.dat"; SF_string = SF_stringstream.str(); const char* SF_Cstr = SF_string.c_str(); - + stringstream SFsrc_stringstream; string SFsrc_string; SFsrc_stringstream << "SF_4p_k_" << k << "_prec_" << req_prec << "_Npts_" << Npts_w << "_" << Npts_K << "_" << Npts_W << ".src"; //SFsrc_stringstream << "SF_4p_k_" << k << "_prec_" << req_prec << "_Npts_" << Npts_w << "_" << Npts_K << "_" << Npts_W << "_ch.src"; SFsrc_string = SFsrc_stringstream.str(); const char* SFsrc_Cstr = SFsrc_string.c_str(); - + ofstream SFraw_outfile; SFraw_outfile.open(SFraw_Cstr); ofstream SFsrc_outfile; SFsrc_outfile.open(SFsrc_Cstr); - + //DP omegamin_used = 0.5 * wmin_4p (k); // Correct for factor of 2 in E between me & Bougourzi //DP omegamax_used = 0.5 * wmax_4p (k); - + Vect_DP args_to_SF(5); args_to_SF[0] = k; args_to_SF[1] = 0.0; // integration variable args_to_SF[2] = req_prec; args_to_SF[3] = DP(Npts_K); args_to_SF[4] = DP(Npts_W); - + // Version using omega = omegamin + (omegamax - omegamin) * (1-cos(alpha)) Integral_result answer = Integrate_optimal_using_table (SF_4p_kwKW_alpha_opt, args_to_SF, 1, Itable, 0.0, 0.5*PI, req_prec, 1.0e-32, Npts_w, SFraw_outfile); // Version using omega = omegamin * cosh(alpha) @@ -70,16 +68,16 @@ namespace JSC { answer.abs_prec /= twoPI; SFraw_outfile.close(); - + SFsrc_outfile << answer << endl; SFsrc_outfile.close(); - + // Translate raw data into SF_4p (k,omega) data - + Translate_raw_4p_data (k, answer.n_vals, SFraw_Cstr, SF_Cstr, SFsrc_Cstr, Itable); //Translate_raw_4p_data_cosh (k, answer.n_vals, SFraw_Cstr, SF_Cstr, SFsrc_Cstr, Itable); - + return(answer); } -} // namespace JSC +} // namespace ABACUS diff --git a/src/XXX_h0/XXX_h0_v2.cc b/src/XXX_VOA/XXX_h0_v2.cc similarity index 86% rename from src/XXX_h0/XXX_h0_v2.cc rename to src/XXX_VOA/XXX_h0_v2.cc index dd1cc5a..bdb886b 100755 --- a/src/XXX_h0/XXX_h0_v2.cc +++ b/src/XXX_VOA/XXX_h0_v2.cc @@ -1,21 +1,25 @@ /**************************************************************** -XXX_h0_v2.cc +This software is part of J.-S. Caux's C++ library. -Defines all class procedures used for the XXX chain in zero field. -Aims at calculating the full k, omega dependence in one go. +Copyright (c) J.-S. Caux. -LAST MODIFIED: 19/02/07 +----------------------------------------------------------- + +File: XXX_h0_v2.cc + +Purpose: Defines all class procedures used for the XXX chain in zero field. + Aims at calculating the full k, omega dependence in one go. ******************************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -namespace JSC { +namespace ABACUS { + - DP Direct_J_integral (int Npts_p, DP req_prec, I_table Itable) { stringstream outfile_stringstream; @@ -23,7 +27,7 @@ namespace JSC { outfile_stringstream << "SF_4p_Np_" << Npts_p << "_prec_" << req_prec << ".raw"; outfile_string = outfile_stringstream.str(); const char* outfile_Cstr = outfile_string.c_str(); - + ofstream outfile; outfile.open(outfile_Cstr); outfile.precision(16); @@ -33,7 +37,7 @@ namespace JSC { src_stringstream << "SF_4p_Np_" << Npts_p << "_prec_" << req_prec << ".src"; src_string = src_stringstream.str(); const char* src_Cstr = src_string.c_str(); - + ofstream srcfile; srcfile.open(src_Cstr); srcfile.precision(16); @@ -51,7 +55,7 @@ namespace JSC { p[3] = - (ip3 + 0.5) * PI/Npts_p; J_fn_cont = J_fn (p, req_prec, Itable); sum_J_fn += J_fn_cont; - if (p[0] > 0 || p[1] > 1 || p[2] > 2 || p[3] > 3) outfile << endl; + if (p[0] > 0 || p[1] > 1 || p[2] > 2 || p[3] > 3) outfile << endl; outfile << p << "\t" << J_fn_cont; } } @@ -59,7 +63,7 @@ namespace JSC { } DP integral_J = Compute_C4 (req_prec) * 24.0 * sum_J_fn * pow(PI/Npts_p, 4.0); - // 24: from using ordered p's + // 24: from using ordered p's srcfile << integral_J << "\t" << integral_J/(4.0 * PI * PI) << "\t" << integral_J/(PI * PI) << endl; @@ -76,7 +80,7 @@ namespace JSC { rawfile_stringstream << "SF_4p_Np_" << Npts_p << "_No_" << Npts_o << "_prec_" << req_prec << ".raw"; rawfile_string = rawfile_stringstream.str(); const char* rawfile_Cstr = rawfile_string.c_str(); - + ifstream rawfile; rawfile.open(rawfile_Cstr); @@ -85,36 +89,36 @@ namespace JSC { smfile_stringstream << "SF_4p_Np_" << Npts_p << "_No_" << Npts_o << "_prec_" << req_prec << "_w_" << width << ".dat"; smfile_string = smfile_stringstream.str(); const char* smfile_Cstr = smfile_string.c_str(); - + ofstream smfile; smfile.open(smfile_Cstr); smfile.precision(16); - DP* SF_4p_raw = new DP[(Npts_p + 1) * Npts_o]; - DP* SF_4p_sm = new DP[(Npts_p + 1) * Npts_o]; + DP* SF_4p_raw = new DP[(Npts_p + 1) * Npts_o]; + DP* SF_4p_sm = new DP[(Npts_p + 1) * Npts_o]; - for (int iw = 0; iw < Npts_o; ++iw) + for (int iw = 0; iw < Npts_o; ++iw) for (int ik = 0; ik <= Npts_p; ++ik) rawfile >> SF_4p_raw[Npts_o * ik + iw]; - + rawfile.close(); // We now broaden to a Gaussian: int iw_half_window = int(width/(2.0 * PI/Npts_o)); - if (iw_half_window == 0) JSCerror("width too small in Smoothen_raw_SF_4p"); + if (iw_half_window == 0) ABACUSerror("width too small in Smoothen_raw_SF_4p"); int iwstart, iwstop; DP domega_sq_over_width_sq = pow(2.0 * PI/(Npts_o * width), 2.0); DP exp_factor; for (int iw = 0; iw < Npts_o; ++iw) { - iwstart = JSC::max(0, iw - 10 * iw_half_window); - iwstop = JSC::min(Npts_o, iw + 10 * iw_half_window); + iwstart = ABACUS::max(0, iw - 10 * iw_half_window); + iwstop = ABACUS::min(Npts_o, iw + 10 * iw_half_window); for (int iwraw = iwstart; iwraw <= iwstop; ++iwraw) { exp_factor = exp(-(iwraw - iw) * (iwraw - iw) * domega_sq_over_width_sq); - for (int ik = 0; ik <= Npts_p; ++ik) + for (int ik = 0; ik <= Npts_p; ++ik) { SF_4p_sm[Npts_o * ik + iw] += SF_4p_raw[Npts_o * ik + iwraw] * exp_factor; } @@ -142,7 +146,7 @@ namespace JSC { rawfile_stringstream << "SF_4p_Np_" << Npts_p << "_No_" << Npts_o << "_prec_" << req_prec << ".raw"; rawfile_string = rawfile_stringstream.str(); const char* rawfile_Cstr = rawfile_string.c_str(); - + ofstream rawfile; rawfile.open(rawfile_Cstr); rawfile.precision(16); @@ -152,7 +156,7 @@ namespace JSC { src_stringstream << "SF_4p_Np_" << Npts_p << "_No_" << Npts_o << "_prec_" << req_prec << ".src"; src_string = src_stringstream.str(); const char* src_Cstr = src_string.c_str(); - + ofstream srcfile; srcfile.open(src_Cstr); srcfile.precision(16); @@ -161,7 +165,7 @@ namespace JSC { DP J_fn_cont = 0.0; DP sum_J_fn = 0.0; - DP* SF_4p_raw = new DP[(Npts_p + 1) * Npts_o]; + DP* SF_4p_raw = new DP[(Npts_p + 1) * Npts_o]; // labelling: index is Npts_o * ik + iomega DP omegamax = 2.0 * PI; @@ -188,17 +192,17 @@ namespace JSC { ik = ip0 + ip1 + ip2 + ip3; if (ik > 2 * Npts_p) ik -= 2*Npts_p; // guarantees 0 <= ik < 2Npts - - if (ik <= Npts_p) { - + + if (ik <= Npts_p) { + omega = -0.5 * PI * (sinp0 + sinp1 + sinp2 + sin(p[3])); iomega = int(omega * Npts_o/omegamax); - + //cout << ik << "\t" << iomega << endl; - + J_fn_cont = J_fn (p, req_prec, Itable); sum_J_fn += (ik == Npts_p ? 1.0 : 2.0) * J_fn_cont; - + SF_4p_raw[Npts_o * ik + iomega] += J_fn_cont; } } @@ -207,7 +211,7 @@ namespace JSC { } DP prefactor = Compute_C4 (req_prec) * 24.0 * pow(PI/Npts_p, 4.0); - // 24: from using ordered p's + // 24: from using ordered p's DP integral_J = prefactor * sum_J_fn; @@ -227,6 +231,4 @@ namespace JSC { return(integral_J); } -} // namespace JSC - - +} // namespace ABACUS diff --git a/src/XXZ_h0/XXZ_h0.cc b/src/XXZ_VOA/XXZ_VOA.cc similarity index 90% rename from src/XXZ_h0/XXZ_h0.cc rename to src/XXZ_VOA/XXZ_VOA.cc index 3d692b3..a03e57a 100644 --- a/src/XXZ_h0/XXZ_h0.cc +++ b/src/XXZ_VOA/XXZ_VOA.cc @@ -1,30 +1,29 @@ /********************************************************** -This software is part of J.-S. Caux's ABACUS++ library. +This software is part of J.-S. Caux's ABACUS library. -Copyright (c) +Copyright (c) J.-S. Caux. ----------------------------------------------------------- -File: XXZ_h0.cc +File: XXZ_VOA.cc Purpose: Defines all class procedures used for the infinite XXZ chain in zero field. - ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" using namespace std; -namespace JSC { +namespace ABACUS { DP Fermi_velocity_XXZ_h0 (DP Delta) { // This uses the J > 0 conventions, with H = J \sum S.S - if (Delta <= -1.0 || Delta >= 1.0) JSCerror("Use Delta in AFM gapless regime for Fermi_velocity_XXZ_h0."); + if (Delta <= -1.0 || Delta >= 1.0) ABACUSerror("Use Delta in AFM gapless regime for Fermi_velocity_XXZ_h0."); return(0.5 * PI * sqrt(1.0 - Delta * Delta)/acos(Delta)); } @@ -39,7 +38,7 @@ namespace JSC { DP answer; if (args[0] * args[2] <= 1.0) { - + if (args[0] <= 1.0) { answer = sinh(args[0] * (1.0 + args[2])) * sinh(args[0]) * cos(4.0 * args[0] * args[1]) /(args[0] * sinh(args[0] * args[2]) * pow(cosh(args[0]), 2.0)); @@ -95,7 +94,7 @@ namespace JSC { DP I_xi_12_integral (DP xi, DP rho, DP req_prec, int max_nr_pts, DP t1bar) { - DP tinf = 24.0; // such that exp(-2tinf) << machine_eps + DP tinf = 24.0; // such that exp(-2tinf) << machine_eps DP rho_used = fabs(rho); Vect_DP args(3); @@ -126,16 +125,16 @@ namespace JSC { DP expm2t = exp(-2.0 * args[0]); DP expm2txi = exp(-2.0*args[0]*args[2]); //answer = 8.0 * expm2t * pow(sin(2.0 * args[0] * args[1]), 2.0)/(args[0] * (1.0 - expm2t) * (1.0 + expm2t) * (1.0 + expm2t)); - answer = 8.0 * (1.0 - expm2t*expm2txi) * expm2t * + answer = 8.0 * (1.0 - expm2t*expm2txi) * expm2t * pow(sin(2.0 * args[0] * args[1]), 2.0)/(args[0] * (1.0 - expm2txi) * (1.0 - expm2t) * (1.0 + expm2t) * (1.0 + expm2t)); } DP expm2t = exp(-2.0 * args[0]); DP expm2txi = exp(-2.0*args[0]*args[2]); //answer = 8.0 * expm2t * pow(sin(2.0 * args[0] * args[1]), 2.0)/(args[0] * (1.0 - expm2t) * (1.0 + expm2t) * (1.0 + expm2t)); - answer = 8.0 * (1.0 - expm2t*expm2txi) * expm2t * + answer = 8.0 * (1.0 - expm2t*expm2txi) * expm2t * pow(sin(2.0 * args[0] * args[1]), 2.0)/(args[0] * (1.0 - expm2txi) * (1.0 - expm2t) * (1.0 + expm2t) * (1.0 + expm2t)); - + return(answer); ... NOT USED @@ -149,7 +148,7 @@ namespace JSC { // args[0] corresponds to t, args[1] to rho, args[2] to xi DP answer = 0.0; - if (args[0] < 1.0) + if (args[0] < 1.0) answer = pow(sin(2.0 * args[0] * args[1]), 2.0)/(args[0] * tanh(args[0] * args[2]) * pow(cosh(args[0]), 2.0)); else if (args[0] >= 1.0) { DP expm2t = exp(-2.0 * args[0]); @@ -161,7 +160,7 @@ namespace JSC { DP I_xi_2_integral (DP xi, DP rho, DP req_prec, int max_nr_pts) { - DP tinf = 24.0; // such that exp(-2tinf) << machine_eps + DP tinf = 24.0; // such that exp(-2tinf) << machine_eps DP rho_used = fabs(rho); Vect_DP args(3); @@ -173,8 +172,8 @@ namespace JSC { //if (rho_used <= 1.0) answer = (Integrate_optimal (Integrand_xi_2, args, 0, 0.0, tinf, req_prec, req_prec, max_nr_pts)).integ_est; - //else - answer = PI * rho + log(0.5 * (1.0 + exp(-2.0 * PI * rho_used))) // This is I^{(21)} + //else + answer = PI * rho + log(0.5 * (1.0 + exp(-2.0 * PI * rho_used))) // This is I^{(21)} + (Integrate_optimal (Integrand_xi_22, args, 0, 0.0, tinf, req_prec, req_prec, max_nr_pts)).integ_est; return(answer); @@ -186,8 +185,8 @@ namespace JSC { DP t1bar = 1.0; // delimiter between the I_xi_11 and I__xi_12 integrals - DP answer = I_xi_11_integral (xi, rho, req_prec, max_nr_pts, t1bar) - + I_xi_12_integral (xi, rho, req_prec, max_nr_pts, t1bar) + DP answer = I_xi_11_integral (xi, rho, req_prec, max_nr_pts, t1bar) + + I_xi_12_integral (xi, rho, req_prec, max_nr_pts, t1bar) - 2.0 * Cosine_Integral (4.0 * rho * t1bar) - I_xi_2_integral (xi, rho, req_prec, max_nr_pts); @@ -197,13 +196,13 @@ namespace JSC { /********************* TWO SPINONS ********************/ - + DP Szz_XXZ_h0_2spinons (DP Delta, DP k, DP omega, Integral_table Itable) { // Careful ! This is S(k, omega) = S (k, w) |dw/domega| = 2 S(k, w) - + DP w = 2.0 * omega; // Rescale energies by factor 2 because of definitions of H_XXX (omega: S.S; w: 0.5 * sigma.sigma = 2 S.S) - + DP vF = Fermi_velocity_XXZ_h0 (Delta); // in units of omega //DP wu = twoPI * sin(0.5 * k); @@ -218,11 +217,11 @@ namespace JSC { //return(w < wu && w > wl ? 2.0 * 0.5 * exp(-Itable.Return_val (acosh(sqrt((wu * wu - wl * wl)/(w * w - wl * wl)))/PI))/sqrt(wu * wu - w * w) : 0.0); DP expmtwoPIrhooverxi = exp(-twoPI * rho/xi); //return(w < wu && w > wl ? 2.0 * exp(-Itable.Return_val (rho))/(sqrt(wu * wu - w * w) * (cosh(twoPI * rho/xi) + cos(PI/xi))) : 0.0); - return(w < wu && w > wl ? 2.0 * pow(1.0 + 1.0/xi, 2.0) * exp(-Itable.Return_val (rho)) + return(w < wu && w > wl ? 2.0 * pow(1.0 + 1.0/xi, 2.0) * exp(-Itable.Return_val (rho)) * expmtwoPIrhooverxi/(sqrt(wu * wu - w * w) - * (0.5 * (1.0 + expmtwoPIrhooverxi * expmtwoPIrhooverxi) + expmtwoPIrhooverxi * cos(PI/xi))) + * (0.5 * (1.0 + expmtwoPIrhooverxi * expmtwoPIrhooverxi) + expmtwoPIrhooverxi * cos(PI/xi))) : 0.0); - + } DP Szz_XXZ_h0_2spinons (Vect_DP args, Integral_table Itable) @@ -238,7 +237,7 @@ namespace JSC { return(Szz_XXZ_h0_2spinons (Delta, args[0], args[1], Itable)); /* - + // This uses args[0] = k, args[1] = w, args[2] = xi DP Delta = cos(PI/(args[2] + 1.0)); @@ -254,12 +253,12 @@ namespace JSC { DP expmtwoPIrhooverxi = exp(-twoPI * rho/args[2]); // 0.5 factor: 1 from Bougourzi, and 1/2 is S^{zz} = 1/2 * S^{+-} - return(args[1] < wu && args[1] > wl ? + return(args[1] < wu && args[1] > wl ? //0.5 * exp(-Itable.Return_val (acosh(sqrt((wu * wu - wl * wl)/(args[1] * args[1] - wl * wl)))/PI))/sqrt(wu * wu - args[1] * args[1]) : 0.0); pow(1.0 + 1.0/args[2], 2.0) * exp(-Itable.Return_val (rho)) * expmtwoPIrhooverxi - /(sqrt(wu * wu - args[1] * args[1]) + /(sqrt(wu * wu - args[1] * args[1]) * (0.5 * (1.0 + expmtwoPIrhooverxi * expmtwoPIrhooverxi) + expmtwoPIrhooverxi * cos(PI/args[2]))) : 0.0); - + */ } @@ -267,7 +266,7 @@ namespace JSC { { // This returns S(k, omega) \times Jacobian (d omega)/(d alpha) where omega = omega_{lower threshold} cosh \alpha - // so returns S(k, omega) \sqrt{omega^2 - omega_l^2} + // so returns S(k, omega) \sqrt{omega^2 - omega_l^2} // This uses args[0] = k, args[1] = alpha, args[2] = xi @@ -276,11 +275,11 @@ namespace JSC { DP omegaup = 2.0 * vF * sin(0.5 * args[0]); DP omegalow = vF * fabs(sin(args[0])); - + DP omega = omegalow * cosh(args[1]); - + if (omega >= omegaup || omega <= omegalow) return(0.0); - + DP Jacobian = sqrt(omega * omega - omegalow * omegalow); return(Jacobian * Szz_XXZ_h0_2spinons (Delta, args[0], omega, Itable)); @@ -290,13 +289,13 @@ namespace JSC { DP wu = 4.0 * vF * sin(0.5 * args[0]); //DP wl = PI * fabs(sin(k)); DP wl = 2.0 * vF * fabs(sin(args[0])); - + //DP w = wu * cos(args[1]); //DP factor = 1.0; DP w = wl * cosh(args[1]); - + if (w >= wu || w <= wl) return(0.0); - + DP factor = sqrt((w * w - wl * wl)/(wu * wu - w * w)); DP rho = acosh(sqrt((wu * wu - wl * wl)/(w * w - wl * wl)))/PI; @@ -304,7 +303,7 @@ namespace JSC { // 0.5 factor: 1 from Bougourzi, and 1/2 is S^{zz} = 1/2 * S^{+-} //return(factor * 0.5 * exp(-Itable.Return_val (acosh(sqrt((wu * wu - wl * wl)/(w * w - wl * wl)))/PI))); - return(pow(1.0 + 1.0/args[2], 2.0) * factor + return(pow(1.0 + 1.0/args[2], 2.0) * factor * exp(-Itable.Return_val (rho)) * expmtwoPIrhooverxi/(0.5 * (1.0 + expmtwoPIrhooverxi * expmtwoPIrhooverxi) + expmtwoPIrhooverxi * cos(PI/args[2]))); */ @@ -325,7 +324,7 @@ namespace JSC { DP vF = Fermi_velocity_XXZ_h0 (Delta); // in units of omega DP omegalow = vF * fabs(sin(args[0])); - + DP omega = omegalow * cosh(args[1]); args[1] = omega; @@ -337,51 +336,51 @@ namespace JSC { DP Szz_XXZ_h0_2spinons_intomega (Vect_DP args, Integral_table Itable) { // This returns \int_0^2PI domega/2PI S(k, omega) - + DP k = args[0]; DP req_prec = args[1]; DP xi = args[2]; int max_nr_pts = int(args[3]); - + DP Delta = cos(PI/(args[2] + 1.0)); DP vF = Fermi_velocity_XXZ_h0 (Delta); // in units of omega DP omegaup = 2.0 * vF * sin(0.5 * args[0]); DP omegalow = vF * fabs(sin(args[0])); - + Vect_DP args_to_SF_2p(4); args_to_SF_2p[0] = k; args_to_SF_2p[1] = 0.0; // this will be omega - args_to_SF_2p[2] = xi; - args_to_SF_2p[3] = JSC::max(1.0e-14, 0.01 * req_prec); - - return((Integrate_optimal_using_table (Szz_XXZ_h0_2spinons, args_to_SF_2p, 1, Itable, + args_to_SF_2p[2] = xi; + args_to_SF_2p[3] = ABACUS::max(1.0e-14, 0.01 * req_prec); + + return((Integrate_optimal_using_table (Szz_XXZ_h0_2spinons, args_to_SF_2p, 1, Itable, omegalow, omegaup, req_prec, req_prec, max_nr_pts)).integ_est/twoPI); } DP Szz_XXZ_h0_2spinons_intomega_alt (Vect_DP args, Integral_table Itable) { // This returns \int_0^2PI domega/2PI S(k, omega) - + DP k = args[0]; DP req_prec = args[1]; DP xi = args[2]; int max_nr_pts = int(args[3]); - + DP Delta = cos(PI/(args[2] + 1.0)); DP vF = Fermi_velocity_XXZ_h0 (Delta); // in units of omega DP omegaup = 2.0 * vF * sin(0.5 * args[0]); DP omegalow = vF * fabs(sin(args[0])); - + Vect_DP args_to_SF_2p(4); args_to_SF_2p[0] = k; args_to_SF_2p[1] = 0.0; // this will be omega args_to_SF_2p[2] = xi; - args_to_SF_2p[3] = JSC::max(1.0e-14, 0.01 * req_prec); - + args_to_SF_2p[3] = ABACUS::max(1.0e-14, 0.01 * req_prec); + //return(Integrate_rec_using_table (SF_2p_alt, args_to_SF_2p, 1, Itable, 0.0, acos(wl/wu), req_prec, max_rec)/twoPI); - return((Integrate_optimal_using_table (Szz_XXZ_h0_2spinons_alt, args_to_SF_2p, 1, Itable, + return((Integrate_optimal_using_table (Szz_XXZ_h0_2spinons_alt, args_to_SF_2p, 1, Itable, 0.0, acosh(omegaup/omegalow), req_prec, req_prec, max_nr_pts)).integ_est/twoPI); } @@ -389,39 +388,39 @@ namespace JSC { { // Near XX: it's better to use this function. // Near XXX: it's better to use the ..._alt function below. - + Vect_DP args_to_Szz_intomega (4); - + args_to_Szz_intomega[0] = 0.0; // this will be k - args_to_Szz_intomega[1] = JSC::max(1.0e-14, 0.01 * req_prec); + args_to_Szz_intomega[1] = ABACUS::max(1.0e-14, 0.01 * req_prec); args_to_Szz_intomega[2] = PI/acos(Delta) - 1.0; args_to_Szz_intomega[3] = DP(max_nr_pts); // Factor 4: we expect \int_0^\infty \frac{d\omega}{2\pi} \int_0^{2\pi} \frac{dk}{2\pi} S^zz (k, omega) = 1/4 // Factor 2: int[0, 2PI] = 2 int[0, PI] - return(4.0 * 2.0 * (Integrate_optimal_using_table (Szz_XXZ_h0_2spinons_intomega, args_to_Szz_intomega, 0, Itable, + return(4.0 * 2.0 * (Integrate_optimal_using_table (Szz_XXZ_h0_2spinons_intomega, args_to_Szz_intomega, 0, Itable, 0.0, PI, req_prec, req_prec, max_nr_pts)).integ_est/twoPI); } - + DP Szz_XXZ_h0_2spinons_check_sumrule_alt (DP Delta, DP req_prec, int max_nr_pts, Integral_table Itable) { // This is the preferred version if near XXX. - + Vect_DP args_to_Szz_intomega (4); - + args_to_Szz_intomega[0] = 0.0; // this will be k - args_to_Szz_intomega[1] = JSC::max(1.0e-14, 0.01 * req_prec); + args_to_Szz_intomega[1] = ABACUS::max(1.0e-14, 0.01 * req_prec); args_to_Szz_intomega[2] = PI/acos(Delta) - 1.0; args_to_Szz_intomega[3] = DP(max_nr_pts); - + // Factor 2: int[0, 2PI] = 2 int[0, PI] - return(4.0 * 2.0 * (Integrate_optimal_using_table (Szz_XXZ_h0_2spinons_intomega_alt, args_to_Szz_intomega, 0, Itable, + return(4.0 * 2.0 * (Integrate_optimal_using_table (Szz_XXZ_h0_2spinons_intomega_alt, args_to_Szz_intomega, 0, Itable, 0.0, PI, req_prec, req_prec, max_nr_pts)).integ_est/twoPI); } DP Fixed_k_sumrule_omega_Szz_XXZ_h0_N (DP Delta, DP k) { - // This is K_1 (k) = \int domega/2PI omega S(k, omega) + // This is K_1 (k) = \int domega/2PI omega S(k, omega) //return(4.0 * (log(2.0) - 0.25) * (1.0 - cos(k))/3.0); // XXX_h0 // Calculate the average: @@ -431,7 +430,7 @@ namespace JSC { return (-2.0 * (1.0 - cos(k)) * Xavg/N); } - + DP Integrand_GSE_XXZ_h0 (Vect_DP args) { // args[0] corresponds to t, args[1] to xi @@ -445,7 +444,7 @@ namespace JSC { { DP xi = PI/acos(Delta) - 1.0; - DP tinf = 24.0; // such that exp(-2tinf) << machine_eps + DP tinf = 24.0; // such that exp(-2tinf) << machine_eps Vect_DP args(2); args[0] = 0.0; @@ -466,16 +465,16 @@ namespace JSC { DP Fixed_k_sumrule_omega_Szz_XXZ_h0 (DP Delta, DP k, DP req_prec, int max_nr_pts) { - // + // DP xi = PI/acos(Delta) - 1.0; - DP tinf = 24.0; // such that exp(-2tinf) << machine_eps + DP tinf = 24.0; // such that exp(-2tinf) << machine_eps Vect_DP args(2); args[0] = 0.0; args[1] = xi; - DP Xavg = -(0.25/(acos(Delta) * sqrt(1.0 - Delta * Delta))) * 2.0 * (Integrate_optimal (Integrand_GSE_XXZ_h0, args, 0, 0.0, tinf, req_prec, req_prec, max_nr_pts).integ_est) + DP Xavg = -(0.25/(acos(Delta) * sqrt(1.0 - Delta * Delta))) * 2.0 * (Integrate_optimal (Integrand_GSE_XXZ_h0, args, 0, 0.0, tinf, req_prec, req_prec, max_nr_pts).integ_est) + 0.25 * (Delta/pow(acos(Delta), 2.0)) * 2.0 * (Integrate_optimal (Integrand_2_fSR_XXZ_h0, args, 0, 0.0, tinf, req_prec, req_prec, max_nr_pts).integ_est); return (-2.0 * (1.0 - cos(k)) * Xavg); @@ -484,80 +483,80 @@ namespace JSC { DP Szz_XXZ_h0_2spinons_check_fixed_k_Szz_sumrule (DP Delta, DP k, DP req_prec, int max_nr_pts, Integral_table Itable) { // Near XXX, it's better to use the ..._alt function below. - + DP vF = Fermi_velocity_XXZ_h0 (Delta); // in units of omega DP omegaup = 2.0 * vF * sin(0.5 * k); DP omegalow = vF * fabs(sin(k)); - + Vect_DP args_to_SF_2p(4); args_to_SF_2p[0] = k; args_to_SF_2p[1] = 0.0; // this will be omega args_to_SF_2p[2] = PI/acos(Delta) - 1.0; - args_to_SF_2p[3] = JSC::max(1.0e-14, 0.01 * req_prec); - + args_to_SF_2p[3] = ABACUS::max(1.0e-14, 0.01 * req_prec); + return(((Integrate_optimal_using_table (Szz_XXZ_h0_2spinons_omega, args_to_SF_2p, 1, Itable, omegalow, omegaup, req_prec, req_prec, max_nr_pts)).integ_est/twoPI)/Fixed_k_sumrule_omega_Szz_XXZ_h0(Delta, k, req_prec, max_nr_pts)); } DP Szz_XXZ_h0_2spinons_check_fixed_k_Szz_sumrule_alt (DP Delta, DP k, DP req_prec, int max_nr_pts, Integral_table Itable) { // This is the preferred version if near XXX. - + DP vF = Fermi_velocity_XXZ_h0 (Delta); // in units of omega DP omegaup = 2.0 * vF * sin(0.5 * k); DP omegalow = vF * fabs(sin(k)); - + Vect_DP args_to_SF_2p(4); args_to_SF_2p[0] = k; args_to_SF_2p[1] = 0.0; // this will be alpha args_to_SF_2p[2] = PI/acos(Delta) - 1.0; - args_to_SF_2p[3] = JSC::max(1.0e-14, 0.01 * req_prec); - + args_to_SF_2p[3] = ABACUS::max(1.0e-14, 0.01 * req_prec); + return(((Integrate_optimal_using_table (Szz_XXZ_h0_2spinons_omega_alt, args_to_SF_2p, 1, Itable, 0.0, acosh(omegaup/omegalow), req_prec, req_prec, max_nr_pts)).integ_est/twoPI)/Fixed_k_sumrule_omega_Szz_XXZ_h0(Delta, k, req_prec, max_nr_pts)); } - + //******************************** Functions to produce files similar to ABACUS ********************************** - + void Produce_Szz_XXZ_h0_2spinons_file (DP Delta, int N, int Nomega, DP omegamax, Integral_table Itable) { - // IMPORTANT NOTE: this produces a file with Szz !! - - if (N % 2) JSCerror("Please use N even in Produce_Szz_XXZ_h0_2spinons_file."); - + // IMPORTANT NOTE: this produces a file with Szz !! + + if (N % 2) ABACUSerror("Please use N even in Produce_Szz_XXZ_h0_2spinons_file."); + stringstream SF_stringstream; string SF_string; SF_stringstream << "Szz_XXZ_h0_2spinons_Delta_" << Delta << "_N_" << N << "_Nom_" << Nomega << "_ommax_" << omegamax << ".dat"; SF_string = SF_stringstream.str(); const char* SF_Cstr = SF_string.c_str(); - + Write_K_File (N, 0, N); Write_Omega_File (Nomega, 0.0, omegamax); - + int dim_K = N/2 + 1; DP* K = new DP[dim_K]; for (int iK = 0; iK < dim_K; ++iK) K[iK] = (twoPI * iK)/N; - + DP* omega = new DP[Nomega]; for (int iw = 0; iw < Nomega; ++iw) omega[iw] = omegamax * (iw + 0.5)/Nomega; - + DP* SF_XXZ_2p_dat = new DP[dim_K * Nomega]; - + DP srtot = 0.0; Vect_DP sr1(0.0, dim_K); - for (int iK = 0; iK < dim_K; ++iK) + for (int iK = 0; iK < dim_K; ++iK) for (int iw = 0; iw < Nomega; ++iw) { SF_XXZ_2p_dat[dim_K * iw + iK] = Szz_XXZ_h0_2spinons (Delta, K[iK], omega[iw], Itable); srtot += (iK == N/2 ? 1.0 : 2.0) * SF_XXZ_2p_dat[dim_K * iw + iK]; sr1[iK] += omega[iw] * SF_XXZ_2p_dat[dim_K * iw + iK]; } - + ofstream SF_outfile; SF_outfile.open(SF_Cstr); SF_outfile.precision(14); - + for (int iw = 0; iw < Nomega; ++iw) { for (int iK = 0; iK < dim_K; ++iK) SF_outfile << SF_XXZ_2p_dat[dim_K * iw + iK] << "\t"; @@ -565,9 +564,9 @@ namespace JSC { SF_outfile << SF_XXZ_2p_dat[dim_K * iw + iKt] << "\t"; SF_outfile << endl; } - + SF_outfile.close(); - + // Do sum rule files: stringstream SRC_stringstream; @@ -606,9 +605,9 @@ namespace JSC { else sr1factor = 1.0; for (int iK = 1; iK < dim_K; ++iK) - SR1_outfile << iK << "\t" << K[iK] << "\t" << sr1[iK] * omegamax/(twoPI * Nomega) - //<< "\t" << -((1.0 - cos(K[iK])) * 2.0 * (0.25 - log(2.0))/3.0) << "\t" - << "\t" << (1.0 - cos(K[iK])) * sr1factor << "\t" + SR1_outfile << iK << "\t" << K[iK] << "\t" << sr1[iK] * omegamax/(twoPI * Nomega) + //<< "\t" << -((1.0 - cos(K[iK])) * 2.0 * (0.25 - log(2.0))/3.0) << "\t" + << "\t" << (1.0 - cos(K[iK])) * sr1factor << "\t" //<< -sr1[iK] * omegamax/(twoPI * Nomega)/((1.0 - cos(K[iK])) * 2.0 * (0.25 - log(2.0))/3.0) << endl; << sr1[iK] * omegamax/(twoPI * Nomega)/((1.0 - cos(K[iK])) * sr1factor) << endl; @@ -619,46 +618,46 @@ namespace JSC { void Produce_Szz_XXZ_h0_2spinons_fixed_K_file (DP Delta, DP Kover2PI, int Nomega, Integral_table Itable) { - // IMPORTANT NOTE: this produces a file with Szz !! - + // IMPORTANT NOTE: this produces a file with Szz !! + stringstream SF_stringstream; string SF_string; SF_stringstream << "Szz_XXZ_h0_2spinons_Delta_" << Delta << "_Kover2PI_" << Kover2PI << "_Nom_" << Nomega << ".dat"; SF_string = SF_stringstream.str(); const char* SF_Cstr = SF_string.c_str(); - + DP K = twoPI * Kover2PI; - + DP* omega = new DP[Nomega]; DP vF = Fermi_velocity_XXZ_h0 (Delta); // in units of omega DP omegaup = 2.0 * vF * sin(0.5 * K); DP omegalow = vF * fabs(sin(K)); - + for (int iw = 0; iw < Nomega; ++iw) omega[iw] = 0.99 * omegalow + (1.01 * omegaup - 0.99 * omegalow) * (iw + 0.5)/Nomega; // factor of 1.01: just to have zeroes on either side of continuum. - + DP* SF_XXZ_2p_dat = new DP[Nomega]; - + DP sr1 = 0.0; for (int iw = 0; iw < Nomega; ++iw) { SF_XXZ_2p_dat[iw] = Szz_XXZ_h0_2spinons (Delta, K, omega[iw], Itable); sr1 += omega[iw] * SF_XXZ_2p_dat[iw]; } - + ofstream SF_outfile; SF_outfile.open(SF_Cstr); SF_outfile.precision(14); - + SF_outfile << omega[0] << "\t" << SF_XXZ_2p_dat[0]; for (int iw = 0; iw < Nomega; ++iw) { SF_outfile << endl << omega[iw] << "\t" << SF_XXZ_2p_dat[iw]; } - + SF_outfile.close(); - + // Do sum rule files: /* NOT ACCURATE SINCE WE'RE PLOTTING SOMEWHAT OUTSIDE OF CONTINUUM AS WELL (to get nice figures) @@ -684,8 +683,8 @@ namespace JSC { if (Delta > 0.0) sr1factor = -2.0 * Xavg/Nfsr; else sr1factor = 1.0; - SR1_outfile << Kover2PI << "\t" << sr1 * (omegaup - omegalow)/(twoPI * Nomega) - << "\t" << (1.0 - cos(K)) * sr1factor << "\t" + SR1_outfile << Kover2PI << "\t" << sr1 * (omegaup - omegalow)/(twoPI * Nomega) + << "\t" << (1.0 - cos(K)) * sr1factor << "\t" << sr1 * (omegaup - omegalow)/(twoPI * Nomega)/((1.0 - cos(K)) * sr1factor) << endl; SR1_outfile.close(); @@ -696,6 +695,4 @@ namespace JSC { -} // namespace JSC - - +} // namespace ABACUS diff --git a/src/YOUNG/Young_Tableau.cc b/src/YOUNG/Young_Tableau.cc index c1c2b62..208d834 100644 --- a/src/YOUNG/Young_Tableau.cc +++ b/src/YOUNG/Young_Tableau.cc @@ -1,8 +1,8 @@ /********************************************************** -This software is part of J.-S. Caux's ABACUS++ library. +This software is part of J.-S. Caux's ABACUS library. -Copyright (c) 2006-9. +Copyright (c) J.-S. Caux. ----------------------------------------------------------- @@ -10,73 +10,74 @@ File: Young_Tableau.cc Purpose: Defines Young_Tableau class and procedures. -Last modified: 08/10/2009 - ***********************************************************/ -#include "JSC.h" +#include "ABACUS.h" -namespace JSC { +using namespace std; - Young_Tableau::Young_Tableau () : Nrows(0), Ncols(0), Row_L(0), Col_L(0), id(0LL), maxid(0LL), + +namespace ABACUS { + + Young_Tableau::Young_Tableau () : Nrows(0), Ncols(0), Row_L(0), Col_L(0), id(0LL), maxid(0LL), map(new long long int [1]), map_computed(false), idnr_reached(0LL), nboxes_reached(-1), dimchoose(0), choose_table(0LL) {} - - Young_Tableau::Young_Tableau (int Nr, int Nc) - : Nrows(Nr), Ncols(Nc), Row_L(new int[Nrows]), Col_L(new int[Ncols]), id(0LL), - maxid(choose_lli(Nr + Nc, Nc) - 1LL), - map(new long long int [YOUNG_TABLEAU_ID_OPTION == 2 ? JSC::min(maxid + 1LL, TABLEAU_ID_UPPER_LIMIT) : 1]), + + Young_Tableau::Young_Tableau (int Nr, int Nc) + : Nrows(Nr), Ncols(Nc), Row_L(new int[Nrows]), Col_L(new int[Ncols]), id(0LL), + maxid(choose_lli(Nr + Nc, Nc) - 1LL), + map(new long long int [YOUNG_TABLEAU_ID_OPTION == 2 ? ABACUS::min(maxid + 1LL, TABLEAU_ID_UPPER_LIMIT) : 1]), map_computed(false), idnr_reached(0LL), nboxes_reached(-1), - dimchoose (JSC::min(Nr, Nc) + 1), + dimchoose (ABACUS::min(Nr, Nc) + 1), choose_table(new long long int[(Nr + Nc + 1) * dimchoose]) - + { // Constructs empty tableau of appropriate size - + for (int i = 0; i < Nrows; ++i) Row_L[i] = 0; for (int i = 0; i < Ncols; ++i) Col_L[i] = 0; - + // Construct the choose_table - for (int cti = 0; cti < Nr + Nc + 1; ++cti) + for (int cti = 0; cti < Nr + Nc + 1; ++cti) for (int ctj = 0; ctj < dimchoose; ++ctj) { if (cti >= ctj) choose_table[dimchoose * cti + ctj] = choose_lli(cti, ctj); else choose_table[dimchoose * cti + ctj] = 0LL; } - // Fill map with zeros: - for (int i = 0; i < (YOUNG_TABLEAU_ID_OPTION == 2 ? JSC::min(maxid + 1LL, TABLEAU_ID_UPPER_LIMIT) : 1); ++i) map[i] = 0LL; + // Fill map with zeros: + for (int i = 0; i < (YOUNG_TABLEAU_ID_OPTION == 2 ? ABACUS::min(maxid + 1LL, TABLEAU_ID_UPPER_LIMIT) : 1); ++i) map[i] = 0LL; } - /* SEGFAULTS - Young_Tableau::Young_Tableau (int Nr, int Nc, long long int idnr) - : Nrows(Nr), Ncols(Nc), Row_L(new int[Nrows]), Col_L(new int[Ncols]), id(idnr), - maxid(choose_lli(Nr + Nc, Nc) - 1LL), - map(new long long int [YOUNG_TABLEAU_ID_OPTION == 2 ? JSC::min(maxid + 1LL, TABLEAU_ID_UPPER_LIMIT) : 1]), + /* SEGFAULTS + Young_Tableau::Young_Tableau (int Nr, int Nc, long long int idnr) + : Nrows(Nr), Ncols(Nc), Row_L(new int[Nrows]), Col_L(new int[Ncols]), id(idnr), + maxid(choose_lli(Nr + Nc, Nc) - 1LL), + map(new long long int [YOUNG_TABLEAU_ID_OPTION == 2 ? ABACUS::min(maxid + 1LL, TABLEAU_ID_UPPER_LIMIT) : 1]), map_computed(false), idnr_reached(0LL), nboxes_reached(-1), - dimchoose (JSC::min(Nr, Nc) + 1), + dimchoose (ABACUS::min(Nr, Nc) + 1), choose_table(new long long int[(Nr + Nc + 1) * dimchoose]) { - // Constructs Young tableau of given idnr, if consistent with Nr, Nc. + // Constructs Young tableau of given idnr, if consistent with Nr, Nc. // Construct the choose_table - for (int cti = 0; cti < Nr + Nc + 1; ++cti) + for (int cti = 0; cti < Nr + Nc + 1; ++cti) for (int ctj = 0; ctj < dimchoose; ++ctj) { if (cti >= ctj) choose_table[dimchoose * cti + ctj] = choose_lli(cti, ctj); else choose_table[dimchoose * cti + ctj] = 0LL; } - for (int i = 0; i < YOUNG_TABLEAU_ID_OPTION == 2 ? JSC::min(maxid + 1LL, TABLEAU_ID_UPPER_LIMIT) : 1; ++i) map[i] = 0LL; + for (int i = 0; i < YOUNG_TABLEAU_ID_OPTION == 2 ? ABACUS::min(maxid + 1LL, TABLEAU_ID_UPPER_LIMIT) : 1; ++i) map[i] = 0LL; (*this).Set_to_id(idnr); } */ Young_Tableau::Young_Tableau (const Young_Tableau& RefTableau) // copy constructor - : Nrows(RefTableau.Nrows), Ncols(RefTableau.Ncols), Row_L(new int[RefTableau.Nrows]), Col_L(new int[RefTableau.Ncols]), - id(RefTableau.id), maxid(RefTableau.maxid), - map(new long long int [YOUNG_TABLEAU_ID_OPTION == 2 ? JSC::min(maxid + 1LL, TABLEAU_ID_UPPER_LIMIT) : 1]), - map_computed(RefTableau.map_computed), idnr_reached(RefTableau.idnr_reached), + : Nrows(RefTableau.Nrows), Ncols(RefTableau.Ncols), Row_L(new int[RefTableau.Nrows]), Col_L(new int[RefTableau.Ncols]), + id(RefTableau.id), maxid(RefTableau.maxid), + map(new long long int [YOUNG_TABLEAU_ID_OPTION == 2 ? ABACUS::min(maxid + 1LL, TABLEAU_ID_UPPER_LIMIT) : 1]), + map_computed(RefTableau.map_computed), idnr_reached(RefTableau.idnr_reached), nboxes_reached(RefTableau.nboxes_reached), dimchoose (RefTableau.dimchoose), choose_table(new long long int[(Nrows + Ncols + 1) * dimchoose]) @@ -85,24 +86,24 @@ namespace JSC { for (int i = 0; i < Ncols; ++i) Col_L[i] = RefTableau.Col_L[i]; // Construct the choose_table - for (int cti = 0; cti < Nrows + Ncols + 1; ++cti) + for (int cti = 0; cti < Nrows + Ncols + 1; ++cti) for (int ctj = 0; ctj < dimchoose; ++ctj) { if (cti >= ctj) choose_table[dimchoose * cti + ctj] = choose_lli(cti, ctj); else choose_table[dimchoose * cti + ctj] = 0LL; } // The map: - for (int i = 0; i < (YOUNG_TABLEAU_ID_OPTION == 2 ? JSC::min(maxid + 1LL, TABLEAU_ID_UPPER_LIMIT) : 1); ++i) map[i] = RefTableau.map[i]; + for (int i = 0; i < (YOUNG_TABLEAU_ID_OPTION == 2 ? ABACUS::min(maxid + 1LL, TABLEAU_ID_UPPER_LIMIT) : 1); ++i) map[i] = RefTableau.map[i]; } /* Young_Tableau::Young_Tableau (int Nr, int Nc, long long int* ref_choose_table, int dimref) - : Nrows(Nr), Ncols(Nc), Row_L(new int[Nrows]), Col_L(new int[Ncols]), id(0LL), - maxid(choose_lli(Nr + Nc, Nc) - 1LL), + : Nrows(Nr), Ncols(Nc), Row_L(new int[Nrows]), Col_L(new int[Ncols]), id(0LL), + maxid(choose_lli(Nr + Nc, Nc) - 1LL), //choose_table(new long long int[(Nr + Nc + 1) * (Nr + Nc + 1)]), - choose_table(new long long int[(Nr + Nc + 1) * (JSC::min(Nr, Nc) + 1)]), - //map(new long long int[JSC::min(maxid + 1LL, TABLEAU_ID_UPPER_LIMIT)]), - map(new long long int[YOUNG_TABLEAU_ID_OPTION == 2 ? JSC::min(maxid + 1LL, TABLEAU_ID_UPPER_LIMIT) : 1]), + choose_table(new long long int[(Nr + Nc + 1) * (ABACUS::min(Nr, Nc) + 1)]), + //map(new long long int[ABACUS::min(maxid + 1LL, TABLEAU_ID_UPPER_LIMIT)]), + map(new long long int[YOUNG_TABLEAU_ID_OPTION == 2 ? ABACUS::min(maxid + 1LL, TABLEAU_ID_UPPER_LIMIT) : 1]), map_computed(false), idnr_reached(0LL), nboxes_reached(-1) { @@ -114,31 +115,31 @@ namespace JSC { // Construct the choose_table // Copy entries from reference table - for (int cti = 0; cti < JSC::min(Nr + Nc + 1, dimref); ++cti) - for (int ctj = 0; ctj < JSC::min(Nr + Nc + 1, dimref); ++ctj) + for (int cti = 0; cti < ABACUS::min(Nr + Nc + 1, dimref); ++cti) + for (int ctj = 0; ctj < ABACUS::min(Nr + Nc + 1, dimref); ++ctj) choose_table[(Nr + Nc + 1) * cti + ctj] = cti >= ctj ? ref_choose_table[dimref * cti + ctj] : 0LL; // add missing parts if there are any if (dimref < Nr + Nc + 1) { - for (int cti = 0; cti < Nr + Nc + 1; ++cti) - for (int ctj = dimref; ctj < Nr + Nc + 1; ++ctj) + for (int cti = 0; cti < Nr + Nc + 1; ++cti) + for (int ctj = dimref; ctj < Nr + Nc + 1; ++ctj) choose_table[(Nr + Nc + 1) * cti + ctj] = 0LL; - for (int cti = dimref; cti < Nr + Nc + 1; ++cti) - for (int ctj = 0; ctj < Nr + Nc + 1; ++ctj) + for (int cti = dimref; cti < Nr + Nc + 1; ++cti) + for (int ctj = 0; ctj < Nr + Nc + 1; ++ctj) choose_table[(Nr + Nc + 1) * cti + ctj] = cti >= ctj ? choose_lli(cti, ctj) : 0LL; } - + // The map: - //for (int i = 0; i < JSC::min(maxid + 1LL, TABLEAU_ID_UPPER_LIMIT); ++i) map[i] = 0LL; - for (int i = 0; i < (YOUNG_TABLEAU_ID_OPTION == 2 ? JSC::min(maxid + 1LL, TABLEAU_ID_UPPER_LIMIT) : 1); ++i) map[i] = 0LL; + //for (int i = 0; i < ABACUS::min(maxid + 1LL, TABLEAU_ID_UPPER_LIMIT); ++i) map[i] = 0LL; + for (int i = 0; i < (YOUNG_TABLEAU_ID_OPTION == 2 ? ABACUS::min(maxid + 1LL, TABLEAU_ID_UPPER_LIMIT) : 1); ++i) map[i] = 0LL; } */ Young_Tableau::Young_Tableau (int Nr, int Nc, const Young_Tableau& RefTableau) - : Nrows(Nr), Ncols(Nc), Row_L(new int[Nrows]), Col_L(new int[Ncols]), id(0LL), - maxid(choose_lli(Nr + Nc, Nc) - 1LL), - map(new long long int[YOUNG_TABLEAU_ID_OPTION == 2 ? JSC::min(maxid + 1LL, TABLEAU_ID_UPPER_LIMIT) : 1]), + : Nrows(Nr), Ncols(Nc), Row_L(new int[Nrows]), Col_L(new int[Ncols]), id(0LL), + maxid(choose_lli(Nr + Nc, Nc) - 1LL), + map(new long long int[YOUNG_TABLEAU_ID_OPTION == 2 ? ABACUS::min(maxid + 1LL, TABLEAU_ID_UPPER_LIMIT) : 1]), map_computed(false), idnr_reached(0LL), nboxes_reached(-1), - dimchoose (JSC::min(Nr, Nc) + 1), + dimchoose (ABACUS::min(Nr, Nc) + 1), choose_table(new long long int[(Nr + Nc + 1) * dimchoose]) { // Constructs empty tableau of appropriate size @@ -149,8 +150,8 @@ namespace JSC { // Construct the choose_table // Copy entries from reference table - for (int cti = 0; cti < JSC::min(Nr + Nc + 1, RefTableau.Nrows + RefTableau.Ncols + 1); ++cti) - for (int ctj = 0; ctj < JSC::min(dimchoose, RefTableau.dimchoose); ++ctj) + for (int cti = 0; cti < ABACUS::min(Nr + Nc + 1, RefTableau.Nrows + RefTableau.Ncols + 1); ++cti) + for (int ctj = 0; ctj < ABACUS::min(dimchoose, RefTableau.dimchoose); ++ctj) choose_table[dimchoose * cti + ctj] = cti >= ctj ? RefTableau.choose_table[RefTableau.dimchoose * cti + ctj] : 0LL; // add missing parts if there are any @@ -158,11 +159,11 @@ namespace JSC { for (int cti = 0; cti < Nr + Nc + 1; ++cti) for (int ctj = 0; ctj < dimchoose; ++ctj) - if (cti >= refdim1 || ctj >= RefTableau.dimchoose) + if (cti >= refdim1 || ctj >= RefTableau.dimchoose) choose_table[dimchoose * cti + ctj] = cti >= ctj ? choose_lli(cti, ctj) : 0LL; - + // The map: - for (int i = 0; i < (YOUNG_TABLEAU_ID_OPTION == 2 ? JSC::min(maxid + 1LL, TABLEAU_ID_UPPER_LIMIT) : 1); ++i) map[i] = 0LL; + for (int i = 0; i < (YOUNG_TABLEAU_ID_OPTION == 2 ? ABACUS::min(maxid + 1LL, TABLEAU_ID_UPPER_LIMIT) : 1); ++i) map[i] = 0LL; } Young_Tableau& Young_Tableau::operator= (const Young_Tableau& RefTableau) @@ -181,15 +182,15 @@ namespace JSC { dimchoose = RefTableau.dimchoose; if (choose_table != 0LL) delete[] choose_table; choose_table = new long long int[(Nrows + Ncols + 1) * dimchoose]; - for (int cti = 0; cti < Nrows + Ncols + 1; ++cti) - for (int ctj = 0; ctj < dimchoose; ++ctj) + for (int cti = 0; cti < Nrows + Ncols + 1; ++cti) + for (int ctj = 0; ctj < dimchoose; ++ctj) { choose_table[dimchoose * cti + ctj] = RefTableau.choose_table[dimchoose * cti + ctj]; } if (map != 0LL) delete[] map; - map = new long long int[YOUNG_TABLEAU_ID_OPTION == 2 ? JSC::min(maxid + 1LL, TABLEAU_ID_UPPER_LIMIT) : 1]; - for (long long int i = 0; i < (YOUNG_TABLEAU_ID_OPTION == 2 ? JSC::min(maxid + 1LL, TABLEAU_ID_UPPER_LIMIT) : 1); ++i) map[i] = RefTableau.map[i]; + map = new long long int[YOUNG_TABLEAU_ID_OPTION == 2 ? ABACUS::min(maxid + 1LL, TABLEAU_ID_UPPER_LIMIT) : 1]; + for (long long int i = 0; i < (YOUNG_TABLEAU_ID_OPTION == 2 ? ABACUS::min(maxid + 1LL, TABLEAU_ID_UPPER_LIMIT) : 1); ++i) map[i] = RefTableau.map[i]; map_computed = RefTableau.map_computed; idnr_reached = RefTableau.idnr_reached; nboxes_reached = RefTableau.nboxes_reached; @@ -197,7 +198,7 @@ namespace JSC { if (choose_table[0] != 1LL) { // compute the table - for (int cti = 0; cti < Nrows + Ncols + 1; ++cti) + for (int cti = 0; cti < Nrows + Ncols + 1; ++cti) for (int ctj = 0; ctj < dimchoose; ++ctj) { choose_table[dimchoose * cti + ctj] = cti >= ctj ? choose_lli(cti, ctj) : 0LL; @@ -217,13 +218,13 @@ namespace JSC { //********************************************************************************* // Member functions - + Young_Tableau& Young_Tableau::Compute_Map (long long int idnr_to_reach) { - if (idnr_to_reach < 0LL) JSCerror("negative id requested in Compute_Map"); + if (idnr_to_reach < 0LL) ABACUSerror("negative id requested in Compute_Map"); + + long long int idnr_to_reach_here = ABACUS::min(idnr_to_reach, ABACUS::min(maxid + 1LL, TABLEAU_ID_UPPER_LIMIT)); - long long int idnr_to_reach_here = JSC::min(idnr_to_reach, JSC::min(maxid + 1LL, TABLEAU_ID_UPPER_LIMIT)); - if (!map_computed) { nboxes_reached = -1; idnr_reached = 0LL; @@ -239,12 +240,12 @@ namespace JSC { // Keep a copy of the Tableau, in case... int* old_Row_L = new int[Nrows]; for (int i = 0; i < Nrows; ++i) old_Row_L[i] = Row_L[i]; - - while (idnr_reached <= JSC::min(idnr_to_reach, TABLEAU_ID_UPPER_LIMIT)) { + + while (idnr_reached <= ABACUS::min(idnr_to_reach, TABLEAU_ID_UPPER_LIMIT)) { nboxes_reached++; Distribute_boxes (nboxes_reached, 0); } - + // Reset Row_L for (int i = 0; i < Nrows; ++i) Row_L[i] = old_Row_L[i]; delete[] old_Row_L; @@ -260,27 +261,27 @@ namespace JSC { if (level > Nrows) { // Failed to achieve proper distribution. Do nothing. } - + else if (nboxes_to_dist > Ncols * (Nrows - level)) { cout << Nrows << "\t" << Ncols << "\t" << level << "\t" << nboxes_to_dist << "\t" << idnr_reached << "\t" << nboxes_reached << endl; - JSCerror("nboxes_to_dist too high"); + ABACUSerror("nboxes_to_dist too high"); } else if (nboxes_to_dist == 0) { for (int j = level; j < Nrows; ++j) Row_L[j] = 0; Compute_id (0); if (idnr_reached < TABLEAU_ID_UPPER_LIMIT) map[idnr_reached] = id; - idnr_reached++; + idnr_reached++; } - + else { int maxlength = level == 0 ? Ncols : Row_L[level - 1]; - for (int nboxes_of_level = (nboxes_to_dist - 1)/(Nrows - level) + 1; - nboxes_of_level <= JSC::min(nboxes_to_dist, maxlength); ++nboxes_of_level) { + for (int nboxes_of_level = (nboxes_to_dist - 1)/(Nrows - level) + 1; + nboxes_of_level <= ABACUS::min(nboxes_to_dist, maxlength); ++nboxes_of_level) { Row_L[level] = nboxes_of_level; Distribute_boxes (nboxes_to_dist - nboxes_of_level, level + 1); } - } + } return(*this); } @@ -290,7 +291,7 @@ namespace JSC { return(*this); } - long long int Young_Tableau::Compute_Descendent_id (int option, Vect_INT& Desc_Row_L, int Nrows_Desc, int Ncols_Desc, + long long int Young_Tableau::Compute_Descendent_id (int option, Vect_INT& Desc_Row_L, int Nrows_Desc, int Ncols_Desc, const Young_Tableau& RefTableau) { long long int answer = 0; @@ -301,16 +302,16 @@ namespace JSC { else if (Nrows_Desc == 1) answer = Desc_Row_L[0]; else { int highest_occupied_row = Nrows_Desc - 1; - while (Desc_Row_L[highest_occupied_row] == 0) highest_occupied_row--; // index of highest occupied row; + while (Desc_Row_L[highest_occupied_row] == 0) highest_occupied_row--; // index of highest occupied row; - for (int j = 0; j < Desc_Row_L[highest_occupied_row]; ++j) - answer += RefTableau.choose_table[RefTableau.dimchoose * (highest_occupied_row + Ncols_Desc - j) - + JSC::min(highest_occupied_row, Ncols_Desc - j)]; + for (int j = 0; j < Desc_Row_L[highest_occupied_row]; ++j) + answer += RefTableau.choose_table[RefTableau.dimchoose * (highest_occupied_row + Ncols_Desc - j) + + ABACUS::min(highest_occupied_row, Ncols_Desc - j)]; Vect_INT Desc_Desc_Row_L(highest_occupied_row); for (int i = 0; i < highest_occupied_row; ++i) Desc_Desc_Row_L[i] = Desc_Row_L[i] - Desc_Row_L[highest_occupied_row]; - answer += Compute_Descendent_id (0, Desc_Desc_Row_L, highest_occupied_row, Ncols_Desc - Desc_Row_L[highest_occupied_row], + answer += Compute_Descendent_id (0, Desc_Desc_Row_L, highest_occupied_row, Ncols_Desc - Desc_Row_L[highest_occupied_row], RefTableau); } @@ -319,31 +320,31 @@ namespace JSC { else if (option == 1) { if (Nrows_Desc == 0 || Ncols_Desc == 0) answer = 0; - + else if (Desc_Row_L[0] == 0) answer = 0; - + else if ((Nrows_Desc == 1) || (Desc_Row_L[1] == 0)) answer = Desc_Row_L[0]; - + else { int ndiag = 0; while (Desc_Row_L[ndiag] > ndiag) ndiag++; - + if (ndiag == 1) { int Desc_Col_L_0 = Nrows_Desc; while (Desc_Row_L[Desc_Col_L_0 - 1] == 0) Desc_Col_L_0--; answer = (Desc_Col_L_0 - 1) * Ncols_Desc + Desc_Row_L[0]; } - + else { - - for (int j = 0; j < ndiag; ++j) answer += RefTableau.choose_table[RefTableau.dimchoose * Nrows_Desc + j] + + for (int j = 0; j < ndiag; ++j) answer += RefTableau.choose_table[RefTableau.dimchoose * Nrows_Desc + j] * RefTableau.choose_table[RefTableau.dimchoose * Ncols_Desc + j]; - + Vect_INT Desc1_Row_L(ndiag); for (int i = 0; i < ndiag; ++i) Desc1_Row_L[i] = Desc_Row_L[i] - ndiag; Vect_INT Desc2_Row_L(ndiag); - for (int i = 0; i < ndiag; ++i) { + for (int i = 0; i < ndiag; ++i) { Desc2_Row_L[i] = 0; while(Desc_Row_L[Desc2_Row_L[i] ] > i && Desc2_Row_L[i] < Ncols_Desc) Desc2_Row_L[i]++; Desc2_Row_L[i] -= ndiag; @@ -354,10 +355,10 @@ namespace JSC { answer += Desc2_id * RefTableau.choose_table[RefTableau.dimchoose * Ncols_Desc + ndiag] + Desc1_id; } } - + } // else if (option == 1) - else JSCerror("Wrong option in Young_Tableau::Compute_Descendent_id"); + else ABACUSerror("Wrong option in Young_Tableau::Compute_Descendent_id"); return(answer); } @@ -366,22 +367,22 @@ namespace JSC { { long long int idnr = 0; - + if (option == 0) { if (Nrows == 0) idnr = 0; - + else if (Row_L[0] == 0) idnr = 0; - + else if (Nrows == 1) idnr = Row_L[0]; - + else { - + int highest_occupied_row = Nrows - 1; - while (Row_L[highest_occupied_row] == 0) highest_occupied_row--; // index of highest occupied row; + while (Row_L[highest_occupied_row] == 0) highest_occupied_row--; // index of highest occupied row; for (int j = 0; j < Row_L[highest_occupied_row]; ++j) idnr += choose_table[dimchoose * (highest_occupied_row + Ncols - j) - + JSC::min(highest_occupied_row, Ncols - j)]; + + ABACUS::min(highest_occupied_row, Ncols - j)]; Vect_INT Desc_Row_L(highest_occupied_row); @@ -389,28 +390,28 @@ namespace JSC { idnr += Compute_Descendent_id (0, Desc_Row_L, highest_occupied_row, Ncols - Row_L[highest_occupied_row], (*this)); } - } - + } + else if (option == 1) { - + if (Nrows == 0 || Ncols == 0) idnr = 0; - + else if (Row_L[0] == 0) idnr = 0; - + else if ((Nrows == 1) || (Row_L[1] == 0)) idnr = Row_L[0]; - + else { int ndiag = 0; while (Row_L[ndiag] > ndiag) ndiag++; - + if (ndiag == 1) { idnr = (Col_L[0] - 1) * Ncols + Row_L[0]; } - + else { - + for (int j = 0; j < ndiag; ++j) idnr += choose_table[dimchoose * Nrows + j] * choose_table[dimchoose * Ncols + j]; - + Vect_INT Desc1_Row_L(ndiag); for (int i = 0; i < ndiag; ++i) Desc1_Row_L[i] = Row_L[i] - ndiag; @@ -422,22 +423,22 @@ namespace JSC { idnr += Desc2_id * choose_table[dimchoose * Ncols + ndiag] + Desc1_id; } } - + } // else if (option == 1) - + else if (option == 2) { - + // The order here is given by first listing all tableaux with 0 boxes, then 1, 2, ... by using Map Compute_id (0); // sets the id according to rule 0 Compute_Map (idnr); // make sure the state map is computed - while (map[idnr] != id && idnr < JSC::min(maxid + 1LL, TABLEAU_ID_UPPER_LIMIT)) idnr++; // match with inverse map to get the idnr according to rule 2 + while (map[idnr] != id && idnr < ABACUS::min(maxid + 1LL, TABLEAU_ID_UPPER_LIMIT)) idnr++; // match with inverse map to get the idnr according to rule 2 } - - else JSCerror("Wrong option for Tableau ids"); - + + else ABACUSerror("Wrong option for Tableau ids"); + id = idnr; - + return (*this); } @@ -446,7 +447,7 @@ namespace JSC { Set_to_id (idnr, 0); return(*this); } - + Young_Tableau& Young_Tableau::Set_to_id (long long int idnr, int option) // sets the tableau to the one corresponding to idnr { @@ -454,28 +455,28 @@ namespace JSC { if ((idnr < 0) || ((maxid < idnr) && (Nrows*Ncols != 0))) { cout << "Nrows = " << Nrows << "\tNcols = " << Ncols << "\tmaxid = " << maxid << "\trequested id = " << idnr << endl; - JSCerror("Wrong idnr in Set_to_id for Young Tableau."); + ABACUSerror("Wrong idnr in Set_to_id for Young Tableau."); } id = idnr; - + int NColumnseff = Ncols; long long int ideff = idnr; - + for (int i = 0; i < Ncols; ++i) { if (ideff == 0) Col_L[i] = 0; - + else { - + int nbar = 0; - + if (ideff <= 0) nbar = 0; - - while (ideff >= choose_table[dimchoose * (NColumnseff + nbar) + JSC::min(NColumnseff, nbar)]) nbar++; + + while (ideff >= choose_table[dimchoose * (NColumnseff + nbar) + ABACUS::min(NColumnseff, nbar)]) nbar++; Col_L[i] = nbar; - ideff -= choose_table[dimchoose * (NColumnseff + Col_L[i] - 1) + JSC::min(NColumnseff, Col_L[i] - 1)]; + ideff -= choose_table[dimchoose * (NColumnseff + Col_L[i] - 1) + ABACUS::min(NColumnseff, Col_L[i] - 1)]; NColumnseff--; } @@ -488,58 +489,58 @@ namespace JSC { else if (option == 1) { - if ((idnr < 0LL) || ((maxid < idnr) && (Nrows*Ncols != 0))) JSCerror("Wrong idnr in Set_to_id for Young Tableau."); - - if (Nrows*Ncols == 0 && idnr != 0LL) JSCerror("Trying nonzero id on empty Tableau."); - + if ((idnr < 0LL) || ((maxid < idnr) && (Nrows*Ncols != 0))) ABACUSerror("Wrong idnr in Set_to_id for Young Tableau."); + + if (Nrows*Ncols == 0 && idnr != 0LL) ABACUSerror("Trying nonzero id on empty Tableau."); + id = idnr; - + if (idnr == 0LL) { for (int i = 0; i < Nrows; ++i) Row_L[i] = 0; for (int i = 0; i < Ncols; ++i) Col_L[i] = 0; } - + else { int ndiag = 0; - int sum = 0; + int sum = 0; while ((sum < idnr) && (ndiag < Nrows) && (ndiag < Ncols)) { ndiag++; sum += choose_table[dimchoose * Nrows + ndiag] * choose_table[dimchoose * Ncols + ndiag]; } - + long long int residual_id = idnr - 1 - sum + choose_table[dimchoose * Nrows + ndiag] * choose_table[dimchoose * Ncols + ndiag]; - - if (ndiag == 0 && idnr != 0LL) JSCerror("Zero ndiag for nonzero idnr in Tableau."); - + + if (ndiag == 0 && idnr != 0LL) ABACUSerror("Zero ndiag for nonzero idnr in Tableau."); + else if (ndiag == 1) { if (Nrows >= Ncols) { - Col_L[0] = (idnr - 1)/Ncols + 1; + Col_L[0] = (idnr - 1)/Ncols + 1; for (int i = 1; i < idnr - Ncols * (Col_L[0] - 1); ++i) Col_L[i] = 1; for (int i = idnr - Ncols * (Col_L[0] - 1); i < Ncols; ++i) Col_L[i] = 0; (*this).Set_Row_L_given_Col_L(); } else if (Nrows < Ncols) { - Row_L[0] = (idnr - 1)/Nrows + 1; + Row_L[0] = (idnr - 1)/Nrows + 1; for (int i = 1; i < idnr - Nrows * (Row_L[0] - 1); ++i) Row_L[i] = 1; for (int i = idnr - Nrows * (Row_L[0] - 1); i < Nrows; ++i) Row_L[i] = 0; (*this).Set_Col_L_given_Row_L(); } } - + else { - + Young_Tableau Residual1(ndiag, Ncols - ndiag); Young_Tableau Residual2(ndiag, Nrows - ndiag); - + Residual2.Set_to_id(residual_id/(Residual1.maxid + 1LL)); residual_id -= (Residual1.maxid + 1LL) * Residual2.id; Residual1.Set_to_id(residual_id); - + for (int i = 0; i < ndiag; ++i) Row_L[i] = ndiag + Residual1.Row_L[i]; for (int i = 0; i < Residual2.Ncols; ++i) Row_L[ndiag + i] = Residual2.Col_L[i]; - + (*this).Set_Col_L_given_Row_L(); - + } } } // else if (option == 1) @@ -547,23 +548,23 @@ namespace JSC { else if (option == 2) { Compute_Map (idnr); // make sure the state map is computed - (*this).Set_to_id (map[idnr], 0); + (*this).Set_to_id (map[idnr], 0); id = idnr; } - else JSCerror("Wrong option for Tableau id in Set_to_id"); + else ABACUSerror("Wrong option for Tableau id in Set_to_id"); return(*this); } Young_Tableau& Young_Tableau::Set_Row_L (Vect_INT& Row_Lengths) // set row lengths to elements of given vector { - if (Row_Lengths.size() != Nrows) JSCerror("Vector of incompatible dimension used to initialize Young Tableau."); + if (Row_Lengths.size() != Nrows) ABACUSerror("Vector of incompatible dimension used to initialize Young Tableau."); + + for (int i = 0; i < Row_Lengths.size() - 1; ++i) if (Row_Lengths[i] < Row_Lengths[i+1]) ABACUSerror("Vector is not a proper Young tableau."); - for (int i = 0; i < Row_Lengths.size() - 1; ++i) if (Row_Lengths[i] < Row_Lengths[i+1]) JSCerror("Vector is not a proper Young tableau."); - for (int i = 0; i < Nrows; ++i) Row_L[i] = Row_Lengths[i]; (*this).Set_Col_L_given_Row_L(); @@ -627,7 +628,7 @@ namespace JSC { // Recomputes id. if (id == 0LL || Nrows == 0 || Ncols == 0) return(false); // Tableau is empty - if (i < 0 || i >= Nrows) JSCerror("Trying to Lower_Row of out of bounds index."); + if (i < 0 || i >= Nrows) ABACUSerror("Trying to Lower_Row of out of bounds index."); if (Row_L[i] < 1 || (i < Nrows - 1 && Row_L[i+1] == Row_L[i])) // can't lower Row_L, breaks tableau rules return(false); else { @@ -638,14 +639,14 @@ namespace JSC { } return(false); } - + bool Young_Tableau::Raise_Row (int i) { // Adds a box to row i. Returns success boolean. // Recomputes id. if (Nrows == 0 || Ncols == 0) return(false); // Tableau is empty - if (i < 0 || i >= Nrows) JSCerror("Trying to Raise_Row of out of bounds index."); + if (i < 0 || i >= Nrows) ABACUSerror("Trying to Raise_Row of out of bounds index."); if (Row_L[i] == Ncols || (i > 1 && Row_L[i-1] == Row_L[i])) // can't raise Row_L, breaks tableau rules return(false); else { @@ -656,21 +657,21 @@ namespace JSC { } return(false); } - + bool Young_Tableau::Raise_Lowest_Nonzero_Row() - { + { // adds a box to the lowest nonzero length Row, recomputes id, returns true if tableau has changed //cout << "Check before: "; (*this).Print(); - + if (id == 0LL || Nrows == 0 || Ncols == 0) return(false); // Tableau is empty // otherwise find the lowest nonzero row: int iln0r = Nrows - 1; while (Row_L[iln0r] == 0 && iln0r >= 0) iln0r--; - if (iln0r < 0) JSCerror("id wrongly set in Young_Tableau (Raise_Lowest_Nonzero_Row)."); + if (iln0r < 0) ABACUSerror("id wrongly set in Young_Tableau (Raise_Lowest_Nonzero_Row)."); // This should not happen, since if iln0r == -1, id should be 0. else if (iln0r == 0 && Row_L[0] < Ncols || iln0r > 0 && Row_L[iln0r - 1] > Row_L[iln0r]) { // there is space for at least one more box ! @@ -687,7 +688,7 @@ namespace JSC { } bool Young_Tableau::Raise_Next_to_Lowest_Nonzero_Row() - { + { // same thing, but for Row under lowest nonzero length one. // Important: allow raising first row if tableau is empty. @@ -701,10 +702,10 @@ namespace JSC { while (Row_L[iln0r] == 0 && iln0r >= 0) iln0r--; //cout << "iln0r = " << iln0r << "\t" << Row_L[iln0r] << "\t" << Row_L[iln0r + 1] << endl; - + //if (iln0r == Nrows - 1) return(false); // no row under that one; allow raising of row 0 - if (iln0r == -1 && Row_L[0] < Ncols || iln0r >= 0 && iln0r < Nrows - 1 && Row_L[iln0r] > Row_L[iln0r + 1]) { + if (iln0r == -1 && Row_L[0] < Ncols || iln0r >= 0 && iln0r < Nrows - 1 && Row_L[iln0r] > Row_L[iln0r + 1]) { // there is space for at least one more box ! Row_L[iln0r + 1] += 1; Set_Col_L_given_Row_L(); @@ -715,17 +716,17 @@ namespace JSC { return(true); } - return(false); + return(false); } bool Young_Tableau::Move_Box_from_Col_to_Col (int ifrom, int ito) { // Moves a box from column ifrom to column ito. Recomputes id. // If fails: returns false, leaves Tableau unchanged. - + if (!(ifrom >= 0 && ifrom < Ncols && ito >= 0 && ito < Ncols)) return(false); - + else { // try it out int* Col_L_check = new int[Ncols]; for (int i = 0; i < Ncols; ++i) Col_L_check[i] = Col_L[i]; @@ -745,7 +746,7 @@ namespace JSC { Vect Young_Tableau::Descendents (int fixed_Nboxes) { - // Produces a vector of Young_Tableau which are the descendents of + // Produces a vector of Young_Tableau which are the descendents of // the (*this) object. If the number of boxes is not fixed, there // are up to 2 decendents. If the number of boxes is fixed, there // can be many more. @@ -784,27 +785,27 @@ namespace JSC { for (int i = 0; i < Nrows; ++i) Nboxes_tot += Row_L[i]; int Nboxes_above = 0; for (int level = 0; level < Nrows; ++level) { - Tableau_zero.Row_L[level] = JSC::min(Nboxes_tot - Nboxes_above, Ncols); + Tableau_zero.Row_L[level] = ABACUS::min(Nboxes_tot - Nboxes_above, Ncols); Nboxes_above += Tableau_zero.Row_L[level]; } Tableau_zero.Set_Col_L_given_Row_L(); int level_bdry = 0; - for (int level = 0; level < Nrows; ++level) + for (int level = 0; level < Nrows; ++level) if (Row_L[level] < Tableau_zero.Row_L[level]) level_bdry = level; - int right_bdry = JSC::min(Row_L[level_bdry] + 1, Ncols - 1); - // We can now displace a box from right to left, starting from + int right_bdry = ABACUS::min(Row_L[level_bdry] + 1, Ncols - 1); + // We can now displace a box from right to left, starting from // a column with index <= right_bdry. int left_bdry = 0; - for (int level = 0; level < Ncols; ++level) + for (int level = 0; level < Ncols; ++level) if (Col_L[level] > Tableau_zero.Col_L[level]) left_bdry = level; // We can put a box into a column with index >= left_bdry // Now do the descendents: Vect Tableau_desc_init ((right_bdry - left_bdry) * (right_bdry - left_bdry)); Young_Tableau Tableau_ref = (*this); - Young_Tableau Tableau_check = (*this); + Young_Tableau Tableau_check = (*this); for (int ifrom = right_bdry; ifrom >= left_bdry + 1; --ifrom) for (int ito = ifrom - 1; ito >= left_bdry; --ito) { if (Tableau_check.Move_Box_from_Col_to_Col (ifrom, ito)) { @@ -825,13 +826,13 @@ namespace JSC { Vect Young_Tableau::Descendents_Boosted_State (int fixed_Nboxes) { - // Produces a vector of Young_Tableau which are the descendents of + // Produces a vector of Young_Tableau which are the descendents of // the (*this) object. If the number of boxes is not fixed, there // are up to 2 decendents. If the number of boxes is fixed, there // can be many more. // IMPORTANT ASSUMPTIONS: - // (*this) is (or is descended from) a boosted state. The only + // (*this) is (or is descended from) a boosted state. The only // descendents considered here are thus those for which the raised // box is the highest still occupied box of the originally boosted state. @@ -845,7 +846,7 @@ namespace JSC { for (int i = 0; i < Nrows; ++i) Nboxes += Row_L[i]; if (Nboxes == 0) return(Vect (0)); - + // Look for the level with the highest as yet unraised box of initial // boosted state: @@ -854,7 +855,7 @@ namespace JSC { while (Row_L[level_from] == Ncols) level_from++; // necessarily is a row length < Ncols - if (Row_L[level_from] == 0) level_from--; // if row empty or beyond limit, go back one + if (Row_L[level_from] == 0) level_from--; // if row empty or beyond limit, go back one if (!fixed_Nboxes) { // The convention here is that we *remove* the highest yet unraised box only @@ -871,7 +872,7 @@ namespace JSC { Tableau_desc[0] = descendent_attempt; return(Tableau_desc); } - else if (ndesc != 0) JSCerror("There should be either 0 or 1 descendents in Descended_Boosted_State with fixed_iK == true."); + else if (ndesc != 0) ABACUSerror("There should be either 0 or 1 descendents in Descended_Boosted_State with fixed_iK == true."); } // if (!fixed_Nboxes) @@ -893,7 +894,7 @@ namespace JSC { if (ndesc > 0) { Vect Tableau_desc(ndesc); if (check1) Tableau_desc[0] = Tableau_check1; - if (check2) Tableau_desc[ndesc - 1] = Tableau_check2; // only up to 2 descendents + if (check2) Tableau_desc[ndesc - 1] = Tableau_check2; // only up to 2 descendents return(Tableau_desc); } @@ -902,7 +903,7 @@ namespace JSC { return(Vect (0)); } - int Young_Tableau::Add_Boxes_From_Lowest (int Nboxes) + int Young_Tableau::Add_Boxes_From_Lowest (int Nboxes) { // tries to add Nboxes to Tableau, returns number of boxes added. if (Ncols == 0 || Nrows == 0) return(0); // can't do anything ! @@ -913,7 +914,7 @@ namespace JSC { int previous_Row_L = 0; for (int working_level = 0; working_level < Nrows; ++working_level) { previous_Row_L = Row_L[working_level]; - Row_L[working_level] = JSC::min(previous_Row_L + Nboxes - Nboxes_added, Ncols); + Row_L[working_level] = ABACUS::min(previous_Row_L + Nboxes - Nboxes_added, Ncols); Nboxes_added += Row_L[working_level] - previous_Row_L; if (Nboxes_added == Nboxes) break; } @@ -923,4 +924,4 @@ namespace JSC { return(Nboxes_added); } -} // namespace JSC +} // namespace ABACUS