xabs.c 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. #include <math.h>
  2. #include <grass/gis.h>
  3. #include <grass/raster.h>
  4. #include "globals.h"
  5. #include "expression.h"
  6. #include "func_proto.h"
  7. /**********************************************************************
  8. abs(x)
  9. absolute value. if x is negative returns -x
  10. **********************************************************************/
  11. int f_abs(int argc, const int *argt, void **args)
  12. {
  13. int i;
  14. if (argc < 1)
  15. return E_ARG_LO;
  16. if (argc > 1)
  17. return E_ARG_HI;
  18. if (argt[0] != argt[1])
  19. return E_RES_TYPE;
  20. switch (argt[1]) {
  21. case CELL_TYPE:
  22. {
  23. CELL *res = args[0];
  24. CELL *arg1 = args[1];
  25. for (i = 0; i < columns; i++)
  26. if (IS_NULL_C(&arg1[i]))
  27. SET_NULL_C(&res[i]);
  28. else
  29. res[i] = arg1[i] < 0 ? -arg1[i]
  30. : arg1[i];
  31. return 0;
  32. }
  33. case FCELL_TYPE:
  34. {
  35. FCELL *res = args[0];
  36. FCELL *arg1 = args[1];
  37. for (i = 0; i < columns; i++)
  38. if (IS_NULL_F(&arg1[i]))
  39. SET_NULL_F(&res[i]);
  40. else
  41. res[i] = (FCELL) fabs(arg1[i]);
  42. return 0;
  43. }
  44. case DCELL_TYPE:
  45. {
  46. DCELL *res = args[0];
  47. DCELL *arg1 = args[1];
  48. for (i = 0; i < columns; i++)
  49. if (IS_NULL_D(&arg1[i]))
  50. SET_NULL_D(&res[i]);
  51. else
  52. res[i] = fabs(arg1[i]);
  53. return 0;
  54. }
  55. default:
  56. return E_INV_TYPE;
  57. }
  58. }