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

这里先说一下我们的目的,最近在用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); % 存储结果

效果图如下:

1519078-20190816155321101-189509385.png

转载于:https://www.cnblogs.com/dereen/p/affine_matlab.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值