1
0
mirror of https://github.com/paboyle/Grid.git synced 2025-04-09 21:50:45 +01:00

First implementation of the scalar QED propagator, runs but absolutely not checked

This commit is contained in:
Antonin Portelli 2017-01-12 20:44:23 +00:00
parent 889d828bc2
commit 65987a8a58
2 changed files with 115 additions and 20 deletions

View File

@ -32,23 +32,28 @@ std::vector<std::string> TChargedProp::getOutput(void)
void TChargedProp::setup(void) void TChargedProp::setup(void)
{ {
freeMomPropName_ = FREEMOMPROP(par().mass); freeMomPropName_ = FREEMOMPROP(par().mass);
shiftedMomPropName_.clear(); phaseName_.clear();
for (unsigned int mu = 0; mu < env().getNd(); ++mu) for (unsigned int mu = 0; mu < env().getNd(); ++mu)
{ {
shiftedMomPropName_.push_back(freeMomPropName_ + "_" phaseName_.push_back(freeMomPropName_ + "_"
+ std::to_string(mu)); + std::to_string(mu));
} }
GFSrcName_ = "_" + getName() + "_DinvSrc";
if (!env().hasRegisteredObject(freeMomPropName_)) if (!env().hasRegisteredObject(freeMomPropName_))
{ {
env().registerLattice<ScalarField>(freeMomPropName_); env().registerLattice<ScalarField>(freeMomPropName_);
} }
if (!env().hasRegisteredObject(shiftedMomPropName_[0])) if (!env().hasRegisteredObject(phaseName_[0]))
{ {
for (unsigned int mu = 0; mu < env().getNd(); ++mu) for (unsigned int mu = 0; mu < env().getNd(); ++mu)
{ {
env().registerLattice<ScalarField>(shiftedMomPropName_[mu]); env().registerLattice<ScalarField>(phaseName_[mu]);
} }
} }
if (!env().hasRegisteredObject(GFSrcName_))
{
env().registerLattice<ScalarField>(GFSrcName_);
}
env().registerLattice<ScalarField>(getName()); env().registerLattice<ScalarField>(getName());
} }
@ -56,24 +61,26 @@ void TChargedProp::setup(void)
// execution /////////////////////////////////////////////////////////////////// // execution ///////////////////////////////////////////////////////////////////
void TChargedProp::execute(void) void TChargedProp::execute(void)
{ {
// CACHING ANALYTIC EXPRESSIONS
ScalarField &prop = *env().createLattice<ScalarField>(getName()); ScalarField &prop = *env().createLattice<ScalarField>(getName());
ScalarField &source = *env().getObject<ScalarField>(par().source); ScalarField &source = *env().getObject<ScalarField>(par().source);
ScalarField *freeMomProp; Complex ci(0.0,1.0);
std::vector<ScalarField *> shiftedMomProp; FFT fft(env().getGrid());
Complex ci(0.0,1.0);
// cache free scalar propagator
if (!env().hasCreatedObject(freeMomPropName_)) if (!env().hasCreatedObject(freeMomPropName_))
{ {
LOG(Message) << "Caching momentum space free scalar propagator" LOG(Message) << "Caching momentum space free scalar propagator"
<< " (mass= " << par().mass << ")..." << std::endl; << " (mass= " << par().mass << ")..." << std::endl;
freeMomProp = env().createLattice<ScalarField>(freeMomPropName_); freeMomProp_ = env().createLattice<ScalarField>(freeMomPropName_);
Scalar<SIMPL>::MomentumSpacePropagator(*freeMomProp, par().mass); Scalar<SIMPL>::MomentumSpacePropagator(*freeMomProp_, par().mass);
} }
else else
{ {
freeMomProp = env().getObject<ScalarField>(freeMomPropName_); freeMomProp_ = env().getObject<ScalarField>(freeMomPropName_);
} }
if (!env().hasCreatedObject(shiftedMomPropName_[0])) // cache phases
if (!env().hasCreatedObject(phaseName_[0]))
{ {
std::vector<int> &l = env().getGrid()->_fdimensions; std::vector<int> &l = env().getGrid()->_fdimensions;
@ -83,20 +90,99 @@ void TChargedProp::execute(void)
{ {
Real twoPiL = M_PI*2./l[mu]; Real twoPiL = M_PI*2./l[mu];
shiftedMomProp.push_back( phase_.push_back(env().createLattice<ScalarField>(phaseName_[mu]));
env().createLattice<ScalarField>(shiftedMomPropName_[mu])); LatticeCoordinate(*(phase_[mu]), mu);
LatticeCoordinate(*(shiftedMomProp[mu]), mu); *(phase_[mu]) = exp(ci*twoPiL*(*(phase_[mu])));
*(shiftedMomProp[mu]) = exp(ci*twoPiL*(*(shiftedMomProp[mu])))
*(*freeMomProp);
} }
} }
else else
{ {
for (unsigned int mu = 0; mu < env().getNd(); ++mu) for (unsigned int mu = 0; mu < env().getNd(); ++mu)
{ {
shiftedMomProp.push_back( phase_.push_back(env().getObject<ScalarField>(phaseName_[mu]));
env().getObject<ScalarField>(shiftedMomPropName_[mu]));
} }
} }
// cache G*F*src
if (!env().hasCreatedObject(GFSrcName_))
{
GFSrc_ = env().createLattice<ScalarField>(GFSrcName_);
fft.FFT_all_dim(*GFSrc_, source, FFT::forward);
*GFSrc_ = (*freeMomProp_)*(*GFSrc_);
}
else
{
GFSrc_ = env().getObject<ScalarField>(GFSrcName_);
}
// PROPAGATOR CALCULATION
ScalarField buf(env().getGrid());
ScalarField &GFSrc = *GFSrc_, &G = *freeMomProp_;
double q = par().charge;
// G*F*Src
prop = GFSrc;
// - q*G*momD1*G*F*Src (momD1 = F*D1*Finv)
buf = GFSrc;
momD1(buf, fft);
buf = G*buf;
prop = prop - q*buf;
// + q^2*G*momD1*G*momD1*G*F*Src (here buf = G*momD1*G*F*Src)
momD1(buf, fft);
prop = prop + q*q*G*buf;
// + q^2*G*momD2*G*F*Src (momD1 = F*D2*Finv)
buf = GFSrc;
momD2(buf, fft);
prop = prop + q*q*G*buf;
// final FT
fft.FFT_all_dim(prop, prop, FFT::backward);
}
void TChargedProp::momD1(ScalarField &s, FFT &fft)
{
EmField &A = *env().getObject<EmField>(par().emField);
ScalarField buf(env().getGrid()), Amu(env().getGrid());
Complex ci(0.0,1.0);
for (unsigned int mu = 0; mu < env().getNd(); ++mu)
{
Amu = peekLorentz(A, mu);
fft.FFT_all_dim(buf, s, FFT::backward);
buf = Amu*buf;
fft.FFT_all_dim(buf, buf, FFT::forward);
s = s + ci*adj(*phase_[mu])*buf;
}
for (unsigned int mu = 0; mu < env().getNd(); ++mu)
{
Amu = peekLorentz(A, mu);
buf = (*phase_[mu])*s;
fft.FFT_all_dim(buf, buf, FFT::backward);
buf = Amu*buf;
fft.FFT_all_dim(buf, buf, FFT::forward);
s = s - ci*buf;
}
}
void TChargedProp::momD2(ScalarField &s, FFT &fft)
{
EmField &A = *env().getObject<EmField>(par().emField);
ScalarField buf(env().getGrid()), Amu(env().getGrid());
for (unsigned int mu = 0; mu < env().getNd(); ++mu)
{
Amu = peekLorentz(A, mu);
fft.FFT_all_dim(buf, s, FFT::backward);
buf = Amu*Amu*buf;
fft.FFT_all_dim(buf, buf, FFT::forward);
s = s + .5*adj(*phase_[mu])*buf;
}
for (unsigned int mu = 0; mu < env().getNd(); ++mu)
{
Amu = peekLorentz(A, mu);
buf = (*phase_[mu])*s;
fft.FFT_all_dim(buf, buf, FFT::backward);
buf = Amu*Amu*buf;
fft.FFT_all_dim(buf, buf, FFT::forward);
s = s + .5*buf;
}
} }

View File

@ -19,6 +19,7 @@ public:
std::string, emField, std::string, emField,
std::string, source, std::string, source,
double, mass, double, mass,
double, charge,
std::string, output); std::string, output);
}; };
@ -26,6 +27,8 @@ class TChargedProp: public Module<ChargedPropPar>
{ {
public: public:
SCALAR_TYPE_ALIASES(SIMPL,); SCALAR_TYPE_ALIASES(SIMPL,);
typedef PhotonR::GaugeField EmField;
typedef PhotonR::GaugeLinkField EmComp;
public: public:
// constructor // constructor
TChargedProp(const std::string name); TChargedProp(const std::string name);
@ -39,8 +42,14 @@ public:
// execution // execution
virtual void execute(void); virtual void execute(void);
private: private:
std::string freeMomPropName_; void momD1(ScalarField &s, FFT &fft);
std::vector<std::string> shiftedMomPropName_; void momD2(ScalarField &s, FFT &fft);
private:
std::string freeMomPropName_, GFSrcName_;
std::vector<std::string> phaseName_;
ScalarField *freeMomProp_, *GFSrc_;
std::vector<ScalarField *> phase_;
EmField *A;
}; };
MODULE_REGISTER_NS(ChargedProp, TChargedProp, MScalar); MODULE_REGISTER_NS(ChargedProp, TChargedProp, MScalar);