计算无人机俯拍图像的地面采样距离(GSD)矩阵

引言

在无人机遥感、测绘和精细农业等领域,地面采样距离(Ground Sampling Distance,简称 GSD)是一个非常重要的指标。GSD 是指图像中每个像素在地面上实际代表的物理距离,通常以米或厘米为单位。GSD 决定了图像的空间分辨率,直接影响到后续的分析结果,比如分割对象的精度、目标检测的准确性以及面积测量的精度。

在本篇文章中,我们将介绍如何计算无人机俯拍图像的 GSD 矩阵,并探讨其在实际应用中的价值。

背景和应用场景

1.1 什么是 GSD?

GSD 是衡量图像空间分辨率的核心指标。对于一个无人机拍摄的影像,GSD 通常由以下因素决定:

  • 图像传感器大小:传感器越大,单个像素接收到的地面信息越多。
  • 飞行高度:飞行高度越高,每个像素对应的地面范围越大,但空间分辨率相对降低。
  • 相机焦距:焦距越长,地面范围缩小,从而提高分辨率。
  • 图像尺寸:图像的分辨率(像素宽度与高度)也会影响每个像素所覆盖的地面范围。

1.2 GSD 的实际意义

GSD 在许多应用场景中都有重要意义:

  • 目标检测与分割:通过 GSD,可以将像素级的分割结果转化为实际的物理尺寸。例如,在精细农业中,通过分割作物的区域并结合 GSD,可以精确计算每块地的作物面积。
  • 精确测量:在无人机航拍的测绘中,GSD 决定了测量地物(如建筑物、道路、土地分块等)大小的精度。
  • 多尺度分析:结合 GSD,可以实现不同尺度图像的对比分析,便于对某一区域的精细解读。

GSD 矩阵的计算

import numpy as np

def calculate_gsd_matrix(image_height: int, image_width: int, sensor_height: float, sensor_width: float, focal_length: float,
                         flying_height: float, pitch_angle: float) -> np.ndarray:
    """
    计算无人机拍摄的图像每个像素的地面采样距离(GSD)矩阵。
    
    Args:
        image_height: 图像高度(像素)。
        image_width: 图像宽度(像素)。
        sensor_height: 相机传感器高度(毫米)。
        sensor_width: 相机传感器宽度(毫米)。
        focal_length: 相机焦距(毫米)。
        flying_height: 无人机飞行高度(米)。
        pitch_angle: 相机俯仰角(度)。

    Returns:
        代表每个像素 GSD 的 2D numpy 数组。
    """
    # 预先计算的常量
    pixel_size_height = sensor_height / image_height
    pixel_size_width = sensor_width / image_width
    horizontal_gsd_height = (flying_height * pixel_size_height) / focal_length
    horizontal_gsd_width = (flying_height * pixel_size_width) / focal_length

    # 计算垂直视场角(VFOV)和水平视场角(HFOV)
    vfov = 2 * np.arctan(sensor_height / (2 * focal_length))
    hfov = 2 * np.arctan(sensor_width / (2 * focal_length))

    # 计算每个像素的俯仰角和翻滚角
    pixel_angles_v = ((np.arange(image_height) - image_height / 2) / image_height) * np.degrees(vfov) + pitch_angle
    pixel_angles_h = ((np.arange(image_width) - image_width / 2) / image_width) * np.degrees(hfov)

    # 应用无效角度的掩码
    invalid_mask_v = (pixel_angles_v > 90) | (pixel_angles_v < -90)
    invalid_mask_h = (pixel_angles_h > 90) | (pixel_angles_h < -90)

    # 计算垂直和水平 GSD
    row_gsd = horizontal_gsd_height / np.cos(np.radians(pixel_angles_v))
    col_gsd = horizontal_gsd_width / np.cos(np.radians(pixel_angles_h))

    # 设置无效 GSD 为 nan
    row_gsd[invalid_mask_v] = np.nan
    col_gsd[invalid_mask_h] = np.nan

    # 结合垂直和水平 GSD
    gsd_matrix = np.outer(row_gsd, np.ones(image_width))

    return gsd_matrix

我们可以利用上述函数计算 GSD 矩阵:

# 示例参数
image_height = 3000
image_width = 4000
sensor_height = 8.8  # mm
sensor_width = 13.2  # mm
focal_length = 8.0  # mm
flying_height = 120.0  # m
pitch_angle = 0.0  # degrees

# 计算 GSD 矩阵
gsd_matrix = calculate_gsd_matrix(image_height, image_width, sensor_height, sensor_width,
                                  focal_length, flying_height, pitch_angle)

