【多媒体技术与实践】使用OpenCV处理图像(实验三.上)

1:图像直方图

将原彩色图像转成灰度图像,得到该灰度图像的灰度直方图,并对灰度直方图进行直方图均衡化,将原图、灰度图、直方图及均衡化后的直方图一起拼接为一张图片

import cv2  
import numpy as np  
import matplotlib.pyplot as plt  # 读取原彩色图像  
img = cv2.imread(r'input.jpg')  # 将原彩色图像转换为灰度图像  
gray_img = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)  # 获取灰度直方图  
hist, bins = np.histogram(gray_img.flatten(), 256, [0, 256])  # 进行直方图均衡化  
equ_img = cv2.equalizeHist(gray_img)  # 获取均衡化后的灰度直方图  
equ_hist, bins = np.histogram(equ_img.flatten(), 256, [0, 256])  # 绘制原图、灰度图、直方图和均衡化后的直方图  
fig, axs = plt.subplots(2, 2)  
axs[0, 0].imshow(cv2.cvtColor(img, cv2.COLOR_BGR2RGB))  
axs[0, 0].set_title('Original Image')  
axs[0, 1].imshow(gray_img, cmap='gray')  
axs[0, 1].set_title('Grayscale Image')  
axs[1, 0].hist(gray_img.flatten(), 256, [0, 256])  
axs[1, 0].set_title('Original Histogram')  
axs[1, 1].hist(equ_img.flatten(), 256, [0, 256])  
axs[1, 1].set_title('Equalized Histogram')  
plt.tight_layout()  # 保存拼接后的图片  
plt.savefig(r'out.jpg')

eg.

2:图像变换

对作品一的灰度图像进行傅里叶变换,转成频域图像,对该频域图像分别进行低通和高通滤波后做傅里叶逆变换还原,得到两幅图像,将灰度图像、频域图像、低通还原图像及高通还原图像一起拼接为一张图片

import cv2
import numpy as np
import matplotlib.pyplot as plt# 读取原彩色图像  
img = cv2.imread(r'input.jpg')  # 将原彩色图像转换为灰度图像  
gray_image = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)  # 进行傅里叶变换
f_transform = np.fft.fft2(gray_image)
fshift = np.fft.fftshift(f_transform)
magnitude_spectrum = 20 * np.log(np.abs(fshift))# 创建一个低通滤波器(示例中使用方形掩码)
rows, cols = gray_image.shape
crow, ccol = rows // 2, cols // 2
low_pass_filter = np.zeros((rows, cols), np.uint8)
low_pass_filter[crow-30:crow+30, ccol-30:ccol+30] = 1# 应用低通滤波器
fshift_low = fshift * low_pass_filter# 创建一个高通滤波器(高通滤波器是低通滤波器的逆)
high_pass_filter = 1 - low_pass_filter# 应用高通滤波器
fshift_high = fshift * high_pass_filter# 傅里叶逆变换还原
img_low = np.fft.ifftshift(fshift_low)
img_low = np.fft.ifft2(img_low)
img_low = np.abs(img_low)img_high = np.fft.ifftshift(fshift_high)
img_high = np.fft.ifft2(img_high)
img_high = np.abs(img_high)# 调整图像位置
result_image = np.zeros((rows*2, cols*2), dtype=np.uint8)
result_image[0:rows, 0:cols] = gray_image
result_image[0:rows, cols:] = magnitude_spectrum
result_image[rows:, 0:cols] = img_low
result_image[rows:, cols:] = img_high# 显示并保存拼接后的图像
cv2.imwrite(r'output.jpg', result_image)
plt.imshow(result_image, cmap='gray')
plt.axis('off')
plt.show()

eg.

3:图像平滑

从作品一的原彩色图像中的任意位置截取一块大小为 300*400 的图像块,然后添加高斯噪声,并用任意一种平滑方法(均值滤波、高斯滤波、中值滤波)对图像进行平滑处理,将原图截取的图像块、加噪图像及平滑图像一起拼接为一张图片

