12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273 |
- #include <grass/gis.h>
- #include <grass/raster.h>
- #include "mask.h"
- #include "local_proto.h"
- int init_d_mask_rules(d_Mask * d_mask)
- {
- d_mask->list = NULL;
- return 0;
- }
- int add_d_mask_rule(d_Mask * d_mask, double a, double b, int inf)
- {
- d_Interval *I;
- I = (d_Interval *) G_malloc(sizeof(d_Interval));
- I->low = a <= b ? a : b;
- I->high = a >= b ? a : b;
- I->inf = inf;
- I->next = d_mask->list;
- d_mask->list = I;
- return 0;
- }
- int mask_raster_array(void *rast, int ncols,
- int change_null, RASTER_MAP_TYPE data_type)
- {
- DCELL x;
- while (ncols-- > 0) {
- x = Rast_get_d_value(rast, data_type);
- if (change_null && Rast_is_null_value(rast, data_type))
- Rast_set_d_value(rast, new_null, data_type);
- if (mask_d_select(&x, &d_mask))
- Rast_set_null_value(rast, 1, data_type);
- rast = G_incr_void_ptr(rast, Rast_cell_size(data_type));
- }
- return 0;
- }
- int mask_d_select(DCELL * x, d_Mask * mask)
- {
- d_Interval *I;
- if (mask->list == NULL)
- return 0;
- for (I = mask->list; I; I = I->next) {
- if (mask_match_d_interval(*x, I))
- return 1;
- }
- return 0;
- }
- int mask_match_d_interval(DCELL x, d_Interval * I)
- {
- if (Rast_is_d_null_value(&x))
- return 0;
- if (I->inf < 0)
- return x <= I->low;
- if (I->inf > 0)
- return x >= I->high;
- if (I->low != I->low && I->high != I->high)
- return x != x;
- return x >= I->low && x <= I->high;
- }
|