数字图像处理 实验三 数字图像的几何运算

一、实验目的

掌握图像的基本几何变换的方法

        1. 图像的平移 

        2. 图像的旋转

二、实验环境

        1. PC计算机

        2. MatLab软件/语言包括图像处理工具箱(Image Processing Toolbox)

        3. 实验所需要的图片

三、实验原理

提示:图片平移就是实现运算

四、实验图像

           

图片名称:                       kugou.jpeg                                       QQ.jpeg

图片尺寸:                       512*512*3                                      512*512*3 

五、实验步骤和结果

练习用matalb命令实现图像的缩放、旋转和平移操作

1. 读入图像并显示。

A = imread('kugou.jpeg');  
imshow(A);B = imread("QQ.jpeg");  
imshow(B);

2. 将图像放大1.5倍,插值方法使用三种不同方法,显示放大后的图像,比较不同插值方法的结果有什么不同。将图像放大到其它倍数,重复实验;选用其它图像,重复实验。

A1 = imresize(A, 1.5, 'nearest');  
imshow(A1);B1 = imresize(B, 1.5, 'nearest');  
imshow(B1);

A2 = imresize(A, 1.5, 'bilinear');  
imshow(A2);B2 = imresize(B, 1.5, 'bilinear');  
imshow(B2);

A3 = imresize(A, 1.5, 'bicubic');  
imshow(A3);B3 = imresize(B, 1.5, 'bicubic');  
imshow(B3);

最近邻域内插计算量较小,但可能会造成插值生成的图像灰度上的不连续,在灰度变化的地方可能出现明显的锯齿状。

双线性内插法的计算比最邻近点法复杂,计算量较大,但没有灰度不连续的缺点,结果基本令人满意。它具有低通滤波性质,使高频分量受损,图像轮廓可能会有一点模糊。

双三次内插方法计算量较大,但插值后的图像效果最好。

3. 图像缩小0.8、0.5倍,插值方法使用三种不同方法,显示并比较结果有什么差异。

提示:用imresize函数,imresize函数的语法格式为:B = imresize(A, m, method)

这里参数method用于指定插值的方法,可选用的值为'nearest'(最邻近法),'bilinear' (双线性插值),'bicubic'(双三次插值),默认为'nearest'。

A1 = imresize(A, 0.8, 'nearest');  
imshow(A1);
B1 = imresize(B, 0.8, 'nearest');  
imshow(B1);A2 = imresize(A, 0.8, 'bilinear');  
imshow(A2);
B2 = imresize(B, 0.8, 'bilinear');  
imshow(B2);A3 = imresize(A, 0.8, 'bicubic');  
imshow(A3);
B3 = imresize(B, 0.8, 'bicubic');  
imshow(B3);

A1 = imresize(A, 0.5, 'nearest');  
imshow(A1);
B1 = imresize(B, 0.5, 'nearest');  
imshow(B1);A2 = imresize(A, 0.5, 'bilinear');  
imshow(A2);
B2 = imresize(B, 0.5, 'bilinear');  
imshow(B2);A3 = imresize(A, 0.5, 'bicubic');  
imshow(A3);
B3 = imresize(B, 0.5, 'bicubic');  
imshow(B3);

最近邻域内插计算量较小,但可能会造成插值生成的图像灰度上的不连续,在灰度变化的地方可能出现明显的锯齿状。

双线性内插法的计算比最邻近点法复杂,计算量较大,但没有灰度不连续的缺点,结果基本令人满意。它具有低通滤波性质,使高频分量受损,图像轮廓可能会有一点模糊。

双三次内插方法计算量较大,但插值后的图像效果最好。

4. 图像分别顺时针旋转30度、45度,插值方法使用三种不同方法,显示旋转后的图像并比较结果有什么不同。

提示:用imrotate函数,imrotate的语法格式为:B = imrotate(A, angle, method)

函数imrotate对图像进行旋转,参数method用于指定插值的方法,可选用的值为'nearest'(最邻近法),'bilinear'(双线性插值),'bicubic'(双三次插值),默认为'nearest'。一般说来旋转后的图像会比原图大,超出原图部分值为0。

A1 = imrotate(A, 30, 'nearest');  
imshow(A1);
B1 = imrotate(B, 30, 'nearest');  
imshow(B1);A2 = imrotate(A, 30, 'bilinea');  
imshow(A2);
B2 = imrotate(B, 30, 'bilinea');  
imshow(B2);A3 = imrotate(A, 30, 'bicubic');  
imshow(A3);
B3 = imrotate(B, 30, 'bicubic');  
imshow(B3);

