熱線電話:0755-23712116
郵箱:contact@shuangyi-tech.com
地址:深圳市寶安區(qū)沙井街道后亭茅洲山工業(yè)園工業(yè)大廈全至科技創(chuàng)新園科創(chuàng)大廈2層2A
前面幾篇文章介紹的是圖像的空間域?yàn)V波,其對像素的處理都是基于像素的某一鄰域進(jìn)行的。本文介紹的圖像的灰度變換則不同,其對像素的計(jì)算僅僅依賴于當(dāng)前像素和灰度變換函數(shù)。
灰度變換也被稱為圖像的點(diǎn)運(yùn)算(只針對圖像的某一像素點(diǎn))是所有圖像處理技術(shù)中最簡單的技術(shù),其變換形式如下:
其中,T是灰度變換函數(shù);r是變換前的灰度;s是變換后的像素。
圖像灰度變換的有以下作用:
? 改善圖像的質(zhì)量,使圖像能夠顯示更多的細(xì)節(jié),提高圖像的對比度(對比度拉伸)
? 有選擇的突出圖像感興趣的特征或者抑制圖像中不需要的特征
? 可以有效的改變圖像的直方圖分布,使像素的分布更為均勻
灰度變換函數(shù)描述了輸入灰度值和輸出灰度值之間變換關(guān)系,一旦灰度變換函數(shù)確定下來了,那么其輸出的灰度值也就確定了??梢娀叶茸儞Q函數(shù)的性質(zhì)就決定了灰度變換所能達(dá)到的效果。用于圖像灰度變換的函數(shù)主要有以下三種:
? 線性函數(shù) (圖像反轉(zhuǎn))
? 對數(shù)函數(shù):對數(shù)和反對數(shù)變換
? 冪律函數(shù):n次冪和n次開方變換
上圖給出了幾種常見灰度變換函數(shù)的曲線圖,根據(jù)這幾種常見函數(shù)的曲線形狀,可以知道這幾種變換的所能達(dá)到的效果。例如,對數(shù)變換和冪律變換都能實(shí)現(xiàn)圖像灰度級(jí)的擴(kuò)展/壓縮,另外對數(shù)變換還有一個(gè)重要的性質(zhì),它能壓縮圖像灰度值變換較大的圖像的動(dòng)態(tài)范圍(例如,傅立葉變換的頻譜顯示)。令r為變換前的灰度,s為變換后的灰度,則線性變換的函數(shù):
其中,a為直線的斜率,b為在y軸的截距。選擇不同的a,b值會(huì)有不同的效果:
?
?
?
?
?
?
在進(jìn)行圖像增強(qiáng)時(shí),上述的線性變換函數(shù)用的較多的就是圖像反轉(zhuǎn)了,根據(jù)上面的參數(shù),圖像反轉(zhuǎn)的變換函數(shù)為:
圖像反轉(zhuǎn)的實(shí)現(xiàn)是比較簡單的,在OpenCV中有對Mat的運(yùn)算符重載,可以直接Mat r = 255 - img
或者~img
來實(shí)現(xiàn)。
對數(shù)變換的通用公式是:
其中,c是一個(gè)常數(shù),,假設(shè)
這使用的對數(shù)函數(shù)的底為10。由于灰度變換是灰度值之間的一對一的映射,而灰度值區(qū)間通常為[0,255],所以在進(jìn)行灰度變換時(shí),通常使用查表法。也就是,現(xiàn)將每個(gè)灰度值的映射后的結(jié)果計(jì)算出來,在變換時(shí),通過查表得到變換后的灰度值。執(zhí)行上面結(jié)果得到的結(jié)果如下:
伽馬變換的公式為:
其中c和為正常數(shù)。
伽馬變換的效果與對數(shù)變換有點(diǎn)類似,當(dāng)
當(dāng)
伽馬變換主要用于圖像的校正,對灰度值過高(圖像過亮)或者過低(圖像過暗)的圖像進(jìn)行修正,增加圖像的對比度,從而改善圖像的顯示效果。
基于OpenCV的實(shí)現(xiàn):
float pixels[256];
for (int i = 0; i < 256; i++)
pixels[i] = i * i *i;
Mat imageLog(image.size(), CV_32FC3);
for (int i = 0; i<image.rows; i++)
{
for (int j = 0; j<image.cols; j++)
{
imageLog.at
這里選擇的參數(shù)為c = 1,
當(dāng)選擇參數(shù)為c = 1,
根據(jù)以上的結(jié)果,結(jié)合伽馬變換的函數(shù)曲線圖,做如下總結(jié):
?
?
灰度變換屬于點(diǎn)對點(diǎn)的一一變換,在實(shí)現(xiàn)的時(shí)候,可以利用查表法。也就是實(shí)現(xiàn)將[0,255]區(qū)間的各個(gè)灰度值的變換后的值計(jì)算出來,在變換的時(shí)候直接根據(jù)灰度值進(jìn)行查表得到變換后的結(jié)果。其實(shí)現(xiàn)如下:
/////////////////////////////////////////////////////////////////////
//
// 灰度線性變換函數(shù)
// 參數(shù):
// src,輸入原圖像
// dst,輸出圖像,類型為CV_32F,大小及通道數(shù)與原圖像相同
// mapping,灰度映射表,可以根據(jù)不同的變換函數(shù),提前計(jì)算好圖像的灰度映射表
//
////////////////////////////////////////////////////////////////////
void gray_trans(const Mat& src, Mat& dst,float* mapping)
{
int channels = src.channels();
if (channels == 1)
{
dst = Mat(src.size(), CV_32FC1);
for (int i = 0; i < src.rows; i++)
{
float* p1 = dst.ptr<float>(i);
const uchar* p2 = src.ptr(i);
for (int j = 0; j < src.cols; j++)
p1[j] = mapping[p2[j]];
}
}
else if (channels == 3)
{
dst = Mat(src.size(), CV_32FC3);
for (int i = 0; i < src.rows; i++)
{
float* p1 = dst.ptr<float>(i);
const uchar* p2 = src.ptr(i);
for (int j = 0; j < src.cols * 3; j+=3)
{
p1[j] = mapping[p2[j]];
p1[j+1] = mapping[p2[j+1]];
p1[j+2] = mapping[p2[j+2]];
}
}
}
}
其調(diào)用也比較簡單,根據(jù)具體的灰度變換函數(shù),填充灰度映射表即可,以伽馬變換為例:
float pixels[256];
for (int i = 0; i < 256; i++)
pixels[i] = powf(i, 1.5);
Mat imageLog;
gray_trans(image, imageLog, pixels);
本文主要對圖像的幾種常見的灰度變換進(jìn)行了總結(jié)。
? 圖像反轉(zhuǎn),是圖像線性變換的一種,可以得到圖像負(fù)片,能夠有效的增強(qiáng)圖像的暗色區(qū)域中的白色或者灰色細(xì)節(jié)
? 對數(shù)變換,擴(kuò)展圖像中的低灰度區(qū)域,壓縮圖像中的高灰度區(qū)域,能夠增強(qiáng)圖像中的暗色區(qū)域的細(xì)節(jié);反對數(shù)變換與此相反。對數(shù)變換還有個(gè)重要作用是,能夠壓縮圖像灰度值的動(dòng)態(tài)范圍,在傅立葉變換中能夠顯示更多的變換后的頻譜細(xì)節(jié)。
? 伽馬變換,主要用于圖像的校正,根據(jù)參數(shù)
文章轉(zhuǎn)自Brook_icv https://www.cnblogs.com/wangguchangqing/p/6983680.html