青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

隨筆-60  評論-111  文章-0  trackbacks-0

1 前言

        自然界的顏色千變?nèi)f化,為了給顏色一個量化的衡量標準,就需要建立色彩空間模型來描述各種各樣的顏色,由于人對色彩的感知是一個復(fù)雜的生理和心理聯(lián)合作用 的過程,所以在不同的應(yīng)用領(lǐng)域中為了更好更準確的滿足各自的需求,就出現(xiàn)了各種各樣的色彩空間模型來量化的描述顏色。我們比較常接觸到的就包括 RGB / CMYK / YIQ / YUV / HSI等等。

        對于數(shù)字電子多媒體領(lǐng)域來說,我們經(jīng)常接觸到的色彩空間的概念,主要是RGB , YUV這兩種(實際上,這兩種體系包含了許多種具體的顏色表達方式和模型,如sRGB, Adobe RGB, YUV422, YUV420 …), RGB是按三基色加光系統(tǒng)的原理來描述顏色,而YUV則是按照 亮度,色差的原理來描述顏色。

        即使只是RGB YUV這兩大類色彩空間,所涉及到的知識也是十分豐富復(fù)雜的,自知不具備足夠的相關(guān)專業(yè)知識,所以本文主要針對工程領(lǐng)域的應(yīng)用及算法進行討論。

2 YUV相關(guān)色彩空間模型

2.1 YUV 與 YIQ YcrCb

        對于YUV模型,實際上很多時候,我們是把它和YIQ / YCrCb模型混為一談的。

        實際上,YUV模型用于PAL制式的電視系統(tǒng),Y表示亮度,UV并非任何單詞的縮寫。

        YIQ模型與YUV模型類似,用于NTSC制式的電視系統(tǒng)。YIQ顏色空間中的I和Q分量相當于將YUV空間中的UV分量做了一個33度的旋轉(zhuǎn)。

        YCbCr顏色空間是由YUV顏色空間派生的一種顏色空間,主要用于數(shù)字電視系統(tǒng)中。從RGB到Y(jié)CbCr的轉(zhuǎn)換中,輸入、輸出都是8位二進制格式。

        三者與RGB的轉(zhuǎn)換方程如下:

        RGB -> YUV:


        實際上也就是:

Y=0.30R+0.59G+0.11B , U=0.493(B-Y) , V=0.877(R-Y)

        RGB -> YIQ:


        RGB -> YCrCb:


        從公式中,我們關(guān)鍵要理解的一點是,UV / CbCr信號實際上就是藍色差信號和紅色差信號,進而言之,實際上一定程度上間接的代表了藍色和紅色的強度,理解這一點對于我們理解各種顏色變換處理的過程會有很大的幫助。

        我們在數(shù)字電子多媒體領(lǐng)域所談到的YUV格式,實際上準確的說,是以YcrCb色彩空間模型為基礎(chǔ)的具有多種存儲格式的一類顏色模型的家族(包括 YUV444 / YUV422 / YUV420 / YUV420P等等)。并不是傳統(tǒng)意義上用于PAL制模擬電視的YUV模型。這些YUV模型的區(qū)別主要在于UV數(shù)據(jù)的采樣方式和存儲方式,這里就不詳述。

        而在Camera Sensor中,最常用的YUV模型是 YUV422格式,因為它采用4個字節(jié)描述兩個像素,能和RGB565模型比較好的兼容。有利于Camera Sensor和Camera controller的軟硬件接口設(shè)計。

3 YUV2RGB快速算法分析

        這里指的YUV實際是YcrCb了 8  ) YUV2RGB的轉(zhuǎn)換公式本身是很簡單的,但是牽涉到浮點運算,所以,如果要實現(xiàn)快速算法,算法結(jié)構(gòu)本身沒什么好研究的了,主要是采用整型運算或者查表來加快計算速度。
首先可以推導(dǎo)得到轉(zhuǎn)換公式為:

        R = Y + 1.4075 *(V-128)
        G = Y – 0.3455 *(U –128) – 0.7169 *(V –128)
        B = Y + 1.779 *(U – 128)

