C#結(jié)合OpenCVSharp4使用直方圖算法實現(xiàn)圖片相似度比較
C#結(jié)合OpenCVSharp4使用直方圖算法比較圖片相似度
直方圖有 灰度直方圖 、 顏色直方圖 ,如果是灰度圖像,那么就用 灰度直方圖 ,這里使用 顏色直方圖 來計算兩個圖片的相似度。
這里只記錄如何使用,至于算法原理,問就是不會。
直方圖算法效率高,但精度不夠,適合快速比較,例如 以圖搜圖
1. 下載 OpenCVSharp4
通過NuGet包管理器進行下載。搜索 OpenCVSharp4 下載??蓞⒖记耙黄恼?C#結(jié)合OpenCVSharp4圖片相似度識別
2. 使用
/// <summary>
/// 直方圖相關(guān)性
/// 結(jié)果越接近1 則越相似
/// 圖片相似度識別(精度不高,速度較快,可用于以圖搜圖)
/// </summary>
/// <param name="imgFile1"></param>
/// <param name="imgFile2"></param>
public double Compare_Hist(string imgFile1, string imgFile2)
{
var matA = Cv2.ImRead(imgFile1);
var matB = Cv2.ImRead(imgFile2);
// 拆分通道
Cv2.Split(matA, out Mat[] matA_S);
Cv2.Split(matB, out Mat[] matB_S);
//直方圖的像素范圍
Rangef[] histRange = { new Rangef(0, 256) };
//直方圖數(shù)組大小
int[] histSize = { 256 };
//直方圖輸出數(shù)組
Mat hist_A = new Mat();
Mat hist_B = new Mat();
bool uniform = true, accumulate = false;
Cv2.CalcHist(matA_S, new int[] { 0, 1, 2 }, null, hist_A, 1, histSize, histRange, uniform, accumulate);
Cv2.CalcHist(matB_S, new int[] { 0, 1, 2 }, null, hist_B, 1, histSize, histRange, uniform, accumulate);
//歸一化,排除圖像分辨率不一致的影響
Cv2.Normalize(hist_A, hist_A, 0, 1, NormTypes.MinMax, -1, null);
Cv2.Normalize(hist_B, hist_B, 0, 1, NormTypes.MinMax, -1, null);
//相關(guān)性比較
var res = Cv2.CompareHist(hist_A, hist_B, HistCompMethods.Correl);
return res;
}比較結(jié)果


可以看出基本符合預(yù)期。
注意:由于直方圖算法未考慮像素的空間位置,所以當圖片旋轉(zhuǎn)后,仍會被認為是同一個圖
下面是將圖片旋轉(zhuǎn)后的計算結(jié)果,可以看到跟沒有旋轉(zhuǎn)時的計算結(jié)果一樣

記錄完畢~
到此這篇關(guān)于C#結(jié)合OpenCVSharp4使用直方圖算法實現(xiàn)圖片相似度比較的文章就介紹到這了,更多相關(guān)C# OpenCVSharp4內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C#結(jié)合JS解決Word添加無效位圖導(dǎo)致進程停滯的問題
這篇文章主要為大家詳細介紹了C#如何結(jié)合JS解決Word添加無效位圖導(dǎo)致進程停滯的問題,感興趣的小伙伴可以跟隨小編一起學習一下2024-11-11

