o_mode.c 1.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. #include <stdlib.h>
  2. #include <unistd.h>
  3. #include <grass/gis.h>
  4. #include <grass/raster.h>
  5. #include "method.h"
  6. int
  7. o_mode(const char *basemap, const char *covermap, const char *outputmap, int usecats,
  8. struct Categories *cats)
  9. {
  10. struct Popen stats_child, reclass_child;
  11. FILE *stats, *reclass;
  12. int first;
  13. long basecat, covercat, catb, catc;
  14. double value, max;
  15. stats = run_stats(&stats_child, basemap, covermap, "-an");
  16. reclass = run_reclass(&reclass_child, basemap, outputmap);
  17. first = 1;
  18. while (read_stats(stats, &basecat, &covercat, &value)) {
  19. if (first) {
  20. first = 0;
  21. catb = basecat;
  22. catc = covercat;
  23. max = value;
  24. }
  25. if (basecat != catb) {
  26. write_reclass(reclass, catb, catc, Rast_get_c_cat((CELL *) &catc, cats),
  27. usecats);
  28. catb = basecat;
  29. catc = covercat;
  30. max = value;
  31. }
  32. if (value > max) {
  33. catc = covercat;
  34. max = value;
  35. }
  36. }
  37. if (first) {
  38. catb = catc = 0;
  39. }
  40. write_reclass(reclass, catb, catc, Rast_get_c_cat((CELL *) &catc, cats), usecats);
  41. G_popen_close(&stats_child);
  42. G_popen_close(&reclass_child);
  43. return 0;
  44. }