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


C++ model::setParent方法代码示例

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


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

示例1: chain

void chain( model &M, int N)
{
	cout << "Creating a chain model" << endl;
	// make a chain model

	double m = 1.0; // mass of links
	double L = 1.0; // length of each chain link
	
	// define N, parent, pitch, Xtree, I
	M.setN(N);
	
	// deifne size
	if (N == 1)
	{
		M.setParent( zeros<irowvec>(1) );
	}
	else
	{
		M.setParent( linspace<irowvec>( 0, N-1, N) );
	}
	
	// define vector (3D pos) argument for xtree
	vec r = zeros<vec>(3);
	M.setXtree( 0, xlt(r) );

	// cdefine center of mass 3D pos vector
	vec com = zeros<vec>(3);
	com(0) = L/2.0;

	// define inertia
	vec inertia = m*pow(L,2)/12.0 * ones<vec>(3);
	inertia(0) = 0.01; // no thickness in this direction
	M.setI(0, mcI( m, com, diagmat(inertia)) );
		
	// RIGID BODY
	RBbox* box1 = new RBbox( m, L, L/5, L/5);

/*	char* torus = const_cast<char*>("torus.obj");
	RBobj* box1 = new RBobj( torus );
	box1->normalize();
*/
	M.setRB( 0, box1);

	r(0) = L; // for the rest of the links
	// fill in the fields
	for (int i = 1; i < N; i++)
	{
		M.setXtree( i, xlt(r) );
		M.setI( i, mcI( m, com, diagmat(inertia)) );
		M.setRB( i, box1);
	}
	
	// define pitch
	M.setPitch( 2*ones<rowvec>(N) );

}
开发者ID:chrisdembia,项目名称:feather,代码行数:56,代码来源:main.cpp

示例2: chain3DOF2

void chain3DOF2( model &M, int nlinks)
{
	cout << "Creating a chain3DOF2 model" << endl;
	// make a chain model

	double m = 0.0; // mass of links
	double L = 1.0; // length of each chain link
	
	int N = 3*nlinks;
	
	// define N, parent, pitch, Xtree, I
	M.setN(N);
	
	// deifne size
	M.setParent( linspace<irowvec>( 0, N-1, N) );
	
	// define vector (3D pos) argument for xtree
	vec com;
	vec inertia;

	RBbox* box1 = new RBbox( m, L, L/5, L/5);
	RBnull* null1 = new RBnull();

	M.setXtree(0,  xlt( zeros<vec>(3) ) );
	vec r(3);
	r(0) = L;
	
	for (int i = 0; i < N-2; i+=3)
	{
		if ( i != 0 )
		{
				M.setXtree(0+i,  xlt( r ) );
		}
		M.setXtree(1+i, xlt( zeros<vec>(3) ) );
		M.setXtree(2+i, xlt( zeros<vec>(3) ) );
		//
		m = 0.0;
		com = zeros<vec>(3);
		inertia = zeros<vec>(3);
		M.setI(0+i, mcI( m, com, diagmat(inertia)) );
		M.setI(1+i, mcI( m, com, diagmat(inertia)) );
		
		com(0) = L/2.0;	m = 1.0;
		inertia = m*pow(L,2)/12.0 * ones<vec>(3); inertia(0) = 0.01;
		M.setI(2+i, mcI( m, com, diagmat(inertia)) );	
		//
		M.setRB( 0+i, null1);
		M.setRB( 1+i, null1);
		M.setRB( 2+i, box1);
		
		M.setPitch(i+0, 0);			
		M.setPitch(i+1, 1);			
		M.setPitch(i+2, 2);			
	}
	// define pitch

}
开发者ID:chrisdembia,项目名称:feather,代码行数:57,代码来源:main.cpp

示例3: chain3DOF

void chain3DOF( model &M)
{
	cout << "Creating a chain3DOF model" << endl;
	// make a chain model

	double m = 0.0; // mass of links
	double L = 1.0; // length of each chain link
	
	int N = 3;
	
	// define N, parent, pitch, Xtree, I
	M.setN(N);
	
	// deifne size
	M.setParent( linspace<irowvec>( 0, N-1, N) );
	
	// define vector (3D pos) argument for xtree
	M.setXtree(0,  xlt( zeros<vec>(3) ) );
	M.setXtree(1, rotx( -math::pi()/2 ) );
	M.setXtree(2, roty( math::pi()/2 ) );

	// cdefine center of mass 3D pos vector
	vec com = zeros<vec>(3);

	vec inertia = zeros<vec>(3);
	
	M.setI(0, mcI( m, com, diagmat(inertia)) );
	M.setI(1, mcI( m, com, diagmat(inertia)) );

	com(0) = L/2.0;

	m = 1.0;
	
	// define inertia
	inertia = m*pow(L,2)/12.0 * ones<vec>(3);
	inertia(0) = 0.01; // no thickness in this direction
	M.setI(2, mcI( m, com, diagmat(inertia)) );
		
	// RIGID BODY
	RBbox* box1 = new RBbox( m, L, L/5, L/5);
	RBnull* null1 = new RBnull();
	
	M.setRB( 0, null1);
	M.setRB( 1, null1);
	M.setRB( 2, box1);
	
	// define pitch
	M.setPitch( 2*ones<rowvec>(N) );

/*
	M.setXtree(0, xlt(zeros<vec>(3)));
	M.setXtree(1, rotx( math::pi()/2) );
	M.setXtree(2, roty( math::pi()/2) );
*/
	

}
开发者ID:chrisdembia,项目名称:feather,代码行数:57,代码来源:main.cpp

示例4: chainrot

void chainrot( model &M, int nlinks)
{
	cout << "Creating a chainrot model" << endl;
	// make a chain model

	int N = nlinks + 1;
	
	double m = 1.0; // mass of links
	double L = 1.0; // length of each chain link
	
	// define N, parent, pitch, Xtree, I
	M.setN(N);
	
	// deifne size
	M.setParent( linspace<irowvec>( 0, N-1, N) );
	
	// define vector (3D pos) argument for xtree
	vec r = zeros<vec>(3);
	// RIGID BODY
	RBnull* null1 = new RBnull();
	RBbox* box1 = new RBbox( m, L, L/6, L/6);
	
	// cdefine center of mass 3D pos vector
	vec com = zeros<vec>(3);
	com(0) = L/2.0;

	// define inertia
	vec inertia = m*pow(L,2)/12.0 * ones<vec>(3);
	inertia(0) = 0.01; // no thickness in this direction
	
	M.setXtree( 0, xlt(r) );
	M.setI(0, mcI( 0, zeros<vec>(3), diagmat(zeros<vec>(3) ) ) );
	M.setRB( 0, null1);
		
	M.setXtree( 1, xlt(r) );
	M.setI(1, mcI( m, com, diagmat(inertia)) );
	M.setRB( 1, box1);

	r(0) = L; // for the rest of the links
	// fill in the fields
	for (int i = 2; i < N; i++)
	{
		M.setXtree( i, xlt(r) );
		M.setI( i, mcI( m, com, diagmat(inertia)) );
		M.setRB( i, box1);
	}
	
	// define pitch
	rowvec pitch = 2*ones<rowvec>(N);
	pitch(0) = 1;
	M.setPitch( pitch );

}
开发者ID:chrisdembia,项目名称:feather,代码行数:53,代码来源:main.cpp


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