亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? rigidbody2d.cpp

?? 通過人工智能算法快速實現(xiàn)神經(jīng)網(wǎng)絡(luò)識別
?? CPP
字號:
#include "RigidBody2D.h"

RigidBody2D::RigidBody2D(void)
{
	
	
}

void	RigidBody2D::CalcLoads(void)
{
	Vector	Fb;				// stores the sum of forces
	Vector	Mb;				// stores the sum of moments
	Vector	Thrust;			// thrust vector
	
	// reset forces and moments:
	vForces.x = 0.0f;
	vForces.y = 0.0f;
	vForces.z = 0.0f;	// always zero in 2D

	vMoment.x = 0.0f;	// always zero in 2D
	vMoment.y = 0.0f;	// always zero in 2D
	vMoment.z = 0.0f;

	Fb.x = 0.0f;	
	Fb.y = 0.0f;	
	Fb.z = 0.0f;	

	Mb.x = 0.0f;
	Mb.y = 0.0f;
	Mb.z = 0.0f;

	// Define the thrust vector, which acts through the craft's CG
	Thrust.x = 0.0f;
	Thrust.y = 1.0f;
	Thrust.z = 0.0f;  // zero in 2D
	Thrust *= ThrustForce;
	
	// Calculate forces and moments in body space:
	Vector	vLocalVelocity;
	float	fLocalSpeed;
	Vector	vDragVector;	
	float	tmp;
	Vector	vResultant;	
	Vector	vtmp;	

	// Calculate the aerodynamic drag force:
		// Calculate local velocity:
		// The local velocity includes the velocity due to linear motion of the craft, 
		// plus the velocity at each element due to the rotation of the craft.
		vtmp = vAngularVelocity^CD; // rotational part
		vLocalVelocity = vVelocityBody + vtmp; 

		// Calculate local air speed
		fLocalSpeed = vLocalVelocity.Magnitude();

		// Find the direction in which drag will act.
		// Drag always acts inline with the relative velocity but in the opposing direction
		if(fLocalSpeed > tol) 
		{
			vLocalVelocity.Normalize();
			vDragVector = -vLocalVelocity;		

			// Determine the resultant force on the element.
			double f;
			if((Thrust * vLocalVelocity)/(Thrust.Magnitude() * vLocalVelocity.Magnitude()) > 0)
				f = 2;	
			else
				f = 1;

			tmp = 0.5f * rho * fLocalSpeed*fLocalSpeed * ProjectedArea * f;		
			vResultant = vDragVector * _LINEARDRAGCOEFFICIENT * tmp; // simulate fuselage drag

			// Keep a running total of these resultant forces (total force)
			Fb += vResultant;
		
			// Calculate the moment about the CG of this element's force
			// and keep a running total of these moments (total moment)
			vtmp = CD^vResultant; 
			Mb += vtmp;
		}

		// Calculate the Port & Starboard bow thruster forces:
		// Keep a running total of these resultant forces (total force)
		Fb += 3*PThrust;
		

		// Calculate the moment about the CG of this element's force
		// and keep a running total of these moments (total moment)
		vtmp = CPT^PThrust; 
		Mb += vtmp;

		// Keep a running total of these resultant forces (total force)
		Fb += 3*SThrust;

		// Calculate the moment about the CG of this element's force
		// and keep a running total of these moments (total moment)
		vtmp = CST^SThrust; 		
		Mb += vtmp;

		// do other applied forces here
		Fb += Fa;
		vtmp = Pa ^ Fa;
		Mb += vtmp;

		// Calculate rotational drag
		if(vAngularVelocity.Magnitude() > tol)
		{
			vtmp.x = 0;
			vtmp.y = 0;
			tmp = 0.5f * rho * vAngularVelocity.z*vAngularVelocity.z * ProjectedArea;
			if(vAngularVelocity.z > 0.0)
				vtmp.z = -_ANGULARDRAGCOEFFICIENT * tmp;		
			else
				vtmp.z = _ANGULARDRAGCOEFFICIENT * tmp;		

			Mb += vtmp;
		}


	// Now add the propulsion thrust
	Fb += Thrust; // no moment since line of action is through CG

	// Convert forces from model space to earth space
	vForces = VRotate2D(fOrientation, Fb);

	vMoment += Mb;
	
	
}

