基于Openmv的色块识别代码及注意事项

在给出代码之前我先说注意事项以及需要用到的函数

1、白平衡和自动增益的关闭

打开白平衡和自动增益会影响颜色识别的效果,具体影响体现在可能使你颜色阈值发生改变

关闭代码如下

sensor.set_auto_gain(False)     #关闭自动增益
sensor.set_whitebal(False)       #关闭白平衡

2、用于寻找色块的函数

image.find_blobs(thresholds, roi=Auto, x_stride=2, y_stride=1, invert=False, area_threshold=10, pixels_threshold=10, merge=False, margin=0, threshold_cb=None, merge_cb=None)

(1)需要注意的参数

thresholds:色彩阈值的元组(LAB形式)

ROI:ROI的四个参数按照顺序分别是顶点的x轴坐标,顶点的y轴坐标,矩形的长度,矩形的宽度

x_stride:查找的色块x方向上最小宽度的像素,默认为2,默认情况x方向长度小于2像素的色块自动忽略

y_stride:查找的色块y方向上最小宽度的像素,默认为1,默认情况y方向长度小于1像素的色块自动忽略

area_threshold:面积阈值,如果色块被框起来的面积小于这个值,会被过滤掉

pixel_threshold:像素个数阈值,如果色块像素数量小于这个值,会被过滤掉

merge:合并,如果设置为True,那么合并所有重叠的blob为一个。(注意,这会合并所有的blob,无论是什么颜色的。如果你想不同颜色的分开,需要在代码上分别处理)

(2)颜色阈值的调节

调节工具位置如下:工具\机器视觉\阈值编辑器

需要注意的一点:想要更好地调节阈值,需要了解一下LAB 

(3)关于LAB的拓展

L代表明度,取值0~100

A代表从绿色到红色的分量:取值-128~127

B代表从蓝色到黄色的分量:取值-128~127

这样规定是根据人类的视觉原理,灵长类动物的视觉都有两条通道:红绿通道和蓝黄通道,大多数动物只有一条通道,如果有人缺失其中的一条,就是我们所说的色盲。(以上的红绿和蓝黄通道并非纯色,只是接近的颜色用红绿和蓝黄描述比较方便)

关于每个通道具体的色阶划分,有兴趣的同学可以自己去了解,我这里就不作过多赘述 

(4)函数返回的东西

blob对象中有还能多方法返回不同的参数,我们可以利用这些参数做很多事情

返回对象详见:寻找色块 · OpenMV中文入门教程

3、多颜色识别

在Openmv官方给出的示例中,直接寻找所有色块,这样就会导致merge为True时合并不同颜色色块

所以我利用标志位写了一份分别扫描的代码

    flag += 1
    if flag > 3:
        flag = 1

    # 根据当前 flag 使用相应的阈值
    threshold = thresholds[flag-1]

    blobs = img.find_blobs([threshold], x_stride=7, y_stride=7, merge=True)

4、全部代码

在给出全部代码之前说明一点:LAB阈值需要自己调,不然就会框框满天飞

# 导入依赖的模块
import sensor
import image
import time

# 阈值
thresholds = [
    (63, 100, -37, -12, -26, 0),  # 通用红色阈值
    (30, 100, -64, -8, -32, 32),  # 通用绿色阈值
    (0, 15, 0, 40, -80, -20),     # 通用蓝色阈值
]

# 初始化设置
sensor.reset()  # 重置摄像头模块,以确保摄像头处于已知的初始状态
sensor.set_pixformat(sensor.RGB565)  # 像素格式设置
sensor.set_framesize(sensor.QVGA)  # 分辨率大小设置,QVGA为320x240
sensor.skip_frames(time=2000)  # 让摄像头跳过前两秒的帧,为了在实际图像捕获之前,摄像头有足够的时间自动调整
sensor.set_auto_gain(False)  # 必须关闭自动增益以进行颜色跟踪
sensor.set_auto_whitebal(False)  # 必须关闭自动白平衡以进行颜色跟踪
clock = time.clock()

