__2018-01-17 如一模式识别研究

如一模式识别研究

matlab>>Matlab主要函数使用方法!

转自:http://blog.csdn.net/zmqhbd/article/details/1923011

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))

==========================================================================================

评论留言区

:
  

作者: 游客 ; *
评论内容: *
带*号为必填项目

如一模式识别更新提示

matlab在图像处理方面的应用有更新

如一模式识别 友情链接

关于本站作者     chinaw3c     mozilla