mirror of
				https://github.com/paboyle/Grid.git
				synced 2025-10-24 17:54:47 +01:00 
			
		
		
		
	Merge branch 'develop' into release/v0.6.0
This commit is contained in:
		
							
								
								
									
										18
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										18
									
								
								README.md
									
									
									
									
									
								
							| @@ -20,7 +20,7 @@ License: GPL v2. | ||||
|  | ||||
| Last update Nov 2016. | ||||
|  | ||||
| _Please send all pull requests to the `develop` branch._ | ||||
| _Please do not send pull requests to the `master` branch which is reserved for releases._ | ||||
|  | ||||
| ### Bug report | ||||
|  | ||||
| @@ -29,7 +29,7 @@ _To help us tracking and solving more efficiently issues with Grid, please repor | ||||
| When you file an issue, please go though the following checklist: | ||||
|  | ||||
| 1. Check that the code is pointing to the `HEAD` of `develop` or any commit in `master` which is tagged with a version number.  | ||||
| 2. Give a description of the target platform (CPU, network, compiler). | ||||
| 2. Give a description of the target platform (CPU, network, compiler). Please give the full CPU part description, using for example `cat /proc/cpuinfo | grep 'model name' | uniq` (Linux) or `sysctl machdep.cpu.brand_string` (macOS) and the full output the `--version` option of your compiler. | ||||
| 3. Give the exact `configure` command used. | ||||
| 4. Attach `config.log`. | ||||
| 5. Attach `config.summary`. | ||||
| @@ -45,7 +45,7 @@ are provided, similar to HPF and cmfortran, and user control is given over the m | ||||
| array indices to both MPI tasks and SIMD processing elements. | ||||
|  | ||||
| * Identically shaped arrays then be processed with perfect data parallelisation. | ||||
| * Such identically shapped arrays are called conformable arrays. | ||||
| * Such identically shaped arrays are called conformable arrays. | ||||
|  | ||||
| The transformation is based on the observation that Cartesian array processing involves | ||||
| identical processing to be performed on different regions of the Cartesian array. | ||||
| @@ -128,13 +128,14 @@ make -C tests/<subdir> tests | ||||
| The following options can be use with the `--enable-simd=` option to target different communication interfaces: | ||||
|  | ||||
| | `<comm>`       | Description                                                   | | ||||
| | ------------- | -------------------------------------------- | | ||||
| | -------------- | ------------------------------------------------------------- | | ||||
| | `none`         | no communications                                             | | ||||
| | `mpi[-auto]`   | MPI communications                                            | | ||||
| | `mpi3[-auto]`  | MPI communications using MPI 3 shared memory                  | | ||||
| | `mpi3l[-auto]` | MPI communications using MPI 3 shared memory and leader model | | ||||
| | `shmem `       | Cray SHMEM communications                                     | | ||||
|  | ||||
| For `mpi` and `mpi3` the optional `-auto` suffix instructs the `configure` scripts to determine all the necessary compilation and linking flags. This is done by extracting the informations from the MPI wrapper specified in the environment variable `MPICXX` (if not specified `configure` will scan though a list of default names). | ||||
| For the MPI interfaces the optional `-auto` suffix instructs the `configure` scripts to determine all the necessary compilation and linking flags. This is done by extracting the informations from the MPI wrapper specified in the environment variable `MPICXX` (if not specified `configure` will scan though a list of default names). | ||||
|  | ||||
| ### Possible SIMD types | ||||
|  | ||||
| @@ -160,7 +161,7 @@ Alternatively, some CPU codenames can be directly used: | ||||
| | `BGQ`       | Blue Gene/Q                            | | ||||
|  | ||||
| #### Notes: | ||||
| - We currently support AVX512 only for the Intel compiler. Support for GCC and clang will appear in future versions. | ||||
| - We currently support AVX512 only for the Intel compiler. Support for GCC and clang will appear in future versions of Grid when the AVX512 support within GCC and clang will be more advanced. | ||||
| - For BG/Q only [bgclang](http://trac.alcf.anl.gov/projects/llvm-bgq) is supported. We do not presently plan to support more compilers for this platform. | ||||
| - BG/Q performances are currently rather poor. This is being investigated for future versions. | ||||
|  | ||||
| @@ -171,7 +172,7 @@ The following configuration is recommended for the Intel Knights Landing platfor | ||||
| ``` bash | ||||
| ../configure --enable-precision=double\ | ||||
|              --enable-simd=KNL        \ | ||||
|              --enable-comms=mpi3-auto \ | ||||
|              --enable-comms=mpi-auto \ | ||||
|              --with-gmp=<path>        \ | ||||
|              --with-mpfr=<path>       \ | ||||
|              --enable-mkl             \ | ||||
| @@ -183,10 +184,9 @@ where `<path>` is the UNIX prefix where GMP and MPFR are installed. If you are w | ||||
| ``` bash | ||||
| ../configure --enable-precision=double\ | ||||
|              --enable-simd=KNL        \ | ||||
|              --enable-comms=mpi3      \ | ||||
|              --enable-comms=mpi       \ | ||||
|              --with-gmp=<path>        \ | ||||
|              --with-mpfr=<path>       \ | ||||
|              --enable-mkl             \ | ||||
|              CXX=CC CC=cc | ||||
| ``` | ||||
|  | ||||
|   | ||||
							
								
								
									
										32
									
								
								configure.ac
									
									
									
									
									
								
							
							
						
						
									
										32
									
								
								configure.ac
									
									
									
									
									
								
							| @@ -4,6 +4,7 @@ AC_CANONICAL_BUILD | ||||
| AC_CANONICAL_HOST | ||||
| AC_CANONICAL_TARGET | ||||
| AM_INIT_AUTOMAKE(subdir-objects) | ||||
| AM_EXTRA_RECURSIVE_TARGETS([tests]) | ||||
| AC_CONFIG_MACRO_DIR([m4]) | ||||
| AC_CONFIG_SRCDIR([lib/Grid.h]) | ||||
| AC_CONFIG_HEADERS([lib/Config.h]) | ||||
| @@ -253,18 +254,23 @@ AC_ARG_ENABLE([comms],[AC_HELP_STRING([--enable-comms=none|mpi|mpi-auto|mpi3|mpi | ||||
| case ${ac_COMMS} in | ||||
|      none) | ||||
|         AC_DEFINE([GRID_COMMS_NONE],[1],[GRID_COMMS_NONE] ) | ||||
|         comms_type='none' | ||||
|      ;; | ||||
|      mpi|mpi-auto) | ||||
|         AC_DEFINE([GRID_COMMS_MPI],[1],[GRID_COMMS_MPI] ) | ||||
|      ;; | ||||
|      mpi3|mpi3-auto) | ||||
|         AC_DEFINE([GRID_COMMS_MPI3],[1],[GRID_COMMS_MPI3] ) | ||||
|      ;; | ||||
|      mpi3l) | ||||
|      mpi3l*) | ||||
|        AC_DEFINE([GRID_COMMS_MPI3L],[1],[GRID_COMMS_MPI3L] ) | ||||
|        comms_type='mpi3l' | ||||
|      ;; | ||||
|      mpi3*) | ||||
|         AC_DEFINE([GRID_COMMS_MPI3],[1],[GRID_COMMS_MPI3] ) | ||||
|         comms_type='mpi3' | ||||
|      ;; | ||||
|      mpi*) | ||||
|         AC_DEFINE([GRID_COMMS_MPI],[1],[GRID_COMMS_MPI] ) | ||||
|         comms_type='mpi' | ||||
|      ;; | ||||
|      shmem) | ||||
|         AC_DEFINE([GRID_COMMS_SHMEM],[1],[GRID_COMMS_SHMEM] ) | ||||
|         comms_type='shmem' | ||||
|      ;; | ||||
|      *) | ||||
|         AC_MSG_ERROR([${ac_COMMS} unsupported --enable-comms option]);  | ||||
| @@ -282,11 +288,11 @@ case ${ac_COMMS} in | ||||
|         ;; | ||||
| esac | ||||
|  | ||||
| AM_CONDITIONAL(BUILD_COMMS_SHMEM,[ test "X${ac_COMMS}X" == "XshmemX" ]) | ||||
| AM_CONDITIONAL(BUILD_COMMS_MPI,[ test "X${ac_COMMS}X" == "XmpiX" || test "X${ac_COMMS}X" == "Xmpi-autoX" ]) | ||||
| AM_CONDITIONAL(BUILD_COMMS_MPI3,[ test "X${ac_COMMS}X" == "Xmpi3X"] ) | ||||
| AM_CONDITIONAL(BUILD_COMMS_MPI3L,[ test "X${ac_COMMS}X" == "Xmpi3lX"] ) | ||||
| AM_CONDITIONAL(BUILD_COMMS_NONE,[ test "X${ac_COMMS}X" == "XnoneX" ]) | ||||
| AM_CONDITIONAL(BUILD_COMMS_SHMEM, [ test "${comms_type}X" == "shmemX" ]) | ||||
| AM_CONDITIONAL(BUILD_COMMS_MPI,   [ test "${comms_type}X" == "mpiX" ]) | ||||
| AM_CONDITIONAL(BUILD_COMMS_MPI3,  [ test "${comms_type}X" == "mpi3X" ] ) | ||||
| AM_CONDITIONAL(BUILD_COMMS_MPI3L, [ test "${comms_type}X" == "mpi3lX" ] ) | ||||
| AM_CONDITIONAL(BUILD_COMMS_NONE,  [ test "${comms_type}X" == "noneX" ]) | ||||
|  | ||||
| ############### RNG selection | ||||
| AC_ARG_ENABLE([rng],[AC_HELP_STRING([--enable-rng=ranlux48|mt19937],\ | ||||
| @@ -379,7 +385,7 @@ compiler version            : ${ax_cv_gxx_version} | ||||
| ----- BUILD OPTIONS ----------------------------------- | ||||
| SIMD                        : ${ac_SIMD} | ||||
| Threading                   : ${ac_openmp}  | ||||
| Communications type         : ${ac_COMMS} | ||||
| Communications type         : ${comms_type} | ||||
| Default precision           : ${ac_PRECISION} | ||||
| RNG choice                  : ${ac_RNG}  | ||||
| GMP                         : `if test "x$have_gmp" = xtrue; then echo yes; else echo no; fi` | ||||
|   | ||||
							
								
								
									
										124
									
								
								lib/FFT.h
									
									
									
									
									
								
							
							
						
						
									
										124
									
								
								lib/FFT.h
									
									
									
									
									
								
							| @@ -30,8 +30,10 @@ Author: Peter Boyle <paboyle@ph.ed.ac.uk> | ||||
| #define _GRID_FFT_H_ | ||||
|  | ||||
| #ifdef HAVE_FFTW	 | ||||
| #include <Grid/fftw/fftw3.h> | ||||
| #include <fftw3.h> | ||||
| #endif | ||||
|  | ||||
|  | ||||
| namespace Grid { | ||||
|  | ||||
|   template<class scalar> struct FFTW { }; | ||||
| @@ -139,10 +141,34 @@ namespace Grid { | ||||
|     } | ||||
|      | ||||
|     template<class vobj> | ||||
|     void FFT_dim(Lattice<vobj> &result,const Lattice<vobj> &source,int dim, int inverse){ | ||||
|     void FFT_dim_mask(Lattice<vobj> &result,const Lattice<vobj> &source,std::vector<int> mask,int sign){ | ||||
|  | ||||
|       conformable(result._grid,vgrid); | ||||
|       conformable(source._grid,vgrid); | ||||
|       Lattice<vobj> tmp(vgrid); | ||||
|       tmp = source; | ||||
|       for(int d=0;d<Nd;d++){ | ||||
| 	if( mask[d] ) { | ||||
| 	  FFT_dim(result,tmp,d,sign); | ||||
| 	  tmp=result; | ||||
| 	} | ||||
|       } | ||||
|     } | ||||
|  | ||||
|     template<class vobj> | ||||
|     void FFT_all_dim(Lattice<vobj> &result,const Lattice<vobj> &source,int sign){ | ||||
|       std::vector<int> mask(Nd,1); | ||||
|       FFT_dim_mask(result,source,mask,sign); | ||||
|     } | ||||
|  | ||||
|  | ||||
|     template<class vobj> | ||||
|     void FFT_dim(Lattice<vobj> &result,const Lattice<vobj> &source,int dim, int sign){ | ||||
| #ifndef HAVE_FFTW | ||||
|       assert(0); | ||||
| #else | ||||
|       conformable(result._grid,vgrid); | ||||
|       conformable(source._grid,vgrid); | ||||
|  | ||||
|       int L = vgrid->_ldimensions[dim]; | ||||
|       int G = vgrid->_fdimensions[dim]; | ||||
| @@ -159,17 +185,12 @@ namespace Grid { | ||||
|       typedef typename vobj::scalar_object sobj; | ||||
|       typedef typename sobj::scalar_type   scalar; | ||||
|        | ||||
|       Lattice<vobj> ssource(vgrid); ssource =source; | ||||
|       Lattice<sobj> pgsource(&pencil_g); | ||||
|       Lattice<sobj> pgresult(&pencil_g); pgresult=zero; | ||||
|       Lattice<sobj> pgbuf(&pencil_g); | ||||
|        | ||||
|  | ||||
| #ifndef HAVE_FFTW	 | ||||
|       assert(0); | ||||
| #else  | ||||
|       typedef typename FFTW<scalar>::FFTW_scalar FFTW_scalar; | ||||
|       typedef typename FFTW<scalar>::FFTW_plan   FFTW_plan; | ||||
|        | ||||
|       { | ||||
|       int Ncomp = sizeof(sobj)/sizeof(scalar); | ||||
|       int Nlow  = 1; | ||||
|       for(int d=0;d<dim;d++){ | ||||
| @@ -184,14 +205,15 @@ namespace Grid { | ||||
|       istride = ostride = Ncomp*Nlow; /* distance between two elements in the same FT */ | ||||
|       int *inembed = n, *onembed = n; | ||||
|        | ||||
| 	 | ||||
| 	int sign = FFTW_FORWARD; | ||||
| 	if (inverse) sign = FFTW_BACKWARD; | ||||
|       scalar div; | ||||
| 	  if ( sign == backward ) div = 1.0/G; | ||||
| 	  else if ( sign == forward ) div = 1.0; | ||||
| 	  else assert(0); | ||||
|        | ||||
|       FFTW_plan p; | ||||
|       { | ||||
| 	  FFTW_scalar *in = (FFTW_scalar *)&pgsource._odata[0]; | ||||
| 	  FFTW_scalar *out= (FFTW_scalar *)&pgresult._odata[0]; | ||||
|         FFTW_scalar *in = (FFTW_scalar *)&pgbuf._odata[0]; | ||||
|         FFTW_scalar *out= (FFTW_scalar *)&pgbuf._odata[0]; | ||||
|         p = FFTW<scalar>::fftw_plan_many_dft(rank,n,howmany, | ||||
|                                              in,inembed, | ||||
|                                              istride,idist, | ||||
| @@ -200,72 +222,76 @@ namespace Grid { | ||||
|                                              sign,FFTW_ESTIMATE); | ||||
|       } | ||||
|        | ||||
|     std::vector<int> lcoor(Nd), gcoor(Nd); | ||||
|  | ||||
|       // Barrel shift and collect global pencil | ||||
|       std::vector<int> lcoor(Nd), gcoor(Nd); | ||||
|       result = source; | ||||
|       for(int p=0;p<processors[dim];p++) { | ||||
|  | ||||
| 	  for(int idx=0;idx<sgrid->lSites();idx++) {  | ||||
|  | ||||
| 	     | ||||
|     	    sgrid->LocalIndexToLocalCoor(idx,lcoor); | ||||
|  | ||||
|         PARALLEL_REGION | ||||
|         { | ||||
|           std::vector<int> cbuf(Nd); | ||||
|           sobj s; | ||||
|            | ||||
| 	    peekLocalSite(s,ssource,lcoor); | ||||
|  | ||||
| 	    lcoor[dim]+=p*L; | ||||
| 	    | ||||
| 	    pokeLocalSite(s,pgsource,lcoor); | ||||
|           PARALLEL_FOR_LOOP_INTERN | ||||
|           for(int idx=0;idx<sgrid->lSites();idx++) { | ||||
|             sgrid->LocalIndexToLocalCoor(idx,cbuf); | ||||
|             peekLocalSite(s,result,cbuf); | ||||
|             cbuf[dim]+=p*L; | ||||
|             pokeLocalSite(s,pgbuf,cbuf); | ||||
|           } | ||||
|  | ||||
| 	  ssource = Cshift(ssource,dim,L); | ||||
|         } | ||||
|         result = Cshift(result,dim,L); | ||||
|       } | ||||
|        | ||||
|       // Loop over orthog coords | ||||
|       int NN=pencil_g.lSites(); | ||||
|       GridStopWatch timer; | ||||
|       timer.Start(); | ||||
|       PARALLEL_REGION | ||||
|       { | ||||
|         std::vector<int> cbuf(Nd); | ||||
|          | ||||
| //PARALLEL_FOR_LOOP | ||||
|         PARALLEL_FOR_LOOP_INTERN | ||||
|         for(int idx=0;idx<NN;idx++) { | ||||
| 	  pencil_g.LocalIndexToLocalCoor(idx,lcoor); | ||||
|  | ||||
| 	  if ( lcoor[dim] == 0 ) {  // restricts loop to plane at lcoor[dim]==0 | ||||
| 	    FFTW_scalar *in = (FFTW_scalar *)&pgsource._odata[idx]; | ||||
| 	    FFTW_scalar *out= (FFTW_scalar *)&pgresult._odata[idx]; | ||||
|           pencil_g.LocalIndexToLocalCoor(idx, cbuf); | ||||
|           if ( cbuf[dim] == 0 ) {  // restricts loop to plane at lcoor[dim]==0 | ||||
|             FFTW_scalar *in = (FFTW_scalar *)&pgbuf._odata[idx]; | ||||
|             FFTW_scalar *out= (FFTW_scalar *)&pgbuf._odata[idx]; | ||||
|             FFTW<scalar>::fftw_execute_dft(p,in,out); | ||||
|           } | ||||
|         } | ||||
|  | ||||
|       } | ||||
|       timer.Stop(); | ||||
|        | ||||
|       // performance counting | ||||
|       double add,mul,fma; | ||||
|       FFTW<scalar>::fftw_flops(p,&add,&mul,&fma); | ||||
|       flops_call = add+mul+2.0*fma; | ||||
|       usec += timer.useconds(); | ||||
|       flops+= flops_call*NN; | ||||
|        | ||||
|       // writing out result | ||||
|       int pc = processor_coor[dim]; | ||||
|         for(int idx=0;idx<sgrid->lSites();idx++) { | ||||
| 	  sgrid->LocalIndexToLocalCoor(idx,lcoor); | ||||
| 	  gcoor = lcoor; | ||||
| 	  // extract the result | ||||
|       PARALLEL_REGION | ||||
|       { | ||||
|         std::vector<int> clbuf(Nd), cgbuf(Nd); | ||||
|         sobj s; | ||||
| 	  gcoor[dim] = lcoor[dim]+L*pc; | ||||
| 	  peekLocalSite(s,pgresult,gcoor); | ||||
| 	  pokeLocalSite(s,result,lcoor); | ||||
|          | ||||
|         PARALLEL_FOR_LOOP_INTERN | ||||
|         for(int idx=0;idx<sgrid->lSites();idx++) { | ||||
|           sgrid->LocalIndexToLocalCoor(idx,clbuf); | ||||
|           cgbuf = clbuf; | ||||
|           cgbuf[dim] = clbuf[dim]+L*pc; | ||||
|           peekLocalSite(s,pgbuf,cgbuf); | ||||
|           s = s * div; | ||||
|           pokeLocalSite(s,result,clbuf); | ||||
|         } | ||||
|       } | ||||
|        | ||||
|       // destroying plan | ||||
|       FFTW<scalar>::fftw_destroy_plan(p); | ||||
|       } | ||||
| #endif | ||||
|  | ||||
|  | ||||
|     } | ||||
|  | ||||
|   }; | ||||
|  | ||||
|  | ||||
| } | ||||
|  | ||||
| #endif | ||||
|   | ||||
| @@ -77,11 +77,10 @@ Author: paboyle <paboyle@ph.ed.ac.uk> | ||||
| #include <Grid/Stencil.h>       | ||||
| #include <Grid/Algorithms.h>    | ||||
| #include <Grid/parallelIO/BinaryIO.h> | ||||
| #include <Grid/qcd/QCD.h> | ||||
| #include <Grid/parallelIO/NerscIO.h> | ||||
|  | ||||
| #include <Grid/FFT.h> | ||||
|  | ||||
| #include <Grid/qcd/QCD.h> | ||||
| #include <Grid/parallelIO/NerscIO.h> | ||||
| #include <Grid/qcd/hmc/NerscCheckpointer.h> | ||||
| #include <Grid/qcd/hmc/HmcRunner.h> | ||||
|  | ||||
|   | ||||
							
								
								
									
										39
									
								
								lib/Init.cc
									
									
									
									
									
								
							
							
						
						
									
										39
									
								
								lib/Init.cc
									
									
									
									
									
								
							| @@ -44,9 +44,33 @@ Author: paboyle <paboyle@ph.ed.ac.uk> | ||||
| #include <Grid.h> | ||||
| #include <algorithm> | ||||
| #include <iterator> | ||||
| #include <cstdlib> | ||||
| #include <memory> | ||||
|  | ||||
|  | ||||
| #include <fenv.h> | ||||
| #ifdef __APPLE__ | ||||
| static int | ||||
| feenableexcept (unsigned int excepts) | ||||
| { | ||||
|   static fenv_t fenv; | ||||
|   unsigned int new_excepts = excepts & FE_ALL_EXCEPT, | ||||
|     old_excepts;  // previous masks | ||||
|  | ||||
|   if ( fegetenv (&fenv) ) return -1; | ||||
|   old_excepts = fenv.__control & FE_ALL_EXCEPT; | ||||
|  | ||||
|   // unmask | ||||
|   fenv.__control &= ~new_excepts; | ||||
|   fenv.__mxcsr   &= ~(new_excepts << 7); | ||||
|  | ||||
|   return ( fesetenv (&fenv) ? -1 : old_excepts ); | ||||
| } | ||||
| #endif | ||||
|  | ||||
| namespace Grid { | ||||
|  | ||||
|  | ||||
| ////////////////////////////////////////////////////// | ||||
| // Convenience functions to access stadard command line arg | ||||
| // driven parallelism controls | ||||
| @@ -234,7 +258,7 @@ void Grid_init(int *argc,char ***argv) | ||||
|     std::cout<<GridLogMessage<<"  --decomposition : report on default omp,mpi and simd decomposition"<<std::endl;     | ||||
|     std::cout<<GridLogMessage<<"  --debug-signals : catch sigsegv and print a blame report"<<std::endl; | ||||
|     std::cout<<GridLogMessage<<"  --debug-stdout  : print stdout from EVERY node"<<std::endl;     | ||||
|     std::cout<<GridLogMessage<<"  --timestamp     : tag with millisecond resolution stamps"<<std::endl;     | ||||
|     std::cout<<GridLogMessage<<"  --notimestamp   : suppress millisecond resolution stamps"<<std::endl;     | ||||
|     std::cout<<GridLogMessage<<std::endl; | ||||
|     std::cout<<GridLogMessage<<"Performance:"<<std::endl; | ||||
|     std::cout<<GridLogMessage<<"  --dslash-generic: Wilson kernel for generic Nc"<<std::endl;     | ||||
| @@ -316,7 +340,9 @@ void Grid_init(int *argc,char ***argv) | ||||
|     arg= GridCmdOptionPayload(*argv,*argv+*argc,"--cacheblocking"); | ||||
|     GridCmdOptionIntVector(arg,LebesgueOrder::Block); | ||||
|   } | ||||
|   if( GridCmdOptionExists(*argv,*argv+*argc,"--timestamp") ){ | ||||
|   if( GridCmdOptionExists(*argv,*argv+*argc,"--notimestamp") ){ | ||||
|     GridLogTimestamp(0); | ||||
|   } else {  | ||||
|     GridLogTimestamp(1); | ||||
|   } | ||||
|  | ||||
| @@ -390,10 +416,7 @@ void Grid_sa_signal_handler(int sig,siginfo_t *si,void * ptr) | ||||
|   exit(0); | ||||
|   return; | ||||
| }; | ||||
| #ifdef GRID_FPE | ||||
| #define _GNU_SOURCE | ||||
| #include <fenv.h> | ||||
| #endif | ||||
|  | ||||
| void Grid_debug_handler_init(void) | ||||
| { | ||||
|   struct sigaction sa,osa; | ||||
| @@ -402,9 +425,9 @@ void Grid_debug_handler_init(void) | ||||
|   sa.sa_flags    = SA_SIGINFO; | ||||
|   sigaction(SIGSEGV,&sa,NULL); | ||||
|   sigaction(SIGTRAP,&sa,NULL); | ||||
| #ifdef GRID_FPE | ||||
|  | ||||
|   feenableexcept( FE_INVALID|FE_OVERFLOW|FE_DIVBYZERO); | ||||
|  | ||||
|   sigaction(SIGFPE,&sa,NULL); | ||||
| #endif | ||||
| } | ||||
| } | ||||
|   | ||||
| @@ -54,6 +54,7 @@ namespace Grid { | ||||
|   void GridCmdOptionCSL(std::string str,std::vector<std::string> & vec); | ||||
|   void GridCmdOptionIntVector(std::string &str,std::vector<int> & vec); | ||||
|  | ||||
|  | ||||
|   void GridParseLayout(char **argv,int argc, | ||||
| 		       std::vector<int> &latt, | ||||
| 		       std::vector<int> &simd, | ||||
|   | ||||
							
								
								
									
										15
									
								
								lib/Log.cc
									
									
									
									
									
								
							
							
						
						
									
										15
									
								
								lib/Log.cc
									
									
									
									
									
								
							| @@ -31,8 +31,23 @@ directory | ||||
| /*  END LEGAL */ | ||||
| #include <Grid.h> | ||||
|  | ||||
| #include <cxxabi.h> | ||||
|  | ||||
| namespace Grid { | ||||
|  | ||||
|   std::string demangle(const char* name) { | ||||
|      | ||||
|     int status = -4; // some arbitrary value to eliminate the compiler warning | ||||
|      | ||||
|     // enable c++11 by passing the flag -std=c++11 to g++ | ||||
|     std::unique_ptr<char, void(*)(void*)> res { | ||||
|       abi::__cxa_demangle(name, NULL, NULL, &status), | ||||
| 	std::free | ||||
| 	}; | ||||
|      | ||||
|     return (status==0) ? res.get() : name ; | ||||
|   } | ||||
|    | ||||
| GridStopWatch Logger::StopWatch; | ||||
| int Logger::timestamp; | ||||
| std::ostream Logger::devnull(0); | ||||
|   | ||||
| @@ -144,6 +144,7 @@ extern GridLogger GridLogIterative  ; | ||||
| extern GridLogger GridLogIntegrator  ; | ||||
| extern Colours    GridLogColours; | ||||
|  | ||||
|  std::string demangle(const char* name) ; | ||||
|  | ||||
| #define _NBACKTRACE (256) | ||||
| extern void * Grid_backtrace_buffer[_NBACKTRACE]; | ||||
| @@ -162,7 +163,7 @@ std::fclose(fp);	    \ | ||||
| int symbols    = backtrace        (Grid_backtrace_buffer,_NBACKTRACE);\ | ||||
| char **strings = backtrace_symbols(Grid_backtrace_buffer,symbols);\ | ||||
| for (int i = 0; i < symbols; i++){\ | ||||
|   std::fprintf (fp,"BackTrace Strings: %d %s\n",i, strings[i]); std::fflush(fp); \ | ||||
|   std::fprintf (fp,"BackTrace Strings: %d %s\n",i, demangle(strings[i]).c_str()); std::fflush(fp); \ | ||||
| }\ | ||||
| } | ||||
| #else  | ||||
|   | ||||
							
								
								
									
										12
									
								
								lib/Simd.h
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								lib/Simd.h
									
									
									
									
									
								
							| @@ -237,6 +237,18 @@ namespace Grid { | ||||
|     stream<<">"; | ||||
|     return stream; | ||||
|   } | ||||
|   inline std::ostream& operator<< (std::ostream& stream, const vInteger &o){ | ||||
|     int nn=vInteger::Nsimd(); | ||||
|     std::vector<Integer,alignedAllocator<Integer> > buf(nn); | ||||
|     vstore(o,&buf[0]); | ||||
|     stream<<"<"; | ||||
|     for(int i=0;i<nn;i++){ | ||||
|       stream<<buf[i]; | ||||
|       if(i<nn-1) stream<<","; | ||||
|     } | ||||
|     stream<<">"; | ||||
|     return stream; | ||||
|   } | ||||
|  | ||||
|  | ||||
| } | ||||
|   | ||||
| @@ -39,13 +39,18 @@ Author: paboyle <paboyle@ph.ed.ac.uk> | ||||
| #include <omp.h> | ||||
| #ifdef GRID_NUMA | ||||
| #define PARALLEL_FOR_LOOP        _Pragma("omp parallel for schedule(static)") | ||||
| #define PARALLEL_FOR_LOOP_INTERN _Pragma("omp for schedule(static)") | ||||
| #else | ||||
| #define PARALLEL_FOR_LOOP        _Pragma("omp parallel for schedule(runtime)") | ||||
| #define PARALLEL_FOR_LOOP_INTERN _Pragma("omp for schedule(runtime)") | ||||
| #endif | ||||
| #define PARALLEL_NESTED_LOOP2 _Pragma("omp parallel for collapse(2)") | ||||
| #define PARALLEL_REGION       _Pragma("omp parallel") | ||||
| #else | ||||
| #define PARALLEL_FOR_LOOP | ||||
| #define PARALLEL_FOR_LOOP_INTERN | ||||
| #define PARALLEL_NESTED_LOOP2 | ||||
| #define PARALLEL_REGION | ||||
| #endif | ||||
|  | ||||
| namespace Grid { | ||||
|   | ||||
| @@ -39,6 +39,10 @@ Author: Peter Boyle <paboyle@ph.ed.ac.uk> | ||||
| /// | ||||
| //////////////////////////////////////////////////////////////////////////////////////////////////////////////// | ||||
| #include <semaphore.h> | ||||
| #include <fcntl.h> | ||||
| #include <unistd.h> | ||||
| #include <limits.h> | ||||
|  | ||||
| typedef sem_t *Grid_semaphore; | ||||
|  | ||||
| #define SEM_INIT(S)      S = sem_open(sem_name,0,0600,0); assert ( S != SEM_FAILED ); | ||||
| @@ -48,7 +52,6 @@ typedef sem_t *Grid_semaphore; | ||||
|  | ||||
| #include <sys/mman.h> | ||||
|  | ||||
|  | ||||
| namespace Grid { | ||||
|  | ||||
| enum { COMMAND_ISEND, COMMAND_IRECV, COMMAND_WAITALL }; | ||||
| @@ -91,18 +94,18 @@ public: | ||||
|  | ||||
|   void SemInit(void) { | ||||
|     sprintf(sem_name,"/Grid_mpi3_sem_head_%d",universe_rank); | ||||
|     printf("SEM_NAME: %s \n",sem_name); | ||||
|     //    printf("SEM_NAME: %s \n",sem_name); | ||||
|     SEM_INIT(sem_head); | ||||
|     sprintf(sem_name,"/Grid_mpi3_sem_tail_%d",universe_rank); | ||||
|     printf("SEM_NAME: %s \n",sem_name); | ||||
|     //    printf("SEM_NAME: %s \n",sem_name); | ||||
|     SEM_INIT(sem_tail); | ||||
|   }   | ||||
|   void SemInitExcl(void) { | ||||
|     sprintf(sem_name,"/Grid_mpi3_sem_head_%d",universe_rank); | ||||
|     printf("SEM_INIT_EXCL: %s \n",sem_name); | ||||
|     //    printf("SEM_INIT_EXCL: %s \n",sem_name); | ||||
|     SEM_INIT_EXCL(sem_head); | ||||
|     sprintf(sem_name,"/Grid_mpi3_sem_tail_%d",universe_rank); | ||||
|     printf("SEM_INIT_EXCL: %s \n",sem_name); | ||||
|     //    printf("SEM_INIT_EXCL: %s \n",sem_name); | ||||
|     SEM_INIT_EXCL(sem_tail); | ||||
|   }   | ||||
|   void WakeUpDMA(void) {  | ||||
| @@ -118,7 +121,7 @@ public: | ||||
|     SEM_WAIT(sem_tail); | ||||
|   }; | ||||
|   void EventLoop (void) { | ||||
|     std::cout<< " Entering event loop "<<std::endl; | ||||
|     //    std::cout<< " Entering event loop "<<std::endl; | ||||
|     while(1){ | ||||
|       WaitForCommand(); | ||||
|       //      std::cout << "Getting command "<<std::endl; | ||||
| @@ -291,7 +294,7 @@ void MPIoffloadEngine::CommunicatorInit (MPI_Comm &communicator_world, | ||||
|   ///////////////////////////////////////////////////////////////////// | ||||
|   // Split into groups that can share memory (Verticals) | ||||
|   ///////////////////////////////////////////////////////////////////// | ||||
| #define MPI_SHARED_MEM_DEBUG | ||||
| #undef MPI_SHARED_MEM_DEBUG | ||||
| #ifdef  MPI_SHARED_MEM_DEBUG | ||||
|   MPI_Comm_split(communicator_universe,(UniverseRank/4),UniverseRank,&VerticalComm); | ||||
| #else  | ||||
| @@ -527,7 +530,7 @@ void Slave::Init(SlaveState * _state,MPI_Comm _squadron,int _universe_rank,int _ | ||||
|   universe_rank=_universe_rank; | ||||
|   vertical_rank=_vertical_rank; | ||||
|   state   =_state; | ||||
|   std::cout << "state "<<_state<<" comm "<<_squadron<<" universe_rank"<<universe_rank <<std::endl; | ||||
|   //  std::cout << "state "<<_state<<" comm "<<_squadron<<" universe_rank"<<universe_rank <<std::endl; | ||||
|   state->head = state->tail = state->start = 0; | ||||
|   base = (uint64_t)MPIoffloadEngine::VerticalShmBufs[0]; | ||||
|   int rank; MPI_Comm_rank(_squadron,&rank); | ||||
|   | ||||
							
								
								
									
										412
									
								
								lib/fftw/fftw3.h
									
									
									
									
									
								
							
							
						
						
									
										412
									
								
								lib/fftw/fftw3.h
									
									
									
									
									
								
							| @@ -1,412 +0,0 @@ | ||||
| /* | ||||
|  * Copyright (c) 2003, 2007-14 Matteo Frigo | ||||
|  * Copyright (c) 2003, 2007-14 Massachusetts Institute of Technology | ||||
|  * | ||||
|  * The following statement of license applies *only* to this header file, | ||||
|  * and *not* to the other files distributed with FFTW or derived therefrom: | ||||
|  *  | ||||
|  * Redistribution and use in source and binary forms, with or without | ||||
|  * modification, are permitted provided that the following conditions | ||||
|  * are met: | ||||
|  * | ||||
|  * 1. Redistributions of source code must retain the above copyright | ||||
|  *    notice, this list of conditions and the following disclaimer. | ||||
|  * | ||||
|  * 2. Redistributions in binary form must reproduce the above copyright | ||||
|  *    notice, this list of conditions and the following disclaimer in the | ||||
|  *    documentation and/or other materials provided with the distribution. | ||||
|  * | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS | ||||
|  * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
|  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE | ||||
|  * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY | ||||
|  * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | ||||
|  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE | ||||
|  * GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS | ||||
|  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, | ||||
|  * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||||
|  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
|  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  */ | ||||
|  | ||||
| /***************************** NOTE TO USERS ********************************* | ||||
|  * | ||||
|  *                 THIS IS A HEADER FILE, NOT A MANUAL | ||||
|  * | ||||
|  *    If you want to know how to use FFTW, please read the manual, | ||||
|  *    online at http://www.fftw.org/doc/ and also included with FFTW. | ||||
|  *    For a quick start, see the manual's tutorial section. | ||||
|  * | ||||
|  *   (Reading header files to learn how to use a library is a habit | ||||
|  *    stemming from code lacking a proper manual.  Arguably, it's a | ||||
|  *    *bad* habit in most cases, because header files can contain | ||||
|  *    interfaces that are not part of the public, stable API.) | ||||
|  * | ||||
|  ****************************************************************************/ | ||||
|  | ||||
| #ifndef FFTW3_H | ||||
| #define FFTW3_H | ||||
|  | ||||
| #include <stdio.h> | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| extern "C" | ||||
| { | ||||
| #endif /* __cplusplus */ | ||||
|  | ||||
| /* If <complex.h> is included, use the C99 complex type.  Otherwise | ||||
|    define a type bit-compatible with C99 complex */ | ||||
| #if !defined(FFTW_NO_Complex) && defined(_Complex_I) && defined(complex) && defined(I) | ||||
| #  define FFTW_DEFINE_COMPLEX(R, C) typedef R _Complex C | ||||
| #else | ||||
| #  define FFTW_DEFINE_COMPLEX(R, C) typedef R C[2] | ||||
| #endif | ||||
|  | ||||
| #define FFTW_CONCAT(prefix, name) prefix ## name | ||||
| #define FFTW_MANGLE_DOUBLE(name) FFTW_CONCAT(fftw_, name) | ||||
| #define FFTW_MANGLE_FLOAT(name) FFTW_CONCAT(fftwf_, name) | ||||
| #define FFTW_MANGLE_LONG_DOUBLE(name) FFTW_CONCAT(fftwl_, name) | ||||
| #define FFTW_MANGLE_QUAD(name) FFTW_CONCAT(fftwq_, name) | ||||
|  | ||||
| /* IMPORTANT: for Windows compilers, you should add a line | ||||
|         #define FFTW_DLL | ||||
|    here and in kernel/ifftw.h if you are compiling/using FFTW as a | ||||
|    DLL, in order to do the proper importing/exporting, or | ||||
|    alternatively compile with -DFFTW_DLL or the equivalent | ||||
|    command-line flag.  This is not necessary under MinGW/Cygwin, where | ||||
|    libtool does the imports/exports automatically. */ | ||||
| #if defined(FFTW_DLL) && (defined(_WIN32) || defined(__WIN32__)) | ||||
|    /* annoying Windows syntax for shared-library declarations */ | ||||
| #  if defined(COMPILING_FFTW) /* defined in api.h when compiling FFTW */ | ||||
| #    define FFTW_EXTERN extern __declspec(dllexport)  | ||||
| #  else /* user is calling FFTW; import symbol */ | ||||
| #    define FFTW_EXTERN extern __declspec(dllimport)  | ||||
| #  endif | ||||
| #else | ||||
| #  define FFTW_EXTERN extern | ||||
| #endif | ||||
|  | ||||
| enum fftw_r2r_kind_do_not_use_me { | ||||
|      FFTW_R2HC=0, FFTW_HC2R=1, FFTW_DHT=2, | ||||
|      FFTW_REDFT00=3, FFTW_REDFT01=4, FFTW_REDFT10=5, FFTW_REDFT11=6, | ||||
|      FFTW_RODFT00=7, FFTW_RODFT01=8, FFTW_RODFT10=9, FFTW_RODFT11=10 | ||||
| }; | ||||
|  | ||||
| struct fftw_iodim_do_not_use_me { | ||||
|      int n;                     /* dimension size */ | ||||
|      int is;			/* input stride */ | ||||
|      int os;			/* output stride */ | ||||
| }; | ||||
|  | ||||
| #include <stddef.h> /* for ptrdiff_t */ | ||||
| struct fftw_iodim64_do_not_use_me { | ||||
|      ptrdiff_t n;                     /* dimension size */ | ||||
|      ptrdiff_t is;			/* input stride */ | ||||
|      ptrdiff_t os;			/* output stride */ | ||||
| }; | ||||
|  | ||||
| typedef void (*fftw_write_char_func_do_not_use_me)(char c, void *); | ||||
| typedef int (*fftw_read_char_func_do_not_use_me)(void *); | ||||
|  | ||||
| /* | ||||
|   huge second-order macro that defines prototypes for all API | ||||
|   functions.  We expand this macro for each supported precision | ||||
|   | ||||
|   X: name-mangling macro | ||||
|   R: real data type | ||||
|   C: complex data type | ||||
| */ | ||||
|  | ||||
| #define FFTW_DEFINE_API(X, R, C)					   \ | ||||
| 									   \ | ||||
| FFTW_DEFINE_COMPLEX(R, C);						   \ | ||||
| 									   \ | ||||
| typedef struct X(plan_s) *X(plan);					   \ | ||||
| 									   \ | ||||
| typedef struct fftw_iodim_do_not_use_me X(iodim);			   \ | ||||
| typedef struct fftw_iodim64_do_not_use_me X(iodim64);			   \ | ||||
| 									   \ | ||||
| typedef enum fftw_r2r_kind_do_not_use_me X(r2r_kind);			   \ | ||||
| 									   \ | ||||
| typedef fftw_write_char_func_do_not_use_me X(write_char_func);		   \ | ||||
| typedef fftw_read_char_func_do_not_use_me X(read_char_func);		   \ | ||||
| 									   \ | ||||
| FFTW_EXTERN void X(execute)(const X(plan) p);				   \ | ||||
| 									   \ | ||||
| FFTW_EXTERN X(plan) X(plan_dft)(int rank, const int *n,			   \ | ||||
| 		    C *in, C *out, int sign, unsigned flags);		   \ | ||||
| 									   \ | ||||
| FFTW_EXTERN X(plan) X(plan_dft_1d)(int n, C *in, C *out, int sign,	   \ | ||||
| 		       unsigned flags);					   \ | ||||
| FFTW_EXTERN X(plan) X(plan_dft_2d)(int n0, int n1,			   \ | ||||
| 		       C *in, C *out, int sign, unsigned flags);	   \ | ||||
| FFTW_EXTERN X(plan) X(plan_dft_3d)(int n0, int n1, int n2,		   \ | ||||
| 		       C *in, C *out, int sign, unsigned flags);	   \ | ||||
| 									   \ | ||||
| FFTW_EXTERN X(plan) X(plan_many_dft)(int rank, const int *n,		   \ | ||||
|                          int howmany,					   \ | ||||
|                          C *in, const int *inembed,			   \ | ||||
|                          int istride, int idist,			   \ | ||||
|                          C *out, const int *onembed,			   \ | ||||
|                          int ostride, int odist,			   \ | ||||
|                          int sign, unsigned flags);			   \ | ||||
| 									   \ | ||||
| FFTW_EXTERN X(plan) X(plan_guru_dft)(int rank, const X(iodim) *dims,	   \ | ||||
| 			 int howmany_rank,				   \ | ||||
| 			 const X(iodim) *howmany_dims,			   \ | ||||
| 			 C *in, C *out,					   \ | ||||
| 			 int sign, unsigned flags);			   \ | ||||
| FFTW_EXTERN X(plan) X(plan_guru_split_dft)(int rank, const X(iodim) *dims, \ | ||||
| 			 int howmany_rank,				   \ | ||||
| 			 const X(iodim) *howmany_dims,			   \ | ||||
| 			 R *ri, R *ii, R *ro, R *io,			   \ | ||||
| 			 unsigned flags);				   \ | ||||
| 									   \ | ||||
| FFTW_EXTERN X(plan) X(plan_guru64_dft)(int rank,			   \ | ||||
|                          const X(iodim64) *dims,			   \ | ||||
| 			 int howmany_rank,				   \ | ||||
| 			 const X(iodim64) *howmany_dims,		   \ | ||||
| 			 C *in, C *out,					   \ | ||||
| 			 int sign, unsigned flags);			   \ | ||||
| FFTW_EXTERN X(plan) X(plan_guru64_split_dft)(int rank,			   \ | ||||
|                          const X(iodim64) *dims,			   \ | ||||
| 			 int howmany_rank,				   \ | ||||
| 			 const X(iodim64) *howmany_dims,		   \ | ||||
| 			 R *ri, R *ii, R *ro, R *io,			   \ | ||||
| 			 unsigned flags);				   \ | ||||
| 									   \ | ||||
| FFTW_EXTERN void X(execute_dft)(const X(plan) p, C *in, C *out);	   \ | ||||
| FFTW_EXTERN void X(execute_split_dft)(const X(plan) p, R *ri, R *ii,	   \ | ||||
|                                       R *ro, R *io);			   \ | ||||
| 									   \ | ||||
| FFTW_EXTERN X(plan) X(plan_many_dft_r2c)(int rank, const int *n,	   \ | ||||
|                              int howmany,				   \ | ||||
|                              R *in, const int *inembed,			   \ | ||||
|                              int istride, int idist,			   \ | ||||
|                              C *out, const int *onembed,		   \ | ||||
|                              int ostride, int odist,			   \ | ||||
|                              unsigned flags);				   \ | ||||
| 									   \ | ||||
| FFTW_EXTERN X(plan) X(plan_dft_r2c)(int rank, const int *n,		   \ | ||||
|                         R *in, C *out, unsigned flags);			   \ | ||||
| 									   \ | ||||
| FFTW_EXTERN X(plan) X(plan_dft_r2c_1d)(int n,R *in,C *out,unsigned flags); \ | ||||
| FFTW_EXTERN X(plan) X(plan_dft_r2c_2d)(int n0, int n1,			   \ | ||||
| 			   R *in, C *out, unsigned flags);		   \ | ||||
| FFTW_EXTERN X(plan) X(plan_dft_r2c_3d)(int n0, int n1,			   \ | ||||
| 			   int n2,					   \ | ||||
| 			   R *in, C *out, unsigned flags);		   \ | ||||
| 									   \ | ||||
| 									   \ | ||||
| FFTW_EXTERN X(plan) X(plan_many_dft_c2r)(int rank, const int *n,	   \ | ||||
| 			     int howmany,				   \ | ||||
| 			     C *in, const int *inembed,			   \ | ||||
| 			     int istride, int idist,			   \ | ||||
| 			     R *out, const int *onembed,		   \ | ||||
| 			     int ostride, int odist,			   \ | ||||
| 			     unsigned flags);				   \ | ||||
| 									   \ | ||||
| FFTW_EXTERN X(plan) X(plan_dft_c2r)(int rank, const int *n,		   \ | ||||
|                         C *in, R *out, unsigned flags);			   \ | ||||
| 									   \ | ||||
| FFTW_EXTERN X(plan) X(plan_dft_c2r_1d)(int n,C *in,R *out,unsigned flags); \ | ||||
| FFTW_EXTERN X(plan) X(plan_dft_c2r_2d)(int n0, int n1,			   \ | ||||
| 			   C *in, R *out, unsigned flags);		   \ | ||||
| FFTW_EXTERN X(plan) X(plan_dft_c2r_3d)(int n0, int n1,			   \ | ||||
| 			   int n2,					   \ | ||||
| 			   C *in, R *out, unsigned flags);		   \ | ||||
| 									   \ | ||||
| FFTW_EXTERN X(plan) X(plan_guru_dft_r2c)(int rank, const X(iodim) *dims,   \ | ||||
| 			     int howmany_rank,				   \ | ||||
| 			     const X(iodim) *howmany_dims,		   \ | ||||
| 			     R *in, C *out,				   \ | ||||
| 			     unsigned flags);				   \ | ||||
| FFTW_EXTERN X(plan) X(plan_guru_dft_c2r)(int rank, const X(iodim) *dims,   \ | ||||
| 			     int howmany_rank,				   \ | ||||
| 			     const X(iodim) *howmany_dims,		   \ | ||||
| 			     C *in, R *out,				   \ | ||||
| 			     unsigned flags);				   \ | ||||
| 									   \ | ||||
| FFTW_EXTERN X(plan) X(plan_guru_split_dft_r2c)(				   \ | ||||
|                              int rank, const X(iodim) *dims,		   \ | ||||
| 			     int howmany_rank,				   \ | ||||
| 			     const X(iodim) *howmany_dims,		   \ | ||||
| 			     R *in, R *ro, R *io,			   \ | ||||
| 			     unsigned flags);				   \ | ||||
| FFTW_EXTERN X(plan) X(plan_guru_split_dft_c2r)(				   \ | ||||
|                              int rank, const X(iodim) *dims,		   \ | ||||
| 			     int howmany_rank,				   \ | ||||
| 			     const X(iodim) *howmany_dims,		   \ | ||||
| 			     R *ri, R *ii, R *out,			   \ | ||||
| 			     unsigned flags);				   \ | ||||
| 									   \ | ||||
| FFTW_EXTERN X(plan) X(plan_guru64_dft_r2c)(int rank,			   \ | ||||
|                              const X(iodim64) *dims,			   \ | ||||
| 			     int howmany_rank,				   \ | ||||
| 			     const X(iodim64) *howmany_dims,		   \ | ||||
| 			     R *in, C *out,				   \ | ||||
| 			     unsigned flags);				   \ | ||||
| FFTW_EXTERN X(plan) X(plan_guru64_dft_c2r)(int rank,			   \ | ||||
|                              const X(iodim64) *dims,			   \ | ||||
| 			     int howmany_rank,				   \ | ||||
| 			     const X(iodim64) *howmany_dims,		   \ | ||||
| 			     C *in, R *out,				   \ | ||||
| 			     unsigned flags);				   \ | ||||
| 									   \ | ||||
| FFTW_EXTERN X(plan) X(plan_guru64_split_dft_r2c)(			   \ | ||||
|                              int rank, const X(iodim64) *dims,		   \ | ||||
| 			     int howmany_rank,				   \ | ||||
| 			     const X(iodim64) *howmany_dims,		   \ | ||||
| 			     R *in, R *ro, R *io,			   \ | ||||
| 			     unsigned flags);				   \ | ||||
| FFTW_EXTERN X(plan) X(plan_guru64_split_dft_c2r)(			   \ | ||||
|                              int rank, const X(iodim64) *dims,		   \ | ||||
| 			     int howmany_rank,				   \ | ||||
| 			     const X(iodim64) *howmany_dims,		   \ | ||||
| 			     R *ri, R *ii, R *out,			   \ | ||||
| 			     unsigned flags);				   \ | ||||
| 									   \ | ||||
| FFTW_EXTERN void X(execute_dft_r2c)(const X(plan) p, R *in, C *out);	   \ | ||||
| FFTW_EXTERN void X(execute_dft_c2r)(const X(plan) p, C *in, R *out);	   \ | ||||
| 									   \ | ||||
| FFTW_EXTERN void X(execute_split_dft_r2c)(const X(plan) p,		   \ | ||||
|                                           R *in, R *ro, R *io);		   \ | ||||
| FFTW_EXTERN void X(execute_split_dft_c2r)(const X(plan) p,		   \ | ||||
|                                           R *ri, R *ii, R *out);	   \ | ||||
| 									   \ | ||||
| FFTW_EXTERN X(plan) X(plan_many_r2r)(int rank, const int *n,		   \ | ||||
|                          int howmany,					   \ | ||||
|                          R *in, const int *inembed,			   \ | ||||
|                          int istride, int idist,			   \ | ||||
|                          R *out, const int *onembed,			   \ | ||||
|                          int ostride, int odist,			   \ | ||||
|                          const X(r2r_kind) *kind, unsigned flags);	   \ | ||||
| 									   \ | ||||
| FFTW_EXTERN X(plan) X(plan_r2r)(int rank, const int *n, R *in, R *out,	   \ | ||||
|                     const X(r2r_kind) *kind, unsigned flags);		   \ | ||||
| 									   \ | ||||
| FFTW_EXTERN X(plan) X(plan_r2r_1d)(int n, R *in, R *out,		   \ | ||||
|                        X(r2r_kind) kind, unsigned flags);		   \ | ||||
| FFTW_EXTERN X(plan) X(plan_r2r_2d)(int n0, int n1, R *in, R *out,	   \ | ||||
|                        X(r2r_kind) kind0, X(r2r_kind) kind1,		   \ | ||||
|                        unsigned flags);					   \ | ||||
| FFTW_EXTERN X(plan) X(plan_r2r_3d)(int n0, int n1, int n2,		   \ | ||||
|                        R *in, R *out, X(r2r_kind) kind0,		   \ | ||||
|                        X(r2r_kind) kind1, X(r2r_kind) kind2,		   \ | ||||
|                        unsigned flags);					   \ | ||||
| 									   \ | ||||
| FFTW_EXTERN X(plan) X(plan_guru_r2r)(int rank, const X(iodim) *dims,	   \ | ||||
|                          int howmany_rank,				   \ | ||||
|                          const X(iodim) *howmany_dims,			   \ | ||||
|                          R *in, R *out,					   \ | ||||
|                          const X(r2r_kind) *kind, unsigned flags);	   \ | ||||
| 									   \ | ||||
| FFTW_EXTERN X(plan) X(plan_guru64_r2r)(int rank, const X(iodim64) *dims,   \ | ||||
|                          int howmany_rank,				   \ | ||||
|                          const X(iodim64) *howmany_dims,		   \ | ||||
|                          R *in, R *out,					   \ | ||||
|                          const X(r2r_kind) *kind, unsigned flags);	   \ | ||||
| 									   \ | ||||
| FFTW_EXTERN void X(execute_r2r)(const X(plan) p, R *in, R *out);	   \ | ||||
| 									   \ | ||||
| FFTW_EXTERN void X(destroy_plan)(X(plan) p);				   \ | ||||
| FFTW_EXTERN void X(forget_wisdom)(void);				   \ | ||||
| FFTW_EXTERN void X(cleanup)(void);					   \ | ||||
| 									   \ | ||||
| FFTW_EXTERN void X(set_timelimit)(double t);				   \ | ||||
| 									   \ | ||||
| FFTW_EXTERN void X(plan_with_nthreads)(int nthreads);			   \ | ||||
| FFTW_EXTERN int X(init_threads)(void);					   \ | ||||
| FFTW_EXTERN void X(cleanup_threads)(void);				   \ | ||||
| 									   \ | ||||
| FFTW_EXTERN int X(export_wisdom_to_filename)(const char *filename);	   \ | ||||
| FFTW_EXTERN void X(export_wisdom_to_file)(FILE *output_file);		   \ | ||||
| FFTW_EXTERN char *X(export_wisdom_to_string)(void);			   \ | ||||
| FFTW_EXTERN void X(export_wisdom)(X(write_char_func) write_char,   	   \ | ||||
|                                   void *data);				   \ | ||||
| FFTW_EXTERN int X(import_system_wisdom)(void);				   \ | ||||
| FFTW_EXTERN int X(import_wisdom_from_filename)(const char *filename);	   \ | ||||
| FFTW_EXTERN int X(import_wisdom_from_file)(FILE *input_file);		   \ | ||||
| FFTW_EXTERN int X(import_wisdom_from_string)(const char *input_string);	   \ | ||||
| FFTW_EXTERN int X(import_wisdom)(X(read_char_func) read_char, void *data); \ | ||||
| 									   \ | ||||
| FFTW_EXTERN void X(fprint_plan)(const X(plan) p, FILE *output_file);	   \ | ||||
| FFTW_EXTERN void X(print_plan)(const X(plan) p);			   \ | ||||
| FFTW_EXTERN char *X(sprint_plan)(const X(plan) p);			   \ | ||||
| 									   \ | ||||
| FFTW_EXTERN void *X(malloc)(size_t n);					   \ | ||||
| FFTW_EXTERN R *X(alloc_real)(size_t n);					   \ | ||||
| FFTW_EXTERN C *X(alloc_complex)(size_t n);				   \ | ||||
| FFTW_EXTERN void X(free)(void *p);					   \ | ||||
| 									   \ | ||||
| FFTW_EXTERN void X(flops)(const X(plan) p,				   \ | ||||
|                           double *add, double *mul, double *fmas);	   \ | ||||
| FFTW_EXTERN double X(estimate_cost)(const X(plan) p);			   \ | ||||
| FFTW_EXTERN double X(cost)(const X(plan) p);				   \ | ||||
| 									   \ | ||||
| FFTW_EXTERN int X(alignment_of)(R *p);                                     \ | ||||
| FFTW_EXTERN const char X(version)[];                                       \ | ||||
| FFTW_EXTERN const char X(cc)[];						   \ | ||||
| FFTW_EXTERN const char X(codelet_optim)[]; | ||||
|  | ||||
|  | ||||
| /* end of FFTW_DEFINE_API macro */ | ||||
|  | ||||
| FFTW_DEFINE_API(FFTW_MANGLE_DOUBLE, double, fftw_complex) | ||||
| FFTW_DEFINE_API(FFTW_MANGLE_FLOAT, float, fftwf_complex) | ||||
| FFTW_DEFINE_API(FFTW_MANGLE_LONG_DOUBLE, long double, fftwl_complex) | ||||
|  | ||||
| /* __float128 (quad precision) is a gcc extension on i386, x86_64, and ia64 | ||||
|    for gcc >= 4.6 (compiled in FFTW with --enable-quad-precision) */ | ||||
| #if (__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 6)) \ | ||||
|  && !(defined(__ICC) || defined(__INTEL_COMPILER)) \ | ||||
|  && (defined(__i386__) || defined(__x86_64__) || defined(__ia64__)) | ||||
| #  if !defined(FFTW_NO_Complex) && defined(_Complex_I) && defined(complex) && defined(I) | ||||
| /* note: __float128 is a typedef, which is not supported with the _Complex | ||||
|          keyword in gcc, so instead we use this ugly __attribute__ version. | ||||
|          However, we can't simply pass the __attribute__ version to | ||||
|          FFTW_DEFINE_API because the __attribute__ confuses gcc in pointer | ||||
|          types.  Hence redefining FFTW_DEFINE_COMPLEX.  Ugh. */ | ||||
| #    undef FFTW_DEFINE_COMPLEX | ||||
| #    define FFTW_DEFINE_COMPLEX(R, C) typedef _Complex float __attribute__((mode(TC))) C | ||||
| #  endif | ||||
| FFTW_DEFINE_API(FFTW_MANGLE_QUAD, __float128, fftwq_complex) | ||||
| #endif | ||||
|  | ||||
| #define FFTW_FORWARD (-1) | ||||
| #define FFTW_BACKWARD (+1) | ||||
|  | ||||
| #define FFTW_NO_TIMELIMIT (-1.0) | ||||
|  | ||||
| /* documented flags */ | ||||
| #define FFTW_MEASURE (0U) | ||||
| #define FFTW_DESTROY_INPUT (1U << 0) | ||||
| #define FFTW_UNALIGNED (1U << 1) | ||||
| #define FFTW_CONSERVE_MEMORY (1U << 2) | ||||
| #define FFTW_EXHAUSTIVE (1U << 3) /* NO_EXHAUSTIVE is default */ | ||||
| #define FFTW_PRESERVE_INPUT (1U << 4) /* cancels FFTW_DESTROY_INPUT */ | ||||
| #define FFTW_PATIENT (1U << 5) /* IMPATIENT is default */ | ||||
| #define FFTW_ESTIMATE (1U << 6) | ||||
| #define FFTW_WISDOM_ONLY (1U << 21) | ||||
|  | ||||
| /* undocumented beyond-guru flags */ | ||||
| #define FFTW_ESTIMATE_PATIENT (1U << 7) | ||||
| #define FFTW_BELIEVE_PCOST (1U << 8) | ||||
| #define FFTW_NO_DFT_R2HC (1U << 9) | ||||
| #define FFTW_NO_NONTHREADED (1U << 10) | ||||
| #define FFTW_NO_BUFFERING (1U << 11) | ||||
| #define FFTW_NO_INDIRECT_OP (1U << 12) | ||||
| #define FFTW_ALLOW_LARGE_GENERIC (1U << 13) /* NO_LARGE_GENERIC is default */ | ||||
| #define FFTW_NO_RANK_SPLITS (1U << 14) | ||||
| #define FFTW_NO_VRANK_SPLITS (1U << 15) | ||||
| #define FFTW_NO_VRECURSE (1U << 16) | ||||
| #define FFTW_NO_SIMD (1U << 17) | ||||
| #define FFTW_NO_SLOW (1U << 18) | ||||
| #define FFTW_NO_FIXED_RADIX_LARGE_N (1U << 19) | ||||
| #define FFTW_ALLOW_PRUNING (1U << 20) | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| }  /* extern "C" */ | ||||
| #endif /* __cplusplus */ | ||||
|  | ||||
| #endif /* FFTW3_H */ | ||||
| @@ -261,6 +261,7 @@ GridUnopClass(UnaryExp, exp(a)); | ||||
| GridBinOpClass(BinaryAdd, lhs + rhs); | ||||
| GridBinOpClass(BinarySub, lhs - rhs); | ||||
| GridBinOpClass(BinaryMul, lhs *rhs); | ||||
| GridBinOpClass(BinaryDiv, lhs /rhs); | ||||
|  | ||||
| GridBinOpClass(BinaryAnd, lhs &rhs); | ||||
| GridBinOpClass(BinaryOr, lhs | rhs); | ||||
| @@ -385,6 +386,7 @@ GRID_DEF_UNOP(exp, UnaryExp); | ||||
| GRID_DEF_BINOP(operator+, BinaryAdd); | ||||
| GRID_DEF_BINOP(operator-, BinarySub); | ||||
| GRID_DEF_BINOP(operator*, BinaryMul); | ||||
| GRID_DEF_BINOP(operator/, BinaryDiv); | ||||
|  | ||||
| GRID_DEF_BINOP(operator&, BinaryAnd); | ||||
| GRID_DEF_BINOP(operator|, BinaryOr); | ||||
|   | ||||
| @@ -300,17 +300,6 @@ PARALLEL_FOR_LOOP | ||||
|         *this = (*this)+r; | ||||
|         return *this; | ||||
|     } | ||||
|      | ||||
|     strong_inline friend Lattice<vobj> operator / (const Lattice<vobj> &lhs,const Lattice<vobj> &rhs){ | ||||
|         conformable(lhs,rhs); | ||||
|         Lattice<vobj> ret(lhs._grid); | ||||
| PARALLEL_FOR_LOOP | ||||
|         for(int ss=0;ss<lhs._grid->oSites();ss++){ | ||||
| 	  ret._odata[ss] = lhs._odata[ss]*pow(rhs._odata[ss],-1.0); | ||||
|         } | ||||
|         return ret; | ||||
|     }; | ||||
|  | ||||
|  }; // class Lattice | ||||
|  | ||||
|   template<class vobj> std::ostream& operator<< (std::ostream& stream, const Lattice<vobj> &o){ | ||||
|   | ||||
| @@ -457,7 +457,7 @@ class BinaryIO { | ||||
|     // available (how short sighted is that?) | ||||
|     ////////////////////////////////////////////////////////// | ||||
|     Umu = zero; | ||||
|     static uint32_t csum=0; | ||||
|     static uint32_t csum; csum=0; | ||||
|     fobj fileObj; | ||||
|     static sobj siteObj; // Static to place in symmetric region for SHMEM | ||||
|  | ||||
|   | ||||
| @@ -50,6 +50,30 @@ namespace QCD { | ||||
|    mass(_mass) | ||||
|  { } | ||||
|  | ||||
| template<class Impl>   | ||||
| void CayleyFermion5D<Impl>::Dminus(const FermionField &psi, FermionField &chi) | ||||
| { | ||||
|   int Ls=this->Ls; | ||||
|   FermionField tmp(psi._grid); | ||||
|  | ||||
|   this->DW(psi,tmp,DaggerNo); | ||||
|  | ||||
|   for(int s=0;s<Ls;s++){ | ||||
|     axpby_ssp(chi,Coeff_t(1.0),psi,-cs[s],tmp,s,s);// chi = (1-c[s] D_W) psi | ||||
|   } | ||||
| } | ||||
| template<class Impl>   | ||||
| void CayleyFermion5D<Impl>::DminusDag(const FermionField &psi, FermionField &chi) | ||||
| { | ||||
|   int Ls=this->Ls; | ||||
|   FermionField tmp(psi._grid); | ||||
|  | ||||
|   this->DW(psi,tmp,DaggerYes); | ||||
|  | ||||
|   for(int s=0;s<Ls;s++){ | ||||
|     axpby_ssp(chi,Coeff_t(1.0),psi,-cs[s],tmp,s,s);// chi = (1-c[s] D_W) psi | ||||
|   } | ||||
| } | ||||
| template<class Impl>   | ||||
| void CayleyFermion5D<Impl>::M5D   (const FermionField &psi, FermionField &chi) | ||||
| { | ||||
|   | ||||
| @@ -56,6 +56,9 @@ namespace Grid { | ||||
|       virtual void   M5D   (const FermionField &psi, FermionField &chi); | ||||
|       virtual void   M5Ddag(const FermionField &psi, FermionField &chi); | ||||
|  | ||||
|       virtual void   Dminus(const FermionField &psi, FermionField &chi); | ||||
|       virtual void   DminusDag(const FermionField &psi, FermionField &chi); | ||||
|  | ||||
|       ///////////////////////////////////////////////////// | ||||
|       // Instantiate different versions depending on Impl | ||||
|       ///////////////////////////////////////////////////// | ||||
| @@ -117,6 +120,7 @@ namespace Grid { | ||||
| 		      GridRedBlackCartesian &FourDimRedBlackGrid, | ||||
| 		      RealD _mass,RealD _M5,const ImplParams &p= ImplParams()); | ||||
|  | ||||
|  | ||||
|     protected: | ||||
|       void SetCoefficientsZolotarev(RealD zolohi,Approx::zolotarev_data *zdata,RealD b,RealD c); | ||||
|       void SetCoefficientsTanh(Approx::zolotarev_data *zdata,RealD b,RealD c); | ||||
|   | ||||
| @@ -42,6 +42,10 @@ namespace Grid { | ||||
|      INHERIT_IMPL_TYPES(Impl); | ||||
|     public: | ||||
|  | ||||
|       void  MomentumSpacePropagator(FermionField &out,const FermionField &in,RealD _m) {  | ||||
| 	this->MomentumSpacePropagatorHt(out,in,_m); | ||||
|       }; | ||||
|  | ||||
|       virtual void   Instantiatable(void) {}; | ||||
|       // Constructors | ||||
|       DomainWallFermion(GaugeField &_Umu, | ||||
| @@ -51,6 +55,7 @@ namespace Grid { | ||||
| 			GridRedBlackCartesian &FourDimRedBlackGrid, | ||||
| 			RealD _mass,RealD _M5,const ImplParams &p= ImplParams()) :  | ||||
|  | ||||
|  | ||||
|       CayleyFermion5D<Impl>(_Umu, | ||||
| 			    FiveDimGrid, | ||||
| 			    FiveDimRedBlackGrid, | ||||
|   | ||||
| @@ -91,6 +91,20 @@ namespace Grid { | ||||
|       virtual void  Mdiag  (const FermionField &in, FermionField &out) { Mooee(in,out);};   // Same as Mooee applied to both CB's | ||||
|       virtual void  Mdir   (const FermionField &in, FermionField &out,int dir,int disp)=0;   // case by case Wilson, Clover, Cayley, ContFrac, PartFrac | ||||
|  | ||||
|  | ||||
|       virtual void  MomentumSpacePropagator(FermionField &out,const FermionField &in,RealD _m) { assert(0);}; | ||||
|  | ||||
|       virtual void  FreePropagator(const FermionField &in,FermionField &out,RealD mass) {  | ||||
| 	FFT theFFT((GridCartesian *) in._grid); | ||||
|  | ||||
| 	FermionField in_k(in._grid); | ||||
| 	FermionField prop_k(in._grid); | ||||
|  | ||||
| 	theFFT.FFT_all_dim(in_k,in,FFT::forward); | ||||
|         this->MomentumSpacePropagator(prop_k,in_k,mass); | ||||
| 	theFFT.FFT_all_dim(out,prop_k,FFT::backward); | ||||
|       }; | ||||
|  | ||||
|       /////////////////////////////////////////////// | ||||
|       // Updates gauge field during HMC | ||||
|       /////////////////////////////////////////////// | ||||
|   | ||||
| @@ -42,6 +42,10 @@ namespace Grid { | ||||
|      INHERIT_IMPL_TYPES(Impl); | ||||
|     public: | ||||
|  | ||||
|      void  MomentumSpacePropagator(FermionField &out,const FermionField &in,RealD _m) {  | ||||
|        this->MomentumSpacePropagatorHw(out,in,_m); | ||||
|      }; | ||||
|  | ||||
|      // Constructors | ||||
|     OverlapWilsonCayleyTanhFermion(GaugeField &_Umu, | ||||
| 				   GridCartesian         &FiveDimGrid, | ||||
|   | ||||
| @@ -101,6 +101,7 @@ void WilsonFermion<Impl>::Meooe(const FermionField &in, FermionField &out) { | ||||
|     DhopOE(in, out, DaggerNo); | ||||
|   } | ||||
| } | ||||
|  | ||||
| template <class Impl> | ||||
| void WilsonFermion<Impl>::MeooeDag(const FermionField &in, FermionField &out) { | ||||
|   if (in.checkerboard == Odd) { | ||||
| @@ -110,31 +111,86 @@ void WilsonFermion<Impl>::MeooeDag(const FermionField &in, FermionField &out) { | ||||
|   } | ||||
| } | ||||
|    | ||||
| template <class Impl> | ||||
| void WilsonFermion<Impl>::Mooee(const FermionField &in, FermionField &out) { | ||||
|   template <class Impl> | ||||
|   void WilsonFermion<Impl>::Mooee(const FermionField &in, FermionField &out) { | ||||
|     out.checkerboard = in.checkerboard; | ||||
|     typename FermionField::scalar_type scal(4.0 + mass); | ||||
|     out = scal * in; | ||||
| } | ||||
|   } | ||||
|  | ||||
| template <class Impl> | ||||
| void WilsonFermion<Impl>::MooeeDag(const FermionField &in, FermionField &out) { | ||||
|   template <class Impl> | ||||
|   void WilsonFermion<Impl>::MooeeDag(const FermionField &in, FermionField &out) { | ||||
|     out.checkerboard = in.checkerboard; | ||||
|     Mooee(in, out); | ||||
| } | ||||
|   } | ||||
|  | ||||
| template <class Impl> | ||||
| void WilsonFermion<Impl>::MooeeInv(const FermionField &in, FermionField &out) { | ||||
|   template<class Impl> | ||||
|   void WilsonFermion<Impl>::MooeeInv(const FermionField &in, FermionField &out) { | ||||
|     out.checkerboard = in.checkerboard; | ||||
|   out = (1.0 / (4.0 + mass)) * in; | ||||
| } | ||||
|     out = (1.0/(4.0+mass))*in; | ||||
|   } | ||||
|    | ||||
| template <class Impl> | ||||
| void WilsonFermion<Impl>::MooeeInvDag(const FermionField &in, | ||||
|                                       FermionField &out) { | ||||
|   template<class Impl> | ||||
|   void WilsonFermion<Impl>::MooeeInvDag(const FermionField &in, FermionField &out) { | ||||
|     out.checkerboard = in.checkerboard; | ||||
|   MooeeInv(in, out); | ||||
| } | ||||
|     MooeeInv(in,out); | ||||
|   } | ||||
|  | ||||
|   template<class Impl> | ||||
|   void WilsonFermion<Impl>::MomentumSpacePropagator(FermionField &out, const FermionField &in,RealD _m) { | ||||
|  | ||||
|     // what type LatticeComplex  | ||||
|     conformable(_grid,out._grid); | ||||
|  | ||||
|     typedef typename FermionField::vector_type vector_type; | ||||
|     typedef typename FermionField::scalar_type ScalComplex; | ||||
|  | ||||
|     typedef Lattice<iSinglet<vector_type> > LatComplex; | ||||
|  | ||||
|     Gamma::GammaMatrix Gmu [] = { | ||||
|       Gamma::GammaX, | ||||
|       Gamma::GammaY, | ||||
|       Gamma::GammaZ, | ||||
|       Gamma::GammaT | ||||
|     }; | ||||
|  | ||||
|     std::vector<int> latt_size   = _grid->_fdimensions; | ||||
|  | ||||
|     FermionField   num  (_grid); num  = zero; | ||||
|     LatComplex    wilson(_grid); wilson= zero; | ||||
|     LatComplex     one  (_grid); one = ScalComplex(1.0,0.0); | ||||
|  | ||||
|     LatComplex denom(_grid); denom= zero; | ||||
|     LatComplex kmu(_grid);  | ||||
|     ScalComplex ci(0.0,1.0); | ||||
|     // momphase = n * 2pi / L | ||||
|     for(int mu=0;mu<Nd;mu++) { | ||||
|  | ||||
|       LatticeCoordinate(kmu,mu); | ||||
|  | ||||
|       RealD TwoPiL =  M_PI * 2.0/ latt_size[mu]; | ||||
|  | ||||
|       kmu = TwoPiL * kmu; | ||||
|  | ||||
|       wilson = wilson + 2.0*sin(kmu*0.5)*sin(kmu*0.5); // Wilson term | ||||
|  | ||||
|       num = num - sin(kmu)*ci*(Gamma(Gmu[mu])*in);    // derivative term | ||||
|  | ||||
|       denom=denom + sin(kmu)*sin(kmu); | ||||
|     } | ||||
|  | ||||
|     wilson = wilson + _m;     // 2 sin^2 k/2 + m | ||||
|  | ||||
|     num   = num + wilson*in;     // -i gmu sin k + 2 sin^2 k/2 + m | ||||
|  | ||||
|     denom= denom+wilson*wilson; // sin^2 k + (2 sin^2 k/2 + m)^2 | ||||
|  | ||||
|     denom= one/denom; | ||||
|  | ||||
|     out = num*denom; // [ -i gmu sin k + 2 sin^2 k/2 + m] / [ sin^2 k + (2 sin^2 k/2 + m)^2 ] | ||||
|  | ||||
|   } | ||||
|   | ||||
|  | ||||
| /////////////////////////////////// | ||||
| // Internal | ||||
|   | ||||
| @@ -78,16 +78,15 @@ class WilsonFermion : public WilsonKernels<Impl>, public WilsonFermionStatic { | ||||
|   virtual void MooeeInv(const FermionField &in, FermionField &out); | ||||
|   virtual void MooeeInvDag(const FermionField &in, FermionField &out); | ||||
|  | ||||
|   virtual void  MomentumSpacePropagator(FermionField &out,const FermionField &in,RealD _mass) ; | ||||
|  | ||||
|   //////////////////////// | ||||
|   // Derivative interface | ||||
|   //////////////////////// | ||||
|   // Interface calls an internal routine | ||||
|   void DhopDeriv(GaugeField &mat, const FermionField &U, const FermionField &V, | ||||
|                  int dag); | ||||
|   void DhopDerivOE(GaugeField &mat, const FermionField &U, | ||||
|                    const FermionField &V, int dag); | ||||
|   void DhopDerivEO(GaugeField &mat, const FermionField &U, | ||||
|                    const FermionField &V, int dag); | ||||
|   void DhopDeriv(GaugeField &mat,const FermionField &U,const FermionField &V,int dag); | ||||
|   void DhopDerivOE(GaugeField &mat,const FermionField &U,const FermionField &V,int dag); | ||||
|   void DhopDerivEO(GaugeField &mat,const FermionField &U,const FermionField &V,int dag); | ||||
|  | ||||
|   /////////////////////////////////////////////////////////////// | ||||
|   // non-hermitian hopping term; half cb or both | ||||
|   | ||||
| @@ -482,6 +482,148 @@ void WilsonFermion5D<Impl>::DW(const FermionField &in, FermionField &out,int dag | ||||
|   axpy(out,4.0-M5,in,out); | ||||
| } | ||||
|  | ||||
| template<class Impl> | ||||
| void WilsonFermion5D<Impl>::MomentumSpacePropagatorHt(FermionField &out,const FermionField &in, RealD mass)  | ||||
| { | ||||
|   // what type LatticeComplex  | ||||
|   GridBase *_grid = _FourDimGrid; | ||||
|   conformable(_grid,out._grid); | ||||
|    | ||||
|   typedef typename FermionField::vector_type vector_type; | ||||
|   typedef typename FermionField::scalar_type ScalComplex; | ||||
|   typedef iSinglet<ScalComplex> Tcomplex; | ||||
|   typedef Lattice<iSinglet<vector_type> > LatComplex; | ||||
|    | ||||
|   Gamma::GammaMatrix Gmu [] = { | ||||
|     Gamma::GammaX, | ||||
|     Gamma::GammaY, | ||||
|     Gamma::GammaZ, | ||||
|     Gamma::GammaT | ||||
|   }; | ||||
|  | ||||
|   std::vector<int> latt_size   = _grid->_fdimensions; | ||||
|  | ||||
|    | ||||
|   FermionField   num  (_grid); num  = zero; | ||||
|  | ||||
|   LatComplex    sk(_grid);  sk = zero; | ||||
|   LatComplex    sk2(_grid); sk2= zero; | ||||
|   LatComplex    W(_grid); W= zero; | ||||
|   LatComplex    a(_grid); a= zero; | ||||
|   LatComplex    one  (_grid); one = ScalComplex(1.0,0.0); | ||||
|   LatComplex denom(_grid); denom= zero; | ||||
|   LatComplex cosha(_grid);  | ||||
|   LatComplex kmu(_grid);  | ||||
|   LatComplex Wea(_grid);  | ||||
|   LatComplex Wema(_grid);  | ||||
|  | ||||
|   ScalComplex ci(0.0,1.0); | ||||
|    | ||||
|   for(int mu=0;mu<Nd;mu++) { | ||||
|      | ||||
|     LatticeCoordinate(kmu,mu); | ||||
|      | ||||
|     RealD TwoPiL =  M_PI * 2.0/ latt_size[mu]; | ||||
|      | ||||
|     kmu = TwoPiL * kmu; | ||||
|      | ||||
|     sk2 = sk2 + 2.0*sin(kmu*0.5)*sin(kmu*0.5); | ||||
|     sk  = sk  +     sin(kmu)    *sin(kmu);  | ||||
|      | ||||
|     num = num - sin(kmu)*ci*(Gamma(Gmu[mu])*in); | ||||
|      | ||||
|   } | ||||
|    | ||||
|   W = one - M5 + sk2; | ||||
|  | ||||
|   //////////////////////////////////////////// | ||||
|   // Cosh alpha -> alpha | ||||
|   //////////////////////////////////////////// | ||||
|   cosha =  (one + W*W + sk) / (W*2.0); | ||||
|  | ||||
|   // FIXME Need a Lattice acosh | ||||
|   for(int idx=0;idx<_grid->lSites();idx++){ | ||||
|     std::vector<int> lcoor(Nd); | ||||
|     Tcomplex cc; | ||||
|     RealD sgn; | ||||
|     _grid->LocalIndexToLocalCoor(idx,lcoor); | ||||
|     peekLocalSite(cc,cosha,lcoor); | ||||
|     assert((double)real(cc)>=1.0); | ||||
|     assert(fabs((double)imag(cc))<=1.0e-15); | ||||
|     cc = ScalComplex(::acosh(real(cc)),0.0); | ||||
|     pokeLocalSite(cc,a,lcoor); | ||||
|   } | ||||
|    | ||||
|   Wea = ( exp( a) * W  );  | ||||
|   Wema= ( exp(-a) * W  );  | ||||
|    | ||||
|   num   = num + ( one - Wema ) * mass * in; | ||||
|   denom= ( Wea - one ) + mass*mass * (one - Wema);  | ||||
|   out = num/denom; | ||||
| } | ||||
|  | ||||
| template<class Impl> | ||||
| void WilsonFermion5D<Impl>::MomentumSpacePropagatorHw(FermionField &out,const FermionField &in,RealD mass)  | ||||
| { | ||||
|     Gamma::GammaMatrix Gmu [] = { | ||||
|       Gamma::GammaX, | ||||
|       Gamma::GammaY, | ||||
|       Gamma::GammaZ, | ||||
|       Gamma::GammaT | ||||
|     }; | ||||
|  | ||||
|     GridBase *_grid = _FourDimGrid; | ||||
|     conformable(_grid,out._grid); | ||||
|  | ||||
|     typedef typename FermionField::vector_type vector_type; | ||||
|     typedef typename FermionField::scalar_type ScalComplex; | ||||
|  | ||||
|     typedef Lattice<iSinglet<vector_type> > LatComplex; | ||||
|  | ||||
|  | ||||
|     std::vector<int> latt_size   = _grid->_fdimensions; | ||||
|  | ||||
|     LatComplex    sk(_grid);  sk = zero; | ||||
|     LatComplex    sk2(_grid); sk2= zero; | ||||
|  | ||||
|     LatComplex    w_k(_grid); w_k= zero; | ||||
|     LatComplex    b_k(_grid); b_k= zero; | ||||
|  | ||||
|     LatComplex     one  (_grid); one = ScalComplex(1.0,0.0); | ||||
|  | ||||
|     FermionField   num  (_grid); num  = zero; | ||||
|     LatComplex denom(_grid); denom= zero; | ||||
|     LatComplex kmu(_grid);  | ||||
|     ScalComplex ci(0.0,1.0); | ||||
|  | ||||
|     for(int mu=0;mu<Nd;mu++) { | ||||
|  | ||||
|       LatticeCoordinate(kmu,mu); | ||||
|  | ||||
|       RealD TwoPiL =  M_PI * 2.0/ latt_size[mu]; | ||||
|  | ||||
|       kmu = TwoPiL * kmu; | ||||
|  | ||||
|       sk2 = sk2 + 2.0*sin(kmu*0.5)*sin(kmu*0.5); | ||||
|       sk  = sk  + sin(kmu)*sin(kmu);  | ||||
|  | ||||
|       num = num - sin(kmu)*ci*(Gamma(Gmu[mu])*in); | ||||
|  | ||||
|     } | ||||
|     num = num + mass * in ; | ||||
|  | ||||
|     b_k = sk2 - M5; | ||||
|       | ||||
|     w_k = sqrt(sk + b_k*b_k); | ||||
|  | ||||
|     denom= ( w_k + b_k + mass*mass) ; | ||||
|  | ||||
|     denom= one/denom; | ||||
|     out = num*denom; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| FermOpTemplateInstantiate(WilsonFermion5D); | ||||
| GparityFermOpTemplateInstantiate(WilsonFermion5D); | ||||
|    | ||||
|   | ||||
| @@ -36,6 +36,17 @@ Author: paboyle <paboyle@ph.ed.ac.uk> | ||||
| namespace Grid { | ||||
| namespace QCD { | ||||
|  | ||||
|   //////////////////////////////////////////////////////////////////////////////// | ||||
|   // This is the 4d red black case appropriate to support | ||||
|   // | ||||
|   // parity = (x+y+z+t)|2; | ||||
|   // generalised five dim fermions like mobius, zolotarev etc..	 | ||||
|   // | ||||
|   // i.e. even even contains fifth dim hopping term. | ||||
|   // | ||||
|   // [DIFFERS from original CPS red black implementation parity = (x+y+z+t+s)|2 ] | ||||
|   //////////////////////////////////////////////////////////////////////////////// | ||||
|  | ||||
|     //////////////////////////////////////////////////////////////////////////////// | ||||
|     // This is the 4d red black case appropriate to support | ||||
|     // | ||||
| @@ -101,6 +112,9 @@ namespace QCD { | ||||
|       virtual void DhopDerivEO(GaugeField &mat,const FermionField &U,const FermionField &V,int dag); | ||||
|       virtual void DhopDerivOE(GaugeField &mat,const FermionField &U,const FermionField &V,int dag); | ||||
|  | ||||
|       void MomentumSpacePropagatorHt(FermionField &out,const FermionField &in,RealD mass) ; | ||||
|       void MomentumSpacePropagatorHw(FermionField &out,const FermionField &in,RealD mass) ; | ||||
|  | ||||
|       // Implement hopping term non-hermitian hopping term; half cb or both | ||||
|       // Implement s-diagonal DW | ||||
|       void DW    (const FermionField &in, FermionField &out,int dag); | ||||
|   | ||||
| @@ -61,13 +61,7 @@ public: | ||||
|     switch(Opt) { | ||||
| #ifdef AVX512 | ||||
|     case OptInlineAsm: | ||||
|       for (int site = 0; site < Ns; site++) { | ||||
| 	for (int s = 0; s < Ls; s++) { | ||||
|        WilsonKernels<Impl>::DiracOptAsmDhopSite(st,lo,U,buf,sF,sU,Ls,Ns,in,out); | ||||
| 	  sF++; | ||||
| 	} | ||||
| 	sU++; | ||||
|       } | ||||
|        break; | ||||
| #endif | ||||
|     case OptHandUnroll: | ||||
| @@ -115,13 +109,7 @@ public: | ||||
|     switch(Opt) { | ||||
| #ifdef AVX512 | ||||
|     case OptInlineAsm: | ||||
|       for (int site = 0; site < Ns; site++) { | ||||
| 	for (int s = 0; s < Ls; s++) { | ||||
|       WilsonKernels<Impl>::DiracOptAsmDhopSiteDag(st,lo,U,buf,sF,sU,Ls,Ns,in,out); | ||||
| 	  sF++; | ||||
| 	} | ||||
| 	sU++; | ||||
|       } | ||||
|       break; | ||||
| #endif | ||||
|     case OptHandUnroll: | ||||
|   | ||||
| @@ -39,8 +39,8 @@ namespace QCD{ | ||||
| //on the 5d (rb4d) checkerboarded lattices | ||||
| //////////////////////////////////////////////////////////////////////// | ||||
|  | ||||
| template<class vobj>  | ||||
| void axpibg5x(Lattice<vobj> &z,const Lattice<vobj> &x,RealD a,RealD b) | ||||
| template<class vobj,class Coeff> | ||||
| void axpibg5x(Lattice<vobj> &z,const Lattice<vobj> &x,Coeff a,Coeff b) | ||||
| { | ||||
|   z.checkerboard = x.checkerboard; | ||||
|   conformable(x,z); | ||||
| @@ -57,8 +57,8 @@ PARALLEL_FOR_LOOP | ||||
|   } | ||||
| } | ||||
|  | ||||
| template<class vobj>  | ||||
| void axpby_ssp(Lattice<vobj> &z, RealD a,const Lattice<vobj> &x,RealD b,const Lattice<vobj> &y,int s,int sp) | ||||
| template<class vobj,class Coeff>  | ||||
| void axpby_ssp(Lattice<vobj> &z, Coeff a,const Lattice<vobj> &x,Coeff b,const Lattice<vobj> &y,int s,int sp) | ||||
| { | ||||
|   z.checkerboard = x.checkerboard; | ||||
|   conformable(x,y); | ||||
| @@ -72,8 +72,8 @@ PARALLEL_FOR_LOOP | ||||
|   } | ||||
| } | ||||
|  | ||||
| template<class vobj>  | ||||
| void ag5xpby_ssp(Lattice<vobj> &z,RealD a,const Lattice<vobj> &x,RealD b,const Lattice<vobj> &y,int s,int sp) | ||||
| template<class vobj,class Coeff>  | ||||
| void ag5xpby_ssp(Lattice<vobj> &z,Coeff a,const Lattice<vobj> &x,Coeff b,const Lattice<vobj> &y,int s,int sp) | ||||
| { | ||||
|   z.checkerboard = x.checkerboard; | ||||
|   conformable(x,y); | ||||
| @@ -90,8 +90,8 @@ PARALLEL_FOR_LOOP | ||||
|   } | ||||
| } | ||||
|  | ||||
| template<class vobj>  | ||||
| void axpbg5y_ssp(Lattice<vobj> &z,RealD a,const Lattice<vobj> &x,RealD b,const Lattice<vobj> &y,int s,int sp) | ||||
| template<class vobj,class Coeff>  | ||||
| void axpbg5y_ssp(Lattice<vobj> &z,Coeff a,const Lattice<vobj> &x,Coeff b,const Lattice<vobj> &y,int s,int sp) | ||||
| { | ||||
|   z.checkerboard = x.checkerboard; | ||||
|   conformable(x,y); | ||||
| @@ -108,8 +108,8 @@ PARALLEL_FOR_LOOP | ||||
|   } | ||||
| } | ||||
|  | ||||
| template<class vobj>  | ||||
| void ag5xpbg5y_ssp(Lattice<vobj> &z,RealD a,const Lattice<vobj> &x,RealD b,const Lattice<vobj> &y,int s,int sp) | ||||
| template<class vobj,class Coeff>  | ||||
| void ag5xpbg5y_ssp(Lattice<vobj> &z,Coeff a,const Lattice<vobj> &x,Coeff b,const Lattice<vobj> &y,int s,int sp) | ||||
| { | ||||
|   z.checkerboard = x.checkerboard; | ||||
|   conformable(x,y); | ||||
| @@ -127,8 +127,8 @@ PARALLEL_FOR_LOOP | ||||
|   } | ||||
| } | ||||
|  | ||||
| template<class vobj>  | ||||
| void axpby_ssp_pminus(Lattice<vobj> &z,RealD a,const Lattice<vobj> &x,RealD b,const Lattice<vobj> &y,int s,int sp) | ||||
| template<class vobj,class Coeff>  | ||||
| void axpby_ssp_pminus(Lattice<vobj> &z,Coeff a,const Lattice<vobj> &x,Coeff b,const Lattice<vobj> &y,int s,int sp) | ||||
| { | ||||
|   z.checkerboard = x.checkerboard; | ||||
|   conformable(x,y); | ||||
| @@ -144,8 +144,8 @@ PARALLEL_FOR_LOOP | ||||
|   } | ||||
| } | ||||
|  | ||||
| template<class vobj>  | ||||
| void axpby_ssp_pplus(Lattice<vobj> &z,RealD a,const Lattice<vobj> &x,RealD b,const Lattice<vobj> &y,int s,int sp) | ||||
| template<class vobj,class Coeff>  | ||||
| void axpby_ssp_pplus(Lattice<vobj> &z,Coeff a,const Lattice<vobj> &x,Coeff b,const Lattice<vobj> &y,int s,int sp) | ||||
| { | ||||
|   z.checkerboard = x.checkerboard; | ||||
|   conformable(x,y); | ||||
|   | ||||
| @@ -674,6 +674,37 @@ class SU { | ||||
|       out += la; | ||||
|     } | ||||
|   } | ||||
| /* | ||||
|  add GaugeTrans | ||||
| */ | ||||
|  | ||||
| template<typename GaugeField,typename GaugeMat> | ||||
|   static void GaugeTransform( GaugeField &Umu, GaugeMat &g){ | ||||
|     GridBase *grid = Umu._grid; | ||||
|     conformable(grid,g._grid); | ||||
|  | ||||
|     GaugeMat U(grid); | ||||
|     GaugeMat ag(grid); ag = adj(g); | ||||
|  | ||||
|     for(int mu=0;mu<Nd;mu++){ | ||||
|       U= PeekIndex<LorentzIndex>(Umu,mu); | ||||
|       U = g*U*Cshift(ag, mu, 1); | ||||
|       PokeIndex<LorentzIndex>(Umu,U,mu); | ||||
|     } | ||||
|   } | ||||
|   template<typename GaugeMat> | ||||
|     static void GaugeTransform( std::vector<GaugeMat> &U, GaugeMat &g){ | ||||
|     GridBase *grid = g._grid; | ||||
|     GaugeMat ag(grid); ag = adj(g); | ||||
|     for(int mu=0;mu<Nd;mu++){ | ||||
|       U[mu] = g*U[mu]*Cshift(ag, mu, 1); | ||||
|     } | ||||
|   } | ||||
|   template<typename GaugeField,typename GaugeMat> | ||||
|   static void RandomGaugeTransform(GridParallelRNG &pRNG, GaugeField &Umu, GaugeMat &g){ | ||||
|     LieRandomize(pRNG,g,1.0); | ||||
|     GaugeTransform(Umu,g); | ||||
|   } | ||||
|  | ||||
|   // Projects the algebra components a lattice matrix (of dimension ncol*ncol -1 ) | ||||
|   // inverse operation: FundamentalLieAlgebraMatrix | ||||
| @@ -702,23 +733,33 @@ class SU { | ||||
|       PokeIndex<LorentzIndex>(out, Umu, mu); | ||||
|     } | ||||
|   } | ||||
|   static void TepidConfiguration(GridParallelRNG &pRNG, | ||||
|                                  LatticeGaugeField &out) { | ||||
|     LatticeMatrix Umu(out._grid); | ||||
|     for (int mu = 0; mu < Nd; mu++) { | ||||
|       LieRandomize(pRNG, Umu, 0.01); | ||||
|       PokeIndex<LorentzIndex>(out, Umu, mu); | ||||
|   template<typename GaugeField> | ||||
|   static void TepidConfiguration(GridParallelRNG &pRNG,GaugeField &out){ | ||||
|     typedef typename GaugeField::vector_type vector_type; | ||||
|     typedef iSUnMatrix<vector_type> vMatrixType; | ||||
|     typedef Lattice<vMatrixType> LatticeMatrixType; | ||||
|  | ||||
|     LatticeMatrixType Umu(out._grid); | ||||
|     for(int mu=0;mu<Nd;mu++){ | ||||
|       LieRandomize(pRNG,Umu,0.01); | ||||
|       PokeIndex<LorentzIndex>(out,Umu,mu); | ||||
|     } | ||||
|   } | ||||
|   static void ColdConfiguration(GridParallelRNG &pRNG, LatticeGaugeField &out) { | ||||
|     LatticeMatrix Umu(out._grid); | ||||
|     Umu = 1.0; | ||||
|     for (int mu = 0; mu < Nd; mu++) { | ||||
|       PokeIndex<LorentzIndex>(out, Umu, mu); | ||||
|   template<typename GaugeField> | ||||
|   static void ColdConfiguration(GridParallelRNG &pRNG,GaugeField &out){ | ||||
|     typedef typename GaugeField::vector_type vector_type; | ||||
|     typedef iSUnMatrix<vector_type> vMatrixType; | ||||
|     typedef Lattice<vMatrixType> LatticeMatrixType; | ||||
|  | ||||
|     LatticeMatrixType Umu(out._grid); | ||||
|     Umu=1.0; | ||||
|     for(int mu=0;mu<Nd;mu++){ | ||||
|       PokeIndex<LorentzIndex>(out,Umu,mu); | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   static void taProj(const LatticeMatrix &in, LatticeMatrix &out) { | ||||
|   template<typename LatticeMatrixType> | ||||
|   static void taProj( const LatticeMatrixType &in,  LatticeMatrixType &out){ | ||||
|     out = Ta(in); | ||||
|   } | ||||
|   template <typename LatticeMatrixType> | ||||
|   | ||||
| @@ -365,6 +365,18 @@ namespace Optimization { | ||||
|     } | ||||
|   }; | ||||
|  | ||||
|   struct Div{ | ||||
|     // Real float | ||||
|     inline __m256 operator()(__m256 a, __m256 b){ | ||||
|       return _mm256_div_ps(a,b); | ||||
|     } | ||||
|     // Real double | ||||
|     inline __m256d operator()(__m256d a, __m256d b){ | ||||
|       return _mm256_div_pd(a,b); | ||||
|     } | ||||
|   }; | ||||
|  | ||||
|  | ||||
|   struct Conj{ | ||||
|     // Complex single | ||||
|     inline __m256 operator()(__m256 in){ | ||||
| @@ -437,14 +449,13 @@ namespace Optimization { | ||||
|  | ||||
|   }; | ||||
|  | ||||
| #if defined (AVX2) || defined (AVXFMA4)  | ||||
| #define _mm256_alignr_epi32(ret,a,b,n) ret=(__m256) _mm256_alignr_epi8((__m256i)a,(__m256i)b,(n*4)%16) | ||||
| #define _mm256_alignr_epi64(ret,a,b,n) ret=(__m256d) _mm256_alignr_epi8((__m256i)a,(__m256i)b,(n*8)%16) | ||||
| #if defined (AVX2) | ||||
| #define _mm256_alignr_epi32_grid(ret,a,b,n) ret=(__m256)  _mm256_alignr_epi8((__m256i)a,(__m256i)b,(n*4)%16) | ||||
| #define _mm256_alignr_epi64_grid(ret,a,b,n) ret=(__m256d) _mm256_alignr_epi8((__m256i)a,(__m256i)b,(n*8)%16) | ||||
| #endif | ||||
|  | ||||
| #if defined (AVX1) || defined (AVXFMA)   | ||||
|  | ||||
| #define _mm256_alignr_epi32(ret,a,b,n) {	\ | ||||
| #define _mm256_alignr_epi32_grid(ret,a,b,n) {	\ | ||||
|     __m128 aa, bb;				\ | ||||
| 						\ | ||||
|     aa  = _mm256_extractf128_ps(a,1);		\ | ||||
| @@ -458,7 +469,7 @@ namespace Optimization { | ||||
|     ret = _mm256_insertf128_ps(ret,aa,0);	\ | ||||
|   } | ||||
|  | ||||
| #define _mm256_alignr_epi64(ret,a,b,n) {	\ | ||||
| #define _mm256_alignr_epi64_grid(ret,a,b,n) {	\ | ||||
|     __m128d aa, bb;				\ | ||||
| 						\ | ||||
|     aa  = _mm256_extractf128_pd(a,1);		\ | ||||
| @@ -474,19 +485,6 @@ namespace Optimization { | ||||
|  | ||||
| #endif | ||||
|  | ||||
|     inline std::ostream & operator << (std::ostream& stream, const __m256 a) | ||||
|     { | ||||
|       const float *p=(const float *)&a; | ||||
|       stream<< "{"<<p[0]<<","<<p[1]<<","<<p[2]<<","<<p[3]<<","<<p[4]<<","<<p[5]<<","<<p[6]<<","<<p[7]<<"}"; | ||||
|       return stream; | ||||
|     }; | ||||
|     inline std::ostream & operator<< (std::ostream& stream, const __m256d a) | ||||
|     { | ||||
|       const double *p=(const double *)&a; | ||||
|       stream<< "{"<<p[0]<<","<<p[1]<<","<<p[2]<<","<<p[3]<<"}"; | ||||
|       return stream; | ||||
|     }; | ||||
|  | ||||
|   struct Rotate{ | ||||
|  | ||||
|     static inline __m256 rotate(__m256 in,int n){  | ||||
| @@ -518,11 +516,10 @@ namespace Optimization { | ||||
|       __m256 tmp = Permute::Permute0(in); | ||||
|       __m256 ret; | ||||
|       if ( n > 3 ) {  | ||||
| 	_mm256_alignr_epi32(ret,in,tmp,n);   | ||||
| 	_mm256_alignr_epi32_grid(ret,in,tmp,n);   | ||||
|       } else { | ||||
|         _mm256_alignr_epi32(ret,tmp,in,n);           | ||||
|         _mm256_alignr_epi32_grid(ret,tmp,in,n);           | ||||
|       } | ||||
|       //      std::cout << " align epi32 n=" <<n<<" in "<<tmp<<in<<" -> "<< ret <<std::endl; | ||||
|       return ret; | ||||
|     }; | ||||
|  | ||||
| @@ -531,18 +528,15 @@ namespace Optimization { | ||||
|       __m256d tmp = Permute::Permute0(in); | ||||
|       __m256d ret; | ||||
|       if ( n > 1 ) { | ||||
| 	_mm256_alignr_epi64(ret,in,tmp,n);           | ||||
| 	_mm256_alignr_epi64_grid(ret,in,tmp,n);           | ||||
|       } else { | ||||
|         _mm256_alignr_epi64(ret,tmp,in,n);           | ||||
|         _mm256_alignr_epi64_grid(ret,tmp,in,n);           | ||||
|       } | ||||
|       //      std::cout << " align epi64 n=" <<n<<" in "<<tmp<<in<<" -> "<< ret <<std::endl; | ||||
|       return ret; | ||||
|     }; | ||||
|  | ||||
|   }; | ||||
|  | ||||
|  | ||||
|  | ||||
|   //Complex float Reduce | ||||
|   template<> | ||||
|     inline Grid::ComplexF Reduce<Grid::ComplexF, __m256>::operator()(__m256 in){ | ||||
| @@ -631,6 +625,7 @@ namespace Optimization { | ||||
|   // Arithmetic operations | ||||
|   typedef Optimization::Sum         SumSIMD; | ||||
|   typedef Optimization::Sub         SubSIMD; | ||||
|   typedef Optimization::Div         DivSIMD; | ||||
|   typedef Optimization::Mult        MultSIMD; | ||||
|   typedef Optimization::MultComplex MultComplexSIMD; | ||||
|   typedef Optimization::Conj        ConjSIMD; | ||||
|   | ||||
| @@ -240,6 +240,17 @@ namespace Optimization { | ||||
|     } | ||||
|   }; | ||||
|  | ||||
|   struct Div{ | ||||
|     // Real float | ||||
|     inline __m512 operator()(__m512 a, __m512 b){ | ||||
|       return _mm512_div_ps(a,b); | ||||
|     } | ||||
|     // Real double | ||||
|     inline __m512d operator()(__m512d a, __m512d b){ | ||||
|       return _mm512_div_pd(a,b); | ||||
|     } | ||||
|   }; | ||||
|  | ||||
|  | ||||
|   struct Conj{ | ||||
|     // Complex single | ||||
| @@ -497,6 +508,7 @@ namespace Optimization { | ||||
|   typedef Optimization::Sum         SumSIMD; | ||||
|   typedef Optimization::Sub         SubSIMD; | ||||
|   typedef Optimization::Mult        MultSIMD; | ||||
|   typedef Optimization::Div         DivSIMD; | ||||
|   typedef Optimization::MultComplex MultComplexSIMD; | ||||
|   typedef Optimization::Conj        ConjSIMD; | ||||
|   typedef Optimization::TimesMinusI TimesMinusISIMD; | ||||
|   | ||||
| @@ -244,6 +244,17 @@ namespace Optimization { | ||||
|     } | ||||
|   }; | ||||
|  | ||||
|   struct Div{ | ||||
|     // Real float | ||||
|     inline __m512 operator()(__m512 a, __m512 b){ | ||||
|       return _mm512_div_ps(a,b); | ||||
|     } | ||||
|     // Real double | ||||
|     inline __m512d operator()(__m512d a, __m512d b){ | ||||
|       return _mm512_div_pd(a,b); | ||||
|     } | ||||
|   }; | ||||
|  | ||||
|  | ||||
|   struct Conj{ | ||||
|     // Complex single | ||||
| @@ -437,6 +448,7 @@ namespace Optimization { | ||||
|   // Arithmetic operations | ||||
|   typedef Optimization::Sum         SumSIMD; | ||||
|   typedef Optimization::Sub         SubSIMD; | ||||
|   typedef Optimization::Div         DivSIMD; | ||||
|   typedef Optimization::Mult        MultSIMD; | ||||
|   typedef Optimization::MultComplex MultComplexSIMD; | ||||
|   typedef Optimization::Conj        ConjSIMD; | ||||
|   | ||||
| @@ -224,6 +224,18 @@ namespace Optimization { | ||||
|     } | ||||
|   }; | ||||
|  | ||||
|   struct Div{ | ||||
|     // Real float | ||||
|     inline __m128 operator()(__m128 a, __m128 b){ | ||||
|       return _mm_div_ps(a,b); | ||||
|     } | ||||
|     // Real double | ||||
|     inline __m128d operator()(__m128d a, __m128d b){ | ||||
|       return _mm_div_pd(a,b); | ||||
|     } | ||||
|   }; | ||||
|  | ||||
|  | ||||
|   struct Conj{ | ||||
|     // Complex single | ||||
|     inline __m128 operator()(__m128 in){ | ||||
| @@ -372,6 +384,8 @@ namespace Optimization { | ||||
|   } | ||||
| } | ||||
|  | ||||
|  | ||||
|  | ||||
| ////////////////////////////////////////////////////////////////////////////////////// | ||||
| // Here assign types  | ||||
|  | ||||
| @@ -398,6 +412,7 @@ namespace Optimization { | ||||
|   // Arithmetic operations | ||||
|   typedef Optimization::Sum         SumSIMD; | ||||
|   typedef Optimization::Sub         SubSIMD; | ||||
|   typedef Optimization::Div         DivSIMD; | ||||
|   typedef Optimization::Mult        MultSIMD; | ||||
|   typedef Optimization::MultComplex MultComplexSIMD; | ||||
|   typedef Optimization::Conj        ConjSIMD; | ||||
|   | ||||
| @@ -77,38 +77,24 @@ struct RealPart<std::complex<T> > { | ||||
| ////////////////////////////////////// | ||||
| // demote a vector to real type | ||||
| ////////////////////////////////////// | ||||
|  | ||||
| // type alias used to simplify the syntax of std::enable_if | ||||
| template <typename T> | ||||
| using Invoke = typename T::type; | ||||
| template <typename Condition, typename ReturnType> | ||||
| using EnableIf = Invoke<std::enable_if<Condition::value, ReturnType> >; | ||||
| template <typename Condition, typename ReturnType> | ||||
| using NotEnableIf = Invoke<std::enable_if<!Condition::value, ReturnType> >; | ||||
| template <typename T> using Invoke = typename T::type; | ||||
| template <typename Condition, typename ReturnType> using EnableIf = Invoke<std::enable_if<Condition::value, ReturnType> >; | ||||
| template <typename Condition, typename ReturnType> using NotEnableIf = Invoke<std::enable_if<!Condition::value, ReturnType> >; | ||||
|  | ||||
| //////////////////////////////////////////////////////// | ||||
| // Check for complexity with type traits | ||||
| template <typename T> | ||||
| struct is_complex : public std::false_type {}; | ||||
| template <> | ||||
| struct is_complex<std::complex<double> > : public std::true_type {}; | ||||
| template <> | ||||
| struct is_complex<std::complex<float> > : public std::true_type {}; | ||||
| template <typename T> struct is_complex : public std::false_type {}; | ||||
| template <> struct is_complex<std::complex<double> > : public std::true_type {}; | ||||
| template <> struct is_complex<std::complex<float> > : public std::true_type {}; | ||||
|  | ||||
| template <typename T> | ||||
| using IfReal = Invoke<std::enable_if<std::is_floating_point<T>::value, int> >; | ||||
| template <typename T> | ||||
| using IfComplex = Invoke<std::enable_if<is_complex<T>::value, int> >; | ||||
| template <typename T> | ||||
| using IfInteger = Invoke<std::enable_if<std::is_integral<T>::value, int> >; | ||||
| template <typename T> using IfReal       = Invoke<std::enable_if<std::is_floating_point<T>::value, int> >; | ||||
| template <typename T> using IfComplex    = Invoke<std::enable_if<is_complex<T>::value, int> >; | ||||
| template <typename T> using IfInteger    = Invoke<std::enable_if<std::is_integral<T>::value, int> >; | ||||
|  | ||||
| template <typename T> | ||||
| using IfNotReal = | ||||
|     Invoke<std::enable_if<!std::is_floating_point<T>::value, int> >; | ||||
| template <typename T> | ||||
| using IfNotComplex = Invoke<std::enable_if<!is_complex<T>::value, int> >; | ||||
| template <typename T> | ||||
| using IfNotInteger = Invoke<std::enable_if<!std::is_integral<T>::value, int> >; | ||||
| template <typename T> using IfNotReal    = Invoke<std::enable_if<!std::is_floating_point<T>::value, int> >; | ||||
| template <typename T> using IfNotComplex = Invoke<std::enable_if<!is_complex<T>::value, int> >; | ||||
| template <typename T> using IfNotInteger = Invoke<std::enable_if<!std::is_integral<T>::value, int> >; | ||||
|  | ||||
| //////////////////////////////////////////////////////// | ||||
| // Define the operation templates functors | ||||
| @@ -285,6 +271,20 @@ class Grid_simd { | ||||
|     return a * b; | ||||
|   } | ||||
|  | ||||
|   ////////////////////////////////// | ||||
|   // Divides | ||||
|   ////////////////////////////////// | ||||
|   friend inline Grid_simd operator/(const Scalar_type &a, Grid_simd b) { | ||||
|     Grid_simd va; | ||||
|     vsplat(va, a); | ||||
|     return va / b; | ||||
|   } | ||||
|   friend inline Grid_simd operator/(Grid_simd b, const Scalar_type &a) { | ||||
|     Grid_simd va; | ||||
|     vsplat(va, a); | ||||
|     return b / a; | ||||
|   } | ||||
|  | ||||
|   /////////////////////// | ||||
|   // Unary negation | ||||
|   /////////////////////// | ||||
| @@ -428,7 +428,6 @@ inline void rotate(Grid_simd<S,V> &ret,Grid_simd<S,V> b,int nrot) | ||||
|   ret.v = Optimization::Rotate::rotate(b.v,2*nrot); | ||||
| } | ||||
|  | ||||
|  | ||||
| template <class S, class V>  | ||||
| inline void vbroadcast(Grid_simd<S,V> &ret,const Grid_simd<S,V> &src,int lane){ | ||||
|   S* typepun =(S*) &src; | ||||
| @@ -512,7 +511,6 @@ template <class S, class V, IfInteger<S> = 0> | ||||
| inline void vfalse(Grid_simd<S, V> &ret) { | ||||
|   vsplat(ret, 0); | ||||
| } | ||||
|  | ||||
| template <class S, class V> | ||||
| inline void zeroit(Grid_simd<S, V> &z) { | ||||
|   vzero(z); | ||||
| @@ -530,7 +528,6 @@ inline void vstream(Grid_simd<S, V> &out, const Grid_simd<S, V> &in) { | ||||
|   typedef typename S::value_type T; | ||||
|   binary<void>((T *)&out.v, in.v, VstreamSIMD()); | ||||
| } | ||||
|  | ||||
| template <class S, class V, IfInteger<S> = 0> | ||||
| inline void vstream(Grid_simd<S, V> &out, const Grid_simd<S, V> &in) { | ||||
|   out = in; | ||||
| @@ -569,6 +566,34 @@ inline Grid_simd<S, V> operator*(Grid_simd<S, V> a, Grid_simd<S, V> b) { | ||||
|   return ret; | ||||
| }; | ||||
|  | ||||
| // Distinguish between complex types and others | ||||
| template <class S, class V, IfComplex<S> = 0> | ||||
| inline Grid_simd<S, V> operator/(Grid_simd<S, V> a, Grid_simd<S, V> b) { | ||||
|   typedef Grid_simd<S, V> simd; | ||||
|  | ||||
|   simd ret; | ||||
|   simd den; | ||||
|   typename simd::conv_t conv; | ||||
|  | ||||
|   ret = a * conjugate(b) ; | ||||
|   den = b * conjugate(b) ; | ||||
|  | ||||
|    | ||||
|   auto real_den = toReal(den); | ||||
|  | ||||
|   ret.v=binary<V>(ret.v, real_den.v, DivSIMD()); | ||||
|  | ||||
|   return ret; | ||||
| }; | ||||
|  | ||||
| // Real/Integer types | ||||
| template <class S, class V, IfNotComplex<S> = 0> | ||||
| inline Grid_simd<S, V> operator/(Grid_simd<S, V> a, Grid_simd<S, V> b) { | ||||
|   Grid_simd<S, V> ret; | ||||
|   ret.v = binary<V>(a.v, b.v, DivSIMD()); | ||||
|   return ret; | ||||
| }; | ||||
|  | ||||
| /////////////////////// | ||||
| // Conjugate | ||||
| /////////////////////// | ||||
| @@ -582,7 +607,6 @@ template <class S, class V, IfNotComplex<S> = 0> | ||||
| inline Grid_simd<S, V> conjugate(const Grid_simd<S, V> &in) { | ||||
|   return in;  // for real objects | ||||
| } | ||||
|  | ||||
| // Suppress adj for integer types... // odd; why conjugate above but not adj?? | ||||
| template <class S, class V, IfNotInteger<S> = 0> | ||||
| inline Grid_simd<S, V> adj(const Grid_simd<S, V> &in) { | ||||
| @@ -596,14 +620,12 @@ template <class S, class V, IfComplex<S> = 0> | ||||
| inline void timesMinusI(Grid_simd<S, V> &ret, const Grid_simd<S, V> &in) { | ||||
|   ret.v = binary<V>(in.v, ret.v, TimesMinusISIMD()); | ||||
| } | ||||
|  | ||||
| template <class S, class V, IfComplex<S> = 0> | ||||
| inline Grid_simd<S, V> timesMinusI(const Grid_simd<S, V> &in) { | ||||
|   Grid_simd<S, V> ret; | ||||
|   timesMinusI(ret, in); | ||||
|   return ret; | ||||
| } | ||||
|  | ||||
| template <class S, class V, IfNotComplex<S> = 0> | ||||
| inline Grid_simd<S, V> timesMinusI(const Grid_simd<S, V> &in) { | ||||
|   return in; | ||||
| @@ -616,14 +638,12 @@ template <class S, class V, IfComplex<S> = 0> | ||||
| inline void timesI(Grid_simd<S, V> &ret, const Grid_simd<S, V> &in) { | ||||
|   ret.v = binary<V>(in.v, ret.v, TimesISIMD()); | ||||
| } | ||||
|  | ||||
| template <class S, class V, IfComplex<S> = 0> | ||||
| inline Grid_simd<S, V> timesI(const Grid_simd<S, V> &in) { | ||||
|   Grid_simd<S, V> ret; | ||||
|   timesI(ret, in); | ||||
|   return ret; | ||||
| } | ||||
|  | ||||
| template <class S, class V, IfNotComplex<S> = 0> | ||||
| inline Grid_simd<S, V> timesI(const Grid_simd<S, V> &in) { | ||||
|   return in; | ||||
|   | ||||
| @@ -127,6 +127,36 @@ iVector<rtype,N> operator * (const iVector<mtype,N>& lhs,const iScalar<vtype>& r | ||||
|     return ret; | ||||
| } | ||||
|  | ||||
| ////////////////////////////////////////////////////////////////// | ||||
| // Divide by scalar | ||||
| ////////////////////////////////////////////////////////////////// | ||||
| template<class rtype,class vtype> strong_inline | ||||
| iScalar<rtype> operator / (const iScalar<rtype>& lhs,const iScalar<vtype>& rhs) | ||||
| { | ||||
|     iScalar<rtype> ret; | ||||
|     ret._internal = lhs._internal/rhs._internal; | ||||
|     return ret; | ||||
| } | ||||
| template<class rtype,class vtype,int N> strong_inline | ||||
| iVector<rtype,N> operator / (const iVector<rtype,N>& lhs,const iScalar<vtype>& rhs) | ||||
| { | ||||
|     iVector<rtype,N> ret; | ||||
|     for(int i=0;i<N;i++){ | ||||
|       ret._internal[i] = lhs._internal[i]/rhs._internal; | ||||
|     } | ||||
|     return ret; | ||||
| } | ||||
| template<class rtype,class vtype,int N> strong_inline | ||||
| iMatrix<rtype,N> operator / (const iMatrix<rtype,N>& lhs,const iScalar<vtype>& rhs) | ||||
| { | ||||
|     iMatrix<rtype,N> ret; | ||||
|     for(int i=0;i<N;i++){ | ||||
|     for(int j=0;j<N;j++){ | ||||
|       ret._internal[i][j] = lhs._internal[i][j]/rhs._internal; | ||||
|     }} | ||||
|     return ret; | ||||
| } | ||||
|      | ||||
|     ////////////////////////////////////////////////////////////////// | ||||
|     // Glue operators to mult routines. Must resolve return type cleverly from typeof(internal) | ||||
|     // since nesting matrix<scalar> x matrix<matrix>-> matrix<matrix> | ||||
|   | ||||
| @@ -20,7 +20,7 @@ for subdir in $dirs; do | ||||
|     TESTS=`ls T*.cc` | ||||
|     TESTLIST=`echo ${TESTS} | sed s/.cc//g ` | ||||
|     PREF=`[ $subdir = '.' ] && echo noinst || echo EXTRA` | ||||
|     echo "tests: ${TESTLIST}" > Make.inc | ||||
|     echo "tests-local: ${TESTLIST}" > Make.inc | ||||
|     echo ${PREF}_PROGRAMS = ${TESTLIST} >> Make.inc | ||||
|     echo >> Make.inc | ||||
|     for f in $TESTS; do | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
|     /************************************************************************************* | ||||
|  | ||||
|     Grid physics library, www.github.com/paboyle/Grid  | ||||
|     grid` physics library, www.github.com/paboyle/Grid  | ||||
|  | ||||
|     Source file: ./tests/Test_cshift.cc | ||||
|  | ||||
| @@ -46,57 +46,79 @@ int main (int argc, char ** argv) | ||||
|   for(int d=0;d<latt_size.size();d++){ | ||||
|     vol = vol * latt_size[d]; | ||||
|   } | ||||
|   GridCartesian        Fine(latt_size,simd_layout,mpi_layout); | ||||
|   GridCartesian         GRID(latt_size,simd_layout,mpi_layout); | ||||
|   GridRedBlackCartesian RBGRID(latt_size,simd_layout,mpi_layout); | ||||
|  | ||||
|   LatticeComplexD     one(&Fine); | ||||
|   LatticeComplexD      zz(&Fine); | ||||
|   LatticeComplexD       C(&Fine); | ||||
|   LatticeComplexD  Ctilde(&Fine); | ||||
|   LatticeComplexD    coor(&Fine); | ||||
|   LatticeComplexD     one(&GRID); | ||||
|   LatticeComplexD      zz(&GRID); | ||||
|   LatticeComplexD       C(&GRID); | ||||
|   LatticeComplexD  Ctilde(&GRID); | ||||
|   LatticeComplexD  Cref  (&GRID); | ||||
|   LatticeComplexD  Csav  (&GRID); | ||||
|   LatticeComplexD    coor(&GRID); | ||||
|  | ||||
|   LatticeSpinMatrixD    S(&Fine); | ||||
|   LatticeSpinMatrixD    Stilde(&Fine); | ||||
|   LatticeSpinMatrixD    S(&GRID); | ||||
|   LatticeSpinMatrixD    Stilde(&GRID); | ||||
|    | ||||
|   std::vector<int> p({1,2,3,2}); | ||||
|   std::vector<int> p({1,3,2,3}); | ||||
|  | ||||
|   one = ComplexD(1.0,0.0); | ||||
|   zz  = ComplexD(0.0,0.0); | ||||
|  | ||||
|   ComplexD ci(0.0,1.0); | ||||
|  | ||||
|  | ||||
|   std::cout<<"*************************************************"<<std::endl; | ||||
|   std::cout<<"Testing Fourier from of known plane wave         "<<std::endl; | ||||
|   std::cout<<"*************************************************"<<std::endl; | ||||
|   C=zero; | ||||
|   for(int mu=0;mu<4;mu++){ | ||||
|     RealD TwoPiL =  M_PI * 2.0/ latt_size[mu]; | ||||
|     LatticeCoordinate(coor,mu); | ||||
|     C = C - (TwoPiL * p[mu]) * coor; | ||||
|     C = C + (TwoPiL * p[mu]) * coor; | ||||
|   } | ||||
|  | ||||
|   C = exp(C*ci); | ||||
|  | ||||
|   Csav = C; | ||||
|   S=zero; | ||||
|   S = S+C; | ||||
|  | ||||
|   FFT theFFT(&Fine); | ||||
|   FFT theFFT(&GRID); | ||||
|  | ||||
|   theFFT.FFT_dim(Ctilde,C,0,FFT::forward);  C=Ctilde; std::cout << theFFT.MFlops()<<std::endl; | ||||
|   theFFT.FFT_dim(Ctilde,C,1,FFT::forward);  C=Ctilde; std::cout << theFFT.MFlops()<<std::endl; | ||||
|   theFFT.FFT_dim(Ctilde,C,2,FFT::forward);  C=Ctilde; std::cout << theFFT.MFlops()<<std::endl; | ||||
|   theFFT.FFT_dim(Ctilde,C,3,FFT::forward);  std::cout << theFFT.MFlops()<<std::endl; | ||||
|   Ctilde=C; | ||||
|   std::cout<<" Benchmarking FFT of LatticeComplex  "<<std::endl; | ||||
|   theFFT.FFT_dim(Ctilde,Ctilde,0,FFT::forward); std::cout << theFFT.MFlops()<<" Mflops "<<std::endl; | ||||
|   theFFT.FFT_dim(Ctilde,Ctilde,1,FFT::forward); std::cout << theFFT.MFlops()<<" Mflops "<<std::endl; | ||||
|   theFFT.FFT_dim(Ctilde,Ctilde,2,FFT::forward); std::cout << theFFT.MFlops()<<" Mflops "<<std::endl; | ||||
|   theFFT.FFT_dim(Ctilde,Ctilde,3,FFT::forward); std::cout << theFFT.MFlops()<<" Mflops "<<std::endl; | ||||
|  | ||||
|   //  C=zero; | ||||
|   //  Ctilde = where(abs(Ctilde)<1.0e-10,C,Ctilde); | ||||
|   TComplexD cVol; | ||||
|   cVol()()() = vol; | ||||
|  | ||||
|   C=zero; | ||||
|   pokeSite(cVol,C,p); | ||||
|   C=C-Ctilde; | ||||
|   std::cout << "diff scalar "<<norm2(C) << std::endl; | ||||
|   Cref=zero; | ||||
|   pokeSite(cVol,Cref,p); | ||||
|   //  std::cout <<"Ctilde "<< Ctilde <<std::endl; | ||||
|   //  std::cout <<"Cref   "<< Cref <<std::endl; | ||||
|  | ||||
|   theFFT.FFT_dim(Stilde,S,0,FFT::forward);  S=Stilde; std::cout << theFFT.MFlops()<<std::endl; | ||||
|   theFFT.FFT_dim(Stilde,S,1,FFT::forward);  S=Stilde;std::cout << theFFT.MFlops()<<std::endl; | ||||
|   theFFT.FFT_dim(Stilde,S,2,FFT::forward);  S=Stilde;std::cout << theFFT.MFlops()<<std::endl; | ||||
|   theFFT.FFT_dim(Stilde,S,3,FFT::forward);std::cout << theFFT.MFlops()<<std::endl; | ||||
|   Cref=Cref-Ctilde; | ||||
|   std::cout << "diff scalar "<<norm2(Cref) << std::endl; | ||||
|   C=Csav; | ||||
|   theFFT.FFT_all_dim(Ctilde,C,FFT::forward); | ||||
|   theFFT.FFT_all_dim(Cref,Ctilde,FFT::backward);  | ||||
|  | ||||
|   std::cout << norm2(C) << " " << norm2(Ctilde) << " " << norm2(Cref)<< " vol " << vol<< std::endl; | ||||
|  | ||||
|   Cref= Cref - C; | ||||
|   std::cout << " invertible check " << norm2(Cref)<<std::endl; | ||||
|  | ||||
|   Stilde=S; | ||||
|   std::cout<<" Benchmarking FFT of LatticeSpinMatrix  "<<std::endl; | ||||
|   theFFT.FFT_dim(Stilde,S,0,FFT::forward); std::cout << theFFT.MFlops()<<" mflops "<<std::endl; | ||||
|   theFFT.FFT_dim(Stilde,S,1,FFT::forward); std::cout << theFFT.MFlops()<<" mflops "<<std::endl; | ||||
|   theFFT.FFT_dim(Stilde,S,2,FFT::forward); std::cout << theFFT.MFlops()<<" mflops "<<std::endl; | ||||
|   theFFT.FFT_dim(Stilde,S,3,FFT::forward); std::cout << theFFT.MFlops()<<" mflops "<<std::endl; | ||||
|  | ||||
|   SpinMatrixD Sp;  | ||||
|   Sp = zero; Sp = Sp+cVol; | ||||
| @@ -107,5 +129,331 @@ int main (int argc, char ** argv) | ||||
|   S= S-Stilde; | ||||
|   std::cout << "diff FT[SpinMat] "<<norm2(S) << std::endl; | ||||
|  | ||||
|   /* | ||||
|    */ | ||||
|   std::vector<int> seeds({1,2,3,4}); | ||||
|   GridSerialRNG          sRNG;  sRNG.SeedFixedIntegers(seeds); // naughty seeding | ||||
|   GridParallelRNG          pRNG(&GRID); | ||||
|   pRNG.SeedFixedIntegers(seeds); | ||||
|  | ||||
|   LatticeGaugeFieldD Umu(&GRID); | ||||
|  | ||||
|   SU3::ColdConfiguration(pRNG,Umu); // Unit gauge | ||||
|   //  Umu=zero; | ||||
|   //////////////////////////////////////////////////// | ||||
|   // Wilson test | ||||
|   //////////////////////////////////////////////////// | ||||
|   { | ||||
|     LatticeFermionD    src(&GRID); gaussian(pRNG,src); | ||||
|     LatticeFermionD    tmp(&GRID); | ||||
|     LatticeFermionD    ref(&GRID); | ||||
|      | ||||
|     RealD mass=0.01; | ||||
|     WilsonFermionD Dw(Umu,GRID,RBGRID,mass); | ||||
|      | ||||
|     Dw.M(src,tmp); | ||||
|  | ||||
|     std::cout << "Dw src = " <<norm2(src)<<std::endl; | ||||
|     std::cout << "Dw tmp = " <<norm2(tmp)<<std::endl; | ||||
|      | ||||
|     Dw.FreePropagator(tmp,ref,mass); | ||||
|  | ||||
|     std::cout << "Dw ref = " <<norm2(ref)<<std::endl; | ||||
|      | ||||
|     ref = ref - src; | ||||
|      | ||||
|     std::cout << "Dw ref-src = " <<norm2(ref)<<std::endl; | ||||
|   } | ||||
|  | ||||
|   //////////////////////////////////////////////////// | ||||
|   // Dwf matrix | ||||
|   //////////////////////////////////////////////////// | ||||
|   { | ||||
|     std::cout<<"****************************************"<<std::endl; | ||||
|     std::cout<<"Testing Fourier representation of Ddwf"<<std::endl; | ||||
|     std::cout<<"****************************************"<<std::endl; | ||||
|      | ||||
|     const int Ls=16; | ||||
|     const int sdir=0; | ||||
|     RealD mass=0.01; | ||||
|     RealD M5  =1.0; | ||||
|     Gamma G5(Gamma::Gamma5); | ||||
|  | ||||
|     GridCartesian         * FGrid   = SpaceTimeGrid::makeFiveDimGrid(Ls,&GRID); | ||||
|     GridRedBlackCartesian * FrbGrid = SpaceTimeGrid::makeFiveDimRedBlackGrid(Ls,&GRID); | ||||
|  | ||||
|     std::cout<<"Making Ddwf"<<std::endl; | ||||
|     DomainWallFermionD Ddwf(Umu,*FGrid,*FrbGrid,GRID,RBGRID,mass,M5); | ||||
|  | ||||
|     GridParallelRNG          RNG5(FGrid);      RNG5.SeedFixedIntegers(seeds); | ||||
|     LatticeFermionD    src5(FGrid); gaussian(RNG5,src5); | ||||
|     LatticeFermionD    src5_p(FGrid);  | ||||
|     LatticeFermionD    result5(FGrid);  | ||||
|     LatticeFermionD    ref5(FGrid);  | ||||
|     LatticeFermionD    tmp5(FGrid);  | ||||
|  | ||||
|     ///////////////////////////////////////////////////////////////// | ||||
|     // result5 is the non pert operator in 4d mom space | ||||
|     ///////////////////////////////////////////////////////////////// | ||||
|     Ddwf.M(src5,tmp5);  | ||||
|     ref5 = tmp5; | ||||
|      | ||||
|     FFT theFFT5(FGrid); | ||||
|        | ||||
|     theFFT5.FFT_dim(result5,tmp5,1,FFT::forward); tmp5 = result5; | ||||
|     theFFT5.FFT_dim(result5,tmp5,2,FFT::forward); tmp5 = result5; | ||||
|     theFFT5.FFT_dim(result5,tmp5,3,FFT::forward); tmp5 = result5; | ||||
|     theFFT5.FFT_dim(result5,tmp5,4,FFT::forward); result5 = result5*ComplexD(::sqrt(1.0/vol),0.0); | ||||
|      | ||||
|     std::cout<<"Fourier xformed Ddwf"<<std::endl; | ||||
|      | ||||
|     tmp5 = src5; | ||||
|     theFFT5.FFT_dim(src5_p,tmp5,1,FFT::forward); tmp5 = src5_p; | ||||
|     theFFT5.FFT_dim(src5_p,tmp5,2,FFT::forward); tmp5 = src5_p; | ||||
|     theFFT5.FFT_dim(src5_p,tmp5,3,FFT::forward); tmp5 = src5_p; | ||||
|     theFFT5.FFT_dim(src5_p,tmp5,4,FFT::forward); src5_p = src5_p*ComplexD(::sqrt(1.0/vol),0.0); | ||||
|  | ||||
|     std::cout<<"Fourier xformed src5"<<std::endl; | ||||
|        | ||||
|     ///////////////////////////////////////////////////////////////// | ||||
|     // work out the predicted from Fourier | ||||
|     ///////////////////////////////////////////////////////////////// | ||||
|     Gamma::GammaMatrix Gmu [] = { | ||||
|       Gamma::GammaX, | ||||
|       Gamma::GammaY, | ||||
|       Gamma::GammaZ, | ||||
|       Gamma::GammaT, | ||||
|       Gamma::Gamma5 | ||||
|     }; | ||||
|     LatticeFermionD    Kinetic(FGrid); Kinetic = zero; | ||||
|     LatticeComplexD    kmu(FGrid);  | ||||
|     LatticeInteger     scoor(FGrid);  | ||||
|     LatticeComplexD    sk (FGrid); sk = zero; | ||||
|     LatticeComplexD    sk2(FGrid); sk2= zero; | ||||
|     LatticeComplexD    W(FGrid); W= zero; | ||||
|     //      LatticeComplexD    a(FGrid); a= zero; | ||||
|     LatticeComplexD    one(FGrid); one =ComplexD(1.0,0.0); | ||||
|     ComplexD ci(0.0,1.0); | ||||
|      | ||||
|     for(int mu=0;mu<Nd;mu++) { | ||||
|        | ||||
|       LatticeCoordinate(kmu,mu+1); | ||||
|        | ||||
|       RealD TwoPiL =  M_PI * 2.0/ latt_size[mu]; | ||||
|        | ||||
|       kmu = TwoPiL * kmu; | ||||
|        | ||||
|       sk2 = sk2 + 2.0*sin(kmu*0.5)*sin(kmu*0.5); | ||||
|       sk  = sk  +     sin(kmu)    *sin(kmu);  | ||||
|        | ||||
|       // -1/2 Dw ->  1/2 gmu (eip - emip) = i sinp gmu | ||||
|       Kinetic = Kinetic + sin(kmu)*ci*(Gamma(Gmu[mu])*src5_p); | ||||
|        | ||||
|     } | ||||
|      | ||||
|     // NB implicit sum over mu | ||||
|     // | ||||
|     // 1-1/2 Dw = 1 - 1/2 ( eip+emip) | ||||
|     //          = - 1/2 (ei - 2 +  emi)  | ||||
|     //          = - 1/4 2 (eih - eimh)(eih - eimh)  | ||||
|     //          = 2 sink/2 ink/2 = sk2 | ||||
|      | ||||
|     W = one - M5 + sk2;  | ||||
|     Kinetic = Kinetic + W * src5_p; | ||||
|      | ||||
|     LatticeCoordinate(scoor,sdir); | ||||
|      | ||||
|     tmp5 = Cshift(src5_p,sdir,+1); | ||||
|     tmp5 = (tmp5 - G5*tmp5)*0.5; | ||||
|     tmp5 = where(scoor==Integer(Ls-1),mass*tmp5,-tmp5); | ||||
|     Kinetic = Kinetic + tmp5; | ||||
|      | ||||
|     tmp5 = Cshift(src5_p,sdir,-1); | ||||
|     tmp5 = (tmp5 + G5*tmp5)*0.5; | ||||
|     tmp5 = where(scoor==Integer(0),mass*tmp5,-tmp5); | ||||
|     Kinetic = Kinetic + tmp5; | ||||
|      | ||||
|     std::cout<<"Momentum space Ddwf  "<< norm2(Kinetic)<<std::endl; | ||||
|     std::cout<<"Stencil Ddwf         "<< norm2(result5)<<std::endl; | ||||
|      | ||||
|     result5 = result5 - Kinetic; | ||||
|     std::cout<<"diff "<< norm2(result5)<<std::endl; | ||||
|      | ||||
|   } | ||||
|  | ||||
|   //////////////////////////////////////////////////// | ||||
|   // Dwf prop | ||||
|   //////////////////////////////////////////////////// | ||||
|   { | ||||
|     std::cout<<"****************************************"<<std::endl; | ||||
|     std::cout << "Testing Ddwf Ht Mom space 4d propagator \n"; | ||||
|     std::cout<<"****************************************"<<std::endl; | ||||
|  | ||||
|     LatticeFermionD    src(&GRID); gaussian(pRNG,src); | ||||
|     LatticeFermionD    tmp(&GRID); | ||||
|     LatticeFermionD    ref(&GRID); | ||||
|     LatticeFermionD    diff(&GRID); | ||||
|  | ||||
|     std::vector<int> point(4,0); | ||||
|     src=zero; | ||||
|     SpinColourVectorD ferm; gaussian(sRNG,ferm); | ||||
|     pokeSite(ferm,src,point); | ||||
|  | ||||
|     const int Ls=32; | ||||
|     GridCartesian         * FGrid   = SpaceTimeGrid::makeFiveDimGrid(Ls,&GRID); | ||||
|     GridRedBlackCartesian * FrbGrid = SpaceTimeGrid::makeFiveDimRedBlackGrid(Ls,&GRID); | ||||
|  | ||||
|     RealD mass=0.01; | ||||
|     RealD M5  =0.8; | ||||
|     DomainWallFermionD Ddwf(Umu,*FGrid,*FrbGrid,GRID,RBGRID,mass,M5); | ||||
|  | ||||
|     // Momentum space prop | ||||
|     std::cout << " Solving by FFT and Feynman rules" <<std::endl; | ||||
|     Ddwf.FreePropagator(src,ref,mass) ; | ||||
|  | ||||
|     Gamma G5(Gamma::Gamma5); | ||||
|  | ||||
|     LatticeFermionD    src5(FGrid); src5=zero; | ||||
|     LatticeFermionD    tmp5(FGrid);  | ||||
|     LatticeFermionD    result5(FGrid); result5=zero; | ||||
|     LatticeFermionD    result4(&GRID);  | ||||
|     const int sdir=0; | ||||
|  | ||||
|     //////////////////////////////////////////////////////////////////////// | ||||
|     // Domain wall physical field source | ||||
|     //////////////////////////////////////////////////////////////////////// | ||||
|     /* | ||||
| 	chi_5[0]   = chiralProjectPlus(chi); | ||||
| 	chi_5[Ls-1]= chiralProjectMinus(chi); | ||||
|     */       | ||||
|     tmp =   (src + G5*src)*0.5;      InsertSlice(tmp,src5,   0,sdir); | ||||
|     tmp =   (src - G5*src)*0.5;      InsertSlice(tmp,src5,Ls-1,sdir); | ||||
|      | ||||
|     //////////////////////////////////////////////////////////////////////// | ||||
|     // Conjugate gradient on normal equations system | ||||
|     //////////////////////////////////////////////////////////////////////// | ||||
|     std::cout << " Solving by Conjugate Gradient (CGNE)" <<std::endl; | ||||
|     Ddwf.Mdag(src5,tmp5); | ||||
|     src5=tmp5; | ||||
|     MdagMLinearOperator<DomainWallFermionD,LatticeFermionD> HermOp(Ddwf); | ||||
|     ConjugateGradient<LatticeFermionD> CG(1.0e-16,10000); | ||||
|     CG(HermOp,src5,result5); | ||||
|      | ||||
|     //////////////////////////////////////////////////////////////////////// | ||||
|     // Domain wall physical field propagator | ||||
|     //////////////////////////////////////////////////////////////////////// | ||||
|     /* | ||||
|       psi  = chiralProjectMinus(psi_5[0]); | ||||
|       psi += chiralProjectPlus(psi_5[Ls-1]); | ||||
|     */ | ||||
|     ExtractSlice(tmp,result5,0   ,sdir);   result4 =         (tmp-G5*tmp)*0.5; | ||||
|     ExtractSlice(tmp,result5,Ls-1,sdir);   result4 = result4+(tmp+G5*tmp)*0.5; | ||||
|      | ||||
|     std::cout << " Taking difference" <<std::endl; | ||||
|     std::cout << "Ddwf result4 "<<norm2(result4)<<std::endl; | ||||
|     std::cout << "Ddwf ref     "<<norm2(ref)<<std::endl; | ||||
|      | ||||
|     diff = ref - result4; | ||||
|     std::cout << "result - ref     "<<norm2(diff)<<std::endl; | ||||
|  | ||||
|   } | ||||
|  | ||||
|  | ||||
|  | ||||
|   //////////////////////////////////////////////////// | ||||
|   // Dwf prop | ||||
|   //////////////////////////////////////////////////// | ||||
|   { | ||||
|     std::cout<<"****************************************"<<std::endl; | ||||
|     std::cout << "Testing Dov Ht Mom space 4d propagator \n"; | ||||
|     std::cout<<"****************************************"<<std::endl; | ||||
|  | ||||
|     LatticeFermionD    src(&GRID); gaussian(pRNG,src); | ||||
|     LatticeFermionD    tmp(&GRID); | ||||
|     LatticeFermionD    ref(&GRID); | ||||
|     LatticeFermionD    diff(&GRID); | ||||
|  | ||||
|     std::vector<int> point(4,0); | ||||
|     src=zero; | ||||
|     SpinColourVectorD ferm; gaussian(sRNG,ferm); | ||||
|     pokeSite(ferm,src,point); | ||||
|  | ||||
|     const int Ls=48; | ||||
|     GridCartesian         * FGrid   = SpaceTimeGrid::makeFiveDimGrid(Ls,&GRID); | ||||
|     GridRedBlackCartesian * FrbGrid = SpaceTimeGrid::makeFiveDimRedBlackGrid(Ls,&GRID); | ||||
|  | ||||
|     RealD mass=0.01; | ||||
|     RealD M5  =0.8; | ||||
|  | ||||
|     OverlapWilsonCayleyTanhFermionD Dov(Umu,*FGrid,*FrbGrid,GRID,RBGRID,mass,M5,1.0); | ||||
|  | ||||
|     // Momentum space prop | ||||
|     std::cout << " Solving by FFT and Feynman rules" <<std::endl; | ||||
|     Dov.FreePropagator(src,ref,mass) ; | ||||
|  | ||||
|     Gamma G5(Gamma::Gamma5); | ||||
|  | ||||
|     LatticeFermionD    src5(FGrid); src5=zero; | ||||
|     LatticeFermionD    tmp5(FGrid);  | ||||
|     LatticeFermionD    result5(FGrid); result5=zero; | ||||
|     LatticeFermionD    result4(&GRID);  | ||||
|     const int sdir=0; | ||||
|  | ||||
|     //////////////////////////////////////////////////////////////////////// | ||||
|     // Domain wall physical field source; need D_minus | ||||
|     //////////////////////////////////////////////////////////////////////// | ||||
|     /* | ||||
| 	chi_5[0]   = chiralProjectPlus(chi); | ||||
| 	chi_5[Ls-1]= chiralProjectMinus(chi); | ||||
|     */       | ||||
|     tmp =   (src + G5*src)*0.5;      InsertSlice(tmp,src5,   0,sdir); | ||||
|     tmp =   (src - G5*src)*0.5;      InsertSlice(tmp,src5,Ls-1,sdir); | ||||
|  | ||||
|      | ||||
|     //////////////////////////////////////////////////////////////////////// | ||||
|     // Conjugate gradient on normal equations system | ||||
|     //////////////////////////////////////////////////////////////////////// | ||||
|     std::cout << " Solving by Conjugate Gradient (CGNE)" <<std::endl; | ||||
|     Dov.Dminus(src5,tmp5); | ||||
|     src5=tmp5; | ||||
|     Dov.Mdag(src5,tmp5); | ||||
|     src5=tmp5; | ||||
|     MdagMLinearOperator<OverlapWilsonCayleyTanhFermionD,LatticeFermionD> HermOp(Dov); | ||||
|     ConjugateGradient<LatticeFermionD> CG(1.0e-16,10000); | ||||
|     CG(HermOp,src5,result5); | ||||
|      | ||||
|     //////////////////////////////////////////////////////////////////////// | ||||
|     // Domain wall physical field propagator | ||||
|     //////////////////////////////////////////////////////////////////////// | ||||
|     /* | ||||
|       psi  = chiralProjectMinus(psi_5[0]); | ||||
|       psi += chiralProjectPlus(psi_5[Ls-1]); | ||||
|     */ | ||||
|     ExtractSlice(tmp,result5,0   ,sdir);   result4 =         (tmp-G5*tmp)*0.5; | ||||
|     ExtractSlice(tmp,result5,Ls-1,sdir);   result4 = result4+(tmp+G5*tmp)*0.5; | ||||
|      | ||||
|     std::cout << " Taking difference" <<std::endl; | ||||
|     std::cout << "Dov result4 "<<norm2(result4)<<std::endl; | ||||
|     std::cout << "Dov ref     "<<norm2(ref)<<std::endl; | ||||
|      | ||||
|     diff = ref - result4; | ||||
|     std::cout << "result - ref     "<<norm2(diff)<<std::endl; | ||||
|  | ||||
|   } | ||||
|  | ||||
|   { | ||||
|     /* | ||||
|      *  | ||||
|     typedef GaugeImplTypes<vComplexD, 1> QEDGimplTypesD; | ||||
|     typedef Photon<QEDGimplTypesD>       QEDGaction; | ||||
|  | ||||
|     QEDGaction Maxwell(QEDGaction::FEYNMAN_L); | ||||
|     QEDGaction::GaugeField Prop(&GRID);Prop=zero; | ||||
|     QEDGaction::GaugeField Source(&GRID);Source=zero; | ||||
|  | ||||
|     Maxwell.FreePropagator (Source,Prop); | ||||
|     std::cout << " MaxwellFree propagator\n"; | ||||
|     */ | ||||
|   } | ||||
|   Grid_finalize(); | ||||
| } | ||||
|   | ||||
							
								
								
									
										300
									
								
								tests/core/Test_fft_gfix.cc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										300
									
								
								tests/core/Test_fft_gfix.cc
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,300 @@ | ||||
|     /************************************************************************************* | ||||
|  | ||||
|     grid` physics library, www.github.com/paboyle/Grid  | ||||
|  | ||||
|     Source file: ./tests/Test_cshift.cc | ||||
|  | ||||
|     Copyright (C) 2015 | ||||
|  | ||||
| Author: Azusa Yamaguchi <ayamaguc@staffmail.ed.ac.uk> | ||||
| Author: Peter Boyle <paboyle@ph.ed.ac.uk> | ||||
|  | ||||
|     This program is free software; you can redistribute it and/or modify | ||||
|     it under the terms of the GNU General Public License as published by | ||||
|     the Free Software Foundation; either version 2 of the License, or | ||||
|     (at your option) any later version. | ||||
|  | ||||
|     This program is distributed in the hope that it will be useful, | ||||
|     but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|     GNU General Public License for more details. | ||||
|  | ||||
|     You should have received a copy of the GNU General Public License along | ||||
|     with this program; if not, write to the Free Software Foundation, Inc., | ||||
|     51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. | ||||
|  | ||||
|     See the full license in the file "LICENSE" in the top level distribution directory | ||||
|     *************************************************************************************/ | ||||
|     /*  END LEGAL */ | ||||
| #include <Grid/Grid.h> | ||||
|  | ||||
| using namespace Grid; | ||||
| using namespace Grid::QCD; | ||||
|  | ||||
| template <class Gimpl>  | ||||
| class FourierAcceleratedGaugeFixer  : public Gimpl { | ||||
|   public: | ||||
|   INHERIT_GIMPL_TYPES(Gimpl); | ||||
|  | ||||
|   typedef typename Gimpl::GaugeLinkField GaugeMat; | ||||
|   typedef typename Gimpl::GaugeField GaugeLorentz; | ||||
|  | ||||
|   static void GaugeLinkToLieAlgebraField(const std::vector<GaugeMat> &U,std::vector<GaugeMat> &A) { | ||||
|     for(int mu=0;mu<Nd;mu++){ | ||||
| //      ImplComplex cmi(0.0,-1.0); | ||||
|       ComplexD cmi(0.0,-1.0); | ||||
|       A[mu] = Ta(U[mu]) * cmi; | ||||
|     } | ||||
|   } | ||||
|   static void DmuAmu(const std::vector<GaugeMat> &A,GaugeMat &dmuAmu) { | ||||
|     dmuAmu=zero; | ||||
|     for(int mu=0;mu<Nd;mu++){ | ||||
|       dmuAmu = dmuAmu + A[mu] - Cshift(A[mu],mu,-1); | ||||
|     } | ||||
|   }   | ||||
|   static void SteepestDescentGaugeFix(GaugeLorentz &Umu,RealD & alpha,int maxiter,RealD Omega_tol, RealD Phi_tol) { | ||||
|     GridBase *grid = Umu._grid; | ||||
|  | ||||
|     RealD org_plaq      =WilsonLoops<Gimpl>::avgPlaquette(Umu); | ||||
|     RealD org_link_trace=WilsonLoops<Gimpl>::linkTrace(Umu);  | ||||
|     RealD old_trace = org_link_trace; | ||||
|     RealD trG; | ||||
|  | ||||
|     std::vector<GaugeMat> U(Nd,grid); | ||||
|                  GaugeMat dmuAmu(grid); | ||||
|  | ||||
|     for(int i=0;i<maxiter;i++){ | ||||
|       for(int mu=0;mu<Nd;mu++) U[mu]= PeekIndex<LorentzIndex>(Umu,mu); | ||||
|       //trG = SteepestDescentStep(U,alpha,dmuAmu); | ||||
|       trG = FourierAccelSteepestDescentStep(U,alpha,dmuAmu); | ||||
|       for(int mu=0;mu<Nd;mu++) PokeIndex<LorentzIndex>(Umu,U[mu],mu); | ||||
|       // Monitor progress and convergence test  | ||||
|       // infrequently to minimise cost overhead | ||||
|       if ( i %20 == 0 ) {  | ||||
| 	RealD plaq      =WilsonLoops<Gimpl>::avgPlaquette(Umu); | ||||
| 	RealD link_trace=WilsonLoops<Gimpl>::linkTrace(Umu);  | ||||
|  | ||||
| 	std::cout << GridLogMessage << " Iteration "<<i<< " plaq= "<<plaq<< " dmuAmu " << norm2(dmuAmu)<< std::endl; | ||||
| 	 | ||||
| 	RealD Phi  = 1.0 - old_trace / link_trace ; | ||||
| 	RealD Omega= 1.0 - trG; | ||||
|  | ||||
|  | ||||
| 	std::cout << GridLogMessage << " Iteration "<<i<< " Phi= "<<Phi<< " Omega= " << Omega<< " trG " << trG <<std::endl; | ||||
| 	if ( (Omega < Omega_tol) && ( ::fabs(Phi) < Phi_tol) ) { | ||||
| 	  std::cout << GridLogMessage << "Converged ! "<<std::endl; | ||||
| 	  return; | ||||
| 	} | ||||
|  | ||||
| 	old_trace = link_trace; | ||||
|  | ||||
|       } | ||||
|     } | ||||
|   }; | ||||
|   static RealD SteepestDescentStep(std::vector<GaugeMat> &U,RealD & alpha, GaugeMat & dmuAmu) { | ||||
|     GridBase *grid = U[0]._grid; | ||||
|  | ||||
|     std::vector<GaugeMat> A(Nd,grid); | ||||
|     GaugeMat g(grid); | ||||
|  | ||||
|     GaugeLinkToLieAlgebraField(U,A); | ||||
|     ExpiAlphaDmuAmu(A,g,alpha,dmuAmu); | ||||
|  | ||||
|  | ||||
|     RealD vol = grid->gSites(); | ||||
|     RealD trG = TensorRemove(sum(trace(g))).real()/vol/Nc; | ||||
|  | ||||
|     SU<Nc>::GaugeTransform(U,g); | ||||
|  | ||||
|     return trG; | ||||
|   } | ||||
|  | ||||
|   static RealD FourierAccelSteepestDescentStep(std::vector<GaugeMat> &U,RealD & alpha, GaugeMat & dmuAmu) { | ||||
|  | ||||
|     GridBase *grid = U[0]._grid; | ||||
|  | ||||
|     RealD vol = grid->gSites(); | ||||
|  | ||||
|     FFT theFFT((GridCartesian *)grid); | ||||
|  | ||||
|     LatticeComplex  Fp(grid); | ||||
|     LatticeComplex  psq(grid); psq=zero; | ||||
|     LatticeComplex  pmu(grid);  | ||||
|     LatticeComplex   one(grid); one = ComplexD(1.0,0.0); | ||||
|  | ||||
|     GaugeMat g(grid); | ||||
|     GaugeMat dmuAmu_p(grid); | ||||
|     std::vector<GaugeMat> A(Nd,grid); | ||||
|  | ||||
|     GaugeLinkToLieAlgebraField(U,A); | ||||
|  | ||||
|     DmuAmu(A,dmuAmu); | ||||
|  | ||||
|     theFFT.FFT_all_dim(dmuAmu_p,dmuAmu,FFT::forward); | ||||
|  | ||||
|     ////////////////////////////////// | ||||
|     // Work out Fp = psq_max/ psq... | ||||
|     ////////////////////////////////// | ||||
|     std::vector<int> latt_size = grid->GlobalDimensions(); | ||||
|     std::vector<int> coor(grid->_ndimension,0); | ||||
|     for(int mu=0;mu<Nd;mu++) { | ||||
|  | ||||
|       RealD TwoPiL =  M_PI * 2.0/ latt_size[mu]; | ||||
|       LatticeCoordinate(pmu,mu); | ||||
|       pmu = TwoPiL * pmu ; | ||||
|       psq = psq + 4.0*sin(pmu*0.5)*sin(pmu*0.5);  | ||||
|     } | ||||
|  | ||||
|     ComplexD psqMax(16.0); | ||||
|     Fp =  psqMax*one/psq; | ||||
|  | ||||
|     static int once; | ||||
|     if ( once == 0 ) {  | ||||
|       std::cout << " Fp " << Fp <<std::endl; | ||||
|       once ++; | ||||
|     } | ||||
|     pokeSite(TComplex(1.0),Fp,coor); | ||||
|  | ||||
|     dmuAmu_p  = dmuAmu_p * Fp;  | ||||
|  | ||||
|     theFFT.FFT_all_dim(dmuAmu,dmuAmu_p,FFT::backward); | ||||
|  | ||||
|     GaugeMat ciadmam(grid); | ||||
|     ComplexD cialpha(0.0,-alpha); | ||||
|     ciadmam = dmuAmu*cialpha; | ||||
|     SU<Nc>::taExp(ciadmam,g); | ||||
|  | ||||
|     RealD trG = TensorRemove(sum(trace(g))).real()/vol/Nc; | ||||
|  | ||||
|     SU<Nc>::GaugeTransform(U,g); | ||||
|  | ||||
|     return trG; | ||||
|   } | ||||
|  | ||||
|   static void ExpiAlphaDmuAmu(const std::vector<GaugeMat> &A,GaugeMat &g,RealD & alpha, GaugeMat &dmuAmu) { | ||||
|     GridBase *grid = g._grid; | ||||
|     ComplexD cialpha(0.0,-alpha); | ||||
|     GaugeMat ciadmam(grid); | ||||
|     DmuAmu(A,dmuAmu); | ||||
|     ciadmam = dmuAmu*cialpha; | ||||
|     SU<Nc>::taExp(ciadmam,g); | ||||
|   }   | ||||
| /* | ||||
|   //////////////////////////////////////////////////////////////// | ||||
|   // NB The FT for fields living on links has an extra phase in it | ||||
|   // Could add these to the FFT class as a later task since this code | ||||
|   // might be reused elsewhere ???? | ||||
|   //////////////////////////////////////////////////////////////// | ||||
|   static void InverseFourierTransformAmu(FFT &theFFT,const std::vector<GaugeMat> &Ap,std::vector<GaugeMat> &Ax) { | ||||
|     GridBase * grid = theFFT.Grid(); | ||||
|     std::vector<int> latt_size = grid->GlobalDimensions(); | ||||
|  | ||||
|     ComplexField  pmu(grid); | ||||
|     ComplexField  pha(grid); | ||||
|     GaugeMat      Apha(grid); | ||||
|  | ||||
|     ComplexD ci(0.0,1.0); | ||||
|  | ||||
|     for(int mu=0;mu<Nd;mu++){ | ||||
|  | ||||
|       RealD TwoPiL =  M_PI * 2.0/ latt_size[mu]; | ||||
|       LatticeCoordinate(pmu,mu); | ||||
|       pmu = TwoPiL * pmu ; | ||||
|       pha = exp(pmu *  (0.5 *ci)); // e(ipmu/2) since Amu(x+mu/2) | ||||
|  | ||||
|       Apha = Ap[mu] * pha; | ||||
|  | ||||
|       theFFT.FFT_all_dim(Apha,Ax[mu],FFT::backward); | ||||
|     } | ||||
|   } | ||||
|   static void FourierTransformAmu(FFT & theFFT,const std::vector<GaugeMat> &Ax,std::vector<GaugeMat> &Ap) { | ||||
|     GridBase * grid = theFFT.Grid(); | ||||
|     std::vector<int> latt_size = grid->GlobalDimensions(); | ||||
|  | ||||
|     ComplexField  pmu(grid); | ||||
|     ComplexField  pha(grid); | ||||
|     ComplexD ci(0.0,1.0); | ||||
|      | ||||
|     // Sign convention for FFTW calls: | ||||
|     // A(x)= Sum_p e^ipx A(p) / V | ||||
|     // A(p)= Sum_p e^-ipx A(x) | ||||
|  | ||||
|     for(int mu=0;mu<Nd;mu++){ | ||||
|       RealD TwoPiL =  M_PI * 2.0/ latt_size[mu]; | ||||
|       LatticeCoordinate(pmu,mu); | ||||
|       pmu = TwoPiL * pmu ; | ||||
|       pha = exp(-pmu *  (0.5 *ci)); // e(+ipmu/2) since Amu(x+mu/2) | ||||
|  | ||||
|       theFFT.FFT_all_dim(Ax[mu],Ap[mu],FFT::backward); | ||||
|       Ap[mu] = Ap[mu] * pha; | ||||
|     } | ||||
|   } | ||||
| */ | ||||
| }; | ||||
|  | ||||
| int main (int argc, char ** argv) | ||||
| { | ||||
|   std::vector<int> seeds({1,2,3,4}); | ||||
|  | ||||
|   Grid_init(&argc,&argv); | ||||
|  | ||||
|   int threads = GridThread::GetThreads(); | ||||
|  | ||||
|   std::vector<int> latt_size   = GridDefaultLatt(); | ||||
|   std::vector<int> simd_layout( { vComplexD::Nsimd(),1,1,1}); | ||||
|   std::vector<int> mpi_layout  = GridDefaultMpi(); | ||||
|  | ||||
|   int vol = 1; | ||||
|   for(int d=0;d<latt_size.size();d++){ | ||||
|     vol = vol * latt_size[d]; | ||||
|   } | ||||
|  | ||||
|   GridCartesian         GRID(latt_size,simd_layout,mpi_layout); | ||||
|   GridSerialRNG          sRNG;  sRNG.SeedFixedIntegers(seeds); // naughty seeding | ||||
|   GridParallelRNG          pRNG(&GRID);   pRNG.SeedFixedIntegers(seeds); | ||||
|  | ||||
|   FFT theFFT(&GRID); | ||||
|  | ||||
|   std::cout<<GridLogMessage << "Grid is setup to use "<<threads<<" threads"<<std::endl; | ||||
|  | ||||
|   std::cout<< "*****************************************************************" <<std::endl; | ||||
|   std::cout<< "* Testing we can gauge fix steep descent a RGT of Unit gauge    *" <<std::endl; | ||||
|   std::cout<< "*****************************************************************" <<std::endl; | ||||
|  | ||||
|   LatticeGaugeFieldD   Umu(&GRID); | ||||
|   LatticeGaugeFieldD   Uorg(&GRID); | ||||
|   LatticeColourMatrixD   g(&GRID); // Gauge xform | ||||
|  | ||||
|    | ||||
|   SU3::ColdConfiguration(pRNG,Umu); // Unit gauge | ||||
|   Uorg=Umu; | ||||
|  | ||||
|   SU3::RandomGaugeTransform(pRNG,Umu,g); // Unit gauge | ||||
|   RealD plaq=WilsonLoops<PeriodicGimplD>::avgPlaquette(Umu); | ||||
|   std::cout << " Initial plaquette "<<plaq << std::endl; | ||||
|  | ||||
|  | ||||
|  | ||||
|   RealD alpha=0.1; | ||||
|   FourierAcceleratedGaugeFixer<PeriodicGimplD>::SteepestDescentGaugeFix(Umu,alpha,10000,1.0e-10, 1.0e-10); | ||||
|  | ||||
|  | ||||
|   plaq=WilsonLoops<PeriodicGimplD>::avgPlaquette(Umu); | ||||
|   std::cout << " Final plaquette "<<plaq << std::endl; | ||||
|  | ||||
|   Uorg = Uorg - Umu; | ||||
|   std::cout << " Norm Difference "<< norm2(Uorg) << std::endl; | ||||
|  | ||||
|  | ||||
|   //  std::cout<< "*****************************************************************" <<std::endl; | ||||
|   //  std::cout<< "* Testing Fourier accelerated fixing                            *" <<std::endl; | ||||
|   //  std::cout<< "*****************************************************************" <<std::endl; | ||||
|  | ||||
|   //  std::cout<< "*****************************************************************" <<std::endl; | ||||
|   //  std::cout<< "* Testing non-unit configuration                                *" <<std::endl; | ||||
|   //  std::cout<< "*****************************************************************" <<std::endl; | ||||
|  | ||||
|  | ||||
|  | ||||
|   Grid_finalize(); | ||||
| } | ||||
							
								
								
									
										138
									
								
								tests/core/Test_poisson_fft.cc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										138
									
								
								tests/core/Test_poisson_fft.cc
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,138 @@ | ||||
|     /************************************************************************************* | ||||
|  | ||||
|     Grid physics library, www.github.com/paboyle/Grid  | ||||
|  | ||||
|     Source file: ./tests/Test_poisson_fft.cc | ||||
|  | ||||
|     Copyright (C) 2015 | ||||
|  | ||||
| Author: Azusa Yamaguchi <ayamaguc@staffmail.ed.ac.uk> | ||||
| Author: Peter Boyle <paboyle@ph.ed.ac.uk> | ||||
|  | ||||
|     This program is free software; you can redistribute it and/or modify | ||||
|     it under the terms of the GNU General Public License as published by | ||||
|     the Free Software Foundation; either version 2 of the License, or | ||||
|     (at your option) any later version. | ||||
|  | ||||
|     This program is distributed in the hope that it will be useful, | ||||
|     but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|     GNU General Public License for more details. | ||||
|  | ||||
|     You should have received a copy of the GNU General Public License along | ||||
|     with this program; if not, write to the Free Software Foundation, Inc., | ||||
|     51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. | ||||
|  | ||||
|     See the full license in the file "LICENSE" in the top level distribution directory | ||||
|     *************************************************************************************/ | ||||
|     /*  END LEGAL */ | ||||
| #include <Grid/Grid.h> | ||||
|  | ||||
| using namespace Grid; | ||||
| using namespace Grid::QCD; | ||||
|  | ||||
| int main (int argc, char ** argv) | ||||
| { | ||||
|   Grid_init(&argc,&argv); | ||||
|  | ||||
|   int threads = GridThread::GetThreads(); | ||||
|   std::cout<<GridLogMessage << "Grid is setup to use "<<threads<<" threads"<<std::endl; | ||||
|  | ||||
|   int N=128; | ||||
|   int N2=64; | ||||
|   int W=16; | ||||
|   int D=8; | ||||
|   std::vector<int> latt_size  ({N,N}); | ||||
|   std::vector<int> simd_layout({vComplexD::Nsimd(),1}); | ||||
|   std::vector<int> mpi_layout ({1,1}); | ||||
|  | ||||
|   int vol = 1; | ||||
|   int nd  = latt_size.size(); | ||||
|   for(int d=0;d<nd;d++){ | ||||
|     vol = vol * latt_size[d]; | ||||
|   } | ||||
|  | ||||
|   GridCartesian         GRID(latt_size,simd_layout,mpi_layout); | ||||
|  | ||||
|   LatticeComplexD     pos(&GRID); | ||||
|   LatticeComplexD      zz(&GRID); | ||||
|   LatticeComplexD     neg(&GRID); | ||||
|   LatticeInteger     coor(&GRID); | ||||
|   LatticeComplexD  Charge(&GRID); | ||||
|   LatticeComplexD  ChargeTilde(&GRID); | ||||
|   LatticeComplexD       V(&GRID); | ||||
|   LatticeComplexD       Vtilde(&GRID); | ||||
|  | ||||
|   pos = ComplexD(1.0,0.0); | ||||
|   neg = -pos; | ||||
|   zz  = ComplexD(0.0,0.0); | ||||
|  | ||||
|   Charge=zero; | ||||
|    | ||||
|   // Parallel plate capacitor | ||||
|   { | ||||
|     int mu=0; | ||||
|     LatticeCoordinate(coor,mu); | ||||
|  | ||||
|     Charge=where(coor==Integer(N2-D),pos,zz); | ||||
|     Charge=where(coor==Integer(N2+D),neg,Charge); | ||||
|   } | ||||
|  | ||||
|   { | ||||
|     int mu=1; | ||||
|     LatticeCoordinate(coor,mu); | ||||
|     Charge=where(coor<Integer(N2-W),zz,Charge); | ||||
|     Charge=where(coor>Integer(N2+W),zz,Charge); | ||||
|   } | ||||
|  | ||||
|   //  std::cout << Charge <<std::endl; | ||||
|  | ||||
|   std::vector<LatticeComplexD> k(4,&GRID); | ||||
|   LatticeComplexD ksq(&GRID); | ||||
|  | ||||
|   ksq=zero; | ||||
|   for(int mu=0;mu<nd;mu++) { | ||||
|      | ||||
|     Integer L=latt_size[mu]; | ||||
|      | ||||
|     LatticeCoordinate(coor,mu); | ||||
|     LatticeCoordinate(k[mu],mu); | ||||
|  | ||||
|     k[mu] = where ( coor > (L/2), k[mu]-L, k[mu]); | ||||
|  | ||||
|     //    std::cout << k[mu]<<std::endl; | ||||
|  | ||||
|     RealD TwoPiL =  M_PI * 2.0/ L; | ||||
|  | ||||
|     k[mu] = TwoPiL * k[mu];       | ||||
|  | ||||
|     ksq = ksq + k[mu]*k[mu]; | ||||
|  | ||||
|   } | ||||
|    | ||||
|   // D^2 V   = - rho | ||||
|   // ksq Vtilde = rhoTilde | ||||
|   // Vtilde = rhoTilde/Ksq | ||||
|   // Fix zero of potential : Vtilde(0) = 0; | ||||
|   std::vector<int> zero_mode(nd,0); | ||||
|   TComplexD Tone = ComplexD(1.0,0.0); | ||||
|   pokeSite(Tone,ksq,zero_mode);  | ||||
|  | ||||
|   //  std::cout << "Charge\n" << Charge <<std::endl; | ||||
|  | ||||
|   FFT theFFT(&GRID); | ||||
|   theFFT.FFT_all_dim(ChargeTilde,Charge,FFT::forward);  | ||||
|   //  std::cout << "Rhotilde\n" << ChargeTilde <<std::endl; | ||||
|  | ||||
|   Vtilde = ChargeTilde / ksq; | ||||
|   //  std::cout << "Vtilde\n" << Vtilde <<std::endl; | ||||
|  | ||||
|   TComplexD Tzero = ComplexD(0.0,0.0); | ||||
|   pokeSite(Tzero,Vtilde,zero_mode); | ||||
|  | ||||
|   theFFT.FFT_all_dim(V,Vtilde,FFT::backward);  | ||||
|  | ||||
|   std::cout << "V\n" << V <<std::endl; | ||||
|  | ||||
|   Grid_finalize(); | ||||
| } | ||||
| @@ -102,16 +102,14 @@ int main (int argc, char ** argv) | ||||
|     PokeIndex<LorentzIndex>(mom,mommu,mu); | ||||
|  | ||||
|     // fourth order exponential approx | ||||
|     parallel_for(auto i=mom.begin();i<mom.end();i++){ | ||||
|       Uprime[i](mu) = | ||||
| 	  U[i](mu) | ||||
| 	+ mom[i](mu)*U[i](mu)*dt  | ||||
| 	+ mom[i](mu) *mom[i](mu) *U[i](mu)*(dt*dt/2.0) | ||||
| 	+ mom[i](mu) *mom[i](mu) *mom[i](mu) *U[i](mu)*(dt*dt*dt/6.0) | ||||
| 	+ mom[i](mu) *mom[i](mu) *mom[i](mu) *mom[i](mu) *U[i](mu)*(dt*dt*dt*dt/24.0) | ||||
| 	+ mom[i](mu) *mom[i](mu) *mom[i](mu) *mom[i](mu) *mom[i](mu) *U[i](mu)*(dt*dt*dt*dt*dt/120.0) | ||||
| 	+ mom[i](mu) *mom[i](mu) *mom[i](mu) *mom[i](mu) *mom[i](mu) *mom[i](mu) *U[i](mu)*(dt*dt*dt*dt*dt*dt/720.0) | ||||
| 	; | ||||
|     parallel_for(auto i=mom.begin();i<mom.end();i++) { | ||||
|       Uprime[i](mu)  =	  U[i](mu); | ||||
|       Uprime[i](mu) += mom[i](mu)*U[i](mu)*dt ; | ||||
|       Uprime[i](mu) += mom[i](mu) *mom[i](mu) *U[i](mu)*(dt*dt/2.0); | ||||
|       Uprime[i](mu) += mom[i](mu) *mom[i](mu) *mom[i](mu) *U[i](mu)*(dt*dt*dt/6.0); | ||||
|       Uprime[i](mu) += mom[i](mu) *mom[i](mu) *mom[i](mu) *mom[i](mu) *U[i](mu)*(dt*dt*dt*dt/24.0); | ||||
|       Uprime[i](mu) += mom[i](mu) *mom[i](mu) *mom[i](mu) *mom[i](mu) *mom[i](mu) *U[i](mu)*(dt*dt*dt*dt*dt/120.0); | ||||
|       Uprime[i](mu) += mom[i](mu) *mom[i](mu) *mom[i](mu) *mom[i](mu) *mom[i](mu) *mom[i](mu) *U[i](mu)*(dt*dt*dt*dt*dt*dt/720.0); | ||||
|     } | ||||
|  | ||||
|   } | ||||
|   | ||||
| @@ -1,63 +0,0 @@ | ||||
| tests: Test_hmc_EODWFRatio Test_hmc_EODWFRatio_Gparity Test_hmc_EOWilsonFermionGauge Test_hmc_EOWilsonRatio Test_hmc_GparityIwasakiGauge Test_hmc_GparityWilsonGauge Test_hmc_IwasakiGauge Test_hmc_RectGauge Test_hmc_WilsonAdjointFermionGauge Test_hmc_WilsonFermionGauge Test_hmc_WilsonGauge Test_hmc_WilsonMixedRepresentationsFermionGauge Test_hmc_WilsonRatio Test_hmc_WilsonTwoIndexSymmetricFermionGauge Test_multishift_sqrt Test_remez Test_rhmc_EOWilson1p1 Test_rhmc_EOWilsonRatio Test_rhmc_Wilson1p1 Test_rhmc_WilsonRatio | ||||
| EXTRA_PROGRAMS = Test_hmc_EODWFRatio Test_hmc_EODWFRatio_Gparity Test_hmc_EOWilsonFermionGauge Test_hmc_EOWilsonRatio Test_hmc_GparityIwasakiGauge Test_hmc_GparityWilsonGauge Test_hmc_IwasakiGauge Test_hmc_RectGauge Test_hmc_WilsonAdjointFermionGauge Test_hmc_WilsonFermionGauge Test_hmc_WilsonGauge Test_hmc_WilsonMixedRepresentationsFermionGauge Test_hmc_WilsonRatio Test_hmc_WilsonTwoIndexSymmetricFermionGauge Test_multishift_sqrt Test_remez Test_rhmc_EOWilson1p1 Test_rhmc_EOWilsonRatio Test_rhmc_Wilson1p1 Test_rhmc_WilsonRatio | ||||
|  | ||||
| Test_hmc_EODWFRatio_SOURCES=Test_hmc_EODWFRatio.cc | ||||
| Test_hmc_EODWFRatio_LDADD=-lGrid | ||||
|  | ||||
| Test_hmc_EODWFRatio_Gparity_SOURCES=Test_hmc_EODWFRatio_Gparity.cc | ||||
| Test_hmc_EODWFRatio_Gparity_LDADD=-lGrid | ||||
|  | ||||
| Test_hmc_EOWilsonFermionGauge_SOURCES=Test_hmc_EOWilsonFermionGauge.cc | ||||
| Test_hmc_EOWilsonFermionGauge_LDADD=-lGrid | ||||
|  | ||||
| Test_hmc_EOWilsonRatio_SOURCES=Test_hmc_EOWilsonRatio.cc | ||||
| Test_hmc_EOWilsonRatio_LDADD=-lGrid | ||||
|  | ||||
| Test_hmc_GparityIwasakiGauge_SOURCES=Test_hmc_GparityIwasakiGauge.cc | ||||
| Test_hmc_GparityIwasakiGauge_LDADD=-lGrid | ||||
|  | ||||
| Test_hmc_GparityWilsonGauge_SOURCES=Test_hmc_GparityWilsonGauge.cc | ||||
| Test_hmc_GparityWilsonGauge_LDADD=-lGrid | ||||
|  | ||||
| Test_hmc_IwasakiGauge_SOURCES=Test_hmc_IwasakiGauge.cc | ||||
| Test_hmc_IwasakiGauge_LDADD=-lGrid | ||||
|  | ||||
| Test_hmc_RectGauge_SOURCES=Test_hmc_RectGauge.cc | ||||
| Test_hmc_RectGauge_LDADD=-lGrid | ||||
|  | ||||
| Test_hmc_WilsonAdjointFermionGauge_SOURCES=Test_hmc_WilsonAdjointFermionGauge.cc | ||||
| Test_hmc_WilsonAdjointFermionGauge_LDADD=-lGrid | ||||
|  | ||||
| Test_hmc_WilsonFermionGauge_SOURCES=Test_hmc_WilsonFermionGauge.cc | ||||
| Test_hmc_WilsonFermionGauge_LDADD=-lGrid | ||||
|  | ||||
| Test_hmc_WilsonGauge_SOURCES=Test_hmc_WilsonGauge.cc | ||||
| Test_hmc_WilsonGauge_LDADD=-lGrid | ||||
|  | ||||
| Test_hmc_WilsonMixedRepresentationsFermionGauge_SOURCES=Test_hmc_WilsonMixedRepresentationsFermionGauge.cc | ||||
| Test_hmc_WilsonMixedRepresentationsFermionGauge_LDADD=-lGrid | ||||
|  | ||||
| Test_hmc_WilsonRatio_SOURCES=Test_hmc_WilsonRatio.cc | ||||
| Test_hmc_WilsonRatio_LDADD=-lGrid | ||||
|  | ||||
| Test_hmc_WilsonTwoIndexSymmetricFermionGauge_SOURCES=Test_hmc_WilsonTwoIndexSymmetricFermionGauge.cc | ||||
| Test_hmc_WilsonTwoIndexSymmetricFermionGauge_LDADD=-lGrid | ||||
|  | ||||
| Test_multishift_sqrt_SOURCES=Test_multishift_sqrt.cc | ||||
| Test_multishift_sqrt_LDADD=-lGrid | ||||
|  | ||||
| Test_remez_SOURCES=Test_remez.cc | ||||
| Test_remez_LDADD=-lGrid | ||||
|  | ||||
| Test_rhmc_EOWilson1p1_SOURCES=Test_rhmc_EOWilson1p1.cc | ||||
| Test_rhmc_EOWilson1p1_LDADD=-lGrid | ||||
|  | ||||
| Test_rhmc_EOWilsonRatio_SOURCES=Test_rhmc_EOWilsonRatio.cc | ||||
| Test_rhmc_EOWilsonRatio_LDADD=-lGrid | ||||
|  | ||||
| Test_rhmc_Wilson1p1_SOURCES=Test_rhmc_Wilson1p1.cc | ||||
| Test_rhmc_Wilson1p1_LDADD=-lGrid | ||||
|  | ||||
| Test_rhmc_WilsonRatio_SOURCES=Test_rhmc_WilsonRatio.cc | ||||
| Test_rhmc_WilsonRatio_LDADD=-lGrid | ||||
|  | ||||
		Reference in New Issue
	
	Block a user