Skip to content

Commit

Permalink
Improve grouped stations and tile rendering (#178)
Browse files Browse the repository at this point in the history
Deployment is timing out because of highly inefficient spatial queries
for the grouped station, e.g.
https://github.com/hiddewie/OpenRailwayMap-vector/actions/runs/12341057178
  • Loading branch information
hiddewie authored Dec 16, 2024
1 parent 0d31fce commit f1201a2
Show file tree
Hide file tree
Showing 4 changed files with 67 additions and 105 deletions.
39 changes: 14 additions & 25 deletions api/prepare_facilities.sql
Original file line number Diff line number Diff line change
Expand Up @@ -44,30 +44,19 @@ CREATE TABLE openrailwaymap_facilities_for_search AS
geom
FROM (
SELECT DISTINCT ON (osm_id, key, value, name, railway, station, railway_ref, route_count, geom)
osm_id,
(each(name_tags)).key AS key,
(each(name_tags)).value AS value,
name,
railway,
station,
railway_ref,
route_count,
geom
FROM (
SELECT
osm_id,
name,
railway,
station,
railway_ref,
name_tags,
route_count,
ST_Centroid(way) AS geom
FROM stations_with_route_counts
WHERE
railway IN ('station', 'halt', 'tram_stop', 'service_station', 'yard', 'junction', 'spur_junction', 'crossover', 'site')
-- TODO support other states as well
) AS organised
) AS duplicated;
osm_id,
(each(name_tags)).key AS key,
(each(name_tags)).value AS value,
name,
railway,
station,
railway_ref,
route_count,
center as geom
FROM stations_with_route_counts
WHERE
railway IN ('station', 'halt', 'tram_stop', 'service_station', 'yard', 'junction', 'spur_junction', 'crossover', 'site')
-- TODO support other states as well
) AS duplicated;

CREATE INDEX openrailwaymap_facilities_name_index ON openrailwaymap_facilities_for_search USING gin(terms);
68 changes: 43 additions & 25 deletions import/sql/get_station_importance.sql
Original file line number Diff line number Diff line change
Expand Up @@ -61,39 +61,57 @@ CREATE OR REPLACE VIEW station_nodes_platforms_rel_count AS
-- or about 20 to 30 minutes for the whole planet
CREATE MATERIALIZED VIEW IF NOT EXISTS stations_with_route_counts AS
SELECT
MIN(id) as id,
MIN(osm_id) as osm_id,
id,
osm_id,
name,
station,
railway_ref,
railway,
MAX(route_count) as route_count,
hstore(string_agg(nullif(name_tags::text, ''), ',')) as name_tags,
ST_RemoveRepeatedPoints(ST_Collect(way)) as way
route_count,
name_tags,
ST_Centroid(way) as center,
ST_Buffer(ST_ConvexHull(way), 50) as buffered,
ST_NumGeometries(way) as count
FROM (
SELECT
*,
ST_ClusterDBSCAN(way, 400, 1) OVER (PARTITION BY name, station, railway_ref, railway) AS cluster_id
MIN(id) as id,
MIN(osm_id) as osm_id,
name,
station,
railway_ref,
railway,
MAX(route_count) as route_count,
hstore(string_agg(nullif(name_tags::text, ''), ',')) as name_tags,
ST_RemoveRepeatedPoints(ST_Collect(way)) as way
FROM (
SELECT MIN(id) as id, MIN(osm_id) as osm_id, name, station, railway_ref, railway, ARRAY_LENGTH(ARRAY_AGG(DISTINCT route_id), 1) AS route_count, name_tags, way
SELECT
*,
ST_ClusterDBSCAN(way, 400, 1) OVER (PARTITION BY name, station, railway_ref, railway) AS cluster_id
FROM (
SELECT id, osm_id, name, station, railway_ref, railway, UNNEST(route_ids) AS route_id, name_tags, way
FROM station_nodes_stop_positions_rel_count
SELECT MIN(id) as id, MIN(osm_id) as osm_id, name, station, railway_ref, railway, ARRAY_LENGTH(ARRAY_AGG(DISTINCT route_id), 1) AS route_count, name_tags, way
FROM (
SELECT id, osm_id, name, station, railway_ref, railway, UNNEST(route_ids) AS route_id, name_tags, way
FROM station_nodes_stop_positions_rel_count
UNION ALL
SELECT id, osm_id, name, station, railway_ref, railway, UNNEST(route_ids) AS route_id, name_tags, way
FROM station_nodes_platforms_rel_count
) AS a
GROUP BY name, station, railway_ref, railway, way, name_tags
UNION ALL
SELECT id, osm_id, name, station, railway_ref, railway, UNNEST(route_ids) AS route_id, name_tags, way
FROM station_nodes_platforms_rel_count
) AS a
GROUP BY name, station, railway_ref, railway, way, name_tags
UNION ALL
SELECT id, osm_id, name, station, railway_ref, railway, 0 AS route_count, name_tags, way
FROM stations
WHERE railway IN ('station', 'halt', 'tram_stop', 'service_station', 'yard', 'junction', 'spur_junction', 'crossover', 'site')
) AS grouped_facilities
) AS facilities
GROUP BY name, station, railway_ref, railway, cluster_id
-- ORDER BY is required to ensure that the larger route_count is used.
ORDER BY name, station, railway_ref, railway, route_count DESC;
SELECT id, osm_id, name, station, railway_ref, railway, 0 AS route_count, name_tags, way
FROM stations
WHERE railway IN ('station', 'halt', 'tram_stop', 'service_station', 'yard', 'junction', 'spur_junction', 'crossover', 'site')
) AS grouped_facilities
) AS facilities
GROUP BY name, station, railway_ref, railway, cluster_id
-- ORDER BY is required to ensure that the larger route_count is used.
ORDER BY name, station, railway_ref, railway, route_count DESC
) as source_facilities;

