OPENMV的学习(三)巡线

存储文件

插入sd卡,会将默认储存地址flash改为sd卡。

image.save("/example.jpg")

串口通信

传输面积最大的色块的坐标

# Blob Detection and uart transport
import sensor, image, time
from pyb import UART
import json
# For color tracking to work really well you should ideally be in a very, very,
# very, controlled enviroment where the lighting is constant...
yellow_threshold   = (65, 100, -10, 6, 24, 51)
# You may need to tweak the above settings for tracking green things...
# Select an area in the Framebuffer to copy the color settings.

sensor.reset() # Initialize the camera sensor.
sensor.set_pixformat(sensor.RGB565) # use RGB565.
sensor.set_framesize(sensor.QQVGA) # use QQVGA for speed.
sensor.skip_frames(10) # Let new settings take affect.
sensor.set_auto_whitebal(False) # turn this off.
clock = time.clock() # Tracks FPS.

uart = UART(3, 115200)
def find_max(blobs):
    max_size=0
    for blob in blobs:
        if blob.pixels() > max_size:
            max_blob=blob
            max_size = blob.pixels()
    return max_blob

while(True):
    img = sensor.snapshot() # Take a picture and return the image.

    blobs = img.find_blobs([yellow_threshold])
    if blobs:
        max_blob=find_max(blobs)
        print('sum :', len(blobs))
        img.draw_rectangle(max_blob.rect())
        img.draw_cross(max_blob.cx(), max_blob.cy())

        output_str="[%d,%d]" % (max_blob.cx(),max_blob.cy()) #方式1
        #output_str=json.dumps([max_blob.cx(),max_blob.cy()]) #方式2
        print('you send:',output_str)
        uart.write(output_str+'\r\n')
    else:
        print('not found!')

优化图像

直方图均衡化是通过拉伸像素强度分布范围来增强图像对比度的一种方法.说得更清楚一些, 以上面的直方图为例, 你可以看到像素主要集中在中间的一些强度值上. 直方图均衡化要做的就是 拉伸 这个范围. 见下面左图: 绿圈圈出了 少有像素分布其上的 强度值. 对其应用均衡化后, 得到了中间图所示的直方图. 均衡化的图像见下面右图.

# Blob Detection and uart transport
import sensor, image, time
from pyb import UART
import json
# For color tracking to work really well you should ideally be in a very, very,
# very, controlled enviroment where the lighting is constant...
yellow_threshold   = (65, 100, -10, 6, 24, 51)
# You may need to tweak the above settings for tracking green things...
# Select an area in the Framebuffer to copy the color settings.

sensor.reset() # Initialize the camera sensor.
sensor.set_pixformat(sensor.RGB565) # use RGB565.
sensor.set_framesize(sensor.QQVGA) # use QQVGA for speed.
sensor.skip_frames(10) # Let new settings take affect.
sensor.set_auto_whitebal(False) # turn this off.
clock = time.clock() # Tracks FPS.

uart = UART(3, 115200)
def find_max(blobs):
    max_size=0
    for blob in blobs:
        if blob.pixels() > max_size:
            max_blob=blob
            max_size = blob.pixels()
    return max_blob

while(True):
    img = sensor.snapshot() # Take a picture and return the image.

    blobs = img.find_blobs([yellow_threshold])
    if blobs:
        max_blob=find_max(blobs)
        print('sum :', len(blobs))
        img.draw_rectangle(max_blob.rect())
        img.draw_cross(max_blob.cx(), max_blob.cy())

        output_str="[%d,%d]" % (max_blob.cx(),max_blob.cy()) #方式1
        #output_str=json.dumps([max_blob.cx(),max_blob.cy()]) #方式2
        print('you send:',output_str)
        uart.write(output_str+'\r\n')
    else:
        print('not found!')

image.histeq([adaptive=False[, clip_limit=-1[, mask=None]]])
在图像上运行直方图均衡算法。 直方图均衡化使图像中的对比度和亮度标准化。
如果 adaptive 传递为True,那么将在图像上运行自适应直方图均衡方法,这通常比非自适应直方图限定更好,但运行时间更长
clip_limit 提供了一种限制自适应直方图均衡的对比度的方法。 使用较小的值(例如10)可以生成良好的直方图均衡对比度受限图像。
mask 是另一个用作绘图操作的像素级掩码的图像。掩码应该是一个只有黑色或白色像素的图像,并且应该与你正在绘制的 image 大小相同。 仅掩码中设置的像素被修改。
返回图像对象,以便您可以使用 . 表示法调用另一个方法。
不支持压缩图像和bayer图像。

线性回归(循迹)

线性回归能找到视野中任何的线,但是处理速度就会很慢,为了能更快的寻到我们想要的轨迹,把颜色调为灰度,不去处理追踪颜色,图像大小设成QQVGA,缩小图像面积,来增加速度。通过二值化,能让我们想要的线条更加清晰,使用binary()来获取图像信息,用mean(2)来消噪。
==image.erode(size[, threshold[, mask=None]])==从分割区域的边缘删除像素。
这一方法通过卷积图像上((size2)+1)x((size2)+1)像素的核来实现,如果相邻像素集的总和小于 threshold ,则对内核的中心像素进行归零。若 threshold 未设定,这个方法的功能如标准腐蚀方法一样。若threshold设定,您就可以指定腐蚀的特定像素,例如:设置低于2个的像素周围阈值为2。
mask 是另一个用作绘图操作的像素级掩码的图像。掩码应该是一个只有黑色或白色像素的图像,并且应该与你正在绘制的 image 大小相同。最后通过image.get_regression(阀值)来找线。
巡线代码如下

