当前位置: 首页 > news >正文

python学习——对无人机影像有RGB转换到HSV

问题描述

最近需要对无人机影像中绿色植被信息进行提取,查看相关论文,发现用的比较多的就是HSV色彩转换方法,动手实践一下。

解决思路

HSV转换
直方图确定阈值
掩膜提取

解决过程

HSV转换

import os
import numpy as np
from osgeo import gdal
'''
本代码实现将RGB波段的无人机影像转换到HSV色彩空间。
注意无人机影像波段顺序为R,G,B
'''
def RGB2HSV(file):src = gdal.Open(file)col = src.RasterXSizerow = src.RasterYSize_ = 3red = np.array(src.GetRasterBand(1).ReadAsArray().astype(float))green = np.array(src.GetRasterBand(2).ReadAsArray().astype(float))blue = np.array(src.GetRasterBand(3).ReadAsArray().astype(float))arr = np.stack((red, green, blue), axis=2)dst = np.zeros((row, col, 3), dtype=np.float32)for i in range(row):for j in range(col):r, g, b = arr[i, j] / 255.0minn = np.min([r, g, b])maxx = np.max([r, g, b])dst[i, j, 2] = maxx  # Vdelta = maxx - minnh, s = 0, 0if maxx != 0:s = delta / maxxif r == maxx:h = (g - b) / deltaelif g == maxx:h = 2 + (b - r) / deltaelse:h = 4 + (r - g) / deltah *= 60if h < 0:h += 360dst[i, j, 0] = hdst[i, j, 1] = sprint('开始输出')out_name = 'hsv.tif'out_ds = gdal.GetDriverByName('GTiff').Create(out_name, col, row, 3, gdal.GDT_Float32)for i in range(3):# data = out_ds.GetRasterBand(i+1).ReadAsArray()band = out_ds.GetRasterBand(i+1).WriteArray(dst[:,:,i])del bandout_ds.SetProjection(src.GetProjection())out_ds.SetGeoTransform(src.GetGeoTransform())out_ds.FlushCache()return out_dsfile = r'G:\temp\forestVFC\标注影像\ZJM_ZLHF_2308221.dat'# Convert to HSV
dst = RGB2HSV(file)

直方图查看

原结果如下:
在这里插入图片描述
HSV结果如下所示:
在这里插入图片描述
查看HSV结果波段1的直方图
我这里的需求是分为植被和非植被,查看直方图中第一个波谷的折点即为植被和非植被区域阈值,也就是下图中的28.1115
在这里插入图片描述

掩膜提取

在ENVI——bandmath中使用下面这个公式对原始结果进行掩膜即可得到绿色植被区域的影像。

(float(b1) ge 28.0 ) * float(b2)
# b1 为HSV影像的波段1,b2为原始无人机影像

![在这里插入图片描述](https://i-blog.csdnimg.cn/direct/a9f424f422a247aa9acf7b3b615214ae.png

参考:
https://blog.csdn.net/u012294613/article/details/141096007

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。

http://www.lryc.cn/news/439508.html

相关文章:

  • 【南方科技大学】CS315 Computer Security 【Lab2 Buffer Overflow】
  • 持续集成与持续交付CI/CD
  • C++学习笔记之变量作用域
  • 解决跨境电商平台账号无法访问的常见问题
  • P2847 [USACO16DEC] Moocast G
  • 针对国内AIGC市场,国内目前出台了那些法律法规?
  • Windows+Ubuntu双系统下时钟设置
  • 一些写leetcode的笔记
  • shopify主题开发之template模板解析
  • Zookeeper学习
  • FAT32文件系统详细分析 (格式化SD nandSD卡)
  • 通义灵码在Visual Studio上
  • 基于SpringBoot的招生宣传管理系统【附源码】
  • SOT23封装1A电流LDO具有使能功能的 1A、低 IQ、高精度、低压降稳压器系列TLV757P
  • python绘制3d建筑
  • 机器学习实战21-基于XGBoost算法实现糖尿病数据集的分类预测模型及应用
  • ElasticSearch数据类型和分词器
  • 【云原生监控】Prometheus之PushGateway
  • sqlalchemy JSON 字段写入时中文序列化问题
  • C++ 类域+类的对象大小
  • QT开发:深入详解QtCore模块事件处理,一文学懂QT 事件循环与处理机制
  • 小米,B站网络安全岗位笔试题目+答案
  • 微信小程序中巧妙使用 wx:if 和 catchtouchmove 实现弹窗禁止页面滑动功能
  • 唯徳知识产权管理系统 DownloadFileWordTemplate 文件读取漏洞复现
  • 我在高职教STM32——准备HAL库工程模板(2)
  • 数字化转型的实战法则:全面剖析《数字化专业知识体系》中的落地策略与最佳实践
  • 远程桌面内网穿透是什么?有什么作用?
  • 【算法专场】分治(上)
  • 腾讯云软件工程师面试问题收集记录-数据库
  • Sourcetree安装教程及使用