[postgis-users] Fast collect() aggregate

strk strk at keybit.net
Tue Oct 28 08:59:48 PST 2003


I've made the fast collect() aggregate.
It uses geom_accum() as state transaction function
and a newly made collect_garray() as final function.

Running time to collect  8109 objects in 8102 geometries
goes from 32 minutes to less then 5 minutes.

I strongly belive no much more memory is used by new implementation
since array-accumulated geometries will be (in this case) bigger
then result collection by 8102 geometry headers (number of geoms in input).

Memory usage evaluation - though - is not easy with postgresql.

Anyway: here is how to enable 'fastcollect':

If you did not already do it for 'fastunion' create the geom_accum() function:

        CREATE FUNCTION geom_accum (geometry[],geometry)
                RETURNS geometry[]
                AS '$libdir/../libpostgis.so.0.8'
                LANGUAGE 'C';

Create the new collect_garray function and the aggregate:

        CREATE FUNCTION collect_garray (geometry[])
                RETURNS geometry
                AS '$libdir/../libpostgis.so.0.8'
                LANGUAGE 'C';

        CREATE AGGREGATE fastcollect (
                sfunc = geom_accum,
                basetype = geometry,
                stype = geometry[],
                finalfunc = collect_garray
        );
                                                        [

PS: remember to get in sync with CVS.

--strk;



More information about the postgis-users mailing list