On Mar 7, 2009, at 8:50 PM, Helena Mitasova wrote:
There is no question that the default should be kept negative,
although checking whether the result
is correct would not hurt - we can look at it with our Panama
experiments, others using
r.watershed could provide some helpful feedback too.
But adding a flag to keep values positive actually makes sense to
me, if the flag is properly
described (e.g. use positive flowaccumulation even for uncomplete
contributing areas).
User who selects to run r.watershed with this flag apparently knows
that he has
uncomplete watersheds and will be getting negative values that may
not be useful
for his application, so there is no need to tell him that he has a
problem - he would already know it
and for some reason wants to ignore it. I often found myself running
mapcalc abs on the accum
output for various reasons.
BUT for erosion modeling you really want to run r.watershed with
negative values - erosion models require
upslope contributing area as measure of water flow and if the
watershed is not complete,
water flow will be underestimated leading to underestimated erosion
rates. So the cells with
uncomplete contributing area need to be excluded from the
computation of erosion, and here
the negative values actually come handy.
Helena
I agree. This is what I'm suggesting. We cannot change the default
behavior for GRASS 6 and may not want to for GRASS 7. But it would be
good to have a way to turn this off in some circumstances.
Michael
On Mar 6, 2009, at 12:35 PM, Markus Metz wrote:
Michael Barton wrote:
A much more direct way is to give a warning for each problematic
basin in the output:
WARNING: part of basin XX extends beyond region extent;
accumulation values may be too low.
IMHO not very practical. When thousands of basins are calculated,
you would get flooded with these warnings.
Are people calculating so many basins that thousands would be
along the region extents?
It is technically possible to calculate thousands of basins,
therefore the code must consider that. IMHO, the code must consider
all technically possible scenarios, you never know what a module is
used for, and I would like it to be very generally applicable and
not restricted to certain scenarios.
Hmm, don't you need to know the exact flow accumulation to
calculate erosion/deposition? Are some "at least so much, but
probably much more" values really ok? BTW, RUSLE factors as
created by r.watershed are also only correct for cells with
positive flow accumulation.
It depends on how much difference there is. A couple cells would
not make much difference, 100's would make a difference. But I'd
still like to know which ones are a problem of course. I'm not
suggesting to make absolute value of accumulation a default (not
permitted in 6.5 anyway), but simply making it an option that the
user could exercise
Now I'm confused: negative values tell you where there is a
problem, but you don't want negative values, only positive values,
but then there should be additional, new output telling you where
the problems are?
Coming up with my technically possible scenarios: let's assume a
basin threshold of 10,000, that gives a max accumulation value for
exterior basins of 10,000. 10 cells within an exterior basin have
negative flow accumulation, that's only 0.1%. The absolute flow
accumulation value is probably very low, whereas the real flow
accumulation value can be anything, also >>> 10,000. Certain
calculations will be very different. The exterior basin is in this
case in reality an interior basin, but this can only be found out
by expanding the computational region.
The new SFD version should produce results identical to previous
versions. If not, I introduced a bug. The MFD version calculates
different, improved basins compared to SFD.
This is the issue. It happened when we tried MFD. I'm happy for
the better calculations and we'll redo our watershed boundaries.
But this points out some of the problems.
To be precise, the calculations are only better if MFD is regarded
as more accurate than SFD.
Or introduce a new output option named something like
"incomplete_basin_parts" where the incomplete parts are assigned
the negative value of the basin they belong to.
If this is better than warnings, that's OK too. I just think that
there might be a better way to do this than only by making the
accumulation values negative.
Maybe Helena can give some tips?
I personally am biased, I like the concept of the original
r.watershed with all that information in the output too much:-) See
also negative drainage direction, IMHO very useful.
Markus M
_______________________________________________
grass-dev mailing list
grass-dev@lists.osgeo.org
http://lists.osgeo.org/mailman/listinfo/grass-dev
_______________________________________________
grass-dev mailing list
grass-dev@lists.osgeo.org
http://lists.osgeo.org/mailman/listinfo/grass-dev