| |
| |
| |
| |
| |
|
|
|
|
| import numpy as np |
| import cv2 as cv |
|
|
| class PPResNet: |
| def __init__(self, modelPath, labelPath): |
| self._modelPath = modelPath |
| self._model = cv.dnn.readNet(self._modelPath) |
| self._labelPath = labelPath |
|
|
| self._inputNames = '' |
| self._outputNames = ['save_infer_model/scale_0.tmp_0'] |
| self._inputSize = [224, 224] |
| self._mean = np.array([0.485, 0.456, 0.406])[np.newaxis, np.newaxis, :] |
| self._std = np.array([0.229, 0.224, 0.225])[np.newaxis, np.newaxis, :] |
|
|
| |
| self._labels = self._load_labels() |
|
|
| def _load_labels(self): |
| labels = [] |
| with open(self._labelPath, 'r') as f: |
| for line in f: |
| labels.append(line.strip()) |
| return labels |
|
|
| @property |
| def name(self): |
| return self.__class__.__name__ |
|
|
| def setBackend(self, backend_id): |
| self._model.setPreferableBackend(backend_id) |
|
|
| def setTarget(self, target_id): |
| self._model.setPreferableTarget(target_id) |
|
|
| def _preprocess(self, image): |
| image = image.astype(np.float32, copy=False) / 255.0 |
| image -= self._mean |
| image /= self._std |
| return cv.dnn.blobFromImage(image) |
|
|
| def infer(self, image): |
| assert image.shape[0] == self._inputSize[1], '{} (height of input image) != {} (preset height)'.format(image.shape[0], self._inputSize[1]) |
| assert image.shape[1] == self._inputSize[0], '{} (width of input image) != {} (preset width)'.format(image.shape[1], self._inputSize[0]) |
|
|
| |
| inputBlob = self._preprocess(image) |
|
|
| |
| self._model.setInput(inputBlob, self._inputNames) |
| outputBlob = self._model.forward(self._outputNames) |
|
|
| |
| results = self._postprocess(outputBlob) |
|
|
| return results |
|
|
| def _postprocess(self, outputBlob): |
| class_id = np.argmax(outputBlob[0]) |
| return self._labels[class_id] |