-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathchiptfuncs.hpp
131 lines (117 loc) · 6.12 KB
/
chiptfuncs.hpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
#ifndef _CHIPTFUNCS
#define _CHIPTFUNCS
namespace pertutils{
//******************************************************************
//******************************************************************
//START chiPT FV functions
//******************************************************************
//******************************************************************
class Xifunc{
private:
double MLsqmin, MLsqmax, MLcount, MLstep, s;
Vector<double> xvec, yvec;
spline_interp* interpolation;
public:
Xifunc(double MLSQMIN, double MLSQMAX, int MLCOUNT, double ss);
Xifunc(::std::string filename);
int writefile(::std::string filename);
double operator()(const double Msq, const double L);
double get(const double Msq, const double L);
double get_MLsqmin();
double get_MLsqmax();
double get_s();
~Xifunc();
};
class Xifuncintegrandtransformed : public TFunctor{
private:
double MLsq, s;
int flag;
public:
Xifuncintegrandtransformed(const double MLML, const double ss, int fflag) : MLsq(MLML), s(ss), flag(fflag) {};
double operator()(const double t);
};
double Xifuncintegrand(double tau, double MLsq, double s);
double Xifuncnorm(double,double,int flag=0);
//Colangelo+Stephan
const int multiplicities[301]={1,6,12,8,6,24,24,0,12,30,24,24,8,24,48,0,6,48,36,24,24,48,24,0,24,30,72,32,0,72,48,0,12,48,48,48,30,24,72,0,24,96,48,24,24,72,48,0,8,54,84,48,24,72,96,0,48,48,24,72,0,72,96,0,6,96,96,24,48,96,48,0,36,48,120,56,24,96,48,0,24,102,48,72,48,48,120,0,24,144,120,48,0,48,96,0,24,48,108,72,30,168,48,0,72,96,72,72,32,72,144,0,0,96,96,48,72,120,72,0,48,78,120,48,0,144,144,0,12,144,48,120,48,48,168,0,48,96,96,72,48,96,48,0,30,96,192,56,24,168,120,0,72,144,96,96,0,72,96,0,24,192,108,24,96,96,120,0,48,78,144,120,24,168,144,0,24,48,96,120,72,120,144,0,48,192,144,48,0,192,48,0,8,48,240,96,54,120,120,0,84,144,72,96,48,96,240,0,24,240,96,72,72,96,72,0,96,96,120,96,0,192,144,0,48,150,96,120,48,120,240,0,24,144,216,48,72,144,96,0,0,144,132,104,72,168,144,0,96,144,144,168,0,48,192,0,6,192,96,96,96,216,72,0,96,96,240,48,24,264,192,0,48,96,144,120,96,72,168,0,48,240,96,72,0,192,144,0,36,102,240,96,48,216,168,0,120,192,72,192,56};
double Ikfunc2(int n, double mpiL);
double Ipifunc2(int n, double mpiL);
double mpiLovermpi(double mpi, double fpi, double L);
double mkLovermk(double mpi, double mk, double fpi, double L);
double fkLoverfk(double mpi, double fpi, double fk, double L);
double fpiLoverfpi(double mpi, double fpi, double L);
//******************************************************************
//******************************************************************
//END chiPT FV functions
//******************************************************************
//******************************************************************
//******************************************************************
//******************************************************************
//START Zeta-function on a torus
//******************************************************************
//******************************************************************
//implementation of expression (5) in arXiv:1107.5023, first the integrand:
struct Zetafuncint : TFunctor{
double qsq, ghatwnorm;
int l;
bool improved;
Zetafuncint() : improved(false){};
Zetafuncint(const double q2, const double ghatw, const int lval, const bool imprvd=false) : qsq(q2), ghatwnorm(ghatw), l(lval), improved(imprvd){};
void set(const double q2, const double ghatw, const int lval, const bool imprvd=false){
qsq=q2;
ghatwnorm=ghatw;
l=lval;
improved=imprvd;
}
double operator()(const double t){
if(!improved) return ::std::pow(t,-(1.5+static_cast<double>(l)))*::std::exp(t*qsq)*::std::exp(-sqr(pimath*ghatwnorm)/t);
else return ::std::pow(t,-1.5)*::std::exp(t*qsq)*::std::pow((EllipticTheta(sqr(pimath)/t)-1.),3.);
};
};
class Zetafunc{
private:
threevec<double> boost;
bool is_improved, is_zeroboost;
double gamma,lambda;
dcomplex term1val,term2val,term3val;
int l,m;
int MAXRUN;
dcomplex term1full(const double q2);
dcomplex term1noboost(const double q2);
double term1spherical(const double q2);
double term2full(const double q2);
dcomplex term3full(const double q2);
dcomplex term3noboost(const double q2);
double term3spherical(const double q2);
public:
Zetafunc(const int ll, const int mm, const double gammaa=1., const threevec<double> boostvec=threevec<double>(0.,0.,0.), const double lambdaa=1., const int maxrun=10) : boost(boostvec), gamma(gammaa), lambda(lambdaa), l(ll), m(mm), MAXRUN(maxrun) {
if( (l==0) && (m==0) ){
is_improved=true;
}
else{
is_improved=false;
}
if(boost.norm()< ::std::numeric_limits<double>::epsilon()){
is_zeroboost=true;
gamma=1.;
}
else is_zeroboost=false;
term1val(0.,0.);
term2val(0.,0.);
term3val(0.,0.);
};
dcomplex operator()(const double q2);
void set_numterms_sum(const int run);
void set_boost(const threevec<double> boostvec, const double gammaa);
void print_contributions();
double getGamma()const{ return gamma;}
threevec<double> getBoost()const{ return boost;}
friend double qromb(double &func, double a, double b, const double eps);
};
//******************************************************************
//******************************************************************
//END Zeta-function on a torus
//******************************************************************
//******************************************************************
}
#endif