OpenCV学习(2.1) 初识图像

1.图像对象

图像是由一个个像素组成的,像素越多,体现到图像就是更加清晰,有更多的细节。举个例子,通常来说的分辨率,1080P,720P,480P就是指像素的数量,数量越多就越清晰。

2.打印图像的像素值

import cv2

image = 'D:\papercode\AI\Ai-Dentist-Sample-Code-main\opencv\car_recognition\car.jpg'
#读取图片
image = cv2.imread(image)

print("image0",image)
print("image1",image[0])
print("image2",image[0][0])
print("image3",image[0][0][0])

print("image0",image.shape)
print("image1",image[0].shape)
print("image2",image[0][0].shape)
print("image3",image[0][0][0].shape)

结果展示:

image1 [[ 52  81  85]
 [ 75 102 106]
 [ 91 110 113]
 ...
 [229 208 193]
 [229 208 193]
 [229 208 193]]
image2 [52 81 85]
image3 52
image0 (861, 697, 3)
image1 (697, 3)
image2 (3,)
image3 ()

输出的image0没有打印出来,太长了,不过可以从shape中看到是(861,697,3),代表的是长和宽以及通道数;image1是指定了长的位置,显示的是长为序列【0】时宽以及三个通道上的数值,对应的形状就是(697,3);image2就是选定了长和宽的位置,显示的是在该位置上的三个通道的数值,对应形状就是(3,); image3就是选定了长和宽以及通道的值,其形状说明这个元素是一个标量(scalar),而不是一个具有维度的数组或张量。

3.其他读取方式

import cv2

image = 'D:\papercode\AI\Ai-Dentist-Sample-Code-main\opencv\car_recognition\car.jpg'


#其它加载图像的方式
image1 = cv2.imread(image, cv2.IMREAD_COLOR)
image2 = cv2.imread(image,cv2.IMREAD_GRAYSCALE)
image3 = cv2.imread(image,cv2.IMREAD_UNCHANGED)
print('image1',image1.shape)
print('image2',image2.shape)
print('image3',image3.shape)
cv2.imshow('image1',image1)
cv2.imshow('image2',image2)
cv2.imshow('image3',image2)

cv2.waitKey(0)
cv2.destroyAllWindows()

输出结果:

image1 (861, 697, 3)
image2 (861, 697)
image3 (861, 697, 3)

cv2.imread(image, cv2.IMREAD_COLOR)

  • 这行代码将以彩色模式读取图像,即使图像是多通道的,也会被读取为彩色图像。
  • 如果图像是多通道的(例如RGB图像),则image1将会是一个三通道的彩色图像。

cv2.imread(image, cv2.IMREAD_GRAYSCALE)

  • 这行代码将以灰度模式读取图像,将图像转换为单通道的灰度图像。
  • 无论输入的图像是多通道还是单通道,image2都将是一个单通道的灰度图像。

cv2.IMREAD_UNCHANGED

  • 是 OpenCV 中的一个常量,用于指定读取图像时保持原始图像的通道数和深度。这意味着,如果图像是一个多通道图像,那么读取后的图像将保持多通道,如果是单通道图像,也会保持单通道。
  • 所以,cv2.imread(image, cv2.IMREAD_UNCHANGED) 将以不变的方式读取图像,保持图像的通道和深度不变。

cv.waitKey()是一个键盘绑定函数。其参数是以毫秒为单位的时间。该函数等待任何键盘事件指定的毫秒。如果您在这段时间内按下任何键,程序将继续运行。如果**0**被传递,它将无限期地等待一次敲击键。它也可以设置为检测特定的按键,例如,如果按下键 a 等,我们将在下面讨论。

cv.destroyAllWindows()只会破坏我们创建的所有窗口。如果要销毁任何特定的窗口,请使用函数 cv.destroyWindow()在其中传递确切的窗口名称作为参数。

4.图像存储

#图像存储
cv2.imwrite('messigray.png', image2)

输出显示:存放到当前路径

使用函数**cv.imwrite**()保存图像。

第一个参数是文件名,第二个参数是要保存的图像。 cv.imwrite('messigray.png',img)

这会将图像以PNG格式保存在工作目录中。

5.图像灰度化的原理

