2018-01-27 充值卡OCR的嘗試

充值卡上的卡號(hào)蘸嘶、密碼是否OCR識(shí)別训唱?我要嘗試一下雪情,今天記錄第一步巡通,圖像分割宴凉,將數(shù)字分割出來(lái)弥锄。下一步是數(shù)字二次分割蟆沫、訓(xùn)練饭庞、識(shí)別。

充值卡的圖是這樣的:

chongzhika.jpg

直接上代碼卤恳,注釋中解釋處理過(guò)程突琳。


import cv2
import imutils
from imutils import contours
import numpy as np


#open convert to gray  打開(kāi)圖片符相,轉(zhuǎn)換為灰度圖 
img=cv2.imread("chongzhika.jpg")
bimg=cv2.cvtColor(img,cv2.COLOR_BGR2GRAY) 
#cv2 里面的色彩序列是 BGR 
#cv2.imshow('bimg',bimg)
#cv2.waitKey()


#threshold 二值化并翻轉(zhuǎn)主巍,二值化的閾值 設(shè)置為12 ,由于照片上的右側(cè)白色部分逛艰,因?yàn)椴蝗缱髠?cè)黑色的部分明顯搞旭,
#在二值化中會(huì)被過(guò)濾掉肄渗,這里偷懶了,最好的做法是做直方圖分析欠动,獲取到中間黑白的分割線(xiàn)具伍,
#然后截取黑色部分處理圈驼。所以在這里二值化的閾值大小人芽,會(huì)影響后面分割的效果。
#threshod infect the result!
bimg=cv2.threshold(bimg,12,255,cv2.THRESH_BINARY_INV)[1]

#調(diào)整一下圖片绩脆,旋轉(zhuǎn)為橫向的萤厅,并且調(diào)整大小
bimg=imutils.rotate(bimg,90)
bimg=cv2.resize(bimg,(int(bimg.shape[1]/2),int(bimg.shape[0]/2)))
cv2.imshow('bimg',bimg)
cv2.waitKey()


#contors  開(kāi)始搜索輪廓

#算子用的兩個(gè)核
rectKernel=cv2.getStructuringElement(cv2.MORPH_RECT,(9,3))
sqKernel=cv2.getStructuringElement(cv2.MORPH_RECT,(6,6))
##tophat 第一次遮罩
tophat=cv2.morphologyEx(bimg,cv2.MORPH_TOPHAT,rectKernel)
cv2.imshow('tophat',tophat)
cv2.waitKey()

##compute 做,sobel算子邊緣檢測(cè)后靴迫,二次進(jìn)行均值增強(qiáng)
gradX=cv2.Sobel(tophat,ddepth=cv2.CV_32F,dx=1,dy=0,ksize=1)
gradX=np.absolute(gradX)
(minVal,maxVal)=(np.min(gradX),np.max(gradX))
gradX=(255*((gradX-minVal)/(maxVal-minVal)))
gradX=gradX.astype('uint8')

##2 對(duì)增強(qiáng)后的圖像進(jìn)行閉運(yùn)算--二值化---二次閉預(yù)算 
gradX=cv2.morphologyEx(gradX,cv2.MORPH_CLOSE,rectKernel)
thresh=cv2.threshold(gradX,0,255,cv2.THRESH_BINARY|cv2.THRESH_OTSU)[1]
thresh=cv2.morphologyEx(thresh,cv2.MORPH_CLOSE,sqKernel)

#獲得大輪廓惕味,目的就是將白色的數(shù)字部分連在一起,方便后面的輪廓檢測(cè)
cv2.imshow('thresh',thresh)
cv2.waitKey()

#filter
#預(yù)留玉锌,將各種噪點(diǎn)濾除
## 獲取連續(xù)區(qū)域
cnts=cv2.findContours(thresh.copy(),cv2.RETR_EXTERNAL,cv2.CHAIN_APPROX_SIMPLE)
cnts=cnts[0] if imutils.is_cv2() else cnts[1]
cnts=contours.sort_contours(cnts,method='left-to-right')[0]

locs=[]
locs2=[]

#loop over the contors 循環(huán)判斷連續(xù)區(qū)域的寬高比名挥,寬度、高度是否符合預(yù)期
for(i,c) in enumerate(cnts):

    (x,y,w,h)=cv2.boundingRect(c)
    ar=w/float(h)

#password 4 digits       因?yàn)榭艿?數(shù)字中芬沉,四個(gè)字母一組比較多躺同,所以設(shè)置寬高比為 2.5 --4.5 
    if ar>2.5 and ar<5.0:
        print('ar=',ar)
        print('x=',x,'y=',y,'width=',w,'height=',h)
        if(w>15 and w< 180) and (h> 15 and h<30):
            locs.append((x,y,w,h))
