xnot.c 851 B

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. #include <grass/gis.h>
  2. #include <grass/raster.h>
  3. #include <grass/calc.h>
  4. /****************************************************************
  5. not(a) = !a
  6. ****************************************************************/
  7. int f_not(int argc, const int *argt, void **args)
  8. {
  9. CELL *res = args[0];
  10. CELL *arg1 = args[1];
  11. int i;
  12. if (argc < 1)
  13. return E_ARG_LO;
  14. if (argc > 1)
  15. return E_ARG_HI;
  16. if (argt[1] != CELL_TYPE)
  17. return E_ARG_TYPE;
  18. if (argt[0] != CELL_TYPE)
  19. return E_RES_TYPE;
  20. for (i = 0; i < columns; i++) {
  21. if (IS_NULL_C(&arg1[i]))
  22. SET_NULL_C(&res[i]);
  23. else
  24. res[i] = !arg1[i];
  25. }
  26. return 0;
  27. }
  28. int c_not(int argc, int *argt)
  29. {
  30. if (argc < 1)
  31. return E_ARG_LO;
  32. if (argc > 1)
  33. return E_ARG_HI;
  34. if (argt[1] != CELL_TYPE)
  35. return E_ARG_TYPE;
  36. argt[0] = CELL_TYPE;
  37. return 0;
  38. }