A1 = imrotate(A, 45, 'nearest');  
imshow(A1);
B1 = imrotate(B, 45, 'nearest');  
imshow(B1);A2 = imrotate(A, 45, 'bilinea');  
imshow(A2);
B2 = imrotate(B, 45, 'bilinea');  
imshow(B2);A3 = imrotate(A, 45, 'bicubic');  
imshow(A3);
B3 = imrotate(B, 45, 'bicubic');  
imshow(B3);

最近邻域内插计算量较小,但可能会造成插值生成的图像灰度上的不连续,在灰度变化的地方可能出现明显的锯齿状。

双线性内插法的计算比最邻近点法复杂,计算量较大,但没有灰度不连续的缺点,结果基本令人满意。它具有低通滤波性质,使高频分量受损,图像轮廓可能会有一点模糊。

双三次内插方法计算量较大,但插值后的图像效果最好。

5. 编写实现图像平移的函数。

% 编写实现图像平移的函数hmove,平移量为x0,y0,平移前图像矩阵为i
function [I]=hmove(i,x0,y0); 
[r,c]=size(i);               
I(r+x0,c+y0)=0;            % 平移后图像矩阵为I
for x=1:r;for y=1:c;x1=x+x0;y1=y+y0;I(x1,y1)=i(x,y);end;
end;

6. 调用平移函数,将灰度图平移100行20列,在同一个窗口中显示平移前和平移后的图像。

函数调用示例:I1=hmove(gray1,100,20);

I = im2double(A);  
I1=hmove(I, 100, 20);  
imshow(I1);

I = im2double(B);  
I1=hmove(I, 100, 20);  
imshow(I1);

六、实验思考

通过本次实验,初步掌握了图像的平移、旋转等图像的基本几何变换的方法。

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

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

相关文章

11.20[JAVAEXP3]重定向细究【DEBUG】

设置了根域名访问为testServlet,让他重定向到首页为test.jsp,事实上也都触发了,但是最后显示的为什么不是test.jsp生成页面,依然还是index.jsp生成的页面?? 重定向是通过Dispatcher进行的,而不是sendRedir…

大端存储和小端存储究竟是什么

数据存储方式 数据在计算机中表现为是0101的二进制形式,cpu在读取数据的时候需要从低地址向高地址读取 注意: 永远都是从低地址开始读取数据 低地址和高地址 内存地址空间: 计算机的内存被划分为一个连续的地址空间,这个空间从0开始,一直…

8. Debian系统中显示屏免密码自动登录

