[GRASS-SVN] r62473 - grass/branches/releasebranch_7_0/raster/r.horizon

svn_grass at osgeo.org svn_grass at osgeo.org
Wed Oct 29 03:42:27 PDT 2014


Author: neteler
Date: 2014-10-29 03:42:27 -0700 (Wed, 29 Oct 2014)
New Revision: 62473

Modified:
   grass/branches/releasebranch_7_0/raster/r.horizon/main.c
Log:
r.horizon + r.sun: parameter changes (backported trunk r61096, r61098, r61099) - part 2

Modified: grass/branches/releasebranch_7_0/raster/r.horizon/main.c
===================================================================
--- grass/branches/releasebranch_7_0/raster/r.horizon/main.c	2014-10-29 10:19:05 UTC (rev 62472)
+++ grass/branches/releasebranch_7_0/raster/r.horizon/main.c	2014-10-29 10:42:27 UTC (rev 62473)
@@ -69,7 +69,7 @@
 const char *horizon = NULL;
 const char *mapset = NULL;
 const char *per;
-char shad_filename[GNAME_MAX];
+char *shad_filename;
 char *outfile;
 
 struct Cell_head cellhd;
@@ -119,14 +119,15 @@
 double xmin, xmax, ymin, ymax, zmax = 0.;
 int d, day, tien = 0;
 
-double length, maxlength = BIG, zmult = 1.0, step = 0.0, dist;
-double fixedMaxLength = BIG;
+double length, maxlength = BIG, zmult = 1.0, dist;
+double fixedMaxLength = BIG, step = 0.0, start = 0.0, end = 0.0;
 char *tt, *lt;
 double z_orig, zp;
 double h0, tanh0, angle;
 double stepsinangle, stepcosangle, sinangle, cosangle, distsinangle,
     distcosangle;
 double TOLER;
+const char *str_step;
 
 int mode;
 int isMode()
@@ -141,6 +142,7 @@
 int ll_correction = FALSE;
 double coslatsq;
 
+
 /* why not use G_distance() here which switches to geodesic/great
   circle distance as needed? */
 double distance(double x1, double x2, double y1, double y2)
@@ -155,7 +157,6 @@
 }
 
 
