• Mxnet框架使用


    目录

    1.mxnet推理API

    2.MXNET模型转ONNX

    3.运行示例

    1.mxnet推理API

    1. # 导入 MXNet 深度学习框架
    2. import mxnet as mx
    3. if __name__ == '__main__':
    4. # 指定预训练模型的 JSON 文件
    5. json_file = 'resnext50_32x4d'
    6. # 指定模型的参数文件
    7. params_file = 'resnext50_32x4d-0000.params'
    8. # 使用 MXNet 加载模型的架构和参数
    9. sym, arg_params, aux_params = mx.model.load_checkpoint(json_file, 0)
    10. # 创建一个模型对象
    11. mod = mx.mod.Module(symbol=sym, context=mx.cpu(), label_names=None)
    12. # 绑定模型参数和输入数据的形状
    13. mod.bind(for_training=False, data_shapes=[('data', (1, 3, 224, 224))])
    14. # 设置模型的参数
    15. mod.set_params(arg_params, aux_params)
    16. # 将输入数据转换为 MXNet 的 NDArray 格式
    17. data = mx.nd.array(img)
    18. # 使用模型进行推理,获取输出并转换为 NumPy 数组
    19. output = mod.predict(data).asnumpy()

    2.MXNET模型转ONNX

    1. import numpy as np
    2. import mxnet as mx
    3. from mxnet.contrib import onnx as onnx_mxnet
    4. sym = "resnext50_32x4d-symbol.json"
    5. params = "resnext50_32x4d-0000.params"
    6. input_shape = (1 ,3 ,224 ,224)
    7. onnx_file = './resnext50.onnx'
    8. converted_model_path = onnx_mxnet.export_model(sym, params, [input_shape], np.float32, onnx_file)
    9. # onnx 1.14.0
    10. # numpy 1.23.2

    3.运行示例

    具体代码和模型见百度网盘

            https://pan.baidu.com/s/1iQELVg7xNjiIlSZZp47xag

            提取码: 24ei 

    1. # 导入 NumPy 库,并将其别名命名为 np
    2. import numpy as np
    3. # 导入 OpenCV 库
    4. import cv2
    5. # 导入 MXNet 深度学习框架
    6. import mxnet as mx
    7. # 导入时间库,用于计时
    8. import time
    9. # 定义一个函数 show_top5,用于显示前5个类别及其概率
    10. def show_top5(outputs):
    11. # 使用 softmax 函数对输出进行概率归一化
    12. output = softmax(outputs[0])
    13. # 对概率从高到低排序,获取排序后的索引
    14. reverse_sort_index = np.argsort(output)[::-1]
    15. # 打印标识,表示接下来是前5个类别
    16. print('-----TOP 5-----')
    17. # 循环遍历前5个类别
    18. for i in range(5):
    19. # 打印类别索引和对应的概率
    20. print(reverse_sort_index[i], ':', output[reverse_sort_index[i]])
    21. # 定义 softmax 函数,用于计算 softmax 概率
    22. def softmax(x):
    23. return np.exp(x) / sum(np.exp(x))
    24. if __name__ == '__main__':
    25. # 从文件中加载图像
    26. img = cv2.imread('./space_shuttle_224.jpg')
    27. # 对图像进行预处理,将其从 BGR 格式转换为 RGB 格式,并调整数据类型为 float32,
    28. # 然后进行维度转置和形状重塑,以匹配模型的输入格式
    29. img = cv2.cvtColor(img, cv2.COLOR_BGR2RGB).astype('float32').transpose(2, 0, 1).reshape(1, 3, 224, 224)
    30. # 指定预训练模型的 JSON 文件
    31. json_file = 'resnext50_32x4d'
    32. # 指定模型的参数文件
    33. params_file = 'resnext50_32x4d-0000.params'
    34. # 记录开始时间
    35. t1 = time.time()
    36. # 使用 MXNet 加载模型的架构和参数
    37. sym, arg_params, aux_params = mx.model.load_checkpoint(json_file, 0)
    38. # 创建一个模型对象
    39. mod = mx.mod.Module(symbol=sym, context=mx.cpu(), label_names=None)
    40. # 绑定模型参数和输入数据的形状
    41. mod.bind(for_training=False, data_shapes=[('data', (1, 3, 224, 224))])
    42. # 设置模型的参数
    43. mod.set_params(arg_params, aux_params)
    44. # 将输入数据转换为 MXNet 的 NDArray 格式
    45. data = mx.nd.array(img)
    46. # 使用模型进行推理,获取输出并转换为 NumPy 数组
    47. output = mod.predict(data).asnumpy()
    48. # 记录结束时间
    49. t2 = time.time()
    50. # 打印推理所需的时间
    51. print("inf_time:", t2 - t1)
    52. # 调用显示前5个类别及其概率的函数
    53. show_top5(output)
    54. # 打印 "done" 表示脚本执行完成
    55. print('done')

  • 相关阅读:
    谷粒学院——后台管理系统功能模块
    将json数据导入到ES集群——解决方案对比&填坑日记
    mybatis实战:三、mybatis多表查询的映射
    字符驱动开发2
    47_ue4进阶末日生存游戏开发[基础游戏循环]
    git在linux情况下设置git 命令高亮
    05-Redis 持久化之RDB 的奥秘
    热门股权项目:富滇银行股份有限公司0.0232%股权转让
    猿创征文 |【算法面试入门必刷】动态规划-线性dp(二)
    【Android笔记14】Android基本的UI控件(Chronometer、SeekBar、RatingBar)
  • 原文地址:https://blog.csdn.net/weixin_43999691/article/details/134156067