o_divr.c 1.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243
  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_divr(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_fp, *reclass_fp;
  11. int first;
  12. long basecat, covercat, catb, catc;
  13. double area;
  14. stats_fp = run_stats(&stats_child, basemap, covermap, "-an");
  15. reclass_fp = run_reclass(&reclass_child, basemap, outputmap);
  16. first = 1;
  17. while (read_stats(stats_fp, &basecat, &covercat, &area)) {
  18. if (first) {
  19. first = 0;
  20. catb = basecat;
  21. catc = 0;
  22. }
  23. if (basecat != catb) {
  24. write_reclass(reclass_fp, catb, catc, Rast_get_c_cat((CELL *) &catc, cats),
  25. usecats);
  26. catb = basecat;
  27. catc = 0;
  28. }
  29. catc++;
  30. }
  31. if (!first)
  32. write_reclass(reclass_fp, catb, catc, Rast_get_c_cat((CELL *) &catc, cats), usecats);
  33. G_popen_close(&stats_child);
  34. G_popen_close(&reclass_child);
  35. return 0;
  36. }