Files
2024-12-01 17:46:49 +08:00

59 lines
1.7 KiB
Python

import cv2 as cv
import joblib
from matplotlib import pyplot as plt, rcParams
# 导入模型
classifier = joblib.load('models/classifier.pkl')
# 导入测试图片
img=cv.imread('test.png',cv.IMREAD_GRAYSCALE)
# 设置中文字体
rcParams['font.sans-serif'] = ['SimHei']
rcParams['axes.unicode_minus'] = False
# 预处理图像
img=cv.resize(img,(28,28))
_,img_classifier=cv.threshold(img, 0, 255, cv.THRESH_BINARY + cv.THRESH_OTSU)
img_classifier=cv.blur(img,(3,3))
# 特征提取
def extract_contour_features(img):
contours, _ = cv.findContours(img, cv.RETR_EXTERNAL, cv.CHAIN_APPROX_SIMPLE)
contour = contours[0]
area = cv.contourArea(contour)
perimeter = cv.arcLength(contour, True)
return [area, perimeter]
def extract_shape_features(contour):
x, y, w, h = cv.boundingRect(contour)
aspect_ratio = float(w) / h
rect_area = w * h
shape_factor = cv.contourArea(contour) / rect_area
return [aspect_ratio, shape_factor]
def extract_hu_moments(contour):
moments = cv.moments(contour)
hu_moments = cv.HuMoments(moments)
return hu_moments.flatten()
def extract_features(img):
contours, _ = cv.findContours(img, cv.RETR_EXTERNAL, cv.CHAIN_APPROX_SIMPLE)
contour = contours[0]
contour_features = extract_contour_features(img)
shape_features = extract_shape_features(contour)
hu_moments = extract_hu_moments(contour)
feature_vector = contour_features + shape_features + hu_moments.tolist()
return feature_vector
feature_vector = extract_features(img)
# 预测
predicted_label=classifier.predict([feature_vector])
plt.figure()
plt.imshow(img,cmap='gray')
plt.title('预测结果:'+str(predicted_label[0]))
plt.axis('off')
plt.tight_layout()
plt.show()