21. Geometry Constructing Exercises¶
Here’s a reminder of some of the functions we have seen. Hint: they should be useful for the exercises!
sum(expression) aggregate to return a sum for a set of records
ST_Area(geometry) returns the area of the geometry
ST_Centroid(geometry) returns the
geometry
centroidST_Transform(geometry, srid) converts
geometries
into different spatial reference systemsST_Buffer(geometry, radius) returns an expanded
geometry
shapeST_Contains(geometry1, geometry2) returns true if geometry1 contains geometry2
ST_Union(geometry[]) returns the aggregate union of all geometries in the group
ST_GeometryType(geometry) returns the type of the geometry
ST_NumGeometries(geometry) returns the number of geometries in a collection or 1 for simple geometries
ST_Intersection(geometry, geometry) returns the area that the two input geometries share in common
Remember the tables we have available:
nyc_census_blocks
name, popn_total, boroname, geom
nyc_streets
name, type, geom
nyc_subway_stations
name, geom
nyc_neighborhoods
name, boroname, geom
21.1. Exercises¶
How many census blocks don’t contain their own centroid?
SELECT Count(*) FROM nyc_census_blocks WHERE NOT ST_Contains( geom, ST_Centroid(geom) );
481
Union all the census blocks into a single output. What kind of geometry is it? How many parts does it have?
CREATE TABLE nyc_census_blocks_merge AS SELECT ST_Union(geom) AS geom FROM nyc_census_blocks; SELECT ST_GeometryType(geom) FROM nyc_census_blocks_merge;
ST_MultiPolygon
SELECT ST_NumGeometries(geom) FROM nyc_census_blocks_merge;
63
What is the area of a one unit buffer around the origin? How different is it from what you would expect? Why?
SELECT ST_Area(ST_Buffer('POINT(0 0)', 1));
3.121445152258052
참고
A unit circle (circle with radius of one) should have an area of pi, 3.1415926… The difference is due to the linear stroking of the edges of the buffer. The buffer has a finite number of edges. Increasing the number of edges in the buffer will get the value closer to pi, but it will always be smaller due to the linearization.
The Brooklyn neighborhoods of ‘Park Slope’ and ‘Carroll Gardens’ are going to war! Construct a polygon delineating a 100 meter wide DMZ on the border between the neighborhoods. What is the area of the DMZ?
CREATE TABLE brooklyn_dmz AS SELECT ST_Intersection( ST_Buffer(ps.geom, 50), ST_Buffer(cg.geom, 50)) AS geom FROM nyc_neighborhoods ps, nyc_neighborhoods cg WHERE ps.name = 'Park Slope' AND cg.name = 'Carroll Gardens'; SELECT ST_Area(geom) FROM brooklyn_dmz;
참고
It is easy to buffer both the neighborhoods of interest, but to get the intersection requires a self-join of the table, creating one relation (
ps
) with just the 《Park Slope》 record and another (cg
) with just the 《Carroll Gardens》 record. Note that the area of the intersection is in square meters because we are still working in UTM 18 (EPSG:26918).180990.964207547