Matlab主要函数使用方法.docVIP

  1. 1、本文档共6页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Matlab主要函数使用方法,matlaberror函数使用,matlab函数使用,matlab函数及使用说明,matlab函数句柄使用,matlabinv函数的使用,matlab函数,matlabfind函数,matlab函数速查手册,matlabsize函数

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(uin

文档评论(0)

docindpp + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档