From 6d9f3779134db2bbd35b3044ce0b9b4348592b23 Mon Sep 17 00:00:00 2001 From: Felix Erben Date: Thu, 28 Feb 2019 11:05:31 +0000 Subject: [PATCH] added parity --- Grid/qcd/utils/A2Autils.h | 18 +++++++++++------- 1 file changed, 11 insertions(+), 7 deletions(-) diff --git a/Grid/qcd/utils/A2Autils.h b/Grid/qcd/utils/A2Autils.h index 749987c0..4caf0d5f 100644 --- a/Grid/qcd/utils/A2Autils.h +++ b/Grid/qcd/utils/A2Autils.h @@ -102,13 +102,16 @@ public: }; /* template -void A2Autils::NucleonFieldMom(Eigen::Tensor &mat, +void A2Autils::NucleonFieldMom(Eigen::Tensor &mat, const FermionField *one, const FermionField *two, const FermionField *three, const std::vector &mom, + int parity, int orthogdim) { + assert(parity == 1 || parity == -1); + typedef typename FImpl::SiteSpinor vobj; typedef typename vobj::scalar_object sobj; @@ -166,6 +169,7 @@ void A2Autils::NucleonFieldMom(Eigen::Tensor &mat, for(int i=0;i::NucleonFieldMom(Eigen::Tensor &mat, auto gv3 = Gamma(Gamma::Algebra::SigmaXZ) * v3; SpinVector_v vv; - vv()()() = v1()()(0) * v2()()(1) * gv3()()(2) //Cross product - - v1()()(0) * v2()()(2) * gv3()()(1) - + v1()()(1) * v2()()(2) * gv3()()(0) - - v1()()(1) * v2()()(0) * gv3()()(2) - + v1()()(2) * v2()()(0) * gv3()()(1) - - v1()()(2) * v2()()(1) * gv3()()(0); + vv()()() = pv1()()(0) * v2()()(1) * gv3()()(2) //Cross product + - pv1()()(0) * v2()()(2) * gv3()()(1) + + pv1()()(1) * v2()()(2) * gv3()()(0) + - pv1()()(1) * v2()()(0) * gv3()()(2) + + pv1()()(2) * v2()()(0) * gv3()()(1) + - pv1()()(2) * v2()()(1) * gv3()()(0); // After getting the sitewise product do the mom phase loop