实验三 图像增强—灰度变换

news2025/1/10 15:58:28

一、实验目的:

1、了解图像增强的目的及意义,加深对图像增强的感性认识,巩固所学理论知识。

2、学会对图像直方图的分析。

3、掌握直接灰度变换的图像增强方法。

二、实验原理及知识点

术语‘空间域’指的是图像平面本身,在空间域内处理图像的方法是直接对图像的像素进行处理。空间域处理方法分为两种:灰度级变换、空间滤波。空间域技术直接对像素进行操作其表达式为

                                                                 g(x,y)=T[f(x,y)]

其中f(x,y)为输入图像,g(x,y)为输出图像,T是对图像f进行处理的操作符,定义在点(x,y)的指定领域内。

定义点(x,y)的空间邻近区域的主要方法是,使用中心位于(x,y)的正方形或长方形区域。此区域的中心从原点(如左上角)开始逐像素点移动,在移动的同时,该区域会包含不同的邻域。T应用于每个位置(x,y),以便在该位置得到输出图像g。在计算(x,y)处的g值时,只使用该邻域的像素。

灰度变换T的最简单形式是使用大小为1×1的邻域,此时,(x,y)处的g值仅由f在该点处的亮度决定,T也变为一个亮度或灰度级变化函数。当处理单设(灰度)图像时,这两个术语可以互换。由于亮度变换函数仅取决于亮度的值,而与(x,y)无关,所以亮度函数通常可写做如下所示的简单形式:

                                                                          s=T(r)

其中,r表示图像f中相应点(x,y)的亮度,s表示图像g中相应点(x,y)的亮度。

2.1灰度变换函数

重点使用imadjuststretchlim函数

q=imadjust(I, [low_in; high_in], [low_out; high_out], gamma)

python的基本实现https://stackoverflow.com/questions/39767612/what-is-the-equivalent-of-matlabs-imadjust-in-python

stretchlim在matlab原型如下:

Low_High = stretchlim(f, tol)

其中f是一张灰度图片,tol如果是一个两元素向量[low_frac high_frac],指定了图像低和高像素的饱和度百分比,tol如果是一个标量,那么

low_frac = tol, high_frac = 1 - low_frac。

tol默认值是[0.01 0.99]。简单的说,就是计算两个阈值,(默认情况)其中low代表小于这个值的像素占整张图片的1%,其中high代表大于这个值的像素占整张图片的1-0.99=1%。

如果选择tol=0,low_frac=[min(f(:)) max(f(:))] 。

通常利用stretchlim配合imadjust来自动地提高图片的对比度,而不关心参数高低的处理

2.2对数及对比度扩展

三、实验内容(不限编程语言、也可自行选择实验图像):

(1)灰度变换imadjust、intrans函数和stretchlim函数的使用。

对数变化mat2gray函数的使用,例如:

1、图像数据读出

2、计算并分析图像直方图

3、利用直接灰度变换法对图像进行灰度变换

下面给出灰度变化的MATLAB程序

f=imread('medicine_pic.jpg');%或者选lenna.jpg

g=imhist(f,256);            %显示其直方图

g1=imadjust(f,[0 1],[1 0]);    %灰度转换,实现明暗转换(负片图像)

figure,imshow(g1)

%将0.5到0.75的灰度级扩展到范围[0 1]

g2=imadjust(f,[0.5 0.75],[0 1]);

figure,imshow(g2)

g=imread('point.jpg');

h=log(1+double(g));    %对输入图像对数映射变换

h=mat2gray(h);         %将矩阵h转换为灰度图片

h=im2uint8(h);         %将灰度图转换为8位图

figure,imshow(h)

(2)图像的几何变换(图像的缩放)、旋转、镜像变换

旋转函数(思考并实现镜像变换。所谓的镜像,通俗地讲,是指在镜子中所成的像。其特点是左右颠倒或者是上下颠倒。镜像分为水平镜像和垂直镜像。)

B = imrotate(A,angle)

B = imrotate(A,angle,method)

B = imrotate(A,angle,method,bbox)

示例:

img_w = 640;

img_h = img_w;

img_oblique_rect = zeros(img_h, img_w);

