欧美性猛交XXXX免费看蜜桃,成人网18免费韩国,亚洲国产成人精品区综合,欧美日韩一区二区三区高清不卡,亚洲综合一区二区精品久久

打開(kāi)APP
userphoto
未登錄

開(kāi)通VIP,暢享免費電子書(shū)等14項超值服

開(kāi)通VIP
OTSU算法提取圖像閾值的C語(yǔ)言實(shí)現 - Steven Wang's Blog

OTSU算法提取圖像閾值的C語(yǔ)言實(shí)現

OTSU算法也稱(chēng)最大類(lèi)間差法,有時(shí)也稱(chēng)之為大津算法,被認為是圖像分割中閾值選取的最佳算法,計算簡(jiǎn)單,不受圖像亮度和對比度的影響,因此在數字圖像處理上得到了廣泛的應用。它是按圖像的灰度特性,將圖像分成背景和前景兩部分。背景和前景之間的類(lèi)間方差越大,說(shuō)明構成圖像的兩部分的差別越大,當部分前景錯分為背景或部分背景錯分為前景都會(huì )導致兩部分差別變小。因此,使類(lèi)間方差最大的分割意味著(zhù)錯分概率最小。

設灰度圖像灰度級是L,則灰度范圍為[0,L-1],利用OTSU算法計算圖像的最佳閾值為:
t = Max[w0(t) *(u0(t) - u)^2 + w1(t) * (u1(t) - u)^2)]
其中的變量說(shuō)明:當分割的閾值為t時(shí),w0為背景比例,u0為背景均值,w1為前景比例,u1為前景均值,u為整幅圖像的均值。
使以上表達式值最大的t,即為分割圖像的最佳閾值。

以下是一段在OpenCV中實(shí)現的C語(yǔ)言程序,即一個(gè)使用OTSU算法提取圖像閾值的函數,輸入參數為一個(gè)圖像指針,返回分割該圖像的最佳閾值。

01 int otsuThreshold(IplImage *frame)
02 {
03     int width = frame->width;
04     int height = frame->height;
05     int pixelCount[GrayScale];
06     float pixelPro[GrayScale];
07     int i, j, pixelSum = width * height, threshold = 0;
08     uchar* data = (uchar*)frame->imageData;
09  
10     for(i = 0; i < GrayScale; i++)
11     {
12         pixelCount[i] = 0;
13         pixelPro[i] = 0;
14     }
15  
16     //統計灰度級中每個(gè)像素在整幅圖像中的 個(gè)數
17     for(i = 0; i < height; i++)
18     {
19         for(j = 0;j < width;j++)
20         {
21             pixelCount[(int)data[i * width + j]]++;
22         }
23     }
24      
25     //計算每個(gè)像素在整幅圖像中的比例
26     for(i = 0; i < GrayScale; i++)
27     {
28         pixelPro[i] = (float)pixelCount[i] / pixelSum;
29     }
30  
31     //遍歷灰度級[0,255]
32     float w0, w1, u0tmp, u1tmp, u0, u1, u,
33             deltaTmp, deltaMax = 0;
34     for(i = 0; i < GrayScale; i++)
35     {
36         w0 = w1 = u0tmp = u1tmp = u0 = u1 = u = deltaTmp = 0;
37         for(j = 0; j < GrayScale; j++)
38         {
39             if(j <= i)   //背景部 分
40             {
41                 w0 += pixelPro[j];
42                 u0tmp += j * pixelPro[j];
43             }
44             else   //前景部分
45             {
46                 w1 += pixelPro[j];
47                 u1tmp += j * pixelPro[j];
48             }
49         }
50         u0 = u0tmp / w0;
51         u1 = u1tmp / w1;
52         u = u0tmp + u1tmp;
53         deltaTmp =
54             w0 * pow((u0 - u), 2) + w1 * pow((u1 - u), 2);
55         if(deltaTmp > deltaMax)
56         {
57             deltaMax = deltaTmp;
58             threshold = i;
59         }
60     }
61     return threshold;
62 }
--End--
作者:Steven Wang | 可以轉載,轉載時(shí)務(wù)必以超鏈接形式標明文章原始出處和作者信息及版權聲明
本站僅提供存儲服務(wù),所有內容均由用戶(hù)發(fā)布,如發(fā)現有害或侵權內容,請點(diǎn)擊舉報。
打開(kāi)APP,閱讀全文并永久保存 查看更多類(lèi)似文章
猜你喜歡
類(lèi)似文章
基于 OpenCV 的圖像分割
灰度圖像閾值化分割常見(jiàn)方法總結及VC實(shí)現
圖像二值化
基于改進(jìn)Sobel算子和遺傳算法的圖像邊緣檢測
halcon自動(dòng)計算閾值方法
SimpleITK中的圖像分割_weixin_42834523的博客-CSDN博客
更多類(lèi)似文章 >>
生活服務(wù)
分享 收藏 導長(cháng)圖 關(guān)注 下載文章
綁定賬號成功
后續可登錄賬號暢享VIP特權!
如果VIP功能使用有故障,
可點(diǎn)擊這里聯(lián)系客服!

聯(lián)系客服

欧美性猛交XXXX免费看蜜桃,成人网18免费韩国,亚洲国产成人精品区综合,欧美日韩一区二区三区高清不卡,亚洲综合一区二区精品久久