终于能识别自己的手写体了,正确率从10%,上升到了50%?
记录一下
1、预处理过程
(1)灰度 :此过程和PS里面的灰度类似
(2)大小调整:需要使用的参数为InterpolationFlags.Area不能使用默认值,但效果比不上PS的两次立方
(3)反相 : 和ps的效果相同
(4)阈值调整:和ps效果相同
(5)切割:subMat
(6)调整为20*20
代码分享如下:
Mat temp = Cv2.ImRead("2010.png", ImreadModes.Grayscale).Clone();
Cv2.Resize(temp, temp, new Size(400, 190),0,0,InterpolationFlags.Area); //
Cv2.BitwiseNot(temp, temp);
Cv2.Threshold(temp, temp, 20, 255, ThresholdTypes.Binary);
Mat aimImg = temp.SubMat(i * rowD, i * rowD + rowD, j * colD, j * colD + colD).Clone();//取得待识别的矩阵
Mat aim = new Mat(20, 20, aimImg.Type(),Scalar.All(0));//生成一个20*20的全黑矩阵
Mat roi = aim.SubMat(0, 19, 0, 20);
aimImg.CopyTo(roi);
Cv2.ImWrite(i.ToString()+".png", aim);
aim = aim.Reshape(1, 1);
aim.ConvertTo(aim, MatType.CV_32F);
float res_f = knn.Predict(aim);
我自己写的字是10行,每行20个。在A4纸上写后扫描的。处理后发现,裁剪变成了20*19大小。
故在保证长宽比例不变的情况下,显然新图片处理为400*190合适。
另外在缩小的情况下,需要用area,不能用默认值。
对识别的图要求20*20,显然把20*19的图用resize处理为20*20是不合适的。
故这里生成了一个全黑矩阵,并把图片拷贝到此图片上。后面和其他类似。不再累述。