CV12_ONNX转RKNN模型(谛听盒子)

暂时简单整理一下:

1.在边缘设备上配置相关环境。

2.配置完成后,获取模型中间的输入输出结果,保存为npy格式。

3.将onnx格式的模型,以及中间输入输出文件传送到边缘设备上。

4.编写一个python文件用于转换模型格式,dataset作为测试可以是随便的数据。

5.将python传送到边缘设备上并运行。

注意:所有文件要在同一目录下。

参考代码一:

python 复制代码
# Author:SiZhen
# Create: 2024/7/15
# Description: ONNX转RKNN
import os
import numpy as np
from rknn.api import RKNN

def convert_onnx_to_rknn(onnx_path,rknn_path,input_data,output_data):
    #创建RKNN对象
    rknn = RKNN()
    rknn.config(
        target_platforms='rk3588',
        quantized_algorithm='mmse',
        optimization_level = 2
    )
    #加载ONNX模型
    print('loading ONNX model...')
    ret = rknn.load_onnx(model=onnx_path)
    if ret !=0:
        print("load failed!")
        return
    #构建模型,进行RKNN模型转换
    print('building rknn model...')
    ret = rknn.build(do_quantization=False,dataset='/home/DiTing/sizhen/dataset.txt')
    if ret !=0:
        print('Build RKNN model failed!')

    #导出RKNN模型
    print('Exporting RKNN model...')
    ret = rknn.export_rknn(rknn_path)
    if ret != 0:
        print('Export RKNN failed!')
        return
    print('RKNN model is successfully exported to ',rknn_path)

    rknn.init_runtime()
    outputs=rknn.inference(inputs=[input_data],data_format='nchw')
    try:
        if np.test.assert_almost_equal(outputs[0],output_data,decimal=1)is None:
            print('模型输出与预期一致。')
    except AssertionError as e :
        print("不一致,详细信息:",e)

#转换模型
i = 0
onnx_path = r'/home/DiTing/sizhen/resNet34.onnx'
rknn_path = onnx_path.replace('.onnx','.rknn')
input_data = np.load('/home/DiTing/sizhen/input_data.npy')
output_data = np.load('/home/DiTing/sizhen/output_data.npy')
convert_onnx_to_rknn(onnx_path,rknn_path,input_data,output_data)

问题及解决方法

问题一

安装失败。

解决方法:这个地方,谛听盒子应该是arm的版本而不是x86:(Lite版本)

问题二

安装成功找不到属性

解决方法:用如下包替代

问题三

lite版本缺少属性

初步讨论结果:lite版本应该是只包含运行环境的,最好不要在盒子上进行模型转换,会又慢又卡,可能利特版本就是没有模型转换的功能的。

解决方法:在其他环境转换。(待更新)可能的解决办法:https://bbs.eeworld.com.cn/thread-1283146-1-1.html

相关推荐
罗西的思考17 小时前
AI Agent框架探秘:拆解 OpenHands(10)--- Runtime
人工智能·算法·机器学习
冬奇Lab18 小时前
OpenClaw 源码精读(2):Channel & Routing——一条消息如何找到它的 Agent?
人工智能·开源·源码阅读
冬奇Lab18 小时前
一天一个开源项目(第38篇):Claude Code Telegram - 用 Telegram 远程用 Claude Code,随时随地聊项目
人工智能·开源·资讯
孟健19 小时前
Karpathy 用 200 行纯 Python 从零实现 GPT:代码逐行解析
python
格砸19 小时前
从入门到辞职|从ChatGPT到OpenClaw,跟上智能时代的进化
前端·人工智能·后端
可观测性用观测云20 小时前
可观测性 4.0:教系统如何思考
人工智能
sunny86520 小时前
Claude Code 跨会话上下文恢复:从 8 次纠正到 0 次的工程实践
人工智能·开源·github
小笼包包仔20 小时前
OpenClaw 多Agent软件开发最佳实践指南
人工智能
smallyoung20 小时前
AgenticRAG:智能体驱动的检索增强生成
人工智能
_skyming_20 小时前
OpenCode 如何做到结果不做自动质量评估,为什么结果还不错?
人工智能