• <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>

            實時陰影繪制技術(shù)研究

            C++博客 首頁 新隨筆 聯(lián)系 聚合 管理
              48 Posts :: 20 Stories :: 57 Comments :: 0 Trackbacks
            作者:azure
            轉(zhuǎn)自:http://www.azure.com.cn/article.asp?id=192

            通常影響程序運行速度的地方,都是在執(zhí)行次數(shù)最多的地方。比如顯示一張800*600的256色圖形,如果在設(shè)置調(diào)色板時浪費了0.001秒,那么對整個程序不會有很大影響,因為設(shè)置調(diào)色板的操作只要作一次就完成,但是每繪出一點要多浪費0.001秒,那么整張圖畫完就會慢上800*600*0.001秒,這是一個相當可觀的數(shù)目。下面介紹一些常用的技巧。

            一.盡量使用整數(shù),少用浮點數(shù)
              整數(shù)運算比浮點數(shù)快得多,而在繪圖程序中用到小數(shù)點的機會實在少之又少,所以這是很容易做到的技巧。

            二.避免乘法與除法
              乘法與除法都是相當浪費CPU運算時間的一種運算,所以在繪圖程序中應(yīng)盡量避免,在無法避免時,如果乘除的數(shù)目為2次方,例如2、4、8、16等,則可改用左移或右移來取代:

            a*2^n-->a<<n 例:a*16-->a<<4
            a/2^n-->a>>n 例:a/32-->a>>5

              上式中2^n表示2的n次方。

            三.少用求模運算
              求模的運算(%)通常也是用乘除來完成的,所以速度很慢,我們也要盡量避免,當然如果除數(shù)為2的次方,那么可以改用&來替代:

            a%2^n --> a&(2^n-1)

            例:a%8 --> a&0x07


            注意,如果除數(shù)不是2的次方,絕不能用&來替代。

            四.復(fù)雜的二維計算改用查表法
              所謂查表法,就是事先將一些運算結(jié)果存入表格中,然后在需要時直接取出來使用而不必再做運算。最常見的例子就是在做圖形旋轉(zhuǎn)時,往往會用到sin()、cos()等函數(shù)來計算角度,如果能將這些運算結(jié)果事先存于表格中,那么必能省下相當多的時間。
              對于較簡單的顯示圖形的程序,我們也可以利用查表法來避免乘法的使用。例如在320*200*256模式下,我們要在(x,y)的地方畫出一點,那么必然要做(y*320+x)的計算,如果能將每一條起始掃描線的位置事先算出并存入表格中:

            unsinged table[200];
            for( i=0; i<200; i++ )
            table[i] = i * 320;

            那么在繪點時便可以直接使用下面的方法來取得位置:

            table[y] + x;

            避免了乘法運算,這就是“以空間換取時間“的做法。還有一種變形的查表法也值得一提,那就是如果在程序中有很多地方都用到了相同的運算,那么可以事先算出結(jié)果并加以儲存,例如:

            ......
            MaxSize = width * height * 3 + 200;
            ......
            MinSize = width * height * 3 - 100;
            ......

            則可先算出size:

            size = width * height * 3;
            ......
            MaxSize = size + 200;
            ......
            MinSize = size - 100;
            ......

            五.將耗時的運算移到循環(huán)之外
              通常在循環(huán)內(nèi)的程序碼會執(zhí)行較多次,所以應(yīng)減少耗時的運算,例如320*200*256模式政繪制一個實心的矩形時:

            char far *vp = (char far *)0xA0000000L;
            for( y=50; y<150; y++ )
            for( x=100; x<200; x++ )
            *(vp+y*320+x) = 0x0f;

            可以改成:

            char far *vp = (char far *)0xA0000000L;
            char far *p;
            for( y=50; y<150; y++ )
            {
            p = vp+y*320+100; /* 將乘法移出內(nèi)層循環(huán)*/
            for( x=100; x<200; x++ )
            *(p++) = 0x0f;
            }

            再進一步還可以更上一層樓,將乘法完全移出循環(huán):

            char far *vp = (char far *)0xA0000000L;
            char far *p;
            int offset = 320-(200-100);
            p = vp+50*320+100;
            for( y=50; y<150; y++ )
            {
            for( x=100; x<200; x++ )
            *(p++) = 0x0f;
            p += offset;
            }

            其中offset的值正是矩形中最右邊的一點到下一條掃描線最左邊一點的差距值。

            六.使用寄存器變量
              寄存器的存取速度要比內(nèi)存快,一般c/c++編譯器都至少提供1~2個寄存器變量給程序使用,我們應(yīng)該將使用最頻繁的變量定義成寄存器變量,這樣可以加快執(zhí)行效率,例如:

            register int i;
            for( i=0; i<3000; i++ )
            *(p+i) = 0x0f;

            七.編譯器的設(shè)置
              在編譯程序時,我們也可以通過某些設(shè)置來加快程序效率,例如,產(chǎn)生最快的執(zhí)行速度的最佳化,不做堆棧溢出檢查等,如果你使用tc20,那么只要在Option菜單中選Compiler/Optimizations,然后選擇底部的Fastest Code按鈕便可。讀者可以自行參考相關(guān)手冊。
            posted on 2006-03-17 23:27 苦行僧 閱讀(668) 評論(0)  編輯 收藏 引用 所屬分類: 轉(zhuǎn)載
            97久久婷婷五月综合色d啪蜜芽| 久久99九九国产免费看小说| 久久中文字幕人妻熟av女| 久久综合欧美成人| 久久成人国产精品二三区| av无码久久久久久不卡网站| 粉嫩小泬无遮挡久久久久久| 久久国产色AV免费观看| 久久婷婷激情综合色综合俺也去| 国产成人无码精品久久久性色 | 国产免费久久精品99久久| 99久久婷婷国产一区二区| 精品久久综合1区2区3区激情| 国产国产成人久久精品| 久久精品亚洲福利| 久久人人爽人人爽人人av东京热| 一本一本久久a久久综合精品蜜桃 一本一道久久综合狠狠老 | 久久久久久久人妻无码中文字幕爆| 久久AV高清无码| 久久综合狠狠综合久久激情 | 免费精品久久久久久中文字幕| 少妇久久久久久被弄到高潮 | 国产午夜精品理论片久久影视 | 久久久国产精品亚洲一区| 国产一级持黄大片99久久| 久久久久久无码国产精品中文字幕| 伊人久久大香线蕉无码麻豆| 青青草原精品99久久精品66| 成人a毛片久久免费播放| 中文字幕无码久久人妻| 久久精品夜夜夜夜夜久久| 国产亚洲精久久久久久无码AV| 精品伊人久久久| 久久久国产精品福利免费| 国产精品一区二区久久精品涩爱| 东京热TOKYO综合久久精品| 久久九九免费高清视频| 久久国产精品成人片免费| 中文字幕精品无码久久久久久3D日动漫 | 久久精品国产精品青草app| 人人妻久久人人澡人人爽人人精品 |