CREATE INDEX IF NOT EXISTS stations_with_route_counts_geom_index
CREATE INDEX IF NOT EXISTS stations_with_route_counts_center_index
ON stations_with_route_counts
USING GIST(way);
USING GIST(center);

CREATE INDEX IF NOT EXISTS stations_with_route_counts_buffered_index
ON stations_with_route_counts
USING GIST(buffered);
40 changes: 9 additions & 31 deletions import/sql/tile_views.sql
Original file line number Diff line number Diff line change
Expand Up @@ -139,7 +139,7 @@ CREATE OR REPLACE VIEW standard_railway_text_stations_low AS
SELECT
id,
osm_id,
ST_Centroid(way) as way,
center as way,
railway_ref as label
FROM stations_with_route_counts
WHERE
Expand All @@ -153,7 +153,7 @@ CREATE OR REPLACE VIEW standard_railway_text_stations_med AS
SELECT
id,
osm_id,
ST_Centroid(way) as way,
center as way,
railway_ref as label
FROM stations_with_route_counts
WHERE
Expand All @@ -166,7 +166,7 @@ CREATE OR REPLACE VIEW standard_railway_text_stations AS
SELECT
id,
osm_id,
way,
center as way,
railway,
station,
railway_ref as label,
Expand All @@ -187,44 +187,22 @@ CREATE OR REPLACE VIEW standard_railway_text_stations AS
ELSE 50
END AS rank,
count
FROM (
SELECT
id,
osm_id,
ST_Centroid(way) as way,
railway,
route_count,
station,
railway_ref,
name,
ST_NumGeometries(way) as count
FROM stations_with_route_counts
WHERE railway IN ('station', 'halt', 'service_station', 'yard', 'junction', 'spur_junction', 'crossover', 'site', 'tram_stop')
AND name IS NOT NULL
) AS r
FROM stations_with_route_counts
WHERE railway IN ('station', 'halt', 'service_station', 'yard', 'junction', 'spur_junction', 'crossover', 'site', 'tram_stop')
AND name IS NOT NULL
ORDER by rank DESC NULLS LAST, route_count DESC NULLS LAST;

CREATE OR REPLACE VIEW standard_railway_grouped_stations AS
SELECT
id,
osm_id,
way,
buffered as way,
railway,
station,
railway_ref as label,
name
FROM (
SELECT
id,
osm_id,
ST_Buffer(ST_ConvexHull(way), 50) as way,
railway,
station,
railway_ref,
name
FROM stations_with_route_counts
WHERE railway IN ('station', 'halt', 'service_station', 'yard', 'junction', 'spur_junction', 'crossover', 'site', 'tram_stop')
) AS r;
FROM stations_with_route_counts
WHERE railway IN ('station', 'halt', 'service_station', 'yard', 'junction', 'spur_junction', 'crossover', 'site', 'tram_stop');

CREATE OR REPLACE VIEW standard_railway_symbols AS
SELECT
Expand Down
25 changes: 1 addition & 24 deletions proxy/js/styles.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -1387,32 +1387,9 @@ const layers = Object.fromEntries(knownThemes.map(theme => [theme, {
{
id: 'railway_grouped_stations',
type: 'fill',
minzoom: 8,
minzoom: 13,
source: 'openrailwaymap_standard',
'source-layer': 'standard_railway_grouped_stations',
filter: ['step', ['zoom'],
['all',
['==', ['get', 'railway'], 'station'],
['!=', ['get', 'station'], 'light_rail'],
['!=', ['get', 'station'], 'subway'],
['!=', ['get', 'station'], 'funicular'],
],
9,
['all',
['any',
['==', ['get', 'railway'], 'station'],
['==', ['get', 'railway'], 'halt'],
],
['!=', ['get', 'station'], 'funicular'],
],
10,
['all',
['!=', ['get', 'railway'], 'tram_stop'],
['!=', ['get', 'station'], 'funicular'],
],
13,
['!=', ['get', 'station'], 'funicular'],
],
paint: {
'fill-color': ['case',
['==', ['get', 'railway'], 'tram_stop'], colors[theme].styles.standard.tram,
Expand Down

0 comments on commit f1201a2

Please sign in to comment.