read_data.c 1.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. #include <stdlib.h>
  2. #include <grass/raster.h>
  3. #include <grass/imagery.h>
  4. #include <grass/glocale.h>
  5. #include "files.h"
  6. /* #include "local_proto.h" */
  7. int read_data(struct files *files, struct SigSet *S)
  8. {
  9. int n;
  10. int b;
  11. int nrows, ncols, row, col;
  12. CELL *class;
  13. struct ClassData *Data;
  14. nrows = Rast_window_rows();
  15. ncols = Rast_window_cols();
  16. class = (CELL *) G_calloc(ncols, sizeof(CELL));
  17. G_message(_("Reading raster maps..."));
  18. for (row = 0; row < nrows; row++) {
  19. G_percent(row, nrows, 2);
  20. read_training_map(class, row, ncols, files);
  21. for (b = 0; b < files->nbands; b++)
  22. Rast_get_d_row(files->band_fd[b], files->band_cell[b], row);
  23. for (col = 0; col < ncols; col++) {
  24. n = class[col];
  25. if (n < 0)
  26. continue;
  27. Data = &S->ClassSig[n].ClassData;
  28. for (b = 0; b < files->nbands; b++) {
  29. if (Rast_is_d_null_value(&files->band_cell[b][col]))
  30. Rast_set_d_null_value(&Data->x[Data->count][b], 1);
  31. else
  32. Data->x[Data->count][b] = files->band_cell[b][col];
  33. }
  34. Data->count++;
  35. }
  36. }
  37. G_percent(nrows, nrows, 2);
  38. G_free(class);
  39. return 0;
  40. }