克里金插值c程序_Openlayer——Kriging和turf实现克里金插值

本文介绍了如何使用OpenLayers结合Kriging和Turf库进行空间克里金插值。通过克里金算法的训练、网格化和绘图功能,实现了在地图上展示地统计学的等值面。文章中详细阐述了从定义插值参数、矢量数据源、地图交互操作,到计算点集和绘制插值图的整个过程。
摘要由CSDN通过智能技术生成

克里金插值也称作空间局部插值法,或空间自协方差最佳插值法,它以变异函数理论和结构分析为基础, 在特定区域内对区域化变量进行无偏最优估计,被广泛应用于土壤制图领域,是一种非常重要的地统计学方法。


克里金算法已有开源的实现。克里金算法中有三个重要函数:


(1)kriging.train(t,x,y,model,sigma2,alpha)。使用gaussian、exponential或spherical模型对数据集进行训练,返回的是一个variogram对象。


(2)kriging.grid(polygons,variogram,width)。使用刚才的variogram对象使polygons描述的地理位置内的格网元素具备不一样的预测值。


(3)kriging.plot(canvas,grid,xlim,ylim,colors)。将得到的格网grid渲染至canvas上。


本文介绍openlayer结合kriging和turf实现空间的克里金插值。使用turf来处理网格数据,生成等值面,提升交互性能,效果会更好。


(1)定义插值参数、矢量数据源和矢量图层,并添加到地图容器中。

let params = {
            mapCenter: [121.483101, 31.227036],        maxValue: 100,        krigingModel: 'spherical', //model还可选'gaussian','spherical',exponential        krigingSigma2: 0,        krigingAlpha: 100,        canvasAlpha: 0.75, //canvas图层透明度        colors: ['#006837',            '#1a9850',            '#66bd63',            '#a6d96a',            '#d9ef8b',            '#ffffbf',            '#fee08b',            '#fdae61',            '#f46d43',            '#d73027',            '#a50026']    };    var map = new ol.Map ({
            target: 'map',        layers: [            new ol.layer.Tile({
                    title: '天地图矢量图层',                source: new ol.source.XYZ({
                        url: 'http://t0.tianditu.com
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值