• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

图像仿射变换——MatLab代码实现

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

这里先说一下我们的目的,最近在用Pix2Pix 做一个项目的时候,遇到了成对图像质量差,存在着特征不能对齐的问题,即A图与B图是一组成对图像,我们想要将A 图中的物体转化为B 图中的物体,但这个物体在A 图与B 图中的坐标位置相差较大。

为了解决这一问题,我们使用图像仿射变换技术来解决这个问题,仿射变换的原理网上一搜就有一大把,这里不做介绍,这里只给出代码实现。

img_x = "./1.png";
img_y = "./2.png";
x = imread(img_x);	% 读取图像x
y = imread(img_y);	% 读取图像y
figure;
subplot(1, 2, 1); imshow(x);	% 显示图像x
subplot(1, 2, 2); imshow(y);	% 显示图像y
set(gcf, "outerposition", get(0, "screensize")); 	% 将图像全萤幕显示
[x0,y0] = ginput(3);	% 通过鼠标点击三次取得三个坐标点
[x1,y1] = ginput(3);	% 通过鼠标点击三次取得目标图中对应的三个坐标点
close all;	% 关闭图像显示
in_points = [x0,y0];
out_points = [x1,y1];
tform2 = maketform('affine', in_points, out_points);	% 计算变换矩阵
T = affine2d(tform2.tdata.T);	% 将变换矩阵转化为仿射变换矩阵类型
z = imwarp(x,T,'OutputView',imref2d(size(y)));	% 进行仿射变换
img_result = "./3.png";
imwrite(z, img_result);	% 存储结果

效果图如下:


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
matlab 读取视频aviread 报错 Unable to locate decompressor to decompress video st ...发布时间:2022-07-18
下一篇:
delphi快捷键大全发布时间:2022-07-18
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap