当前位置: 首页>>代码示例>>C++>>正文


C++ Matrix::DotMPlus方法代码示例

本文整理汇总了C++中Matrix::DotMPlus方法的典型用法代码示例。如果您正苦于以下问题:C++ Matrix::DotMPlus方法的具体用法?C++ Matrix::DotMPlus怎么用?C++ Matrix::DotMPlus使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在Matrix的用法示例。


在下文中一共展示了Matrix::DotMPlus方法的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: GforceSite

//------------------------------------------------------------------------------
// GforceSite(Matrix& force, int *x, int mu):
// It calculates the gauge force at site x and direction mu.
//------------------------------------------------------------------------------
void GimprRect::GforceSite(Matrix& force, int *x, int mu)
{
  const char *fname = "GforceSite(M&,i*,i)";
  setCbufCntrlReg(4, CBUF_MODE4);

  Matrix *u_off = GaugeField()+GsiteOffset(x)+mu;

  Matrix mt1;
  //----------------------------------------------------------------------------
  //  get staple
  //     mt1 = staple
  //----------------------------------------------------------------------------
  Staple(mt1, x, mu);	
  ForceFlops += 198*3*3+12+216*3;

  //----------------------------------------------------------------------------
  // mt2 = U_mu(x)
  //----------------------------------------------------------------------------
  Matrix mt2(*u_off);
  // moveMem((IFloat *)mp2, (IFloat *)u_off, MATRIX_SIZE * sizeof(IFloat)) ;

  //----------------------------------------------------------------------------
  // force = -(beta*(1-8*c_1)/3)*U_mu(x)*stap
  //----------------------------------------------------------------------------
  force.DotMEqual(mt2, mt1);
  force *= plaq_coeff;
  // mDotMEqual((IFloat *)&force, (const IFloat *)mp2, (const IFloat *)mp1);
  // tmp = plaq_coeff ;
  // vecTimesEquFloat((IFloat *)&force, tmp, MATRIX_SIZE);

  //----------------------------------------------------------------------------
  //  get rectangle staple
  //     mt1 = rect_stap
  //----------------------------------------------------------------------------
  RectStaple(mt1, x, mu);
  ForceFlops += 198*3*18+216*3*6;

  //----------------------------------------------------------------------------
  // mt2 = -(beta*c_1/3)*U_mu(x)
  //----------------------------------------------------------------------------
  // mt2 = *u_off;
  // moveMem((IFloat *)mp2, (IFloat *)u_off, MATRIX_SIZE*sizeof(IFloat));

  mt2 *= rect_coeff;
  // tmp = rect_coeff;
  // vecTimesEquFloat((IFloat *)mp2, tmp, MATRIX_SIZE) ;
  ForceFlops +=234;

  //----------------------------------------------------------------------------
  // force += -(beta*c_1/3)*U_mu(x)*rect_stap
  //----------------------------------------------------------------------------
  force.DotMPlus(mt2, mt1); 
  // mDotMPlus((IFloat *)&force, (const IFloat *)mp2, (const IFloat *)mp1);

  mt1.Dagger(force);
  force.TrLessAntiHermMatrix(mt1);
  ForceFlops +=198+24;
}
开发者ID:DeanHowarth,项目名称:QUDA-CPS,代码行数:62,代码来源:g_impr_rect.C

示例2: MkTop

Complex MkTop( Matrix plaqs1[], Matrix plaqs2[] )
{
  const Float nfactor(-1.0/( 4 * 3.141592654 * 3.141592654 ));

  Matrix Top;

  // negative weight

  Top.DotMEqual( plaqs1[1] , plaqs2[4] );
  
  Top *= -1.0 ;
  // positive weight 
  
  Top.DotMPlus ( plaqs1[2] , plaqs2[3] );
  Top.DotMPlus ( plaqs1[5] , plaqs2[0] );
  
  return nfactor*Top.Tr();
}
开发者ID:DeanHowarth,项目名称:QUDA-CPS,代码行数:18,代码来源:alg_tcharge.C

示例3: GetLink