print("GSD 矩阵计算完成,矩阵尺寸为:", gsd_matrix.shape)

可视化的GSD矩阵如下:
GSD矩阵,为方便理解进行了分段上色

GSD 矩阵的实际应用

3.1 面积测量

在遥感分析中,常常需要计算某个区域的面积。例如,结合分割算法将作物区域提取出来后,可以利用 GSD 矩阵将像素面积映射为实际物理面积。

3.2 精确定位与测绘

结合 GSD 矩阵,可以将像素坐标直接映射为实际地理坐标。这在无人机测绘中非常有用,可以高效生成高精度的地理信息图。

总结

本文介绍了如何计算无人机俯拍图像的 GSD 矩阵,并展示了其在面积测量等实际应用中的价值。掌握 GSD 的计算与应用方法,可以帮助我们更好地处理无人机影像数据,提升分析结果的精度与可信度。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/938789.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

图变换器的再思考:谱注意力网络

人工智能咨询培训老师叶梓 转载标明出处 图神经网络&#xff08;GNNs&#xff09;的传统策略是通过稀疏的消息传递过程直接编码图结构。然而&#xff0c;这种方法存在固有的局限性&#xff0c;例如过度平滑和过度压缩问题&#xff0c;这些限制了模型的性能和表达能力。为了克服…

构建全面的生产监控体系:从基础设施到业务服务

在现代 IT 系统中&#xff0c;监控体系是确保高可用性、高性能和稳定性的核心工具。一个完善的监控体系能够及时发现系统问题、分析问题根源并快速采取应对措施&#xff0c;避免故障进一步扩散。本文将从基础设施层、中间件层、容器与编排层、应用与服务层逐步展开&#xff0c;…

Rk3588 FFmpeg 拉流 RTSP, 硬解码转RGB

RK3588 ,基于FFmpeg, 拉取RTSP,使用 h264_rkmpp 实现硬解码. ⚡️ 传送 ➡️ RK3588, FFmpeg 拉流 RTSP, mpp 硬解码转RGBRk3588 FFmpeg 拉流 RTSP, 硬解码转RGBUbuntu x64 架构, 交叉编译aarch64 FFmpeg mppRK3588 , mpp硬编码rgb, 保存MP4视频文件.</

进程通信方式---共享映射区(无血缘关系用的)

5.共享映射区&#xff08;无血缘关系用的&#xff09; 文章目录 5.共享映射区&#xff08;无血缘关系用的&#xff09;1.概述2.mmap&&munmap函数3.mmap注意事项4.mmap实现进程通信父子进程练习 无血缘关系 5.mmap匿名映射区 1.概述 原理&#xff1a;共享映射区是将文件…

【Redis篇】Set和Zset 有序集合基本使用

目录 Set 基本命令 sadd SMEMBERS SISMEMBER SCARD 返回值&#xff1a; SPOP SMOVE SREM 集合间操作 交集&#xff1a; 并集&#xff1a; 差集&#xff1a; ​编辑 内部编码 使用场景&#xff1a; Zset 有序集合 Zset基本命令 ZADD ZCARD ZCOUNT ZRANGE …

SAP自定义权限对象

一、创建域和数据元素 SE11 二、创建权限字段 SU20 关联数据元素ZAPP 三、创建权限对象 SU21 关联权限字段ZAPP 四、新建程序&#xff0c;加入权限对象 SE38 在程序中增加以下块 AUTHORITY-CHECK OBJECT Z_BC_APP ID ZAPP FIELD 01. IF sy-subrc EQ 0. ENDIF. 五、…

linux0.11源码分析第二弹——setup.s内容

&#x1f680; 前言 继上篇博客分享了boot文件的内容后&#xff0c;本篇博客进而来到第二个文件&#xff1a; setup.s &#xff0c;对应了《linux源码趣读》的第5~8回。这部分的功能主要就是做了 三件事 &#xff0c;第一件事是做代码搬运和临时变量存放&#xff0c;第二件事是…

Halcon中histo_2dim(Operator)算子原理及应用详解

在Halcon中&#xff0c;histo_2dim算子是一个用于计算双通道灰度值图像的直方图的工具。以下是对该算子的原理及应用的详细解释&#xff1a; 一、原理 histo_2dim算子的函数原型为&#xff1a;histo_2dim(Regions, ImageCol, ImageRow : Histo2Dim : : )。 输入参数&#xff…

(vue)el-table在表头添加筛选功能

(vue)el-table在表头添加筛选功能 筛选前&#xff1a; 选择条件&#xff1a; 筛选后&#xff1a; 返回数据格式: 代码: <el-tableref"filterTable":data"projectData.list"height"540":header-cell-style"{border-bottom: 1px soli…

