OpenMV:14巡线小车

这篇具有很好参考价值的文章主要介绍了OpenMV:14巡线小车。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

这个例子展示了在OpenMV Cam上使用get_regression()方法获得ROI的线性回归。使用这种方法,可以轻松让机器人跟踪所有指向相同大致方向的线。

本例程可以用于机器人巡线,效果非常好。

“巡线小车”的原理和“追小球的小车”是差不多一样的,其中car.py和pid.py完全一样,改动的就只有主函数main.py

追小球的小车

采用的是颜色识别算法,调用的是find_blobs()函数

巡线小车

采用的是线性回归算法,调用的是get_regression()函数:快速线性回归,返回视野中的一条回归直线,该函数可以得到直线的斜率、角度(或者说是偏移的距离),然后我们就可以用直线返回来的角度来控制我们的小球进行运动
如果我们在OpenMV视野中看到的直线正好是竖直的,说明我们看到的是一条位于正前方的直线,那么我们就可以控制小车的两个电机转速一样往前跑
如果我们在OpenMV视野中看到的直线是左偏45°,那么我们就可以控制我们的小车右边的电机比左边的速度快让小车稍微向左前方进行移动,右前方同理
openmv巡线小车,计算机视觉,python,机器学习

car.py和pid.py详见"追小球的小车"
使用时要将car.py和pid.py保存到OpenMV内置的flash中!

main.py文章来源地址https://www.toymoban.com/news/detail-583404.html

THRESHOLD = (5, 70, -23, 15, -57, 0) # 追踪的线的颜色阈值

import sensor, image, time
from pyb import LED
import car
from pid import PID

# 一条线的表示方法 " y = ax + b "   其中:
rho_pid = PID(p=0.4, i=0)   # 相当于“ b ”——> 截距        控制直线在视野中的位置(左右距离的偏移)最终目的是线在视野的中央
theta_pid = PID(p=0.001, i=0)   # 相当于“ a ”——> 斜率    控制直线偏移的角度    
        # 如果在运动过程中小车偏移得比较大或者是转弯转得比较大,那么就减小相应pid的值


# 打开OpenMV的RGB灯——>用于补光  因为颜色会受到环境光照的影响,所以我们建议最好打开OpenMV自带的补光灯来保持环境的稳定
LED(1).on()
LED(2).on()
LED(3).on()
    #如果开灯会造成严重反光,则关闭灯!

sensor.reset()

# 在安装时我们的OpenMV是倒着安装的,因此我们需要相应地在代码里把图像正过来!以下两句函数均是对图像进行镜像处理
sensor.set_vflip(True)      # 设置OpenMV图像“水平方向进行翻转”
sensor.set_hmirror(True)    # 设置OpenMV图像“竖直方向进行翻转”
sensor.set_pixformat(sensor.RGB565)
sensor.set_framesize(sensor.QQQVGA) # 线性回归算法的运算量大,越小的分辨率识别的效果越好,运算速度越快
#sensor.set_windowing([0,20,80,40])
sensor.skip_frames(time = 2000)     # 等待2秒    
        # 警告:如果使用QQVGA,有时处理帧可能需要几秒钟。
clock = time.clock()                

while(True):
    clock.tick()
    img = sensor.snapshot().binary([THRESHOLD]) # 截取一张图片,进行 “阈值分割”
                        # 阈值分割函数image.binary()对图像进行二值化(binary:二元的;由两部分组成的)
                        # 得到的效果是:将阈值颜色变成白色,非阈值颜色变成黑色
    
    # 调用线性回归函数
    line = img.get_regression([(100,100)], robust = True)# 对所有的阈值像素进行线性回归
                                                         # 线性回归的效果就是将我们视野中“二值化”分割后的图像回归成一条直线
                # get_regression()返回的是一条直线line
   
    #如果发现了线                                       
    if (line):# 利用得到的line对象来计算pid的值——>进而控制小车运动
        rho_err = abs(line.rho())-img.width()/2 # 计算我们的直线相对于中央位置偏移的距离(偏移的像素)
                    # abs()函数:返回数字的绝对值  line.rho():返回霍夫变换后的直线p值。
        
        # 进行坐标的变换:y轴方向为0°,x轴正方向为90°,x轴负方向为-90°
        if line.theta()>90:# line.theta()是我们得到的直线的角度
            theta_err = line.theta()-180
        else:
            theta_err = line.theta()
            
            
        # 将我们得到的直线画出来    
        img.draw_line(line.line(), color = 127)# line.line():返回一个直线元组(x1, y1, x2, y2)  
        
        print(rho_err,line.magnitude(),rho_err) #line.magnitude()返回一个表示“线性回归效果”的值,这个值越大,线性回归效果越好;
                                                               # 如果越接近于0,说明我们的线性回归效果越接近于一个圆,效果越差 
        if line.magnitude()>8:  # 如果线性回归的效果比较好
            #进行pid的运算
            rho_output = rho_pid.get_pid(rho_err,1) # 将刚刚计算出的rho_err传递进rho_pid中
            theta_output = theta_pid.get_pid(theta_err,1)
            output = rho_output+theta_output    # 将得到的两个pid参数进行相加,利用得到的参数output来控制小车电机的运动
            
            car.run(50+output, 50-output)# 对于左轮子来说就是+output,对于右轮子来说就是-output
                                         # 以中央速度50为基准值进行加减(car.run()函数中小车电机的速度为0-100)
                                         # 如果想让小车快一点就设置为大于50的数,慢一点就设置为小于50的数   
        else:# 如果线性回归的效果并不好
            car.run(0,0)    # 那么就停止运动
   
    # 如果没有发现线
    else:
        car.run(50,-50)# 原地旋转,寻找视野中的线
        pass
    #print(clock.fps())