% create a oblique(45) rectangle in the matrix

x1 = int32(img_w / 5 * 2); x2 = int32(img_w / 5 * 3);

y1 = int32(img_h / 7); y2 = int32(img_h / 7 * 6);

% 下面这句代码产生一个常规矩形。

img_oblique_rect(y1:y2, x1:x2) = 1;

% 利用双线性插值算法对图像进行旋转, 产生一个斜矩形

img_oblique_rect=imrotate(img_oblique_rect,45,'bilinear','crop');

img_oblique_rect = imcomplement(img_oblique_rect);

figure('Name', '这是一个斜矩形'), imshow(img_oblique_rect)

三.实验程序、实验结果与实验分析

1. 实验程序

(1)灰度变换imadjust、intrans函数和stretchlim函数的使用

f=imread('medicine_pic.jpg');%或者选lenna.jpg

imhist(f,256);          %显示其直方图

g1=imadjust(f,[0 1],[1 0]);    %灰度转换,实现明暗转换(负片图像)

figure,imshow(g1),title('负片图像');

%将0.5到0.75的灰度级扩展到范围[0 1]

g2=imadjust(f,[0.5 0.75],[0 1]);

figure, imshow(g2), title('灰度级扩展后的图像');

g=imread('point.jpg');

h=log(1+double(g));    %对输入图像对数映射变换

h=mat2gray(h);         %将矩阵h转换为灰度图片

h=im2uint8(h);         %将灰度图转换为8位图

figure,imshow(h),title('对数映射变换图像');

(2)图像的几何变换(图像的缩放)、旋转、镜像变换

I=imread('Cameraman.tif');

figure,imshow(I),title('原始图像');

scale=0.5;

J=imresize(I,scale);

figure,imshow(J),title('图像缩小为原始大小一半的图像');



img_w = 640;

img_h = img_w;

img_oblique_rect = zeros(img_h, img_w);

% create a oblique(45) rectangle in the matrix

x1 = int32(img_w / 5 * 2); x2 = int32(img_w / 5 * 3);

y1 = int32(img_h / 7); y2 = int32(img_h / 7 * 6);

% 下面这句代码产生一个常规矩形。

img_oblique_rect(y1:y2, x1:x2) = 1;

imshow(img_oblique_rect),title('常规矩形');

% 利用双线性插值算法对图像进行旋转, 产生一个斜矩形

img_oblique_rect=imrotate(img_oblique_rect,45,'bilinear','crop');

img_oblique_rect = imcomplement(img_oblique_rect);

figure('Name', '这是一个斜矩形'), imshow(img_oblique_rect),title('斜矩形');

2. 实验结果

(1)灰度变换imadjust、intrans函数和stretchlim函数的使用(Test3_1)

①图像medicine_pic的直方图

②负片图像

③灰度级扩展后的图像

④对数映射变换图像

(2)图像的几何变换(图像的缩放)、旋转、镜像变换(Test3_2)

①原始图像

②图像缩小为原始大小一般的图像

③常规矩形

④斜矩形

3. 实验分析

(1)灰度变换imadjust、intrans函数和stretchlim函数的使用

①读入图像medicine_pic.jpg
f=imread('medicine_pic.jpg');

imhist(f,256);          %显示其直方图
②使用imadjust()函数进行灰度转换,实现明暗转换(负片图像)
g1=imadjust(f,[0 1],[1 0]);    %灰度转换,实现明暗转换(负片图像)

figure,imshow(g1),title('负片图像');

%将0.5到0.75的灰度级扩展到范围[0 1]
③使用imadjust()函数将图像的灰度级扩展到[0 1]
g2=imadjust(f,[0.5 0.75],[0 1]);

figure, imshow(g2), title('灰度级扩展后的图像');
④读入图像point.jpg
g=imread('point.jpg');
⑤对输入图像对数映射变换
h=log(1+double(g));
⑥将矩阵h转换为灰度图片   
h=mat2gray(h); 
⑦将灰度图转换为8位图       
h=im2uint8(h);          

figure,imshow(h),title('对数映射变换图像');

(2)图像的几何变换(图像的缩放)、旋转、镜像变换