3.1 整型算法

       要用整型運算代替浮點運算,當然是要用移位的辦法了,我們可以很容易得到下列算法:

        u = YUVdata[UPOS] - 128;
        v = YUVdata[VPOS] - 128;

        rdif = v + ((v * 103) >> 8);
        invgdif = ((u * 88) >> 8) +((v * 183) >> 8);
        bdif = u +( (u*198) >> 8);

        r = YUVdata[YPOS] + rdif;
        g = YUVdata[YPOS] - invgdif;
        b = YUVdata[YPOS] + bdif;

為了防止出現(xiàn)溢出,還需要判錯計算的結(jié)果是否在0-255范圍內(nèi),做類似下面的判斷。

        if (r>255)
            r=255;
        if (r<0)
            r=0;

        要從RGB24轉(zhuǎn)換成RGB565數(shù)據(jù)還要做移位和或運算:

        RGBdata[1] =( (r & 0xF8)  | ( g >> 5) );
        RGBdata[0] =( ((g & 0x1C) << 3) | ( b >> 3) );

3.2 部分查表法

        查表法首先可以想到的就是用查表替代上述整型算法中的乘法運算。

        rdif = fac_1_4075[u];
        invgdif = fac_m_0_3455[u] + fac_m_0_7169[v];
        bdif = fac_1_779[u];

        這里一共需要4個1維數(shù)組,下標從0開始到255,表格共占用約1K的內(nèi)存空間。uv可以不需要做減128的操作了。在事先計算對應(yīng)的數(shù)組元素的值的時候計算在內(nèi)就好了。

        對于每個像素,部分查表法用查表替代了2次減法運算和4次乘法運算,4次移位運算。但是,依然需要多次加法運算和6次比較運算和可能存在的賦值操作,相對第一種方法運算速度提高并不明顯。

3.3 完全查表法

        那么是否可以由YUV直接查表得到對應(yīng)的RGB值呢?乍一看似乎不太可能,以最復(fù)雜的G的運算為例,因為G與YUV三者都相關(guān),所以類似 G=YUV2G[Y][U][V]這樣的算法,一個三維下標尺寸都為256的數(shù)組就需要占用2的24次方約16兆空間,絕對是沒法接受的。所以目前多數(shù)都 是采用部分查表法。

        但是,如果我們仔細分析就可以發(fā)現(xiàn),對于G我們實際上完全沒有必要采用三維數(shù)組,因為Y只與UV運算的結(jié)果相關(guān),與UV的個體無關(guān),所以我們可以采用二次查表的方法將G的運算簡化為對兩個二維數(shù)組的查表操作,如下:

        G = yig2g_table[ y ][ uv2ig_table[ u ][ v ] ];

        而RB本身就只和YU或YV相關(guān),所以這樣我們一共需要4個8*8的二維表格,需要占用4乘2的16次方共256K內(nèi)存。基本可以接受。但是對于手機這樣的嵌入式運用來說,還是略有些大了。

        進一步分析,我們可以看到,因為在手機等嵌入式運用上我們最終是要把數(shù)據(jù)轉(zhuǎn)換成RGB565格式送到LCD屏上顯示的,所以,對于RGB三分量來說,我們 根本不需要8bit這么高的精度,為了簡單和運算的統(tǒng)一起見,對每個分量我們其實只需要高6bit的數(shù)據(jù)就足夠了,所以我們可以進一步把表格改為4個 6*6的二維表格,這樣一共只需要占用16K內(nèi)存!在計算表格元素值的時候還可以把最終的溢出判斷也事先做完。最后的算法如下:

        y = (YUVdata[Y1POS] >> 2);
        u = (YUVdata[UPOS] >> 2);
        v = (YUVdata[VPOS] >> 2);

        r = yv2r_table[ y ][ v ];
        g = yig2g_table[ y ][ uv2ig_table[ u ][ v ] ];
        b = yu2b_table[ y ][ u ];
 
        RGBdata[1] =( (r & 0xF8)  | ( g >> 5) );
        RGBdata[0] =( ((g & 0x1C) << 3) | ( b >> 3) );

        這樣相對部分查表法,我們增加了3次移位運算,而進一步減少了4次加法運算和6次比較賦值操作。

        在計算表格元素數(shù)值的時候,要考慮舍入和偏移等因數(shù)使得計算的中間結(jié)果滿足數(shù)組下標非負的要求,需要一定的技巧。

        采用完全查表法,相對于第一種算法,最終運算速度可以有比較明顯的提高,具體性能能提高多少,要看所在平臺的CPU運算速度和內(nèi)存存取速度的相對比例。內(nèi) 存存取速度越快,用查表法帶來的性能改善越明顯。在我的PC上測試的結(jié)果性能大約能提高35%。而在某ARM平臺上測試只提高了約15%。

