一、简介

英文网址:http://www.gdal.org/grid_tutorial.html。

网格插值的意思就是从离散的数据点创建一个栅格图像的过程。通常情况下,你有一系列研究区域的离散点,如果你想将这些点转换为规则的网格数据来进行进一步的处理,或者和其他网格数据进行合并等处理。下图是网格插值的一个示意图:

网格插值示意图

使用数据插值和逼近算法可以用来解决这个问题,但是插值的作用并不仅仅用来处理这个问题。有时候,你并不需要对数据进行插值处理,你需要做的就是计算一下数据覆盖区域的统计值和其他指标。统计值本身是十分有用的,或者你可以根据这些来选择更好的插值算法和参数。

这就是GDAL网格插值API所要理解的东西。它可以帮助你更好的对数据进行插值(参考下面的离散数据插值)或者计算数据的指标信息(参加下面的数据指标计算)。

一共有两种方式来使用这个接口。一种是使用GDALGridCreate的C语言接口编程实现,另一种是使用gdal_grid工具来使用。本文后面的内容将详细介绍GDAL网格插值API的算法原理及其参数表示的含义。

二、离散数据插值

1、反距离权重插值(Inverse Distance to a Power)

反距离权重插值方法是一种加权平均插值方式。你应该提供离散的数据值和每个点的坐标信息以及输出的格网,然后函数会插值计算输出格网节点的数据值。每一个格网节点的计算方式如下:

上式中字母的含义分别是:

  • Zi是已知点i的值;
  • r是格网节点到点i的距离;
  • p是权重指数;
  • n是搜索椭圆中的点个数。

在这个算法中权重系数ω的计算方式是:

可以参考函数GDALGridCreate中结构体GDALGridInverseDistanceToAPowerOptions的参数列表和gdal_grid工具的invdist选项列表。

2、移动平均值(Moving Average)

移动平均值是一个简单的数据平均算法,具体是用一个椭圆形的移动窗口,然后搜索在移动窗口中的所有的离散点,然后计算平均值。搜索椭圆可以指定旋转角度,椭圆的中心点位于网格节点。数据点的最少个数的平均值可以进行设置,如果没有足够的点在移动窗口中,这个网格节点就是空的,然后使用NODATA值来进行填充。

算法的数学公式可用下面的公式来表示:

上式中字母的含义分别是:

  • Z是插值结果,
  • Zi是已知点i的值;
  • n是搜索椭圆中的点个数。

可以参考函数GDALGridCreate中结构体GDALGridMovingAverageOptions的参数列表和gdal_grid 工具的average选项列表。

3、最邻近插值(Nearest Neighbor)

最邻近插值不使用任何插值算法和平滑算法,只需在搜索椭圆中找到离中心网格节点最近的离散点,然后把该离散点的值作为网格的节点值。如果没有找到点,将该格网节点设置为NODATA值。

可以参考函数GDALGridCreate中结构体GDALGridNearestNeighborOptions的参数列表和gdal_grid工具的nearest选项列表。

三、数据指标计算

所有的指标计算都是用一个叫GDALGridDataMetricsOptions的结构体来进行控制。

1、数据最小值(Minimum Data Value)

在搜索椭圆中找到的最小值,如果没有找到点,将返回NODATA值,公式如下:

式中:

  • Z是返回的结果值;
  • Zi表示第i个点的值;
  • N表示在搜索椭圆中的点。

2、数据最大值(Maximum Data Value)

在搜索椭圆中找到的最大值,如果没有找到点,将返回NODATA值,公式如下:

式中:

  • Z是返回的结果值;
  • Zi表示第i个点的值;
  • N表示在搜索椭圆中的点。

3、数据范围(Data Range)

在搜索椭圆中最大值和最小值的差,如果没有点,返回NODATA值,公式如下:

式中:

Z是返回的结果值;

Zi表示第i个点的值;

N表示在搜索椭圆中的点。

4、搜索椭圆(Search Ellipse)

在格网插值算法中用到的搜索窗口是一个旋转的椭圆,可以用下面三个参数来进行描述:

  • 第一半径(如果旋转角度为0,就是x轴)
  • 第二半径(如果旋转角度为0,就是y轴)
  • 旋转角度(逆时针方向)

只有点位于搜索椭圆之内(包括边界上)的点才用于计算。

