o_max.c 1.0 KB

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