GRASS Programmer's Manual  6.5.svn(2014)-r66266
 All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Macros Pages
c_median.c
Go to the documentation of this file.
1 #include <grass/gis.h>
2 #include <grass/stats.h>
3 
4 void c_median(DCELL * result, DCELL * values, int n, const void *closure)
5 {
6  n = sort_cell(values, n);
7 
8  if (n < 1)
9  G_set_d_null_value(result, 1);
10  else
11  *result = (values[(n - 1) / 2] + values[n / 2]) / 2;
12 }
13 
14 void w_median(DCELL * result, DCELL(*values)[2], int n, const void *closure)
15 {
16  DCELL total;
17  int i;
18  DCELL k;
19 
20  n = sort_cell_w(values, n);
21 
22  if (n < 1) {
23  G_set_d_null_value(result, 1);
24  return;
25  }
26 
27  total = 0.0;
28  for (i = 0; i < n; i++)
29  total += values[i][1];
30 
31  k = 0.0;
32  for (i = 0; i < n; i++) {
33  k += values[i][1];
34  if (k >= total / 2)
35  break;
36  }
37 
38  *result = values[i][0];
39 }
int sort_cell_w(DCELL(*array)[2], int n)
Definition: sort_cell.c:34
void G_set_d_null_value(DCELL *dcellVals, int numVals)
Definition: null_val.c:176
void w_median(DCELL *result, DCELL(*values)[2], int n, const void *closure)
Definition: c_median.c:14
int sort_cell(DCELL *array, int n)
Definition: sort_cell.c:21
int n
Definition: dataquad.c:291
void c_median(DCELL *result, DCELL *values, int n, const void *closure)
Definition: c_median.c:4