Openmv和k210识别物体颜色,形状,以及与STM32单片机的通信。两者之间的比较

Openmv识别颜色和形状


提示:需要考虑光照,更换场地需要重新调节颜色阈值

文章目录

  • Openmv识别颜色和形状
  • 前言
  • 一、openmv参数调节
    • 1.颜色阈值
    • 2.更改函数参数,来限制识别区域,提高精度
    • 3.更改参数density和size的判定范围,提高识别的精度
  • 二、openmv识别方法
    • 1. 每次取所识别区域的最大值
    • 2.识别二维码
  • 三、openmv与STM32进行通信
    • 1. openmv端发送函数
    • 2.STM32端接收
  • 四、openmv与k210的区别
    • 1.k210串口配置
    • 2.k210屏幕配置
  • 总结


前言

在STM32端,使用mode值来设置openmv的模式:

mode的值是0,表示停止,不识别;(不使用openmv时,在STM32端将mode值设置为0)
mode的值是1,表示同时识别颜色和形状;
mode的值是2,表示识别小球颜色;
mode的值是3,表示识别二维码;

STM32端使用三个变量接收,openmv发来的数据:

color的值是1,表示红色;
color的值是2,表示蓝色;

shape的值是1,表示圆环;
shape的值是2,表示正方形;
shape的值是3,表示矩形;

color_circle的值是1,表示红色;
color_circle的值是2,表示蓝色;
color_circle的值是3,表示黄色;
color_circle的值是4,表示白色;

openmv串口(使用USART3):

P4端口是TX,接单片机的RX
P5端口是RX,接单片机的TX


一、openmv参数调节

1.颜色阈值

#设置颜色阈值
#更换场景,如果识别效果不好需要重新调阈值
red1 = (32, 75, 28, 89, 93, -6)
red2 = (70, 19, 66, 23, 68, -35)
blue = (41, 8, -47, 97, -24, -107)
yellow = (38, 89, -22, 25, 78, 29)
white = (33, 84, -34, 61, -72, -2)

2.更改函数参数,来限制识别区域,提高精度

red_blobs = img.find_blobs([red1], x_stride=10, y_stride=10, pixels_threshold=250)

3.更改参数density和size的判定范围,提高识别的精度

1.density表示目标区域中,像素的密度。正方形和矩形的像素密度相差不大,三角形像素密度较小,调试时根据观察到的值实时修改。
2.size表示矩形或者正方形的长和宽的比值。比值大的是矩形,比值小的时正方形。需要注意的时,如果更换方向,矩形的size也会很小,所以要设置两个阈值,一个极大值一个极小值。

if density < 0.65 and density > 0.4:print("红色", "圆环", size, density, y.area())send_data(uart, 1, 1)for c in img.find_circles(threshold = 3500, x_margin = 15, y_margin = 10, r_margin = 10):img.draw_circle(c.x(), c.y(), c.r(), color = (255, 255, 255))elif density > 0.65:img.draw_rectangle((y[0],y[1],y[2],y[3]),color=(255,255,255))if size > 0.9 and size < 1.1:send_data(uart, 1, 2)print("红色", "正方形", size, density, y.area())if size > 1.1 or size < 0.7:send_data(uart, 1, 3)print("红色", "矩形", size, density, y.area())

二、openmv识别方法

1. 每次取所识别区域的最大值

#寻找图像中的最大色块
#高度增加无法识别可以减小max_size
def find_max(blobs):max_blob = Nonemax_size = 200for blob in blobs:if blob[2]*blob[3]>max_size:#blob[2]*blob[3],计算包含色块的最小矩形面积大小max_blob=blobmax_size=blob[2]*blob[3]return max_blob

根据实际情况,通过调节max_size的值,来提高精度

2.识别二维码

#识别二维码if mode == 3:red_led.off()blue_led.off()for code in img.find_qrcodes():img.draw_rectangle(code.rect(), color = (255, 0, 0))print(code.payload())

