目录
- # 导入 MXNet 深度学习框架
- import mxnet as mx
-
-
- if __name__ == '__main__':
-
- # 指定预训练模型的 JSON 文件
- json_file = 'resnext50_32x4d'
-
- # 指定模型的参数文件
- params_file = 'resnext50_32x4d-0000.params'
-
- # 使用 MXNet 加载模型的架构和参数
- sym, arg_params, aux_params = mx.model.load_checkpoint(json_file, 0)
-
- # 创建一个模型对象
- mod = mx.mod.Module(symbol=sym, context=mx.cpu(), label_names=None)
- # 绑定模型参数和输入数据的形状
- mod.bind(for_training=False, data_shapes=[('data', (1, 3, 224, 224))])
-
- # 设置模型的参数
- mod.set_params(arg_params, aux_params)
-
- # 将输入数据转换为 MXNet 的 NDArray 格式
- data = mx.nd.array(img)
-
- # 使用模型进行推理,获取输出并转换为 NumPy 数组
- output = mod.predict(data).asnumpy()
- import numpy as np
- import mxnet as mx
- from mxnet.contrib import onnx as onnx_mxnet
-
-
- sym = "resnext50_32x4d-symbol.json"
- params = "resnext50_32x4d-0000.params"
- input_shape = (1 ,3 ,224 ,224)
- onnx_file = './resnext50.onnx'
-
- converted_model_path = onnx_mxnet.export_model(sym, params, [input_shape], np.float32, onnx_file)
- # onnx 1.14.0
- # numpy 1.23.2
具体代码和模型见百度网盘:
https://pan.baidu.com/s/1iQELVg7xNjiIlSZZp47xag
提取码: 24ei
- # 导入 NumPy 库,并将其别名命名为 np
- import numpy as np
- # 导入 OpenCV 库
- import cv2
- # 导入 MXNet 深度学习框架
- import mxnet as mx
- # 导入时间库,用于计时
- import time
-
-
- # 定义一个函数 show_top5,用于显示前5个类别及其概率
- def show_top5(outputs):
- # 使用 softmax 函数对输出进行概率归一化
- output = softmax(outputs[0])
- # 对概率从高到低排序,获取排序后的索引
- reverse_sort_index = np.argsort(output)[::-1]
- # 打印标识,表示接下来是前5个类别
- print('-----TOP 5-----')
- # 循环遍历前5个类别
- for i in range(5):
- # 打印类别索引和对应的概率
- print(reverse_sort_index[i], ':', output[reverse_sort_index[i]])
-
- # 定义 softmax 函数,用于计算 softmax 概率
- def softmax(x):
- return np.exp(x) / sum(np.exp(x))
-
-
- if __name__ == '__main__':
- # 从文件中加载图像
- img = cv2.imread('./space_shuttle_224.jpg')
-
- # 对图像进行预处理,将其从 BGR 格式转换为 RGB 格式,并调整数据类型为 float32,
- # 然后进行维度转置和形状重塑,以匹配模型的输入格式
- img = cv2.cvtColor(img, cv2.COLOR_BGR2RGB).astype('float32').transpose(2, 0, 1).reshape(1, 3, 224, 224)
-
- # 指定预训练模型的 JSON 文件
- json_file = 'resnext50_32x4d'
-
- # 指定模型的参数文件
- params_file = 'resnext50_32x4d-0000.params'
-
- # 记录开始时间
- t1 = time.time()
-
- # 使用 MXNet 加载模型的架构和参数
- sym, arg_params, aux_params = mx.model.load_checkpoint(json_file, 0)
-
- # 创建一个模型对象
- mod = mx.mod.Module(symbol=sym, context=mx.cpu(), label_names=None)
-
- # 绑定模型参数和输入数据的形状
- mod.bind(for_training=False, data_shapes=[('data', (1, 3, 224, 224))])
-
- # 设置模型的参数
- mod.set_params(arg_params, aux_params)
-
- # 将输入数据转换为 MXNet 的 NDArray 格式
- data = mx.nd.array(img)
-
- # 使用模型进行推理,获取输出并转换为 NumPy 数组
- output = mod.predict(data).asnumpy()
-
- # 记录结束时间
- t2 = time.time()
-
- # 打印推理所需的时间
- print("inf_time:", t2 - t1)
-
- # 调用显示前5个类别及其概率的函数
- show_top5(output)
-
- # 打印 "done" 表示脚本执行完成
- print('done')