# password 3 digits 3個(gè)數(shù)字的寬高比略微小點(diǎn),也別漏了,當(dāng)然也會(huì)帶來(lái)很多噪點(diǎn)
    if ar>1.5 and ar<2.5:
            print('ar=',ar)
            print('x=',x,'y=',y,'width=',w,'height=',h)
            if(w>15 and w< 180) and (h> 15 and h<30):
                locs.append((x,y,w,h))
#number 15 digits 卡號(hào)的部分,超長(zhǎng)检吆,設(shè)置大點(diǎn)的寬高比章鲤,同時(shí)這里也有個(gè)問(wèn)題就是最下面的條碼寬高比是一樣的,通過(guò)高度區(qū)分,這里設(shè)置h 在15-30 之間,是觀(guān)察出來(lái)的酥泛。捶索。。需要考慮圖片的傾斜璃弄、小角度旋轉(zhuǎn)脐供、大小等變化
    if ar>10 or ar<20:
        if(w>100 and w< 300) and (h> 15 and h<30):
            locs2.append((x,y,w,h))
        
print('locs=', locs)
print('locs2=', locs2)

#將檢測(cè)到的輪廓在圖上畫(huà)出來(lái)
if(len(locs)>0):
    output = cv2.merge([bimg] * 3)
    for (x,y,w,h) in locs:
        cv2.rectangle(output, (x - 2, y - 2), (x + w + 4, y + h + 4), (0, 255, 0), 2)
 
    if(len(locs2)>0):
 
        for (x,y,w,h) in locs2:
            cv2.rectangle(output, (x - 2, y - 2), (x + w + 4, y + h + 4), (0, 0, 255), 2)
    cv2.imshow('output',output)
    cv2.waitKey()

最終的效果,左側(cè)是進(jìn)行膨脹連通之后的效果印蓖,右側(cè)是最終進(jìn)行連續(xù)路徑檢測(cè)之后公浪,對(duì)數(shù)字的標(biāo)注,綠色是小寬高比的標(biāo)注,紅色是大寬高比的標(biāo)注。


分割2.png

目前的檢測(cè)只是初步的嘗試陌凳,無(wú)法應(yīng)對(duì)圖像的明暗、旋轉(zhuǎn)批狱、翻轉(zhuǎn)爪膊、大小等多種多樣的變化耘成,仍然需要繼續(xù)探索。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,546評(píng)論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件赃额,死亡現(xiàn)場(chǎng)離奇詭異竹勉,居然都是意外死亡飞盆,警方通過(guò)查閱死者的電腦和手機(jī)票腰,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,224評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén)完域,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人荤崇,你說(shuō)我怎么就攤上這事∽涌猓” “怎么了舱权?”我有些...
    開(kāi)封第一講書(shū)人閱讀 164,911評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀(guān)的道長(zhǎng)刚照。 經(jīng)常有香客問(wèn)我,道長(zhǎng)喧兄,這世上最難降的妖魔是什么无畔? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,737評(píng)論 1 294
  • 正文 為了忘掉前任,我火速辦了婚禮吠冤,結(jié)果婚禮上浑彰,老公的妹妹穿的比我還像新娘。我一直安慰自己拯辙,他們只是感情好郭变,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,753評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著涯保,像睡著了一般诉濒。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上夕春,一...
    開(kāi)封第一講書(shū)人閱讀 51,598評(píng)論 1 305
  • 那天未荒,我揣著相機(jī)與錄音,去河邊找鬼及志。 笑死片排,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的速侈。 我是一名探鬼主播率寡,決...
    沈念sama閱讀 40,338評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼倚搬!你這毒婦竟也來(lái)了冶共?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 39,249評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎比默,沒(méi)想到半個(gè)月后幻捏,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,696評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡命咐,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,888評(píng)論 3 336
  • 正文 我和宋清朗相戀三年篡九,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片醋奠。...
    茶點(diǎn)故事閱讀 40,013評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡榛臼,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出窜司,到底是詐尸還是另有隱情沛善,我是刑警寧澤,帶...
    沈念sama閱讀 35,731評(píng)論 5 346
  • 正文 年R本政府宣布塞祈,位于F島的核電站金刁,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏议薪。R本人自食惡果不足惜尤蛮,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,348評(píng)論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望斯议。 院中可真熱鬧产捞,春花似錦、人聲如沸哼御。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,929評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)恋昼。三九已至看靠,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間液肌,已是汗流浹背衷笋。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,048評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留矩屁,地道東北人辟宗。 一個(gè)月前我還...
    沈念sama閱讀 48,203評(píng)論 3 370
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像吝秕,于是被迫代替她去往敵國(guó)和親泊脐。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,960評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容