稳健地对时间序列光学卫星图像进行配准教程

news2025/1/23 4:47:13

一、引言

        几何误差会导致连续卫星图像采集之间的错位,进而影响土地监测和变化检测分析。在这篇博客文章中,我们研究了如何稳健地对时间序列光学卫星图像进行配准,以减少这种错位的影响。

        在本篇博客的末尾,给出用Python配准大区域的高分辨率遥感影像资源,供大家参考学习。

        图1  哨兵-2斯洛文尼亚东部一条道路的L1C延时。时间段为2021年3月至2021年8月。包含经Sentinel Hub 2022修改的哥白尼Sentinel-2数据。 

二、配准探索

        在某些情况下,错位可能会影响对时间变化的分析。正如您在上面的动画中看到的那样,对于大小与圆形误差相当的对象尤其如此。与较大的物体(如森林或较大的农业地块)相比,道路、桥梁和建筑物的分析在一定程度上更受地理位置误差的影响。这些误差是定位和正交校正过程中固有的,并且可以校正到一定程度。它们在能够进行陆地监测的高时间分辨率数据收集中更为明显,如Sentinel-2、Landsat和PlanetScope。

        我们已经构建了相当多的机器学习(ML)产品,用于土地和区域监测、变化检测和卫星图像的时间分析。我们已经注意到,这些几何误差是我们结果中噪声的一个重要来源。例如,我们的场描绘算法对预测进行逐像素的时间合并,以得出边界所在位置的更稳健的估计。几何误差引入了影响最终结果的虚构边界变化,如下所示。

图2 箭头像素是否为场边界像素的概率变化。概率的波动是由于地理位置误差造成的。 

        因此,我们着手开发一个工作流程来补偿几何误差。我们希望这个过程对数据收集是不可知的,在很大的时间间隔内工作,并对土地覆盖的巨大变化保持稳健。我们确定基于图像的配准是实现这一切的最佳方式。

        协同配准的目的是估计两个图像之间发生的运动,这里称为模板和输入图像。 估计的运动可用于将输入图像与模板对齐。 通过对所有时间帧重复这个过程,我们获得了一个应该与模板图像对齐的时间堆栈。 简而言之,基于图像的配准是一种优化算法,根据目标函数,输入图像使用参数化运动模型进行迭代变换,直到两幅图像看起来相同。 运动模型的示例包括平移(其中输入图像只能在 x 和 y 方向上移动)到仿射变换(其中还对旋转、缩放和倾斜进行建模)。 此外,还可以对非刚性变形进行建模,从而增加优化的自由度和复杂性。 至于目标函数,最常见的是基于均方差、互相关或互信息,具体取决于共同配准的数据集合。

        我们进行了许多实验并测试了不同的算法和参数,我们探索的内容包括:

  • 应使用哪个模板图像,例如 一个随机的时间框架,时间框架的平均值;
  • 哪个波段或波段组合携带最佳信息以在较大的时间间隔内配准图像;
  • 哪种运动模型在简单性、收敛速度和准确性之间给出了最佳权衡;
  • 没有真实信息的情况下,应该跟踪哪些指标来评估算法的性能;
  • 哪个目标函数更适合光学卫星图像。

        我们针对 Sentinel-2 和 PlanetScope 时间序列独立进行了实验,我们发现相同的工作流程和参数组合对两种数据收集均显示出最佳结果。 为了评估性能,我们研究了已配准序列相对于未配准模板图像的图像相似性(即均方误差和结构相似性指数)的改进。 我们还查看了估计循环移位的分布和算法的执行时间。 此外,当我们专注于场描绘时,我们跟踪了像素成为已配准和未配准序列边界的概率的变化。 假设已配准的序列将显示较少的概率变化。

        我们考虑了斯洛文尼亚东部的一个兴趣区 (AOI),那里有大量的小型农业地块。

        发现较好的参数组合如下:

  • 使用平均时间图像作为模板图像。 这种选择可能会造成混淆,尤其是因为在很长的时间间隔内,平均图像的真实特征都被剥离了。 然而,平均图像代表了对真实位置的最佳估计,尽管有噪声,并且与所有帧有一定程度的相似性;
  • 使用平均 RGB 通道的梯度。 联合配准算法使用单个波段进行优化,因此我们研究了哪个波段单独或它们的组合会产生稳健的结果。 对通过平均 R、G 和 B 波段创建的强度图像进行了测试,其性能优于单独考虑的任何单个波段。 此外,我们使用值的梯度进行测试,以减少不同采集条件(如光照和对比度)的影响。 梯度的使用提高了性能,因为它也将配准集中在对齐感兴趣的特征,如边缘和轮廓;
  • 使用仅平移运动模型。 我们已经看到,添加旋转或缩放会减慢优化速度,而不会带来跟踪指标的额外改进。 当然,可以在已注册的堆栈中找到残留的非刚性未对准。 请注意,最合适的模型的选择可能取决于共同注册的场景的大小;
  • 在使用不同的算法和目标函数测试了许多实现之后,我们决定使用 OpenCV 库中的“findTransformECC”方法,因为它允许调整许多参数并使用定义有效和无效像素的掩码。 该方法使用增强互相关 (ECC) 目标函数。

        让我们来看看一些结果! 这是与上面相同的场景,具有共同配准的时间序列。 你现在可以体会到,小桥小路不再四处飘荡。

