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


C++ options::Multipliers方法代码示例

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


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

示例1: BackwardSweep

void BackwardSweep(options & nominal){

	double x, y, z, xdot, ydot, zdot;
	double xf, yf, zf, xdotf, ydotf, zdotf;
	double l0, l1, l2, l3, l4, l5;

	// Extract some information
	x = nominal.traj[nominal.nstages][1];
	y = nominal.traj[nominal.nstages][2];
	z = nominal.traj[nominal.nstages][3];
	xdot = nominal.traj[nominal.nstages][4];
	ydot = nominal.traj[nominal.nstages][5];
	zdot = nominal.traj[nominal.nstages][6];

	xf = nominal.r_target[0];
	yf = nominal.r_target[1];
	zf = nominal.r_target[2];
	xdotf = nominal.v_target[0];
	ydotf = nominal.v_target[1];
	zdotf = nominal.v_target[2];

	l0 = nominal.Multipliers(0);
	l1 = nominal.Multipliers(1);
	l2 = nominal.Multipliers(2);
	l3 = nominal.Multipliers(3);
	l4 = nominal.Multipliers(4);
	l5 = nominal.Multipliers(5);

	// Compute Terminal Cost Derivatives
	Matrix<double> Vl(6, 1), Vll(6, 6, 0.0), Vx(7, 1), Vxx(7, 7, 0.0), Vxl(7, 6);

	Vl(0,0) = pow(x - xf, 2.0);
	Vl(1,0) = pow(y - yf, 2.0);
	Vl(2,0) = pow(z - zf, 2.0);
	Vl(3,0) = pow(xdot - xdotf, 2.0);
	Vl(4,0) = pow(ydot - ydotf, 2.0);
	Vl(5,0) = pow(zdot - zdotf, 2.0);

	Vx(0,0) = l0*(x*2.0 - xf*2.0);
	Vx(1,0) = l1*(y*2.0 - yf*2.0);
	Vx(2,0) = l2*(z*2.0 - zf*2.0);
	Vx(3,0) = l3*(xdot*2.0 - xdotf*2.0);
	Vx(4,0) = l4*(ydot*2.0 - ydotf*2.0);
	Vx(5,0) = l5*(zdot*2.0 - zdotf*2.0);
	Vx(6,0) = -1.0*nominal.s;

	Vxx(0,0) = l0*2.0;
	Vxx(1,1) = l1*2.0;
	Vxx(2,2) = l2*2.0;
	Vxx(3,3) = l3*2.0;
	Vxx(4,4) = l4*2.0;
	Vxx(5,5) = l5*2.0;

	Vxl(0,0) = x*2.0 - xf*2.0;
	Vxl(1,1) = y*2.0 - yf*2.0;
	Vxl(2,2) = z*2.0 - zf*2.0;
	Vxl(3,3) = xdot*2.0 - xdotf*2.0;
	Vxl(4,4) = ydot*2.0 - ydotf*2.0;
	Vxl(5,5) = zdot*2.0 - zdotf*2.0;
	
	// Start Sweeping
	Matrix<double> lx(7, 1), lxx(7,7), lu(3, 1), luu(3,3), lux(3, 7);
	nominal.ER = 0.0;
	for (int stage = nominal.nstages - 1; stage >= 0; stage--){
		Matrix<double> identity(3, 3), G, K, A, B, C;

		// Stage Cost Derivatives
		lx = 0.0;
		lxx = 0.0;
		lux = 0.0;
		lu = 0.0;
		luu = 0.0;

		Matrix<double> u_stage(3, 1);
		u_stage(0, 0) = nominal.traj[stage][8];
		u_stage(1, 0) = nominal.traj[stage][9];
		u_stage(2, 0) = nominal.traj[stage][10];
		/*
		for (int i = 0; i < 3; i++){
			lu(0, i) = .01*nominal.delta_u[stage](i,0);
			luu(i, i) = .01*1.0;
		}
		*/
		// Partition the STM
		Matrix<double> STM = nominal.STMs[stage];
		Matrix<double> STMx(7,7), STMu(7,3);

		for (int i = 0; i < 7; i++)
			for (int j = 0; j < 7; j++)
				STMx(i, j) = STM(i, j);

		for (int i = 0; i < 7; i++)
			for (int j = 0; j < 3; j++)
				STMu(i, j) = STM(i, 7 + j);

		// Partition the STT
		vector< Matrix<double> > STT, STTxx(7, Matrix<double>(7, 7)), STTuu(3, Matrix<double>(7, 3)), STTux(7, Matrix<double>(7, 3));
		
		for (int i = 0; i < 10; i++)
			STT.push_back(nominal.STTs[stage + i]);
//.........这里部分代码省略.........
开发者ID:jdaziz,项目名称:DDP,代码行数:101,代码来源:BackwardSweep+(Jonathan-Laptop's+conflicted+copy+2015-06-02).cpp


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