[GRASS-SVN] r62809 - grass/trunk/raster/r.in.poly
svn_grass at osgeo.org
svn_grass at osgeo.org
Tue Nov 18 20:15:42 PST 2014
Author: annakrat
Date: 2014-11-18 20:15:42 -0800 (Tue, 18 Nov 2014)
New Revision: 62809
Modified:
grass/trunk/raster/r.in.poly/format.h
grass/trunk/raster/r.in.poly/get_item.c
grass/trunk/raster/r.in.poly/getformat.c
grass/trunk/raster/r.in.poly/local_proto.h
grass/trunk/raster/r.in.poly/main.c
grass/trunk/raster/r.in.poly/poly2rast.c
grass/trunk/raster/r.in.poly/raster.c
Log:
r.in.poly: add support for FCELL, DCELL output map and fix writing zeros and nulls
Modified: grass/trunk/raster/r.in.poly/format.h
===================================================================
--- grass/trunk/raster/r.in.poly/format.h 2014-11-18 20:06:24 UTC (rev 62808)
+++ grass/trunk/raster/r.in.poly/format.h 2014-11-19 04:15:42 UTC (rev 62809)
@@ -2,3 +2,5 @@
#define USE_UCHAR 2
#define USE_SHORT 3
#define USE_CELL 4
+#define USE_FCELL 5
+#define USE_DCELL 6
Modified: grass/trunk/raster/r.in.poly/get_item.c
===================================================================
--- grass/trunk/raster/r.in.poly/get_item.c 2014-11-18 20:06:24 UTC (rev 62808)
+++ grass/trunk/raster/r.in.poly/get_item.c 2014-11-19 04:15:42 UTC (rev 62809)
@@ -1,8 +1,9 @@
#include <grass/gis.h>
#include <grass/raster.h>
#include <grass/glocale.h>
+#include "format.h"
-int get_item(FILE * fd, int *type, long *cat, double **x, double **y,
+int get_item(FILE * fd, int format, int *type, int *cat_int, double *cat_double, double **x, double **y,
int *count, struct Categories *labels)
{
static double *X = NULL;
@@ -13,8 +14,10 @@
char east[256], north[256];
double e, n;
long offset;
+ FCELL cat_float_tmp;
- *cat = 0;
+ *cat_int = 0;
+ *cat_double = 0;
*count = 0;
*type = 0;
@@ -63,14 +66,32 @@
/* if we found a cat (and optionally a label), read them and continue to scan */
if (*buf == '=') {
- if (sscanf(buf + 1, "%ld", cat) != 1)
+ if (format == USE_FCELL || format == USE_DCELL) {
+ if (sscanf(buf + 1, "%lf", cat_double) != 1)
+ continue;
+ /* probably change this as G_getl2() doesn't store the new line (?) */
+ if (sscanf(buf + 1, "%lf%[^\n]", cat_double, lbl) == 2) {
+ G_strip(lbl);
+ if (format == USE_FCELL) {
+ cat_float_tmp = (FCELL) *cat_double;
+ Rast_set_f_cat(&cat_float_tmp, &cat_float_tmp, lbl, labels);
+ }
+ else {
+ Rast_set_d_cat((DCELL*) cat_double, (DCELL *) cat_double, lbl, labels);
+ }
+ }
continue;
- /* probably change this as G_getl2() doesn't store the new line (?) */
- if (sscanf(buf + 1, "%ld%[^\n]", cat, lbl) == 2) {
- G_strip(lbl);
- Rast_set_c_cat((CELL*) cat, (CELL *) cat, lbl, labels);
}
- continue;
+ else {
+ if (sscanf(buf + 1, "%d", cat_int) != 1)
+ continue;
+ /* probably change this as G_getl2() doesn't store the new line (?) */
+ if (sscanf(buf + 1, "%d%[^\n]", cat_int, lbl) == 2) {
+ G_strip(lbl);
+ Rast_set_c_cat((CELL*) cat_int, (CELL *) cat_int, lbl, labels);
+ }
+ continue;
+ }
}
if (sscanf(buf, "%s %s", east, north) != 2) {
G_warning(_("Illegal coordinate <%s, %s>, skipping."), east, north);
Modified: grass/trunk/raster/r.in.poly/getformat.c
===================================================================
--- grass/trunk/raster/r.in.poly/getformat.c 2014-11-18 20:06:24 UTC (rev 62808)
+++ grass/trunk/raster/r.in.poly/getformat.c 2014-11-19 04:15:42 UTC (rev 62809)
@@ -2,7 +2,7 @@
#include <grass/raster.h>
#include "format.h"
-int getformat(FILE * fd)
+int getformat(FILE * fd, int raster_type, int *null)
{
char buf[1024];
long x;
@@ -12,6 +12,14 @@
short Smin, Smax;
int first;
+ if (raster_type == FCELL_TYPE)
+ return USE_FCELL;
+ if (raster_type == DCELL_TYPE)
+ return USE_DCELL;
+
+ if (null)
+ return USE_CELL;
+
max = min = 0;
first = 1;
G_fseek(fd, 0L, 0);
Modified: grass/trunk/raster/r.in.poly/local_proto.h
===================================================================
--- grass/trunk/raster/r.in.poly/local_proto.h 2014-11-18 20:06:24 UTC (rev 62808)
+++ grass/trunk/raster/r.in.poly/local_proto.h 2014-11-19 04:15:42 UTC (rev 62809)
@@ -1,17 +1,18 @@
#include <grass/raster.h>
/* get_item.c */
-int get_item(FILE *, int *, long *, double **, double **, int *,
+int get_item(FILE *, int, int *, int *, double *, double **, double **, int *,
struct Categories *);
/* getformat.c */
-int getformat(FILE *);
+int getformat(FILE *, int, int *);
/* poly2rast.c */
-int poly_to_rast(char *, char *, char *, int);
+int poly_to_rast(char *, char *, char *, int, int, int *);
/* raster.c */
int begin_rasterization(int, int);
int configure_plot(void);
-int output_raster(int);
-int set_cat(long);
+int output_raster(int, int *);
+int set_cat_int(int);
+int set_cat_double(double);
int raster_dot(int, int);
Modified: grass/trunk/raster/r.in.poly/main.c
===================================================================
--- grass/trunk/raster/r.in.poly/main.c 2014-11-18 20:06:24 UTC (rev 62808)
+++ grass/trunk/raster/r.in.poly/main.c 2014-11-19 04:15:42 UTC (rev 62809)
@@ -12,6 +12,7 @@
*
*****************************************************************************/
#include <stdlib.h>
+#include <string.h>
#include <grass/gis.h>
#include <grass/glocale.h>
#include "local_proto.h"
@@ -20,8 +21,12 @@
int main(int argc, char *argv[])
{
struct GModule *module;
- struct Option *input, *output, *title, *rows;
+ struct Option *input, *output, *title, *rows, *nulls, *type;
int n;
+ int raster_type;
+ int null_value;
+ int *null;
+ null = &null_value;
G_gisinit(argv[0]);
@@ -44,6 +49,20 @@
title->required = NO;
title->description = _("Title for resultant raster map");
+ type = G_define_option();
+ type->key = "type";
+ type->type = TYPE_STRING;
+ type->required = NO;
+ type->description = _("Output raster type");
+ type->options = "CELL,FCELL,DCELL";
+ type->answer = "CELL";
+
+ nulls = G_define_option();
+ nulls->key = "null";
+ nulls->type = TYPE_INTEGER;
+ nulls->required = NO;
+ nulls->description = _("Integer representing NULL value data cell");
+
rows = G_define_option();
rows->key = "rows";
rows->type = TYPE_INTEGER;
@@ -54,10 +73,23 @@
if (G_parser(argc, argv))
exit(EXIT_FAILURE);
-
sscanf(rows->answer, "%d", &n);
if (n < 1)
G_fatal_error(_("Minimum number of rows to hold in memory is 1"));
- exit(poly_to_rast(input->answer, output->answer, title->answer, n));
+ if (strcmp(type->answer, "CELL") == 0)
+ raster_type = CELL_TYPE;
+ else if (strcmp(type->answer, "FCELL") == 0)
+ raster_type = FCELL_TYPE;
+ else if (strcmp(type->answer, "DCELL") == 0)
+ raster_type = DCELL_TYPE;
+ else
+ G_fatal_error(_("Type doesn't exist"));
+
+ if (nulls->answer)
+ *null = atoi(nulls->answer);
+ else
+ null = NULL;
+
+ exit(poly_to_rast(input->answer, output->answer, title->answer, n, raster_type, null));
}
Modified: grass/trunk/raster/r.in.poly/poly2rast.c
===================================================================
--- grass/trunk/raster/r.in.poly/poly2rast.c 2014-11-18 20:06:24 UTC (rev 62808)
+++ grass/trunk/raster/r.in.poly/poly2rast.c 2014-11-19 04:15:42 UTC (rev 62809)
@@ -6,11 +6,12 @@
#include "format.h"
#include "local_proto.h"
-int poly_to_rast(char *input_file, char *raster_map, char *title, int nrows)
+int poly_to_rast(char *input_file, char *raster_map, char *title, int nrows, int raster_type, int *null)
{
double *x, *y;
int count;
- long cat;
+ int cat_int;
+ double cat_double;
int type;
struct Categories labels;
FILE *ifd; /* for input file */
@@ -32,7 +33,7 @@
exit(EXIT_FAILURE);
}
- rfd = Rast_open_c_new(raster_map);
+ rfd = Rast_open_new(raster_map, raster_type);
if (title == NULL)
title = "";
@@ -40,7 +41,7 @@
Rast_init_cats(title, &labels);
- format = getformat(ifd);
+ format = getformat(ifd, raster_type, null);
/* ?? otherwise get complaints about window changes */
G_suppress_warnings(TRUE);
@@ -55,8 +56,11 @@
G_message(_("Pass #%d (of %d) ..."), pass, npasses);
G_fseek(ifd, 0L, 0);
- while (get_item(ifd, &type, &cat, &x, &y, &count, &labels)) {
- set_cat(cat);
+ while (get_item(ifd, format, &type, &cat_int, &cat_double, &x, &y, &count, &labels)) {
+ if (format == USE_FCELL || format == USE_DCELL)
+ set_cat_double(cat_double);
+ else
+ set_cat_int(cat_int);
switch (type) {
case 'A':
G_plot_polygon(x, y, count);
@@ -76,7 +80,7 @@
G_message(_("Writing raster map..."));
- stat = output_raster(rfd);
+ stat = output_raster(rfd, null);
} while (stat == 0);
/* stat: 0 means repeat
* 1 means done
Modified: grass/trunk/raster/r.in.poly/raster.c
===================================================================
--- grass/trunk/raster/r.in.poly/raster.c 2014-11-18 20:06:24 UTC (rev 62808)
+++ grass/trunk/raster/r.in.poly/raster.c 2014-11-19 04:15:42 UTC (rev 62809)
@@ -1,3 +1,4 @@
+#include <math.h>
#include <grass/gis.h>
#include <grass/raster.h>
#include "format.h"
@@ -11,16 +12,21 @@
unsigned char **u;
short **s;
CELL **cell;
+ FCELL **fcell;
+ DCELL **dcell;
} raster;
static int max_rows;
static int at_row;
-static long cat;
+static int cat_int;
+static double cat_double;
static int cur_x, cur_y;
static int format;
static CELL *cell;
static int (*dot) ();
static int cell_dot(int, int);
+static int fcell_dot(int, int);
+static int dcell_dot(int, int);
static int uchar_dot(int, int);
static int char_dot(int, int);
static int short_dot(int, int);
@@ -80,8 +86,24 @@
raster.cell[i] = raster.cell[i - 1] + region.cols;
dot = cell_dot;
break;
+
+ case USE_FCELL:
+ raster.fcell = (FCELL **) G_calloc(max_rows, sizeof(FCELL *));
+ raster.fcell[0] = (FCELL *) G_calloc(size, sizeof(FCELL));
+ for (i = 1; i < max_rows; i++)
+ raster.fcell[i] = raster.fcell[i - 1] + region.cols;
+ dot = fcell_dot;
+ break;
+
+ case USE_DCELL:
+ raster.dcell = (DCELL **) G_calloc(max_rows, sizeof(DCELL *));
+ raster.dcell[0] = (DCELL *) G_calloc(size, sizeof(DCELL));
+ for (i = 1; i < max_rows; i++)
+ raster.dcell[i] = raster.dcell[i - 1] + region.cols;
+ dot = dcell_dot;
+ break;
}
- if (format != USE_CELL)
+ if (format != USE_CELL && format != USE_FCELL && format != USE_DCELL)
cell = Rast_allocate_c_buf();
at_row = 0;
@@ -131,9 +153,16 @@
case USE_CELL:
for (i = 0; i < nrows; i++)
- for (j = 0; j < ncols; j++)
- raster.cell[i][j] = 0;
+ Rast_set_c_null_value(raster.cell[i], ncols);
break;
+ case USE_FCELL:
+ for (i = 0; i < nrows; i++)
+ Rast_set_f_null_value(raster.fcell[i], ncols);
+ break;
+ case USE_DCELL:
+ for (i = 0; i < nrows; i++)
+ Rast_set_d_null_value(raster.dcell[i], ncols);
+ break;
}
/* change the region */
@@ -148,58 +177,103 @@
return AGAIN;
}
-int output_raster(int fd)
+int output_raster(int fd, int *null)
{
int i, j;
+ FCELL *fcell;
+ DCELL *dcell;
for (i = 0; i < page.rows; i++, at_row++) {
- switch (format) {
+ switch (format) {
+
+ case USE_CHAR:
+ for (j = 0; j < page.cols; j++) {
+ cell[j] = (CELL) raster.c[i][j];
+ if (cell[j] == 0)
+ Rast_set_null_value(&cell[j], 1, CELL_TYPE);
+ }
+ break;
+
+ case USE_UCHAR:
+ for (j = 0; j < page.cols; j++) {
+ cell[j] = (CELL) raster.u[i][j];
+ if (cell[j] == 0)
+ Rast_set_null_value(&cell[j], 1, CELL_TYPE);
+ }
+ break;
+
+ case USE_SHORT:
+ for (j = 0; j < page.cols; j++) {
+ cell[j] = (CELL) raster.s[i][j];
+ if (cell[j] == 0)
+ Rast_set_null_value(&cell[j], 1, CELL_TYPE);
+ }
+ break;
- case USE_CHAR:
- for (j = 0; j < page.cols; j++) {
- cell[j] = (CELL) raster.c[i][j];
- if (cell[j] == 0)
- Rast_set_null_value(&cell[j], 1, CELL_TYPE);
- }
- break;
+ case USE_CELL:
+ cell = raster.cell[i];
+ if (!null)
+ break;
+ for (j = 0; j < page.cols; j++) {
+ if (cell[j] == *null)
+ Rast_set_null_value(&cell[j], 1, CELL_TYPE);
+ }
+ break;
- case USE_UCHAR:
- for (j = 0; j < page.cols; j++) {
- cell[j] = (CELL) raster.u[i][j];
- if (cell[j] == 0)
- Rast_set_null_value(&cell[j], 1, CELL_TYPE);
- }
- break;
-
- case USE_SHORT:
- for (j = 0; j < page.cols; j++) {
- cell[j] = (CELL) raster.s[i][j];
- if (cell[j] == 0)
- Rast_set_null_value(&cell[j], 1, CELL_TYPE);
- }
- break;
-
- case USE_CELL:
- cell = raster.cell[i];
- if (cell == 0)
- Rast_set_null_value(&cell, 1, CELL_TYPE);
- break;
- }
-
- G_percent(i, page.rows, 2);
- Rast_put_row(fd, cell, CELL_TYPE);
+ case USE_FCELL:
+ fcell = raster.fcell[i];
+ if (!null)
+ break;
+ for (j = 0; j < page.cols; j++) {
+ if (fabs(fcell[j] - (FCELL) *null) < 1e-6)
+ Rast_set_null_value(&fcell[j], 1, FCELL_TYPE);
+ }
+ break;
+
+ case USE_DCELL:
+ dcell = raster.dcell[i];
+ if (!null)
+ break;
+ for (j = 0; j < page.cols; j++) {
+ if (fabs(dcell[j] - (DCELL) *null) < 1e-6)
+ Rast_set_null_value(&dcell[j], 1, DCELL_TYPE);
+ }
+ break;
+ }
+ switch (format) {
+ case USE_CHAR:
+ case USE_UCHAR:
+ case USE_SHORT:
+ case USE_CELL:
+ Rast_put_row(fd, cell, CELL_TYPE);
+ break;
+ case USE_FCELL:
+ Rast_put_row(fd, fcell, FCELL_TYPE);
+ break;
+ case USE_DCELL:
+ Rast_put_row(fd, dcell, DCELL_TYPE);
+ break;
+ }
+ G_percent(i, page.rows, 2);
}
G_percent(i, page.rows, 2);
return configure_plot();
}
-int set_cat(long x)
+int set_cat_int(int x)
{
- cat = x;
+ cat_int = x;
return 0;
}
+int set_cat_double(double x)
+{
+ cat_double = x;
+
+ return 0;
+}
+
int raster_dot(int x, int y)
{
dot(x, y);
@@ -237,15 +311,31 @@
static int cell_dot(int x, int y)
{
if (x >= 0 && x < page.cols && y >= 0 && y < page.rows)
- raster.cell[y][x] = cat;
+ raster.cell[y][x] = (CELL) cat_int;
return 0;
}
+static int fcell_dot(int x, int y)
+{
+ if (x >= 0 && x < page.cols && y >= 0 && y < page.rows)
+ raster.fcell[y][x] = (FCELL) cat_double;
+
+ return 0;
+}
+
+static int dcell_dot(int x, int y)
+{
+ if (x >= 0 && x < page.cols && y >= 0 && y < page.rows)
+ raster.dcell[y][x] = (DCELL) cat_double;
+
+ return 0;
+}
+
static int uchar_dot(int x, int y)
{
if (x >= 0 && x < page.cols && y >= 0 && y < page.rows)
- raster.u[y][x] = cat;
+ raster.u[y][x] = cat_int;
return 0;
}
@@ -253,7 +343,7 @@
static int char_dot(int x, int y)
{
if (x >= 0 && x < page.cols && y >= 0 && y < page.rows)
- raster.c[y][x] = cat;
+ raster.c[y][x] = cat_int;
return 0;
}
@@ -261,7 +351,7 @@
static int short_dot(int x, int y)
{
if (x >= 0 && x < page.cols && y >= 0 && y < page.rows)
- raster.s[y][x] = cat;
+ raster.s[y][x] = cat_int;
return 0;
}
More information about the grass-commit
mailing list