[GRASS-dev] Re: [GRASS-user] problems using r.proj with large
data set
Glynn Clements
glynn at gclements.plus.com
Tue Dec 19 08:19:00 EST 2006
Glynn Clements wrote:
> > > Assuming that it works out okay, I'll probably end up merging
> > > r.proj.seg into r.proj, with the macro handling the details of whether
> > > to read from a tile cache (large maps) or from a single block of
> > > memory (small maps).
> >
> > This makes sense. For small maps is it much faster to not use the cache?
>
> I haven't performed timings; to be of much use, they would need to be
> done with "real-world" cases.
>
> As it stands, even if you made the cache large enough to hold the
> entire map, it would currently get written out to a temporary file
> then read back in on demand.
>
> There's bound to be some overhead to using an extra level of
> indirection, but it's probably trivial compared to the projection
> calculations (and particularly compared to bicubic interpolation).
>
> One of the next things which needs to be done to r.proj.seg is to add
> an option to set the cache size. Once that's done, I'll look into
> trapping the case where the cache can hold the entire map, and
> eliminate the temporary file in that situation.
I've done that; some (not exactly representative) results reprojecting
GTOPO30 to spearfish (30m, 634 cols x 477 rows):
$ r.proj input=w140n90 location=global mapset=glynn output=proj method=nearest
real 0m2.971s
user 0m2.922s
sys 0m0.023s
$ r.proj.seg memory=100 input=w140n90 location=global mapset=glynn output=proj method=nearest
real 0m2.929s
user 0m2.891s
sys 0m0.018s
$ r.proj input=w140n90 location=global mapset=glynn output=proj method=bilinear
real 0m3.419s
user 0m3.280s
sys 0m0.106s
$ r.proj.seg input=w140n90 location=global mapset=glynn output=proj method=bilinear memory=100
real 0m3.461s
user 0m3.346s
sys 0m0.088s
$ r.proj input=w140n90 location=global mapset=glynn output=proj method=cubic
real 0m3.877s
user 0m3.731s
sys 0m0.111s
$ r.proj.seg memory=100 input=w140n90 location=global mapset=glynn output=proj method=cubic
real 0m4.169s
user 0m4.058s
sys 0m0.093s
The speed of r.proj.seg relative to r.proj ranges from ~1.4% faster
(nearest) to ~7.5% slower (bicubic). If those results hold up for
representative data, r.proj.seg can replace r.proj.
--
Glynn Clements <glynn at gclements.plus.com>
More information about the grass-dev
mailing list