人工智能计算机视觉先锋——OpenCv 的颜色检测

红色

在计算机的世界里,只有 0 或者1,如何让计算机认识颜色是计算机视觉工作者首先需要考虑的事情,我们知道整个世界的颜色虽然五彩缤纷,但是都是3种原色彩合成的(R G B),有了(R G B)三源色,便可以通过调节不同的颜色比例来达到其他颜色的效果。

在计算机的世界里面,我们定义了(R G B)三源色的像素都在(0-255之间),通过配置这些数字,便可以显示不同的色彩

首先定义一个数组colist:

复制代码
import numpy as np
import cv2
image = cv2.imread("11.jpg")

colist = [
	([17, 15, 100], [50, 56, 200]),
	([86, 31, 4], [220, 88, 50]),
	([25, 146, 190]	, [62, 174, 250]),
	([103, 86, 65], [145, 133, 128])
]

在RGB色彩空间,当然opencv是在BGR的空间,定义了四种不同颜色的像素,同时代表了R G B ,gray

在这里,我们说图像中所有具有R> = 100G> = 15B> = 17 以及R <= 200G<= 56B <= 50的 像素 将被视为 红色,

具有R> = 4G> = 31B> = 86 以及R <= 50G<= 88B <= 220的 像素将被视为绿色

具有R> = 190G> = 146B> = 25 以及R <= 250G<= 174B <= 62的 像素将被视为黄色

具有R> = 65G> = 86B> = 103 以及R <= 128G<= 133B <= 145的 像素将被视为灰色

有了这些颜色的定义,我们便可以使用上下限的颜色数据,对图片中的颜色进行检测,

复制代码
for (lower, upper) in colist:
	lower = np.array(lower, dtype = "uint8")
	upper = np.array(upper, dtype = "uint8")
	mask = cv2.inRange(image, lower, upper)
	output = cv2.bitwise_and(image, image, mask = mask)
	cv2.imshow("images", np.hstack([image, output]))
	cv2.waitKey(0)

首先使用cv2.inRange(image, lower, upper)函数进行图片颜色的筛选

复制代码
mask = cv2.inRange(image, lower, upper) 
函数参数有三个
第一个参数:image指的是原图

第二个参数:lower指的是图像中低于这个lower的值,图像值变为0

第三个参数:upper指的是图像中高于这个upper的值,图像值变为0

而在lower~upper之间的值变成255

黄色

按照红色为例:通过以上函数的筛选,不是红色区域的都被置为0,而红色区域都被置为255

经过以上步骤,mask便是一个黑白的照片,其中不是红色的区域为黑色,红色区域为白色

然后使用cv2.bitwise_and函数对图片进行与操作

cv2.bitwise_and()是对二进制数据进行"与"操作,即对图像(灰度图像或彩色图像均可)每个像素值进行二进制"与"操作,1&1=1,1&0=0,0&1=0,0&0=0

利用掩膜(mask)进行"与"操作,即掩膜图像白色区域是对需要处理图像像素的保留,黑色区域是对需要处理图像像素的剔除

这样我们便可以删除了除红色区域以外的其他颜色,保留了红色,当然其他颜色具有类似的原理

代码截图

最后我们显示一下图片中的颜色

绿色

当然你也可以使用L*a*b颜色空间,或者hsv颜色空间,什么叫L*a*b颜色空间,或者hsv颜色空间

python神经网络一键格式化黑白视频为彩色视频

python神经网络一键转变黑白照片为彩色照片

以上2篇文章主要介绍了lab空间的颜色使用

hsv颜色空间的使用,可以参考小编的专栏《打造属于自己的天眼目标追踪系统》中的颜色追踪

复制代码
更多transformer,VIT,swin tranformer
参考头条号:人工智能研究所
v号:启示AI科技

动画详解transformer 在线教程

相关推荐
爱写代码的小朋友18 分钟前
人工智能驱动下个性化学习路径的构建与实践研究——以K12数学学科为例
人工智能·学习
宝贝儿好2 小时前
【强化学习实战】第十一章:Gymnasium库的介绍和使用(1)、出租车游戏代码详解(Sarsa & Q learning)
人工智能·python·深度学习·算法·游戏·机器学习
绝世这天下4 小时前
【在 DGX Spark 上运行 vLLM-Omni 用于 Qwen3-TTS(语音设计,语音克隆)】
人工智能
陈大鱼头5 小时前
[译]费尽心思来保障 OpenClaw ?那跟直接用 GPT 有什么区别?
人工智能
Fleshy数模5 小时前
玩转OpenCV:视频椒盐噪声处理与图像形态学操作实战
人工智能·opencv·音视频
程序媛一枚~5 小时前
✨✨✨使用Python,OpenCV及图片拼接生成❤️LOVE❤️字样图,每张小图加随机颜色边框,大图加随机大小随机颜色边框
图像处理·python·opencv·numpy·图像拼接
幂律智能5 小时前
Agent × 流程引擎融合架构:从静态流程到智能流程编排
人工智能·架构·agent
无垠的广袤6 小时前
ChatECNU 大语言模型与 PicoClaw 部署
人工智能·语言模型·自然语言处理·嵌入式·树莓派
爱淋雨的男人6 小时前
自动驾驶感知相关算法
人工智能·算法·自动驾驶
互联网科技看点6 小时前
AI算力爆发叠加数据资产风口,铂拉锐科技布局去中心化数字生态
人工智能·科技·去中心化