3.4 進一步的思考

        實際上,上述算法:

        RGBdata[1] =( (r & 0xF8)  | ( g >> 5) );
        RGBdata[0] =( ((g & 0x1C) << 3) | ( b >> 3) );

        中的 (r & 0xF8) 和 ( b >> 3) 等運算也完全可以在表格中事先計算出來。另外,YU / YV的取值實際上不可能覆蓋滿6*6的范圍,中間有些點是永遠取不到的無輸入,RB的運算也可以考慮用5*5的表格。這些都可能進一步提高運算的速度,減 小表格的尺寸。

        另外,在嵌入式運用中,如果可能盡量將表格放在高速內(nèi)存如SRAM中應(yīng)該比放在SDRAM中更加能發(fā)揮查表法的優(yōu)勢。

4 RGB2YUV ?

        目前覺得這個是沒法將3維表格的查表運算化簡為2維表格的查表運算了。只能用部分查表法替代其中的乘法運算。

        另外,多數(shù)情況下,我們需要的還是YUV2RGB的轉(zhuǎn)換,因為從Sensor得到的數(shù)據(jù)通常我們會用YUV數(shù)據(jù),此外JPG和MPEG實際上也是基于YUV格式編碼的,所以要顯示解碼后的數(shù)據(jù)需要的也是YUV2RGB的運算 8 )運氣運氣。

 

本文來自CSDN博客,轉(zhuǎn)載請標明出處:http://blog.csdn.net/ALENTAM/archive/2008/03/13/2178020.aspx

