Bridge++  Ver. 2.0.2
Staple_SF Class Reference

Staple construction. More...

#include <staple_SF.h>

Public Member Functions

 Staple_SF ()
 
 Staple_SF (const Parameters &params)
 
void set_parameters (const Parameters &params)
 
void set_parameters (const std::vector< double > &phi, const std::vector< double > &phipr)
 
void set_parameters (const double *phi, const double *phipr, const double *pomega)
 
void set_parameters (const std::vector< double > &phi, const std::vector< double > &phipr, const std::vector< double > &p_omega)
 
void set_parameter_verboselevel (const Bridge::VerboseLevel vl)
 
void get_parameters (Parameters &params) const
 
void upper (Field_G &, const Field_G &, const int, const int)
 
void lower (Field_G &, const Field_G &, const int, const int)
 
double plaq_s (const Field_G &)
 
double plaq_t (const Field_G &)
 
double plaq_t_ct (const Field_G &, const double ct)
 
double plaquette (const Field_G &)
 
double plaquette_ct (const Field_G &, const double ct)
 
double sf_coupling_plaq (const Field_G &, const double ct)
 
double sf_coupling_rect (const Field_G &, const double ctr)
 
void staple (Field_G &, const Field_G &, const int)
 
void staple_ct (Field_G &, const Field_G &, const int, const double ct)
 
void print_plaquette (const Field_G &)
 

Static Public Attributes

static const std::string class_name = "Staple_SF"
 

Protected Attributes

Bridge::VerboseLevel m_vl
 

Private Member Functions

 Staple_SF (const Staple_SF &)
 
Staple_SFoperator= (const Staple_SF &)
 

Private Attributes

Index_lex m_index
 
ShiftField_lex m_shift
 
Mat_SU_N m_wk
 
Mat_SU_N m_wkpr
 
Mat_SU_N m_i_omega0
 
int m_initialized
 
std::vector< double > m_phi
 
std::vector< double > m_phipr
 
std::vector< double > m_p_omega
 

Detailed Description

Staple construction.

Evaluate staple with SF BC.

  • The BC parameters phi, phipr are set into SU(3) matrix wk, wkpr for boundary spatial link variable.
  • [26 Jan. 2012 Y.Taniguchi]

(Coding history will be recovered from trac.) YAML is implemented. [14 Nov 2012 Y.Namekawa]

Definition at line 36 of file staple_SF.h.

Constructor & Destructor Documentation

◆ Staple_SF() [1/3]

Staple_SF::Staple_SF ( )
inline

Definition at line 54 of file staple_SF.h.

◆ Staple_SF() [2/3]

Staple_SF::Staple_SF ( const Parameters params)
inline

Definition at line 62 of file staple_SF.h.

◆ Staple_SF() [3/3]

Staple_SF::Staple_SF ( const Staple_SF )
private

Member Function Documentation

◆ get_parameters()

void Staple_SF::get_parameters ( Parameters params) const

Definition at line 61 of file staple_SF.cpp.

◆ lower()

void Staple_SF::lower ( Field_G c,
const Field_G U,
const int  mu,
const int  nu 
)

Definition at line 912 of file staple_SF.cpp.

◆ operator=()

Staple_SF& Staple_SF::operator= ( const Staple_SF )
private

◆ plaq_s()

double Staple_SF::plaq_s ( const Field_G U)

Evaluate summed spatial ReTr plaquette with SF BC.

  • Plaquette is NOT normalized at all.
  • Contribution from the spatial plaquettes at t=0 and t=T are not included since they are always unity.
  • The function upper(U,mu=k,nu) is modified to give zero.

Definition at line 652 of file staple_SF.cpp.

◆ plaq_t()

double Staple_SF::plaq_t ( const Field_G U)

Evaluate summed temporal ReTr plaquette with SF BC.

  • Plaquette is NOT normalized at all.
  • The temporal plaquettes attached to t=0 and t=T boundary are evaluated with Wk and Wk'.
  • The function lower(U,3,nu) is modified to use Wk and Wk'.

Definition at line 690 of file staple_SF.cpp.

◆ plaq_t_ct()

double Staple_SF::plaq_t_ct ( const Field_G U,
const double  ct 
)

Evaluate summed temporal ReTr plaquette with SF BC.

  • The temporal plaquette attached to the boundary is multiplied with ct.
         +---+
      ct |   |
     t=0 x---+
    
  • The temporal plaquettes attached to t=0 and t=T boundary are evaluated with Wk and Wk'.
  • The function lower(U,3,nu) is modified to use Wk and Wk'.
  • Plaquette is NOT normalized at all.

Definition at line 733 of file staple_SF.cpp.

◆ plaquette()

double Staple_SF::plaquette ( const Field_G U)

Evaluate summed ReTr plaquette with SF BC.

  • Plaquette is NOT normalized at all.
  • Contribution from the spatial plaquettes at t=0 and t=T are not included since they are always unity.

Definition at line 606 of file staple_SF.cpp.

◆ plaquette_ct()

double Staple_SF::plaquette_ct ( const Field_G U,
const double  ct 
)

Evaluate summed ReTr plaquette with SF BC.

  • The temporal plaquette attached to the boundary is multiplied with the improvement factor ct.
         +---+
      ct |   |
     t=0 x---+
    
  • Plaquette is NOT normalized at all.
  • Contribution from the spatial plaquettes at t=0 and t=T are not included since they are always unity.

Definition at line 632 of file staple_SF.cpp.

◆ print_plaquette()

void Staple_SF::print_plaquette ( const Field_G U)

Print out the plaquette for two definitions.

\[ \frac{1}{3}\frac{1}{6L_xL_yL_zL_t-3L_xL_yL_z}\sum_{p\notin{\rm boundary}}U_p \]

  • Contributions from the boundary spatial plaquettes is not included.
  • Normalized with the number of plaquettes Lx*Ly*Lz*(6Lt-3) and color factor 3.

\[ \frac{1}{3}\frac{1}{6L_xL_yL_zL_t}\sum_{p}U_p \]

  • Contributions from the boundary spatial plaquettes is included.
  • Normalized with the number of plaquettes 6*Lx*Ly*Lz*Lt and color factor 3.

Definition at line 966 of file staple_SF.cpp.

◆ set_parameter_verboselevel()

void Staple_SF::set_parameter_verboselevel ( const Bridge::VerboseLevel  vl)
inline

Definition at line 87 of file staple_SF.h.

◆ set_parameters() [1/4]

void Staple_SF::set_parameters ( const double *  phi,
const double *  phipr,
const double *  pomega 
)

◆ set_parameters() [2/4]

void Staple_SF::set_parameters ( const Parameters params)

Definition at line 35 of file staple_SF.cpp.

◆ set_parameters() [3/4]

void Staple_SF::set_parameters ( const std::vector< double > &  phi,
const std::vector< double > &  phipr 
)

Definition at line 139 of file staple_SF.cpp.

◆ set_parameters() [4/4]

void Staple_SF::set_parameters ( const std::vector< double > &  phi,
const std::vector< double > &  phipr,
const std::vector< double > &  p_omega 
)

Set the SF BC for wk, wkpr and omega0.

\[ U_k(x)|_{t=0}=W_k(\vec{x})=\exp\left(a C_k\right),\quad C_k=\frac{i}{L}\pmatrix{\phi_1\cr&\phi_2\cr&&\phi_3\cr}, \]

\[ U_k(x)|_{t=T}=W_k'(\vec{x})=\exp\left(a C_k'\right),\quad C_k'=\frac{i}{L}\pmatrix{\phi'_1\cr&\phi'_2\cr&&\phi'_3\cr}, \]

omega0 is set to the input value

\[ \verb|omega0|=i\Omega_0 \]

Definition at line 88 of file staple_SF.cpp.

◆ sf_coupling_plaq()

double Staple_SF::sf_coupling_plaq ( const Field_G U,
const double  ct 
)

Evaluate boudary plaqutte VEV for the SF coupling. The SF running coupling is defined as

\[ \frac{k}{\overline{g}^2}= \left\langle\frac{\partial S_g}{\partial\eta}\right\rangle +\left\langle\frac{\partial S_f}{\partial\eta}\right\rangle \]

\[ k=12\left(\frac{L}{a}\right)^2 \left(\sin\theta+\sin\left(2\theta\right)\right), \quad \theta=\frac{1}{3}\pi\left(\frac{a^2}{TL}\right) \]

