mirror of
https://github.com/paboyle/Grid.git
synced 2025-04-04 19:25:56 +01:00
Some more edit
This commit is contained in:
parent
c68a2b9637
commit
eda4dd622e
@ -505,7 +505,7 @@ class BinaryIO {
|
|||||||
// available (how short sighted is that?)
|
// available (how short sighted is that?)
|
||||||
//////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////
|
||||||
Umu = zero;
|
Umu = zero;
|
||||||
static uint32_t csum=0;
|
static uint32_t csum; csum=0;//static for SHMEM
|
||||||
fobj fileObj;
|
fobj fileObj;
|
||||||
static sobj siteObj; // Static to place in symmetric region for SHMEM
|
static sobj siteObj; // Static to place in symmetric region for SHMEM
|
||||||
|
|
||||||
|
@ -33,6 +33,71 @@ Author: paboyle <paboyle@ph.ed.ac.uk>
|
|||||||
#define GRID_QCD_H
|
#define GRID_QCD_H
|
||||||
namespace Grid{
|
namespace Grid{
|
||||||
|
|
||||||
|
// First steps in the complete generalization of the Physics part
|
||||||
|
namespace LatticeTheories {
|
||||||
|
|
||||||
|
template <int Dimensions>
|
||||||
|
struct LatticeTheory {
|
||||||
|
static const int Nd = Dimensions;
|
||||||
|
static const int Nds = Dimensions * 2; // double stored field
|
||||||
|
template <typename vtype>
|
||||||
|
using iSinglet = iScalar<iScalar<iScalar<vtype> > >;
|
||||||
|
};
|
||||||
|
|
||||||
|
template <int Dimensions, int Colours>
|
||||||
|
struct LatticeGaugeTheory : public LatticeTheory<Dimensions> {
|
||||||
|
static const int Nds = Dimensions * 2;
|
||||||
|
static const int Nd = Dimensions;
|
||||||
|
static const int Nc = Colours;
|
||||||
|
|
||||||
|
template <typename vtype>
|
||||||
|
using iColourMatrix = iScalar<iScalar<iMatrix<vtype, Nc> > >;
|
||||||
|
template <typename vtype>
|
||||||
|
using iLorentzColourMatrix = iVector<iScalar<iMatrix<vtype, Nc> >, Nd>;
|
||||||
|
template <typename vtype>
|
||||||
|
using iDoubleStoredColourMatrix = iVector<iScalar<iMatrix<vtype, Nc> >, Nds>;
|
||||||
|
template <typename vtype>
|
||||||
|
using iColourVector = iScalar<iScalar<iVector<vtype, Nc> > >;
|
||||||
|
};
|
||||||
|
|
||||||
|
template <int Dimensions, int Colours, int Spin>
|
||||||
|
struct FermionicLatticeGaugeTheory
|
||||||
|
: public LatticeGaugeTheory<Dimensions, Colours> {
|
||||||
|
static const int Nd = Dimensions;
|
||||||
|
static const int Nds = Dimensions * 2;
|
||||||
|
static const int Nc = Colours;
|
||||||
|
static const int Ns = Spin;
|
||||||
|
|
||||||
|
template <typename vtype>
|
||||||
|
using iSpinMatrix = iScalar<iMatrix<iScalar<vtype>, Ns> >;
|
||||||
|
template <typename vtype>
|
||||||
|
using iSpinColourMatrix = iScalar<iMatrix<iMatrix<vtype, Nc>, Ns> >;
|
||||||
|
template <typename vtype>
|
||||||
|
using iSpinVector = iScalar<iVector<iScalar<vtype>, Ns> >;
|
||||||
|
template <typename vtype>
|
||||||
|
using iSpinColourVector = iScalar<iVector<iVector<vtype, Nc>, Ns> >;
|
||||||
|
// These 2 only is Spin is a multiple of 2
|
||||||
|
static const int Nhs = Spin / 2;
|
||||||
|
template <typename vtype>
|
||||||
|
using iHalfSpinVector = iScalar<iVector<iScalar<vtype>, Nhs> >;
|
||||||
|
template <typename vtype>
|
||||||
|
using iHalfSpinColourVector = iScalar<iVector<iVector<vtype, Nc>, Nhs> >;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct QCD : public FermionicLatticeGaugeTheory<4, 3, 4> {
|
||||||
|
typedef FermionicLatticeGaugeTheory FLGT;
|
||||||
|
typedef FLGT::iSpinMatrix<Complex > SpinMatrix;
|
||||||
|
typedef FLGT::iSpinMatrix<ComplexF > SpinMatrixF;
|
||||||
|
typedef FLGT::iSpinMatrix<ComplexD > SpinMatrixD;
|
||||||
|
|
||||||
|
};
|
||||||
|
struct QED : public FermionicLatticeGaugeTheory<4, 1, 4> {};
|
||||||
|
|
||||||
|
template <int Dimensions>
|
||||||
|
struct Scalar : public LatticeTheory<Dimensions> {};
|
||||||
|
|
||||||
|
} // LatticeTheories
|
||||||
|
|
||||||
namespace QCD {
|
namespace QCD {
|
||||||
|
|
||||||
|
|
||||||
@ -355,36 +420,36 @@ namespace QCD {
|
|||||||
//////////////////////////////////////////////
|
//////////////////////////////////////////////
|
||||||
template<class vobj>
|
template<class vobj>
|
||||||
void pokeColour(Lattice<vobj> &lhs,
|
void pokeColour(Lattice<vobj> &lhs,
|
||||||
const Lattice<decltype(peekIndex<ColourIndex>(lhs._odata[0],0))> & rhs,
|
const Lattice<decltype(peekIndex<ColourIndex>(lhs._odata[0],0))> & rhs,
|
||||||
int i)
|
int i)
|
||||||
{
|
{
|
||||||
PokeIndex<ColourIndex>(lhs,rhs,i);
|
PokeIndex<ColourIndex>(lhs,rhs,i);
|
||||||
}
|
}
|
||||||
template<class vobj>
|
template<class vobj>
|
||||||
void pokeColour(Lattice<vobj> &lhs,
|
void pokeColour(Lattice<vobj> &lhs,
|
||||||
const Lattice<decltype(peekIndex<ColourIndex>(lhs._odata[0],0,0))> & rhs,
|
const Lattice<decltype(peekIndex<ColourIndex>(lhs._odata[0],0,0))> & rhs,
|
||||||
int i,int j)
|
int i,int j)
|
||||||
{
|
{
|
||||||
PokeIndex<ColourIndex>(lhs,rhs,i,j);
|
PokeIndex<ColourIndex>(lhs,rhs,i,j);
|
||||||
}
|
}
|
||||||
template<class vobj>
|
template<class vobj>
|
||||||
void pokeSpin(Lattice<vobj> &lhs,
|
void pokeSpin(Lattice<vobj> &lhs,
|
||||||
const Lattice<decltype(peekIndex<SpinIndex>(lhs._odata[0],0))> & rhs,
|
const Lattice<decltype(peekIndex<SpinIndex>(lhs._odata[0],0))> & rhs,
|
||||||
int i)
|
int i)
|
||||||
{
|
{
|
||||||
PokeIndex<SpinIndex>(lhs,rhs,i);
|
PokeIndex<SpinIndex>(lhs,rhs,i);
|
||||||
}
|
}
|
||||||
template<class vobj>
|
template<class vobj>
|
||||||
void pokeSpin(Lattice<vobj> &lhs,
|
void pokeSpin(Lattice<vobj> &lhs,
|
||||||
const Lattice<decltype(peekIndex<SpinIndex>(lhs._odata[0],0,0))> & rhs,
|
const Lattice<decltype(peekIndex<SpinIndex>(lhs._odata[0],0,0))> & rhs,
|
||||||
int i,int j)
|
int i,int j)
|
||||||
{
|
{
|
||||||
PokeIndex<SpinIndex>(lhs,rhs,i,j);
|
PokeIndex<SpinIndex>(lhs,rhs,i,j);
|
||||||
}
|
}
|
||||||
template<class vobj>
|
template<class vobj>
|
||||||
void pokeLorentz(Lattice<vobj> &lhs,
|
void pokeLorentz(Lattice<vobj> &lhs,
|
||||||
const Lattice<decltype(peekIndex<LorentzIndex>(lhs._odata[0],0))> & rhs,
|
const Lattice<decltype(peekIndex<LorentzIndex>(lhs._odata[0],0))> & rhs,
|
||||||
int i)
|
int i)
|
||||||
{
|
{
|
||||||
PokeIndex<LorentzIndex>(lhs,rhs,i);
|
PokeIndex<LorentzIndex>(lhs,rhs,i);
|
||||||
}
|
}
|
||||||
@ -500,7 +565,7 @@ namespace QCD {
|
|||||||
#include <Grid/qcd/utils/LinalgUtils.h>
|
#include <Grid/qcd/utils/LinalgUtils.h>
|
||||||
#include <Grid/qcd/utils/CovariantCshift.h>
|
#include <Grid/qcd/utils/CovariantCshift.h>
|
||||||
|
|
||||||
// Include representations
|
// Include representations
|
||||||
#include <Grid/qcd/utils/SUn.h>
|
#include <Grid/qcd/utils/SUn.h>
|
||||||
#include <Grid/qcd/utils/SUnAdjoint.h>
|
#include <Grid/qcd/utils/SUnAdjoint.h>
|
||||||
#include <Grid/qcd/utils/SUnTwoIndex.h>
|
#include <Grid/qcd/utils/SUnTwoIndex.h>
|
||||||
|
@ -111,9 +111,11 @@ template <class IOCheckpointer = BinaryHmcCheckpointer<Implementation> >
|
|||||||
GridParallelRNG pRNG(UGrid);
|
GridParallelRNG pRNG(UGrid);
|
||||||
Field U(UGrid);
|
Field U(UGrid);
|
||||||
|
|
||||||
|
// This outside
|
||||||
std::vector<int> SerSeed({1, 2, 3, 4, 5});
|
std::vector<int> SerSeed({1, 2, 3, 4, 5});
|
||||||
std::vector<int> ParSeed({6, 7, 8, 9, 10});
|
std::vector<int> ParSeed({6, 7, 8, 9, 10});
|
||||||
|
|
||||||
|
// these decisions outside
|
||||||
NoSmearing<Implementation> SmearingPolicy;
|
NoSmearing<Implementation> SmearingPolicy;
|
||||||
typedef MinimumNorm2<Implementation, NoSmearing<Implementation>,
|
typedef MinimumNorm2<Implementation, NoSmearing<Implementation>,
|
||||||
RepresentationsPolicy>
|
RepresentationsPolicy>
|
||||||
@ -121,15 +123,6 @@ template <class IOCheckpointer = BinaryHmcCheckpointer<Implementation> >
|
|||||||
IntegratorParameters MDpar(20, 1.0);
|
IntegratorParameters MDpar(20, 1.0);
|
||||||
IntegratorType MDynamics(UGrid, MDpar, TheAction, SmearingPolicy);
|
IntegratorType MDynamics(UGrid, MDpar, TheAction, SmearingPolicy);
|
||||||
|
|
||||||
// Checkpoint strategy
|
|
||||||
/*
|
|
||||||
int SaveInterval = 1;
|
|
||||||
std::string format = std::string("IEEE64BIG");
|
|
||||||
std::string conf_prefix = std::string("ckpoint_lat");
|
|
||||||
std::string rng_prefix = std::string("ckpoint_rng");
|
|
||||||
IOCheckpointer Checkpoint(conf_prefix, rng_prefix, SaveInterval, format);
|
|
||||||
*/
|
|
||||||
|
|
||||||
HMCparameters HMCpar;
|
HMCparameters HMCpar;
|
||||||
HMCpar.StartTrajectory = StartTraj;
|
HMCpar.StartTrajectory = StartTraj;
|
||||||
HMCpar.Trajectories = NumTraj;
|
HMCpar.Trajectories = NumTraj;
|
||||||
|
@ -44,6 +44,8 @@ auto outerProduct (const iVector<l,N>& lhs,const iVector<r,N>& rhs) -> iMatrix<d
|
|||||||
}}
|
}}
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
template<class l,class r> inline
|
template<class l,class r> inline
|
||||||
auto outerProduct (const iScalar<l>& lhs,const iScalar<r>& rhs) -> iScalar<decltype(outerProduct(lhs._internal,rhs._internal))>
|
auto outerProduct (const iScalar<l>& lhs,const iScalar<r>& rhs) -> iScalar<decltype(outerProduct(lhs._internal,rhs._internal))>
|
||||||
{
|
{
|
||||||
@ -53,6 +55,7 @@ auto outerProduct (const iScalar<l>& lhs,const iScalar<r>& rhs) -> iScalar<declt
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
inline ComplexF outerProduct(const ComplexF &l, const ComplexF& r)
|
inline ComplexF outerProduct(const ComplexF &l, const ComplexF& r)
|
||||||
{
|
{
|
||||||
std::cout << "outer product taking conj "<<r<<" "<<conj(r)<<std::endl;
|
std::cout << "outer product taking conj "<<r<<" "<<conj(r)<<std::endl;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user