日韩久久久精品,亚洲精品久久久久久久久久久,亚洲欧美一区二区三区国产精品 ,一区二区福利

Gamma校正及其OpenCV實(shí)現(xiàn)

系統(tǒng) 2232 0

參考:[1] http://www.cambridgeincolour.com/tutorials/gamma-correction.htm

[2] http://en.wikipedia.org/wiki/Gamma_correction

?

一、什么是Gamma校正?

Gamma校正是對(duì)輸入圖像灰度值進(jìn)行的非線性操作,使輸出圖像灰度值與輸入圖像灰度值呈指數(shù)關(guān)系:

[2]

這個(gè)指數(shù)即為Gamma.

經(jīng)過(guò)Gamma校正后的輸入和輸出圖像灰度值關(guān)系如圖1所看到的:橫坐標(biāo)是輸入灰度值,縱坐標(biāo)是輸出灰度值,藍(lán)色曲線是gamma值小于1時(shí)的輸入輸出關(guān)系,紅色曲線是gamma值大于1時(shí)的輸入輸出關(guān)系。能夠觀察到,當(dāng)gamma值小于1時(shí)(藍(lán)色曲線),圖像的總體亮度值得到提升,同一時(shí)候低灰度處的對(duì)照度得到添加,更利于分辯低灰度值時(shí)的圖像細(xì)節(jié)。

Gamma校正及其OpenCV實(shí)現(xiàn)

??????????????????????????????????????????????????????????????????????????????? 圖1 Gamma校正.

?

二、為什么進(jìn)行Gamma校正?

1. 人眼對(duì)外界光源的感光值與輸入光強(qiáng)不是呈線性關(guān)系的,而是呈指數(shù)型關(guān)系的。在低照度下,人眼更easy分辨出亮度的變化,隨著照度的添加,人眼不易分辨出亮度的變化。而攝像機(jī)感光與輸入光強(qiáng)呈線性關(guān)系。如圖2所看到的:

Gamma校正及其OpenCV實(shí)現(xiàn)

圖2 人眼和攝像機(jī)的感光與實(shí)際輸入光強(qiáng)的關(guān)系[1]。

為方便人眼辨識(shí)圖像,須要將攝像機(jī)採(cǎi)集的圖像進(jìn)行g(shù)amma校正。

?

2. 為能更有效的保存圖像亮度信息,需進(jìn)行Gamma校正。

未經(jīng)gamma校正和經(jīng)過(guò)gamma校正保存圖像信息如圖3所看到的:

Gamma校正及其OpenCV實(shí)現(xiàn)

圖3 未經(jīng)gamma校正和經(jīng)過(guò)gamma校正保存圖像信息.

能夠觀察到,未經(jīng)gamma校正的情況下,低灰度時(shí),有較大范圍的灰度值被保存成同一個(gè)值,造成信息丟失;同一時(shí)候高灰度值時(shí),非常多比較接近的灰度值卻被保存成不同的值,造成空間浪費(fèi)。經(jīng)過(guò)gamma校正后,改善了存儲(chǔ)的有效性和效率。

?

三、利用OpenCV實(shí)現(xiàn)的Gamma校正

      void MyGammaCorrection(Mat& src, Mat& dst, float fGamma)
{
	CV_Assert(src.data);

	// accept only char type matrices
	CV_Assert(src.depth() != sizeof(uchar));

	// build look up table
	unsigned char lut[256];
	for( int i = 0; i < 256; i++ )
	{
		lut[i] = saturate_cast<uchar>(pow((float)(i/255.0), fGamma) * 255.0f);
	}

	dst = src.clone();
	const int channels = dst.channels();
	switch(channels)
	{
		case 1:
			{

				MatIterator_<uchar> it, end;
				for( it = dst.begin<uchar>(), end = dst.end<uchar>(); it != end; it++ )
					//*it = pow((float)(((*it))/255.0), fGamma) * 255.0;
					*it = lut[(*it)];

				break;
			}
		case 3: 
			{

				MatIterator_<Vec3b> it, end;
				for( it = dst.begin<Vec3b>(), end = dst.end<Vec3b>(); it != end; it++ )
				{
					//(*it)[0] = pow((float)(((*it)[0])/255.0), fGamma) * 255.0;
					//(*it)[1] = pow((float)(((*it)[1])/255.0), fGamma) * 255.0;
					//(*it)[2] = pow((float)(((*it)[2])/255.0), fGamma) * 255.0;
					(*it)[0] = lut[((*it)[0])];
					(*it)[1] = lut[((*it)[1])];
					(*it)[2] = lut[((*it)[2])];
				}

				break;

			}
	}
}
    
      
      
      
      
      
    

Gamma校正及其OpenCV實(shí)現(xiàn)


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對(duì)您有幫助就好】

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長(zhǎng)會(huì)非常 感謝您的哦!!!

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論
主站蜘蛛池模板: 武义县| 拉萨市| 施甸县| 平泉县| 泽库县| 嫩江县| 莱芜市| 兰西县| 永德县| 越西县| 兴山县| 白城市| 定边县| 高安市| 红桥区| 大关县| 罗城| 浏阳市| 门头沟区| 德昌县| 盐源县| 柞水县| 德江县| 平陆县| 肥西县| 云浮市| 连州市| 五指山市| 五家渠市| 娄烦县| 合阳县| 安仁县| 隆回县| 普宁市| 镇江市| 朝阳市| 大厂| 海原县| 乐昌市| 平潭县| 河东区|