while(True):
    clock.tick()
    img = sensor.snapshot().binary([THRESHOLD]) if BINARY_VISIBLE else sensor.snapshot()

    # 返回类似于由find_lines()和find_line_segments()返回的线对象。
    # 你有x1(),y1(),x2(),y2(),length(),
    # theta()(以度为单位的旋转),rho()和magnitude()。
    #
    # magnitude() 表示线性回归的工作情况。这对于鲁棒的线性回归意味着不同
    # 的东西。一般来说,值越大越好...
    line = img.get_regression([(255,255) if BINARY_VISIBLE else THRESHOLD],roi = ROI,robust = True)
    img.mean(2)
    if (line):
        img.draw_line(line.line(), color = 255)#127
        #print(line.theta())
        th = line.theta()
        if th > 90:
            th = 180 - th
            if th > 7:
                print('L',th)
        else:
            if line.theta() > 7:
                print('R',line.theta())
                
  • 10
    点赞
  • 161
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
### 回答1: openmv巡线颜色是指在openmv机器视觉模块中,使用巡线传感器对地面的线路进行检测时,所采用的线路颜色。openmv支持多种巡线传感器,包括黑白线、彩色线、红外线等等。不同的巡线传感器对颜色的要求也不同。在使用openmv进行巡线的时候,需要根据不同的巡线传感器,选择合适的线路颜色。 对于黑白线巡线传感器,对线路的颜色要求相对较低,因为它只需要检测黑色和白色的对比度即可。在黑色和白色之间,其余颜色的线路都会被认为是无效的。 对于彩色线巡线传感器,就需要更为精确的色彩识别。根据巡线传感器的灵敏度,可以选取不同颜色的线路进行巡线。通常情况下,比较常用的线路颜色是红色、蓝色、绿色等几种。 对于红外线巡线传感器,使用的是红外线光源进行检测。其对线路颜色的要求也较低,但是对线路的反光度有一定要求。因此,需要选择较为光滑、反光度较高的线路。 总的来说,选择合适的巡线传感器和线路颜色,可以提高openmv巡线系统的稳定性和准确性。 ### 回答2: OpenMV 是一种基于 Python 的微控制器,可以让开发者轻松地进行计算机视觉应用程序的开发。其中之一的应用场景就是巡线,而颜色检测是其中的一种重要方法。 OpenMV 巡线的工作原理是通过摄像头采集地面图像后,通过算法分析判断机器人当前的位置,从而控制机器人的运动方向。颜色检测是其中必不可少的一步。 在 OpenMV 中,我们可以通过调用图像处理库中的函数对采集到的图像进行颜色识别。对于巡线来说,我们需要设定一段颜色范围,将符合要求的像素点标记为白色,不符合要求的像素点标记为黑色,这样就得到了一张黑白二值图像。然后,我们可以用二值图像上的连通域来分析轮廓和种子点,以此来确定机器人的运动轨迹。 具体来说,我们可以根据实际情况来设定颜色范围。首先,我们需要调节摄像头的曝光度和白平衡来确保图像质量较好。然后,我们可以通过图像处理库中的颜色阈值函数来获取目标颜色范围的二值图像,可以通过调整阈值参数来获取更好的效果。 总之,OpenMV 巡线是一种基于计算机视觉的自动化控制技术,而颜色检测则是其很重要的一部分。只有通过对颜色范围的精确定义,才能实现对机器人运动轨迹的精确控制。 ### 回答3: OpenMV巡线识别是一种在机器人领域中常见的技术,它的基本原理是使用摄像头逐帧获取场景图像,然后通过图像处理算法提取出巡线所需的特征,最终通过算法判断行进方向。 在OpenMV中,巡线识别最常见的特征是颜色。使用OpenMV进行巡线识别的第一步就是要确定颜色的阈值,这个阈值不仅包括巡线粗略的颜色,也包括周围环境色彩对颜色认知的影响。 经过网上资料的总结,以下是OpenMV巡线识别的基础流程: 1. 程序启动后,需要将摄像头输送的画面转换成HSV(色相、饱和度、亮度)值。 2. 指定阈值范围,确定需要识别的巡线颜色。 3. 进行二值化处理,通过比较前后两帧图像的差异,识别并方向巡线。 4. 整合旋转、调整转动速度等控制机器人行进方向。 需要注意的是,在OpenMV巡线识别过程中,颜色阈值和环境亮度均会影响识别效果,因此,在使用OpenMV进行巡线时,需对阈值进行精确的调节,同时要保证环境光线充足、整洁,避免出现误判误差。 总之,OpenMV巡线识别是一种使用机器视觉技术实现自主行进的方法,其核心是通过对画面中的颜色进行识别,辅以其他辅助技术,实现了自主行进的功能,有着广泛的应用前景。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值