图 3. 图 1 中所示的 Sentinel-2 L1C 的时间序列配准结果。已校正桥梁、道路和房屋等较小特征周围可见的波动。 包含使用 Sentinel Hub 2022 修改的 Copernicus Sentinel-2 数据。 

        查看 Sentinel-2 和 PlanetScope 的配准结果,您会发现平移位移已正确恢复,并且帧之间剩余的未对齐主要显示非刚性(局部)组件。 如果我们查看估计,我们会注意到分布并不是完全偶然的,即值似乎不是从随机正态分布中提取的。 请记住,我们不是在查看循环误差的真实分布,而是通过配准算法估计的分布,它引入了自己的偏差。 然而,这些值分布在 (0, 0) 附近,这证明使用平均图像作为真实位置的噪声估计是合理的。

图 4. Sentinel-2(左)和 PlanetScope(右)的估计像素偏移。 图中看到的相关性可能是由于用于对图块进行地理定位的算法和我们自己的基于图像的配准算法的偏差。 

         查看 Sentinel-2 估计偏移的范数分布,即循环误差的估计值,我们可以看到它大致类似于数据质量报告中报告的值。我们还重复了 2022 年相同 AOI 的配准过程,看看我们是否可以观察到由于改进的定位算法,估计的圆移明显减少。 结果显示在下图 5中,我们确实看到与未精炼产品相比,估计循环误差的分布更接近 0。

         图 5. PlanetScope(左)和 Sentinel-2(右)属于农田的像素概率可变性降低的示例。此处显示的值是未配准概率值的绝对差值之和 (x 轴)和共同注册的(y 轴)堆栈。

三、Python配准大区域的高分辨率遥感影像资源

        我们参照上述研究成果,基于GDAL库与OpenCV库,针对大覆盖影像(比如高分二号融合产品)可以分块实现同名点提取,对整幅影像进行配准。下图为配准前后的效果。由于整景影像过大,资源提供的实验数据为裁剪的一部分,供大家学习:)

资源地址如下:

https://download.csdn.net/download/u010329292/87844863

(1)配准前两幅高分二影像(分辨率为0.8米)

图6 前一时相影像

图7 第二时相影像 

图8 通过卷帘功能可以看到配准前的误差,约80像素左右 

 (2)配准后结果

 图9 通过卷帘功能可以看到配准后的误差,约2-3像素左右 

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【TES710D-EXT】基于复旦微的FMQL10S400全国产化ARM核心模块之扩展板

板卡概述 TES710D-EXT是专门针对我司TES710D(基于复旦微FMQL10S400的全国产化ARM核心板)的测试扩展板。 FMQL10S400是复旦微电子研制的全可编程融合芯片,在单芯片内集成了具有丰富特点的四核处理器(PS)和可编程逻辑&am…

B/S架构与C/S架构的区别

B/S与C/S区别: 1、c/s架构主要应用于局域网内,而b/s架构主要应用于广域网中; 2、c/s架构一般面向相对固定的用户群,对信息安全的控制能力很强,而b/s架构对安全的控制能力相对弱; 3、B/S架构维护升级比较简单…

考研算法复试刷题第20天:Dijkstra求最短路 【有向图的最短路径问题】

Dijkstra求最短路 我们先来说说这道算法的过程: 和上道题不同的是我们这次是求一个有向图到最终节点的最短距离,所以其策略也有所不同。我们先手动模拟一下过程吧假如有4个点,有他们之间有五条边,那么我们如何来求其1到4的最短路…

【Daily Share】觉得浏览器low?手写一个浏览器扩展程序,让自己的浏览器变得与众不同!!!!

浏览器扩展 概念 扩展为浏览器添加了特性与功能。它通过我们所熟悉的 Web 技术-HTML,CSS 还有 JavaScript 来创建。扩展可以利用与 JavaScript 相同的网页 API,但是扩展也可以访问它自己专有的 JavaScript API。这意味着,和在网页里编码相比…

音视频基础知识

视频基础知识 分辨率 分辨率又称为解析度,分辨率越高,像素越多,图像越清晰。 视频分辨率:又称为图像分辨率,由视频的宽高组成,表示形式宽x高,常见的视频分辨率有480P、720P、1080P、2K(2048x…

动态规划-书籍复印

动态规划-书籍复印 1 描述2 样例2.1 样例 1:2.2 样例 2: 3 解题方法3.1 算法解题思路3.2 算法代码实现 该题是lintcode上的算法题,该题的解题思路是依据九章侯老师提供的解题思路去处理的: https://www.lintcode.com/problem/437/description 1 描述 给…

ACL2023 | 黑盒大模型如何微调?清华Decoder Tuning方法提升大模型few-shot场景效果

一、概述 title:Decoder Tuning: Efficient Language Understanding as Decoding 论文地址:https://arxiv.org/abs/2212.08408 代码:GitHub - thunlp/DecT 二、Motivation 现在有很多模型只提供API,没法直接训练,…

关键字 package、import的使用

一、package 关键字的使用 为了更好的实现项目中类型的管理,提供了包的概念使用package声明类或接口所属的包,声明在源文件的首行包 术语标识符,遵循标识符的命名规则、规范(xxxyyyzzz)、“见名知意”每 “ . ”一次&…

自动化测试selenium环境搭建

自动化测试工具selenium搭建 1. 自动化和selenium基本概念 1) 什么是自动化?为什么要做自动化? 自动化测试能够代替一部分的手工测试,自动化测试能够提高测试的效率。随着项目功能的增加,版本越来越多,版本的回归测试的压力也…