import cv2
import numpy as np# 读取原彩色图像
original_image = cv2.imread(r'input.jpg')# 截取图像块
x, y = 100, 200  # 起始坐标,请根据需要修改
roi = original_image[y:y+300, x:x+400]# 添加高斯噪声
mean = 0
stddev = 25  # 调整噪声的强度
gaussian_noise = np.random.normal(mean, stddev, roi.shape).astype(np.uint8)
noisy_roi = cv2.add(roi, gaussian_noise)# 使用均值滤波对图像进行平滑处理
smoothed_mean = cv2.blur(noisy_roi, (5, 5))  # 调整内核大小# 创建一个空白的拼接图像
result_image = np.zeros((300, 1200, 3), dtype=np.uint8)# 将原图截取的图像块、加噪图像和平滑图像拼接在一起
result_image[0:300, 0:400] = roi
result_image[0:300, 400:800] = noisy_roi
result_image[0:300, 800:1200] = smoothed_mean# 保存拼接后的图像
cv2.imwrite(r'output.jpg', result_image)

eg.

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

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

相关文章

浅谈压力测试的作用是什么

随着现代应用程序变得越来越复杂,用户的期望也在不断提高,对性能和可靠性的要求变得更加苛刻。在应用程序开发和维护的过程中,压力测试是一项至关重要的活动,它可以帮助发现潜在的问题、评估系统的性能极限,以及确保在…

4、在 CentOS 8 系统上安装 pgAdmin 4

pgAdmin 4 是一个开源的数据库管理工具,专门用于管理和操作 PostgreSQL 数据库系统。它提供了一个图形用户界面(GUI),使用户能够轻松地连接到 PostgreSQL 数据库实例,执行 SQL 查询,管理数据库对象&#xf…

基于知识图谱建模、全文检索的智能知识管理库(源码)

一、项目介绍 一款全源码,可二开,可基于云部署、私有部署的企业级知识库云平台,一款让企业知识变为实打实的数字财富的系统,应用在需要进行文档整理、分类、归集、检索、分析的场景。 知识图谱提供了一种从海量文本和图像中抽取结…

自定义类型:结构体,枚举,联合 (2)

