模式识别作业:颜色算子的三种阈值分割算法

news2024/11/24 1:22:52

一、引言:

在图像处理中,我们往往需要提取图像的一些关键信息,比如本篇文章的内容——提取颜色,然而当我们需要提取某一种颜色时,无论图像余下的部分如何“丰富多彩”,他们都不再重要,需要被忽略,我们称其为“背景”。此时我们只需要黑白图像就可以清晰的展示出需要提取的颜色。我们往往将每个像素点的灰度值转换为0或1,表示黑色或白色,从而将图像转换为黑白二色,这样的图像被称为二值化图像

借助 OpenCV 的 inRange 函数我们就可以根据阈值提取满足条件的像素。

二、RGB 颜色阈值算子

1 RGB空间:

还记得第一篇文章提到的张量么,一张彩色图片可以看作一个三阶张量,即一张彩色图像是由红,绿,蓝三张图片叠加成的,每张图片的有无数的像素点,每个像素点的值域为0~255来表示颜色深浅。这就是最常用的三通道颜色空间,RGB空间。

2 代码实现:

import cv2
import numpy as np


def color_threshold(image, lower_threshold, upper_threshold):
    """
    RGB颜色阈值算子

    参数:
    - image: 输入的RGB图像
    - lower_threshold: 低阈值,为一个包含三个元素的列表或元组,分别对应BGR通道的最小值
    - upper_threshold: 高阈值,为一个包含三个元素的列表或元组,分别对应BGR通道的最大值

    返回值:
    - thresholded_image: 经过阈值处理后的二值图像
    """

    # 使用OpenCV的inRange函数根据阈值提取满足条件的像素
    thresholded_image = cv2.inRange(image, np.array(lower_threshold), np.array(upper_threshold))

    return thresholded_image


# 主函数
if __name__ == "__main__":
    # 读取输入图像
    input_image = cv2.imread("leaf.jpg")

    # 定义颜色阈值
    lower_threshold = [0, 100, 0]  # 低阈值,例如,过滤掉B通道小于0,G通道小于100,R通道小于0的像素
    upper_threshold = [50, 255, 50]  # 高阈值,例如,过滤掉B通道大于50,G通道大于255,R通道大于50的像素

    # 应用颜色阈值算子
    thresholded_image = color_threshold(input_image, lower_threshold, upper_threshold)

    # 显示原始图像和处理后的二值图像
    cv2.imshow("Original Image", input_image)  # imshow用于新建弹窗显示图像
    cv2.imshow("Thresholded Image", thresholded_image)
    cv2.waitKey(0)  # 保留弹窗直至检测到其他键盘操作
    cv2.destroyAllWindows()

3 运行结果:

三、HSV 颜色阈值算子

1 HSV空间:

HSV空间指的是色彩空间中的一种,由色相(Hue)、饱和度(Saturation)和明度(Value)三个要素组成。色相表示颜色的基本属性,饱和度表示颜色的纯度或深浅程度,而明度则表示颜色的亮度。

2 代码实现:

import cv2
import numpy as np


def hsv_threshold(image, lower_hsv, upper_hsv):
    """
    使用HSV颜色空间进行颜色阈值分割

    参数:
        image: 输入的RGB图像
        lower_hsv: HSV颜色空间下的下限阈值,格式为(H_MIN, S_MIN, V_MIN)
        upper_hsv: HSV颜色空间下的上限阈值,格式为(H_MAX, S_MAX, V_MAX)

    返回:
        thresholded_image: 分割后的二值图像
    """
    # 将RGB图像转换为HSV颜色空间
    hsv_image = cv2.cvtColor(image, cv2.COLOR_BGR2HSV)

    # 设置阈值范围
    lower = np.array(lower_hsv)
    upper = np.array(upper_hsv)

    # 根据阈值进行二值化处理
    thresholded_image = cv2.inRange(hsv_image, lower, upper)

    return thresholded_image


# 主函数
if __name__ == "__main__":
    # 读取图像
    image = cv2.imread("apple.jpg")

    # 定义想要提取的HSV颜色范围
    lower_colour = (40, 100, 100)
    upper_colour = (80, 255, 255)


    # 使用阈值算子分割图像
    colour_threshold = hsv_threshold(image, lower_colour, upper_colour)

    # 显示原始图像和分割后的图像
    cv2.imshow("Original Image", image)  # imshow用于新建弹窗显示图像
    cv2.imshow("colour Threshold", colour_threshold)
    cv2.waitKey(0)  # 保留弹窗直至检测到其他键盘操作
    cv2.destroyAllWindows()

3 运行结果:

四、CIE Lab 颜色阈值算子

1 lab空间:

LAB空间是一种色彩空间,也称为CIE LAB色彩空间。它包含三个坐标轴:L表示亮度(Lightness),a表示从洋红色(红色的负轴)到绿色(绿色的正轴)的范围,b表示从蓝色(蓝色的负轴)到黄色(黄色的正轴)的范围。

2 代码实现:

import numpy as np
import cv2


def lab_color_threshold(image, lower_bound, upper_bound):
    """
    使用CIE Lab颜色空间进行阈值分割

    参数:
        image: 输入的RGB图像
        lower_bound: 一个包含3个元素的列表,表示颜色的下界(L, a, b)
        upper_bound: 一个包含3个元素的列表,表示颜色的上界(L, a, b)

    返回:
        thresholded: 二值图像,仅包含在指定颜色范围内的区域
    """
    # 将RGB图像转换为CIE Lab颜色空间
    lab_image = cv2.cvtColor(image, cv2.COLOR_BGR2LAB)

    # 提取L、a、b通道
    L, a, b = cv2.split(lab_image)

    # 创建空的二值图像
    thresholded = np.zeros_like(L)

    # 将颜色通道与阈值进行比较,生成二值图像
    within_bounds = (lower_bound[0] <= L) & (L <= upper_bound[0]) & \
                    (lower_bound[1] <= a) & (a <= upper_bound[1]) & \
                    (lower_bound[2] <= b) & (b <= upper_bound[2])

    # 将满足条件的像素设置为255(白色)
    thresholded[within_bounds] = 255

    return thresholded


# 主函数
if __name__ == "__main__":
    # 读取图像
    image = cv2.imread("apple.jpg")

    # 设置阈值范围(这里使用的是示例值,你可以根据需要调整)
    lower_bound = [0, 128, 128]  # L, a, b 的下界
    upper_bound = [255, 255, 255]  # L, a, b 的上界

    # 应用颜色阈值算子
    thresholded_image = lab_color_threshold(image, lower_bound, upper_bound)

    # 显示结果
    cv2.imshow("Original Image", image)  # imshow用于新建弹窗显示图像
    cv2.imshow("Thresholded Image", thresholded_image)
    cv2.waitKey(0)  # 保留弹窗直至检测到其他键盘操作
    cv2.destroyAllWindows()

3 运行结果:

五、优缺点对比

1 RGB优缺点:

(1)优点:

  1. 直接对应于显示器和相机的工作原理,易于理解和实现。
  2. 在处理彩色图像时,RGB是一种直观的颜色表示方式。

(2)缺点:

  1. RGB模型对光照和阴影等因素较为敏感,不太适合于需要考虑光照条件的任务。
  2. RGB模型下的颜色值不够直观,不易于对颜色的特性进行准确描述。
  3. 某些情况下,RGB模型下的颜色空间变换不够灵活,无法有效地处理一些特定的颜色操作。

2 HSV优缺点:

(1)优点:

  1. HSV模型更符合人类对颜色的感知,色相、饱和度和明度的概念更直观。
  2. 色相分量可以独立于光照条件而保持不变,因此HSV对光照条件的影响较小。
  3. 在某些任务中,如颜色识别和区分不同颜色的对象,HSV模型可能更有效。

(2)缺点:

  1. HSV模型的计算量较大,不够简洁高效,对计算资源要求较高。
  2. HSV模型不是设备无关的,可能会受到设备性能和环境光照的影响。
  3. 在一些情况下,HSV模型下的颜色分布不均匀,可能导致某些区域难以区分或处理。

3 LAB优缺点:

(1)优点:

  1. LAB模型是一种设备无关的颜色空间模型,颜色值在不同设备和环境下保持一致。
  2. LAB模型更符合人类视觉系统的感知特性,对颜色的描述更准确。
  3. LAB模型可以很好地处理颜色校正和颜色匹配等任务。

(2)缺点:

  1. LAB模型的数学计算较复杂,相比RGB和HSV模型,计算量较大。
  2. 有时,LAB模型下的颜色表示不够直观,不够直观地反映颜色在图像中的分布情况。
  3. 由于LAB模型对颜色的描述较为细致,可能会导致在某些情况下对颜色的处理和分析更加复杂。

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

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

相关文章

C#核心之面向对象-继承

面向对象-继承 文章目录 1、继承的基本规则1、基本概念2、基本语法3、示例4、访问修饰符的影响5、子类和父类的同名成员 2、里氏替换原则1、基本概念2、is和as3、基本实现 3、继承中的构造函数1、基本概念2、父类的无参构造函数3、通过base调用指定父类构造 4、万物之父和装箱拆…

8.k8s中网络资源service

目录 一、service资源概述 二、service资源类型 1.ClusterIP类型 2.service的nodeport类型 3.service的loadbalancer类型&#xff08;了解即可&#xff09; 4.service的externalname类型&#xff08;了解即可&#xff09; 三、nodeport的端口范围设置和svc的endpoint列表 1.修…

扩散模型(Diffusion Model)概述

扩散模型&#xff08;Diffusion Model&#xff09;是图像生成模型的一种。有别于此前 AI 领域大名鼎鼎的 GAN、VAE 等算法&#xff0c;扩散模型另辟蹊径&#xff0c;其主要思想是一种先对图像增加噪声&#xff0c;再逐步去噪的过程&#xff0c;其中如何去噪还原图像是算法的核心…

web3风格的网页怎么设计?分享几个,找找感觉。

web3风格的网站是指基于区块链技术和去中心化理念的网站设计风格。这种设计风格强调开放性、透明性和用户自治&#xff0c;体现了Web3的核心价值观。 以下是一些常见的Web3风格网站设计元素&#xff1a; 去中心化标志&#xff1a;在网站的设计中使用去中心化的标志&#xff0…

RocketMQ SpringBoot 3.0不兼容解决方案

很多小伙伴在项目升级到springBoot3.0版本以上之后&#xff0c;整合很多中间件会有很多问题&#xff0c;下面带小伙伴解决springBoot3.0版本以上对于RocketMQ 不兼容问题 报错信息 *************************** APPLICATION FAILED TO START *************************** Des…

深入 Django 模型层:数据库设计与 ORM 实践指南

title: 深入 Django 模型层&#xff1a;数据库设计与 ORM 实践指南 date: 2024/5/3 18:25:33 updated: 2024/5/3 18:25:33 categories: 后端开发 tags: Django ORM模型设计数据库关系性能优化数据安全查询操作模型继承 第一章&#xff1a;引言 Django是一个基于Python的开源…

Lucene从入门到精通

**************************************************************************************************************************************************************************** 1、概述 【1】入门&#xff1a;作用、有点与缺点 【2】应用&#xff1a;索引、搜索、fie…

最短路径(朴素)+堆排序+模拟堆

文章目录 Dijkstra求最短路 I堆排序模拟堆 Dijkstra求最短路 I 给定一个 n 个点 m 条边的有向图&#xff0c;图中可能存在重边和自环&#xff0c;所有边权均为正值。 请你求出 1 号点到 n 号点的最短距离&#xff0c;如果无法从 1 号点走到 n 号点&#xff0c;则输出 −1。 输…

对命令模式的理解

目录 一、场景1、文本编辑器并不是一个好的例子&#xff0c;设备控制器才是2、设备控制器的demo 二、不用命令模式1、代码2、问题 三、使用命令模式1、代码2、当需求变化时2.1 新增代码2.2 优点 四、进一步思考1、省略对Command的建模可以吗&#xff1f;2、命令模式的价值 一、…

香港理工大学内地事务总监陆海天教授确认出席“边缘智能2024 - AI开发者峰会”并发表主题演讲

隨著AI技術的日新月異&#xff0c;我們正步入一個邊緣計算智能化與分布式AI相互融合的新紀元。這一變革不僅推動了分布式智能創新應用的飛速發展&#xff0c;還使得邊緣智能——這一結合邊緣計算和智能技術的新興領域&#xff0c;逐漸成為引領AI發展的重要力量。通過其分布式和…

# 从浅入深 学习 SpringCloud 微服务架构(八)Sentinel(1)

从浅入深 学习 SpringCloud 微服务架构&#xff08;八&#xff09;Sentinel&#xff08;1&#xff09; 一、sentinel&#xff1a;概述 1、前言 – 服务熔断 Hystrix 的替换方案。 1&#xff09;2018年底 Netflix 官方宣布 Hystrix 已经足够稳定&#xff0c;不再积极开发 Hys…

基于AT89C52单片机的智能热水器控制系统

点击链接获取Keil源码与Project Backups仿真图&#xff1a; https://download.csdn.net/download/qq_64505944/89242443?spm1001.2014.3001.5503 C 源码仿真图毕业设计实物制作步骤05 题 目 基于单片机的智能热水器系统 学 院 专 业 班 级 学 号 学生姓名 指导教师 完成日期…

【Docker学习】docker version查看版本信息

就像很多应用一样&#xff0c;docker也使用version来查看版本信息。但因为docker包含有不少独立组件&#xff0c;version的作用范围会更广一些。 用法1&#xff1a; docker --version 描述&#xff1a; 输出安装的Docker CLI 的版本号。关于Docker CLI&#xff0c;请访问。 实操…

Ubuntu启动后进入GRUB故障-Minimal BASH like line editing is supported.

目录 1.问题描述 2.解决方案 2.1 临时性办法 2.2 工具永久性修复 总结 1.问题描述 PC安装Ubuntu系统第二天重启后提示GUN GRUB version 2.04&#xff0c;之前是WindowsOS装Ubuntu后无法进入图形界面。具体原因据网友提供线索据说是由于在Windows上进行更新/重装/修改了引…

Golang | Leetcode Golang题解之第66题加一

题目&#xff1a; 题解&#xff1a; func plusOne(digits []int) []int {n : len(digits)for i : n - 1; i > 0; i-- {if digits[i] ! 9 {digits[i]for j : i 1; j < n; j {digits[j] 0}return digits}}// digits 中所有的元素均为 9digits make([]int, n1)digits[0]…

Docker-Compose编排LNMP并部署WordPress

前言 随着云计算和容器化技术的快速发展&#xff0c;使用 Docker Compose 编排 LNMP 环境已经成为快速部署 Web 应用程序的一种流行方式。LNMP 环境由 Linux、Nginx、MySQL 和 PHP 组成&#xff0c;为运行 Web 应用提供了稳定的基础。本文将介绍如何通过 Docker Compose 编排 …

【深度学习】第一门课 神经网络和深度学习 Week 3 浅层神经网络

&#x1f680;Write In Front&#x1f680; &#x1f4dd;个人主页&#xff1a;令夏二十三 &#x1f381;欢迎各位→点赞&#x1f44d; 收藏⭐️ 留言&#x1f4dd; &#x1f4e3;系列专栏&#xff1a;深度学习 &#x1f4ac;总结&#xff1a;希望你看完之后&#xff0c;能对…

20240503解决Ubuntu20.04和WIN10双系统下WIN10的时间异常的问题

20240503解决Ubuntu20.04和WIN10双系统下WIN10的时间异常的问题 2024/5/3 9:33 缘起&#xff1a;因为工作需要&#xff0c;编译服务器上都会安装Ubuntu20.04。 但是因为WINDOWS强悍的生态系统&#xff0c;偶尔还是有必须要用WINDOWS的时候&#xff0c;于是也安装了WIN10。 双系…

AJ-Report开源数据大屏 verification;swagger-ui RCE漏洞复现

0x01 产品简介 AJ-Report是一个完全开源的BI平台,酷炫大屏展示,能随时随地掌控业务动态,让每个决策都有数据支撑。多数据源支持,内置mysql、elasticsearch、kudu等多种驱动,支持自定义数据集省去数据接口开发,支持17+种大屏组件,不会开发,照着设计稿也可以制作大屏。三…

Linux进程——Linux下常见的进程状态

前言&#xff1a;在进程学习这一块&#xff0c;我们主要学习的就是PCB这个进程控制块&#xff0c;而PBC就是用来描述进程的结构体&#xff0c;而进程状态就是PCB结构体中的一个变量。 本篇主要内容&#xff1a; 操作系统中的进程状态Linux下的进程状态 在开始之前&#xff0c;我…