c_range.c 534 B

123456789101112131415161718192021222324252627
  1. #include <grass/gis.h>
  2. void c_range(DCELL * result, DCELL * values, int n)
  3. {
  4. DCELL min, max;
  5. int i;
  6. G_set_d_null_value(&min, 1);
  7. G_set_d_null_value(&max, 1);
  8. for (i = 0; i < n; i++) {
  9. if (G_is_d_null_value(&values[i]))
  10. continue;
  11. if (G_is_d_null_value(&min) || min > values[i])
  12. min = values[i];
  13. if (G_is_d_null_value(&max) || max < values[i])
  14. max = values[i];
  15. }
  16. if (G_is_d_null_value(&min) || G_is_d_null_value(&max))
  17. G_set_d_null_value(result, 1);
  18. else
  19. *result = max - min;
  20. }