GDAL源码剖析(十三)之GDAL网格插值说明相关推荐

  1. GDAL源码剖析(四)之命令行程序说明二

    接博客GDAL源码剖析(四)之命令行程序说明一http://blog.csdn.net/liminlu0314/article/details/6978589 其中有个nearblack,gdalbu ...

  2. 《GDAL源码剖析与开发指南》一一1.9 简单的调用

    本节书摘来自异步社区出版社<GDAL源码剖析与开发指南>一书中的第1章,第1.9节,作者:李民录 更多章节内容可以访问云栖社区"异步社区"公众号查看. 1.9 简单的调 ...

  3. java实现gdal栅格矢量化,《GDAL源码剖析与开发指南》一一1.5 GDAL源码目录

    本节书摘来自异步社区出版社<GDAL源码剖析与开发指南>一书中的第1章,第1.5节,作者:李民录 更多章节内容可以访问云栖社区"异步社区"公众号查看. 1.5 GDAL ...

  4. GDAL源码剖析(一)

    前言:一直在使用和研究GDAL的相关东西,发现网上对GDAL的内容倒是不少,但是很少有系统的介绍说明,以及内部的一些结构说明,基于这些原因,将本人的一些粗浅的理解放在此处,形成一个系列,暂时名为< ...

  5. 《GDAL源码剖析与开发指南》导读

    前言 GDAL源码剖析与开发指南 GDAL全称是Geospatial Data Abstraction Library(地理空间数据抽象库),是一个在X/MIT许可协议下读写空间数据(包括栅格数据和矢 ...

  6. GDAL源码剖析(二)之编译说明

    一.简单的编译 1.使用VisualStudio IDE编译 首先进入GDAL的源代码目录,可以看到有几个sln为后缀的文件名,比如makegdal10.sln,makegdal80.sln,make ...

  7. GDAL源码剖析(十二)之GDAL Warp API使用说明

    一.简介 本文原文地址:http://www.gdal.org/warptut.html GDAL Warp API(在文件gdalwarper.h中定义)是一个高效的进行图像变换的接口.主要由几何变 ...

  8. GDAL源码剖析(六)之GDAL开发及其调试

    写在开头:最近工作太忙,没时间更新,今天抽空更新一篇,上篇博客是四,这篇是六,中间还有一篇第五篇,主要将GDAL中的Python工具集,尽快给大家更新. 一.简单的调用 关于GDAL的使用,网上的资料 ...

  9. GDAL源码剖析(三)之Swig编译和帮助文档生成

    一.Swig编译 1.Swig介绍 SWIG全称是Simplified Wrapper and Interface Generator,官方网站:http://www.swig.org/.SWIG是个 ...

最新文章

  1. ajax+lucene pdf,基于Ajax/Lucene的站内搜索技术研究
  2. .NET 4 上的REST 框架
  3. wxWidgets学习 (2) -- 事件处理
  4. 鸿蒙技术2点O中国成功了吗,华为鸿蒙OS1.0回归,百万用户升级成功,粉丝:谷歌要哭鼻子了...
  5. C++编程练习:多态实验——利用抽象类和纯虚函数,编程计算正方体、球体和圆柱体的表面积和体积。
  6. 三大主流ETL工具选型
  7. CSS如何实现两个a标签元素的文字一个靠左一个靠右,并且能点击分别不同的链接
  8. Window插件获取窗口坐标
  9. 基于RabbitMQ RPC实现的主机异步管理
  10. 控制台打印_星星助手1S·便携式智能液晶电视串口工具 打印信息查看指令发送...
  11. 【硕博士推荐】国内有哪些不错的CV(计算机视觉)团队?
  12. linux ringbuffer原理,linux内核 使用内核队列实现ringbuffer(续)
  13. php 星期几大写,php日期转大写
  14. CSS 边框四个角效果
  15. Verilog转电路图
  16. 让Excel也像百度搜索框一样,录入时逐步提示
  17. 原生ajax crossO,总鳍鱼Crossopterygian
  18. 咦,咋没加volatile,变量也可见的呢?
  19. 求助Fatal error: Class 'think\App' not found in C:\``thinkphp\start.php on line 19Fatal error: Class '
  20. 怎么用EDIUS让滚动字幕停下来

热门文章

  1. python 保留顺序去重_Python入门很简单,只要掌握3456点
  2. charles浏览器抓包https_十分钟学会Charles抓包(iOS的http/https请求)
  3. elementui展示多张图片_Element-ui实现合并多图上传(一次请求多张图片)
  4. 开源 画图_[软件使用05] 快速使用 Deeptools 对 ChIP-seq 数据画图!
  5. 获取变量数据类型(JS)
  6. 绝对定位(HTML、CSS)
  7. 盒子阴影(HTML、CSS)
  8. svg写入/识别html元素和css样式
  9. 地图距离算法_基于权重的地图匹配技术
  10. JSCore的基本使用