通过对图像进行缩放和旋转操作,可以改变图像的尺寸和角度,从而实现图像的变换和几何形状的调整。

①读入图像Cameraman.tif
②使用imresize()函数将原始图像缩小为原始大小的一半
scale=0.5;

J=imresize(I,scale);
创建了一个大小为 640x640 的零矩阵,并在矩阵中创建了一个常规矩形
img_w = 640;

img_h = img_w;

img_oblique_rect = zeros(img_h, img_w);

x1 = int32(img_w / 5 * 2); x2 = int32(img_w / 5 * 3);

y1 = int32(img_h / 7); y2 = int32(img_h / 7 * 6);

img_oblique_rect(y1:y2, x1:x2) = 1;
使用imrotate()函数对图像进行了旋转,角度为45度,使用双线性插值算法,并通过'crop'参数进行裁剪,以防止旋转后的图像超出原始图像范围。
img_oblique_rect=imrotate(img_oblique_rect,45,'bilinear','crop');
将旋转后的图像进行反转(黑白翻转)
img_oblique_rect = imcomplement(img_oblique_rect);

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

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

相关文章

使用Session实现单点登录(SSO)

仅仅是一种思路,细节不做具体说明。

servlet学校会场预约系统-计算机毕业设计源码72972

摘要 学校会场预约是学校管理中的重要环节,但传统的手工预约方式存在效率低下和信息不准确等问题。为了提高预约效率和减少管理成本,许多学校开始采用基于Servlet技术的会场预约系统。本论文旨在设计和实现一种高效的Servlet学校会场预约系统&#xff0c…

已经安装deveco-studio-4.1.3.500的基础上安装deveco-studio-3.1.0.501

目录标题 1、执行exe文件后安装即可2、双击devecostudio64_3.1.0.501.exe2.1、安装Note (注意和4.1的Note放不同目录)2.2、安装ohpm (注意和4.1版本的ohpm放不同目录)2.3、安装SDK (注意和4.1版本的SDK放不同目录) 1、执行exe文件后安装即可 2、双击devecostudio64_3.1.0.501.e…

pycharm如何使用jupyter

目录 配置jupyter新建jupyter文件别人写的方法(在pycharm种安装,在网页中使用) pycharm专业版 配置jupyter 在pycharm终端启动一个conda虚拟环境,输入 conda install jupyter会有很多前置包需要安装: 新建jupyter…

Docker:二、常用命令

🍁docker常用命令 官方帮助文档:https://docs.docker.com/reference/ 🌲帮助命令(版本信息) docker -v # 显示docker版本 docker version # 显示docker版本信息 docker info # 显示docker系统信息 docker 命…

Excel多表格合并

我这里一共有25张表格: 所有表的表头和格式都一样,但是内容不一样: 现在我要做的是把所有表格的内容合并到一起,研究了一下发现WPS的这项功能要开会员的,本来想用代码撸出来的,但是后来想想还是找其他办法,后来找到"易用宝"这个插件,这个插件可以从如下地址下载:ht…

Python中frozenset,秒变不可变集合,再也不用担心多线程了!

目录 1、Frozenset基础介绍 🌐 1.1 Frozenset定义与创建 1.2 不可变集合特性 1.3 与Set的区别对比 2、Frozenset操作实践 🧩 2.1 初始化与添加元素尝试 2.2 成员测试: in & not in 2.3 集合运算: 并集、交集、差集 2.4 使用场景示例: 字典键、函数参数默认值 …

DisFormer:提高视觉动态预测的准确性和泛化能力

最新的研究进展已经显示出目标中心的表示方法在视觉动态预测任务中可以显著提升预测精度,并且增加模型的可解释性。这种表示方法通过将视觉场景分解为独立的对象,有助于模型更好地理解和预测场景中的变化。 尽管在静态图像的解耦表示学习方面已经取得了一…

聊天交友系统开发专业语聊交友app开发搭建同城交友开发婚恋交友系统相亲app开发

1、上麦相亲互动:直播间内除了红娘外,还有男女用户两个视频麦位,直播间符合要求的用户可以申请上麦 2、公屏聊天:为上麦用户可以通过在公屏发言的方式参与直播间内的话题互动。 3、私信,异性用户之间可以发送私信消息,通过付费或开通会员可解…

