matlab中imshow(a,[])用法及其内部计算公式

在matlab中,我们常使用imshow()函数来显示图像,而此时的图像矩阵可能经过了某种运算。在matlab中,为了保证精度,经过了运算的图像矩阵A其数据类型会从unit8型变成double型。如果直接运行imshow(A),我们会发现显示的是一个白色的图像。这是因为imshow()显示图像时对double型是认为在0-1范围内,即大于1时都是显示为白色,而imshow显示uint8型时是0~255范围。而经过运算的范围在0-255之间的double型数据就被不正常得显示为白色图像了。

到两个解决方法:

 imshow(I/256); ———–将图像矩阵转化到0-1之间 
 imshow(I,[]);       ———–自动调整数据的范围以便于显示 

imshow(A,[ ])
inshow(A,[ ])相当于imshow(A,[min(A),max(A)])
其内部计算公式为:

b=(a-min(a(:)))./(max(a(:))-min(a(:)))*255;%%a为double型
imshow(uint8(b));

这样就可以将指定范围的灰度值变换到0-255区间显示。imshow(A,[LOW,HIGH]) 也是使用这种算法进行拉伸显示的。

  • 24
    点赞
  • 94
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
### 回答1: 在MATLAB计算图像的对比度是通过计算图像的灰度级范围来实现的。下面是一种基本的方法: 首先,读取图像并将其转换为灰度图像: ```matlab img = imread('image.jpg'); gray_img = rgb2gray(img); ``` 接下来,我们可以计算图像的最小和最大灰度级: ```matlab min_gray_level = min(min(gray_img)); max_gray_level = max(max(gray_img)); ``` 然后,可以使用以下公式计算图像的对比度: ```matlab contrast = (max_gray_level - min_gray_level) / (max_gray_level + min_gray_level); ``` 这样,对比度的值将介于0和1之间,其0表示图像灰度级均匀,而1表示图像具有最大的对比度。 最后,可以使用imshow函数显示图像和对比度值: ```matlab imshow(gray_img); title(['Contrast: ' num2str(contrast)]); ``` 使用以上代码,您可以计算图像的对比度并显示其结果。请注意,为了获取更准确的结果,您可以对图像进行预处理,例如进行直方图均衡化或对比度拉伸。 ### 回答2: 在Matlab计算图片的对比度可以通过计算图像的灰度直方图来实现。首先,使用imread函数读取图像,将其转换为灰度图像。然后,使用imhist函数计算灰度图像的灰度直方图。接下来,可以使用直方图的统计量来计算对比度。 对比度可以通过计算直方图的标准差来衡量。标准差描述了直方图分布的离散程度,反映了图像像素值的变化范围。标准差越大,对比度越高。使用std函数即可计算直方图的标准差。 以下是一个使用Matlab计算图像对比度的示例代码: ```matlab % 读取图像并转化为灰度图像 image = imread('image.jpg'); gray_image = rgb2gray(image); % 计算灰度直方图 histogram = imhist(gray_image); % 计算对比度 contrast = std(histogram); % 显示图像和对比度值 imshow(gray_image); title(['Contrast: ', num2str(contrast)]); ``` 上述代码的'image.jpg'可以替换为需要计算对比度的图像文件路径。运行代码后,会显示灰度图像,并在图像标题显示对比度值。 通过计算图像的灰度直方图并计算标准差,我们可以在Matlab轻松计算图像的对比度。 ### 回答3: 在MATLAB计算图片对比度可以使用灰度级的标准差来衡量。以下是一种计算图片对比度的方法: 1. 读取图片:使用imread函数将指定的图片读取为MATLAB的矩阵形式。 2. 转为灰度图:使用rgb2gray函数将彩色图片转为灰度图像。转换后的灰度图像也是一个矩阵。 3. 计算平均灰度值:使用mean函数计算灰度图像的平均灰度值。这个值代表了整个图像的平均亮度。 4. 计算每个像素与平均灰度值的差:将灰度图像矩阵的每个像素值减去平均灰度值,得到差值矩阵。 5. 计算差值矩阵的标准差:使用std函数计算差值矩阵的标准差。标准差越大,表示图像的对比度越高。 下面是一个示例代码: ```matlab % 读取图片 img = imread('example.jpg'); % 转为灰度图 grayImg = rgb2gray(img); % 计算平均灰度值 meanGray = mean(grayImg(:)); % 计算差值矩阵 diffMatrix = double(grayImg) - meanGray; % 计算标准差 contrast = std(diffMatrix(:)); % 显示结果 disp(['图片对比度为:', num2str(contrast)]); ``` 以上是一种简单的计算图片对比度的方法。根据具体的需求,也可以使用其他方法来计算图片的对比度,比如直方图均衡化等。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值