flag = 0

# 进入循环
while True:
    clock.tick()  # 用于更新时钟对象的时钟戳,方便后续计算帧率和测量时间间隔
    img = sensor.snapshot()

    # 更新 flag
    flag += 1
    if flag > 3:
        flag = 1

    # 根据当前 flag 使用相应的阈值
    threshold = thresholds[flag-1]

    blobs = img.find_blobs([threshold], x_stride=7, y_stride=7, merge=True)
    if blobs:
        for blob in blobs:
            img.draw_rectangle(blob.rect())  # 绘制矩形
            if flag == 1:
                print("红色")
            elif flag == 2:
                print("绿色")
            elif flag == 3:
                print("蓝色")

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/735597.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【笔记】HashMap的头插死循环问题

HashMap头插死循环是指在JDK1.7中,多线程环境下,HashMap进行扩容时由于多个线程一起执行扩容,可能会导致某一结点被错误插入头部并形成一个循环链表。 发生死循环的源码如下: // hashmap由数组链表构成 void transfer(Entry[] ne…

MySQL进阶——触发器

目录 1介绍 2语法 3案例 3.1 insert插入数据类型 3.2 update修改数据类型 3.3 delete删除数据类型 4视图/存储过程/触发器—小结 1介绍 触发器是与表有关的数据库对象,指在insert/update/delete之前(BEFORE)或之后(AFTER),触发并执行触发器中定义…

mysql启动时遇到:本地计算机上的MySQL服务启动后停止

1.问题重述: 今早启动数据库时发现无法启动,报错:本地计算机 上的 MySQL服务启动后停止。某些服务在未由其他服务或程序使用时将自动停止。 2.解决方案: 1.数据备份: 2.在bin目录下,命令行中输入 mysqld …

认识微服务

单体架构 单体架构:将业务的所有功能集中在一个项目中开发,打成一个包部署。 优点: 架构简单部署成本低缺点: 团队协作成本高系统发布效率低系统可用性差 总结: 单体架构适合开发功能相对简单,规模较小…

上位机图像处理和嵌入式模块部署(mcu开发注意事项)

【 声明:版权所有,欢迎转载,请勿用于商业用途。 联系信箱:feixiaoxing 163.com】 mcu的种类很多,生产的厂家很多。这里面有进口的,有国产的,并且国产替代的趋势越来越明显。但是,不管…

我国人工智能核心产业规模近6000亿元

以下文章来源:中国证券报 2024世界智能产业博览会6月20日至6月23日在天津举行。会上发布的《中国新一代人工智能科技产业发展报告2024》显示,我国人工智能企业数量已经超过4000家,人工智能已成为新一轮科技革命和产业变革的重要驱动力量和战略…

SAP PP学习笔记22 - 生产订单(制造指图)的元素1

前面几章讲了PP 里面生产计划的各种策略以及策略的Customize。 SAP PP学习笔记20 - 复习总结一下MTS,MTO,ATO的各种生产策略-CSDN博客 SAP PP学习笔记21 - 计划策略的Customize:策略组 > 策略 > 需求类型 &#xff1…

Java——集合(一)

前言: Collection集合,List集合 文章目录 一、Collection 集合1.1 集合和数组的区别1.2 集合框架1.3 Collection 集合常用方法1.4 Collction 集合的遍历 二、List 集合2.1 List 概述2.2 List集合的五种遍历方式2.3 List集合的实现类 一、Collection 集合 1.1 集合和…

正则表达式,linux文本三剑客

正则表达式匹配的是文本内容,linux的文本三剑客都是针对文本内容,按行进行匹配 文本三剑客: grep 过滤文本内容 sed 针对文本内容进行增删改查 awd 按行取列 一.grep命令 作用就是使用正则表达式来匹配文本内容 -m 数字:匹配…

什么是深度神经网络?与深度学习、机器学习、人工智能的关系是什么?