直接调用函数识别即可

三、openmv与STM32进行通信

1. openmv端发送函数

def send_data(uart, color, shape):data = bytearray([color & 0xFF, (color >> 8) & 0xFF, shape & 0xFF, (shape >> 8) & 0xFF])uart.write(data)  # 发送数据

openmv端配置串口过程略

2.STM32端接收

1.变量

uint8_t rxBuffer_main,rx_buffer[4];
uint8_t mode = 0;
uint8_t rx_index = 0;
uint16_t color = 0, shape = 0, color_circle = 0;

2.回调函数

// HAL库回调函数
void HAL_UART_RxCpltCallback(UART_HandleTypeDef *huart)
{if (huart->Instance == USART1){// 处理接收到的数据if(mode == 1){// 将接收到的数据添加到缓冲区rx_buffer[rx_index++] = rxBuffer_main;// 检查是否接收到了足够的数据if (rx_index == 4) {// 解析数据color = (rx_buffer[1] << 8) | rx_buffer[0];shape = (rx_buffer[3] << 8) | rx_buffer[2];// 重置索引,准备下一次接收rx_index = 0;}}else if(mode == 2){// 将接收到的数据添加到缓冲区rx_buffer[rx_index++] = rxBuffer_main;// 检查是否接收到了足够的数据if (rx_index == 4) {// 解析数据color_circle = (rx_buffer[1] << 8) | rx_buffer[0];shape = (rx_buffer[3] << 8) | rx_buffer[2];// 重置索引,准备下一次接收rx_index = 0;}}else if(mode == 3){}// 重新启动中断接收,准备接收下一批数据HAL_UART_Receive_IT(&huart1, &rxBuffer_main, sizeof(rxBuffer_main));}
}

注意:需要现在main.c文件中将串口使能

	extern uint8_t rxBuffer_main;// 启动中断接收HAL_UART_Receive_IT(&huart1, &rxBuffer_main, sizeof(rxBuffer_main));

四、openmv与k210的区别

1.k210串口配置

import sensor, image, time, lcd
from fpioa_manager import fm
import time
from machine import UARTlcd.init()                          # Init lcd display
lcd.clear(lcd.RED)                  # Clear lcd screen.# need your connect hardware IO 10/11 to loopback
fm.register(8, fm.fpioa.UART1_TX, force=True)
fm.register(6, fm.fpioa.UART1_RX, force=True)uart_A = UART(UART.UART1, 115200, 8, None, 1, timeout=1000, read_buf_len=4096)time.sleep_ms(100) # wait uart readysensor.reset()
sensor.set_pixformat(sensor.RGB565)
sensor.set_framesize(sensor.QVGA)
sensor.skip_frames(time = 2000)
clock = time.clock()while(True):clock.tick()                    # Update the FPS clocklcd.display(img)                # Display image on lcd.uart_A.deinit()
del uart_A

2.k210屏幕配置

import sensor, image, time, lcdlcd.init()                          # Init lcd display
lcd.clear(lcd.RED)                  # Clear lcd screen.while(True):clock.tick()                    # Update the FPS clock.lcd.display(img)                # Display image on lcd.#print(clock.fps())              # Note: CanMV Cam runs about half as fast when connected# to the IDE. The FPS should increase once disconnected.

以上代码在k210上面也能使用,但k210识别物体的速度很慢,大家择优使用就行
在连接电脑的情况下,k210每秒是跑1帧,但是openmv能跑到40到50帧。

总结

使用以上方法进行openmv识别并不精确,后期还会修改

注意事项有:
1.增加缓冲,等待识别精确后再向单片机发送,或者在单片机端增加缓冲
2.openmv在不使用时需要将mode设置成0,也就是openmv不识别。只有在使用时才可修改mode的值

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

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

【AI知识点】泊松分布(Poisson Distribution)

泊松分布&#xff08;Poisson Distribution&#xff09; 是统计学和概率论中的一种离散概率分布&#xff0c;通常用于描述在固定时间或空间内&#xff0c;某个事件发生的次数。该分布适用于稀有事件的建模&#xff0c;特别是当事件发生是独立的、随机的&#xff0c;且发生的平均…

PCL 点云体素滤波

目录 一、概述 1.1原理 1.2实现步骤 1.3应用场景 二、代码实现 2.1关键函数 2.1.1 体素滤波实现 2.1.2 可视化函数 2.2完整代码 三、实现效果 PCL点云算法汇总及实战案例汇总的目录地址链接&#xff1a; PCL点云算法与项目实战案例汇总&#xff08;长期更新&#xf…

【RISCV指令集手册】向量扩展v1.0

概述 从rvv 0.9说起 此前写过向量扩展0.9的阅读记录&#xff0c;三年已过&#xff0c;本以为不再参与RVV的相关开发&#xff0c;奈何造化弄人&#xff0c;旧业重操&#xff0c;真就世事难料呀。 总的来说1.0版本相比0.9版本的扩充了较多内容&#xff0c;但大部分为指令功能的…

YOLOv8改进线性注意力模块 ICCV2023 FLatten Transformer

1,原理部分 论文地址:2308.00442 (arxiv.org) 在将 Transformer 模型应用于视觉任务时,自我注意的二次计算复杂性一直是一个持续的挑战。另一方面,线性注意力通过精心设计的映射函数近似 Softmax 操作,通过其线性复杂性提供了一种更有效的替代方案。然而,当前的线性注意…

使用LlamaIndex构建RAG

使用LlamaIndex构建RAG 一、什么是LlamaIndex二、环境准备2.1虚拟环境创建及基础安装2.2安装llamaIndex相关2.3下载词向量模型2.4下载NLTK资源2.5准备LLM模型2.6不使用RAG情况下的问答效果2.7使用llama-index的效果2.7.1安装llama-index词嵌入依赖2.7.2获取知识库2.7.3准备代码…

信号检测理论(Signal Detection Theory, SDT)

信号检测理论&#xff08;Signal Detection Theory, SDT&#xff09;模拟是一种实验设计&#xff0c;用于研究和理解在存在噪声或不确定性的情况下如何做出决策。在心理学、认知科学、工程学和许多其他领域&#xff0c;信号检测理论都非常重要。 一、基础概念&#xff1a; 在信…

TIBCO Jaspersoft Studio 创建数据源并进行测试

1、连接数据源&#xff1a; 右键Data Adapters &#xff0c;然后新建 根自己的情况&#xff0c;进行创建&#xff0c;这里测试用的是excel表格。 2、新建Jasper Report&#xff0c;然后我们选择刚刚创建的数据源 这样report就建好了&#xff0c;然后我们进行测试。 3、先把不…

【源码+文档】基于SpringBoot+Vue的酒店管理系统

&#x1f6a9;如何选题&#xff1f; 如何选题、让题目的难度在可控范围&#xff0c;以及如何在选题过程以及整个毕设过程中如何与老师沟通&#xff0c;这些问题是需要大家在选题前需要考虑的&#xff0c;具体的方法我会在文末详细为你解答。 &#x1f6ad;如何快速熟悉一个项目…

文心智能体——制作你的专属AI

随着社会的进步和互联网技术的发展&#xff0c;人工智能领域正蓬勃发展。最近几年关于人工智能的新闻日渐增多并且成为了当代最大的热点&#xff0c;所有的领域都在引进AI、训练AI、使用AI&#xff0c;AI正逐步融入人们的生活。从前几年chatGPT大语言模型的横空出世&#xff0c…

Finops成本优化企业实践-可视化篇

引言&#xff1a;上一章讨论了finops的一些方法论&#xff0c;笔者在拿到finops官方认证finops-engineer certificate之后&#xff0c;将方法论运用到所在项目组中&#xff0c;并于今年完成了40%的费用节省。在此将这些实践方法总结沉淀&#xff0c;与大家分享。实践包括三篇&a…

[Python学习日记-38] Python 中的函数的名称空间

[Python学习日记-38] Python 中的函数的名称空间 简介 名称空间 作用域查找顺序 简介 在前面学习函数的时候我们发现&#xff0c;函数内部也有一个内存空间是用于存储函数自己的一些变量的&#xff0c;及时这个变量名与外部的变量名一样是也没关系&#xff0c;Python 会优先…

SpringCloud Alibaba - Eureka注册中心,Nacos配置中心

Eureka 1、创建服务端 server:port: 8761 # eureka 默认端口spring:application:name: eureka-server # 应用名称&#xff08;微服务中建议必须定义应用名称&#xff09; SpringBootApplication EnableEurekaServer // 开启eureka注册中心功能 public class EurekaServerAppli…

数据驱动投资:AI在股票市场的应用

当ChatGPT首次亮相时&#xff0c;其卓越的语言处理能力立刻引起了许多行业的广泛关注&#xff0c;投资界也不例外。关于ChatGPT是否能应用于投资决策的问题&#xff0c;迅速成为热门讨论的焦点。 近期&#xff0c;加拿大多伦多大学和印度孟买理工学院的研究人员联合开展了一项…

《Linux从小白到高手》理论篇:Linux的进程管理详解

本篇将介绍Linux的进程管理相关知识&#xff0c;并将深入介绍Linux的进程间相互通信。 进程就是运行中的程序&#xff0c;一个运行着的程序&#xff0c;可能有多个进程。 比如Oracle DB&#xff0c;启动Oracle实例服务后&#xff0c;就会有多个进程。 Linux进程分类 在 Linux…

python实战四:输入一个年份,判断是否是闰年

问题&#xff1a; 从键盘获取一个四位的整数年份&#xff0c;判断其是否是闰年。闰年的判断条件为︰能被4整除但不能被100整除&#xff0c;或者能被400整除。 需求方法&#xff1a; 使用 input() 函数从键盘获取输入。输入的年份是一个字符串。检查输入是否为四位数&#xf…

优优嗨聚集团:债务纠纷下的个人财务困境揭秘

在当今社会&#xff0c;随着经济活动的日益频繁与复杂化&#xff0c;债务问题已成为许多人生活中难以回避的挑战之一。债务纠纷&#xff0c;作为这一问题的直接体现&#xff0c;不仅关乎金钱的得失&#xff0c;更深刻地影响着个人的生活方方面面&#xff0c;从心理健康、家庭关…

vscode 连接云服务器(ubantu 20.04)

更改服务器系统 如果云服务器上的系统不是ubantu20.04的&#xff0c;可以进行更改&#xff1a; 登录云服务官网&#xff08;这里以阿里云为例&#xff09;点击控制台 点击服务器实例 点击更多操作、重置系统 点击重置为其他镜像、系统镜像&#xff1a;选择你要使用的系统镜像…

c++ union内存布局

// // Created by 徐昌真 on 2024/10/5. // #include <iostream> using namespace std;//定义一个union union Data{int a;char s[7]; //char值的范围(-128~127) }; int main() {//创建一个unionData d;d.s[0] 255; //16进制 0xFF 16进制F对应二进制 1111d.s[1] 1; …

瓶颈ing

全排列的回溯算法怎么好理解记忆啊&#xff0c;对着解析理解顺着逻辑也能够推&#xff0c;但是自己写无从下手呜呜呜

探索基于基于人工智能进行的漏洞评估的前景

根据2023年的一份报告 网络安全企业据估计&#xff0c;到 10.5 年&#xff0c;网络犯罪每年将给世界造成 2025 万亿美元的损失。每年记录在案的网络犯罪数量都会创下新高。这要求对传统的安全测试流程进行重大改变。这就是漏洞评估发挥作用的地方。 漏洞评估对于识别系统中的弱…