[postgis-users] Deleting an arbitrary polygon
Obe, Regina
robe.dnd at cityofboston.gov
Fri Sep 26 06:34:39 PDT 2008
I'm hoping these tricks (well maybe not this particular example) will be
much easier when 8.4 comes out and supports WITH RECURSIVE CTEs. I
think the 8.4 beta already has a good chunk of the WITH RECURSIVE
functionality in it, but sadly haven't had a chance to test drive it.
It would be interesting to see how it performs in these type of use
cases.
For those wondering - WITH RECURSIVE is along the lines of what I think
Martin said he loved about Oracle their CONNECT BY
http://lin-ear-th-inking.blogspot.com/2007/09/grokking-hierarchical-quer
ies-in-oracle.html
though Oracle is badly none ANSI compliant granted it may be arguably
more succinct in many cases
http://asktom.oracle.com/pls/asktom/f?p=100:11:0::::P11_QUESTION_ID:5313
9879276132
But it PostgreSQL 8.4 follows the ANSI standard CTE convention supported
by SQL Server 2005+
http://www.4guysfromrolla.com/webtech/071906-1.shtml#postadlink
And DB II
http://wiki.ibmdatabasemag.com/index.php/Celko_SQL_Puzzle
Thanks,
Regina
-----Original Message-----
From: postgis-users-bounces at postgis.refractions.net
[mailto:postgis-users-bounces at postgis.refractions.net] On Behalf Of
Burgholzer,Robert
Sent: Friday, September 26, 2008 9:04 AM
To: PostGIS Users Discussion
Subject: RE: [postgis-users] Deleting an arbitrary polygon
This is interesting, so I am kind of thinking in email ...
Assumptions:
- a good goal would be to eliminate the least number of polygons to
create a non-overlapping set
- polygons which overlap multiple polygons would therefore be better
candidates, or at least
- Martin is probably right that this will take multiple passes
Query components:
- Find # of polygons overlapped by each:
SELECT a.poly_id, count(b.poly_id) as overlap
FROM geo_table AS a, geo_table AS b
WHERE st_intersects(a.the_geom, b.the_geom)
AND a.poly_id <> b.poly_id
GROUP BY a.poly_id
ORDER BY overlap DESC
So, I repeat the following until my set has no more overlapping polygons
DELETE from geo_table where poly_id in (
SELECT poly_id FROM
( SELECT a. poly_id, count(b. poly_id) as overlap
FROM geo_table AS a, geo_table AS b
WHERE intersects(a.the_geom, b.the_geom)
AND a. poly_id <> b. poly_id
GROUP BY a. poly_id
ORDER BY overlap DESC
) as foo
LIMIT 1
);
-- and I check to see how many remain with:
SELECT a. poly_id, count(b. poly_id) as overlap
FROM geo_table AS a, geo_table AS b
WHERE intersects(a.the_geom, b.the_geom)
AND a. poly_id <> b. poly_id
GROUP BY a. poly_id
ORDER BY overlap DESC
The ORDER BY clause is a crucial part of this I think. If you order
DESC, as I have done, then you favor leaving small "islands" in your
space, since you would most likely (but not certainly) be targeting
large polygons that contained the smaller ones. If you were to choose
the opposite approach, deleting polygons with smaller numbers of
overlaps, you may tend to weed out small islands, and leave large
"continents". However, there would be cases in which these
probabilities were not true. Regardless, there would most likely be a
different resulting set of remaining, non-overlapping polygons from
either approach.
HTH,
r.b.
Robert W. Burgholzer
Surface Water Modeler
Office of Water Supply and Planning
Virginia Department of Environmental Quality
rwburgholzer at deq.virginia.gov
804-698-4405
Open Source Modeling Tools:
http://sourceforge.net/projects/npsource/
-----Original Message-----
From: postgis-users-bounces at postgis.refractions.net
[mailto:postgis-users-bounces at postgis.refractions.net] On Behalf Of
Martin Davis
Sent: Thursday, September 25, 2008 8:13 PM
To: PostGIS Users Discussion
Subject: Re: [postgis-users] Deleting an arbitrary polygon
AFAIK there is no way to do this in a single pass.
One way to do it iteratively is:
- add a column which will flag features which are "nonoverlapping" (and
which will be kept)
- choose one feature and flag it as nonoverlapping
- iterate {
- delete all features which overlap some "nonoverlapping" feature
- pick an unmarked feature and flag it as "nonoverlapping"
- exit if all features are flagged as "nonoverlapping"
}
This is probably going to be slow...
Dylan Lorimer wrote:
> Hey PostGIS Friends, here's a problem that's stumping me, hoping you
can help:
>
> I have a bunch of polygons, many of which overlap with each other. I
> would like to trim down the set of polygons to only those that do not
> overlap. I'm not particular about which I delete, so long as they
> overlap by a certain %.
>
> Any thoughts on how to do this? I was trying for a self join but can't
> figure out how to not to delete all polygons that overlap.
>
> Cheers,
> dylan
> _______________________________________________
> postgis-users mailing list
> postgis-users at postgis.refractions.net
> http://postgis.refractions.net/mailman/listinfo/postgis-users
>
>
--
Martin Davis
Senior Technical Architect
Refractions Research, Inc.
(250) 383-3022
_______________________________________________
postgis-users mailing list
postgis-users at postgis.refractions.net
http://postgis.refractions.net/mailman/listinfo/postgis-users
_______________________________________________
postgis-users mailing list
postgis-users at postgis.refractions.net
http://postgis.refractions.net/mailman/listinfo/postgis-users
-----------------------------------------
The substance of this message, including any attachments, may be
confidential, legally privileged and/or exempt from disclosure
pursuant to Massachusetts law. It is intended
solely for the addressee. If you received this in error, please
contact the sender and delete the material from any computer.
More information about the postgis-users
mailing list