K210训练模型

1.新建文件夹,将K210采集的图片放入文件夹下‘tp’

在这里插入图片描述

2.打开YOLOV3,打开工具集,进行打标签操作

在这里插入图片描述

3.选择标签集保存地址

在这里插入图片描述
在这里插入图片描述

4.标签完成,准备训练工作,开始训练

在这里插入图片描述
在这里插入图片描述

5.复制.h5和.tflite文件到标签集和数据集的目录下

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

6.复制训练完成弹出的文件夹下的lable.txt和anchors.txt的这两个文件和模型转化成功后的.kmodel文件到SD卡中去

在这里插入图片描述
在这里插入图片描述

7.写入boot.py程序

import sensor
import image
import lcd
import KPU as kpu
from machine import UART
from Maix import GPIO
from fpioa_manager import fm
from board import board_info
import time
import utime

#fm.register(board_info.BOOT_KEY, fm.fpioa.GPIOHS1)
#key = GPIO(GPIO.GPIOHS1, GPIO.IN)

lcd.init()
sensor.reset(dual_buff=True)
sensor.set_pixformat(sensor.RGB565)
sensor.set_framesize(sensor.QVGA)
sensor.set_windowing((224, 224))
sensor.set_hmirror(0)
sensor.set_vflip(1)
sensor.run(1)
fm.register(0,fm.fpioa.UART1_TX)#0脚TX
fm.register(1,fm.fpioa.UART1_RX)#1脚RX
uart_A = UART(UART.UART1, 115200, 8, None, 1, timeout=1000, read_buf_len=4096)
pit=0
#task = kpu.load(0x300000) #从flash或者系统文件中加载模型,这里为模型在 flash 中的偏移大小为:0x3000000
task = kpu.load("/sd/sch.kmodel")
f=open("/sd/anchors.txt","r")
anchor_txt=f.read()
L=[]
for i in anchor_txt.split(","):
    L.append(float(i))
anchor=tuple(L)
f.close()
a = kpu.init_yolo2(task, 0.5, 0.3, 5, anchor)
f=open("/sd/lable.txt","r")
labels_txt=f.read()
labels = labels_txt.split(",")
f.close()
now_lable=0
last_lable=None
while(True):
    img = sensor.snapshot()
    code = kpu.run_yolo2(task, img)
    if code:
        for i in code:
            a=img.draw_rectangle(i.rect(),(0,255,0),2)
            a = lcd.display(img)
            for i in code:
                lcd.draw_string(i.x()+45, i.y()-5, labels[i.classid()]+" "+'%.2f'%i.value(), lcd.WHITE,lcd.GREEN)
                now_lable = i.classid()
                if now_lable != last_lable:
                    last_lable=now_lable
                    if i.classid()==0:
                        uart_A.write('c')
                        time.sleep_ms(200)
                    if i.classid()==1:
                        uart_A.write('q')
                        time.sleep_ms(200)
                    if i.classid()==2:
                        uart_A.write('k')
                        time.sleep_ms(200)
                    if i.classid()==3:
                        uart_A.write('y')
                        time.sleep_ms(200)
    else:
        a = lcd.display(img)

  • 4
    点赞
  • 60
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

自然醒欧

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值