\[ \frac{\partial S_g}{\partial\eta}= -\frac{2}{g_0^2}\sum_{\vec{x}} c_t\sum_{k=1}^{3}\frac{a}{L}{\rm Re\ }{\rm tr}\Bigl( i\Omega_0W_k(\vec{x})U_0(\vec{x}+\hat{k},0)U_k^\dagger(\vec{x},1) U_0^\dagger(\vec{x},0) -i\Omega_0W_k'U_0^\dagger(\vec{x}+\hat{k},T-1)U_k^\dagger(\vec{x},T-1) U_0(\vec{x},T-1) \Bigr) \]

\[ \frac{\partial S_g}{\partial\eta}= -\frac{2}{g_0^2}\sum_{\vec{x}} c_t\sum_{k=1}^{3}\frac{a}{L}{\rm Re\ }{\rm tr}\Bigl( i\Omega_0\verb|upper|(3,k)(\vec{x},0)U_0^\dagger(\vec{x},0) -i\Omega_0\verb|upper|(3,k)(\vec{x},T-1)^\dagger U_0(\vec{x},T-1) \Bigr) \]

  • Evaluete the following quantity and print the result

    \[ -c_t\sum_{\vec{x}}\sum_{k=1}^{3}\frac{a}{L}{\rm Re\ }{\rm tr}\Bigl( i\Omega_0\verb|upper|(3,k)(\vec{x},0)U_0^\dagger(\vec{x},0) -i\Omega_0\verb|upper|(3,k)(\vec{x},T-1)^\dagger U_0(\vec{x},T-1) \Bigr) \]

  • Clover term contribution $\partial S_f/\partial\eta$ is not evaluated here.

Definition at line 210 of file staple_SF.cpp.

◆ sf_coupling_rect()

double Staple_SF::sf_coupling_rect ( const Field_G U,
const double  ctr 
)

Evaluate the temporal rectangle VEV at the boundary for the SF running coupling.

The SF running coupling is given by

\[ \frac{k}{\overline{g}^2}= \left\langle\frac{\partial S_g^{\rm plaq}}{\partial\eta}\right\rangle +\left\langle\frac{\partial S_g^{\rm rect}}{\partial\eta}\right\rangle +\left\langle\frac{\partial S_f}{\partial\eta}\right\rangle \]

\[ \frac{\partial S_g}{\partial\eta}= -\frac{2}{g_0^2}c_1\sum_{\vec{x}}\sum_{k=1}^{3} \frac{ia}{L}{\rm Re}{\rm Tr}\Bigl( c_t^R\left( \Omega S_{kk0}(\vec{x},0) +\Omega S_{0kk}(\vec{x},0)\right) +\Omega S_{00k}(\vec{x},0) \Bigr) \]

\[ +\frac{2}{g_0^2}c_1\sum_{\vec{x}}\sum_{k=1}^{3} \frac{ia}{L}{\rm Re}{\rm Tr}\Bigl( c_t^R\left( \Omega'S_{kk0}(\vec{x},T) +\Omega'S_{0kk}(\vec{x},T)\right) +\Omega'S_{00k}(\vec{x},T) \Bigr) \]

\[ S_{kk0}(\vec{x},0)=W_kW_kU_0(\vec{x}+2\hat{k},0) U_k^\dagger(\vec{x}+\hat{k},1)U_k^\dagger(\vec{x},1)U_0^\dagger(\vec{x},0) \]

\[ S_{0kk}(\vec{x},0)=W_kU_0(\vec{x}+\hat{k},0)U_k^\dagger(\vec{x},1) U_k^\dagger(\vec{x}-\hat{k},1)U_0^\dagger(\vec{x}-\hat{k},0)W_k \]

\[ S_{00k}(\vec{x},0)=W_kU_0(\vec{x}+\hat{k},0)U_0(\vec{x}+\hat{k},1) U_k^\dagger(\vec{x},2)U_0^\dagger(\vec{x},1)U_0^\dagger(\vec{x},0) \]

\[ S_{kk0}(\vec{x},T)=W_k'W_k'U_0^\dagger(\vec{x}+2\hat{k},T) U_k^\dagger(\vec{x}+\hat{k},T-1)U_k^\dagger(\vec{x},T-1)U_0(\vec{x},T-1) \]

\[ S_{0kk}(\vec{x},T)=W_k'U_0^\dagger(\vec{x}+\hat{k},T-1) U_k^\dagger(\vec{x},T-1)U_k^\dagger(\vec{x}-\hat{k},T-1) U_0(\vec{x}-\hat{k},T-1)W_k' \]

\[ S_{00k}(\vec{x},T)=W_k'U_0^\dagger(\vec{x}+\hat{k},T-1) U_0^\dagger(\vec{x}+\hat{k},T-2)U_k^\dagger(\vec{x},T-2)U_0(\vec{x},T-2) U_0(\vec{x},T-1) \]

In this function we evaluate

\[ -\sum_{\vec{x}}\sum_{k=1}^{3} \frac{ia}{L}{\rm Re}{\rm Tr}\Bigl( c_t^R\left( \Omega S_{kk0}(\vec{x},0) +\Omega S_{0kk}(\vec{x},0)\right) +\Omega S_{00k}(\vec{x},0) \Bigr) \]

\[ +\sum_{\vec{x}}\sum_{k=1}^{3} \frac{ia}{L}{\rm Re}{\rm Tr}\Bigl( c_t^R\left( \Omega'S_{kk0}(\vec{x},T) +\Omega'S_{0kk}(\vec{x},T)\right) +\Omega'S_{00k}(\vec{x},T) \Bigr) \]

The following quantities are also printed out.

  rect01         rect02
      <---<---+      <---<---+
      |       |      |       |
  t=0 x--->---+  t=0 +---x---+
  omega0               omega0
  rectt1         rectt2
  omega0              omega0
 t=Nt x--->---+ t=Nt +---x---+
      |       |      |       |
      +---<---+      <---<---+
  rect03      rectt3
              omega0
      +---+  t=Nt x--->
      |   |       |   |
      v   ^       ^   v
      |   |       |   |
  t=0 x--->       +---+
   omega0

Definition at line 395 of file staple_SF.cpp.

◆ staple()

void Staple_SF::staple ( Field_G W,
const Field_G U,
const int  mu 
)

Evaluate staple for all the links in mu direction with SF BC.

   (1)  mu (2)
      +-->--+
   nu |     |
     i+     +
      +     +
   nu |     |
     i+-->--+
    (1)  mu (2)
  • We should notice that all the staple attached to the boundary spatial link is set to zero.
  • This staple at the boundary shall not be used since the corresponding force for the boundary spatial link is always set to zero.

Definition at line 788 of file staple_SF.cpp.

◆ staple_ct()

void Staple_SF::staple_ct ( Field_G W,
const Field_G U,
const int  mu,
const double  ct 
)

Evaluate staple for all the links in mu direction with SF BC and boundary improvement factor ct.

   (1)  mu (2)
      +-->--+
   nu |     |
     i+     +
      +     +
   nu |     |
     i+-->--+
    (1)  mu (2)
  • staple attached to spatial boundary link is set to zero.
  • contributions from the temporal plaquette attached to the boundary is multiplied with ct.

Definition at line 833 of file staple_SF.cpp.

◆ upper()

void Staple_SF::upper ( Field_G c,
const Field_G U,
const int  mu,
const int  nu 
)

Definition at line 877 of file staple_SF.cpp.

Member Data Documentation

◆ class_name

const std::string Staple_SF::class_name = "Staple_SF"
static

Set the SF BC for wk and wkpr.

\[ U_k(x)|_{t=0}=W_k(\vec{x})=\exp\left(a C_k\right),\quad C_k=\frac{i}{L}\pmatrix{\phi_1\cr&\phi_2\cr&&\phi_3\cr}, \]

\[ U_k(x)|_{t=T}=W_k'(\vec{x})=\exp\left(a C_k'\right),\quad C_k'=\frac{i}{L}\pmatrix{\phi'_1\cr&\phi'_2\cr&&\phi'_3\cr}, \]

omega0 is set to the default value

\[ \verb|iomega0|=i\Omega_0=i\pmatrix{1\cr&-\frac{1}{2}\cr&&-\frac{1}{2}\cr} \]

Definition at line 39 of file staple_SF.h.

◆ m_i_omega0

Mat_SU_N Staple_SF::m_i_omega0
private

Definition at line 48 of file staple_SF.h.

◆ m_index

Index_lex Staple_SF::m_index
private

Definition at line 45 of file staple_SF.h.

◆ m_initialized

int Staple_SF::m_initialized
private

Definition at line 49 of file staple_SF.h.

◆ m_p_omega

std::vector<double> Staple_SF::m_p_omega
private

Definition at line 51 of file staple_SF.h.

◆ m_phi

std::vector<double> Staple_SF::m_phi
private

Definition at line 51 of file staple_SF.h.

◆ m_phipr

std::vector<double> Staple_SF::m_phipr
private

Definition at line 51 of file staple_SF.h.

◆ m_shift

ShiftField_lex Staple_SF::m_shift
private

Definition at line 46 of file staple_SF.h.

◆ m_vl

Bridge::VerboseLevel Staple_SF::m_vl
protected

Definition at line 42 of file staple_SF.h.

◆ m_wk

Mat_SU_N Staple_SF::m_wk
private

Definition at line 48 of file staple_SF.h.

◆ m_wkpr

Mat_SU_N Staple_SF::m_wkpr
private

Definition at line 48 of file staple_SF.h.


The documentation for this class was generated from the following files: