Opened 14 years ago
Last modified 8 years ago
#1082 new defect
r.random cover= gets stray data in first and last rows
Reported by: | hamish | Owned by: | |
---|---|---|---|
Priority: | normal | Milestone: | 6.4.6 |
Component: | Raster | Version: | svn-develbranch6 |
Keywords: | r.random | Cc: | |
CPU: | All | Platform: | All |
Description
Hi,
spearfish:
g.region rast=elevation.dem r.random in=elevation.dem cover=fields n=10000 rast=randout WARNING: Only [6248] random points created
the resulting "randout" map is nicely filled with random dots but on the first and last row of the output raster map there are chunks of solid dots which are created no matter what you do.
a more obvious example:
r.random in=elevation.dem cover=fields n=5 rast=randout Collecting Stats... 100% Writing raster map <randout> ... WARNING: Only [3] random points created # ok, so we should expect n=3 in the output map... r.univar randout | grep -w 'n:' n: 248
stray blocks of cells are in the same place regardless of n=.
also, for cover= it would be nice if random.c looped while(nt) so that it ran in multiple passes and you got as many points as you asked for, not less. (like v.random.cover addon does for points)
I thought about adding nt++ inside is_null_value(cover){...} in the column for-loop to counter-act the nt--, but I worry that may harm the overall randomness "density" of the rows for-loop. (just a hunch, I haven't proven that to myself)
thanks, Hamish
Change History (4)
comment:1 by , 14 years ago
CPU: | x86-32 → All |
---|---|
Milestone: | 6.4.0 → 6.4.1 |
Platform: | Linux → All |
comment:2 by , 13 years ago
Milestone: | 6.4.1 → 6.4.3 |
---|
comment:3 by , 11 years ago
Component: | Default → Raster |
---|
comment:4 by , 8 years ago
Milestone: | 6.4.3 → 6.4.6 |
---|
Replying to hamish:
This caused by the loop "continue"ing on null, without setting the output to null. So if the input cell is null but the cover isn't null, it ends up unconditionally writing the cover value to the output.
This would be more obvious except that elevation.dem has so few nulls. (BTW, I think that base and cover are the wrong way around in the example. Either that or both r.random and r.statistics have them the wrong way around; I don't actually know which is correct).
Merging the null tests into the main conditional gets around this issue, although the nc-- needs to also be moved into the body of the test. This should be fixed with r43716 (trunk).
The shortage of points is caused by it ignoring the number of nulls in the cover map when working out the probability of a given cell being chosen. The problem is, it can't work out the right answer because it counts the number of nulls individually for each of the two maps, regardless of whether they are disjoint or overlapping.
This one is a bit more problematic to fix, and if I start, I'm probably going to end up trying to fix everything else which is wrong with r.random (e.g. the code is far more complex than it has a right to be, due to trying to process the data in its native format rather than just using DCELL internally).
Also, the way that input= and cover= work is illogical; if you specify cover=, input= behaves as a base map; if you don't specify cover=, input= behaves as a cover map. It would make more sense for the options to be named base= and cover= or base= and input=.