mirror of
				https://github.com/paboyle/Grid.git
				synced 2025-10-25 18:19:34 +01:00 
			
		
		
		
	More in the clover fermion class
This commit is contained in:
		| @@ -4,9 +4,10 @@ | |||||||
|  |  | ||||||
|     Source file: ./lib/qcd/action/fermion/WilsonTMFermion.h |     Source file: ./lib/qcd/action/fermion/WilsonTMFermion.h | ||||||
|  |  | ||||||
|     Copyright (C) 2015 |     Copyright (C) 2017 | ||||||
|  |  | ||||||
| Author: paboyle <paboyle@ph.ed.ac.uk> | Author: paboyle <paboyle@ph.ed.ac.uk> | ||||||
|  | Author: Guido Cossu <guido.cossu@ed.ac.uk> | ||||||
|  |  | ||||||
|     This program is free software; you can redistribute it and/or modify |     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 |     it under the terms of the GNU General Public License as published by | ||||||
| @@ -25,52 +26,46 @@ Author: paboyle <paboyle@ph.ed.ac.uk> | |||||||
|     See the full license in the file "LICENSE" in the top level distribution directory |     See the full license in the file "LICENSE" in the top level distribution directory | ||||||
|     *************************************************************************************/ |     *************************************************************************************/ | ||||||
| /*  END LEGAL */ | /*  END LEGAL */ | ||||||
| #ifndef  GRID_QCD_WILSON_TM_FERMION_H | #ifndef GRID_QCD_WILSON_CLOVER_FERMION_H | ||||||
| #define  GRID_QCD_WILSON_TM_FERMION_H | #define GRID_QCD_WILSON_CLOVER_FERMION_H | ||||||
|  |  | ||||||
| #include <Grid/Grid.h> | #include <Grid/Grid.h> | ||||||
|  |  | ||||||
| namespace Grid { | namespace Grid { | ||||||
|  |  | ||||||
| namespace QCD { | namespace QCD { | ||||||
|  |  | ||||||
| template <class Impl> | template <class Impl> | ||||||
|     class WilsonTMFermion : public WilsonFermion<Impl> | class WilsonCloverFermion : public WilsonFermion<Impl> { | ||||||
|     { |  | ||||||
| public: | public: | ||||||
|   INHERIT_IMPL_TYPES(Impl); |   INHERIT_IMPL_TYPES(Impl); | ||||||
|     public: |  | ||||||
|  |  | ||||||
|  | public: | ||||||
|   virtual void Instantiatable(void){}; |   virtual void Instantiatable(void){}; | ||||||
|   // Constructors |   // Constructors | ||||||
|       WilsonTMFermion(GaugeField &_Umu, |   WilsonCloverFermion(GaugeField &_Umu, GridCartesian &Fgrid, | ||||||
| 		    GridCartesian         &Fgrid, |  | ||||||
|                       GridRedBlackCartesian &Hgrid, |                       GridRedBlackCartesian &Hgrid, | ||||||
|                       RealD _mass, |                       RealD _mass, | ||||||
| 		    RealD _mu, |                       RealD _csw, | ||||||
| 		    const ImplParams &p= ImplParams() |                       const ImplParams &p = ImplParams()) : WilsonFermion<Impl>(_Umu, | ||||||
| 		      ) : |  | ||||||
| 	WilsonFermion<Impl>(_Umu, |  | ||||||
|                                                                                 Fgrid, |                                                                                 Fgrid, | ||||||
|                                                                                 Hgrid, |                                                                                 Hgrid, | ||||||
|                                                                                 _mass, p) |                                                                                 _mass, p) | ||||||
|  |  | ||||||
|   { |   { | ||||||
| 	mu = _mu; |     csw = _csw; | ||||||
|   } |   } | ||||||
|  |  | ||||||
|  |   virtual RealD M(const FermionField& in, FermionField& out); | ||||||
|  |   virtual RealD Mdag(const FermionField& in, FermionField& out); | ||||||
|  |  | ||||||
|     // allow override for twisted mass and clover |  | ||||||
|   virtual void Mooee(const FermionField &in, FermionField &out); |   virtual void Mooee(const FermionField &in, FermionField &out); | ||||||
|   virtual void MooeeDag(const FermionField &in, FermionField &out); |   virtual void MooeeDag(const FermionField &in, FermionField &out); | ||||||
|   virtual void MooeeInv(const FermionField &in, FermionField &out); |   virtual void MooeeInv(const FermionField &in, FermionField &out); | ||||||
|   virtual void MooeeInvDag(const FermionField &in, FermionField &out); |   virtual void MooeeInvDag(const FermionField &in, FermionField &out); | ||||||
|  |  | ||||||
| private: | private: | ||||||
|      RealD mu; // TwistedMass parameter |   RealD csw; // Clover coefficient | ||||||
|  |  | ||||||
| }; | }; | ||||||
|  | } | ||||||
|  | } | ||||||
|  |  | ||||||
| }} | #endif  // GRID_QCD_WILSON_CLOVER_FERMION_H | ||||||
|  |  | ||||||
| #endif |  | ||||||
|   | |||||||
| @@ -65,8 +65,8 @@ class WilsonFermion : public WilsonKernels<Impl>, public WilsonFermionStatic { | |||||||
|   // override multiply; cut number routines if pass dagger argument |   // override multiply; cut number routines if pass dagger argument | ||||||
|   // and also make interface more uniformly consistent |   // and also make interface more uniformly consistent | ||||||
|   ////////////////////////////////////////////////////////////////// |   ////////////////////////////////////////////////////////////////// | ||||||
|   RealD M(const FermionField &in, FermionField &out); |   virtual RealD M(const FermionField &in, FermionField &out); | ||||||
|   RealD Mdag(const FermionField &in, FermionField &out); |   virtual RealD Mdag(const FermionField &in, FermionField &out); | ||||||
|  |  | ||||||
|   ///////////////////////////////////////////////////////// |   ///////////////////////////////////////////////////////// | ||||||
|   // half checkerboard operations |   // half checkerboard operations | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user