云风的个人空间 : 代码片段[CodeCollection]

首页 :: 索引 :: 修订历史 :: 你好, 3.236.225.157
你的足迹: » 代码片段
这是一个旧版本的CodeCollection于2006-03-21 13:47:18.
一个快速开方的函数:
/* 来至 Quake 3 的源码 */
float CarmSqrt(float x){
	union{
		int intPart;
		float floatPart;
	} convertor;
	union{
		int intPart;
		float floatPart;
	} convertor2;
	convertor.floatPart = x;
	convertor2.floatPart = x;
	convertor.intPart = 0x1FBCF800 + (convertor.intPart >> 1);
	convertor2.intPart = 0x5f3759df - (convertor2.intPart >> 1);
	return 0.5f*(convertor.floatPart + (x * convertor2.floatPart));
}

参考链接:[External Link]http://greatsorcerer.go2.icpcn.com/info/fastsqrt.html