24小时热门版块排行榜    

CyRhmU.jpeg
南方科技大学公共卫生及应急管理学院2025级博士研究生招生报考通知
查看: 586  |  回复: 3

472381565

新虫 (小有名气)

[求助] 给这段MATLAB程序中没加注解的地方加上注解。

I1 = double(imread('X6.jpg'));
[h1 w1 d1] = size(I1);
I2 = double(imread('X7.jpg'));
[h2 w2 d2] = size(I2);
%显示图像并在显示的图像上取坐标

figure; subplot(1,2,1); image(I1/255); axis image; hold on;
title('first input image');
[X1 Y1] = ginput2(2); %在第一幅图像上确定2个点
subplot(1,2,2); image(I2/255); axis image; hold on;
title('second input image');
[X2 Y2] = ginput2(2); %在第二幅图像上取2个点

Z  = [ X2'  Y2' ; Y2' -X2' ; 1 1 0 0  ; 0 0 1 1 ]';         
xp = [ X1 ; Y1 ];
t  = Z \ xp;
a  = t(1);
b  = t(2);
tx = t(3);
ty = t(4);

T = [a b tx ; -b a ty ; 0 0 1];


cp = T*[ 1 1 w2 w2 ; 1 h2 1 h2 ; 1 1 1 1 ];
Xpr = min( [ cp(1, 0 ] ) : max( [cp(1, w1] );
Ypr = min( [ cp(2, 0 ] ) : max( [cp(2, h1] );
[Xp,Yp] = ndgrid(Xpr,Ypr);
[wp hp] = size(Xp);


X = T \ [ Xp( Yp( ones(wp*hp,1) ]';

clear Ip;
xI = reshape( X(1,,wp,hp)';
yI = reshape( X(2,,wp,hp)';
Ip(:,:,1) = interp2(I2(:,:,1), xI, yI, '*bilinear');
Ip(:,:,2) = interp2(I2(:,:,2), xI, yI, '*bilinear');
Ip(:,:,3) = interp2(I2(:,:,3), xI, yI, '*bilinear');


offset =  -round( [ min( [ cp(1, 0 ] ) min( [ cp(2, 0 ] ) ] );
Ip(1+offset(2):h1+offset(2),1+offset(1):w1+offset(1), = double(I1(1:h1,1:w1,);


figure; image(Ip/255); axis image;
title('mosaic image');
回复此楼
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

472381565

新虫 (小有名气)

怎么把代码贴上是这样了
2楼2013-06-01 16:42:49
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

somomo91

专家顾问 (职业作家)

还是你说那一行不明白的方便
另外为了防止 出现笑脸符号,
可以把在 : 和 ) 之间 添加一个空格
3楼2013-06-02 07:30:51
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
4楼2013-06-08 00:19:28
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 472381565 的主题更新
信息提示
请填处理意见