-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmnn_inference.py
77 lines (59 loc) · 2.42 KB
/
mnn_inference.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
import os
import time
import sys
import traceback
import cv2
import numpy as np
import MNN
def normalize(img, mean, std, max_pixel_value=255.0):
mean = np.array(mean, dtype=np.float32)
mean *= max_pixel_value
std = np.array(std, dtype=np.float32)
std *= max_pixel_value
denominator = np.reciprocal(std, dtype=np.float32)
img = img.astype(np.float32)
img -= mean[:, None, None]
img *= denominator[:, None, None]
return img
def transforms_cv2(image, resize=(224, 224)):
image = cv2.resize(image, (224, 224), interpolation=cv2.INTER_LINEAR)
image = cv2.cvtColor(image, cv2.COLOR_BGR2RGB)
image = image.transpose(2, 0, 1)
image = normalize(image, (0.485, 0.456, 0.406), (0.229, 0.224, 0.225))
return image
def main(args):
interpreter = MNN.Interpreter(args.mnn_path)
session = interpreter.createSession()
input_tensor = interpreter.getSessionInput(session)
interpreter.resizeTensor(input_tensor, (1, 3, 224, 224))
interpreter.resizeSession(session)
cnt = 0
bg_time = time.time()
for image_name in os.listdir(args.test_path):
try:
image_ = args.test_path + '/' + image_name
image = cv2.imread(image_)
image = transforms_cv2(image, resize=(args.resize, args.resize))
image = image[..., ::-1]
tmp_input = MNN.Tensor((1, 3, 224, 224), MNN.Halide_Type_Float, image, MNN.Tensor_DimensionType_Caffe)
input_tensor.copyFrom(tmp_input)
interpreter.runSession(session)
output_tensor = interpreter.getSessionOutput(session)
output = output_tensor.getData()
#print(f'output:{output}')
sys.stdout.flush()
cnt += 1
except:
#print(image)
traceback.print_exc()
total_time = time.time() - bg_time
print('Total used time:{}, Avg used time:{}'.format(total_time, total_time/cnt))
if __name__ == '__main__':
import argparse
parser = argparse.ArgumentParser(description='PyTorch Classification Inference')
parser.add_argument('--test-path', default='/ssd_1t/xum/nsfw/two_class/nsfw_binary/test/nsfw', help='dataset')
parser.add_argument('--mnn-path', default='exps/efficientnetb6/efficientnet_b6@epoch7_3199_0.01_fp32.mnn', help='mnn model')
parser.add_argument('--resize', default=224, type=int, help='size of resize')
args = parser.parse_args()
print(args)
main(args)