posted on 2010-03-26 20:27 shaker(太子) 閱讀(6016) 評論(0)  編輯 收藏 引用 所屬分類: C++
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            国产在线视频欧美| 裸体一区二区| 欧美国产日产韩国视频| 久久综合色一综合色88| 久久亚洲春色中文字幕| 欧美一区二区在线免费播放| 亚洲制服av| 久久本道综合色狠狠五月| 久久成人精品视频| 久久久不卡网国产精品一区| 久久综合亚洲社区| 欧美精品一区二区三区高清aⅴ| 欧美成人dvd在线视频| 欧美激情亚洲国产| 国产精品一区免费视频| 激情久久久久久久| 日韩一二三区视频| 欧美综合激情网| 亚洲激情在线观看| 亚洲综合电影| 蜜臀91精品一区二区三区| 欧美日韩久久不卡| 国内精品视频666| 99国产精品| 久久日韩精品| 一区二区欧美亚洲| 久久免费视频在线观看| 欧美视频一区二区三区…| 国产色产综合产在线视频| 亚洲欧洲日本国产| 久久riav二区三区| 亚洲另类春色国产| 久久九九免费视频| 国产伦精品一区二区三区高清| 亚洲国产综合视频在线观看| 欧美永久精品| 99视频一区二区| 美女黄网久久| 狠狠色综合网站久久久久久久| 亚洲综合好骚| 亚洲精品久久久蜜桃| 久久亚洲综合| 狠狠色噜噜狠狠色综合久 | 国产欧美日韩视频在线观看| 亚洲欧洲精品成人久久奇米网| 欧美一区二区三区四区高清| 亚洲精品国产精品乱码不99按摩| 久久久久久午夜| 国产欧美视频一区二区| 亚洲深夜影院| 亚洲日本中文字幕| 男女激情视频一区| 一区免费观看| 久久尤物电影视频在线观看| 午夜精品福利电影| 国产伦精品一区二区三区高清版| 亚洲视频在线观看视频| 最新成人av在线| 欧美电影免费观看网站| 久久亚洲综合网| 亚洲激情电影在线| 欧美成人中文| 亚洲剧情一区二区| 欧美激情一二区| 欧美成人a视频| 亚洲精品日产精品乱码不卡| 亚洲国产另类精品专区| 欧美成人午夜视频| 99视频精品全国免费| 一本色道**综合亚洲精品蜜桃冫| 欧美日韩中文另类| 欧美一进一出视频| 欧美在线一级va免费观看| 国语自产精品视频在线看8查询8| 久久在线免费观看视频| 久久久精品免费视频| 最新国产精品拍自在线播放| 日韩亚洲成人av在线| 国产精品美女在线| 久久三级福利| 欧美激情综合网| 亚洲综合首页| 欧美中文字幕视频在线观看| 亚洲国产婷婷综合在线精品 | 亚洲制服少妇| 国模一区二区三区| 亚洲福利视频二区| 国产精品一区二区久久| 久久人人97超碰国产公开结果| 欧美成人中文字幕在线| 亚洲一区二区三区四区在线观看 | 欧美日韩亚洲网| 午夜视频一区在线观看| 欧美在线观看你懂的| 亚洲激情午夜| 亚洲一二三区精品| 亚洲国产精品一区| 亚洲尤物在线视频观看| 亚洲高清不卡| 欧美一级免费视频| 999亚洲国产精| 久久久久国内| 欧美亚洲尤物久久| 欧美国产日本| 久久资源在线| 国产精品视频xxx| 亚洲国产精品传媒在线观看| 国产精品美女久久久久久免费| 裸体一区二区| 国产精品综合| 亚洲九九精品| 亚洲日本黄色| 久久精品亚洲一区| 欧美在线精品一区| 欧美视频在线观看免费| 欧美国产日本在线| 亚洲高清视频在线观看| 噜噜噜在线观看免费视频日韩 | 久久久国产视频91| 欧美日韩精品免费在线观看视频| 欧美sm重口味系列视频在线观看| 国产精品中文字幕欧美| 亚洲日本欧美天堂| 亚洲精品日韩精品| 久久一区二区三区超碰国产精品| 亚洲欧美日韩天堂一区二区| 欧美片网站免费| 欧美高清视频在线播放| 精品51国产黑色丝袜高跟鞋| 性欧美大战久久久久久久免费观看 | 美乳少妇欧美精品| 国产亚洲精久久久久久| 亚洲网站在线看| 亚洲欧美日韩爽爽影院| 欧美日韩精品不卡| 一区二区三区三区在线| 99re6热在线精品视频播放速度| 美日韩精品视频免费看| 美女网站久久| 亚洲激情不卡| 欧美精品一区三区在线观看| 欧美激情一区二区三级高清视频| 在线观看国产日韩| 欧美成人免费小视频| 亚洲国产精品一区二区第一页| 亚洲免费成人av电影| 欧美午夜电影在线| 午夜精品久久久久久久久| 欧美一级久久久久久久大片| 国产视频精品网| 久久野战av| 亚洲精选在线| 久久国产66| 91久久精品国产91久久| 欧美日韩一区精品| 午夜久久久久久久久久一区二区| 久久久久久久久久看片| 亚洲国产一区二区精品专区| 欧美日韩视频免费播放| 香蕉久久夜色精品国产使用方法| 欧美成人精品福利| 亚洲影院色在线观看免费| 国产毛片精品视频| 模特精品在线| 亚洲免费视频在线观看| 免费人成网站在线观看欧美高清| 亚洲精品视频免费| 国产欧美精品日韩精品| 另类天堂av| 亚洲一区日韩在线| 欧美成人蜜桃| 亚洲男女毛片无遮挡| 在线观看91精品国产麻豆| 欧美日韩国产成人在线观看| 欧美一乱一性一交一视频| 欧美国产大片| 亚洲欧美日韩在线播放| 一区在线视频观看| 欧美日韩在线影院| 可以免费看不卡的av网站| 性高湖久久久久久久久| 久久在线视频在线| 一区二区三区.www| 狂野欧美性猛交xxxx巴西| 亚洲永久在线| 亚洲欧洲日本在线| 韩国v欧美v日本v亚洲v| 国产精品久久久久一区二区三区| 久久噜噜亚洲综合| 午夜免费日韩视频| 亚洲视频在线一区| 亚洲精品欧美日韩专区| 蜜桃久久av| 久久久www成人免费无遮挡大片| 一区二区三区 在线观看视| 亚洲福利视频免费观看| 狠狠色综合网| 黑人巨大精品欧美一区二区| 国产欧美激情| 国产精品三级久久久久久电影|