Сканирование листа пузырей OMR с помощью Python OpenCV - PullRequest
0 голосов
/ 19 июня 2019

Я работаю над сканером пузырьковых листов OMR, определяя правильные пузырьковые ответы с помощью python openCV.При выполнении с кодом ниже я не получаю ответы правильно.Может ли кто-нибудь пройти код и сообщить мне, где я допустил ошибку?

Я попытался с изображением URL ниже

https://www.pyimagesearch.com/wp-content/uploads/2016/10/omr_test_01.png

import cv2 as cv
import numpy as np

image = cv.imread("H:/omr_test_01.png",0)
image1 = cv.imread("H:/omr_test_01.png")
correct_answers = ['B','E','A','C','B']

crop_img = image[157:975, 42:330]
#print(crop_img)
answers = []

itr = 0

for itr in range(2):
    if itr ==0:
        img1 = crop_img[0:818, 0:120]
    else:
        img1 = crop_img[0:818, 167:288]


    img1 = cv.GaussianBlur(img1,(5,5),0)

    img1 = cv.Canny(img1,100,200)

    img1 = cv.adaptiveThreshold(img1,255,cv.ADAPTIVE_THRESH_MEAN_C,cv.THRESH_BINARY,11,2)
    img1 = cv.adaptiveThreshold(img1,255,cv.ADAPTIVE_THRESH_MEAN_C,cv.THRESH_BINARY,11,2)
    img1 = cv.adaptiveThreshold(img1,255,cv.ADAPTIVE_THRESH_MEAN_C,cv.THRESH_BINARY,11,2)
    img1 = cv.adaptiveThreshold(img1,255,cv.ADAPTIVE_THRESH_MEAN_C,cv.THRESH_BINARY,11,2)
    img1 = cv.adaptiveThreshold(img1,255,cv.ADAPTIVE_THRESH_MEAN_C,cv.THRESH_BINARY,11,2)


    img1 = cv.GaussianBlur(img1,(5,5),0)

    img = img1
    img = cv.equalizeHist(img)

    cimg = cv.cvtColor(img,cv.COLOR_GRAY2BGR)
    print(cimg)
    img1 = cv.Canny(img1,100,200)
    img1 = cv.Canny(img1,100,200)
    img1 = cv.Canny(img1,0,255,cv.THRESH_BINARY_INV | cv.THRESH_OTSU)[1]
    img1 = cv.GaussianBlur(img1,(5,5),1)
    img1 = cv.GaussianBlur(img1,(5,5),1)

    circles = cv.HoughCircles(img,cv.HOUGH_GRADIENT,1,10,param1=50,param2=50,minRadius=0,maxRadius=0)
    circles = np.uint16(np.around(circles))
    k=0
    for i in circles[0,:]:
        cv.circle(cimg,(i[0],i[1]),2,(0,255,0),3)
        k = k+1

        cv.waitKey(0)
        cv.destroyAllWindows()


       for i in range(k):
            answers.append(circles[0][i][0]+circles[0][i][1]+circles[0][i][2])


sheet = len(answers)

final_answers = []
for i in range(0,5):
    j = i
    ind = 0
    index = ind
    index = 0
    max = answers[j]
    for j in range(i+1):
        if max<=answers[j]:
            max = answers[j]
            ind = ind+1
            index = ind
    if index == 0:
        final_answers.append('A')
    if index == 1:
        final_answers.append('B')
    if index == 2:
        final_answers.append('C')
    if index == 3:
        final_answers.append('D')
    if index == 4:
        final_answers.append('E')


mark = 0
itrr = len(final_answers)
for i in range(itrr):
    if final_answers[i]==correct_answers[i]:
        mark = mark+1
print(final_answers)
print(mark)


font = cv.FONT_HERSHEY_SIMPLEX

cv.putText(image1,'Marks:2/5', (20,450), font, 2,(0,0,255),3,cv.LINE_AA)
cv.imshow('marks',image1)
cv.waitKey(0)
cv.destroyAllWindows()

Фактический вывод:

['B', 'E', 'A', 'C', 'B']

5

Получение результата:

['B', 'B', 'C', 'C', 'D']

4

...