什么是深度神经网络?与深度学习、机器学习、人工智能的关系是什么? 🤖什么是深度神经网络?与深度学习、机器学习、人工智能的关系是什么?摘要引言正文内容1. 什么是深度神经网络?🧠1.1 深度神经…

git拉取gitee项目到本地

git安装等不做赘述。 根据需要选择不同操作 1.只是单纯拉取个项目,没有后续的追踪等操作 不需要使用git init初始化本地文件夹 新建一个文件夹用于存储项目,右键选择 git bash here 会出现命令行窗口 如果像我一样,只是拉取个项目作业&…

stm32学习笔记---GPIO输入(代码部分)按键控制LED/光敏传感器控制蜂鸣器

目录 第一个代码:按键控制LED 模块化程序 LED驱动程序 GPIO的四个读取函数 GPIO_ReadInputDataBit GPIO_ReadInputData GPIO_ReadOutputDataBit GPIO_ReadOutputData Key驱动程序 第二个代码:光敏传感器控制蜂鸣器 蜂鸣器驱动代码 光敏传感器…

[C++][设计模式][模板方法]详细讲解

目录 1.动机2.理解1.设计流程对比1.结构化软件设计流程2.面向对象软件设计流程 2.早绑定与晚绑定 3.模式定义4.要点总结5.代码感受1.代码一 -- 结构化1.lib.cpp2.app.cpp 2.代码二 -- 面向对象1.lib.cpp2.app.cpp 1.动机 在软件构建过程中,对于某一项任务&#xff…

“实习情报官”上万月薪!量化私募发力学界

选拔要求有“门道” 量化私募的招聘又有新花样! 顶尖高校的数理人才一直是量化机构紧盯的“资源”,包括各类奥赛奖牌得主、理科状元。 最头部的量化机构,也一直是高校学霸们流向的去处。 但是,当业内已有近30家百亿量化私募机…

LLVM——安装多版本LLVM和Clang并切换使用(Ubuntu)

1、描述 本机(Ubuntu22)已经安装了LLVM-14,但是需要使用LLVM-12。安装LLVM-12和Clang-12并切换使用。 2、过程 安装LLVM-12和Clang-12。 sudo apt-get install llvm-12 sudo apt-get install clang-12 【注】运行 sudo apt-get install ll…

Inpaint软件最新版下载【安装详细图文教程】

​根据使用者情况表明在今天的数字时代,我们经常会遇到需要处理图形的情况,然而,当我们遇到水印在图形上,我们就需要寻找一个有效的方式来去除它,Inpaint软件就是一个非常实用的工具,它能够帮助我们去除水印…

6月21日训练 (东北林业大学)(个人题解)(待补全)

前言: 这次训练是大一大二一起参加的训练,总体来说难度是有的,我和队友在比赛时间内就写出了四道题,之后陆陆续续又补了了三道题,还有一道题看了学长题解后感觉有点超出我的能力范围了,就留给以后的自己吧。…

带百分比的进度条控件(ProgressBar)源码

带百分比的进度条控件(ProgressBar): 源码下载地址:https://download.csdn.net/download/wgxds/89472915

淘酒屋荣获2024中法贸易杰出服务商称号暨夏季窖主大会圆满召开

淘酒屋荣获中法贸易杰出服务商称号,暨闪光的创始人2024夏季窖主大会圆满召开 2024年,作为中法建交60周年的重要节点,同时迎来了中法文化旅游年,这为两国文化交流与合作开启了新的篇章。在庆祝中法贸易交流的重要时刻,…

[SAP ABAP] 追加内表数据

向内表中逐条追加数据记录 语法格式 APPEND <wa> TO <itab>. <wa>&#xff1a;代表工作区 <itab>&#xff1a;代表内表 示例1 结果显示&#xff1a; 将一个内表中的所有数据记录添加到另一个内表中 语法格式 APPEND LINES OF <itab1> TO <…