mirror of
				https://github.com/aportelli/LatAnalyze.git
				synced 2025-10-25 05:39:34 +01:00 
			
		
		
		
	Added cotanh fit function
This commit is contained in:
		| @@ -16,7 +16,7 @@ int main(int argc, char *argv[]) | |||||||
|     // parse arguments ///////////////////////////////////////////////////////// |     // parse arguments ///////////////////////////////////////////////////////// | ||||||
|     OptParser            opt; |     OptParser            opt; | ||||||
|     bool                 parsed, doPlot, doHeatmap, doCorr, fold; |     bool                 parsed, doPlot, doHeatmap, doCorr, fold; | ||||||
|     string               corrFileName, model, outFileName, outFmt; |     string               corrFileName, model, outFileName, outFmt, save; | ||||||
|     Index                ti, tf, shift, nPar, thinning; |     Index                ti, tf, shift, nPar, thinning; | ||||||
|     double               svdTol; |     double               svdTol; | ||||||
|     Minimizer::Verbosity verbosity; |     Minimizer::Verbosity verbosity; | ||||||
| @@ -30,7 +30,7 @@ int main(int argc, char *argv[]) | |||||||
|     opt.addOption("s", "shift"    , OptParser::OptType::value  , true, |     opt.addOption("s", "shift"    , OptParser::OptType::value  , true, | ||||||
|                   "time variable shift", "0"); |                   "time variable shift", "0"); | ||||||
|     opt.addOption("m", "model"    , OptParser::OptType::value  , true, |     opt.addOption("m", "model"    , OptParser::OptType::value  , true, | ||||||
|                   "fit model (exp|exp2|exp3|cosh|cosh2|cosh3|explin|const|<interpreter code>)", "cosh"); |                   "fit model (exp|exp2|exp3|sinh|cosh|cosh2|cosh3|cotanh|explin|const|<interpreter code>)", "cosh"); | ||||||
|     opt.addOption("" , "nPar"     , OptParser::OptType::value  , true, |     opt.addOption("" , "nPar"     , OptParser::OptType::value  , true, | ||||||
|                   "number of model parameters for custom models " |                   "number of model parameters for custom models " | ||||||
|                   "(-1 if irrelevant)", "-1"); |                   "(-1 if irrelevant)", "-1"); | ||||||
| @@ -48,6 +48,8 @@ int main(int argc, char *argv[]) | |||||||
|                   "show the fit plot"); |                   "show the fit plot"); | ||||||
|     opt.addOption("h", "heatmap"  , OptParser::OptType::trigger, true, |     opt.addOption("h", "heatmap"  , OptParser::OptType::trigger, true, | ||||||
|                   "show the fit correlation heatmap"); |                   "show the fit correlation heatmap"); | ||||||
|  |     opt.addOption("s", "save", OptParser::OptType::value, true, | ||||||
|  |                     "saves the source and .pdf", ""); | ||||||
|     opt.addOption("", "help"      , OptParser::OptType::trigger, true, |     opt.addOption("", "help"      , OptParser::OptType::trigger, true, | ||||||
|                   "show this help message and exit"); |                   "show this help message and exit"); | ||||||
|     parsed = opt.parse(argc, argv); |     parsed = opt.parse(argc, argv); | ||||||
| @@ -71,6 +73,7 @@ int main(int argc, char *argv[]) | |||||||
|     fold         = opt.gotOption("fold"); |     fold         = opt.gotOption("fold"); | ||||||
|     doPlot       = opt.gotOption("p"); |     doPlot       = opt.gotOption("p"); | ||||||
|     doHeatmap    = opt.gotOption("h"); |     doHeatmap    = opt.gotOption("h"); | ||||||
|  |     save         = opt.optionValue("s"); | ||||||
|     switch (opt.optionValue<unsigned int>("v")) |     switch (opt.optionValue<unsigned int>("v")) | ||||||
|     { |     { | ||||||
|         case 0: |         case 0: | ||||||
| @@ -117,7 +120,7 @@ int main(int argc, char *argv[]) | |||||||
|      |      | ||||||
|     // make model ////////////////////////////////////////////////////////////// |     // make model ////////////////////////////////////////////////////////////// | ||||||
|     DoubleModel mod; |     DoubleModel mod; | ||||||
|     bool        coshModel = false, linearModel = false, constModel = false; |     bool        sinhModel = false, coshModel = false, cotanhModel = false, linearModel = false, constModel = false; | ||||||
|      |      | ||||||
|     if ((model == "exp") or (model == "exp1")) |     if ((model == "exp") or (model == "exp1")) | ||||||
|     { |     { | ||||||
| @@ -144,6 +147,15 @@ int main(int argc, char *argv[]) | |||||||
|                                    + p[5]*exp(-p[4]*x[0]); |                                    + p[5]*exp(-p[4]*x[0]); | ||||||
|                         }, 1, nPar); |                         }, 1, nPar); | ||||||
|     } |     } | ||||||
|  |     else if (model == "sinh") | ||||||
|  |     { | ||||||
|  |         sinhModel = true; | ||||||
|  |         nPar      = 2; | ||||||
|  |         mod.setFunction([nt](const double *x, const double *p) | ||||||
|  |                         { | ||||||
|  |                             return p[1]*(exp(-p[0]*x[0])-exp(-p[0]*(nt-x[0]))); | ||||||
|  |                         }, 1, nPar); | ||||||
|  |     } | ||||||
|     else if ((model == "cosh") or (model == "cosh1")) |     else if ((model == "cosh") or (model == "cosh1")) | ||||||
|     { |     { | ||||||
|         coshModel = true; |         coshModel = true; | ||||||
| @@ -174,6 +186,15 @@ int main(int argc, char *argv[]) | |||||||
|                                  + p[5]*(exp(-p[2]*x[0])+exp(-p[4]*(nt-x[0]))); |                                  + p[5]*(exp(-p[2]*x[0])+exp(-p[4]*(nt-x[0]))); | ||||||
|                         }, 1, nPar); |                         }, 1, nPar); | ||||||
|     } |     } | ||||||
|  |     else if (model == "cotanh") | ||||||
|  |     { | ||||||
|  |         cotanhModel = true; | ||||||
|  |         nPar        = 2; | ||||||
|  |         mod.setFunction([nt](const double *x, const double *p) | ||||||
|  |                         { | ||||||
|  |                             return p[0] + p[1]/tanh(0.1892*(nt/2-x[0])); // 0.1892 is the meson eff mass in lattice unit from 2pt fit | ||||||
|  |                         }, 1, nPar); | ||||||
|  |     } | ||||||
|     else if (model == "explin") |     else if (model == "explin") | ||||||
|     { |     { | ||||||
|         linearModel = true; |         linearModel = true; | ||||||
| @@ -247,6 +268,11 @@ int main(int argc, char *argv[]) | |||||||
|         init(0) = data.y(nt/4, 0)[central]; |         init(0) = data.y(nt/4, 0)[central]; | ||||||
|  |  | ||||||
|     } |     } | ||||||
|  |     else if(cotanhModel) | ||||||
|  |     { | ||||||
|  |         init(0) = 0.5*(data.y(0, 0)[central]+ data.y(nt-1, 0)[central]); | ||||||
|  |         init(1) = 0.5*(data.y(0, 0)[central]- data.y(nt-1, 0)[central]); | ||||||
|  |      } | ||||||
|     else |     else | ||||||
|     { |     { | ||||||
|         init(0) = log(data.y(nt/4, 0)[central]/data.y(nt/4 + 1, 0)[central]); |         init(0) = log(data.y(nt/4, 0)[central]/data.y(nt/4 + 1, 0)[central]); | ||||||
| @@ -269,9 +295,14 @@ int main(int argc, char *argv[]) | |||||||
|         { |         { | ||||||
|             globMin.setLowLimit(p, -10*fabs(init(0))); |             globMin.setLowLimit(p, -10*fabs(init(0))); | ||||||
|             locMin.setLowLimit(p, -10*fabs(init(0))); |             locMin.setLowLimit(p, -10*fabs(init(0))); | ||||||
|             // cout << "Suppressing low limits" << endl; |  | ||||||
|             globMin.setHighLimit(p, 10*fabs(init(0))); |             globMin.setHighLimit(p, 10*fabs(init(0))); | ||||||
|         } |         } | ||||||
|  |         else if(cotanhModel) | ||||||
|  |         { | ||||||
|  |             globMin.setLowLimit(p,-0.5); | ||||||
|  |             locMin.setLowLimit(p, -0.3); | ||||||
|  |             globMin.setHighLimit(p,1); | ||||||
|  |         } | ||||||
|         else |         else | ||||||
|         { |         { | ||||||
|             globMin.setLowLimit(p, 0.); |             globMin.setLowLimit(p, 0.); | ||||||
| @@ -328,6 +359,11 @@ int main(int argc, char *argv[]) | |||||||
|         p << Color("rgb 'blue'") << PlotFunction(fit.getModel(), 0, nt - 1); |         p << Color("rgb 'blue'") << PlotFunction(fit.getModel(), 0, nt - 1); | ||||||
|         p << Color("rgb 'red'")  << PlotData(data.getData()); |         p << Color("rgb 'red'")  << PlotData(data.getData()); | ||||||
|         p.display(); |         p.display(); | ||||||
|  |         if(save != "") | ||||||
|  |         { | ||||||
|  |             cout << "Saving plot and source code to " << save << endl; | ||||||
|  |             p.save(save); | ||||||
|  |         } | ||||||
|         // effective mass plot ////////////////////////////////////////////////////// |         // effective mass plot ////////////////////////////////////////////////////// | ||||||
|         if (!constModel) |         if (!constModel) | ||||||
|         { |         { | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user