Я обучаю сверточную нейронную сеть распознавать символы MRZ (машиночитаемой зоны) на смартфоне. Я хочу знать, должен ли я для тренировки точности использовать несколько шрифтов, даже если MRZ использует только OCR-B. Кроме того, модель не работает на устройстве с тем же уровнем точности, что и в коде Python, который я использую для обучения / тестирования. Есть идеи?
Это архитектура, которую я использую:
model = Sequential()
model.add(Convolution2D(filters=32, kernel_size=(3, 3), strides=(2, 2), activation='relu', input_shape=input_shape))
model.add(MaxPooling2D(pool_size=(2, 2)))
model.add(Dropout(0.5))
model.add(Convolution2D(filters=64, kernel_size=(1, 1), strides=(1, 1), activation='relu'))
model.add(MaxPooling2D(pool_size=(2, 2)))
model.add(Dropout(0.2))
model.add(Flatten())
model.add(Dense(128, activation='relu'))
model.add(Dense(num_classes, activation='softmax'))
model.compile(loss='categorical_crossentropy', optimizer='adam', metrics=['accuracy'])