㈠ matlab 如何將圖像縮放到指定像素大小的函數
1、首先打開電腦,然後在電腦中找到並打開matlab軟體主界面,如圖所示。
㈡ MATLAB圖像基本相關函數(關於縮放)
t1
=
maketform('affine',[2
0
0;
0
1
0;
0
0
1]);%橫向放2倍。如果想縮2倍就把2改為0.5即可,即變為0.5倍
t2
=
maketform('affine',[1
0
0;
0
2
0;
0
0
1]);%縱向放2倍。如果想縮2倍就把2改為0.5即可,即變為0.5倍
t3
=
maketform('affine',[4/5
0
0;
0
3/5
0;
0
0
1]);%橫向4/5,縱向3/5
i
=
imread('cameraman.tif');
i1
=
imtransform(i,t1);
i2
=
imtransform(i,t2);
i3
=
imtransform(i,t3);
imshow(i),
figure,
imshow(i1),
figure,
imshow(i2),
figure,
imshow(i3)
㈢ 如何用MATLAB對圖片進行縮放
MATLAB是美國MathWorks公司出品的商業數學軟體,用於演算法開發、數據可視化、數據分析以及數值計算的高級技術計算語言和互動式環境。
MATLAB和Mathematica、Maple並稱為三大數學軟體。它在數學類科技應用軟體中在數值計算方面首屈一指。無論是做項目還是寫論文,我們都會遇到把Matlab畫的圖形(默認為matlab自帶的圖像格式.fig)轉換為其他格式並導出的問題。
用的最多的圖片格式是eps格式(用latex編輯時用)和jpg(用word編輯時用)。下面以matlab 2011b為例介紹多種縮放方法。
㈣ 怎麼用MATLAB掌握圖像平移、圖像旋轉和圖像縮放的基本原理與實現方法
%圖像平移(1)
F=imread('p2.bmp');
se = translate(strel(1), [0 20]);
%參數[0 20]可以修改,修改後平移距離對應改變
J = imdilate(F,se);
figure;
imshow(J,[]);title('右移後圖形');
%圖像平移(2)
function outImage=immove(inImage,Tx,Ty)
[m, n] = size(inImage);
Tx=fix(Tx);
Ty=fix(Ty);
%move x
if (Tx<0)
inImage=imcrop(inImage,[abs(Tx),1,m-abs(Tx),n]);
[m, n] = size(inImage);
Tx=0;
end
%move y
if (Ty<0)
inImage=imcrop(inImage,[1,abs(Ty),m,n-abs(Ty)]);
[m, n] = size(inImage);
Ty=0;
end
outImage = zeros(m+Ty, n+Tx);
outImage(1+Ty:m+Ty,1+Tx:n+Tx) = inImage;
%圖像旋轉
%X,Y為其行列數
Image=imread('02.jpg');
Image=rgb2gray(Image);
angle=30;
%角度任意的一個數 表示30度
pai=3.14;
Angle=pai*angle/180;
%轉換一下角度的表示方法。
[X,Y]=size(Image);
%原圖顯示
subplot(2,1,1);
imshow(Image);
title('原圖像');
%計算四個角點的新坐標,確定旋轉後的顯示區域
LeftTop(1,1)=-(Y-1)*sin(Angle);
LeftTop(1,2)=(Y-1)*cos(Angle);
LeftBottom(1,1)=0;
LeftBottom(1,2)=0;
RightTop(1,1)=(X-1)*cos(Angle)-(Y-1)*sin(Angle);
RightTop(1,2)=(X-1)*sin(Angle)+(Y-1)*cos(Angle);
RightBottom(1,1)=(X-1)*cos(Angle);
RightBottom(1,2)=(X-1)*sin(Angle);
%計算顯示區域的行列數
Xnew=max([LeftTop(1,1),LeftBottom(1,1),RightTop(1,1),RightBottom(1,1)])-min([LeftTop(1,1),LeftBottom(1,1),RightTop(1,1),RightBottom(1,1)]);
Ynew=max([LeftTop(1,2),LeftBottom(1,2),RightTop(1,2),RightBottom(1,2)])-min([LeftTop(1,2),LeftBottom(1,2),RightTop(1,2),RightBottom(1,2)]);
% 分配新顯示區域矩陣
ImageNew=zeros(round(Xnew),round(Ynew))+255;
%計算原圖像各像素的新坐標
for indexX=0:(X-1)
for indexY=0:(Y-1)
ImageNew(round(indexX*cos(Angle)-indexY*sin(Angle))+round(abs(min([LeftTop(1,1),LeftBottom(1,1),RightTop(1,1),RightBottom(1,1)])))+1,1+round(indexX*sin(Angle)+indexY*cos(Angle))+round(abs(min([LeftTop(1,2),LeftBottom(1,2),RightTop(1,2),RightBottom(1,2)]))))=Image(indexX+1,indexY+1);
end
end
%顯示
subplot(2,1,2);
imshow((ImageNew)/255)
promp=['旋轉角度為:' int2str(angle) '的圖像']
title(promp);
%圖像縮放
function y=resize(a,mul,type)
%****************************************************
%a:輸入圖像灰度值
%mul:縮放倍數
%type:1表示最鄰近法,2表示雙極性插值法
%畫出縮放後圖像並返回其灰度值
%****************************************************
[m,n]=size(a);
m1=m*mul;n1=n*mul;
%****************************************************
if type==1
for i=1:m1
for j=1:n1;
b(i,j)=a(round(i/mul),round(j/mul));
end
end
elseif type==2
for i=1:m1-1
for j=1:n1-1;
u0=i/mul;v0=j/mul;
u=round(u0);v=round(v0);
s=u0-u;t=v0-v;
b(i,j)=(a(u+1,v)-a(u,v))*s+(a(u,v+1)-a(u,v))*t+(a(u+1,v+1)+a(u,v)-a(u,v+1)-a(u+1,v))*s*t+a(u,v);
end
end
end
%*****************************************************
b=uint8(b);
imshow(b);
title('處理後圖像');
y=b;
㈤ 求高手用MATLAB對圖片進行縮放
imo=imread('test.png');%讀取
s=2;%縮放倍數,縮放後與原始大小的比值
figure(1)
imshow(imo);%原圖顯示
[m n d]=size(imo);
if s<=1 & s>0
for i=1:d
im(:,:,i)=imo(round(1:1/s:m),round(1:1/s:n),i);
end
elseif s>1
[X Y]=meshgrid(1:n,1:m);
[Xt Yt]=meshgrid(1:1/s:n,1:1/s:m);
for i=1:d
im(:,:,i)=interp2(double(imo(:,:,i)),Xt,Yt,'spline');
end
if isa(imo,'uint8')
im=uint8(im);
else
im=uint16(im);
end
end
figure(2)
imshow(im);%縮放圖顯示
㈥ matlab圖象縮放程序
你在matlab下使用help imresize就知道了,不要這么懶嘛
例子:
clear;
lena=imread('lena.tiff');
%以下三行指定縮放倍數為0.5,即長寬各變為原始圖像的0.5倍,
%分別使用三種插值方法,即最近鄰插值(默認)、雙線性插值、雙三次插值
lena0_5_1=imresize(lena,0.5);%
lena0_5_2=imresize(lena,0.5,'bilinear');
lena0_5_3=imresize(lena,0.5,'bicubic');
%以下三行指定縮放倍數為2,即長寬各變為原始圖像的2倍,
%分別使用三種插值方法,即最近鄰插值(默認)、雙線性插值、雙三次插值
lena2_1=imresize(lena,2);
lena2_2=imresize(lena,2,'bilinear');
lena2_3=imresize(lena,2,'bicubic');
%下面一行是另外一種方式給定縮放倍數的例子,即給出縮放後圖像的行數和列數
lena2_1_0=imresize(lena,[256 512]);
imshow(lena2_1_0);
㈦ matlab 圖像縮放
T1 = maketform('affine',[2 0 0; 0 1 0; 0 0 1]);%橫向放2倍。如果想縮2倍就把2改為0.5即可,即變為0.5倍
T2 = maketform('affine',[1 0 0; 0 2 0; 0 0 1]);%縱向放2倍。如果想縮2倍就把2改為0.5即可,即變為0.5倍
T3 = maketform('affine',[4/5 0 0; 0 3/5 0; 0 0 1]);%橫向4/5,縱向3/5
I = imread('cameraman.tif');
I1 = imtransform(I,T1);
I2 = imtransform(I,T2);
I3 = imtransform(I,T3);
imshow(I), figure, imshow(I1), figure, imshow(I2), figure, imshow(I3)
㈧ 怎麼將matlab得到的圖局部放大呀
1、首先畫一個軌跡圖像。
㈨ matlab 如何對一個波形進行線性縮放
%% 4.圖像的縮放
% 思路:雙線性插值
kV = 0.5; % 垂直縮放系數
kH = 0.5; % 水平縮放系數
% 讀入圖像
I = imread('D:\lena.bmp'); % 注意修改文件路徑
II = double(I);
[m, n, r]=size(II);
OI=zeros(m*kV,n*kH, r);
rot=[kV 0 0;0 kH 0;0 0 1]; % 變換矩陣
for k=1:r
for i=1:m*kV
for j=1:n*kH
pix=[i j 1]/rot;
Y =pix(1)-floor(pix(1));
X =pix(2)-floor(pix(2));
% 邊界處理
if pix(1) < 1
pix(1) = 1;
end
if pix(1) > m
pix(1) = m;
end
if pix(2) < 1
pix(2) = 1;
end
if pix(2) > n
pix(2) =n;
end
% 四個鄰點
pix1 = [floor(pix(1))floor(pix(2))];
pix2 = [floor(pix(1))ceil(pix(2))];
pix3 = [ceil(pix(1))floor(pix(2))];
pix4 = [ceil(pix(1))ceil(pix(2))];
% 計算臨近四個點的權重
w1 = (1-X)*(1-Y);
w2 = X*(1-Y);
w3 = (1-X)*Y;
w4 = X*Y;
% 按權重進行雙線性插值
OI(i,j,k)=...
w1*II(pix1(1),pix1(2),k)+ ...
w2*II(pix2(1),pix2(2),k)+ ...
w3*II(pix3(1),pix3(2),k)+ ...
w4*II(pix4(1),pix4(2),k);
end
end
end
figure, imshow(uint8(II)), title('原圖')
figure, imshow(uint8(OI)), title('縮放後')
㈩ 如何用MATLAB編寫一個雙線性插值的演算法,用來放大縮小圖象
%% 4.圖像的縮放
% 思路:雙線性插值
kV = 0.5; % 垂直縮放系數
kH = 0.5; % 水平縮放系數
% 讀入圖像
I = imread('D:\lena.bmp'); % 注意修改文件路徑
II = double(I);
[m, n, r]=size(II);
OI=zeros(m*kV,n*kH, r);
rot=[kV 0 0;0 kH 0;0 0 1]; % 變換矩陣
for k=1:r
for i=1:m*kV
for j=1:n*kH
pix=[i j 1]/rot;
Y =pix(1)-floor(pix(1));
X =pix(2)-floor(pix(2));
% 邊界處理
if pix(1) < 1
pix(1) = 1;
end
if pix(1) > m
pix(1) = m;
end
if pix(2) < 1
pix(2) = 1;
end
if pix(2) > n
pix(2) =n;
end
% 四個鄰點
pix1 = [floor(pix(1))floor(pix(2))];
pix2 = [floor(pix(1))ceil(pix(2))];
pix3 = [ceil(pix(1))floor(pix(2))];
pix4 = [ceil(pix(1))ceil(pix(2))];
% 計算臨近四個點的權重
w1 = (1-X)*(1-Y);
w2 = X*(1-Y);
w3 = (1-X)*Y;
w4 = X*Y;
% 按權重進行雙線性插值
OI(i,j,k)=...
w1*II(pix1(1),pix1(2),k)+ ...
w2*II(pix2(1),pix2(2),k)+ ...
w3*II(pix3(1),pix3(2),k)+ ...
w4*II(pix4(1),pix4(2),k);
end
end
end
figure, imshow(uint8(II)), title('原圖')
figure, imshow(uint8(OI)), title('縮放後')