41 typedef LatticeFermion
T;
42 typedef multi1d<LatticeColorMatrix>
Q;
43 typedef multi1d<LatticeColorMatrix>
P;
45 typedef LatticeFermionF
TF;
46 typedef multi1d<LatticeColorMatrixF>
QF;
47 typedef multi1d<LatticeColorMatrixF>
PF;
49 std::istringstream is(
p.fermact.xml);
63 MdagMMultiSysSolverQPhiXClover<T,LatticeColorMatrix> mprec(D_op, connect_state,
p.invParam);
65 multi1d<Real> shifts(n_shifts);
66 shifts[0] = 1.51480322230288e-05 ;
67 shifts[1] = 0.000165259114300968 ;
68 shifts[2] = 0.000661184012887753 ;
69 shifts[3] = 0.00214955953261573 ;
70 shifts[4] = 0.00657190811374048 ;
71 shifts[5] = 0.0197043312297316 ;
72 shifts[6] = 0.0587640674448055 ;
73 shifts[7] = 0.175534749714768 ;
74 shifts[8] = 0.529999019144126 ;
75 shifts[9] = 1.6565878795396 ;
76 shifts[10] = 5.78532483906374 ;
77 shifts[11] = 30.6835527589452 ;
79 multi1d<Real>
RsdCG(shifts.size());
80 if (
p.invParam.RsdTarget.size() == 1) {
81 RsdCG =
p.invParam.RsdTarget[0];
83 else if (
p.invParam.RsdTarget.size() ==
RsdCG.size()) {
85 RsdCG =
p.invParam.RsdTarget;
89 QDPIO::cerr <<
"MdagMMultiSysSolverCGChronoClover: shifts incompatible" << std::endl;
99 multi1d<LatticeFermion>
psi(n_shifts);
100 for(
int i=0;
i < n_shifts;
i++){
112 for(
int i=0;
i < n_shifts;
i++) {
114 r[D_op->subset()]=
chi;
115 LatticeFermion tmp1,
tmp2;
118 tmp2[D_op->subset()] += shifts[
i]*
psi[
i];
119 r[D_op->subset()] -=
tmp2;
120 Double norm = norm2(
r, D_op->subset())/norm2(
chi, D_op->subset());
122 QDPIO::cout <<
"soln "<<
i <<
" : RsdCG=" <<
RsdCG[
i] <<
" r=" << sqrt(
norm) << std::endl;
124 QDPIO::cout <<
"MinvCG: n_count = " << res.
n_count <<
" Time=" << swatch.getTimeInSeconds() << std::endl;
132 for(
int i=0;
i < n_shifts;
i++) {
134 r[D_op->subset()]=
chi;
135 LatticeFermion tmp1,
tmp2;
138 tmp2[D_op->subset()] += shifts[
i]*
psi[
i];
139 r[D_op->subset()] -=
tmp2;
140 Double norm = norm2(
r, D_op->subset())/norm2(
chi, D_op->subset());
142 QDPIO::cout <<
"soln "<<
i <<
" : RsdCG=" <<
RsdCG[
i] <<
" r=" << sqrt(
norm) << std::endl;
144 QDPIO::cout <<
"Chrono: n_count = " << res2.
n_count <<
" Time=" << swatch.getTimeInSeconds() << std::endl;
152 read(
r,
"Cfg",
p.inputCfg);
154 read(
r,
"InvertParam",
p.invParam);
169 int main(
int argc,
char **argv)
173 QDPIO::cout <<
"Linkage = " <<
linkageHack() << std::endl;
186 QDPIO::cerr <<
"Caught Exception reading XML: " << e << std::endl;
189 Layout::setLattSize(
params.nrow);
192 multi1d<LatticeColorMatrix>
u(
Nd);
193 XMLReader gauge_file_xml, gauge_xml;
200 push(xml_out,
"t_invert");
201 push(xml_out,
"params");
206 MesPlq(xml_out,
"Observables",
u);
Primary include file for CHROMA in application codes.
Class for counted reference semantics.
Parameters for Clover fermion action.
Even-odd preconditioned Clover fermion linear operator.
All ferm create-state method.
void read(XMLReader &xml, const std::string &path, AsqtadFermActParams ¶m)
Read parameters.
void write(XMLWriter &xml, const std::string &path, const AsqtadFermActParams ¶m)
Writer parameters.
void unitarityCheck(const multi1d< LatticeColorMatrixF3 > &u)
Check the unitarity of color matrix in SU(N)
void gaugeStartup(XMLReader &gauge_file_xml, XMLReader &gauge_xml, multi1d< LatticeColorMatrix > &u, Cfg_t &cfg)
Initialize the gauge fields.
void MInvCG2(const LinearOperator< LatticeFermionF > &M, const LatticeFermionF &chi, multi1d< LatticeFermionF > &psi, const multi1d< RealF > &shifts, const multi1d< RealF > &RsdCG, int MaxCG, int &n_count)
GroupXML_t readXMLGroup(XMLReader &xml_in, const std::string &path, const std::string &type_name)
Read group and return as a std::string.
Multishift Conjugate-Gradient algorithm for a Linear Operator.
Solve a M*psi=chi linear system by BiCGStab.
bool registerAll()
Register all the factories.
bool registerAll()
Register all the factories.
multi1d< LatticeColorMatrix > P
Asqtad Staggered-Dirac operator.
const WilsonTypeFermAct< multi1d< LatticeFermion > > Handle< const ConnectState > const multi1d< Real > enum InvType invType const multi1d< Real > & RsdCG
static multi1d< LatticeColorMatrix > u
LinOpSysSolverMGProtoClover::Q Q
push(xml_out,"Condensates")
LinOpSysSolverMGProtoClover::T T
void initialize(int *argc, char ***argv)
Chroma initialisation routine.
void finalize(void)
Chroma finalization routine.
multi1d< LatticeFermion > chi(Ncb)
std::string getXMLInputFileName()
Get input file name.
void MesPlq(const multi1d< LatticeColorMatrixF3 > &u, multi2d< Double > &plane_plaq, Double &link)
XMLFileWriter & getXMLOutputInstance()
Get xml output instance.
const WilsonTypeFermAct< multi1d< LatticeFermion > > & S_f
FloatingPoint< double > Double
MultiSysSolverQPhiXCloverParams invParam
Gauge configuration structure.
Hold group xml and type id.
Holds return info from SystemSolver call.
Factory for solving M*psi=chi where M is not hermitian or pos. def.
void checkInverter(const AppParams &p, multi1d< LatticeColorMatrix > &u)
int main(int argc, char **argv)
multi1d< LatticeColorMatrixF > QF
multi1d< LatticeColorMatrixF > PF
Read an XML group as a std::string.