2. 位段 位段的出现就是为了节省空间。 2.1 什么是位段 位段的声明和结构是类似的,有两个不同: 1.位段的成员必须是 int、unsigned int 或signed int 。 2.位段的成员名后边有一个冒号和一个数字。 比如: struct A {int _a:2;int _b:5;int…

Pygame中将鼠标形状设置为图片2-2

3 编写主程序 在主程序中,首先创建屏幕并且完成一些准备工作,之后在while循环中不断更新sprite实例即可。 3.1 创建屏幕及准备工作 创建屏幕及准备工作的代码如图5所示。 图5 创建屏幕及准备工作 其中,第20行代码调用pygame.mouse模块中的…

Hadoop3教程(五):NameNode和SecondaryNameNode

文章目录 (59)NN和2NN的工作机制(60)FsImage镜像文件(61)Edits编辑日志(62)Checkpoint时间设置参考文献 (59)NN和2NN的工作机制 NameNode的数据是存储在磁盘…

思维模型 正/反 木桶理论

本系列文章 主要是 分享 思维模型,涉及各个领域,重在提升认知。 1 正/反 木桶理论的应用 1.1 木桶理论的应用 1.1.1 正木桶理论在考试中的应用 小明是一名理科高中生,他在学习过程中发现自己在数理化方面表现较好,但在语文和英…

多个Python包懒得import,那就一包搞定!

使用Python时,有的代码需要依赖多个框架或库者来完成,代码开头需要import多次,比如, import pandas as pd from pyspark import SparkContext from openpyxl import load_workbook import matplotlib.pyplot as plt import seabo…

bootz启动 Linux内核涉及do_bootm_linux 函数

一. bootz启动Linux uboot 启动Linux内核使用bootz命令。当然还有其它的启动命令,例如,bootm命令等等。 本文只分析 bootz命令启动 Linux内核的过程中涉及的几个重要函数。具体分析 do_bootm_linux函数执行过程。 本文继上一篇文章,地址…

燃气管网监测系统,让城市生命线更安全

万宾科技燃气管网监测系统,让城市生命线更安全 城市是现代社会的中心,拥有庞大的人口和各种基础设施,以满足人们的生活需求。城市基础设施包括供热,供水,管廊,河湖,建筑,排水&#x…

linux 服务器类型Apache配置https访问

一:查看服务器类型,下载相应的SSL证书 命令:netstat -anp | grep :80 httpd是Apache超文本传输协议(HTTP)服务器的主程序,所以下载Apache证书 二:将证书解压后复制到服务器上 三个文件:xxx.key xxx_publ…

草莓病害图像数据集(YOLO使用,train为655张照片和val为487张照片)

前言:所有图像和标签是一一对应,没有标签缺失 写了两个程序来分别检查train文件夹的图像和val文件夹图像是否有缺失标签,如果有,会直接打印出缺失标签的图像名字。也方便以后用户自己添加自己收集的图像数据后,核对图…

Linux shell编程学习笔记12:布尔运算和逻辑运算

Linux Shell 脚本编程和其他编程语言一样,支持算数、关系、布尔、逻辑、字符串、文件测试等多种运算。前面几节我们陆续研究了 Linux shell编程 中的 字符串运算、算术运算和关系运算,今天我们来研究 Linux shell编程中的的布尔运算、逻辑运算。 一、…

纯文本邮件发送:java

1.打开jdk的conf下的security文件的.security,找到并删除&#xff0c;权限问题建议复制文件修改后替换 jdk.tls.disabledAlgorithmsSSLv3, TLSv1, TLSv1.1, RC4, DES, MD5withRSA, \ DH keySize < 1024, EC keySize < 224, 3DES_EDE_CBC, anon, NULL 删除后的内容 然…

数据结构 - 4(栈和队列6000字详解)

一&#xff1a;栈 1.1 栈的概念 栈&#xff1a;一种特殊的线性表&#xff0c;其只允许在固定的一端进行插入和删除元素操作。进行数据插入和删除操作的一端称为栈顶&#xff0c;另一端称为栈底。栈中的数据元素遵守后进先出LIFO&#xff08;Last In First Out&#xff09;的原…

php如何查找地图距离

要在PHP中使用高德地图、百度地图或腾讯地图获取位置信息&#xff0c;您可以使用它们的相应API服务。以下是获取位置信息的一般步骤&#xff1a; 思路: 获取API密钥&#xff1a;首先&#xff0c;您需要注册并获取相应地图服务提供商的API密钥。这将允许您访问他们的API以获取位…

Python学习基础笔记六十九——文本2

二进制&#xff08;字节&#xff09;模式&#xff1a; 文本文件&#xff0c;纯文本文件就是保存文本字符串的文件&#xff0c;跟word还不一样&#xff0c;word是富文本文件。 其实就文件存储的底层来说&#xff0c;不管什么类型的文件&#xff08;文本、视频、图片、word、Ex…

rsync 备份工具(附rsync+inotify 实时同步部署实例)

rsync 备份工具(附rsyncinotify 实时同步部署实例&#xff09; 1、rsync概述1.1关于rsync1.2rsync 的特点1.3工作原理 2、rsync相关命令2.1基本格式和常用选项2.2启动和关闭rsync服务2.3下行同步基本格式2.4上行同步基本格式2.5免交互2.5.1指定密码文件2.5.2rsync-daemon方式2.…

2.9 深入GPU硬件架构及运行机制

五、GPU技术要点 1.SMID和SIMT SIMD&#xff08;Single Instruction Multiple Data&#xff09;是单指令多数据&#xff0c;在GPU的ALU&#xff08;在Core内&#xff09;单元内&#xff0c;一条指令可以处理多维向量&#xff08;一般是4D&#xff09;的数据。比如&#xff0c…

宅在家里也能干的副业,每天挣60—300元,人人可做

想在家搞副业&#xff0c;每天挣60-300元&#xff0c;大家觉得难吗&#xff1f;我告诉你&#xff0c;一点也不难。找对路子&#xff0c;足不出户也能搞钱。今天我就给大家分享一下三个网上靠谱的副业&#xff0c;门槛低上手快&#xff0c;只需一部手机&#xff0c;每天利用碎片…