回答編集履歴

1

a

2018/10/22 11:30

投稿

tiitoi
tiitoi

スコア21956

test CHANGED
@@ -23,3 +23,83 @@
23
23
  MNIST と画像の性質が異なるような場合、精度がでないことが考えられます。
24
24
 
25
25
  推論しようとしている画像 img2 がどのような画像か cv2.imwrite() で保存して、質問欄に貼ることはできますか?
26
+
27
+
28
+
29
+ ## 追記
30
+
31
+
32
+
33
+ ![イメージ説明](3878bea4f269b26faf972ad5db58c81a.png)
34
+
35
+ 質問者さんが推論しようとしている画像
36
+
37
+
38
+
39
+ ![イメージ説明](f488ba77410561e61ee5e96c95b4e067.png)
40
+
41
+ MNIST の画像
42
+
43
+
44
+
45
+ 見ていただければわかると思いますが、推論しようとしている画像が学習にしようした MNIST の画像と性質が大きく異なっていますね。
46
+
47
+ 多少の違いであれば大丈夫なのですが、学習したデータと性質が大きくかけ離れている場合、推論はうまくいかないでしょう。
48
+
49
+
50
+
51
+ 以下のように、画像処理で見た目を MNIST の画像に近づけたところ、6 と正しく認識されました。
52
+
53
+
54
+
55
+ ```
56
+
57
+ import cv2
58
+
59
+ import matplotlib.pyplot as plt
60
+
61
+
62
+
63
+ img = cv2.imread('test.jpg', cv2.IMREAD_GRAYSCALE)
64
+
65
+ img = cv2.resize(img, (28, 28))
66
+
67
+
68
+
69
+ # 表示
70
+
71
+ plt.imshow(img, cmap='gray')
72
+
73
+ plt.show()
74
+
75
+
76
+
77
+ img = cv2.bitwise_not(img) # ネガポジ反転
78
+
79
+ _, img = cv2.threshold(img, 110, 255, cv2.THRESH_TOZERO) # 110 未満の輝度値を0
80
+
81
+ img = cv2.morphologyEx(img, cv2.MORPH_DILATE, np.ones((2, 2), np.uint8)) # 膨張演算で白い線を太くする。
82
+
83
+
84
+
85
+ # 表示
86
+
87
+ plt.imshow(img, cmap='gray')
88
+
89
+ plt.show()
90
+
91
+
92
+
93
+ x = img.reshape(1, -1) # (H, W) -> (1, H * W)
94
+
95
+ pred_label = model.predict_classes(x)
96
+
97
+ print(pred_label) # 推論結果 6
98
+
99
+ ```
100
+
101
+
102
+
103
+ ![イメージ説明](752ad45698145e61e84c63d0589f8c3f.png)
104
+
105
+ 前処理した結果