From b6de8746264a7478c9b601ae18c936f7734aa7d3 Mon Sep 17 00:00:00 2001 From: maddyscientist Date: Thu, 9 Jun 2016 21:38:46 -0700 Subject: [PATCH] Fixed bugs in clover application: dslash_test now supports full clover testing (part 3 of #19). --- include/clover_field_order.h | 2 +- tests/CMakeLists.txt | 2 +- tests/clover_reference.cpp | 71 ++++++++++++++++++++++++++---------- tests/dslash_test.cpp | 6 +-- 4 files changed, 56 insertions(+), 25 deletions(-) diff --git a/include/clover_field_order.h b/include/clover_field_order.h index 73a3112398..91d964e482 100644 --- a/include/clover_field_order.h +++ b/include/clover_field_order.h @@ -144,7 +144,7 @@ namespace quda { complex tmp(a[parity][idx], a[parity][idx+1]); return tmp; } else { - // requesting upper triangular so return conjuate transpose + // requesting upper triangular so return conjugate transpose return conj(operator()(parity,x,s_col,s_row,c_col,c_row) ); } } diff --git a/tests/CMakeLists.txt b/tests/CMakeLists.txt index a6d1a36c3e..04bea130e1 100644 --- a/tests/CMakeLists.txt +++ b/tests/CMakeLists.txt @@ -27,7 +27,7 @@ endif() #define tests if(${QUDA_DIRAC_WILSON} OR ${QUDA_DIRAC_CLOVER} OR ${QUDA_DIRAC_TWISTED_MASS} OR ${QUDA_DIRAC_TWISTED_CLOVER} OR ${QUDA_DIRAC_DOMAIN_WALL}) - cuda_add_executable(dslash_test dslash_test.cpp wilson_dslash_reference.cpp domain_wall_dslash_reference.cpp clover_reference.cpp) + cuda_add_executable(dslash_test dslash_test.cpp wilson_dslash_reference.cpp domain_wall_dslash_reference.cpp clover_reference.cpp blas_reference.cpp) target_link_libraries(dslash_test ${TEST_LIBS} ) cuda_add_executable(invert_test invert_test.cpp wilson_dslash_reference.cpp domain_wall_dslash_reference.cpp clover_reference.cpp blas_reference.cpp) diff --git a/tests/clover_reference.cpp b/tests/clover_reference.cpp index 30e3cb4699..881f383e4e 100644 --- a/tests/clover_reference.cpp +++ b/tests/clover_reference.cpp @@ -20,36 +20,36 @@ template void cloverReference(sFloat *out, cFloat *clover, sFloat *in, int parity) { int nSpin = 4; int nColor = 3; - int N = nSpin * nColor / 2; - int chiralBlock = (nSpin/2) * (nSpin/2) * nColor * nColor; + int N = nColor * nSpin / 2; + int chiralBlock = N + 2*(N-1)*N/2; - for (int i = 0; i < Vh; i++) { + for (int i=0; i *In = reinterpret_cast*>(&in[i*nSpin*nColor*2]); std::complex *Out = reinterpret_cast*>(&out[i*nSpin*nColor*2]); - for (int i=0; i *L = reinterpret_cast*>(&clover[((parity*Vh + i)*2 + chi)*chiralBlock+N]); + std::complex *L = reinterpret_cast*>(&D[N]); for (int s_col=0; s_col(out), static_cast(clover), static_cast(in), parity); + break; case QUDA_SINGLE_PRECISION: cloverReference(static_cast(out), static_cast(clover), static_cast(in), parity); + break; default: errorQuda("Unsupported precision %d", precision); } @@ -95,29 +97,47 @@ void clover_matpc(void *out, void **gauge, void *clover, void *clover_inv, void switch(matpc_type) { case QUDA_MATPC_EVEN_EVEN: - wil_dslash(tmp, gauge, in, 1, dagger, precision, gauge_param); - apply_clover(out, clover_inv, tmp, 1, precision); - wil_dslash(tmp, gauge, out, 0, dagger, precision, gauge_param); - apply_clover(out, clover_inv, tmp, 0, precision); + if (!dagger) { + wil_dslash(tmp, gauge, in, 1, dagger, precision, gauge_param); + apply_clover(out, clover_inv, tmp, 1, precision); + wil_dslash(tmp, gauge, out, 0, dagger, precision, gauge_param); + apply_clover(out, clover_inv, tmp, 0, precision); + } else { + apply_clover(tmp, clover_inv, in, 0, precision); + wil_dslash(out, gauge, tmp, 1, dagger, precision, gauge_param); + apply_clover(tmp, clover_inv, out, 1, precision); + wil_dslash(out, gauge, tmp, 0, dagger, precision, gauge_param); + } xpay(in, kappa2, out, Vh*spinorSiteSize, precision); + break; case QUDA_MATPC_EVEN_EVEN_ASYMMETRIC: wil_dslash(out, gauge, in, 1, dagger, precision, gauge_param); apply_clover(tmp, clover_inv, out, 1, precision); wil_dslash(out, gauge, tmp, 0, dagger, precision, gauge_param); apply_clover(tmp, clover, in, 0, precision); xpay(tmp, kappa2, out, Vh*spinorSiteSize, precision); + break; case QUDA_MATPC_ODD_ODD: - wil_dslash(tmp, gauge, in, 0, dagger, precision, gauge_param); - apply_clover(out, clover_inv, tmp, 0, precision); - wil_dslash(tmp, gauge, out, 1, dagger, precision, gauge_param); - apply_clover(out, clover_inv, tmp, 1, precision); + if (!dagger) { + wil_dslash(tmp, gauge, in, 0, dagger, precision, gauge_param); + apply_clover(out, clover_inv, tmp, 0, precision); + wil_dslash(tmp, gauge, out, 1, dagger, precision, gauge_param); + apply_clover(out, clover_inv, tmp, 1, precision); + } else { + apply_clover(tmp, clover_inv, in, 1, precision); + wil_dslash(out, gauge, tmp, 0, dagger, precision, gauge_param); + apply_clover(tmp, clover_inv, out, 0, precision); + wil_dslash(out, gauge, tmp, 1, dagger, precision, gauge_param); + } xpay(in, kappa2, out, Vh*spinorSiteSize, precision); + break; case QUDA_MATPC_ODD_ODD_ASYMMETRIC: wil_dslash(out, gauge, in, 0, dagger, precision, gauge_param); apply_clover(tmp, clover_inv, out, 0, precision); wil_dslash(out, gauge, tmp, 1, dagger, precision, gauge_param); apply_clover(tmp, clover, in, 1, precision); xpay(tmp, kappa2, out, Vh*spinorSiteSize, precision); + break; default: errorQuda("Unsupoorted matpc=%d", matpc_type); } @@ -129,14 +149,25 @@ void clover_matpc(void *out, void **gauge, void *clover, void *clover_inv, void void clover_mat(void *out, void **gauge, void *clover, void *in, double kappa, int dagger, QudaPrecision precision, QudaGaugeParam &gauge_param) { + void *tmp = malloc(V*spinorSiteSize*precision); + void *inEven = in; void *inOdd = (char*)in + Vh*spinorSiteSize*precision; void *outEven = out; void *outOdd = (char*)out + Vh*spinorSiteSize*precision; + void *tmpEven = tmp; + void *tmpOdd = (char*)tmp + Vh*spinorSiteSize*precision; + + // Odd part + wil_dslash(outOdd, gauge, inEven, 1, dagger, precision, gauge_param); + apply_clover(tmpOdd, clover, inOdd, 1, precision); - clover_dslash(outOdd, gauge, clover, inEven, 1, dagger, precision, gauge_param); - clover_dslash(outEven, gauge, clover, inOdd, 0, dagger, precision, gauge_param); + // Even part + wil_dslash(outEven, gauge, inOdd, 0, dagger, precision, gauge_param); + apply_clover(tmpEven, clover, inEven, 0, precision); // lastly apply the kappa term - xpay(in, -kappa, out, V*spinorSiteSize, precision); + xpay(tmp, -kappa, out, V*spinorSiteSize, precision); + + free(tmp); } diff --git a/tests/dslash_test.cpp b/tests/dslash_test.cpp index d18f2a9f2a..8424818f08 100644 --- a/tests/dslash_test.cpp +++ b/tests/dslash_test.cpp @@ -321,10 +321,10 @@ void init(int argc, char **argv) { construct_gauge_field(hostGauge, 1, gauge_param.cpu_prec, &gauge_param); } - spinor->Source(QUDA_RANDOM_SOURCE); + spinor->Source(QUDA_RANDOM_SOURCE, 0); if (dslash_type == QUDA_CLOVER_WILSON_DSLASH) { - double norm = 0.0; // clover components are random numbers in the range (-norm, norm) + double norm = 1.0; // clover components are random numbers in the range (-norm, norm) double diag = 1.0; // constant added to the diagonal if (test_type == 2 || test_type == 4) { @@ -647,7 +647,7 @@ void dslashRef() { } else if (dslash_type == QUDA_CLOVER_WILSON_DSLASH) { switch (test_type) { case 0: - clover_dslash(spinorTmp->V(), hostGauge, hostClover, spinor->V(), parity, dagger, inv_param.cpu_prec, gauge_param); + clover_dslash(spinorRef->V(), hostGauge, hostCloverInv, spinor->V(), parity, dagger, inv_param.cpu_prec, gauge_param); break; case 1: clover_matpc(spinorRef->V(), hostGauge, hostClover, hostCloverInv, spinor->V(), inv_param.kappa, inv_param.matpc_type,