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


C++ TMatrixD::Use方法代码示例

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


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

示例1: swap_x_y

void leptonic_fitter_algebraic::swap_x_y( const TMatrixD& in, TMatrixD& out )
{
  if( in.GetNoElements() != 9 ) 
    throw std::runtime_error( "ERROR! leptonic_fitter_algebraic::swap_x_y handles only 3 by 3 matrices");

  if( &in == &out )
    throw std::runtime_error( "ERROR! leptonic_fitter_algebraic::swap_x_y needs different in and out objects");

  static int remap[ 9 ]={ 4, 3, 5,   1, 0, 2,  7, 6, 8 };
  static double vec_out[9];

  const double *vec_in = in.GetMatrixArray();
  for( int ic=0;ic<9;++ic ) vec_out[ ic ] = vec_in[ remap[ ic ] ];
  out.Use( 3, 3, vec_out );
}
开发者ID:aharel,项目名称:rocfit,代码行数:15,代码来源:leptonic_fitter_algebraic.c

示例2: rotation

TMatrixD leptonic_fitter_algebraic::rotation( int axis, double cos, double sin )
{
  assert( axis >= 0 );
  static double elem[9];
  for( int ix=0; ix < 3; ++ix ) {
    for( int iy=0; iy < 3; ++iy ) {
      elem[ 3*ix + iy ] = ( ix == iy ) ? cos : 0;
    }
  }
  elem[ 3*((axis+1)%3)+(axis+2)%3 ] = -sin;
  elem[ 3*((axis+2)%3)+(axis+1)%3 ] = sin;
  elem[ 4*(axis%3) ] = 1.;
  TMatrixD out;
  out.Use( 3, 3, elem );
  return out;
}
开发者ID:aharel,项目名称:rocfit,代码行数:16,代码来源:leptonic_fitter_algebraic.c


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