黄色网页视频 I 影音先锋日日狠狠久久 I 秋霞午夜毛片 I 秋霞一二三区 I 国产成人片无码视频 I 国产 精品 自在自线 I av免费观看网站 I 日本精品久久久久中文字幕5 I 91看视频 I 看全色黄大色黄女片18 I 精品不卡一区 I 亚洲最新精品 I 欧美 激情 在线 I 人妻少妇精品久久 I 国产99视频精品免费专区 I 欧美影院 I 欧美精品在欧美一区二区少妇 I av大片网站 I 国产精品黄色片 I 888久久 I 狠狠干最新 I 看看黄色一级片 I 黄色精品久久 I 三级av在线 I 69色综合 I 国产日韩欧美91 I 亚洲精品偷拍 I 激情小说亚洲图片 I 久久国产视频精品 I 国产综合精品一区二区三区 I 色婷婷国产 I 最新成人av在线 I 国产私拍精品 I 日韩成人影音 I 日日夜夜天天综合

Gamma校正及其OpenCV實現

系統 2597 0

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

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

?

一、什么是Gamma校正?

Gamma校正是對輸入圖像灰度值進行的非線性操作,使輸出圖像灰度值與輸入圖像灰度值呈指數關系:

[2]

這個指數即為Gamma.

經過Gamma校正后的輸入和輸出圖像灰度值關系如圖1所看到的:橫坐標是輸入灰度值,縱坐標是輸出灰度值,藍色曲線是gamma值小于1時的輸入輸出關系,紅色曲線是gamma值大于1時的輸入輸出關系。能夠觀察到,當gamma值小于1時(藍色曲線),圖像的總體亮度值得到提升,同一時候低灰度處的對照度得到添加,更利于分辯低灰度值時的圖像細節。

Gamma校正及其OpenCV實現

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

?

二、為什么進行Gamma校正?

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

Gamma校正及其OpenCV實現

圖2 人眼和攝像機的感光與實際輸入光強的關系[1]。

為方便人眼辨識圖像,須要將攝像機採集的圖像進行gamma校正。

?

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

未經gamma校正和經過gamma校正保存圖像信息如圖3所看到的:

Gamma校正及其OpenCV實現

圖3 未經gamma校正和經過gamma校正保存圖像信息.

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

?

三、利用OpenCV實現的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實現


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

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

【本文對您有幫助就好】

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

發表我的評論
最新評論 總共0條評論