• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            隨筆 - 505  文章 - 1034  trackbacks - 0
            <2007年11月>
            28293031123
            45678910
            11121314151617
            18192021222324
            2526272829301
            2345678


            子曾經(jīng)曰過(guò):編程無(wú)他,唯手熟爾!

            常用鏈接

            留言簿(94)

            隨筆分類(649)

            隨筆檔案(505)

            相冊(cè)

            BCB

            Crytek

            • crymod
            • Crytek's Offical Modding Portal

            Game Industry

            OGRE

            other

            Programmers

            Qt

            WOW Stuff

            搜索

            •  

            積分與排名

            • 積分 - 917344
            • 排名 - 14

            最新隨筆

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            估計(jì)carmack在心里說(shuō):其實(shí)我不是很牛,只是我把別人泡妞的時(shí)間拿來(lái)寫(xiě)程序了!

            John Carmack密碼:0x5f3759df

            有人在Quake III的源代碼里面發(fā)現(xiàn)這么一段用來(lái)求平方根的代碼:

            /*
            ================
            SquareRootFloat
            ================
            */
            float SquareRootFloat(float number) {
            long i;
            float x, y;
            const float f = 1.5F;

            x = number * 0.5F;
            y = number;
            i = * ( long * ) &y;
            i = 0x5f3759df - ( i >> 1 ); //注意這一行
            y = * ( float * ) &i;
            y = y * ( f - ( x * y * y ) );
            y = y * ( f - ( x * y * y ) );
            return number * y;
            }
            0x5f3759df? 這是個(gè)什么東西? 學(xué)過(guò)數(shù)值分析就知道,算法里面求平方根一般采用的是無(wú)限逼近的方法,比如牛頓迭代法,抱歉當(dāng)年我數(shù)值分析學(xué)的太爛,也講不清楚。簡(jiǎn)單來(lái)說(shuō)比如求5的平方根,選一個(gè)猜測(cè)值比如2,那么我們可以這么算
            5/2 = 2.5; 2.5+2/2 = 2.25; 5/2.25 = xxx; 2.25+xxx/2 = xxxx ...

            這樣反復(fù)迭代下去,結(jié)果必定收斂于sqrt(5),沒(méi)錯(cuò),一般的求平方根都是這么算的。而卡馬克的不同之處在于,他選擇了一個(gè)神秘的猜測(cè)值0x5f3759df作為起始,使得整個(gè)逼近過(guò)程收斂速度暴漲,對(duì)于Quake III所要求的精度10的負(fù)三次方,只需要一次迭代就能夠得到結(jié)果。

            好吧,如果這還不算牛b,接著看。

            普渡大學(xué)的數(shù)學(xué)家Chris Lomont看了以后覺(jué)得有趣,決定要研究一下卡馬克弄出來(lái)的這個(gè)猜測(cè)值有什么奧秘。Lomont也是個(gè)牛人,在精心研究之后從理論上也推導(dǎo)出一個(gè)最佳猜測(cè)值,和卡馬克的數(shù)字非常接近, 0x5f37642f。卡馬克真牛,他是外星人嗎?

            傳奇并沒(méi)有在這里結(jié)束。Lomont計(jì)算出結(jié)果以后非常滿意,于是拿自己計(jì)算出的起始值和卡馬克的神秘?cái)?shù)字做比賽,看看誰(shuí)的數(shù)字能夠更快更精確的求得平方根。結(jié)果是卡馬克贏了... 誰(shuí)也不知道卡馬克是怎么找到這個(gè)數(shù)字的。

            最后Lomont怒了,采用暴力方法一個(gè)數(shù)字一個(gè)數(shù)字試過(guò)來(lái),終于找到一個(gè)比卡馬克數(shù)字要好上那么一丁點(diǎn)的數(shù)字,雖然實(shí)際上這兩個(gè)數(shù)字所產(chǎn)生的結(jié)果非常近似,這個(gè)暴力得出的數(shù)字是0x5f375a86。

            Lomont為此寫(xiě)下一篇論文,"Fast Inverse Square Root"

            John Carmack, ID的無(wú)價(jià)之寶

            來(lái)源blog:http://jan.yculblog.com/

            posted on 2008-11-29 18:13 七星重劍 閱讀(1966) 評(píng)論(3)  編輯 收藏 引用 所屬分類: PL--c/c++Game GraphicsIDE -- visual c++

            FeedBack:
            # re: John Carmack密碼:0x5f3759df 2008-12-01 10:49 螞蟻終結(jié)者
            不錯(cuò),確實(shí)很強(qiáng)!  回復(fù)  更多評(píng)論
              
            # re: John Carmack密碼:0x5f3759df 2012-05-11 00:13 WILLIAMDolores
            Some time ago, I needed to buy a good house for my corporation but I did not earn enough cash and could not order anything. Thank heaven my mother suggested to try to take the personal loans from reliable creditors. Thus, I acted so and used to be satisfied with my short term loan.   回復(fù)  更多評(píng)論
              
            亚洲国产欧美国产综合久久| 国产精品欧美亚洲韩国日本久久| 久久久久久免费视频| 精品久久久一二三区| 久久精品天天中文字幕人妻| 亚洲国产成人久久精品动漫| 日本高清无卡码一区二区久久| 性欧美大战久久久久久久久| 国产激情久久久久影院老熟女免费 | 久久久久国产一区二区| 久久久久久精品久久久久| 精品一区二区久久久久久久网站| 久久亚洲精品无码观看不卡| 久久se精品一区二区| 久久国产欧美日韩精品| 亚洲国产精品一区二区三区久久| 欧美va久久久噜噜噜久久| 亚洲美日韩Av中文字幕无码久久久妻妇 | 精品久久久久久中文字幕| 一本大道久久东京热无码AV | 欧洲精品久久久av无码电影| 久久www免费人成精品香蕉| 97久久天天综合色天天综合色hd | 精品欧美一区二区三区久久久| 久久精品无码午夜福利理论片| 麻豆av久久av盛宴av| 一本色综合久久| 亚洲国产小视频精品久久久三级| 色综合久久88色综合天天| 99久久99这里只有免费费精品| 无码精品久久久天天影视| 日韩av无码久久精品免费| 午夜天堂精品久久久久| 亚洲综合日韩久久成人AV| 一本一本久久A久久综合精品 | 久久精品国产清自在天天线| 国产三级精品久久| 亚洲乱码日产精品a级毛片久久| 色8激情欧美成人久久综合电| 久久综合色之久久综合| 久久人妻AV中文字幕|