亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

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

系統(tǒng) 2429 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)過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)過gamma校正保存圖像信息如圖3所看到的:

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

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

能夠觀察到,未經(jīng)gamma校正的情況下,低灰度時(shí),有較大范圍的灰度值被保存成同一個(gè)值,造成信息丟失;同一時(shí)候高灰度值時(shí),非常多比較接近的灰度值卻被保存成不同的值,造成空間浪費(fèi)。經(jīng)過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)論
主站蜘蛛池模板: 国产激情久久久久影 | 国产在线精品福利91香蕉 | 精品视频在线观看一区二区 | 国产成人一区二区三区视频免费蜜 | 亚洲精品123区 | 青青青青久久精品国产h | a色毛片免费视频 | 午夜论坛 | 老子影院午夜理伦手机不卡 | 日本精品二区 | 玖玖免费| 中文字幕一区二区三区 精品 | 成年网站视频在线观看 | 黄色毛片一级 | 久久99精品久久久久久噜噜丰满 | a级毛片在线视频免费观看 a级免费网站 | 亚洲精品综合网 | 曰本一级毛片 | 四虎免费视频 | 天堂成人在线 | 国产精品热久久毛片 | 狠狠躁夜夜躁人人爽天天3 狠狠躁夜夜躁人人爽天天miya | 欧美高清理论片在线观看 | 精品72久久久久久久中文字幕 | 成人看片黄a免费 | 亚洲精品天堂自在久久77 | 狠狠色丁香婷婷久久综合不卡 | 亚洲欧洲日韩国产一区二区三区 | 青草视频在线观看视频 | 精品国产一区二区在线观看 | 色婷婷视频 | 色综合色狠狠天天久久婷婷基地 | 亚洲精品在线免费 | 天天操网 | 夜夜爽天天狠狠九月婷婷 | 特一级男女性色大片 | 欧美 日本| 97夜夜操| 能免费看黄的网站 | 国产精品成人观看视频国产奇米 | 亚洲偷图色综合色就色 |