最近開始接觸 c++ 了,就拿乙個 opencv 小專案來練練手。在車牌自動識別系統中,從汽車影象的獲取到車牌字元處理是乙個複雜的過程,本文就以乙個簡單的方法來處理車牌定位。
我國的汽車牌照一般由七個字元和乙個點組成,車牌字元的高度和寬度是固定的,分別為90mm和45mm,七個字元之間的距離也是固定的12mm,點分割符的直徑是10mm。
使用的是從百度上隨便找的(侵刪),展示一下原圖和灰度圖:
#include
#include
#include
#include
using namespace std;
using namespace cv;
int main()
灰度影象的每乙個畫素都是由乙個數字量化的,而彩色影象的每乙個畫素都是由三個數字組成的向量量化的,使用灰度影象會更方便後續的處理。
影象降噪
每一副影象都包含某種程度的雜訊,在大多數情況下,需要平滑技術(也常稱為濾波或者降噪技術)進行抑制或者去除,這些技術包括基於二維離散卷積的高斯平滑、均值平滑、基於統計學方法的中值平滑等。這裡採用基於二維離散卷積的高斯平滑對灰度影象進行降噪處理,處理後的影象效果如下:
形態學處理
完成了高斯去噪以後,為了後面更加準確的提取車牌的輪廓,我們需要對影象進行形態學處理,在這裡,我們對它進行開運算,處理後如下所示:
開運算呢就是先進行 erode 再進行 dilate 的過程就是開運算,它具有消除亮度較高的細小區域、在纖細點處分離物體,對於較大物體,可以在不明顯改變其面積的情況下平滑其邊界等作用。
erode 操作也就是腐蝕操作,類似於卷積,也是一種鄰域運算,但計算的不是加權求和,而是對鄰域中的畫素點按灰度值進行排序,然後選擇該組的最小值作為輸出的灰度值。
dilate 操作就是膨脹操作,與腐蝕操作類似,膨脹是取每乙個位置鄰域內的最大值。既然是取鄰域內的最大值,那麼顯然膨脹後的輸出影象的總體亮度的平均值比起原圖會有所上公升,而影象中較亮物體的尺寸會變大;相反,較暗物體的尺寸會減小,甚至消失。
閾值分割
完成初步的形態學處理以後,我們需要對影象進行閾值分割,我們在這裡採用了 otsu 閾值處理,處理後的效果如下所示:
對影象進行數字處理時,我們需要把影象分成若干個特定的、具有獨特性質的區域,每乙個區域代表乙個畫素的集合,每乙個集合又代表乙個物體,而完成該過程的技術通常稱為影象分割,它是從影象處理到影象分析的關鍵步驟。其實這個過程不難理解,就好比我們人類看景物一樣,我們所看到的世界是由許許多多的物體組合而成的,就像教室是由人、桌子、書本、黑板等等組成。我們通過閾值處理,就是希望能夠從背景中分離出我們的研究物件。
邊緣檢測
經過otsu閾值分割以後,我們要對影象進行邊緣檢測,我們這裡採用的是canny邊緣檢測,處理後的結果如下:
接下來再進行一次閉運算和開運算,填充白色物體內細小黑色空洞的區域並平滑其邊界,處理後的效果如下:
這個時候,車牌的輪廓已經初步被選出來了,只是還有一些白色塊在干擾。
上述過程的**:
// 得出輪廓
bool contour(mat image, vector> &contours, vector &hierarchy)
選取輪廓
現在我們已經有了輪廓,我們需要篩選出車牌所在的那個輪廓,由於車牌寬和高的比例是固定的,依據這個幾何特徵,我們進行篩選,效果如圖:
**如下:
// 車牌輪廓點
point2f(*choose_contour(vector> contours))[2]
float ratio = width / height;
if (2.5 < ratio && ratio < 5.5) }
return contours_result;
}// 擷取車牌區域
int license_gain(point2f (*choose_license)[2], mat img)
} imshow("繪製方框", img);
return 0;
}最後的 main 函式:
int main()
本文標題: opencv實現車牌定位(c++)
本文位址:
車牌區域定位 opencv
include include include include using namespace std using namespace cv void getbluemask iplimage src,iplimage dst int main 若每一行的畫素累加和除以上一行的畫素累加和小於乙個閾值...
opencv實現車牌識別之車牌號定位 1
按照在 跌倒就在 爬起來的精神,本章繼續做車牌號的檢測識別。所有步驟分為3步完成 車牌號定位,車牌號字元分割 字元識別。本章為第一部分 車牌號定位。正式開始講解之前,先看下車牌號定位出來的效果演示。注 本文所有均 於網路。如圖所示,定位到車牌號之後,將車牌號用黃色框選起來,同時將該車牌複製為新顯示出...
opencv 車牌切割
usr bin env python3 coding utf 8 created on thu mar 21 12 42 15 2019 author lg import cv2 import numpy as np 形態學處理 def process img 高斯平滑 gaussian cv2.g...