使用 Marp 将 Markdown 导出为 PPT 后不可编辑的原因说明及解决方案

Marp 是一个流行的 Markdown 演示文稿工具&#xff0c;能够将 Markdown 文件转换为 PPTX 格式。然而&#xff0c;用户在使用 Marp 导出 PPT 时&#xff0c;可能会遇到以下问题&#xff1a; 导出 PPT 不可直接编辑的原因 根据 Marp GitHub 讨论&#xff0c;Marp 导出的 PPTX 文…

UE5安装Fab插件

今天才知道原来Fab也有类似Quixel Bridge的插件&#xff0c;于是立马就安装上了&#xff0c;这里分享一下安装方法 在Epic客户端 - 库 - Fab Library 搜索 Fab 即可安装Fab插件 然后重启引擎&#xff0c;在插件面板勾选即可 然后在窗口这就有了 引擎左下角也会多出一个Fab图标…

Gin- Cookie\Session相关

Cookie&#xff0c;Session是什么&#xff1f; Cookie直译小饼干&#xff0c;是一些数据信息&#xff0c;类似于小型文本文件&#xff0c;存储在浏览器上。Cookie是进行第一次登录之后&#xff0c;由服务器创建后返回给浏览器的。之后&#xff0c;每当浏览器再次向同一服务器发…

使用Python打造高效的PDF文件管理应用(合并以及分割)

在日常工作和学习中&#xff0c;我们经常需要处理大量PDF文件。手动合并、分割PDF不仅耗时&#xff0c;还容易出错。今天&#xff0c;我们将使用Python的wxPython和PyMuPDF库&#xff0c;开发一个强大且易用的PDF文件管理工具。 C:\pythoncode\new\mergeAndsplitPdf.py 所有代…

深度学习中自适应学习率调度器

传统观点认为&#xff0c;太大的学习率不利于优化深度神经网络&#xff0c;而相比固定的学习率而言&#xff0c;变化的学习率更能提供快速的收敛。基于此&#xff0c;本文作者基于理论基础提出了一个计算深度神经网络学习率的新方法。实验结果证明了该方法的有效性。 训练神经…

文献研读|基于像素语义层面图像重建的AI生成图像检测

前言&#xff1a;本篇文章主要对基于重建的AI生成图像检测的四篇相关工作进行介绍&#xff0c;分别为基于像素层面重建的检测方法 DIRE 和 Aeroblade&#xff0c;以及基于语义层面重建的检测方法 SimGIR 和 Zerofake&#xff1b;并对相应方法进行比较。 相关文章&#xff1a;论…

ElasticSearch06-分片节点分配

零、文章目录 ElasticSearch06-分片节点分配 1、单节点多分片多副本 &#xff08;1&#xff09;启动一个空节点 节点的配置如下 cluster.name: mycluster node.name: node-01 node.master: true node.data: true network.host: 127.0.0.1 http.port: 9201 transport.tcp.p…

信息学奥赛一本通 1438:灯泡 | 洛谷 P5931 [清华集训2015] 灯泡

【题目链接】 ybt 1438&#xff1a;灯泡 洛谷 P5931 [清华集训2015] 灯泡 【题目考点】 1. 三分 求函数极值 2. 相似三角形 3. 对钩函数 【解题思路】 首先考虑影子还没有到达对面墙壁的情况 记BM长度为x&#xff0c;影子为AM&#xff0c;长度为L。三角形ABC相似于三角…

揭开 Choerodon UI 拖拽功能的神秘面纱

01 引言 系统的交互方式主要由点击、选择等组成。为了提升 HZERO 系统的用户体验、减少部分操作步骤&#xff0c;组件库集成了卓越的拖拽功能&#xff0c;让用户可以更高效流畅的操作系统。 例如&#xff1a;表格支持多行拖拽排序、跨表数据调整、个性化调整列顺序&#xff1…

【物联网技术与应用】实验4:继电器实验

实验4 继电器实验 【实验介绍】 继电器是一种用于响应施加的输入信号而在两个或多个点或设备之间提供连接的设备。换句话说&#xff0c;继电器提供了控制器和设备之间的隔离&#xff0c;因为设备可以在AC和DC上工作。但是&#xff0c;他们从微控制器接收信号&#xff0c;因此…

fpga系列 HDL:Quartus II 时序约束 静态时序分析 (STA) test.out.sdc的文件结构

test.out.sdc的文件结构 ## Generated SDC file "test.out.sdc"## Copyright (C) 1991-2013 Altera Corporation ## Your use of Altera Corporations design tools, logic functions ## and other software and tools, and its AMPP partner logic ## functions,…