遥感影像阴影检测原理详解及其代码实现(基于HSV彩色模型与C1C2C3彩色模型)

本文详细介绍了基于HSV和C1C2C3彩色模型的遥感影像阴影检测原理及OpenCV C++代码实现,探讨了阴影对遥感信息的影响及检测优化方法。

遥感影像阴影检测原理详解及其代码实现(基于HSV彩色模型与C1C2C3彩色模型)

一、阴影检测原理

遥感影像中的阴影是指一些地物(如建筑物、树木和山脉等)遮挡了太阳光线,导致在地物的背面形成了黑暗的成像区域。阴影区域既是遥感影像的信息源,可以反映建筑物高度,估算建筑物的容积率和提取三维信息;又是遥感影像的噪声源,导致地物特征受到影响,进而影响地物信息的提取。
例如,在下图中,可以发现在房屋背后存在阴影区域,我们的目标就是要检测出这块阴影。
阴影图像
(1)基于HSV彩色空间的阴影检测
HSV模型是基于色调(H)、饱和度(S)和明度(V)的六棱锥颜色空间。(如下图所示)H表示色彩信息,即所处的光谱颜色的位置,用角度表示;S表示成所选颜色的纯度和该颜色最大的纯度之间的比率;V表示色彩的明亮程度。
HSV彩色模型
在HSV模型中,阴影区域主要有三个特点:
①具有更大的色调值H;
②具有高饱和度S,因为散射光线主要来自波长更短的蓝紫色光;
③太阳光线被阻挡,导致明度V较低。
根据HSV模型阴影区域的特点,可以将彩色的RGB图像转换为HSV图像
RGB到HSV转换公式
选取阈值 作为阈值初步分割出阴影区域。

(2)基于C1C2C3彩色空间的阴影检测
与HSV模型类似,可以引入C1C2C3彩色模型实现对遥感影像阴影区域检测
RGC转换为C1C2C3
阴影区域中的像素灰度值一般比非阴影区域小,特别是R和G分量较小,但是B分量较大,其原因主要是在以太阳光为光源的成像过程中,环境对蓝色分量的散射较强所致。并且,在阴影区域中,C3分量具有很高的像素值。因此,需要将C3分量和B分量结果,采用双阈值进行阴影检测。只有C3分量高于阈值T1,B分量低于阈值T2,才被认为是阴影区域。
在这里插入图片描述

二、基于OpenCV的C++代码实现

首先,将RGB图像转换为HSV图像和C1C2C3图像,计算出每一个分量。然后,使用迭代法或Otsu算法求出最佳阈值,并进行阈值分割。最后,对图像进行形态学闭运算,优化检测结果,获得精确的阴影区域。

(1)基于HSV彩色空间的阴影检测
基于RGB到HSV彩色空间的公式,计算出H、S、V每一个分量。然后,使用迭代法求出最佳分割阈值。经过多次的迭代运算后,发现最佳阈值T约为0.2。计算出M分量,与T进行比较,划分图像为目标阴影区域或非阴影区域。
HSV检测流程
代码如下:

void Shadow_detection_HSV(Mat img)
{
   
   
	int width = img.cols;
	int height = img.rows;
	Mat dst;
	dst.create(height, width, CV_8UC1);
	cvtColor(img, dst, CV_RGB2HSV);
	unsigned char *p1 = dst.data;
	unsigned char *p = img.data;
	double h, s, v, m
评论 8
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值