-
 int main(int argc, char *argv[])
 {
     double xcoord, ycoord;
@@ -163,8 +164,9 @@
     struct GModule *module;
     struct
     {
-	struct Option *elevin, *dist, *coord, *direction, *horizon, *step,
-	    *bufferzone, *e_buff, *w_buff, *n_buff, *s_buff, *maxdistance, *output;
+	struct Option *elevin, *dist, *coord, *direction, *horizon, 
+                      *step, *start, *end, *bufferzone, *e_buff, *w_buff, 
+                      *n_buff, *s_buff, *maxdistance, *output;
     } parm;
 
     struct
@@ -179,23 +181,17 @@
     G_add_keyword(_("solar"));
     G_add_keyword(_("sun position"));
     module->label =
-	_("Horizon angle computation from a digital elevation model.");
+	_("Computes horizon angle height from a digital elevation model.");
     module->description =
-	_("Computes horizon angle height from a digital elevation model. The module has two"
-	 " different modes of operation:  "
-	 "1. Computes the entire horizon around a single point whose coordinates are"
-	 " given with the 'coord' option. The horizon height (in radians). "
-	 "2. Computes one or more raster maps of the horizon height in a single direction. "
-	 " The input for this is the angle (in degrees), which is measured "
-	 " counterclockwise with east=0, north=90 etc. The output is the horizon height in radians.");
+	_("The module has two "
+          "different modes of operation: "
+          "1. Computes the entire horizon around a single point whose coordinates are "
+          "given with the 'coord' option. The horizon height (in radians). "
+          "2. Computes one or more raster maps of the horizon height in a single direction. "
+          "The input for this is the angle (in degrees), which is measured "
+          "counterclockwise with east=0, north=90 etc. The output is the horizon height in radians.");
 
-    parm.elevin = G_define_option();
-    parm.elevin->key = "elev_in";
-    parm.elevin->type = TYPE_STRING;
-    parm.elevin->required = YES;
-    parm.elevin->gisprompt = "old,cell,raster";
-    parm.elevin->description =
-	_("Name of the input elevation raster map [meters]");
+    parm.elevin = G_define_standard_option(G_OPT_R_ELEV);
     parm.elevin->guisection = _("Input options");
 
 
@@ -208,13 +204,31 @@
     parm.direction->guisection = _("Input options");
 
     parm.step = G_define_option();
-    parm.step->key = "horizon_step";
+    parm.step->key = "step";
     parm.step->type = TYPE_DOUBLE;
     parm.step->required = NO;
     parm.step->description =
 	_("Angle step size for multidirectional horizon [degrees]");
     parm.step->guisection = _("Input options");
 
+    parm.start = G_define_option();
+    parm.start->key = "start";
+    parm.start->type = TYPE_DOUBLE;
+    parm.start->answer = "0.0";
+    parm.start->required = NO;
+    parm.start->description =
+        _("Start angle for multidirectional horizon [degrees]");
+    parm.start->guisection = _("Input options");
+
+    parm.end = G_define_option();
+    parm.end->key = "end";
+    parm.end->type = TYPE_DOUBLE;
+    parm.end->answer = "360.0";
+    parm.end->required = NO;
+    parm.end->description =
+        _("End angle for multidirectional horizon [degrees]");
+    parm.end->guisection = _("Input options");
+
     parm.bufferzone = G_define_option();
     parm.bufferzone->key = "bufferzone";
     parm.bufferzone->type = TYPE_DOUBLE;
@@ -264,12 +278,8 @@
     parm.maxdistance->guisection = _("Input options");
 
 
-    parm.horizon = G_define_option();
-    parm.horizon->key = "horizon";
-    parm.horizon->type = TYPE_STRING;
+    parm.horizon = G_define_standard_option(G_OPT_R_BASENAME_OUTPUT);
     parm.horizon->required = NO;
-    parm.horizon->gisprompt = "old,cell,raster";
-    parm.horizon->description = _("Prefix of the horizon raster output maps");
     parm.horizon->guisection = _("Output options");
 
 
@@ -343,9 +353,11 @@
     elevin = parm.elevin->answer;
 
     if (parm.coord->answer == NULL) {
+        G_debug(1, "Setting mode: WHOLE_RASTER");
 	setMode(WHOLE_RASTER);
     }
     else {
+        G_debug(1, "Setting mode: SINGLE_POINT");
 	setMode(SINGLE_POINT);
 	if (sscanf(parm.coord->answer, "%lf,%lf", &xcoord, &ycoord) != 2) {
 	    G_fatal_error(
@@ -385,7 +397,23 @@
 	}
 	horizon = parm.horizon->answer;
 	if (parm.step->answer != NULL)
+            str_step = parm.step->answer;
 	    sscanf(parm.step->answer, "%lf", &step);
+        sscanf(parm.start->answer, "%lf", &start);
+        sscanf(parm.end->answer, "%lf", &end);
+        if (start < 0.0) {
+            G_fatal_error(
+                _("Negative values of start angle are not allowed. Aborting."));
+        }
+        if (end < 0.0 || end > 360.0) {
+            G_fatal_error(
+                _("End angle is not between 0 and 360. Aborting."));
+        }
+        if (start >= end) {
+            G_fatal_error(
+                _("You specify a start grater than the end angle. Aborting."));
+        }
+        G_debug(1, "Angle step: %g, start: %g, end: %g", step, start, end);
     }
     else {
 
@@ -394,8 +422,6 @@
 		_("You didn't specify an angle step size. Aborting."));
 	}
 	sscanf(parm.step->answer, "%lf", &step);
-
-
     }
 
     if (step == 0.0) {
@@ -1015,7 +1041,7 @@
 	       int buffer_s, int buffer_n)
 {
     int i, j, l, k = 0;
-    int numDigits;
+    size_t decimals;
 
     int xindex, yindex;
     double shadow_angle;
@@ -1028,7 +1054,6 @@
     double delt_east, delt_nor;
     double delt_dist;
 
-    char formatString[10];
     char msg_buff[256];
 
     int hor_row_start = buffer_s;
@@ -1041,7 +1066,7 @@
     int hor_numcols = n - (buffer_e + buffer_w);
 
     int arrayNumInt;
-    double dfr_rad;
+    double dfr_rad, angle_deg;
 
     xindex = (int)((xcoord - xmin) / stepx);
     yindex = (int)((ycoord - ymin) / stepy);
@@ -1105,24 +1130,25 @@
 	}
 	else {
 	    dfr_rad = step * deg2rad;
-	    arrayNumInt = (int)(360. / fabs(step));
+	    arrayNumInt = (int)((end - start) / fabs(step));
 	}
 
-	numDigits = (int)(log10(1. * arrayNumInt)) + 1;
-	sprintf(formatString, "%%s_%%0%dd", numDigits);
+        decimals = G_get_num_decimals(str_step);
 
 	for (k = 0; k < arrayNumInt; k++) {
 	   struct History history; 
 
-	    if (step != 0.0)
-		sprintf(shad_filename, formatString, horizon, k);
+	    angle = (start + single_direction) * deg2rad + (dfr_rad * k);
+            angle_deg = angle * rad2deg + 0.0001;
 
-	    angle = (single_direction * deg2rad) + (dfr_rad * k);
+            if (step != 0.0)
+                 shad_filename = G_generate_basename(horizon, angle_deg, 3, decimals);
+
 	    /*              
 	       com_par(angle);
 	     */
 	    G_message(_("Calculating map %01d of %01d (angle %.2f, raster map <%s>)"),
-		     (k + 1), arrayNumInt, angle * rad2deg, shad_filename);
+		     (k + 1), arrayNumInt, angle_deg, shad_filename);
 
 	    for (j = hor_row_start; j < hor_row_end; j++) {
 		G_percent(j - hor_row_start, hor_numrows - 1, 2);
@@ -1266,6 +1292,7 @@
 		angle * rad2deg);
 
 	    Rast_write_history(shad_filename, &history);
+            G_free(shad_filename);
 	}
     }
 }



More information about the grass-commit mailing list