Mxnet框架使用

目录

1.mxnet推理API

2.MXNET模型转ONNX

3.运行示例

1.mxnet推理API

python 复制代码
# 导入 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()  

2.MXNET模型转ONNX

python 复制代码
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

3.运行示例

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

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

提取码: 24ei

python 复制代码
# 导入 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') 
相关推荐
子燕若水4 小时前
Unreal Engine 5中的AI知识
人工智能
极限实验室5 小时前
Coco AI 实战(一):Coco Server Linux 平台部署
人工智能
杨过过儿5 小时前
【学习笔记】4.1 什么是 LLM
人工智能
巴伦是只猫5 小时前
【机器学习笔记Ⅰ】13 正则化代价函数
人工智能·笔记·机器学习
伍哥的传说5 小时前
React 各颜色转换方法、颜色值换算工具HEX、RGB/RGBA、HSL/HSLA、HSV、CMYK
深度学习·神经网络·react.js
大千AI助手5 小时前
DTW模版匹配:弹性对齐的时间序列相似度度量算法
人工智能·算法·机器学习·数据挖掘·模版匹配·dtw模版匹配
AI生存日记6 小时前
百度文心大模型 4.5 系列全面开源 英特尔同步支持端侧部署
人工智能·百度·开源·open ai大模型
LCG元6 小时前
自动驾驶感知模块的多模态数据融合:时序同步与空间对齐的框架解析
人工智能·机器学习·自动驾驶
why技术6 小时前
Stack Overflow,轰然倒下!
前端·人工智能·后端