yolov8检测模型pt转rknn

前言:

步骤是pt转onnx再转rknn。以下有些要点,请看代码备注。

一、pt2onnx.py

python 复制代码
import argparse
import cv2
import numpy as np
import onnxruntime as ort
import torch
from ultralytics import YOLO

model = YOLO("runs/detect/train3/weights/best.pt")
# 导出为 ONNX 格式,并指定保存路径
output_path = "runs/detect/train3/weights"  # 自定义路径
 # 指定保存目录  特别注意点:opset = 12
model.export(format="onnx", save_dir="custom_directory",opset = 12) 

二、onnx转rknn

onnx2rknn.py

注意点

  1. 准备校准图片
  2. 注意写好对应的相机型号
  3. 此转换过程是在pc端进行的
python 复制代码
from rknn.api import RKNN
import os


# ===================== 配置(v2.3.2 严格兼容版) =====================
ONNX_MODEL = "./runs/detect/train3/weights/best.onnx"    # 新导出的标准ONNX
RKNN_MODEL = "./runs/detect/train3/weights/obstacle_det.rknn"
TARGET_PLATFORM = "rk3588"   # 根据你使用的相机型号进行替换
CALIB_DIR = "./calib_images/"  # INT8校准图目录(10-50张同分布图片)
CALIB_LIST = "./calib_list.txt"  # 🔧 必须是.txt文件路径,不能是列表

# ===================== 自动生成校准数据集(关键修复) =====================
def get_calib_dataset(calib_dir, CALIB_LIST):
    # 自动遍历文件夹,获取所有图片路径
    img_ext = [".jpg", ".jpeg", ".png", ".bmp"]
    calib_data = []
    for root, _, files in os.walk(calib_dir):
        for file in files:
            if any(file.lower().endswith(ext) for ext in img_ext):
                calib_data.append(os.path.join(root, file))
    if len(calib_dataset) == 0:
        print("❌ calib_images目录下无图片,请放入10-50张校准图")
        exit(1)
    # 写入列表文件
    with open(OUTPUT_LIST, "w") as f:
        for path in calib_dataset:
            f.write(path + "\n")
    return CALIB_LIST
    # return calib_data



# ===================== 初始化RKNN =====================
rknn = RKNN(verbose=True)

# mean_values长度匹配3通道,删除input_size_list等手动指定参数
print("=== 配置RKNN模型(RK3588 v2.3.2兼容) ===")
rknn.config(
    mean_values=[[0, 0, 0]],
    std_values=[[255, 255, 255]],
    target_platform=TARGET_PLATFORM,
    quantized_dtype="w8a8",  # INT8量化
    optimization_level=3
)

# 删除inputs/outputs/input_size_list,让RKNN自动读取ONNX维度
print("=== 加载ONNX模型 ===")
ret = rknn.load_onnx(model=ONNX_MODEL)
if ret != 0:
    print("❌ 加载ONNX失败")
    exit(ret)

# 自动生成校准数据集,传入build函数
print("=== 加载校准图 ===")
CALIB_LIST = get_calib_dataset(CALIB_DIR, CALIB_LIST)

# ===================== 构建INT8 RKNN模型 =====================
print("=== 构建INT8 RKNN模型 ===")
ret = rknn.build(
    do_quantization=True,
    dataset=CALIB_LIST  # 校准图目录
)
if ret != 0:
    print("❌ 构建RKNN失败")
    exit(ret)

# ===================== 导出RKNN模型 =====================
print("=== 导出RKNN模型 ===")
ret = rknn.export_rknn(RKNN_MODEL)
if ret != 0:
    print("❌ 导出RKNN失败")
    exit(ret)

print(f"\n🎉 RK3588专用INT8 RKNN模型生成完成:{RKNN_MODEL}")
rknn.release()

三、最终验证步骤

  1. 放图:把 10~50 张图放进 calib_images/
  2. 生成列表:运行上面的生成脚本
  3. 转换:运行 python onnx2rknn.py
  4. 结果:生成 yolov8s_rk3588_int8.rknn
相关推荐
weixin_468466854 分钟前
千问大模型在阿里生态中的实战应用指南
大数据·人工智能·深度学习·ai·大模型·智能交互·自动应答
kTR2hD1qb17 分钟前
Claude Code Skill的介绍与使用
java·前端·数据库·人工智能
qq_3909347418 分钟前
Cursor使用教程
人工智能
码农小白AI20 分钟前
规范档案复核流程,IACheck+AI 报告审核满足资质监管要求
人工智能
Luhui Dev24 分钟前
大角几何 MCP 服务上线:让 AI Agent 直接完成几何作图
人工智能·数学·机器学习·大角几何·luhuidev
纤纡.25 分钟前
阿里云 DSW 实战:从零完成 Qwen3-4B 大模型 LoRA 微调全流程
人工智能·阿里云·语言模型·云计算
AI视觉网奇32 分钟前
3d 打印模型修复
人工智能·3d
“码”力全开43 分钟前
深度解析:基于 Docker 与边缘计算的 AI 视频管理平台架构——打通 GB28181/RTSP 协议与“源码交付”的高效集成方案
人工智能·docker·边缘计算
wangqiaowq1 小时前
预训练 后预训练 微调
人工智能·深度学习·机器学习
LONGZETECH1 小时前
架构师实战拆解|无人机智慧实训SaaS中台:断电续考、AI组卷、多端同步核心设计
大数据·人工智能·架构·系统架构·无人机