[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