本文介绍如何在Debian系统上,启动后,自动免密登录,不卡在登录界面。 1. 修改lightDM配置文件 嵌入式Debian系统采用lightDM显示管理器,所以,一般需要修改它的配置文件/etc/lightdm/lightdm.conf,找到[Seat…

三菱伺服JET产品线(选型说明)

伺服放大器功能提升 伺服放大器MELSERVO-JET系列为进一步优化了独家控制引擎的高性能伺服放大器。 可通过与支持CC-LinK IE TSN的运动控制器的同步通信,进行高 速、高精度的运动控制。 除了旋转型伺服电机以外,还支持线性伺服电机。MR-JET-G-N1支持EtherCAT。 旋转型伺服电机 …

关于Chrome自动同步书签的解决办法

前言 并不一定适用所有用户, 目前我在网上搜集了一些资料,也做了一些尝试。 就我个人总结的经验来讲,分享大家以下几种办法: 1.书签同步插件 点击如下🔗: Chrome书签同步https://bm.famend.cn/ …

基于elementui的远程搜索下拉选择分页组件

在开发一个练手项目的时候&#xff0c;需要一个远程搜索的下拉选择组件&#xff1b; elementui自带的el-select支持远程搜索&#xff1b;但如果一次性查询的数据过多&#xff1b;会导致卡顿。故自己实现一个可分页的远程下拉选择组件 效果&#xff1a; 代码&#xff1a; <…

告别充电焦虑:移动充电机器人的革命性解决方案

移动充电机器人作为新能源汽车领域的黑科技&#xff0c;正逐渐崭露头角。它的出现为电动汽车充电带来了全新的解决方案&#xff0c;解决了传统充电方式的诸多痛点。 新能源汽车具有诸多优点&#xff0c;如科技含量高、噪音小、使用成本低等&#xff0c;但 “续航焦虑”“充电焦…

Socket 编程预备

目录 理解源 IP 地址和目的 IP 地址 认识端口号 端口号范围划分 理解 "端口号" 和 "进程 ID" 理解源端口号和目的端口号 理解 socket 传输层的典型代表 认识 TCP 协议 认识 UDP 协议 网络字节序 socket 编程接口 socket 常见 API sock…

17. Threejs案例-Three.js创建多个立方体

17. Threejs案例-Three.js创建多个立方体 实现效果 知识点 WebGLRenderer (WebGL渲染器) WebGLRenderer 是 Three.js 中用于渲染 WebGL 场景的核心类。它负责将场景中的对象渲染到画布上。 构造器 new THREE.WebGLRenderer(parameters) 参数类型描述parametersObject可选…

实例教程:BBDB为AHRS算法开发提供完善的支撑环境(下)

4. BBDB基础上为算法实现提供支撑方式二&#xff1a;算法层实现 第2节内容当中讲述在应用层实现AHRS的步骤&#xff0c;这种方法优点在于实现方法比较简单明了。但是缺点在于程序代码的组织算不上很好&#xff0c;AHRS算法代码与PH47框架代码间存在一定的耦合度&#xff0c;会…

Android开发,使用ViewPager2实现自动轮播图

文章目录 1. build.gradle添加依赖&#xff1a;2. AndroidManifest.xml中添加网络访问权限3. 编写 布局文件4. 编写Banner适配器5. 自定义Banner视图6. 定义圆点指示器的drawable资源7. 在需要使用轮播图中的Activity中使用8. 运行效果图9. 视频教程 在Android项目程序设计中&a…

企业网双核心交换机实现冗余和负载均衡(MSTP+VRRP)

MSTP&#xff08;多生成树协议&#xff09; 通过创建多个VLAN实例&#xff0c;将原有的STP、RSTP升级&#xff0c;避免单一VLAN阻塞后导致带宽的浪费&#xff0c;通过将VLAN数据与实例绑定&#xff0c;有效提升网络速率。 VRRP&#xff08;虚拟路由冗余协议&#xff09; 用…

Socket编程-tcp

1. 前言 在tcp套接字编程这里&#xff0c;我们将完成两份代码&#xff0c;一份是基于tcp实现普通的对话&#xff0c;另一份加上业务&#xff0c;client输入要执行的命令&#xff0c;server将执行结果返回给client 2. tcp_echo_server 与udp类似&#xff0c;前两步&#xff1…

15分钟训练数字人MimicTalk

只需15分钟&#xff0c;就能训练高质量&#xff0c;个性化数字人大模型。由浙江大学与字节跳动联合推出MimicTalk算法&#xff0c;目前已开源。 在外表和说话风格上和真人相似。将通用3D数字人大模型适应到单个目标人&#xff0c;采用动静结合的高效微调方案&#xff0…

【kettle】mysql数据抽取至kafka/消费kafka数据存入mysql

目录 一、mysql数据抽取至kafka1、表输入2、json output3、kafka producer4、启动转换&#xff0c;查看是否可以消费 二、消费kafka数据存入mysql1、Kafka consumer2、Get records from stream3、字段选择4、JSON input5、表输出 一、mysql数据抽取至kafka 1、表输入 点击新建…

在 MacOS 上为 LM Studio 更换镜像源

在 MacOS 之中使用 LM Studio 部署本地 LLM时&#xff0c;用户可能会遇到无法下载模型的问题。 一般的解决方法是在 huggingface.co 或者国内的镜像站 hf-mirror.com 的项目介绍卡页面下载模型后拖入 LM Studio 的模型文件夹。这样无法利用 LM Studio 本身的搜索功能。 本文将…

vue中.sync修饰符的用法

一、什么是.sync修饰符 在Vue.js中&#xff0c;.sync 修饰符用于创建一个双向绑定的 prop。它使子组件能够更新父组件的 prop 值&#xff0c;实现父子组件之间的双向数据同步。具体来说&#xff0c;.sync 修饰符主要有以下几个功能&#xff1a; 简化双向绑定&#xff1a; 使用…

【附源码】基于环信鸿蒙IM SDK实现一个聊天Demo

项目背景 本项目基于环信IM 鸿蒙SDK 打造的鸿蒙IM Demo&#xff0c;完全适配HarmonyOS NEXT系统&#xff0c;实现了发送消息&#xff0c;添加好友等基础功能。代码开源&#xff0c;功能简洁&#xff0c;如果您有类似开发需求可以参考。 源码地址&#xff1a;https://github.c…

SHELL----正则表达式

一、文本搜索工具——grep grep -参数 条件 文件名 其中参数有以下&#xff1a; -i 忽略大小写 -c 统计匹配的行数 -v 取反&#xff0c;不显示匹配的行 -w 匹配单词 -E 等价于 egrep &#xff0c;即启用扩展正则表达式 -n 显示行号 -rl 将指定目录内的文件打…

Can‘t find variable: token(token is not defined)

文章目录 例子 1&#xff1a;使用 var例子 2&#xff1a;使用 let 或 const例子 3&#xff1a;异步操作你的代码中的情况 Cant find variable: tokentoken is not defined源代码 // index.jsPage({data: {products:[],cardLayout: grid, // 默认卡片布局为网格模式isGrid: tr…