Spring 6.1.10版本源码编译

每篇一句 我们对时间的感知其实非常主观,我们越习惯于我们的生活方式,生活里面的新鲜感就越少,我们对时间 的感知就越快,生命就越短。 1.源码下载 进入Spring官网 https://spring.io/ 按照上图步骤进入如下Spring Framework链…

通过RpmBuild构建redis-5.0.9版本的RPM类型包

系列文章目录 rpmbuild基础知识 文章目录 系列文章目录前言一、rpmbuild相关操作1、安装rpmbuild命令2、安装spec文件检查工具3、查看rpmbuild版本4、编译工具安装5、修改rpm制作包的默认路径 二、资源准备1、创建rpmbuild工作目录2、目录作用解释3、下载redis源码包4、上传re…

LLM - 神经网络的组成

1. 一个神经元的结构:即接受多个输入X向量,在一个权重向量W和一个偏执标量b的作用下,经过激活函数后,产生一个输出。 2. 一层神经网络的结构:该层网络里的每个神经元并行计算,得到各自的输出;计算方式是输入…

Go源码--channel源码解读

简介 channel顾名思义就是channel的意思,主要用来在协程之间传递数据,所以是并发安全的。其实现原理,其实就是一个共享内存再加上锁,底层阻塞机制使用的是GMP模型。可见 GMP模型就是那个道,道生一,一生二,二生三,三生…

【Spring Boot】统一数据返回

目录 统一数据返回一. 概念二.实现统一数据返回2.1 重写responseAdvice方法2.2 重写beforeBodyWriter方法 三. 特殊类型-String的处理四. 全部代码 统一数据返回 一. 概念 其实统一数据返回是运用了AOP(对某一类事情的集中处理)的思维,简单…

UML2.0-系统架构师(二十四)

1、(重点)系统()在规定时间内和规定条件下能有效实现规定功能的能力。它不仅取决于规定的使用条件等因素,还与设计技术有关。 A可靠性 B可用性 C可测试性 D可理解性 解析: 可靠性:规定时间…

在Linux操作系统中关于逻辑卷的案例

1.如何去创建一个逻辑卷 1.1先去创建物理卷 如上图所示,physical volume 物理卷 被成功创建。 如上图所示,可以使用pvscan来去查看当前Linux操作系统的物理卷/ 1.2使用创建好的物理卷去创建一个卷组。 如上图所示,可以使用第一步创建的两个…

点亮led灯——Arduino uno R3 学习之旅

​ 常识: 一般智能手机的额定工作电流大约为200mA Arduino Uno板上I/0(输入/输出)引脚最大输出电流为40 mA Uno板控制器总的输出电流为200 mA 发光二极管介绍 发光二极管(Light Emitting Diode,简称LED)是一种能够将电能转化为光能的固态的半导体器件。 LED的极…

鸿蒙开发:Universal Keystore Kit(密钥管理服务)【密钥导入介绍及算法规格】

密钥导入介绍及算法规格 如果业务在HUKS外部生成密钥(比如应用间协商生成、服务器端生成),业务可以将密钥导入到HUKS中由HUKS进行管理。密钥一旦导入到HUKS中,在密钥的生命周期内,其明文仅在安全环境中进行访问操作&a…

输入框输入值之后,检索表格中是否存在输入框中的值,存在就让当前文字为红色

this.searchValue为输入框的值 createKeywordHtml_content(data) { if (data undefined) { return data; } if (typeof data ! string) { data String(data) } let value data.replace(this.searchValue, <span style"color:#FF5555">$&</span>…

Vue 性能革命:揭秘前端优化的终极技巧;Vue优化技巧,解决Vue项目卡顿问题

目录 Vue优化路径 一、使用key 二、使用冻结对象 三、使用函数式组件 四、使用计算属性 五、使用非实时绑定的表单项 六、保持对象引用稳定 6.1、保持对象引用稳定定义 6.2、保持对象引用稳定与不稳定的例子 6.3、vue2判断数据是否变化是通过hasChanged函数实现的 ①…