图像的灰度化是将彩色图像转换为灰度图像的过程。灰度图像是一种单通道图像,每个像素只有一个数值,代表了该像素的亮度或灰度级别。灰度化的原理可以通过不同的方法实现,其中最常见的包括加权平均法、亮度法和取值法。

  1. YUV亮度灰度化

    • YUV 是一种颜色编码方法,其中 Y 通道表示亮度,而 U 和 V 通道表示色度。Y 通道包含了图像的亮度信息,因此可以将 Y 通道视为灰度图像的近似。
    • YUV 亮度灰度化方法直接使用 Y 通道作为灰度图像的值,忽略 U 和 V 通道。这种方法简单快速,适用于需要快速处理的场景。
    • 灰度值(Gray) = 0.299 * R + 0.587 * G + 0.114 * B
  2. 最大值灰度化

    • 最大值灰度化方法将彩色图像的每个像素的 R、G、B 三个通道的最大值作为灰度值。这种方法可以保留图像中的最亮部分,适用于需要突出图像亮度信息的场景。
    • 灰度值(Gray) =B = G = R = m a x ( [ B , G , R ] ) 

  3. 平均值灰度化

    • 平均值灰度化方法将彩色图像的每个像素的 R、G、B 三个通道的值取平均作为灰度值。这种方法简单粗暴,会使图像失去一些细节,但可以保留整体的亮度信息。
    • 灰度值(Gray)= (R + G + B) / 3
  4. Gamma校正灰度化

    • Gamma 校正是一种非线性操作,可以调整图像的亮度和对比度。在灰度化中,Gamma 校正可以通过以下公式进行:
      灰度值 = 255 * (原始值 / 255) ^ Gamma 其中,Gamma 为大于 0 的参数,通常在 0.5 到 2.0 之间。Gamma 值越大,图像越暗;Gamma 值越小,图像越亮。Gamma 校正可以调整图像的整体亮度和对比度,适用于需要对图像进行调色和增强的场景。
      

灰度化的目的是降低图像的复杂度,减少处理的计算量,同时保留图像的主要特征和结构。在许多图像处理和计算机视觉任务中,灰度化是一个常见的预处理步骤,可以大大简化后续处理的复杂度。

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

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

相关文章

打工人好用的大模型问答,还需要一款可靠的文档解析工具

如果说三四年前,我们对AI的展望还停留在科幻片的话,现在,通向AI智能的路径已经初现端倪。各行各业的朋友们不约而同地嗅到了大模型带来的生产方式变革气息。 LLM宣布了AI时代的正式到来。 2022年11月30日,ChatGPT发布&#xff0…

c++(四)

c(四) 运算符重载可重载的运算符不可重载的运算符运算符重载的格式运算符重载的方式友元函数进行运算符重载成员函数进行运算符重载 模板定义的格式函数模板类模板 标准模板库vector向量容器STL中的listmap向量容器 运算符重载 运算符相似,运…

AI写作工具的革命:AIGC如何提升内容生产效率

AIGC,即人工智能生成内容,是一种新兴的内容生产方式,它利用人工智能技术来自动生成文本、图像、音频、视频等多种形式的内容即进入实际应用层面。 所以AI不再是高深的、让人望尘莫及的算力算法,而是真实地贴近了我们的生活&#…

Java 泛型 <? super T> 中 super 怎么 理解?与 extends 有何不同?

作者:zhang siege 链接:https://www.zhihu.com/question/20400700/answer/91106397 来源:知乎 著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。 首先,泛型的出现时为了安全,所有与…

经典神经网络(9)VAE模型原理及其在MNIST数据集上的应用

经典神经网络(9)VAE模型原理及其在MNIST数据集上的应用 图片生成领域来说,有四大主流生成模型:生成对抗模型(GAN)、变分自动编码器(VAE)、流模型(Flow based Model)、扩散模型&#…

【最优化方法】实验一 熟悉MATLAB基本功能

实验一  熟悉MATLAB基本功能 实验的目的和要求:在本次实验中,通过亲临使用MATLAB,对该软件做一全面了解并掌握重点内容。 实验内容: 1、全面了解MATLAB系统 2、实验常用工具的具体操作和功能 学习建…

【基础篇-Day8:JAVA字符串的学习】

