c_range.c 605 B

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