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

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

?? math.h

?? 這是VCF框架的代碼
?? H
?? 第 1 頁 / 共 3 頁
字號:
/*	Math.h: the vrtoad::Math classes	Author: Alan Fischer	Email: siralanf_at_lightningtoads_dot_com	Date: 9/21/03	Note: These are untemplated because VC6 fails to optimized templates effectivly.*/#ifndef VRTOAD_MATH_H#define VRTOAD_MATH_H#if defined(WIN32) && defined(_MSC_VER)#	define inline __forceinline#	pragma warning(disable:4244)#endif#ifdef __BORLANDC__#include <cstdlib>#include <cmath>using std::srand;using std::rand;using std::sqrt;using std::acos;using std::asin;using std::cos;using std::sin;using std::atan2;using std::exp;using std::log;using std::fabs;using std::itoa;using std::putenv;using std::ultoa;using std::swab;#define _itoa itoa#define _ultoa ultoa#define _putenv putenv#define _swab swab#else#include <math.h>#include <stdlib.h>#endif#include <vector>#ifdef VRTOAD_MATH_DOUBLE#	define cos cos#	define sin sin#	define sqrt sqrt#	define vrReal double#else#ifndef __BORLANDC__#	define cos cosf#	define sin sinf#	if 1#		define sqrt sqrtf#	else#		define sqrt fastsqrt#	endif#endif#	define vrReal float#endifnamespace vrtoad{//Constantsconst vrReal vrEpsilon=		(vrReal)0.001;const vrReal vrInfinity=	(vrReal)100000000;const vrReal vrSqrt2=		(vrReal)1.41421356237309504880168;const vrReal vrPi=			(vrReal)3.14159265358979323846264;template<class T> inline T Max(const T &t1,const T &t2){	return ((t1>t2)?t1:t2);}template<class T> inline T Min(const T &t1,const T &t2){	return ((t1<t2)?t1:t2);}template<class T> inline T abs(const T &t1){	return ((t1>0)?t1:-t1);}template<class T> inline T square(const T &t1){	return t1*t1;}template<class T> inline T linearInterpolate(const T &t1,const T &t2,vrReal time){	return t1*(1-time)+t2*time;}template<class T1,class T2,class T3> inline T3 clamp(const T1 low,const T2 high,const T3 value){        if(value<low)                return low;        if(value>high)                return high;        return value;}template<class T> inline bool finite(const T &t){	return t==t;}//These two methods aren't templated, because otherwise if you call toRad(90), it will treat it as an integer, which is BADinline vrReal toRad(vrReal deg){	return vrReal(deg*(vrReal)(vrPi/180.0));}inline vrReal toDeg(vrReal rad){	return vrReal(rad*(vrReal)(180.0/vrPi));}#define setBit(v,b) (v|=b)#define clearBit(v,b) (v&=~b)#define isBitSet(v,b) (v&b)inline void setRandomSeed(unsigned int seed){	srand(seed);}//For some reason it appears that the random number functions sometime return numbers equal to upperinline float randomFloat(float lower,float upper){	float r=(float)rand()/(float)RAND_MAX*(upper-lower)+lower;	if(r>=upper){r=lower;}	return r;}inline int randomInt(int lower,int upper){	int r=(int)((float)rand()/(float)RAND_MAX*(float)(upper-lower))+lower;	if(r>=upper){r=lower;}	return r;}float fastsqrt(float n);//Vector2class Vector2{public:	vrReal x,y;	inline Vector2():x(0),y(0){}	inline Vector2(vrReal x1,vrReal y1):x(x1),y(y1){}	inline vrReal *getData(){return (vrReal*)&x;}	inline const vrReal *getData() const{return (vrReal*)&x;}	inline bool operator==(const Vector2 &vec) const{		return (vec.x==x && vec.y==y);	}	inline bool operator!=(const Vector2 &vec) const{		return (vec.x!=x || vec.y!=y);	}	inline Vector2 operator+(const Vector2 &vec) const{		return Vector2(x+vec.x,y+vec.y);	}	inline void operator+=(const Vector2 &vec){		x+=vec.x;		y+=vec.y;	}	inline Vector2 operator-(const Vector2 &vec) const{		return Vector2(x-vec.x,y-vec.y);	}	inline void operator-=(const Vector2 &vec){		x-=vec.x;		y-=vec.y;	}	inline Vector2 operator*(vrReal f) const{		return Vector2(x*f,y*f);	}	inline void operator*=(vrReal f){		x*=f;		y*=f;	}	inline Vector2 operator*(const Vector2 &vec) const{		return Vector2(x*vec.x,y*vec.y);	}	inline void operator*=(const Vector2 &vec){		x*=vec.x;		y*=vec.y;	}	inline Vector2 operator/(vrReal f) const{		f=1/f;		return Vector2(x*f,y*f);	}	inline void operator/=(vrReal f){		f=1/f;		x*=f;		y*=f;	}	inline Vector2 operator/(const Vector2 &vec) const{		return Vector2(x/vec.x,y/vec.y);	}	inline void operator/=(const Vector2 &vec){		x/=vec.x;		y/=vec.y;	}	inline Vector2 operator-() const{		return Vector2(-x,-y);	}	inline vrReal &operator[](int i){		return *(&x+i);	}	inline vrReal operator[](int i) const{		return *(&x+i);	}	//TODO: Remove these on the vectors.  They're not "well defined" operations	inline bool operator>(const Vector2 &vec) const{		return (x>vec.x && y>vec.y);	}	inline bool operator<(const Vector2 &vec) const{		return (x<vec.x && y<vec.y);	}	inline bool operator>=(const Vector2 &vec) const{		return (x>=vec.x && y>=vec.y);	}	inline bool operator<=(const Vector2 &vec) const{		return (x<=vec.x && y<=vec.y);	}};inline Vector2 operator*(vrReal scalar,const Vector2 &vector){	return Vector2(vector.x*scalar,vector.y*scalar);}inline vrReal lengthSquared(const Vector2 &vec){	return vec.x*vec.x+vec.y*vec.y;}inline vrReal length(const Vector2 &vec){	return (vrReal)sqrt((vrReal)(vec.x*vec.x+vec.y*vec.y));}// TODO: return void?inline Vector2 normalize(Vector2 &vec){	vrReal l=1/length(vec);	vec.x*=l;	vec.y*=l;	return vec;}inline Vector2 normalize(const Vector2 &vec){	vrReal l=1/length(vec);	Vector2 vec2;	vec2.x=vec.x*l;	vec2.y=vec.y*l;	return vec2;}//Vector3class Vector3{public:	vrReal x,y,z;	inline Vector3():x(0),y(0),z(0){}	inline Vector3(vrReal x1,vrReal y1,vrReal z1):x(x1),y(y1),z(z1){}	inline Vector3(const Vector2 &vec,vrReal z1){		x=vec.x;y=vec.y;z=z1;	}	inline vrReal *getData(){return (vrReal*)&x;}	inline const vrReal *getData() const{return (vrReal*)&x;}	inline bool operator==(const Vector3 &vec) const{		return (vec.x==x && vec.y==y && vec.z==z);	}	inline bool operator!=(const Vector3 &vec) const{		return (vec.x!=x || vec.y!=y || vec.z!=z);	}	inline Vector3 operator+(const Vector3 &vec) const{		return Vector3(x+vec.x,y+vec.y,z+vec.z);	}	inline void operator+=(const Vector3 &vec){		x+=vec.x;		y+=vec.y;		z+=vec.z;	}	inline Vector3 operator-(const Vector3 &vec) const{		return Vector3(x-vec.x,y-vec.y,z-vec.z);	}	inline void operator-=(const Vector3 &vec){		x-=vec.x;		y-=vec.y;		z-=vec.z;	}	inline Vector3 operator*(vrReal f) const{		return Vector3(x*f,y*f,z*f);	}	inline void operator*=(vrReal f){		x*=f;		y*=f;		z*=f;	}	inline Vector3 operator*(const Vector3 &vec) const{		return Vector3(x*vec.x,y*vec.y,z*vec.z);	}	inline void operator*=(const Vector3 &vec){		x*=vec.x;		y*=vec.y;		z*=vec.z;	}	inline Vector3 operator/(vrReal f) const{		f=1/f;		return Vector3(x*f,y*f,z*f);	}	inline void operator/=(vrReal f){		f=1/f;		x*=f;		y*=f;		z*=f;	}	inline Vector3 operator/(const Vector3 &vec) const{		return Vector3(x/vec.x,y/vec.y,z/vec.z);	}	inline void operator/=(const Vector3 &vec){		x/=vec.x;		y/=vec.y;		z/=vec.z;	}	inline Vector3 operator-() const{		return Vector3(-x,-y,-z);	}	inline vrReal &operator[](int i){		return *(&x+i);	}	inline vrReal operator[](int i) const{		return *(&x+i);	}	inline bool operator>(const Vector3 &vec) const{		return (x>vec.x && y>vec.y && z>vec.z);	}	inline bool operator<(const Vector3 &vec) const{		return (x<vec.x && y<vec.y && z<vec.z);	}	inline bool operator>=(const Vector3 &vec) const{		return (x>=vec.x && y>=vec.y && z>=vec.z);	}	inline bool operator<=(const Vector3 &vec) const{		return (x<=vec.x && y<=vec.y && z<=vec.z);	}};const Vector3 vrRight(1,0,0);const Vector3 vrForward(0,1,0);const Vector3 vrUp(0,0,1);inline vrReal lengthSquared(const Vector3 &vec){	return vec.x*vec.x+vec.y*vec.y+vec.z*vec.z;}inline vrReal length(const Vector3 &vec){	return (vrReal)sqrt((vrReal)(vec.x*vec.x+vec.y*vec.y+vec.z*vec.z));}// TODO: return void?inline Vector3 normalize(Vector3 &vec){	vrReal l=1/length(vec);	vec.x*=l;	vec.y*=l;	vec.z*=l;	return vec;}inline Vector3 normalize(const Vector3 &vec){	vrReal l=1/length(vec);	Vector3 vec2;	vec2.x=vec.x*l;	vec2.y=vec.y*l;	vec2.z=vec.z*l;	return vec2;}// To keep code clean, use this for an XYZ Euler angle, instead of a Vectortypedef Vector3 EulerAngle;inline EulerAngle toRad(const EulerAngle &deg){	return EulerAngle(toRad(deg.x),toRad(deg.y),toRad(deg.z));}inline EulerAngle toDeg(const EulerAngle &deg){	return EulerAngle(toDeg(deg.x),toDeg(deg.y),toDeg(deg.z));}inline Vector3 cross(const Vector3 &vec1,const Vector3 &vec2){	return Vector3(vec1.y*vec2.z-vec1.z*vec2.y,vec1.z*vec2.x-vec1.x*vec2.z,vec1.x*vec2.y-vec1.y*vec2.x);}inline Vector3 operator*(vrReal scalar,const Vector3 &vector){	return Vector3(vector.x*scalar,vector.y*scalar,vector.z*scalar);}inline vrReal dot(const Vector3 &vec1,const Vector3 &vec2){	return vec1.x*vec2.x+vec1.y*vec2.y+vec1.z*vec2.z;}inline Vector3 reflectVector(const Vector3 &vec,const Vector3 &norm){	return norm*(2*dot(vec,norm))-vec;}void setVectorsFromEulerAngles(const EulerAngle &angles,Vector3 &forward,Vector3 &up,Vector3 &right);vrReal getXYAngle(const Vector3 &vec1,const Vector3 &vec2);inline vrReal angleBetween(const Vector3 &vec1,const Vector3 &vec2){	return acos(dot(vec1,vec2));}//Vector4class Vector4{public:	vrReal x,y,z,w;	inline Vector4():x(0),y(0),z(0),w(0){}	inline Vector4(vrReal x1,vrReal y1,vrReal z1,vrReal w1):x(x1),y(y1),z(z1),w(w1){}	inline Vector4(const Vector3 &vec,vrReal w1){		x=vec.x;y=vec.y;z=vec.z;w=w1;	}	inline vrReal *getData(){return (vrReal*)&x;}	inline const vrReal *getData() const{return (vrReal*)&x;}	inline bool operator==(const Vector4 &vec) const{		return (vec.x==x && vec.y==y && vec.z==z && vec.w==w);	}	inline bool operator!=(const Vector4 &vec) const{		return (vec.x!=x || vec.y!=y || vec.z!=z || vec.w!=w);	}	inline Vector4 operator+(const Vector4 &vec) const{		return Vector4(x+vec.x,y+vec.y,z+vec.z,w+vec.w);	}	inline void operator+=(const Vector4 &vec){		x+=vec.x;		y+=vec.y;		z+=vec.z;		w+=vec.w;	}	inline Vector4 operator-(const Vector4 &vec) const{		return Vector4(x-vec.x,y-vec.y,z-vec.z,w-vec.w);	}	inline void operator-=(const Vector4 &vec){		x-=vec.x;		y-=vec.y;		z-=vec.z;		w-=vec.w;	}	inline Vector4 operator*(vrReal f) const{		return Vector4(x*f,y*f,z*f,w*f);	}	inline void operator*=(vrReal f){		x*=f;		y*=f;		z*=f;		w*=f;	}	inline Vector4 operator*(const Vector4 &vec) const{		return Vector4(x*vec.x,y*vec.y,z*vec.z,w*vec.w);	}	inline void operator*=(const Vector4 &vec){		x*=vec.x;		y*=vec.y;		z*=vec.z;		w*=vec.w;	}	inline Vector4 operator/(vrReal f) const{		f=1/f;		return Vector4(x*f,y*f,z*f,w*f);	}	inline void operator/=(vrReal f){		f=1/f;		x*=f;		y*=f;		z*=f;		w*=f;	}	inline void operator/=(const Vector4 &vec){		x/=vec.x;		y/=vec.y;		z/=vec.z;		w/=vec.w;	}	inline Vector4 operator-() const{		return Vector4(-x,-y,-z,-w);	}	inline vrReal &operator[](int i){		return *(&x+i);	}	inline vrReal operator[](int i) const{

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产jizzjizz一区二区| 一道本成人在线| 色综合久久久久久久久久久| 欧美美女视频在线观看| 久久精品亚洲国产奇米99| 亚洲高清三级视频| 91蜜桃在线观看| 国产亚洲美州欧州综合国| 日韩成人午夜精品| 欧美日韩一二三区| 一区二区三区国产精品| 99这里都是精品| 国产精品久久久久久久久图文区| 久久精品国产亚洲一区二区三区| 精品视频1区2区3区| 亚洲欧美日韩国产手机在线 | 成人国产精品免费| 欧美一区二区二区| 香蕉乱码成人久久天堂爱免费| 色综合久久久久| 亚洲欧美一区二区三区孕妇| 国产一区二区按摩在线观看| 欧美成人伊人久久综合网| 亚洲成人激情自拍| 欧美丰满高潮xxxx喷水动漫| 香蕉av福利精品导航| 欧美日韩在线播| 污片在线观看一区二区| 欧美日韩国产一区| 丝袜美腿亚洲一区| 欧美老女人第四色| 视频一区视频二区中文字幕| 91.麻豆视频| 蜜臀精品一区二区三区在线观看 | 成人av电影在线观看| 国产女人18毛片水真多成人如厕| 国产乱码精品一区二区三| 久久久精品国产免大香伊| 风间由美一区二区av101| 国产精品成人一区二区艾草| 91亚洲精华国产精华精华液| 亚洲色图一区二区| 日本福利一区二区| 午夜精品福利视频网站| 26uuu成人网一区二区三区| 国产成人精品亚洲777人妖| 国产亚洲一区二区三区在线观看 | 国产精品一区免费在线观看| 久久久国际精品| 91免费看`日韩一区二区| 亚洲乱码中文字幕| 欧美肥妇free| 国产一区视频在线看| 国产精品久久影院| 欧美丝袜丝交足nylons图片| 免费欧美日韩国产三级电影| 欧美精品一区二区三区在线| 不卡高清视频专区| 亚洲午夜在线视频| 亚洲精品一区二区三区99| 国产乱人伦偷精品视频不卡| 国产精品人妖ts系列视频| 色婷婷久久久亚洲一区二区三区 | 7777精品伊人久久久大香线蕉的| 日韩福利视频导航| 国产精品无人区| 日韩一区二区精品在线观看| 成人激情电影免费在线观看| 性做久久久久久免费观看欧美| 精品国产污污免费网站入口| 97久久精品人人澡人人爽| 蜜臀久久99精品久久久久久9 | 欧美日韩综合在线| 国产精品羞羞答答xxdd| 一区二区三区免费观看| 久久久五月婷婷| 欧美精品久久一区| 北条麻妃一区二区三区| 久久福利视频一区二区| 亚洲精品乱码久久久久| 久久色中文字幕| 欧美另类一区二区三区| 91丨国产丨九色丨pron| 国产一区91精品张津瑜| 日韩精品三区四区| 曰韩精品一区二区| 中文字幕制服丝袜一区二区三区| 日韩欧美国产三级| 在线播放91灌醉迷j高跟美女| 99精品久久只有精品| 国产一区二区三区av电影| 人人精品人人爱| 亚洲国产日日夜夜| 亚洲欧美激情视频在线观看一区二区三区 | 国产女人水真多18毛片18精品视频| 欧美日韩一区二区在线观看 | 成人h动漫精品| 精品写真视频在线观看| 日本最新不卡在线| 亚洲1区2区3区4区| 亚洲综合一区在线| 亚洲一区二区三区中文字幕| 亚洲女同一区二区| 亚洲色图在线播放| 亚洲免费高清视频在线| 欧美国产日本视频| 中文字幕的久久| 日本一二三四高清不卡| 久久久亚洲高清| 国产午夜精品久久| 国产精品视频在线看| 国产欧美一区二区精品久导航| 久久久久久久国产精品影院| 亚洲精品在线电影| 国产农村妇女毛片精品久久麻豆| 久久久美女艺术照精彩视频福利播放| 日韩一区二区三区视频在线| 日韩一区二区精品葵司在线| 欧美精品日韩一区| 欧美成人a视频| 国产欧美一区二区精品性色超碰| 国产免费成人在线视频| 国产精品久久久久久久岛一牛影视 | 亚洲黄色小视频| 亚洲一区二区五区| 毛片av一区二区三区| 国产一区二区三区免费看| 国产精品一级在线| 91蜜桃传媒精品久久久一区二区| 色琪琪一区二区三区亚洲区| 欧美人牲a欧美精品| 日韩免费观看高清完整版| 久久久青草青青国产亚洲免观| 日本一区二区三区dvd视频在线| 国产精品美女久久久久久久久久久| 1024成人网色www| 亚洲777理论| 国产精品1024| 色屁屁一区二区| 亚洲精品一区二区三区福利 | 91免费观看视频| 欧美日韩成人综合在线一区二区| 精品免费一区二区三区| 中文字幕一区免费在线观看 | 欧美大片在线观看一区| 国产亚洲成年网址在线观看| 亚洲女同女同女同女同女同69| 午夜伦欧美伦电影理论片| 国产精品自在在线| 91黄视频在线| 国产日韩视频一区二区三区| 亚洲日本乱码在线观看| 蜜桃av噜噜一区| 91国产成人在线| 久久久久国产精品厨房| 午夜精品一区二区三区免费视频 | 韩国女主播一区二区三区| 91免费观看国产| 久久久久久久综合日本| 亚洲va天堂va国产va久| 成人高清av在线| 欧美电视剧免费观看| 一区二区在线观看不卡| 国产激情一区二区三区四区 | 欧美一区午夜视频在线观看| 中文字幕欧美日韩一区| 日韩福利电影在线| 色呦呦日韩精品| 久久九九99视频| 蜜桃一区二区三区在线观看| 欧美影视一区在线| 国产精品久久福利| 狠狠色丁香婷婷综合| 欧美一区二区在线观看| 一区2区3区在线看| 成人深夜在线观看| 久久久久国色av免费看影院| 日韩电影免费在线| 欧美日韩电影在线| 亚洲综合在线电影| 一本色道久久综合精品竹菊| 亚洲国产精品二十页| 久久精品国产亚洲5555| 欧美一区二区三区在线视频 | 亚洲欧美日本韩国| www.亚洲在线| 中文字幕中文字幕在线一区| 国产永久精品大片wwwapp| 欧美成人福利视频| 久久99久久99| 久久亚洲影视婷婷| 国产真实乱子伦精品视频| 日韩欧美的一区二区| 日本aⅴ亚洲精品中文乱码| 欧美mv和日韩mv国产网站| 免费在线看成人av| 日韩一级完整毛片| 久国产精品韩国三级视频| 精品粉嫩aⅴ一区二区三区四区| 青青青爽久久午夜综合久久午夜|