到了这里,关于OpenMV:14巡线小车的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • OPENMV巡线转弯代码 适用于电赛优化版2022.6.29

    OPENMV通过UART进行通信 ROIS为5块感性区域,在160x120范围内分为5块,方便遇到路口和前方无道路的处理 largest_blob为blob模块[2]为色块w,[3]为色块h,官方docs上有说明 对out_str进行设置可看到串口输出的内容 然后就是一些变量有用没用的自己使用的时候删一下,这一份的逻辑还是

    2024年02月15日
    浏览(42)
  • 基于Openmv H7 Plus 的红色巡线+十字路口+多数字识别算法

    由于是采用命令集的方式控制openmv,摄像头不需要接收太多的数据,我采用的是判断串口接收的长度来区分命令集。flag为接收数据的长度,通过发送不同长度数据来改变openmv的工作模式 1.巡线 在openmv的开源库中有色块识别的关键函数blob(),可以传回识别出的矩形色块的中心

    2024年02月16日
    浏览(33)
  • STM32循迹小车系列教程(四)—— 使用OpenMV循迹

     本章节主要讲解如何使用OpenMV循迹以及OpenMV与STM32串口通信 软件:STM32CubeMx、Keil5 MDK、串口调试助手XCOM、OpenMV_IDE 硬件:OpenMV、STM32F103C8T6核心板、下载器ST_LINK、USB转TTL或J-LINK、小车一辆 OpenMV是一个开源,功能强大的 机器视觉 模块。 它以STM32F427CPU为核心,集成了OV7725摄像头

    2024年02月04日
    浏览(60)
  • 计算机视觉的应用14-目标检测经典算法之YOLOv1-YOLOv5的模型架构与改进过程详解,便于记忆

    大家好,我是微学AI,今天给大家介绍一下计算机视觉的应用14-目标检测经典算法之YOLOv1-YOLOv5的模型架构与改进过程详解,便于记忆。YOLO(You Only Look Once)是一种目标检测深度学习模型。想象一下,传统的目标检测方法就像侦探一样,需要仔细观察整个场景,逐个研究每个细

    2024年02月07日
    浏览(43)
  • 基于OpenMV和正点原子开发的自动追球小车(带云台舵机)

    电赛备赛前,通过OpenMV加舵机云平台由,做了一个追着球跑的小车,由于疫情,以前录制的视频也删除了,最终呈现的效果和B站一位Up主的相似,大家可以参考参考,链接如下:STM32 颜色识别 自动跟随小车_哔哩哔哩_bilibili,首先把我使用到的硬件的图片给大家看看。  电机

    2023年04月13日
    浏览(25)
  • openmv利用模板匹配+控制舵机来控制小车使P点触碰到靶心

    (注:每行代码的解释均已标注,适合复习使用和openmv新手学习) 定义舵机,servo(1)用的是openmv的p7引脚,servo(2)用的是openmv的p8引脚,servo(3)用的是openmv的p9引脚 设置对应的脉宽,分别对应为:允许的最小脉宽:500、允许的最大脉冲:2500、中心/零位置对应的脉宽:500 pid包的函数

    2024年02月14日
    浏览(33)
  • OpenMV 2022电赛泊车视觉方案

    作者第一次参加电赛,也是第一次接触OpenMV,通过几天的学习完成了对 车库 以及 边线巡线 的视觉识别方案,分享出来希望能提供一些思路给其他使用OpenMV的朋友。 车库T型连接处识别: 巡线的效果忘记截图了,不过代码里有,感兴趣的朋友可以跑一下试试。 本项目主要使

    2024年02月13日
    浏览(39)
  • 树莓派视觉小车 -- OpenCV巡线(HSL色彩空间、PID)

    目录 试错 试错1:形态学处理 试错2:HSV色彩空间 基础理论 1、HSV与HSL色彩空间 2、PID调节 一、OpenCV图像处理 1、在HSL色彩空间下得到二值图 2、 对二值图形态学处理 3、找出线的轮廓和中心点坐标 二、PID 三、运动控制 总代码 一开始用的形态学处理,自行改变阈值,调试之后

    2024年02月04日
    浏览(28)
  • 毕业设计 单片机与OpenMV机器视觉目标跟踪系统

    🔥 这两年开始毕业设计和毕业答辩的要求和难度不断提升,传统的毕设题目缺少创新和亮点,往往达不到毕业答辩的要求,这两年不断有学弟学妹告诉学长自己做的项目系统达不到老师的要求。 为了大家能够顺利以及最少的精力通过毕设,学长分享优质毕业设计项目,今天

    2024年02月03日
    浏览(35)
  • 计算机视觉 计算机视觉识别是什么?

    计算机视觉识别(Computer Vision Recognition)是计算机科学和人工智能领域中的一个重要分支,它致力于使计算机系统能够模拟和理解人类视觉的过程,从而能够自动识别、分析和理解图像或视频中的内容。这一领域的发展旨在让计算机具备视觉感知和理解的能力,使其能够从视

    2024年02月07日
    浏览(42)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包