DEI脉冲发生器维修DEI脉冲电源维修PVX-4130

DEI电源维修型号包括:PVX-4130,PVX-4140,PVX-4150,PVX-4120,PVX-5500等型号均可维修。 美国DEI脉冲发生器维修PULSE Generator高压电源维修 DEI脉冲发生器产生高压波形至3500V。 针对高阻抗进行了优化电容性负载,很适合驱动静电引气格栅和偏转板飞行时间质谱仪中粒…

FP独立站不同支付方式的注意事项是什么?

今天,给FP独立站的老板们介绍2个独立站支付方式,以及这些不同的支付方式分别有什么注意事项。 一、PayPal支付 大部分建站平台都支持PayPal支付通道。如果是做美国市场的独立站卖家,PayPal每笔固定收取0.3美金不同比例的手续费,不…

IOS复杂震动AHAP文件编辑指南

简介 目前部分游戏会在播放一些特定的音乐音效时,令设备产生贴合音效的复杂震动,给玩家一个更好的游戏体验。这种复杂震动就是通过苹果的CoreHaptics库实现的。 下面是关于CoreHaptics的官方文档 ​​​​​​​Core Haptics | Apple Developer Docum…

DISC行为模型

DISC行为模型 这是一种研究人行为倾向性的理论,由哈佛大学教授、临床心理学家威廉马斯顿博士提出。它可以用来预测一个人的行为倾向性,让使用者更好地了解自己和影响他人! 模型介绍 马斯顿博士发现,行事风格类似的人会展现出类似…

充电桩检测设备厂家TK4860C交流充电桩检定装置

TK4860系列是专门针对现有交流充电桩现场检测过程中接线复杂、负载笨重、现场检测效率低等问题而研制的一系列高效检测仪器,旨在更好的开展充电桩的强制检定工作。 充电桩检测设备是一款在交流充电桩充电过程中实时检测充电电量的标准仪器,仪器以新能源…

Pandora:一个让你呼吸顺畅的ChatGPT

什么是chatgpt ChatGPT是一种基于GPT(Generative Pre-trained Transformer)的聊天机器人。GPT是一种基于神经网络的自然语言处理模型,它使用大规模的文本数据进行预训练,然后可以用于各种自然语言处理任务,如文本生成…

神州数码DCN路由器之间GREIPsec 配置

拓扑: 说明: R1: g 0/0:192.168.1.1/24 g 0/1:10.1.1.1/24 tunnel 1:172.16.1.1/24 R2: g 0/0:192.168.2.1/24 g 0/1:10.1.1.2/24 tunnel 1:172.16.1.2/24 配置思路: <

阿里Github斩获4.5万Stars!分享的Spring Cloud全栈笔记,你想象不到有多全

如何获得高并发经验&#xff1f; 这是我今天逛知乎的时候系统邀请我回答的一个问题&#xff0c;由此也引发了我的一些思考&#xff1a;为什么人人都想要获得高并发经验&#xff1b;想拥有高并发系统设计技能&#xff1f; 其原因LZ认为主要有以下三点&#xff1a; 涨薪&#…

Pytorch入门(一)数据加载初始化及训练过程监控

Pytorch入门系列大致会更5篇文章不到&#xff0c;以后有机会的话再细细更新吧&#xff0c;主要复习一下Pytorch基本知识&#xff0c;复习一下在大二入门Pytorch的学习笔记&#xff01;原教程位于B站&#xff0c;讲的个人感觉蛮好的。 超级传送门&#xff0c;这个系列教程会很快…

4月刚上岸今日头条(字节)测试开发岗【附答案】

今日头条测试开发面试回顾 字节跳动公司以发展迅猛&#xff0c;待遇优厚和面试难闻名于业界。前段时间面试字节跳动&#xff08;今日头条&#xff09;&#xff0c;并成功拿下高级测试开发工程师岗位后的面试题目回顾,供跳槽季的各位同学参考&#xff01; 一面 自我介绍 编程题…

Java基础-Java常用类2(String类)

本篇文章梳理Java常用类--String类. String类是非常重要的,也是面试的重灾区,一起加油啊~~ 主要讲解String类 : String类的基础知识String类的特性String类的方法String,StringBuilder,StringBuffer之间的比较字符串常量池String应用 : 到底创建了多少个对象 希望给您带来帮助~…