[geos-devel] Current project status
Yury A. Bychkov
ybychkov at direct.ca
Sun Nov 24 17:42:15 EST 2002
There still seems to be a very large number of useless Coordinate() constructor
calls. I'd suggest waiting so see if I can eliminate a large portion of them
easily enough (I'll know if a couple of days). Then I can add self-intersection
speedups and we'll see what the performance will be.
Yury
----- Original Message -----
From: "Martin Davis" <mbdavis at VividSolutions.com>
To: "GEOS Development List" <geos-devel at geos.refractions.net>
Sent: Sunday, November 24, 2002 2:37 PM
Subject: RE: [geos-devel] Current project status
So my take on the statistics below is that GEOS is now somewhat faster than JTS
(at least, JTS before the self-intersection check speedup). So we may be at the
point of diminishing returns for increasing performance using the current
algorithms.
The changes to incorporate the self-intersection check speedup are relatively
minor - I think we should incorporate them now. I will send the code to Yury to
port.
Martin Davis, Senior Technical Specialist
Vivid Solutions Inc.
Suite #1A-2328 Government Street Victoria, B.C. V8T 5G5
Phone: (250) 385 6040 Fax: (250) 385 6046
EMail: mbdavis at vividsolutions.com Web: www.vividsolutions.com
> -----Original Message-----
> From: Yury A. Bychkov [mailto:ybychkov at direct.ca]
> Sent: Sunday, November 24, 2002 2:59 AM
> To: geos-devel at geos.refractions.net
> Subject: [geos-devel] Current project status
>
>
> 1. RobustLineIntersector has been updated.
> 2. MonotoneChainIndexer::getChainStartIndices was a biggest
> single contributor
> to Coordinate() calls (~20% of total calls). I've replaced instances
> CoordinateList with references to gauge performance increase
> (See results
> below).
> 3. Currently I am redoing the CoordinateList (and calls to
> its methods) with
> respect to the suggestions on the list.
>
> Here are the performance results (P4-2.53):
> No modifications:
> # overlapping MCs: 406
> # segment intersection tests: 226
> n Pts: 1000 Executed in 30 ms.
> # overlapping MCs: 406
> # segment intersection tests: 278
> n Pts: 2000 Executed in 50 ms.
> # overlapping MCs: 406
> # segment intersection tests: 248
> n Pts: 4000 Executed in 100 ms.
> # overlapping MCs: 406
> # segment intersection tests: 250
> n Pts: 8000 Executed in 150 ms.
> # overlapping MCs: 406
> # segment intersection tests: 272
> n Pts: 16000 Executed in 391 ms.
> # overlapping MCs: 406
> # segment intersection tests: 264
> n Pts: 32000 Executed in 751 ms.
> # overlapping MCs: 406
> # segment intersection tests: 236
> n Pts: 64000 Executed in 1513 ms.
> # overlapping MCs: 406
> # segment intersection tests: 264
> n Pts: 128000 Executed in 3395 ms.
> # overlapping MCs: 406
> # segment intersection tests: 238
> n Pts: 256000 Executed in 7120 ms.
> # overlapping MCs: 406
> # segment intersection tests: 232
> n Pts: 512000 Executed in 12788 ms.
> # overlapping MCs: 406
> # segment intersection tests: 232
> n Pts: 1024000 Executed in 25296 ms.
>
> New RobustLineIntersector:
> # overlapping MCs: 406
> # segment intersection tests: 226
> n Pts: 1000 Executed in 20 ms.
> # overlapping MCs: 406
> # segment intersection tests: 278
> n Pts: 2000 Executed in 40 ms.
> # overlapping MCs: 406
> # segment intersection tests: 248
> n Pts: 4000 Executed in 90 ms.
> # overlapping MCs: 406
> # segment intersection tests: 250
> n Pts: 8000 Executed in 130 ms.
> # overlapping MCs: 406
> # segment intersection tests: 272
> n Pts: 16000 Executed in 311 ms.
> # overlapping MCs: 406
> # segment intersection tests: 264
> n Pts: 32000 Executed in 621 ms.
> # overlapping MCs: 406
> # segment intersection tests: 236
> n Pts: 64000 Executed in 1252 ms.
> # overlapping MCs: 406
> # segment intersection tests: 264
> n Pts: 128000 Executed in 2754 ms.
> # overlapping MCs: 406
> # segment intersection tests: 238
> n Pts: 256000 Executed in 5688 ms.
> # overlapping MCs: 406
> # segment intersection tests: 232
> n Pts: 512000 Executed in 10895 ms.
> # overlapping MCs: 406
> # segment intersection tests: 232
> n Pts: 1024000 Executed in 22042 ms.
>
> CoordinateList instances replaced with references in
> MonotoneChainIndexer; some
> tweaking of CoordinateList:
> # overlapping MCs: 406
> # segment intersection tests: 226
> n Pts: 1000 Executed in 20 ms.
> # overlapping MCs: 406
> # segment intersection tests: 278
> n Pts: 2000 Executed in 30 ms.
> # overlapping MCs: 406
> # segment intersection tests: 248
> n Pts: 4000 Executed in 70 ms.
> # overlapping MCs: 406
> # segment intersection tests: 250
> n Pts: 8000 Executed in 120 ms.
> # overlapping MCs: 406
> # segment intersection tests: 272
> n Pts: 16000 Executed in 270 ms.
> # overlapping MCs: 406
> # segment intersection tests: 264
> n Pts: 32000 Executed in 500 ms.
> # overlapping MCs: 406
> # segment intersection tests: 236
> n Pts: 64000 Executed in 991 ms.
> # overlapping MCs: 406
> # segment intersection tests: 264
> n Pts: 128000 Executed in 2023 ms.
> # overlapping MCs: 406
> # segment intersection tests: 238
> n Pts: 256000 Executed in 4276 ms.
> # overlapping MCs: 406
> # segment intersection tests: 232
> n Pts: 512000 Executed in 7861 ms.
> # overlapping MCs: 406
> # segment intersection tests: 232
> n Pts: 1024000 Executed in 15993 ms.
>
>
> Yury
>
>
>
> _______________________________________________
> geos-devel mailing list
> geos-devel at geos.refractions.net
> http://geos.refractions.net/mailman/listinfo/geos-devel
>
_______________________________________________
geos-devel mailing list
geos-devel at geos.refractions.net
http://geos.refractions.net/mailman/listinfo/geos-devel
More information about the geos-devel
mailing list