欧美在线观看视频网站,亚洲熟妇色自偷自拍另类,啪啪伊人网,中文字幕第13亚洲另类,中文成人久久久久影院免费观看 ,精品人妻人人做人人爽,亚洲a视频

檢測和校正圖像中的紅眼的方法

文檔序號:6420759閱讀:230來源:國知局
專利名稱:檢測和校正圖像中的紅眼的方法
技術(shù)領(lǐng)域
本發(fā)明涉及圖像處理,并且特別涉及檢測和校正圖像中的紅眼的方法。
背景技術(shù)
紅眼是人的瞳孔周圍出現(xiàn)的不自然紅色調(diào)。它通常是由血管的閃光反射光引起的。目前,有許多校正紅眼的方法。有些方法要求用戶的干預(yù)。這樣對大多數(shù)用戶來說不便。有些方法可以自動地檢測和校正紅眼,但是它們在整幅圖像中搜索紅眼,并且因而需要更多時間。另外,現(xiàn)有檢測和校正紅眼的方法的準(zhǔn)確性不高。

發(fā)明內(nèi)容
本發(fā)明的目的是提供一種能快速檢測圖像中的紅眼,并且準(zhǔn)確校正檢測到的紅眼的方法。
為了實現(xiàn)以上目的,本發(fā)明提供一種檢測圖像中的紅眼的方法,其特征在于包括以下步驟識別所述圖像中的眼區(qū);識別所述眼區(qū)內(nèi)的第一數(shù)目的候選紅眼區(qū)域;縮小所述第一數(shù)目的候選紅眼區(qū)域,得到第二數(shù)目的候選紅眼區(qū)域,所述第二數(shù)目小于或等于所述第一數(shù)目;擴(kuò)大所述第二數(shù)目的候選紅眼區(qū)域,得到第三數(shù)目的候選紅眼區(qū)域,所述第三數(shù)目小于或等于所述第二數(shù)目;以及從所述第三數(shù)目的候選紅眼區(qū)域中選擇不多于一個的候選紅眼區(qū)域,作為所述眼區(qū)內(nèi)檢測到的紅眼。
按照本發(fā)明的方法,在臉部圖像中,或更具體地在臉部圖像中識別的眼區(qū)內(nèi),自動地檢測紅眼。因而,能快速和準(zhǔn)確地檢測紅眼。
由以下連同附圖對優(yōu)選實施例的描述,本發(fā)明的其他特點和優(yōu)點將更加明顯,附圖通過例子說明本發(fā)明的原理。