//--------------------------------------------------------------------------
// void 
// DiracOpClover::SiteFuv(Matrix &Fuv, const int *site, int mu, int nu) const
//--------------------------------------------------------------------------
// Purpose: 
//    calculate F(x, u, v) = 1/4 1/2 (PLAQs - PLAQs^dag)
// where PLAQs are:
//    U_mu(x) U_nu(x+mu) U_mu(x+nu)^dag U_nu(x)^dag +
//    U_nu(x) U_mu(x-mu+nu)^dag U_nu(x-mu)^dag U_mu(x-mu) +
//    U_mu(x-mu)^dag U_nu(x-mu-nu)^dag U_mu(x-mu-nu) U_nu(x-nu) +
//    U_nu(x-nu)^dag U_mu(x-nu) U_nu(x+mu-nu) U_mu(x)^dag
// Note:
//  1. We adopt same definition of clover term as in Xiang-Qian Luo's paper,
//     But slightly different notation:
//        Fuv (here) / i = Fuv (Luo)
//  2. MATRIX STORAGE CONVENTION:
//     2.1. All the comments in this functions choose the canonical
//          convention, that is IFloat[row][col][2].
//     2.2. Fuv returned in the canonical convention.
//     2.3. GetLink(..) gives links in the wilson order, that is
//          IFloat[col][row][2].
//     2.4. In order to use the matrix utilities in the system, 
//          we have to change the formulae into:
//            F(x, u, v) = 1/4 1/2 (NewPLAQs - NewPLAQs^dag)^Transpose
//          where NewPLAQs are
//           [ U_mu(x) U_nu(x+mu) U_mu(x+nu)^dag U_nu(x)^dag +
//             U_nu(x) U_mu(x-mu+nu)^dag U_nu(x-mu)^dag U_mu(x-mu) +
//             U_mu(x-mu)^dag U_nu(x-mu-nu)^dag U_mu(x-mu-nu) U_nu(x-nu) +
//             U_nu(x-nu)^dag U_mu(x-nu) U_nu(x+mu-nu) U_mu(x)^dag 
//           ] ^Transpose
//  3. site[] has to be a legal site, and should not be off-node which is OK
//     only in calling GetLink.
//--------------------------------------------------------------------------
void 
DiracOpClover::SiteFuv(Matrix &Fuv, const int *site, int mu, int nu) const
{
  //  char *fname = "SiteFuv()";
  //  VRB.Func(cname,fname);

  // neighbour[] is the local coordinates of a neighbour site
  //------------------------------------------------------------------------
  int neighbor[4] = {site[0], site[1], site[2], site[3]};
  
  // mp0 = [ U_mu(x) U_nu(x+mu) ] ^Transpose
  //------------------------------------------------------------------------
  ++(neighbor[mu]);                               // neighbor = x+mu
  mp0->DotMEqual(GetLink(neighbor, nu), GetLink(site, mu));
 
  // mp1 = [ U_mu(x+nu)^dag U_nu(x)^dag ] ^Transpose
  //------------------------------------------------------------------------
  --(neighbor[mu]);  
  ++(neighbor[nu]);                               // neighbor = x+nu
  mp2->DotMEqual(GetLink(neighbor, mu), GetLink(site, nu));
  mp1->Dagger(*mp2);  
 
  // Fuv = [ U_mu(x) U_nu(x+mu) U_mu(x+nu)^dag U_nu(x)^dag ] ^Transpose
  //------------------------------------------------------------------------
  Fuv.DotMEqual(*mp1, *mp0);
   
  // mp0 = [ U_nu(x) U_mu(x-mu+nu)^dag ] ^Transpose
  //------------------------------------------------------------------------
  --(neighbor[mu]);                             // neighbor = x-mu+nu
  mp2->Dagger(GetLink(neighbor, mu));
  mp0->DotMEqual(*mp2, GetLink(site, nu));
  
  // mp1 = [ U_nu(x-mu)^dag U_mu(x-mu) ] ^Transpose
  //------------------------------------------------------------------------
  --(neighbor[nu]);                             // neighbor = x-mu
  mp2->Dagger(GetLink(neighbor, nu));
  mp1->DotMEqual(GetLink(neighbor, mu), *mp2);
 
  // Fuv += [ U_nu(x) U_mu(x-mu+nu)^dag U_nu(x-mu)^dag U_mu(x-mu) ] ^Trans
  //------------------------------------------------------------------------
  Fuv.DotMPlus(*mp1, *mp0);

  // mp0 = [ U_mu(x-mu)^dag U_nu(x-mu-nu)^dag ] ^Trans
  //------------------------------------------------------------------------
  mp1->Dagger(GetLink(neighbor, mu));
  --(neighbor[nu]);                             // neighbor = x-mu-nu
  mp2->Dagger(GetLink(neighbor, nu));
  mp0->DotMEqual(*mp2, *mp1);
  
  // mp1 = [ U_mu(x-mu-nu) U_nu(x-nu) ] ^Transpose
  //------------------------------------------------------------------------
  *mp2 = GetLink(neighbor, mu);
  ++(neighbor[mu]);                             // neighbor = x-nu
  mp1->DotMEqual(GetLink(neighbor, nu), *mp2);
  
  // Fuv += [ U_mu(x-mu)^dag U_nu(x-mu-nu)^dag U_mu(x-mu-nu) U_nu(x-nu) ] ^T
  //------------------------------------------------------------------------
  Fuv.DotMPlus(*mp1, *mp0);
 
  // mp0 = [ U_nu(x-nu)^dag U_mu(x-nu) ] ^Transpose
  //------------------------------------------------------------------------
  mp2->Dagger(GetLink(neighbor, nu));
  mp0->DotMEqual(GetLink(neighbor, mu), *mp2);
 
  // mp1 = [ U_nu(x+mu-nu) U_mu(x)^dag ] ^Transpose
  //------------------------------------------------------------------------
  mp2->Dagger(GetLink(site, mu));
//.........这里部分代码省略.........
开发者ID:DeanHowarth,项目名称:QUDA-CPS,代码行数:101,代码来源:d_op_clover_supp.C


注:本文中的Matrix::DotMPlus方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。