目录 1、常用API2、String类2.1 String类的特点2.2 String类的常见构造方法2.3 String类的常见面试题:2.3.1 面试题一:2.3.2 面试题二:2.3.3 面试题三:2.3.4 面试题四: 2.4 String类字符串用于比较的方法2.5 String类字…

基坑气膜:建筑工地环保新利器—轻空间

随着城市化进程的加快,建筑行业的飞速发展带来了严重的环境问题,如噪音和粉尘污染,给人们的生活带来诸多不便。为了解决这些问题,建筑行业一直在探索更为环保和高效的施工方式。近年来,基坑气膜技术逐渐崭露头角&#…

【国信华源:以专业服务,协助水利厅抵御强暴雨】

5月18日-19日,广西出现入汛以来最强暴雨天气过程,钦州、防城港、北海、南宁等地出现特大暴雨,多地打破降雨量极值。国信华源技术团队积极行动驻守一线,为打好山洪灾害防御的提前战、主动战提供了技术支撑。 5月17日18时&#xff0…

SOAR-Top 10安全剧本最佳实践-百度网盘下载

概述: SOAR(Security Orchestration,Automation and Response安全编排自动化响应),Gartner 对 SOAR 的最新描述性定义(摘自 Gartner 报告《Hype Cycle on Threat-Facing Technologies, 2018》) 是:SOAR 是一系列技术的…

基于SpringBoot+Vue在线动漫信息平台设计和实现(源码+LW+部署讲解)

🌹作者主页:青花锁 🌹简介:Java领域优质创作者🏆、Java微服务架构公号作者😄 🌹简历模板、学习资料、面试题库、技术互助 🌹文末获取联系方式 📝 🌹推荐一个人…

使用nexus搭建的nodejs私库,定期清理无用的npm组件,彻底释放磁盘空间

一、背景 昨天我们整理了一篇关于docker私库,如何定期清理以释放磁盘空间的文章。 虽然也提及了npm前端应用的组件该如何定期清理的,本文是对它作一个补充说明。 前文也看到了,npm组件占用的blob空间为180多GB,急需清理。 二、…

K8s证书过期处理

问题描述 本地有一个1master2worker的k8s集群,今天启动VMware虚拟机之后发现api-server没有起来,docker一直退出,这个集群是使用kubeadm安装的。 于是kubectl logs查看了日志,发现证书过期了 解决方案: 查看证书 #…

vue3 部署后修改配置文件

前端项目部署之后,运维可以自行修改配置文件里的接口IP,达到无需再次打包就可以使用的效果 vue2如何修改请看vue 部署后修改配置文件(接口IP)_vue部署后修改配置文件-CSDN博客 使用前提: vite搭建的vue3项目 使用setu…

IND-ID-CPA 和 IND-ANON-ID-CPA Game

Src: https://eprint.iacr.org/2017/967.pdf

WGCLOUD部署好后,怎么登录WGCLOUD界面

WGCLOUD的server启动完成后,我们在浏览器里输入URL,如下 http://[server主机IP]:9999 注意默认端口就是9999,如果修改过,那么把端口改成自己的实际端口 这样就可以看到登录页面了,默认账号密码是:admin/…

2951. 找出峰值

找出数组中的峰值 给你一个下标从 0 开始的数组 mountain 。你的任务是找出数组 mountain 中的所有 峰值。 以数组形式返回给定数组中 峰值 的下标,顺序不限 。 注意 峰值 是指一个严格大于其相邻元素的元素。数组的第一个和最后一个元素 不 是峰值。 示例 1 …

VSCODE常用插件记录

重点提名: back & ForthBookmarksC/ChighlightSSH FS //SSH插件

《精通Stable Diffusion AI绘画:基础技巧、实战案例与海量资源一站式学习》

随着人工智能技术的迅猛发展,AI绘画已经成为了一个炙手可热的话题。特别是在设计、艺术和创意领域,AI绘画工具的出现无疑为创作者们带来了更多的可能性和便利。《Stable Diffusion AI绘画从提示词到模型出图》这本书,就是一本深入解析Stable …

【IDEA】Redis可视化神器

在开发过程中,为了方便地管理 Redis 数据库,我们可能会使用一些数据库可视化插件。这些插件通常可以帮助你在 IDE 中直观地查看和管理 Redis 数据库,包括查看键值对、执行命令、监视数据库活动等。 IDEA作为IDE界的Jenkins,本身自…