matlab主要函数使用方法

matlab主要函数使用方法

ID:1780207

大小:25.00 KB

页数:4页

时间:2017-11-13

matlab主要函数使用方法_第1页
matlab主要函数使用方法_第2页
matlab主要函数使用方法_第3页
matlab主要函数使用方法_第4页
资源描述:

《matlab主要函数使用方法》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、Matlab主要函数使用方法ndims(A)用ndims命令常看矩阵的维数1.matlab中mod的用法简单的说mod(a,b)就是求的是a除以b的余数。比方说mod(100,3)=1,mod(17,6)=5Examplesmod(13,5)ans=3mod([1:5],3)ans=12012mod(magic(3),3)ans=2100211022.关于Matlab中size()的问题size按照下面的形式使用:[m,n]=size(a,x)。一般的,函数的输入参量x不是用,这是当只有一个输出变量时,size返回一个行向量,第一个数为行数,第二个数为列数;如果有两个输出变量

2、,第一个返回量为行数,第二个返回数为列数。当使用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

3、)计算两个矩阵的二维相关系数.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。所以两者不同。小波变换得图像应该用第二种显示,把数据scal

4、e一下。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('水印图像');%嵌入水印forp=1:size/blockf

5、orq=1:size/blockx=(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);if0==W(p,q)a=-1;elsea=1;endblock_dct=block_dct*(1+a*0.01);block_dct=idct2(block_dct);I_w(x:x+block-1,y:y+block-1)=block_dct;endend%显示嵌入水印后的图像subplot(1,3,3),imshow(I_w);title('嵌入水印后

6、的图像');这是一段很简单的DCT嵌入水印的程序,我们不需要理解它。但是你如果直接运行它的时候,会发现最后得到的嵌入水印后的图像显示为一副白屏。这是为什么呢?我们来查看一下I_w数组,会发现它是一个256×256double数组。在matlab里面,我们显示图像可以用imshow函数。它是通过将灰度值标度为灰度级调色板的索引来显示图像的。如果I_w是uint8数组的话,直接显示是没问题的。但是对于double数组,像素值是在[0.0,1.0]范围内的,0.0表示黑色,1.0表示白色。在显示的时候必须保证double的值在[0.0,1.0]才能正确显示。所以我们必须用imsho

7、w(I_w,[0.0,1.0])来显示它,当然也可以用空矩阵[]来指定数据范围,imshow会自动将数据进行标记。也就是imshow(I_w,[])或者我们可以强制把double数组转换成uint8数组来显示也可以imshow(uint8(I_w))

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。