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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? rigidbody2d.cpp

?? 通過人工智能算法快速實現神經網絡識別
?? 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;
}



?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美一区二区精品在线| 中文av一区特黄| 中文字幕欧美激情| av一区二区三区| 3d动漫精品啪啪1区2区免费| 中文一区二区完整视频在线观看| 一区二区三区在线免费视频| 国产精品一区2区| 日韩午夜电影在线观看| 亚洲国产精品久久久男人的天堂 | 久久久美女毛片| 亚洲一区二区三区在线看 | 婷婷六月综合亚洲| 91丨porny丨户外露出| 久久一二三国产| 日本强好片久久久久久aaa| 91浏览器在线视频| 中文字幕在线不卡一区二区三区| 精品一区二区av| 91麻豆精品国产91久久久久久久久 | 日韩高清在线观看| 欧美亚洲一区二区在线观看| 中文字幕在线不卡国产视频| 成人中文字幕合集| 中文字幕va一区二区三区| 国产精品夜夜嗨| 久久久久久电影| 国产成人av资源| 久久精品视频网| 在线一区二区视频| 亚洲一区在线观看免费观看电影高清 | 色综合天天综合| 中文字幕一区av| 99久精品国产| 一区二区三区四区不卡在线 | 亚洲日本在线视频观看| 91丨九色porny丨蝌蚪| 亚洲欧美偷拍三级| 91麻豆国产精品久久| 亚洲精品少妇30p| 欧美性受极品xxxx喷水| 天天免费综合色| 91精品国产91热久久久做人人| 日韩电影在线免费观看| 欧美成人在线直播| 国产成人免费视频一区| 国产日本一区二区| 99久久99久久精品国产片果冻| 一区二区三区丝袜| 欧美电影一区二区| 激情文学综合网| 国产欧美日韩三级| 97se亚洲国产综合自在线观| 亚洲国产精品一区二区www在线| 在线看国产日韩| 免费成人在线影院| 丝袜亚洲另类欧美| 久久综合一区二区| av不卡在线观看| 婷婷久久综合九色综合绿巨人 | 日韩精品成人一区二区三区| 精品国产一区二区三区久久影院| 成人久久久精品乱码一区二区三区| 国产精品午夜电影| 欧美精品色综合| 顶级嫩模精品视频在线看| 一区二区三区美女| 精品噜噜噜噜久久久久久久久试看| 成人性色生活片| 亚洲va欧美va天堂v国产综合| 精品国产自在久精品国产| www.亚洲国产| 麻豆精品视频在线观看免费| 国产精品女同互慰在线看| 欧美精品久久久久久久多人混战| 国产综合成人久久大片91| 中文字幕中文字幕在线一区| 欧美一区二区三区四区五区| av在线不卡电影| 久久精品久久综合| 亚洲精品免费在线播放| 久久久精品欧美丰满| 国产精品网站在线| 555夜色666亚洲国产免| 播五月开心婷婷综合| 首页亚洲欧美制服丝腿| 亚洲欧美一区二区三区孕妇| 久久久九九九九| 欧美一区二区三区人| 色欧美片视频在线观看| 丁香六月综合激情| 精一区二区三区| 日韩制服丝袜av| 亚洲午夜国产一区99re久久| 国产精品动漫网站| 国产欧美一区二区三区鸳鸯浴 | 99久久精品免费| 精品一区二区三区免费| 丝袜美腿亚洲一区二区图片| 一区二区三区在线免费播放| 国产精品成人网| 亚洲国产精品黑人久久久| 日韩一级大片在线| 欧美精品vⅰdeose4hd| 色拍拍在线精品视频8848| a级高清视频欧美日韩| 国产精品一区二区在线观看不卡 | 亚洲综合在线五月| 中文字幕在线观看一区| 国产精品天干天干在观线| 久久久无码精品亚洲日韩按摩| 欧美一区二区三区白人| 欧美一区在线视频| 日韩一区二区高清| 亚洲图片激情小说| 最新不卡av在线| 亚洲日本在线看| 亚洲综合色视频| 亚洲成人在线免费| 午夜精品aaa| 日韩高清不卡在线| 久久国产生活片100| 久久激五月天综合精品| 精品一区二区三区蜜桃| 国产精品亚洲一区二区三区妖精 | 日韩成人午夜电影| 蜜桃免费网站一区二区三区| 久久99久久久欧美国产| 久久精品99国产精品日本| 国产一区欧美二区| 成人免费视频免费观看| 色综合中文字幕国产| av电影天堂一区二区在线| 97se亚洲国产综合在线| 欧美色老头old∨ideo| 91精品国产丝袜白色高跟鞋| 日韩欧美的一区二区| 久久久欧美精品sm网站| 亚洲特黄一级片| 午夜免费久久看| 国产精品羞羞答答xxdd| 日本韩国欧美一区二区三区| 在线成人小视频| 欧美极品另类videosde| 亚洲激情一二三区| 日本不卡不码高清免费观看| 国产精品综合网| 色综合久久中文综合久久牛| 欧美日韩精品一区视频| 亚洲精品一区二区三区精华液 | 成人欧美一区二区三区小说 | 亚洲欧美激情小说另类| 日韩综合一区二区| 国产福利精品一区二区| 精品视频一区二区三区免费| 精品对白一区国产伦| 一区二区三区中文字幕精品精品| 美腿丝袜在线亚洲一区| 色综合久久99| 精品国产乱码久久久久久闺蜜| 自拍偷自拍亚洲精品播放| 日韩av电影免费观看高清完整版 | 97se亚洲国产综合在线| 日韩一区二区三区四区五区六区| 中文一区一区三区高中清不卡| 日韩在线a电影| 91视视频在线直接观看在线看网页在线看 | 精品88久久久久88久久久| 亚洲精品欧美二区三区中文字幕| 国内不卡的二区三区中文字幕| 色一情一伦一子一伦一区| 久久青草欧美一区二区三区| 亚洲va韩国va欧美va| 99久久99久久免费精品蜜臀| 欧美电影精品一区二区| 亚洲成人中文在线| 色av成人天堂桃色av| 七七婷婷婷婷精品国产| 欧美影院一区二区三区| 1区2区3区国产精品| 国产麻豆精品在线| 日韩欧美不卡在线观看视频| 亚洲综合无码一区二区| 99久久久无码国产精品| 国产婷婷色一区二区三区四区| 久久福利资源站| 欧美一级免费观看| 五月天欧美精品| 欧美日韩精品一区二区天天拍小说| 日韩毛片精品高清免费| 成人一级片在线观看| 国产欧美视频一区二区三区| 激情丁香综合五月| 欧美草草影院在线视频| 免费在线看成人av| 日韩一区二区电影| 免费看精品久久片| 日韩一区二区三区电影在线观看| 天堂蜜桃91精品| 欧美一区二区观看视频|