【个人理解】关于矩阵【层,行,列】和图像【高,宽,通道数】的理解

这是我之前一直混淆没弄明白的一个问题
就是诶图像的通道数和矩阵的层数为什么不对应啊或者一张图像表示成矩阵的时候,为什么shape不是我们理解的[层,行,列]的形式?
下午看了不少大佬写的文章
总算是搞清楚了(应该吧哈哈哈哈)

我们先理解一下三维矩阵。

吐司大家应该都吃过吧?
通常定义的三维矩阵,一层就是一片吐司,一个吐司就是一个二维矩阵,有n行m列,这里假设有c片吐司,那这个三维矩阵的shape就是[c, n, m]。
这下大家脑海里应该都有一点想象了吧?

然后就是真实的三维矩阵,写在代码里,在数据上,应该是怎么表示的?
具体例子:看例子点我
参考链接:https://blog.csdn.net/weixin_38267508/article/details/83539395

然后,有一点很重要的是,不同的工具,对于数据结构的定义可能是不一样的。Python中的numpy的数据结构就是这样的[h,w,c],如果你用caffe的话默认[n,c,w,h],这里n是batch_size,剩下就是通道,宽,高。
参考链接:https://www.zhihu.com/question/318026075

然后再来说说图像
我们获取到一张RGB图像以后,输出图像的size,一般都是[h, w, 3]。
RGB图像表示的是三通道图像,这个时候通道数,放在了最后。
我们都知道,一个像素点的值,一般都是一个一维数组[R, G, B]来表示的。
可能有些朋友会想:图像表示成矩阵以后,去看这个矩阵,这个矩阵明明是3列的,为什么说是3层?这个跟我们认知里的三维矩阵应该是[层数,行,列]不一样啊?
有这个疑问的朋友,这时候已经把这两种不同的表示方式混淆起来了。
记住一点,[ 层,行,列 ]和[ 高,宽,通道数 ]的定义都存在,尽量只从一个角度去看这个三维矩阵。
你处理的是图像,那就只需要记住[ 高,宽,通道数 ];你定义了一个[c, n, m]的矩阵,那就只需要记住[ 层,行,列 ]。
具体应该是什么顺序,要看你使用的是什么库,人家是怎么定义的这个数据结构了。

这篇主要是写给我自己看的。提醒自己不要混淆了。
如果有大佬看了觉得我理解的我写的有问题,请一定要告诉我!我好及时改正!

参考链接:三维矩阵Shape的理解
参考链接:矩阵进行concat()的理解
参考链接:numpy中np.shape的理解
参考链接:Python中三维变二维矩阵(用reshape)后各个维度的关系
参考链接:为什么python读取一张图片形成的矩阵维度是(高,宽,通道数),而不是(二维数组个数,行,列)?

  • 7
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 暗通道先验是一种通过观察图像的暗通道来估计图像去雾过程中的大气光照分布的方法。在MATLAB中实现这个方法,可以按照以下步骤进: 1. 加载图像:使用`imread`函加载待处理的图像。 2. 计算暗通道:将图像转换为RGB格式,然后对每个像素的RGB通道计算最小值,得到暗通道图像。可以使用`min`函实现。 3. 估计大气光照分布:在暗通道图像中,选择亮度前0.1%的像素点,这些像素点通常对应着图像中的天空或亮部区域。根据这些像素点的RGB值的最大值,估计大气光照的RGB分量。可以使用MATLAB的`sort`函排序和选择。 4. 估计透射率:计算每个像素点的透射率,可以使用以下公式: t(x)=1-omega*min(J(x)/A_r,J(x)/A_g,J(x)/A_b) 其中,J(x)为原图像的RGB值,A_r、A_g、A_b为估计得到的大气光照的RGB分量,omega为常。需要注意的是,分母中每个通道的值都要除以对应分量的大气光照。 5. 进去雾:根据透射率和大气光照,可以根据以下公式对原图像去雾处理: J(x)=(J(x)-A)/max(t(x),t0)+A 其中,t0为一个小的正,用于防止除零错误。 以上是MATLAB中实现暗通道先验去雾方法的基本步骤。需要注意的是,不同的图像可能需要调整参的值来获得更好的去雾效果。 ### 回答2: 图像去雾是图像处理的一项重要任务,暗通道先验是一种常用的算法之一。 暗通道先验的理论基础是空气光的强度在大部分区域是不变的,这是由于空气中的微小颗粒(雾霾)对光的散射会降低图像的对比度,使得图像整体变暗。因此,图像中具有较低强度的像素代表了雾霾中的散射光,这一区域被称为暗通道。 暗通道先验的主要思想是通过分析图像的暗通道来估计雾霾的浓度,并进一步去除雾霾。在matlab中,实现暗通道先验可以按照以下步骤进: 1.读取待处理的雾霾图像,并将其转换为双精度灰度图像。 2.计算每个像素点的暗通道。这可以通过求取每个像素点周围一个小区域内像素的最小值来实现。 3.估计图像中的全局大气光。这可以通过选择暗通道中灰度值最的像素点来获得。 4.根据全局大气光和雾霾浓度来去除雾霾。通过计算无雾图像中每个像素点的强度值来更新原始图像。 使用matlab实现这些步骤通常需要利用一些图像处理工具箱中提供的函,如imread、rgb2gray、imfilter等。此外,还需要对参适当调整,包括雾霾浓度估计的取值范围以及去雾算法中的参。 总之,通过暗通道先验的处理,我们可以在一定程度上去除图像中的雾霾,提图像的清晰度和对比度。然而,暗通道先验也存在一些局限性,如对夜晚或阴暗场景的适应性较差。因此,在具体应用中,可能需要根据实际情况选择其他合适的去雾算法。 ### 回答3: MATLAB图像去雾算法中的暗通道先验是一种常用的先验知识,用于估计图像中每个像素的全局大气光强度和图像的透射率。 暗通道先验的代码实现如下: ```matlab function dark_channel = dark_channel_prior(image, patch_size) [height, width, ~] = size(image); dark_channel = zeros(height, width); % 计算每个像素的暗通道值 for i = 1:height for j = 1:width patch = image(max(i-patch_size/2,1):min(i+patch_size/2,height), max(j-patch_size/2,1):min(j+patch_size/2,width), :); dark_channel(i, j) = min(patch(:)); end end end ``` 上述代码中,`image`是输入的彩色图像,`patch_size`是局部区域的大小,用于计算暗通道。暗通道是每个像素点在局部区域内RGB三个通道最小值的最小值。 代码首先获取输入图像度和度,然后创建与输入图像相同大小的全零矩阵"dark_channel",用于存储每个像素的暗通道值。 随后,双重循环遍历整个图像,对每个像素点计算对应的局部区域,并选择RGB三个通道中的最小值,将最小值赋值给对应像素点的"dark_channel"。 最终返回"dark_channel"作为输出。 使用暗通道先验的理解: 暗通道先验认为,自然场景中的绝大多局部区域内至少存在一个颜色很暗或者接近于全黑的像素点。该先验基于全球大气的照明模型,即在存在雾霾环境下,图像中的每个像素值可以表示为原始场景反射强度与透射率以及大气光的乘积。 通过计算图像的暗通道,我们可以根据该先验选择合适的全局大气光强度和估计每个像素的透射率。这样就可以通过估计透射率和大气光来恢复原始场景的反射强度,从而有效去除雾霾效果。暗通道先验是图像去雾方法中的一个重要先验知识,通过合理利用暗通道先验可以更加准确地去除图像中的雾霾效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值