(完整版)Matlab主要函数使用方法
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
Matlab主要函数使用方法
ndims(A)用ndims命令常看矩阵的维数
1. matlab中mod的用法
简单的说mod(a,b)就是求的是a除以b的余数。
比方说mod(100,3)=1,mod(17,6)=5
Examples
mod(13,5)
ans =
3
mod([1:5],3)
ans =
1 2 0 1 2
mod(magic(3),3)
ans =
2 1 0
0 2 1
1 0 2
2. 关于Matlab中size()的问题
size按照下面的形式使用:
[m,n]=size(a,x)。
一般的,函数的输入参量x不是用,这是当只有一个输出变量时,size返回一个行向量,第一个数为行数,第二个数为列数;如果有两个输出变量,第一个返回量为行数,第二个返回数为列数。
当使用x时,x=1返回行数,x=2返回列数,这时只有一个返回值。
我要问的是:
I=im2double(imread(file)) ;//把图像数组转换成double精度类型;
if(size(I,3) > 1)
I = rgb2gray( I ) ;
end
中size(I,3) 代表什么意思?按照上面的说法X=1,2都可以理解。
I 代表的是图像数组阿,不是二维的么?那么size(I,3) 中的3 代表什么?
一个函数可以是多维的..比如说是一个10*10*10*10的距阵
那就是说这个距阵是4维的..
那个'()'里的3就是指的第三维
3.r = corr2(A,B)
计算两个矩阵的二维相关系数.
4.matlab中imshow显示问题
各位好,将一幅灰度图像经过小波变换后,数据变成double型,对变换后的图像进行显示时,设变换后的图像为y,为何用imshow(uint8(y))和imshow(y,[])时的图像显示结果不同呢?请问该如何正确显示变换后的图像呢?着急解决,请各位xdjm帮帮忙吧!
回答:
imshow(uint8(y))是按照256级灰度显示y得绝对数据。
0表示0,255表示255,大于255得都是255。
imshow(y,[]),将y得最小值看作0,最大值看作255。
所以两者不同。
小波变换得图像应该用第二种显示,把数据scale一下。
5.matlab中用imshow显示图像由于数组类型产生的错误
今天在用MATLAB写程序的时候遇到个问题,以前一直没有注意到,刚才检查的时候才发现。
我们先来看段不复杂的程序
%定义常量
size=256; block=8; I_w=zeros(size);
%读入原始图像和水印图像并显示
I=imread('lena.bmp'); W=imread('watermark.bmp');
subplot(1,3,1),imshow(I); title('原始图像');
subplot(1,3,2),imshow(W); title('水印图像');
%嵌入水印
for p= 1:size/block
for q= 1:size/block
x= (p-1)*block+1; y=(q-1)*block+1;
block_dct= I(x:x+block-1, y:y+block-1);
block_dct= dct2(block_dct);
if 0==W(p,q)
a= -1;
else
a= 1;
end
block_dct = block_dct *(1+a*0.01);
block_dct = idct2(block_dct);
I_w(x:x+block-1, y:y+block-1)=block_dct;
end
end
%显示嵌入水印后的图像
subplot(1,3,3),imshow(I_w); title('嵌入水印后的图像');
这是一段很简单的DCT嵌入水印的程序,我们不需要理解它。
但是你如果直接运行它的时候,会发现最后得到的嵌入水印后的图像显示为一副白屏。
这是为什么呢?我们来查看一下I_w数组,会发现它是一个256×256 double数组。
在matlab里面,我们显示图像可以用imshow函数。
它是通过将灰度值标度为灰度级调色板的索引来显示图像的。
如果I_w是uint8数组的话,直接显示是没问题的。
但是对于double数组,像素值是在[0.0,1.0]范围内的,0.0表示黑色,1.0表示白色。
在显示的时候必须保证double的值在[0.0,1.0]才能正确显示。
所以我们必须用imshow(I_w,[0.0,1.0])来显示它,当然也可以用空矩阵[]来指定数据范围,imshow会自动将数据进行标记。
也就是imshow(I_w,[])
或者我们可以强制把double数组转换成uint8数组来显示也可以
imshow(uint8(I_w))。