33 assert(Nvol == v1.
nvol());
34 assert(Nvol == v2.
nvol());
36 assert(v1.
nex() == 1);
37 assert(v2.
nex() == 1);
39 double *w1 =
const_cast<Field_F *
>(&v1)->ptr(0);
40 double *w2 =
const_cast<Field_F *
>(&v2)->ptr(0);
41 double *g = u.
ptr(0, 0, ex);
43 for (
int site = 0; site < Nvol; ++site) {
46 for (
int c1 = 0; c1 <
NC; ++c1) {
47 for (
int c2 = 0; c2 <
NC; ++c2) {
48 int ig2 = c2 * 2 + c1 *
NC2 + ig;
51 for (
int s = 0; s <
ND; ++s) {
53 w1[2 * c2 + s *
NC2 + iw] * w2[2 * c1 + s *
NC2 + iw]
54 + w1[2 * c2 + 1 + s *
NC2 + iw] * w2[2 * c1 + 1 + s *
NC2 + iw];
56 w1[2 * c2 + s *
NC2 + iw] * w2[2 * c1 + 1 + s *
NC2 + iw]
57 - w1[2 * c2 + 1 + s *
NC2 + iw] * w2[2 * c1 + s *
NC2 + iw];
double * ptr(const int jin, const int site, const int jex)
Wilson-type fermion field.
void tensorProd_Field_F(Field_G &u, const Field_F &v1, const Field_F &v2)