void	RigidBody2D::UpdateBodyEuler(double dt)
{
		Vector a;
		Vector dv;
		Vector ds;
		float  aa;
		float  dav;
		float  dr;
	
		// Calculate forces and moments:
		CalcLoads();
		
		// Integrate linear equation of motion:
		a = vForces / fMass;
		
		dv = a * dt;
		vVelocity += dv;

		ds = vVelocity * dt;
		vPosition += ds;

		// Integrate angular equation of motion:
		aa = vMoment.z / fInertia;

		dav = aa * dt;
		
		vAngularVelocity.z += dav;
		
		dr = RadiansToDegrees(vAngularVelocity.z * dt);
		fOrientation += dr; 
		
		// Misc. calculations:
		fSpeed = vVelocity.Magnitude();		
		vVelocityBody = VRotate2D(-fOrientation, vVelocity);	
}

void	RigidBody2D::SetThrusters(bool p, bool s, double f)
{
	PThrust.x = 0;
	PThrust.y = 0;
	SThrust.x = 0;
	SThrust.y = 0;
	
	if(p)
		PThrust.x = -_STEERINGFORCE * f;
	if(s)
		SThrust.x = _STEERINGFORCE * f;
}


Vector	VRotate2D( float angle, Vector u)
{
	float	x,y;

	x = u.x * cos(DegreesToRadians(-angle)) + u.y * sin(DegreesToRadians(-angle));
	y = -u.x * sin(DegreesToRadians(-angle)) + u.y * cos(DegreesToRadians(-angle));

	return Vector( x, y, 0);
}

void	RigidBody2D::ModulateThrust(bool up)
{
	double	dT = up ? _DTHRUST:-_DTHRUST;

	ThrustForce += dT;

	if(ThrustForce > _MAXTHRUST) ThrustForce = _MAXTHRUST;
	if(ThrustForce < _MINTHRUST) ThrustForce = _MINTHRUST;
}



?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
秋霞影院一区二区| 中文字幕国产一区二区| 8v天堂国产在线一区二区| 久久影音资源网| 亚洲va国产va欧美va观看| 国产资源精品在线观看| 国产精品福利av| 日本中文字幕一区| 97久久精品人人澡人人爽| 欧美一卡2卡三卡4卡5免费| 18欧美乱大交hd1984| 国产一区三区三区| 欧美剧情片在线观看| 亚洲色图欧美激情| 国产精品456| 日韩美女视频一区二区在线观看| 亚洲日本一区二区| 欧美男生操女生| 中文字幕一区二区三区av| 国产一区三区三区| 欧美电视剧在线观看完整版| 亚洲猫色日本管| www.欧美亚洲| 中文字幕一区二区在线播放| 国产成人av电影在线| 日韩欧美一级二级| 美女爽到高潮91| 日韩欧美资源站| 麻豆freexxxx性91精品| 欧美美女一区二区在线观看| 亚洲国产三级在线| 欧美日韩免费高清一区色橹橹| 自拍av一区二区三区| av电影天堂一区二区在线| 中文字幕制服丝袜一区二区三区 | 91在线观看视频| 国产精品卡一卡二卡三| 99久久免费视频.com| 国产精品国产精品国产专区不蜜 | 国产人成一区二区三区影院| 久久精品国产免费| 欧美精品一区二区三区在线| 国产尤物一区二区| 男人的天堂久久精品| 欧美一区二视频| 老司机精品视频导航| 国产无人区一区二区三区| 懂色av中文一区二区三区| 中文字幕一区二区不卡| 欧美性一二三区| 蜜桃视频在线观看一区| 久久久久久久国产精品影院| 成人免费高清视频在线观看| 亚洲欧美另类综合偷拍| 高清不卡一区二区| 狠狠色狠狠色合久久伊人| 日韩午夜激情av| 国产精品99久久不卡二区| 国产精品免费观看视频| 欧美亚洲另类激情小说| 蜜臀av一级做a爰片久久| 国产偷v国产偷v亚洲高清| 97久久精品人人做人人爽| 性做久久久久久免费观看欧美| 日韩欧美亚洲一区二区| aaa亚洲精品| 日本美女一区二区| 国产精品卡一卡二卡三| 欧美久久一区二区| 国产91色综合久久免费分享| 亚洲国产cao| 国产亚洲欧美激情| 欧美老肥妇做.爰bbww视频| 欧美亚日韩国产aⅴ精品中极品| 蜜臀av亚洲一区中文字幕| 日韩美女精品在线| 日韩一级完整毛片| 欧美日韩一区二区三区免费看| 午夜视频在线观看一区| 欧美精品一区二区三区在线播放| 91美女福利视频| 韩国一区二区视频| 亚洲国产综合91精品麻豆| 久久嫩草精品久久久精品一| 欧美日韩亚洲综合在线| 国产成人综合自拍| 日韩一区精品字幕| 亚洲欧美日韩在线不卡| 国产视频一区二区在线观看| 欧美三级日韩在线| 91在线观看污| 国产福利精品一区| 老司机午夜精品| 日韩精品电影一区亚洲| 一区二区三区蜜桃网| 国产欧美一区视频| 26uuu另类欧美| 日韩三级中文字幕| 欧美这里有精品| 99久久综合99久久综合网站| 国产毛片精品国产一区二区三区| 色综合天天性综合| 国产精品一卡二卡在线观看| 日本最新不卡在线| 视频一区二区三区入口| 亚洲综合一区在线| 亚洲免费在线观看| 亚洲日本丝袜连裤袜办公室| 国产精品丝袜在线| 国产欧美日韩另类一区| 国产午夜亚洲精品理论片色戒| 精品国产一区二区三区不卡| 日韩欧美成人激情| 日韩免费高清av| 精品盗摄一区二区三区| 日韩免费成人网| 久久婷婷成人综合色| 精品国产三级a在线观看| 欧美大白屁股肥臀xxxxxx| 欧美一区二区在线免费播放| 91精品国产美女浴室洗澡无遮挡| 欧美日韩五月天| 欧美卡1卡2卡| 日韩欧美国产wwwww| 欧美精品一区二区久久婷婷| 久久综合色8888| 国产婷婷色一区二区三区四区| 国产欧美一区二区精品婷婷| 国产精品久久久久久久久免费樱桃 | 一个色妞综合视频在线观看| 一区二区理论电影在线观看| 亚洲一区二区美女| 婷婷六月综合亚洲| 捆绑紧缚一区二区三区视频| 国产精品一级二级三级| 成人自拍视频在线| 色综合咪咪久久| 欧美日韩一区二区三区四区五区| 欧美成人三级在线| 国产日产精品1区| 一区二区三区不卡在线观看| 人人超碰91尤物精品国产| 久久99国产精品免费网站| 成人中文字幕合集| 精品视频在线免费| 2020国产精品| 亚洲精品免费在线| 日韩av成人高清| 成人性视频免费网站| 欧美亚洲动漫制服丝袜| 精品少妇一区二区| 中文字幕一区在线观看| 日韩电影一二三区| www.一区二区| 欧美一级xxx| 亚洲丝袜制服诱惑| 美国毛片一区二区三区| 99久久精品国产观看| 日韩欧美123| 一区二区三区毛片| 国产九九视频一区二区三区| 在线观看成人小视频| 精品国产一区二区亚洲人成毛片 | 色妹子一区二区| 欧美变态tickling挠脚心| 亚洲欧美日韩国产手机在线| 久久国产日韩欧美精品| 91国产免费看| 中文字幕成人av| 捆绑调教一区二区三区| 欧美午夜寂寞影院| 国产精品久久久久9999吃药| 蜜臀国产一区二区三区在线播放| 一本高清dvd不卡在线观看| 久久亚洲影视婷婷| 天天色 色综合| 色狠狠综合天天综合综合| 久久一留热品黄| 麻豆专区一区二区三区四区五区| 91国偷自产一区二区三区观看 | 久久成人av少妇免费| 在线视频你懂得一区二区三区| 国产拍欧美日韩视频二区| 激情图片小说一区| 91精品综合久久久久久| 亚洲第一福利视频在线| 99riav一区二区三区| 久久久综合精品| 日韩精品国产欧美| 7777女厕盗摄久久久| 亚洲午夜激情av| 在线观看不卡一区| 一区二区三区在线看| 色综合久久综合中文综合网| 国产精品久久久久久久久久久免费看| 国产精品综合久久| 久久久久亚洲蜜桃| 国产在线麻豆精品观看| 精品sm捆绑视频| 极品少妇一区二区三区精品视频|