fixed數據類型


在處理圖形運算,特別是3D圖形生成運算時,往往要定義一個Fixed數據類型,我稱它為定點數,定點數其時就是一個整形數據類型,他的作用就是把所有數 進行轉換,從而得到相應類型的整型表達,然后使用定點數進行整行運算,取到最終值並將其轉換回實際的基本數據類型。因此它是通過避免大量的浮點運算來加快 圖形處理的一個方式。

 

Fixed是業界使用最廣的一種類型,他並沒有在標准C或者其他語言中定義,程序員可以靈活的使用Fixed類型,可以定義自己想要的Fixed類型。那 么什么是Fixed類型呢?Fixed類型是用來取代浮點,使用4字節的高2個字節表示整數位,低2個字節表示浮點位。每個字節有8個bit位,4個字節 32個bit位,因此,我們把這種Fixed稱為16.16Fixed。當然,也有使用24.8的Fixed,這就要看需求和精確度了。比如Fixed中 的數字1,就是65536,也就是(1<<16)。這里用了位移公式,就是將1左移16位,也就是2個字節,左移16等於剩以65536,只 不過位移來的非常快,快過加法。(這里理解不了就算了)比如數字32.5,等於(32<<16)|32768,等於 32*65536+32768。為什么要這么麻煩呢?有了Fixed,就好像操作整數一樣,都是整數運算了。Fixed的四舍五入也很簡單,比如我們將X 四舍五入到整數類型,就是(X+32768)>>16。32768就是半個Fixed的1,也就是浮點的0.5。右移16位就是除以 65536,為的是將高2字節移到正常的整數位上。我都說暈了,以后慢慢解釋給大家,呵呵。

    Fixed類型說了一堆,究竟來做什么的?

    比如上例中,Y軸每次都要偏移0.4,而這個數是個浮點,嚴重影響了運算速度。比如,我們后台有一個數,用來計量Y軸本次的坐標,就叫做變量YY吧。X每 次都加1,也就是XX++,Y每次加0.4,也就是YY+=0.4。為了提高速度,我們將YY升級到Fixed類型,YY每次加Fixed的0.4,也就 是0.4*65536=26214,然后再四舍五入到整數類型,即YY+=26214,Y=(YY+32768)>>16。這樣,就得到了每 次的整數Y,並且都是整數的加減和位運算,速度非常快

 

http://www.cppblog.com/wrhwww/archive/2010/07/29/121573.html


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM