[postgis-devel] CreateTopoGeom -- why can't create polygon topofrom edges

Paragon Corporation lr at pcorp.us
Tue Sep 13 23:21:38 PDT 2011


Actually if I compensate for the fact the data is imperfect to begin with,
things look much better.
 
  
UPDATE boston.nei 
SET topo = 
    topology.CreateTopoGeom('topo_boston' 
        ,3,6 
        , foo.bedges) 
FROM (SELECT n.gid,  topology.TopoElementArray_Agg(DISTINCT
ARRAY[f.face_id,3]) As bedges 
FROM boston.nei As n 
            INNER JOIN topo_boston.face As f ON n.geom && f.mbr 
        WHERE 
       ST_Covers(n.geom, topology.ST_GetFaceGeometry('topo_boston',
f.face_id)) 
        OR 
      (  ST_Intersects(n.geom, topology.ST_GetFaceGeometry('topo_boston',
f.face_id)) 
            AND ST_Area(ST_Intersection(n.geom,
topology.ST_GetFaceGeometry('topo_boston', f.face_id) ) ) > 
                ST_Area(topology.ST_GetFaceGeometry('topo_boston',
f.face_id))*0.6) 
            GROUP BY n.gid) As foo 
WHERE foo.gid = boston.nei.gid; 
 
It still would be nice though to have choice to form from polygons from
edges instead of just faces.
 
Thanks,
Regina
 
 


  _____  

From: postgis-devel-bounces at postgis.refractions.net
[mailto:postgis-devel-bounces at postgis.refractions.net] On Behalf Of Paragon
Corporation
Sent: Wednesday, September 14, 2011 12:18 AM
To: 'PostGIS Development Discussion'
Cc: 'PostGIS Users Discussion'
Subject: [postgis-devel] CreateTopoGeom -- why can't create polygon topofrom
edges


strk and Andrea,
 
Perhaps this is just illegal by specs, but I'm wondering why I couldn't
logically create a multi/poly topogeometry from edges that form the boundary
of a polygon? or do the specs just not
allow that.  I see the CreateTopoGeom just throws an error if I dear try to
create a polygon from edges.
 
I was trying to take my neighborhoods table and convert my geometries to
topo geoms.  So I used this update statement.  That's a lot of faces though.
I think it would be
much faster if I could have built from the edges of the boundaries.
 
UPDATE boston.nei
 SET topo = 
    topology.CreateTopoGeom('topo_boston'
        ,3,6
        , foo.bedges)
FROM (SELECT n.gid,  topology.TopoElementArray_Agg(DISTINCT
ARRAY[f.face_id,3]) As bedges
 FROM boston.nei As n
            INNER JOIN topo_boston.face As f ON n.geom && f.mbr
        WHERE ST_Covers(n.geom, topology.ST_GetFaceGeometry('topo_boston',
f.face_id))
            GROUP BY n.gid) As foo
WHERE foo.gid = boston.nei.gid;
 
It's also not quite what I hoped for but that could be because I'm still
missing faces or tiger doesn't care about Boston neighborhoods which is
quite possible or who ever drew the maps idea of streets are not aligned
with those of tiger.  See attached images -- my original geometry and the
topo column
generated from it.
 
Boston neighborhoods are kind of dumb since no one can agree on the
boundaries and people get into fist fights about it.  I think the same case
in Philadelphia.
 
 
Thanks,
Regina
 
 
 
 
 

-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.osgeo.org/pipermail/postgis-devel/attachments/20110914/d01fddfe/attachment.html>
-------------- next part --------------
A non-text attachment was scrubbed...
Name: original_nei2.png
Type: image/png
Size: 70233 bytes
Desc: not available
URL: <http://lists.osgeo.org/pipermail/postgis-devel/attachments/20110914/d01fddfe/attachment.png>
-------------- next part --------------
A non-text attachment was scrubbed...
Name: topo_nei2.png
Type: image/png
Size: 70122 bytes
Desc: not available
URL: <http://lists.osgeo.org/pipermail/postgis-devel/attachments/20110914/d01fddfe/attachment-0001.png>


More information about the postgis-devel mailing list