forked from MapServer/MapServer
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathidw.c
76 lines (71 loc) · 3.21 KB
/
idw.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
/******************************************************************************
*
* Project: MapServer
* Purpose: Inverse Distance Weighted layer interpolation.
* Author: Hermes L. Herrera Martinez and the MapServer team.
* Thanks: Thomas Bonfort
*
******************************************************************************
* Copyright (c) 2014 Regents of the University of Minnesota.
*
* Permission is hereby granted, free of charge, to any person obtaining a
* copy of this software and associated documentation files (the "Software"),
* to deal in the Software without restriction, including without limitation
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
* and/or sell copies of the Software, and to permit persons to whom the
* Software is furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in
* all copies of this Software or works derived from this Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
* OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
* THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
* DEALINGS IN THE SOFTWARE.
*****************************************************************************/
#include "mapserver.h"
#include <float.h>
#define EPSILON 0.000000001
#include <time.h>
void msIdw(float *xyz, int width, int height, int npoints, interpolationProcessingParams *interpParams, unsigned char *iValues) {
int i,j,index;
int radius = interpParams->radius;
float power = interpParams->power;
for (j=0; j < height; j++) {
for (i=0; i < width; i++) {
double den = EPSILON, num = 0;
for(index = 0; index < npoints*3; index += 3){
double d = (xyz[index] - i)*(xyz[index] - i)+(xyz[index+1] - j)*(xyz[index+1] - j);
if(radius*radius > d) {
double w = 1.0/(pow(d, power) + EPSILON);
num += w*xyz[index+2];
den += w;
}
}
iValues[j*width + i] = num/den;
}
}
}
void msIdwProcessing(layerObj *layer, interpolationProcessingParams *interpParams) {
const char *interpParamsProcessing = msLayerGetProcessingKey( layer, "IDW_POWER" );
if(interpParamsProcessing) {
interpParams->power = atof(interpParamsProcessing);
} else{
interpParams->power = 1.0;
}
interpParamsProcessing = msLayerGetProcessingKey( layer, "IDW_RADIUS" );
if(interpParamsProcessing){
interpParams->radius = atof(interpParamsProcessing);
} else {
interpParams->radius = MAX(layer->map->width,layer->map->height);
}
interpParamsProcessing = msLayerGetProcessingKey( layer, "IDW_COMPUTE_BORDERS" );
if(interpParamsProcessing && strcasecmp(interpParamsProcessing,"OFF")){
interpParams->expand_searchrect = 1;
} else {
interpParams->expand_searchrect = 0;
}
}