openmv传承(一):自动灰度颜色跟踪示例

这篇具有很好参考价值的文章主要介绍了openmv传承(一):自动灰度颜色跟踪示例。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

前言:

好久没有详细的把之前学习过的openmv的知识整理一下,今天特地抽出一点时间稍微的讲一下几个openmv自带的例程。

一、代码展示

#自动灰度颜色跟踪示例
#
#此示例显示使用OpenMV Cam的单色自动灰度颜色跟踪。 
import sensor, image, time
print("让自动算法运行。不要在摄像机前放置任何东西")
#让自动算法运行。不要在摄像机前放置任何东西
sensor.reset()
sensor.set_pixformat(sensor.GRAYSCALE)
sensor.set_framesize(sensor.QVGA)
sensor.skip_frames(time = 2000)
sensor.set_auto_gain(False) # 关闭自动自动增益。默认开启的
sensor.set_auto_whitebal(False) # 关闭白平衡
clock = time.clock()
#初始化定义
print("初始化完成")
# 捕获图像中心的颜色阈值。
r = [(320//2)-(50//2), (240//2)-(50//2), 50, 50] #QVGA的50x50中心
#QVGA是320*240的屏幕分辨率 所以这个就比较好理解了,因为要画框,r里面的四个参数分别为左上侧坐标,左下侧坐标,右上侧坐标,右下侧坐标。
print("自动算法完成。将要跟踪的对象放在框中的摄像机前面")
print("确保要跟踪的对象的颜色被框完全包围")
#确保要跟踪的对象的颜色被框完全包围!
for i in range(60):#60次循环
    img = sensor.snapshot()#拍照
    img.draw_rectangle(r)#画框

print("学习阈值中///")
threshold = [128, 128] # 中等灰度值。 当灰度Gray小于阈值T时,其像素设置为0,表示黑色;当灰度Gray大于或等于阈值T时,其Y值为255,表示白色。 
for i in range(60):#60次循环
    img = sensor.snapshot()#拍照
    hist = img.get_histogram(roi=r)#获取直方图(颜色直方图)(它所描述的是不同色彩在整幅图像中所占的比例)
    lo = hist.get_percentile(0.01) # 获取直方图在1%范围内的CDF(根据需要进行调整)!
    hi = hist.get_percentile(0.99) # 获取直方图在99%范围内的CDF(根据需要进行调整)!
    #CDF(cumulative distribution function)叫做累积分布函数,描述一个实数随机变量X的概率分布,是概率密度函数的积分。
    #以百分位值表示的平均值。
    threshold[0] = (threshold[0] + lo.value()) // 2 #颜色阈值下限
    threshold[1] = (threshold[1] + hi.value()) // 2 #颜色阈值上限
    print("颜色阈值下限:%f" %threshold[0])
    print("颜色阈值上限:%f" %threshold[1])
    for blob in img.find_blobs([threshold], pixels_threshold=100, area_threshold=100, merge=True, margin=10):#在识别到颜色里循环
        #pixels_threshold 像素阀值 area_threshold 面积阈值 merge合并  merge 边缘
        img.draw_rectangle(blob.rect())#画框 blob.rect 色块边界框值(矩形数组)
        img.draw_cross(blob.cx(), blob.cy())#画十字
        img.draw_rectangle(r)#画框
        #thresholds是颜色的阈值,注意:这个参数是一个列表,可以包含多个颜色。
        #如果你只需要一个颜色,那么在这个列表中只需要有一个颜色值,如果你想要多个颜色阈值,那这个列表就需要多个颜色阈值。
        #注意:在返回的色块对象blob可以调用code方法,来判断是什么颜色的色块。
print("已学习阈值")
print("跟踪颜色")

while(True):
    clock.tick()#返回一个上次调用的时间(以毫秒计)
    img = sensor.snapshot()
    for blob in img.find_blobs([threshold], pixels_threshold=100, area_threshold=100, merge=True, margin=10):
        img.draw_rectangle(blob.rect())#画框
        img.draw_cross(blob.cx(), blob.cy())#画十字,x,y是坐标,
        print([threshold])
    print(clock.fps())#输出时钟帧率,即是识别速率

这边我已经把注释写的较为详细。基本上把疑惑点全写了出来。

二、代码讲解

(1)初始化设计

sensor.reset()
sensor.set_pixformat(sensor.GRAYSCALE)
sensor.set_framesize(sensor.QVGA)
sensor.skip_frames(time = 2000)
sensor.set_auto_gain(False) # 关闭自动自动增益。默认开启的
sensor.set_auto_whitebal(False) # 关闭白平衡
clock = time.clock()
#初始化定义

这一段基本上openmv所以的色块识别都会用到

(2)获得想要追踪颜色的颜色直方图

r = [(320//2)-(50//2), (240//2)-(50//2), 50, 50] #QVGA的50x50中心
#QVGA是320*240的屏幕分辨率 所以这个就比较好理解了,因为要画框,r里面的四个参数分别为左上侧坐标,左下侧坐标,右上侧坐标,右下侧坐标。
print("自动算法完成。将要跟踪的对象放在框中的摄像机前面")
print("确保要跟踪的对象的颜色被框完全包围")
#确保要跟踪的对象的颜色被框完全包围!
for i in range(60):#60次循环
    img = sensor.snapshot()#拍照
    img.draw_rectangle(r)#画框

print("学习阈值中///")
threshold = [128, 128] # 中等灰度值。 当灰度Gray小于阈值T时,其像素设置为0,表示黑色;当灰度Gray大于或等于阈值T时,其Y值为255,表示白色。 
for i in range(60):#60次循环
    img = sensor.snapshot()#拍照
    hist = img.get_histogram(roi=r)#获取直方图(颜色直方图)(它所描述的是不同色彩在整幅图像中所占的比例)
    lo = hist.get_percentile(0.01) # 获取直方图在1%范围内的CDF(根据需要进行调整)!
    hi = hist.get_percentile(0.99) # 获取直方图在99%范围内的CDF(根据需要进行调整)!
    #CDF(cumulative distribution function)叫做累积分布函数,描述一个实数随机变量X的概率分布,是概率密度函数的积分。
    #以百分位值表示的平均值。
    threshold[0] = (threshold[0] + lo.value()) // 2 #颜色阈值下限
    threshold[1] = (threshold[1] + hi.value()) // 2 #颜色阈值上限
    print("颜色阈值下限:%f" %threshold[0])
    print("颜色阈值上限:%f" %threshold[1])

这里使用颜色直方图的方式,通过取其颜色直方图的CDF的方式,获得颜色在基础灰度上的偏移。

(3)进行迭代确定阈值

for blob in img.find_blobs([threshold], pixels_threshold=100, area_threshold=100, merge=True, margin=10):#在识别到颜色里循环
        #pixels_threshold 像素阀值 area_threshold 面积阈值 merge合并  merge 边缘
        img.draw_rectangle(blob.rect())#画框 blob.rect 色块边界框值(矩形数组)
        img.draw_cross(blob.cx(), blob.cy())#画十字
        img.draw_rectangle(r)#画框
        #thresholds是颜色的阈值,注意:这个参数是一个列表,可以包含多个颜色。
        #如果你只需要一个颜色,那么在这个列表中只需要有一个颜色值,如果你想要多个颜色阈值,那这个列表就需要多个颜色阈值。
        #注意:在返回的色块对象blob可以调用code方法,来判断是什么颜色的色块。
print("已学习阈值")
print("跟踪颜色")

三、总结

经过博主用openmv本身的阀值计算器对比之后,感觉这种方式测量出的阈值还是比较合理的。

博主的测试如下:

openmv灰度阈值,openmv,python,opencv,计算机视觉

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

颜色阈值下限:50.000000
颜色阈值上限:77.000003

到了这里,关于openmv传承(一):自动灰度颜色跟踪示例的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

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

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

相关文章

  • openMV实现颜色追踪

    本文在openMV的官网上即可查找(只方便本人查找):openMV追踪小车

    2024年02月14日
    浏览(28)
  • 【OpenMv】颜色模式之Lab

    颜色模式有HSB、RGB、CMYK三种模式,RGB是用于屏幕显示和视频输出,CMYK是用于打印的,HSB是一种直观的观察方法,那Lab颜色模式是干什么的? Lab的全称是CIELAB,有时候也写成CIE L a b* 这里的CIE代表International Commission on Illumination(国际照明委员会),它是一个关于光照、颜色等

    2024年02月11日
    浏览(38)
  • 毕设分享 stm32与openmv的目标跟踪系统

    文章目录 0 前言 课题简介 设计框架 3 硬件设计 4 软件设计 判断被测物体所在区域 5 最后 🔥 这两年开始毕业设计和毕业答辩的要求和难度不断提升,传统的毕设题目缺少创新和亮点,往往达不到毕业答辩的要求,这两年不断有学弟学妹告诉学长自己做的项目系统达不到老师

    2024年02月12日
    浏览(35)
  • 毕业设计 基于stm32与openmv的目标跟踪系统

    文章目录 0 前言 课题简介 设计框架 3 硬件设计 4 软件设计 判断被测物体所在区域 5 最后 🔥 这两年开始毕业设计和毕业答辩的要求和难度不断提升,传统的毕设题目缺少创新和亮点,往往达不到毕业答辩的要求,这两年不断有学弟学妹告诉学长自己做的项目系统达不到老师

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

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

    2024年02月03日
    浏览(44)
  • 嵌入式毕设分享 stm32与openmv的目标跟踪系统

    文章目录 0 前言 课题简介 设计框架 3 硬件设计 4 软件设计 判断被测物体所在区域 5 最后 🔥 这两年开始毕业设计和毕业答辩的要求和难度不断提升,传统的毕设题目缺少创新和亮点,往往达不到毕业答辩的要求,这两年不断有学弟学妹告诉学长自己做的项目系统达不到老师

    2024年02月13日
    浏览(41)
  • OpenMV4 基于色块识别的图形+颜色+坐标识别代码(micropython)

    Hello大家好,最近竞赛需要开始研究OpenMV4,今天和大家分享一段基于 色块识别的图形+颜色+坐标识别代码 ,实测准确率高于90%哦,当然,需要在光线和距离都合适的情况下使用(假如你的识别结果不尽如人意,可以自行调节颜色阈值和目标与摄像头的距离),下面,话不多说

    2024年02月15日
    浏览(36)
  • 【OpenCV常用函数:颜色空间转换、阈值化】cv2.cvtColor()+cv2.threshold()

    对图像进行颜色空间的转换 对图像进行阈值化/二值化

    2024年02月13日
    浏览(50)
  • 使用 ESP32 CAM 和 OpenCV 进行颜色检测和跟踪

    这个项目是关于使用 ESP32 CAM 模块 和 OpenCV 进行颜色检测和跟踪的 。因此,我们将在 实时视频流 中检测任何特定颜色。颜色检测是识别物体所必需的,它也被用作各种图像编辑和绘图应用程序的工具。 这种方法与其他ESP32-CAM 颜色检测方法 完全不同,因为我们不是为 Microc

    2024年02月10日
    浏览(35)
  • 基于FPGA的颜色模型和帧差法的目标检测跟踪算法实现

    目录 一、理论基础 二、核心程序 三、仿真结论          目标跟踪中,基础的差分法,存在较大的缺陷,比如目标静止状态,那么就无法检测,如果场景中,运动的物体非常多,那么就会出现检测混乱的情况,如果摄像机存在较为剧烈的抖动,同样会导致检测失败。然后

    2024年02月07日
    浏览(44)

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

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

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

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

二维码1

领取红包

二维码2

领红包