圖1是本發(fā)明的方法的示意流程圖;圖2是圖1步驟105的一個示例處理的示意流程圖;圖3是圖1步驟105的另一個示例處理的示意流程圖;圖4是圖1步驟106的一個示例處理的示意流程圖;圖5是圖1步驟107的一個示例處理的示意流程圖;圖6是圖1步驟107的一個示例處理的示意流程圖;圖7是圖1步驟108的一個示例處理的示意流程圖;圖8是圖1步驟110的一個示例處理的示意流程圖;圖9A表示一幅包括兩個紅眼的圖像;圖9B表示檢測到兩個紅眼;圖9C表示校正兩個紅眼;圖9D表示檢測到的紅眼的灰度圖像;圖9E表示在對圖9D的灰度圖像執(zhí)行高斯平滑處理之后的結(jié)果灰度圖像;以及圖10示意表示一個圖像處理系統(tǒng),其中能實現(xiàn)圖1至圖8所示的各處理。
具體實施例方式
在以下描述中,關(guān)于怎樣識別候選人臉區(qū)域、怎樣識別人臉中的眼區(qū),能參考由相同申請人于2000年9月15日提交的第00127067.2號中國專利申請,由相同申請人于2001年9月6日提交的第01132807.X號中國專利申請,由相同申請人于2002年12月13日提交的第02155468.4號中國專利申請,由相同申請人于2002年12月30日提交的第021600163.3號中國專利申請,由相同申請人于2003年6月18日提交的第03137345.3號中國專利申請等。這些申請這里參考引入。然而,在這些申請中公開的識別候選人臉區(qū)域的方法和識別眼區(qū)的方法對本發(fā)明不構(gòu)成限制。本發(fā)明可以利用任何識別候選人臉區(qū)域的常規(guī)方法或識別圖像之內(nèi)的眼區(qū)的方法。
圖1是本發(fā)明的方法的示意流程圖。流程在步驟101開始。然后在步驟102,在待處理圖像之內(nèi)識別一個候選人臉區(qū)域。
然后,在步驟103,在步驟102識別的候選人臉區(qū)域中識別兩個眼區(qū)。這兩個眼區(qū)是左眼區(qū)和右眼區(qū)。
如上所述,為了實現(xiàn)步驟102和103,本發(fā)明能使用任何識別候選人臉區(qū)域和識別人臉中眼區(qū)的常規(guī)方法。
其次,在步驟104,將兩個眼區(qū)中的一個設(shè)為當(dāng)前眼區(qū),并且首先經(jīng)受處理(步驟105至108)。
在步驟105,在當(dāng)前眼區(qū)之內(nèi)識別當(dāng)前眼區(qū)內(nèi)的第一數(shù)目的候選紅眼區(qū)域。
為了識別一個眼區(qū)之內(nèi)的一個候選紅眼區(qū)域,考慮眼區(qū)內(nèi)的像素的特征值。在本發(fā)明中,將紅眼內(nèi)包括的一個像素,即一個具有紅眼特征的像素稱為“紅眼像素”。
在步驟105,例如考慮到了眼區(qū)內(nèi)像素的顏色方差或紋理,或顏色方差和紋理的組合。圖2主要涉及考慮眼區(qū)內(nèi)的像素的顏色方差。圖3主要涉及考慮眼區(qū)內(nèi)的像素的紋理。
圖2和圖3所示流程的任何一個可以用來識別當(dāng)前眼區(qū)內(nèi)的第一數(shù)目的候選紅眼區(qū)域,并且以下在本說明書中將非常詳細(xì)地描述。
優(yōu)選地,如果組合使用,圖2和圖3的兩個流程將極大地增加本發(fā)明的方法的準(zhǔn)確性。更優(yōu)選地,如果首先執(zhí)行圖3流程,并且根據(jù)圖3流程的結(jié)果執(zhí)行圖2流程,本發(fā)明的方法將更省時。
在圖1步驟105之后,為步驟106。
在步驟106,縮小第一數(shù)目的候選紅眼區(qū)域。結(jié)果,得到第二數(shù)目的候選紅眼區(qū)域。
按照本縮小處理,為第一數(shù)目的候選紅眼區(qū)域中每個候選紅眼區(qū)域中的每個像素至少估計一個特征值。如果估計的特征值不滿足對紅眼像素設(shè)置的標(biāo)準(zhǔn),則將被評估的像素從相關(guān)候選紅眼區(qū)域中除去。因而,使第一數(shù)目的候選紅眼區(qū)域中的大多數(shù)的面積減少。如果一個候選紅眼區(qū)域內(nèi)包括的所有像素被除去,則這個候選紅眼區(qū)域不存在,并且不再考慮。
因而,第二數(shù)目,即在執(zhí)行步驟106之后的候選紅眼區(qū)域的總數(shù),可能小于第一數(shù)目,即在執(zhí)行步驟106之前的候選紅眼區(qū)域的總數(shù)。圖4表示使候選紅眼區(qū)域縮小的一例,并且將在以下詳細(xì)描述。
在步驟106之后,進(jìn)行到步驟107。
在步驟107,擴(kuò)大第二數(shù)目的候選紅眼區(qū)域。結(jié)果,得到第三數(shù)目的候選紅眼區(qū)域。
在本步驟,考慮第二數(shù)目的候選紅眼區(qū)域各自的邊界像素。“邊界像素”是指位于候選紅眼區(qū)域邊緣的像素。如果一個邊界像素附近的像素滿足為紅眼像素設(shè)置的標(biāo)準(zhǔn),則將這些像素包括在相關(guān)候選紅眼區(qū)域中。因而,使第二數(shù)目的候選紅眼區(qū)域的大多數(shù)的面積增加,并且不可避免地使有些候選紅眼區(qū)域相互合并。這樣引入步驟107的另一個功能。
步驟107的另一個功能是,有選擇地除去合并的候選紅眼區(qū)域,有選擇地組合合并的候選紅眼區(qū)域,或有選擇地保持合并的候選紅眼區(qū)域中的一個而除去其他候選紅眼區(qū)域。
除去的候選紅眼區(qū)域不再加以考慮。
因而,第三數(shù)目,即在執(zhí)行步驟107之后的候選紅眼區(qū)域的總數(shù),可能小于第二數(shù)目,即在執(zhí)行步驟107之前的候選紅眼區(qū)域的總數(shù)。圖5和圖6表示擴(kuò)大候選紅眼區(qū)域的一例,并且將在以下詳細(xì)描述。
步驟107之后是步驟108。
在步驟108,將不多于一個的候選紅眼區(qū)域選擇為該眼區(qū)內(nèi)檢測到的一個紅眼。
在步驟108,估計第三數(shù)目的候選紅眼區(qū)域內(nèi)的像素的大量特征值。根據(jù)估計值,除去第三數(shù)目的候選紅眼區(qū)域中的大多數(shù)。然后對剩下的候選紅眼區(qū)域評分,并且僅對具有最大得分的候選紅眼區(qū)域作進(jìn)一步考慮。如果僅有具有最大得分的候選紅眼區(qū)域滿足標(biāo)準(zhǔn),則將它選擇為當(dāng)前眼區(qū)內(nèi)檢測到的紅眼。否則,當(dāng)前眼區(qū)內(nèi)沒有檢測到紅眼。圖7表示選擇不多于一個的候選紅眼區(qū)域的例子,并且將在以下詳細(xì)描述。
然后在步驟109,判定在步驟108是否選擇一個候選紅眼區(qū)域。如果判定結(jié)果為“是”,處理轉(zhuǎn)到步驟110;否則轉(zhuǎn)到步驟111。
在步驟110,校正所選擇的候選紅眼區(qū)域,即檢測到的紅眼。圖8詳細(xì)描述校正紅眼的處理。在步驟110之后,處理轉(zhuǎn)到步驟111。
在步驟111,判定兩個眼區(qū)是否都考慮了。如果判定結(jié)果為“是”,處理轉(zhuǎn)到步驟113;否則轉(zhuǎn)到步驟112。
在步驟112,設(shè)定另一眼區(qū)為當(dāng)前眼區(qū),處理轉(zhuǎn)到步驟105。
在步驟111,處理結(jié)束。
圖2是圖1步驟105的一個示例處理的示意流程圖。
圖2流程基于顏色方差理論。一般地,紅眼內(nèi)像素的亮度和顏色激烈變化。以(x,y)為中心的眼區(qū)域的特性可以用下列公式(1)來表示variance(x,y)=1|Rx,y|Σr∈Rx,y||r-1|Pr|ΣP∈PrP||2---(1)]]>其中(x,y)是像素的坐標(biāo);Rx,y是以(x,y)為中心的眼區(qū)域;|Rx,y|是眼區(qū)域Rx,y的面積,即眼區(qū)域Rx,y內(nèi)的像素數(shù);Pr是以(x,y)為中心的瞳孔區(qū)域;|Pr|是瞳孔區(qū)域Pr的面積,即瞳孔區(qū)域Pr內(nèi)的像素數(shù);r是眼區(qū)域Rx,y內(nèi)的一個像素P是瞳孔區(qū)域Pr內(nèi)的一個像素。
對于候選人臉區(qū)域內(nèi)的各像素,限定一個眼區(qū)域和一個瞳孔區(qū)域,兩者以這個像素為中心。然后,對這個像素使用以上公式(1)計算方差值。如果計算的方差值大于一個對應(yīng)閾值,則認(rèn)為這個像素是一個紅眼像素。
實際上,對各像素計算兩個方差值。這兩個方差值分別稱為水平顏色方差值和垂直顏色方差值。當(dāng)兩個方差值都大于它們的對應(yīng)閾值時,則認(rèn)為該像素是一個紅眼像素。
如圖2所示,處理在步驟201開始。在步驟202,將變量R設(shè)置為1。在步驟203,將另一個變量C設(shè)置為1。
在步驟204,以像素(R,C)為中心,限定一個瞳孔區(qū)域。
為了限定人臉中的一個瞳孔區(qū)域,人臉的寬度、人臉的高度、眼區(qū)域的寬度、眼區(qū)域的高度、瞳孔區(qū)域的寬度、瞳孔區(qū)域的高度可以滿足以下關(guān)系(1)眼的寬度=0.2*臉的寬度;(2)眼的高度=0.2*臉的高度;(3)瞳孔的寬度=0.1*臉的寬度;(4)瞳孔的高度=0.1*臉的高度。
在步驟205,計算在步驟204限定的瞳孔區(qū)域的r(紅)值、g(綠)值和b(藍(lán))值。
在本發(fā)明中,區(qū)域的r值定義為該區(qū)域中包括的所有像素的r值的平均;區(qū)域的g值定義為該區(qū)域中包括的所有像素的g值的平均;以及區(qū)域的b值定義為該區(qū)域中包括的所有像素的b值的平均。
因而,步驟205對應(yīng)于以上公式(1)中的1|Pr|ΣP∈PrP.]]>然后在步驟206,仍以像素(R,C)為中心,限定一個水平眼區(qū)域。這里,水平眼區(qū)域的寬度可以是一個眼區(qū)域的寬度,并且水平眼區(qū)域的高度可以是一個瞳孔區(qū)域的高度。
其次,在步驟207,對在步驟206限定的水平眼區(qū)域,使用以上公式(1)計算水平顏色方差ScatterH,其中Rx,y是水平眼區(qū)域。
在步驟208,判定ScatterH是否大于第一閾值。第一閾值的范圍為600至2500,并且優(yōu)選地為1200。
如果步驟208的判定結(jié)果為“否”,處理轉(zhuǎn)到步驟213;否則轉(zhuǎn)到步驟209。
在步驟209,仍以像素(R,C)為中心,限定一個垂直眼區(qū)域。這里,垂直眼區(qū)域的寬度可以是一個瞳孔區(qū)域的寬度,并且垂直眼區(qū)域的高度可以是一個眼區(qū)域的高度。
其次,在步驟210,對在步驟209限定的垂直眼區(qū)域,使用以上公式(1)計算垂直顏色方差ScatterV,其中Rx,y是垂直眼區(qū)域。
在步驟211,判定ScatterV是否大于第二閾值。第二閾值的范圍為600至2500,并且優(yōu)選地為1200。
如果步驟211的判定結(jié)果為“否”,處理轉(zhuǎn)到步驟213;否則轉(zhuǎn)到步驟212。
在步驟212,將候選人臉區(qū)域內(nèi)的(R,C)處的像素標(biāo)記為一個紅眼像素。然后,處理轉(zhuǎn)到步驟213。
在步驟213,在使變量C遞增之后,判定C是否大于候選人臉區(qū)域的寬度。
如果步驟213的判定結(jié)果為“否”,處理轉(zhuǎn)到步驟204;否則轉(zhuǎn)到步驟214。
在步驟214,在使變量R遞增之后,判定R是否大于候選人臉區(qū)域的高度。
如果步驟214的判定結(jié)果為“否”,處理轉(zhuǎn)到步驟203;否則轉(zhuǎn)到步驟215。
在步驟215,處理結(jié)束。
通過以上步驟201至215,可以將多個像素標(biāo)記為一個眼區(qū)內(nèi)的紅眼像素。這些紅眼像素可以構(gòu)成圖1步驟105中的第一數(shù)目的候選紅眼區(qū)域。
圖3是圖1步驟105的另一個示例處理的示意流程圖。
圖3流程基于紋理理論。表示明顯紋理特征的像素認(rèn)為是紅眼像素。按照形態(tài)學(xué),開運算和閉運算具有不同結(jié)果。因而,通過使用不同的模板尺寸,能將開運算和閉運算用來提取興趣區(qū)域(例如,一個紅眼區(qū)域)。為了說明開運算和閉運算,可以參考Digital ImageProcessing,Kenneth R.Castleman,Prentice Hall Inc.,Copyright 1996。
如圖3所示,處理在步驟301開始。然后,在步驟302,對候選人臉區(qū)域產(chǎn)生一幅灰度圖像。根據(jù)候選人臉區(qū)域內(nèi)的對應(yīng)像素(x,y)的r(紅)、g(綠)和b(藍(lán))值,計算灰度圖像中像素(x,y)的灰度,它是一幅彩色圖像。像素的灰度定義為r-max(g,b)(2)然后,在步驟303,通過對在步驟302產(chǎn)生的灰度圖像執(zhí)行閉運算,產(chǎn)生一幅閉圖像。在閉運算中,使用3*3模板。
其次,在步驟304,通過對在步驟302產(chǎn)生的灰度圖像執(zhí)行開運算,產(chǎn)生一幅開圖像。在開運算中,使用9*9模板。
然后,在步驟305,通過從閉圖像中減去開圖像,產(chǎn)生一幅目標(biāo)圖像。
在步驟306,對目標(biāo)圖像執(zhí)行高斯平滑處理。這里,在目標(biāo)圖像中,各像素具有一個灰度值。如果目標(biāo)圖像中一個像素的灰度大于灰度的閾值,則認(rèn)為候選人臉區(qū)域內(nèi)對應(yīng)像素是一個紅眼像素。
特別地,在步驟307,將變量R設(shè)置為1。在步驟308,將變量C設(shè)置為1。
在步驟309,判定目標(biāo)圖像中(R,C)處的像素的灰度是否大于第三閾值。第三閾值為目標(biāo)圖像中像素的最大灰度值的50%至70%的范圍內(nèi),并且優(yōu)選地為目標(biāo)圖像中像素的最大灰度值的53%。
如果步驟309的判定結(jié)果為“否”,處理轉(zhuǎn)到步驟311;否則轉(zhuǎn)到步驟310。
在步驟310,將候選人臉區(qū)域內(nèi)(R,C)處的像素標(biāo)記為一個紅眼像素。當(dāng)然,為了以后使用目標(biāo)圖像,目標(biāo)圖像中(R,C)處的像素可以設(shè)置為255。
然后,處理轉(zhuǎn)到步驟311。
在步驟311,在使變量C遞增之后,判定C是否大于候選人臉區(qū)域的寬度。
如果步驟311的判定結(jié)果為“否”,處理轉(zhuǎn)到步驟309;否則轉(zhuǎn)到步驟312。
在步驟312,在使變量R遞增之后,判定R是否大于候選人臉區(qū)域的高度。
如果步驟312的判定結(jié)果為“否”,處理轉(zhuǎn)到步驟308;否則轉(zhuǎn)到步驟313。
在步驟313,處理結(jié)束。
如上參考圖1所述,圖3和圖2的流程可以一起使用。通常,首先執(zhí)行圖3的處理。如果由圖3的處理將一個像素檢測為紅眼像素,那么用圖2的處理來估計該像素。僅當(dāng)像素估計為一個紅眼像素時,這個像素才可能認(rèn)為是一個紅眼像素。在執(zhí)行圖2處理之前,由于圖3處理過濾大量非紅眼像素,所以減少了大量計算操作。
圖4是圖1步驟106的一個示例處理的示意流程圖。
處理在步驟401開始。
在步驟402,對候選人臉區(qū)域產(chǎn)生一幅雙灰度圖像。這個雙灰度圖像也可以是圖3處理的結(jié)果,圖2處理的結(jié)果,或圖3和圖2處理組合的結(jié)果。
在該雙灰度圖像中,具有255灰度的像素對應(yīng)于候選人臉區(qū)域內(nèi)標(biāo)記為紅眼像素的像素,并且具有0灰度的像素對應(yīng)于候選人臉區(qū)域內(nèi)沒有標(biāo)記為紅眼像素的像素。
在步驟402,對在步驟402產(chǎn)生,或由圖1步驟105產(chǎn)生的灰度圖像,執(zhí)行一個“標(biāo)號分割”處理。按照“標(biāo)號分割”處理,識別紅眼像素塊,并且確定紅眼像素塊的數(shù)目。
在步驟404,將變量I設(shè)置為1。
在步驟405,計算第I紅眼像素塊的面積(即第I紅眼像素塊內(nèi)的像素數(shù)),并且判定計算的面積是否小于第四閾值。第四閾值是候選人臉區(qū)域的高度、寬度最小值的一定倍數(shù)的平方。這里的一定倍數(shù)在0.05至0.02范圍內(nèi),并且優(yōu)選地為0.1。
例如,如果候選人臉區(qū)域的高度為189,并且候選人臉區(qū)域的寬度為153,則高度和寬度中較小一個為153。令一定倍數(shù)為0.1。0.1乘153得15.3。取整數(shù)“15”。15的平方為225。因而,本候選人臉區(qū)域的第四閾值可以取值“225”。
這里有另一個例子。假定候選人臉區(qū)域的高度為135,并且候選人臉區(qū)域的寬度為109。高度和寬度中較小一個為109。0.1乘109得10.9。取整數(shù)“10”。10的平方為100。因而,本候選人臉區(qū)域的第四閾值可以取值“100”。
如果步驟405的判定結(jié)果為“是”,處理轉(zhuǎn)到步驟410(也就是,將第I紅眼像素塊保持為原樣);否則轉(zhuǎn)到步驟407。
在步驟407,對第I紅眼塊內(nèi)的各紅眼像素,在候選人臉區(qū)域內(nèi)計算第一紅度。一個像素的第一紅度定義為第一紅度=r/(r+g+b)(3)其中r、g和b是指像素的r(紅)、g(綠)和b(藍(lán))值。
可選擇地,與一個像素的3*3像素鄰域?qū)?yīng)的區(qū)域的第一紅度也可以用作該像素的一個指標(biāo)。
在本發(fā)明中,一個區(qū)域的第一紅度定義為該區(qū)域包括的所有像素的第一紅度的平均。
在步驟408,根據(jù)在步驟407計算的第一紅度的值,為第I紅眼像素塊計算一個臨時閾值。
例如,可以首先對第一紅度值按降序排序,形成一個數(shù)組。并且將數(shù)組中特定位置的值認(rèn)為是臨時閾值。
在步驟409,如果一個像素的第一紅度不大于臨時閾值,將這個像素的灰度從255變?yōu)?。也就是,如果灰度圖像中其對應(yīng)像素的第一紅度不大于臨時閾值,原來是紅眼像素的像素不再被認(rèn)為是紅眼像素。
在步驟410,在使變量I遞增之后,判定I是否大于紅眼像素塊數(shù)。
如果步驟410的判定結(jié)果為“否”,處理轉(zhuǎn)到步驟405;否則轉(zhuǎn)到步驟411。
在步驟411,處理結(jié)束。
圖5和圖6是圖1步驟107的一個示例處理的示意流程圖。圖1步驟107能大致分成三個子步驟。在第一子步驟,對于紅眼像素塊的邊界像素附近的像素,如果附近的這些像素滿足預(yù)定條件,則通過吸收這些像素來增加紅眼像素塊的主體。在第二子步驟,對于與紅眼像素塊的邊界像素相臨的像素,如果這些與邊界像素相臨的像素滿足預(yù)定條件,則通過吸收這些像素來增加紅眼像素塊的主體。第三子步驟是防止紅眼像素塊相互合并,并且除去不滿足預(yù)定條件的紅眼像素塊。圖5示例表示第一和第二子步驟,以及圖6示例表示第三子步驟。
如圖5所示,處理在步驟501開始。在步驟502,將變量I設(shè)置為1。在步驟503,計算第I紅眼像素塊的第一紅度和色調(diào)。
如本說明書前面定義,一個塊(它其實是一個區(qū)域)的第一紅度定義為該塊包括的所有像素的第一紅度的平均。
一個像素的第一紅度如上由公式(3)定義。
一個塊(區(qū)域)的色調(diào)定義為該塊(區(qū)域)包括的所有像素的色調(diào)值的平均。
一個像素的色調(diào)定義為色調(diào)=min(h,360-h)(4)其中h是指候選人臉區(qū)域內(nèi)像素的色調(diào)值。
然后在步驟504,定位第I紅眼像素塊的一個邊界像素。
在步驟505,計算邊界像素的亮度。一個像素的亮度定義為亮度=(r+g+b)/3(5)其中r、g和b是指像素的r(紅)、g(綠)和b(藍(lán))值。
在步驟506,判定在步驟505計算的亮度是否大于第五閾值。第五閾值在80至120的范圍內(nèi),并且優(yōu)選地為100。
如果步驟506的判定結(jié)果為“是”,處理轉(zhuǎn)到步驟509;否則轉(zhuǎn)到步驟507。
在步驟507,判定在步驟505計算的亮度是否大于第六閾值。第六閾值在40至60的范圍內(nèi),并且優(yōu)選地為50。
如果步驟507的判定結(jié)果為“是”,處理轉(zhuǎn)到步驟508;否則轉(zhuǎn)到步驟510。
在步驟509,對于第I紅眼像素塊內(nèi)與邊界像素相臨的每個像素,如果一個與邊界像素間隔一個像素的對應(yīng)像素滿足第一條件,則將該與邊界像素相臨的像素添加到第I紅眼像素塊中。
例如,第I紅眼像素塊的一個邊界像素的坐標(biāo)為(i,j)。步驟509的功能是檢查在(i+2,j)、(i-2,j)、(i,j-2)和(i,j+2)的像素是否滿足第一條件。
例如,如果在(i+2,j)的像素滿足第一條件,則將在(i+1,j)的像素添加到第I紅眼像素塊中。
設(shè)邊界像素為像素A,并且與像素A間隔一個像素的像素為像素B,以及將像素A與像素B之間的像素(即與邊界像素A相臨的一個對應(yīng)像素)添加到第I紅眼像素塊中。那么第一條件可以這樣定義,以便像素A和像素B滿足下列要求(1)像素B的飽和度大于0.9乘像素A的飽和度。這里,系數(shù)0.9可以在0.7至1范圍內(nèi)。
(2)像素B的第一紅度大于0.8乘第I紅眼像素塊的第一紅度。這里,系數(shù)0.8可以在0.7至0.9范圍內(nèi)。
(3)像素B的色調(diào)小于5乘第I紅眼像素塊的色調(diào)(在步驟503計算)。這里,系數(shù)5可以在2至10范圍內(nèi)。
在步驟509之后,為步驟510。
步驟508與步驟509類似。唯一不同是在步驟508估計第二條件。
設(shè)邊界像素為像素A,并且與像素A間隔一個像素的像素為像素B,以及將像素A與像素B之間的像素(即與邊界像素A相臨的一個對應(yīng)像素)添加到第I紅眼像素塊中。那么第二條件可以這樣定義,以便像素A和像素B滿足下列要求(1)像素B的飽和度大于1乘像素A的飽和度,并且像素B與像素A的亮度之間的絕對差小于0.1乘像素A的亮度。這里,系數(shù)1可以在0.8至1.2范圍內(nèi),并且系數(shù)0.1可以在0至0.3范圍內(nèi)。
(2)像素B的第一紅度大于0.8乘第I紅眼像素塊的第一紅度。這里,系數(shù)0.8可以在0.7至0.9范圍內(nèi)。
(3)像素B的色調(diào)小于5乘第I紅眼像素塊的色調(diào)(在步驟503計算)。這里系數(shù)5可以在2至10范圍內(nèi)。
在步驟507、508或509之后,為步驟510。
在步驟510,判定像素的添加是否滿足第五條件。
設(shè)本次(即從步驟505到步驟509的當(dāng)前循環(huán))添加到第I紅眼像素塊中的像素數(shù)為“count2”,上次(即從步驟505到步驟509的前次循環(huán))添加到第I紅眼像素塊中的像素數(shù)為“count1”,擴(kuò)大第I紅眼像素塊的次數(shù)為“times”。
那么,添加像素所滿足的第五條件可以這樣定義(1)count1/count2大于0且小于1。這里值“0”是一個在0至0.5范圍內(nèi)的閾值,并且值“1”是一個在0.8至2范圍內(nèi)的閾值。
(2)count2小于4乘眼區(qū)域的寬度,其中眼區(qū)域的寬度為人臉區(qū)域的寬度和人臉區(qū)域的高度中的最小值乘以1/10。這里,值“4”是一個在1至8范圍內(nèi)的閾值,值“1/10”是一個在1/5至1/15范圍內(nèi)的閾值。
(3)times小于1/2乘眼區(qū)域的寬度。這里,值“1/2”是一個在1/10至1范圍內(nèi)的閾值。
如果步驟510的判定結(jié)果為“是”,處理轉(zhuǎn)到步驟511;否則轉(zhuǎn)到步驟512。
在步驟511,判定是否定位另一個邊界像素。如果步驟511的判定結(jié)果為“是”,處理轉(zhuǎn)到步驟505;否則轉(zhuǎn)到步驟512。
步驟512的處理與步驟505到511的處理類似。步驟512的主要目的是,對于每個與紅眼像素塊的邊界像素相臨的像素,如果這個像素滿足第三條件(類似于第一條件)或第四條件(類似于第二條件),則將這個像素添加到該紅眼像素塊中。
例如,一個紅眼像素塊的一個邊界像素的坐標(biāo)為(i,j)。步驟512的功能之一是檢查在(i+1,j)、(i-1,j)、(i,j-1)和(i,j+1)的像素是否滿足第三條件(或第四條件)。
例如,如果在(i+1,j)的像素滿足第三條件,將在(i+1,j)的像素添加到第I紅眼像素塊中。
然后,在步驟513,在使變量I遞增之后,判定I是否大于紅眼像素塊數(shù)。如果步驟513的判定結(jié)果為“否”,處理轉(zhuǎn)到步驟503;否則轉(zhuǎn)到步驟514。
在步驟504,處理結(jié)束。
如圖6所示,處理在步驟601開始。在步驟602,將變量I設(shè)置為1。在步驟603,判定第I紅眼像素塊是否與另一個紅眼像素塊,比方說塊A相合并。步驟603可以實現(xiàn)為檢查一個紅眼像素塊內(nèi)的一個像素的3*3像素鄰域是否包括另一個紅眼像素塊內(nèi)的一個像素。如果是,將兩個紅眼像素塊相互合并。
如果步驟603的判定結(jié)果為“否”,處理轉(zhuǎn)到步驟611;否則轉(zhuǎn)到步驟604。
在步驟604,對第I紅眼像素塊計算特征值C1,并且對塊A計算特征值C2。
紅眼像素塊的特征值定義為紅眼像素塊的向量[第一紅度,色調(diào),飽和度,Y通道值,Cb通道值,Cr通道值]和權(quán)向量
的點積。
在以上向量中,塊的第一紅度、塊的色調(diào)已在本說明書中前面定義。
一個塊(區(qū)域)的飽和度定義為該塊(區(qū)域)包括的所有像素的飽和度值的平均。
一個塊(區(qū)域)的Y通道值定義為該塊(區(qū)域)包括的所有像素的Y通道值的平均。
一個塊(區(qū)域)的Cb通道值定義為該塊(區(qū)域)包括的所有像素的Cb通道值的平均。
其次,在步驟6051,判定C1是否小于或等于第八閾值。這里,第八閾值使用費舍爾分類法通過訓(xùn)練而得到(R.A.Fisher,“The Use ofMultiple Measures in Taxonomic Problems,”Ann.Eugenics,1936)。第八閾值在0.5至1.5范圍內(nèi),并且優(yōu)選地為0.835。
如果步驟6051的判定結(jié)果為“否”,處理轉(zhuǎn)到步驟6052;否則轉(zhuǎn)到步驟6091。
在步驟6052,判定C2是否小于或等于第八閾值。
如果步驟6052的判定結(jié)果為“否”,處理轉(zhuǎn)到步驟606;否則轉(zhuǎn)到步驟6092。
在步驟606,計算C1與C2之間的絕對差C3。然后,在步驟607,判定C3是否大于第九閾值。
如果步驟607的判定結(jié)果為“是”,處理轉(zhuǎn)到步驟610;否則轉(zhuǎn)到步驟608。
在步驟608,除去具有C1和C2中較小值的紅眼像素塊。也就是,除去的塊不再認(rèn)為是一個紅眼像素塊。然后,步驟轉(zhuǎn)到步驟611。
在步驟610,將第I紅眼像素塊和塊A組合成一個塊。然后處理轉(zhuǎn)到步驟611。
在步驟6091,除去第I紅眼像素塊。也就是,第I塊不再認(rèn)為是紅眼像素塊。然后處理轉(zhuǎn)到步驟6053。
在步驟6053,判定C2是否小于或等于第八閾值。
如果步驟6053的判定結(jié)果為“否”,處理轉(zhuǎn)到步驟611;否則轉(zhuǎn)到步驟6092。
在步驟6092,除去塊A。也就是,塊A不再認(rèn)為是紅眼像素塊。然后處理轉(zhuǎn)到步驟611。
在步驟611,在使變量I遞增之后,判定I是否大于紅眼像素塊數(shù)。如果步驟611的判定結(jié)果為“否”,處理轉(zhuǎn)到步驟603;否則轉(zhuǎn)到步驟612。
在步驟612,處理結(jié)束。
在圖6處理之后,在候選人臉區(qū)域內(nèi)識別多個紅眼像素塊。各紅眼像素塊與候選人臉區(qū)域內(nèi)的一個候選紅眼區(qū)域相對應(yīng)。
圖7是圖1步驟108的一個示例處理的示意流程圖。圖7的目的是根據(jù)多個候選紅眼區(qū)域各自的紅度、飽和度、色調(diào)、Cr通道值、Cb通道值、Y方差、紅度方差、色調(diào)方差、r方差中的至少一個,選擇不多于一個的候選紅眼區(qū)域。
區(qū)域的飽和度、區(qū)域的色調(diào)和區(qū)域的Cb通道值已在本說明書前面定義。區(qū)域的Cr通道值定義為該區(qū)域包括的所有像素的Cr通道值的平均。這里,Cr是顏色空間(Y,Cb,Cr)內(nèi)的一個通道。
本實施例包含三種類型的紅度,它們是第一紅度、第二紅度和第三紅度。一個像素的第一紅度和一個區(qū)域的第一紅度已在本說明書中前面定義。第二紅度和第三紅度將做如下說明。
如圖7所示,處理在步驟701開始。在步驟702,將變量I設(shè)置為1。在步驟703,計算第I紅眼像素塊的第一紅度、第二紅度、第三紅度、飽和度值和Cr通道值。
如本說明書前面定義,一個像素的第一紅度定義為r/(r+g+b)(即公式(3))。并且一個塊(即一個區(qū)域)的第一紅度定義為該塊(區(qū)域)包括的所有像素的第一紅度的平均。
一個像素的第二紅度由公式(6)定義第二紅度=r2/(r2+g2+b2)(6)其中r、g和b是指像素的r(紅)、g(綠)和b(藍(lán))值。
一個塊(即一個區(qū)域)的第二紅度定義為該塊(區(qū)域)包括的所有像素的第二紅度的平均。
一個像素的第三紅度由公式(7)定義第三紅度=r-max(g,b)(7)一個塊(即一個區(qū)域)的第三紅度定義為該塊(區(qū)域)包括的所有像素的第三紅度的平均。
在步驟703之后,處理轉(zhuǎn)到步驟704。在步驟704,判定在步驟703計算的所有以上值是否在各自范圍內(nèi)。
例如,一個塊的第一紅度應(yīng)該大于一個在0.3至0.7范圍內(nèi),并且優(yōu)選地為0.37的閾值。
一個塊的第二紅度應(yīng)該大于一個在0.3至0.7范圍內(nèi)并且優(yōu)選地為0.415的閾值。
一個塊的第三紅度應(yīng)該大于一個在1至100范圍內(nèi)并且優(yōu)選地為11的閾值。
一個塊的飽和度值應(yīng)該大于一個在0.1至0.5范圍內(nèi)并且優(yōu)選地為0.12的閾值。
一個塊的Cr通道值應(yīng)該大于一個在80至200并且優(yōu)選地為138的閾值。
如果步驟704的判定結(jié)果為“是”,處理轉(zhuǎn)到步驟705;否則轉(zhuǎn)到步驟706。
在步驟706,除去第I紅眼塊。也就是,第I紅眼塊不再認(rèn)為是一個紅眼像素塊。然后處理轉(zhuǎn)到步驟707。
在步驟705,對于第I紅眼像素塊,根據(jù)這個塊的第二紅度、這個塊的Cb通道值、這個塊的Y方差、這個塊的第三紅度方差、這個塊的第二紅度方差,以及這個塊的色調(diào)、這個塊的色調(diào)方差、這個塊的r方差和這個塊的第一紅度,計算得分。
一個紅眼像素塊的得分按下列方式計算(1)得到這個塊的第二紅度、這個塊的Cb通道值、這個塊的Y方差、這個塊的第三紅度方差、這個塊的第二紅度方差、這個塊的色調(diào)、這個塊的色調(diào)方差、這個塊的r方差、這個塊的第一紅度,并且根據(jù)這些值形成一個九維向量。
(2)通過對一個訓(xùn)練集執(zhí)行費舍爾分類法和選擇法,得到一個權(quán)向量{0.35352,0.00177666,-0.000882568,0.00124642,0.337243,0.00010886,-0.000689163,0.000666636,-0.303867}。
(3)計算(1)中的向量和(2)中的向量的內(nèi)積,并且對紅眼像素塊得到一個得分。
在步驟705之后,為步驟707。
在步驟707,在使變量I遞增之后,判定I是否大于紅眼像素塊數(shù)。如果步驟707的判定結(jié)果為“否”,處理轉(zhuǎn)到步驟703;否則轉(zhuǎn)到步驟708。
在步驟708,定位具有最大得分的紅眼像素塊。
在步驟709,判定所定位的紅眼像素塊是否大于第十閾值。第十閾值在0.2至0.5范圍內(nèi),并且優(yōu)選地為0.32。第十閾值使用費舍爾分類法通過訓(xùn)練得到。
如果步驟709的判定結(jié)果為“是”,處理轉(zhuǎn)到步驟710;否則轉(zhuǎn)到步驟711。
在步驟710,僅保持具有最大得分的紅眼像素塊,而除去其他紅眼像素塊。也就是,選擇一個候選紅眼區(qū)域。
在步驟711,除去所有紅眼像素。也就是,無選擇紅眼區(qū)域。
在步驟712,處理結(jié)束。
圖8是圖1步驟110的一個示例處理的示意流程圖,即校正紅眼的處理。
在圖8例子中,通過將各像素的R、G、B值改為新R、G、B值,校正紅眼區(qū)域內(nèi)的各像素。
如圖8所示,處理在步驟801開始。在步驟802,對由先前檢測步驟得到的灰度圖像,執(zhí)行高斯平滑處理。
在步驟803,將變量I設(shè)置為1。
在步驟804,判定灰度圖像中第I像素的灰度是否為0。
如果步驟804的判定結(jié)果為“是”,處理轉(zhuǎn)到步驟813;否則轉(zhuǎn)到步驟805。
在步驟805,對于候選人臉區(qū)域內(nèi)的對應(yīng)像素,計算第二紅度P1。
實際上,第二紅度P1計算為P1=r2/(r2+g2+b2)+c1 (8)其中c1是一個在
范圍內(nèi)的經(jīng)驗常數(shù)。如果P1>1,設(shè)P1=1。因而,P1在
范圍內(nèi)。
在步驟806,對第I像素計算一個指標(biāo)P2。指標(biāo)P2指示第I像素離紅眼區(qū)域的邊界有多遠(yuǎn)。一個像素的P2值越小,該像素與紅眼區(qū)域的邊界之間的距離越小。
實際上,一個像素的指標(biāo)P2計算為P2=nGray/10+c2 (9)其中nGray是灰度圖像中像素的灰度,以及c2是
范圍內(nèi)的一個經(jīng)驗常數(shù)。如果P2>1,設(shè)P1=1。因而,P2在
范圍內(nèi)。
在步驟807,校正系數(shù)P計算為P=P1*P2 (10)在步驟808,判定P是否等于0。如果步驟808的判定結(jié)果為“是”,處理轉(zhuǎn)到步驟813;否則轉(zhuǎn)到步驟809。
在步驟809,將第I像素的R、G、B值轉(zhuǎn)換成Y通道值、Cr通道值、Cb通道值。
在步驟810,新Y、Cr、Cb通道值計算如下新Y=Y(jié);新Cr=(1-P)*Cr; (11)新Cb=(1-P)*Cb。
在步驟811,將新Y值、新Cr值、新Cb值轉(zhuǎn)換成新R、新G、新B值。
在步驟812,將第I像素的原R、G、B值改變?yōu)樾翿、G、B值。
在步驟813,在使變量I遞增之后,判定I是否大于灰度圖像中的像素數(shù)。
如果步驟813的判定結(jié)果為“否”,處理轉(zhuǎn)到步驟804;否則轉(zhuǎn)到步驟814。
在步驟814,處理結(jié)束。
圖9A至圖9E說明一個實例。圖9A表示在圖1步驟102識別的一個候選人臉區(qū)域。圖9B表示通過圖1步驟103至108,在左眼區(qū)域內(nèi)檢測到一個紅眼區(qū)域901,以及在右眼區(qū)域內(nèi)檢測到一個紅眼區(qū)域902。
取紅眼區(qū)域901作為例子。圖9D表示在圖1步驟108之后得到的紅眼區(qū)域901的灰度圖像。
圖9E表示在對圖9D灰度圖像執(zhí)行高斯平滑處理(圖8步驟802)之后的結(jié)果灰度圖像。
關(guān)于紅眼區(qū)域902,同樣執(zhí)行類似處理。
圖9C表示其中紅眼已得到校正的人臉。
圖10示意表示一個圖像處理系統(tǒng),其中能實現(xiàn)圖1至圖8所示的各處理。圖10所示圖像處理系統(tǒng)包括一個CPU(中央處理單元)1001,一個RAM(隨機(jī)存取存儲器)1002,一個ROM(只讀存儲器)1003,一個系統(tǒng)總線1004,一個HD(硬盤)控制器1005,一個鍵盤控制器1006,一個串行端口控制器1007,一個并行端口控制器1008,一個顯示器控制器1009,一個硬盤1010,一個鍵盤1011,一個照相機(jī)1012,一個打印機(jī)1013,和一個顯示器1014。在這些部件中,與系統(tǒng)總線1004連接的有CPU1001,RAM1002,ROM1003,HD控制器1005,鍵盤控制器1006,串行端口控制器1007,并行端口控制器1008,和顯示器控制器1009。硬盤1010與HD控制器1005連接,并且鍵盤1011與鍵盤控制器1006連接,照相機(jī)1012與串行端口控制器1007連接,打印機(jī)1013與并行端口控制器1008連接,以及顯示器1004與顯示器控制器1009連接。
圖10中各部件的功能在本領(lǐng)域內(nèi)周知,并且圖10所示體系結(jié)構(gòu)為常規(guī)。這樣的體系結(jié)構(gòu)不僅適用于個人計算機(jī),而且適用于手提式設(shè)備,例如掌上PC、PDA(個人數(shù)字助理)、數(shù)字照相機(jī)等。在不同應(yīng)用中,可以省略圖10所示部件中的有些。例如,如果整個系統(tǒng)是一個數(shù)字照相機(jī),能省略并行端口控制器1008和打印機(jī)1013,并且系統(tǒng)能實現(xiàn)為一個單片微型計算機(jī)。如果應(yīng)用軟件存儲在EPROM或其他非易失存儲器中,能省略HD控制器1005和硬盤1010。
圖10所示整個系統(tǒng)由計算機(jī)可讀指令來控制,這些指令通常作為軟件存儲在硬盤1010中(或如上所述,存儲在EPROM或其他非易失存儲器中)。軟件也能從網(wǎng)絡(luò)(圖中未示出)下載。保存在硬盤1010或從網(wǎng)絡(luò)下載的軟件能裝入RAM1002,并且由CPU1001執(zhí)行,以實現(xiàn)軟件所限定的功能。
對本領(lǐng)域技術(shù)人員,根據(jù)圖1至圖8所示流程圖中的一個或多個,研制一塊或多塊軟件,不涉及創(chuàng)造性工作。
雖然以上所述參考了本發(fā)明的特定實施例,但是本領(lǐng)域技術(shù)人員將會理解,這些只是說明性的,并且在不違反本發(fā)明的原理下,其范圍由附加權(quán)利要求限定,能實現(xiàn)這些實施例的許多改變。
權(quán)利要求
1.一種檢測圖像中的紅眼的方法,其特征在于包括以下步驟識別所述圖像中的一個眼區(qū);識別所述眼區(qū)內(nèi)的第一數(shù)目的候選紅眼區(qū)域;縮小所述第一數(shù)目的候選紅眼區(qū)域,得到第二數(shù)目的候選紅眼區(qū)域,所述第二數(shù)目小于或等于所述第一數(shù)目;擴(kuò)大所述第二數(shù)目的候選紅眼區(qū)域,得到第三數(shù)目的候選紅眼區(qū)域,所述第三數(shù)目小于或等于所述第二數(shù)目;以及從所述第三數(shù)目的候選紅眼區(qū)域中選擇不多于一個的候選紅眼區(qū)域,作為所述眼區(qū)內(nèi)檢測到的紅眼。
2.按照權(quán)利要求1的方法,還包括以下步驟修正所述紅眼中包括的像素的特征值,以便消除所述紅眼。
3.按照權(quán)利要求1的方法,其特征在于對于所述第二數(shù)目的候選紅眼區(qū)域的每個候選紅眼區(qū)域,所述擴(kuò)大所述第二數(shù)目的候選紅眼區(qū)域的步驟包括以下步驟定位所述候選紅眼區(qū)域的一個邊界像素;定位一個不包括在所述候選紅眼區(qū)域中的、但是與所述邊界像素相臨的第一像素;定位一個不包括在所述候選紅眼區(qū)域中的、但是與所述第一像素相臨的第二像素;如果所述邊界像素和所述第二像素滿足一個條件,將所述第一像素添加到所述候選紅眼區(qū)域中。
4.按照權(quán)利要求3的方法,其特征在于所述條件包括第一條件,其中所述邊界像素的亮度大于一個在80至120范圍內(nèi)的第五閾值,所述第二像素的飽和度大于0.7至1乘所述邊界像素的飽和度,所述第二像素的第一紅度大于0.7至0.9乘所述候選紅眼區(qū)域的第一紅度,以及所述第二像素的色調(diào)小于2至10乘所述候選紅眼區(qū)域的色調(diào)。
5.按照權(quán)利要求3的方法,其特征在于所述條件包括第二條件,其中所述邊界像素的亮度大于一個在40至60范圍內(nèi)的第六閾值,所述第二像素的飽和度大于0.8至1.2乘所述邊界像素的飽和度,所述第二像素與所述邊界像素的亮度之間的絕對差小于0至0.3乘所述邊界像素的亮度,所述第二像素的第一紅度大于0.7至0.9乘所述候選紅眼區(qū)域的第一紅度,以及所述第二像素的色調(diào)小于2至10乘所述候選紅眼區(qū)域的色調(diào)。
6.按照權(quán)利要求1的方法,其特征在于對于所述第二數(shù)目的候選紅眼區(qū)域中的每一個候選紅眼區(qū)域,所述擴(kuò)大所述第二數(shù)目的候選紅眼區(qū)域的步驟包括以下步驟定位所述候選紅眼區(qū)域的一個邊界像素;定位一個不包括在所述候選紅眼區(qū)域中的、但是與所述邊界像素相臨的第一像素;如果所述邊界像素和所述第一像素滿足另一個條件,則將所述第一像素添加到所述候選紅眼區(qū)域中。
7.按照權(quán)利要求6的方法,其特征在于所述另一個條件包括第三條件,其中所述邊界像素的亮度大于一個在80至120范圍內(nèi)的第五閾值,所述第一像素的飽和度大于0.7至1乘所述邊界像素的飽和度,所述第一像素的第一紅度大于0.7至0.9乘所述候選紅眼區(qū)域的第一紅度,以及所述第一像素的色度小于2至10乘所述候選紅眼區(qū)域的色調(diào)。
8.按照權(quán)利要求6的方法,其特征在于所述另一個條件包括第四條件,其中所述邊界像素的亮度大于一個在40至60范圍內(nèi)的第六閾值,所述第一像素的飽和度大于0.8至1.2乘所述邊界像素的飽和度,所述第一像素與所述邊界像素的亮度之間的絕對差小于0至0.3乘所述邊界像素的亮度,所述第一像素的第一紅度大于0.7至0.9乘所述候選紅眼區(qū)域的第一紅度,以及所述第一像素的色調(diào)小于2至10乘所述候選紅眼區(qū)域的色調(diào)。
9.按照權(quán)利要求3的方法,其特征在于所述擴(kuò)大所述第二數(shù)目的候選紅眼區(qū)域的步驟還包括以下步驟如果兩個候選紅眼區(qū)域相互合并,并且所述兩個候選紅眼區(qū)域中的一個的特征值小于第八閾值,則除去所述一個候選紅眼區(qū)域。
10.按照權(quán)利要求3的方法,其特征在于所述擴(kuò)大所述第二數(shù)目的候選紅眼區(qū)域的步驟還包括以下步驟如果兩個候選紅眼區(qū)域相互合并,所述兩個候選紅眼區(qū)域的特征值都大于第八閾值,并且兩個特征值之間的絕對差小于第九閾值,則將所述兩個候選紅眼區(qū)域組合成一個候選紅眼區(qū)域。
11.按照權(quán)利要求3的方法,其特征在于所述擴(kuò)大所述第二數(shù)目的候選紅眼區(qū)域的步驟還包括以下步驟如果兩個候選紅眼區(qū)域相互合并,所述兩個候選紅眼區(qū)域的特征值都大于第八閾值,并且兩個候選紅眼區(qū)域的特征值之間的絕對差大于第九閾值,則將所述兩個候選紅眼區(qū)域中具有較低特征值的一個候選紅眼區(qū)域除去。
12.按照權(quán)利要求1的方法,其特征在于所述從所述第三數(shù)目的候選紅眼區(qū)域中選擇不多于一個的候選紅眼區(qū)域的步驟包括以下步驟計算所述第三數(shù)目的候選紅眼區(qū)域中的每一個候選紅眼區(qū)域的得分;以及選擇一個具有最大得分的候選紅眼區(qū)域。
13.按照權(quán)利要求12的方法,其特征在于所述計算所述第三數(shù)目的候選紅眼區(qū)域中的每一個候選紅眼區(qū)域的得分的步驟包括以下步驟對所述候選紅眼區(qū)域,計算第二紅度、Cb通道值、Y方差、第三紅度方差、第二紅度方差、色調(diào)、色調(diào)方差、r方差、第一紅度方差,形成一個九維向量;計算所述九維向量和一個權(quán)向量的內(nèi)積,得到所述候選紅眼區(qū)域的所述得分。
14.按照權(quán)利要求13的方法,其特征在于通過對一個訓(xùn)練集執(zhí)行費舍爾分類法和選擇法,得到所述權(quán)向量。
15.按照權(quán)利要求1的方法,其特征在于對于所述眼區(qū)內(nèi)的每個像素,所述識別所述眼區(qū)內(nèi)的第一數(shù)目的候選紅眼區(qū)域的步驟包括以下步驟限定一個以所述像素為中心的瞳孔區(qū)域;根據(jù)所述瞳孔區(qū)域,計算所述像素的顏色方差;以及如果所述顏色方差大于第一閾值和第二閾值中的至少一個,則將所述像素標(biāo)記為一個紅眼像素,所述紅眼像素和其他紅眼像素一起,形成所述第一數(shù)目的候選紅眼區(qū)域中的一個。
16.按照權(quán)利要求1的方法,其特征在于所述識別所述紅眼區(qū)內(nèi)的第一數(shù)目的候選紅眼區(qū)域的步驟包括以下步驟產(chǎn)生所述圖像的一幅灰度圖像;通過使用第一模板對所述灰度圖像執(zhí)行閉運算,產(chǎn)生一幅閉圖像;通過使用第二模板對所述灰度圖像執(zhí)行開運算,產(chǎn)生一幅開圖像;通過從所述閉圖像減去所述開圖像,產(chǎn)生一幅目標(biāo)圖像;對所述目標(biāo)圖像執(zhí)行高斯平滑處理;以及對所述目標(biāo)圖像中具有大于第三閾值的灰度的每個像素,將原圖像中的一個對應(yīng)像素標(biāo)記為一個紅眼像素,所述紅眼像素和其他紅眼像素一起,形成所述第一數(shù)目的候選紅眼區(qū)域中的一個。
17.按照權(quán)利要求1的方法,其特征在于對于所述第一數(shù)目的候選紅眼區(qū)域的每個候選紅眼區(qū)域,所述縮小所述第一數(shù)目的候選紅眼區(qū)域的步驟包括以下步驟計算所述候選紅眼區(qū)域內(nèi)每個像素的第一紅度;計算所述候選紅眼區(qū)域內(nèi)像素的所述第一紅度的臨時閾值;從所述候選紅眼區(qū)域中除去其第一紅度小于所述臨時閾值的像素。
18.按照權(quán)利要求2的方法,其特征在于對于所述紅眼包括的每個像素,所述修正所述紅眼包括的像素的特征值的步驟包括以下步驟根據(jù)所述像素的紅度和指示所述像素離所述紅眼的邊界有多遠(yuǎn)的指標(biāo),計算所述像素的一個校正系數(shù);以及根據(jù)所述校正系數(shù),修正所述像素的特征值。
19.按照權(quán)利要求18的方法,其特征在于還包括以下步驟將所述像素的R、G、B值轉(zhuǎn)換成Y、Cr、Cb值;計算新Cr值和新Cb值;將Y、新Cr、新Cb值轉(zhuǎn)換成新R、G、B值;用新R、G、B值代替原R、G、B值。
20.按照權(quán)利要求2的方法,其特征在于在所述修正所述紅眼中包括的像素的特征值的步驟之前,還包括以下步驟對所述紅眼的灰度圖像執(zhí)行高斯平滑處理。
全文摘要
本發(fā)明提供一種檢測圖像中的紅眼的方法,其特征在于包括以下步驟識別所述圖像中的眼區(qū);識別所述眼區(qū)內(nèi)的第一數(shù)目的候選紅眼區(qū)域;縮小所述第一數(shù)目的候選紅眼區(qū)域,得到第二數(shù)目的候選紅眼區(qū)域,所述第二數(shù)目小于或等于所述第一數(shù)目;擴(kuò)大所述第二數(shù)目的候選紅眼區(qū)域,得到第三數(shù)目的候選紅眼區(qū)域,所述第三數(shù)目小于或等于所述第二數(shù)目;以及從所述第三數(shù)目的候選紅眼區(qū)域中選擇不多于一個的候選紅眼區(qū)域,作為所述圖像中檢測到的紅眼。
文檔編號G06T5/00GK1635547SQ20031011603
公開日2005年7月6日 申請日期2003年12月29日 優(yōu)先權(quán)日2003年12月29日
發(fā)明者張鉞, 夏一哂, 龔平 申請人:佳能株式會社
網(wǎng)友詢問留言 已有0條留言
  • 還沒有人留言評論。精彩留言會獲得點贊!
1
太仆寺旗| 柯坪县| 客服| 祥云县| 九龙县| 柘荣县| 巍山| 临朐县| 中卫市| 镇赉县| 黔江区| 富锦市| 白银市| 延吉市| 合山市| 都匀市| 怀柔区| 阿拉善盟| 临安市| 砀山县| 林甸县| 育儿| 万荣县| 榕江县| 双鸭山市| 应城市| 固安县| 红安县| 丘北县| 蒙城县| 长岛县| 京山县| 扶沟县| 工布江达县| 永宁县| 仁布县| 肇州县| 龙泉市| 梧州市| 屯留县| 舒兰市|