[GRASS-SVN] r60795 - grass/trunk/raster/r.topmodel
svn_grass at osgeo.org
svn_grass at osgeo.org
Wed Jun 11 14:48:32 PDT 2014
Author: hcho
Date: 2014-06-11 14:48:32 -0700 (Wed, 11 Jun 2014)
New Revision: 60795
Modified:
grass/trunk/raster/r.topmodel/topmodel.c
Log:
r.topmodel: moved local variables
Modified: grass/trunk/raster/r.topmodel/topmodel.c
===================================================================
--- grass/trunk/raster/r.topmodel/topmodel.c 2014-06-11 20:58:52 UTC (rev 60794)
+++ grass/trunk/raster/r.topmodel/topmodel.c 2014-06-11 21:48:32 UTC (rev 60795)
@@ -81,7 +81,7 @@
/* Initialize the flows */
void initialize(void)
{
- int i;
+ int i, j;
double A1, A2;
/* average topographic index */
@@ -124,7 +124,7 @@
/* cumulative ratio of the contribution area for each time step */
misc.Ad = (double *)G_malloc(misc.tcsub * sizeof(double));
for (i = 0; i < misc.tcsub; i++) {
- int j, t;
+ int t;
t = misc.delay + i + 1;
if (t > misc.tch[params.nch - 1])
@@ -187,9 +187,6 @@
void calculate_flows(void)
{
int i, j, k;
- double Aatb_r;
- double f;
- double qo, qv;
misc.S = (double **)G_malloc(input.ntimesteps * sizeof(double *));
misc.Ea = (double **)G_malloc(input.ntimesteps * sizeof(double *));
@@ -204,6 +201,8 @@
misc.fex = (double *)G_malloc(input.ntimesteps * sizeof(double));
for (i = 0; i < input.ntimesteps; i++) {
+ double f;
+
misc.S[i] = (double *)G_malloc(misc.ntopidxclasses * sizeof(double));
misc.Ea[i] = (double *)G_malloc(misc.ntopidxclasses * sizeof(double));
misc.ex[i] = (double *)G_malloc(misc.ntopidxclasses * sizeof(double));
@@ -247,6 +246,8 @@
misc.qs[i] = misc.qss * exp(-misc.S_mean[i] / params.m);
for (j = 0; j < misc.ntopidxclasses; j++) {
+ double Aatb_r;
+
/* average area of a topographic index class */
Aatb_r = (topidxstats.Aatb_r[j] +
(j < misc.ntopidxclasses - 1 ? topidxstats.Aatb_r[j + 1]
@@ -277,21 +278,20 @@
}
/* drainage from unsaturated zone */
- qv = 0.0;
+ misc.qv[i][j] = 0.0;
if (misc.S[i][j] > 0.0) {
- qv = (params.td > 0.0 ?
+ misc.qv[i][j] = (params.td > 0.0 ?
misc.Suz[i][j] /
(misc.S[i][j] * params.td) * input.dt
: -params.td * params.K0 *
exp(-misc.S[i][j] / params.m));
- if (qv > misc.Suz[i][j])
- qv = misc.Suz[i][j];
- misc.Suz[i][j] -= qv;
+ if (misc.qv[i][j] > misc.Suz[i][j])
+ misc.qv[i][j] = misc.Suz[i][j];
+ misc.Suz[i][j] -= misc.qv[i][j];
if (misc.Suz[i][j] < ZERO)
misc.Suz[i][j] = 0.0;
- qv *= Aatb_r;
+ misc.qv[i][j] *= Aatb_r;
}
- misc.qv[i][j] = qv;
misc.qv[i][misc.ntopidxclasses] += misc.qv[i][j];
/* evapotranspiration from root zone storage deficit */
@@ -305,15 +305,14 @@
misc.Srz[i][j] += misc.Ea[i][j];
/* overland flow from fully saturated area */
- qo = 0.0;
+ misc.qo[i][j] = 0.0;
if (j > 0) {
if (misc.ex[i][j] > 0.0)
- qo = topidxstats.Aatb_r[j] *
+ misc.qo[i][j] = topidxstats.Aatb_r[j] *
(misc.ex[i][j - 1] + misc.ex[i][j]) / 2.0;
else if (misc.ex[i][j - 1] > 0.0)
- qo = Aatb_r * misc.ex[i][j - 1] / 2.0;
+ misc.qo[i][j] = Aatb_r * misc.ex[i][j - 1] / 2.0;
}
- misc.qo[i][j] = qo;
misc.qo[i][misc.ntopidxclasses] += misc.qo[i][j];
/* total flow */
More information about the grass-commit
mailing list