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


C++ arr::setDiag方法代码示例

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


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

示例1: fs

 virtual double fs(arr& g, arr& H, const arr& x) {
   double f=exp(-sumOfSqr(x));
   if(&g) g=2.*f*x;
   if(&H) { H.setDiag(2.*f, x.N); H -= 4.*f*(x^x); }
   f = 1.-f;
   return f;
 }
开发者ID:ipa-nhg,项目名称:kukadu,代码行数:7,代码来源:benchmarks.cpp

示例2: getCosts

real SocSystem_Analytical::getCosts(arr& R,arr& r,uint t,const arr& qt){
  uint N=x.N;
  R.resize(N,N); R.setZero();
  r.resize(N);   r.setZero();
  real C=0.;
  
#ifndef USE_TRUNCATION //potentials for collision cost
  arr J(1,qt.N),phiHatQ(1);
  J.setZero();
  phiHatQ.setZero();
  for(uint i=0;i<obstacles.d0;i++){
    real margin = .1;
    real d = (1.-norm(x-obstacles[i])/margin);
    if(d<0) continue;
    phiHatQ(0) += d*d;
    J += ((real)2.*d/margin)*(obstacles[i]-x)/norm(x-obstacles[i]);
  }
  J.reshape(1,J.N);
  arr tJ,target(1);
  target=(real)0.;
  transpose(tJ,J);
  real colprec = (real)5e2;
  C += colprec*sqrDistance(target,phiHatQ);
  R += colprec*tJ*J;
  r += colprec*tJ*(target - phiHatQ + J*qt);
#endif
  
  if(t!=T-1) return C;
  R.setDiag(1.);
  r = x1;
  R *= prec;
  r *= prec;
  C += prec*sqrDistance(x1,x);
  return C;
}
开发者ID:wensun,项目名称:probCollision,代码行数:35,代码来源:soc_system_analytical.cpp

示例3: initKinematic

 //initialization methods
 void initKinematic(uint dim,uint trajectory_length, real w, real endPrec){
   x0.resize(dim); x0.setZero();
   x1=x0; x1(0)=1.;
   x=x0;
   W.setDiag(w,x.N);
   prec=endPrec;
   T=trajectory_length;
   obstacles.resize(2,x.N);
   obstacles(0,0)=.3; obstacles(0,1)=.05;
   obstacles(1,0)=.7; obstacles(1,1)=-.05;
   dynamic=false;
   //os = &cout;
 }
开发者ID:wensun,项目名称:probCollision,代码行数:14,代码来源:soc_system_analytical.cpp

示例4: getProcess

void SocSystem_Analytical::getProcess(arr& A,arr& a,arr& B){
  uint N=x.N;
  A.setDiag(1.,N);
  B.setDiag(1.,N);
  a.resize(N); a.setZero();
}
开发者ID:wensun,项目名称:probCollision,代码行数:6,代码来源:soc_system_analytical.cpp


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