Compare commits
No commits in common. "master" and "last-used" have entirely different histories.
43
.env
@ -1,10 +1,7 @@
|
|||||||
# This file defines default environment variables for all images
|
# This file defines default environment variables for all images
|
||||||
|
|
||||||
# Layers definition and meta data
|
|
||||||
TILESET_FILE=openmaptiles.yaml
|
|
||||||
|
|
||||||
# Use 3-part patch version to ignore patch updates, e.g. 5.0.0
|
# Use 3-part patch version to ignore patch updates, e.g. 5.0.0
|
||||||
TOOLS_VERSION=5.3
|
TOOLS_VERSION=5.1
|
||||||
|
|
||||||
# Make sure these values are in sync with the ones in .env-postgres file
|
# Make sure these values are in sync with the ones in .env-postgres file
|
||||||
PGDATABASE=openmaptiles
|
PGDATABASE=openmaptiles
|
||||||
@ -13,43 +10,17 @@ PGPASSWORD=openmaptiles
|
|||||||
PGHOST=postgres
|
PGHOST=postgres
|
||||||
PGPORT=5432
|
PGPORT=5432
|
||||||
|
|
||||||
# BBOX may get overwritten by the computed bbox of the specific area:
|
QUICKSTART_MIN_ZOOM=0
|
||||||
# make generate-bbox-file
|
QUICKSTART_MAX_ZOOM=7
|
||||||
# By default, the Makefile will use the content of data/$(area).bbox file if it exists.
|
|
||||||
BBOX=-180.0,-85.0511,180.0,85.0511
|
|
||||||
|
|
||||||
# Which zooms to generate in make generate-tiles
|
|
||||||
MIN_ZOOM=0
|
|
||||||
MAX_ZOOM=7
|
|
||||||
|
|
||||||
# Use true (case sensitive) to allow data updates
|
|
||||||
DIFF_MODE=false
|
DIFF_MODE=false
|
||||||
|
|
||||||
|
BBOX=-180.0,-85.0511,180.0,85.0511
|
||||||
|
MIN_ZOOM=0
|
||||||
|
MAX_ZOOM=14
|
||||||
|
|
||||||
# Hide some output from Mapnik tile generation for clarity
|
# Hide some output from Mapnik tile generation for clarity
|
||||||
FILTER_MAPNIK_OUTPUT=1
|
FILTER_MAPNIK_OUTPUT=1
|
||||||
|
|
||||||
# Some area data like openstreetmap.fr can contain invalid references
|
# Some area data like openstreetmap.fr can contain invalid references
|
||||||
# that must be cleaned up before using it for borders -- set it to true.
|
# that must be cleaned up before using it for borders -- set it to true.
|
||||||
BORDERS_CLEANUP=false
|
BORDERS_CLEANUP=false
|
||||||
|
|
||||||
# The current setup assumes this file is placed inside the data/ dir
|
|
||||||
MBTILES_FILE=tiles.mbtiles
|
|
||||||
# This is the current repl_config.json location, pre-configured in the tools Dockerfile
|
|
||||||
# Makefile and quickstart replace it with the dynamically generated one, but we keep it here in case some other method is used to run.
|
|
||||||
IMPOSM_CONFIG_FILE=/usr/src/app/config/repl_config.json
|
|
||||||
|
|
||||||
# import-borders temp files - set them here to defaults, and override in the Makefile based on the area
|
|
||||||
BORDERS_CLEANUP_FILE=data/borders/cleanup.pbf
|
|
||||||
BORDERS_PBF_FILE=data/borders/filtered.pbf
|
|
||||||
BORDERS_CSV_FILE=data/borders/lines.csv
|
|
||||||
|
|
||||||
# Number of parallel processes to use when importing sql files
|
|
||||||
MAX_PARALLEL_PSQL=5
|
|
||||||
|
|
||||||
# Number of parallel threads to use when generating vector map tiles
|
|
||||||
COPY_CONCURRENCY=10
|
|
||||||
|
|
||||||
# Variables for generate tiles using PGquery
|
|
||||||
PGHOSTS_LIST=
|
|
||||||
NO_GZIP=1
|
|
||||||
USE_KEY_COLUMN=1
|
|
||||||
|
|||||||
18
.github/workflows/tests.yml
vendored
@ -20,10 +20,13 @@ jobs:
|
|||||||
- name: Run quickstart for a small area
|
- name: Run quickstart for a small area
|
||||||
env:
|
env:
|
||||||
area: monaco
|
area: monaco
|
||||||
MIN_ZOOM: 0
|
QUICKSTART_MIN_ZOOM: 0
|
||||||
MAX_ZOOM: 14
|
QUICKSTART_MAX_ZOOM: 14
|
||||||
QUIET: 1
|
|
||||||
run: |
|
run: |
|
||||||
|
# For now, change the quickstart values directly in the .env file
|
||||||
|
# TODO: We should probably use env vars instead
|
||||||
|
sed -i 's/QUICKSTART_MAX_ZOOM=7/QUICKSTART_MAX_ZOOM=14/g' .env
|
||||||
|
export QUIET=1
|
||||||
./quickstart.sh $area
|
./quickstart.sh $area
|
||||||
|
|
||||||
- name: Save quickstart.log
|
- name: Save quickstart.log
|
||||||
@ -39,7 +42,10 @@ jobs:
|
|||||||
|
|
||||||
performance:
|
performance:
|
||||||
name: Evaluate performance
|
name: Evaluate performance
|
||||||
runs-on: self-hosted
|
runs-on: ubuntu-latest
|
||||||
|
# Even though we technically don't need to wait for integrity test to finish,
|
||||||
|
# there is no point to run long perf test until we know the code is OK
|
||||||
|
needs: integrity_test
|
||||||
env:
|
env:
|
||||||
## Smaller tests (runs everything in about 30 minutes)
|
## Smaller tests (runs everything in about 30 minutes)
|
||||||
## Two test areas: equatorial-guinea and liechtenstein
|
## Two test areas: equatorial-guinea and liechtenstein
|
||||||
@ -103,7 +109,7 @@ jobs:
|
|||||||
with:
|
with:
|
||||||
path: perf_cache
|
path: perf_cache
|
||||||
# If profiling result cache has incompatible format, increase this "v" number
|
# If profiling result cache has incompatible format, increase this "v" number
|
||||||
key: "v12-${{ steps.calc.outputs.hash }}-${{ env.TEST_DATA_URL }}"
|
key: "v11-${{ steps.calc.outputs.hash }}-${{ env.TEST_DATA_URL }}"
|
||||||
|
|
||||||
- name: Load test data into DB and run performance test
|
- name: Load test data into DB and run performance test
|
||||||
id: main
|
id: main
|
||||||
@ -167,7 +173,7 @@ jobs:
|
|||||||
create_db() {
|
create_db() {
|
||||||
make clean
|
make clean
|
||||||
make init-dirs
|
make init-dirs
|
||||||
cp ../ci_cache/perf-test-areas-latest.osm.pbf data/perf-test-areas.osm.pbf
|
cp ../ci_cache/perf-test-areas-latest.osm.pbf data/perf-test-areas-latest.osm.pbf
|
||||||
make destroy-db
|
make destroy-db
|
||||||
make all
|
make all
|
||||||
make start-db
|
make start-db
|
||||||
|
|||||||
372
Makefile
@ -1,51 +1,41 @@
|
|||||||
#
|
|
||||||
# First section - common variable initialization
|
|
||||||
#
|
|
||||||
|
|
||||||
# Ensure that errors don't hide inside pipes
|
# Ensure that errors don't hide inside pipes
|
||||||
SHELL = /bin/bash
|
SHELL = /bin/bash
|
||||||
.SHELLFLAGS = -o pipefail -c
|
.SHELLFLAGS = -o pipefail -c
|
||||||
|
|
||||||
# Make all .env variables available for make targets
|
|
||||||
include .env
|
|
||||||
|
|
||||||
# Layers definition and meta data
|
|
||||||
TILESET_FILE ?= openmaptiles.yaml
|
|
||||||
|
|
||||||
# Options to run with docker and docker-compose - ensure the container is destroyed on exit
|
# Options to run with docker and docker-compose - ensure the container is destroyed on exit
|
||||||
# Containers run as the current user rather than root (so that created files are not root-owned)
|
# Containers run as the current user rather than root (so that created files are not root-owned)
|
||||||
DC_OPTS ?= --rm --user=$(shell id -u):$(shell id -g)
|
DC_OPTS?=--rm -u $(shell id -u):$(shell id -g)
|
||||||
|
|
||||||
DC_USER?=openmaptiles
|
|
||||||
DC_PASSWORD?=openmaptiles
|
|
||||||
|
|
||||||
# If set to a non-empty value, will use postgis-preloaded instead of postgis docker image
|
# If set to a non-empty value, will use postgis-preloaded instead of postgis docker image
|
||||||
USE_PRELOADED_IMAGE ?=
|
USE_PRELOADED_IMAGE?=
|
||||||
|
|
||||||
|
# If set, this file will be imported in the import-osm target
|
||||||
|
PBF_FILE?=
|
||||||
|
|
||||||
# Local port to use with postserve
|
# Local port to use with postserve
|
||||||
PPORT ?= 8090
|
PPORT?=8090
|
||||||
export PPORT
|
export PPORT
|
||||||
# Local port to use with tileserver
|
# Local port to use with tileserver
|
||||||
TPORT ?= 8081
|
TPORT?=8081
|
||||||
export TPORT
|
export TPORT
|
||||||
|
|
||||||
# Allow a custom docker-compose project name
|
# Allow a custom docker-compose project name
|
||||||
ifeq ($(strip $(DC_PROJECT)),)
|
ifeq ($(strip $(DC_PROJECT)),)
|
||||||
DC_PROJECT := $(notdir $(shell pwd))
|
override DC_PROJECT:=$(notdir $(shell pwd))
|
||||||
DOCKER_COMPOSE := docker-compose
|
DOCKER_COMPOSE:= docker-compose
|
||||||
else
|
else
|
||||||
DOCKER_COMPOSE := docker-compose --project-name $(DC_PROJECT)
|
DOCKER_COMPOSE:= docker-compose --project-name $(DC_PROJECT)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
# Make some operations quieter (e.g. inside the test script)
|
# Make some operations quieter (e.g. inside the test script)
|
||||||
ifeq ($(strip $(QUIET)),)
|
ifeq ($(strip $(QUIET)),)
|
||||||
QUIET_FLAG :=
|
QUIET_FLAG:=
|
||||||
else
|
else
|
||||||
QUIET_FLAG := --quiet
|
QUIET_FLAG:=--quiet
|
||||||
endif
|
endif
|
||||||
|
|
||||||
# Use `xargs --no-run-if-empty` flag, if supported
|
# Use `xargs --no-run-if-empty` flag, if supported
|
||||||
XARGS := xargs $(shell xargs --no-run-if-empty </dev/null 2>/dev/null && echo --no-run-if-empty)
|
XARGS:=xargs $(shell xargs --no-run-if-empty </dev/null 2>/dev/null && echo --no-run-if-empty)
|
||||||
|
|
||||||
# If running in the test mode, compare files rather than copy them
|
# If running in the test mode, compare files rather than copy them
|
||||||
TEST_MODE?=no
|
TEST_MODE?=no
|
||||||
@ -57,139 +47,12 @@ else
|
|||||||
GRAPH_PARAMS=./layers
|
GRAPH_PARAMS=./layers
|
||||||
endif
|
endif
|
||||||
|
|
||||||
# Set OpenMapTiles host
|
|
||||||
OMT_HOST := http://$(firstword $(subst :, ,$(subst tcp://,,$(DOCKER_HOST))) localhost)
|
|
||||||
export OMT_HOST
|
|
||||||
|
|
||||||
# This defines an easy $(newline) value to act as a "\n". Make sure to keep exactly two empty lines after newline.
|
|
||||||
define newline
|
|
||||||
|
|
||||||
|
|
||||||
endef
|
|
||||||
|
|
||||||
|
|
||||||
#
|
|
||||||
# Determine area to work on
|
|
||||||
# If $(area) parameter is not set, and only one *.osm.pbf file is found in ./data, use it as $(area).
|
|
||||||
# Otherwise, all make targets requiring an area will show an error.
|
|
||||||
# Note: If no *.osm.pbf files are found, once the users call "make download area=..."
|
|
||||||
# they will not need to use an "area=" parameter again because there will be just a single file.
|
|
||||||
#
|
|
||||||
|
|
||||||
# historically we have been using $(area) rather than $(AREA), so make both work
|
|
||||||
area ?= $(AREA)
|
|
||||||
# Ensure the $(area) param is set, or try to automatically determine it based on available data files
|
|
||||||
ifeq ($(strip $(area)),)
|
|
||||||
# An $(area) parameter is not set. If only one *.osm.pbf file is found in ./data, use it as $(area).
|
|
||||||
data_files := $(shell find data -name '*.osm.pbf' 2>/dev/null)
|
|
||||||
ifneq ($(word 2,$(data_files)),)
|
|
||||||
define assert_area_is_given
|
|
||||||
@echo ""
|
|
||||||
@echo "ERROR: The 'area' parameter or environment variable have not been set, and there several 'area' options:"
|
|
||||||
@$(patsubst data/%.osm.pbf,echo " '%'";,$(data_files))
|
|
||||||
@echo ""
|
|
||||||
@echo "To specify an area use:"
|
|
||||||
@echo " make $@ area=<area-id>"
|
|
||||||
@echo ""
|
|
||||||
@exit 1
|
|
||||||
endef
|
|
||||||
else
|
|
||||||
ifeq ($(word 1,$(data_files)),)
|
|
||||||
define assert_area_is_given
|
|
||||||
@echo ""
|
|
||||||
@echo "ERROR: The 'area' parameter (or env var) has not been set, and there are no data/*.osm.pbf files"
|
|
||||||
@echo ""
|
|
||||||
@echo "To specify an area use"
|
|
||||||
@echo " make $@ area=<area-id>"
|
|
||||||
@echo ""
|
|
||||||
@echo "To download an area, use make download area=<area-id>"
|
|
||||||
@echo "To list downloadable areas, use make list-geofabrik and/or make list-bbbike"
|
|
||||||
@exit 1
|
|
||||||
@echo ""
|
|
||||||
endef
|
|
||||||
else
|
|
||||||
# Keep just the name of the data file, without the .osm.pbf extension
|
|
||||||
area := $(patsubst data/%.osm.pbf,%,$(data_files))
|
|
||||||
# Rename area-latest.osm.pbf to area.osm.pbf
|
|
||||||
# TODO: This if statement could be removed in a few months once everyone is using the file without the `-latest`?
|
|
||||||
ifneq ($(area),$(area:-latest=))
|
|
||||||
$(shell mv "data/$(area).osm.pbf" "data/$(area:-latest=).osm.pbf")
|
|
||||||
area := $(area:-latest=)
|
|
||||||
$(warning ATTENTION: File data/$(area)-latest.osm.pbf was renamed to $(area).osm.pbf.)
|
|
||||||
AREA_INFO := Detected area=$(area) based on finding a 'data/$(area)-latest.osm.pbf' file - renamed to '$(area).osm.pbf'. Use 'area' parameter or environment variable to override.
|
|
||||||
else
|
|
||||||
AREA_INFO := Detected area=$(area) based on finding a 'data/$(area).osm.pbf' file. Use 'area' parameter or environment variable to override.
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
|
|
||||||
ifneq ($(strip $(AREA_INFO)),)
|
|
||||||
define assert_area_is_given
|
|
||||||
@echo "$(AREA_INFO)"
|
|
||||||
endef
|
|
||||||
endif
|
|
||||||
|
|
||||||
# If set, this file will be downloaded in download-osm and imported in the import-osm targets
|
|
||||||
PBF_FILE ?= data/$(area).osm.pbf
|
|
||||||
|
|
||||||
# For download-osm, allow URL parameter to download file from a given URL. Area param must still be provided.
|
|
||||||
ifneq ($(strip $(url)),)
|
|
||||||
DOWNLOAD_AREA := $(url)
|
|
||||||
else
|
|
||||||
DOWNLOAD_AREA := $(area)
|
|
||||||
endif
|
|
||||||
|
|
||||||
# import-borders uses these temp files during border parsing/import
|
|
||||||
export BORDERS_CLEANUP_FILE ?= data/borders/$(area).cleanup.pbf
|
|
||||||
export BORDERS_PBF_FILE ?= data/borders/$(area).filtered.pbf
|
|
||||||
export BORDERS_CSV_FILE ?= data/borders/$(area).lines.csv
|
|
||||||
|
|
||||||
# The file is placed into the $EXPORT_DIR=/export (mapped to ./data)
|
|
||||||
export MBTILES_FILE ?= $(area).mbtiles
|
|
||||||
MBTILES_LOCAL_FILE = data/$(MBTILES_FILE)
|
|
||||||
|
|
||||||
ifeq ($(strip $(DIFF_MODE)),true)
|
|
||||||
# import-osm implementation requires IMPOSM_CONFIG_FILE to be set to a valid file
|
|
||||||
# For static (no-updates) import, we don't need to override the default value
|
|
||||||
# For the update mode, set location of the dynamically-generated area-based config file
|
|
||||||
export IMPOSM_CONFIG_FILE = data/$(area).repl.json
|
|
||||||
endif
|
|
||||||
|
|
||||||
# Load area-specific bbox file that gets generated by the download-osm --bbox
|
|
||||||
AREA_BBOX_FILE ?= data/$(area).bbox
|
|
||||||
ifneq (,$(wildcard $(AREA_BBOX_FILE)))
|
|
||||||
cat := $(if $(filter $(OS),Windows_NT),type,cat)
|
|
||||||
BBOX := $(shell $(cat) ${AREA_BBOX_FILE})
|
|
||||||
export BBOX
|
|
||||||
endif
|
|
||||||
|
|
||||||
ifeq ($(strip $(area)),)
|
|
||||||
define assert_area_is_given
|
|
||||||
@echo ""
|
|
||||||
@echo "ERROR: $(AREA_ERROR)"
|
|
||||||
@echo ""
|
|
||||||
@echo " make $@ area=<area-id>"
|
|
||||||
@echo ""
|
|
||||||
@echo "To download an area, use make download <area-id>"
|
|
||||||
@echo "To list downloadable areas, use make list-geofabrik and/or make list-bbbike"
|
|
||||||
@exit 1
|
|
||||||
endef
|
|
||||||
else
|
|
||||||
ifneq ($(strip $(AREA_INFO)),)
|
|
||||||
define assert_area_is_given
|
|
||||||
@echo "$(AREA_INFO)"
|
|
||||||
endef
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
|
|
||||||
#
|
|
||||||
# TARGETS
|
|
||||||
#
|
|
||||||
|
|
||||||
.PHONY: all
|
.PHONY: all
|
||||||
all: init-dirs build/openmaptiles.tm2source/data.yml build/mapping.yaml build-sql
|
all: init-dirs build/openmaptiles.tm2source/data.yml build/mapping.yaml build-sql
|
||||||
|
|
||||||
|
# Set OpenMapTiles host
|
||||||
|
OMT_HOST:=http://$(firstword $(subst :, ,$(subst tcp://,,$(DOCKER_HOST))) localhost)
|
||||||
|
|
||||||
.PHONY: help
|
.PHONY: help
|
||||||
help:
|
help:
|
||||||
@echo "=============================================================================="
|
@echo "=============================================================================="
|
||||||
@ -200,23 +63,20 @@ help:
|
|||||||
@echo " "
|
@echo " "
|
||||||
@echo "Hints for designers:"
|
@echo "Hints for designers:"
|
||||||
@echo " make start-maputnik # start Maputnik Editor + dynamic tile server [ see $(OMT_HOST):8088 ]"
|
@echo " make start-maputnik # start Maputnik Editor + dynamic tile server [ see $(OMT_HOST):8088 ]"
|
||||||
@echo " make start-postserve # start dynamic tile server [ see $(OMT_HOST):$(PPORT) ]"
|
@echo " make start-postserve # start dynamic tile server [ see $(OMT_HOST):$(PPORT)} ]"
|
||||||
@echo " make start-tileserver # start maptiler/tileserver-gl [ see $(OMT_HOST):$(TPORT) ]"
|
@echo " make start-tileserver # start maptiler/tileserver-gl [ see $(OMT_HOST):$(TPORT) ]"
|
||||||
@echo " "
|
@echo " "
|
||||||
@echo "Hints for developers:"
|
@echo "Hints for developers:"
|
||||||
@echo " make # build source code"
|
@echo " make # build source code"
|
||||||
@echo " make list-geofabrik # list actual geofabrik OSM extracts for download"
|
@echo " make list-geofabrik # list actual geofabrik OSM extracts for download"
|
||||||
@echo " make list-bbbike # list actual BBBike OSM extracts for download"
|
@echo " make download-geofabrik area=albania # download OSM data from geofabrik, and create config file"
|
||||||
@echo " make download area=albania # download OSM data from any source and create config file"
|
@echo " make download-osmfr area=asia/qatar # download OSM data from openstreetmap.fr, and create config file"
|
||||||
@echo " make download-geofabrik area=albania # download OSM data from geofabrik.de and create config file"
|
@echo " make download-bbike area=Amsterdam # download OSM data from bbike.org, and create config file"
|
||||||
@echo " make download-osmfr area=asia/qatar # download OSM data from openstreetmap.fr and create config file"
|
|
||||||
@echo " make download-bbbike area=Amsterdam # download OSM data from bbbike.org and create config file"
|
|
||||||
@echo " make generate-bbox-file # compute bounding box of a data file and store it in a file"
|
|
||||||
@echo " make psql # start PostgreSQL console"
|
@echo " make psql # start PostgreSQL console"
|
||||||
@echo " make psql-list-tables # list all PostgreSQL tables"
|
@echo " make psql-list-tables # list all PostgreSQL tables"
|
||||||
@echo " make vacuum-db # PostgreSQL: VACUUM ANALYZE"
|
@echo " make vacuum-db # PostgreSQL: VACUUM ANALYZE"
|
||||||
@echo " make analyze-db # PostgreSQL: ANALYZE"
|
@echo " make analyze-db # PostgreSQL: ANALYZE"
|
||||||
@echo " make generate-qa # statistics for a given layer's field"
|
@echo " make generate-qareports # generate reports [./build/qareports]"
|
||||||
@echo " make generate-devdoc # generate devdoc including graphs for all layers [./layers/...]"
|
@echo " make generate-devdoc # generate devdoc including graphs for all layers [./layers/...]"
|
||||||
@echo " make bash # start openmaptiles-tools /bin/bash terminal"
|
@echo " make bash # start openmaptiles-tools /bin/bash terminal"
|
||||||
@echo " make destroy-db # remove docker containers and PostgreSQL data volume"
|
@echo " make destroy-db # remove docker containers and PostgreSQL data volume"
|
||||||
@ -226,8 +86,8 @@ help:
|
|||||||
@echo " make clean-unnecessary-docker # clean unnecessary docker image(s) and container(s)"
|
@echo " make clean-unnecessary-docker # clean unnecessary docker image(s) and container(s)"
|
||||||
@echo " make refresh-docker-images # refresh openmaptiles docker images from Docker HUB"
|
@echo " make refresh-docker-images # refresh openmaptiles docker images from Docker HUB"
|
||||||
@echo " make remove-docker-images # remove openmaptiles docker images"
|
@echo " make remove-docker-images # remove openmaptiles docker images"
|
||||||
@echo " make list-views # list PostgreSQL public schema views"
|
@echo " make pgclimb-list-views # list PostgreSQL public schema views"
|
||||||
@echo " make list-tables # list PostgreSQL public schema tables"
|
@echo " make pgclimb-list-tables # list PostgreSQL public schema tables"
|
||||||
@echo " cat .env # list PG database and MIN_ZOOM and MAX_ZOOM information"
|
@echo " cat .env # list PG database and MIN_ZOOM and MAX_ZOOM information"
|
||||||
@echo " cat quickstart.log # transcript of the last ./quickstart.sh run"
|
@echo " cat quickstart.log # transcript of the last ./quickstart.sh run"
|
||||||
@echo " make help # help about available commands"
|
@echo " make help # help about available commands"
|
||||||
@ -235,39 +95,29 @@ help:
|
|||||||
|
|
||||||
.PHONY: init-dirs
|
.PHONY: init-dirs
|
||||||
init-dirs:
|
init-dirs:
|
||||||
@mkdir -p build/sql/parallel
|
@mkdir -p build/sql
|
||||||
@mkdir -p build/openmaptiles.tm2source
|
@mkdir -p data
|
||||||
@mkdir -p data/borders
|
|
||||||
@mkdir -p cache
|
@mkdir -p cache
|
||||||
|
|
||||||
build/openmaptiles.tm2source/data.yml: init-dirs
|
build/openmaptiles.tm2source/data.yml: init-dirs
|
||||||
ifeq (,$(wildcard build/openmaptiles.tm2source/data.yml))
|
mkdir -p build/openmaptiles.tm2source
|
||||||
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools generate-tm2source $(TILESET_FILE) --host="postgres" --port=5432 --database="openmaptiles" --user="$(DC_USER)" --password="$(DC_PASSWORD)" > $@
|
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools generate-tm2source openmaptiles.yaml --host="postgres" --port=5432 --database="openmaptiles" --user="openmaptiles" --password="openmaptiles" > $@
|
||||||
endif
|
|
||||||
|
|
||||||
build/mapping.yaml: init-dirs
|
build/mapping.yaml: init-dirs
|
||||||
ifeq (,$(wildcard build/mapping.yaml))
|
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools generate-imposm3 openmaptiles.yaml > $@
|
||||||
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools generate-imposm3 $(TILESET_FILE) > $@
|
|
||||||
endif
|
|
||||||
|
|
||||||
.PHONY: build-sql
|
.PHONY: build-sql
|
||||||
build-sql: init-dirs
|
build-sql: init-dirs
|
||||||
ifeq (,$(wildcard build/sql/run_last.sql))
|
|
||||||
@mkdir -p build/sql/parallel
|
|
||||||
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools bash -c \
|
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools bash -c \
|
||||||
'generate-sql $(TILESET_FILE) --dir ./build/sql \
|
'generate-sql openmaptiles.yaml --dir ./build/sql \
|
||||||
&& generate-sqltomvt $(TILESET_FILE) \
|
&& generate-sqltomvt openmaptiles.yaml --key --postgis-ver 2.4.8 --function --fname=getmvt >> "./build/sql/run_last.sql"'
|
||||||
--key --gzip --postgis-ver 3.0.1 \
|
|
||||||
--function --fname=getmvt >> ./build/sql/run_last.sql'
|
|
||||||
endif
|
|
||||||
|
|
||||||
.PHONY: clean
|
.PHONY: clean
|
||||||
clean:
|
clean:
|
||||||
rm -rf build
|
rm -rf build
|
||||||
|
|
||||||
.PHONY: destroy-db
|
.PHONY: destroy-db
|
||||||
# TODO: Use https://stackoverflow.com/a/27852388/177275
|
destroy-db: override DC_PROJECT:=$(shell echo $(DC_PROJECT) | tr A-Z a-z)
|
||||||
destroy-db: DC_PROJECT := $(shell echo $(DC_PROJECT) | tr A-Z a-z)
|
|
||||||
destroy-db:
|
destroy-db:
|
||||||
$(DOCKER_COMPOSE) down -v --remove-orphans
|
$(DOCKER_COMPOSE) down -v --remove-orphans
|
||||||
$(DOCKER_COMPOSE) rm -fv
|
$(DOCKER_COMPOSE) rm -fv
|
||||||
@ -299,126 +149,74 @@ stop-db:
|
|||||||
list-geofabrik: init-dirs
|
list-geofabrik: init-dirs
|
||||||
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools download-osm list geofabrik
|
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools download-osm list geofabrik
|
||||||
|
|
||||||
.PHONY: list-bbbike
|
OSM_SERVERS:=geofabrik osmfr bbbike
|
||||||
list-bbbike: init-dirs
|
ALL_DOWNLOADS:=$(addprefix download-,$(OSM_SERVERS))
|
||||||
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools download-osm list bbbike
|
OSM_SERVER=$(patsubst download-%,%,$@)
|
||||||
|
|
||||||
#
|
|
||||||
# download, download-geofabrik, download-osmfr, and download-bbbike are handled here
|
|
||||||
# The --imposm-cfg will fail for some of the sources, but we ignore that error -- only needed for diff mode
|
|
||||||
#
|
|
||||||
OSM_SERVERS := geofabrik osmfr bbbike
|
|
||||||
ALL_DOWNLOADS := $(addprefix download-,$(OSM_SERVERS)) download
|
|
||||||
OSM_SERVER=$(patsubst download,,$(patsubst download-%,%,$@))
|
|
||||||
.PHONY: $(ALL_DOWNLOADS)
|
.PHONY: $(ALL_DOWNLOADS)
|
||||||
$(ALL_DOWNLOADS): init-dirs
|
$(ALL_DOWNLOADS): init-dirs
|
||||||
@$(assert_area_is_given)
|
ifeq ($(strip $(area)),)
|
||||||
ifneq ($(strip $(url)),)
|
|
||||||
$(if $(OSM_SERVER),$(error url parameter can only be used with non-specific download target:$(newline) make download area=$(area) url="$(url)"$(newline)))
|
|
||||||
endif
|
|
||||||
ifeq (,$(wildcard $(PBF_FILE)))
|
|
||||||
ifeq ($(strip $(DIFF_MODE)),true)
|
|
||||||
@echo "Downloading $(DOWNLOAD_AREA) with replication support into $(PBF_FILE) and $(IMPOSM_CONFIG_FILE) from $(if $(OSM_SERVER),$(OSM_SERVER),any source)"
|
|
||||||
@$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools download-osm $(OSM_SERVER) "$(DOWNLOAD_AREA)" \
|
|
||||||
--imposm-cfg "$(IMPOSM_CONFIG_FILE)" \
|
|
||||||
--bbox "$(AREA_BBOX_FILE)" \
|
|
||||||
--output "$(PBF_FILE)"
|
|
||||||
else
|
|
||||||
@echo "Downloading $(DOWNLOAD_AREA) into $(PBF_FILE) from $(if $(OSM_SERVER),$(OSM_SERVER),any source)"
|
|
||||||
@$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools download-osm $(OSM_SERVER) "$(DOWNLOAD_AREA)" \
|
|
||||||
--bbox "$(AREA_BBOX_FILE)" \
|
|
||||||
--output "$(PBF_FILE)"
|
|
||||||
endif
|
|
||||||
@echo ""
|
@echo ""
|
||||||
|
@echo "ERROR: Unable to download an area if area is not given."
|
||||||
|
@echo "Usage:"
|
||||||
|
@echo " make download-$(OSM_SERVER) area=<area-id>"
|
||||||
|
@echo ""
|
||||||
|
$(if $(filter %-geofabrik,$@),@echo "Use make list-geofabrik to get a list of all available areas";echo "")
|
||||||
|
@exit 1
|
||||||
else
|
else
|
||||||
ifeq ($(strip $(DIFF_MODE)),true)
|
@echo "=============== download-$(OSM_SERVER) ======================="
|
||||||
ifeq (,$(wildcard $(IMPOSM_CONFIG_FILE)))
|
@echo "Download area: $(area)"
|
||||||
$(error \
|
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools bash -c \
|
||||||
$(newline) Data files $(PBF_FILE) already exists, but $(IMPOSM_CONFIG_FILE) does not. \
|
'download-osm $(OSM_SERVER) $(area) \
|
||||||
$(newline) You probably downloaded the data file before setting DIFF_MODE=true. \
|
--minzoom $$QUICKSTART_MIN_ZOOM \
|
||||||
$(newline) You can delete the data file $(PBF_FILE) and re-run make download \
|
--maxzoom $$QUICKSTART_MAX_ZOOM \
|
||||||
$(newline) to re-download and generate config, or manually create $(IMPOSM_CONFIG_FILE) \
|
--make-dc /import/docker-compose-config.yml -- -d /import'
|
||||||
$(newline) See example https://github.com/openmaptiles/openmaptiles-tools/blob/v5.2/bin/config/repl_config.json \
|
ls -la ./data/$(notdir $(area))*
|
||||||
$(newline))
|
@echo ""
|
||||||
else
|
|
||||||
@echo "Data files $(PBF_FILE) and replication config $(IMPOSM_CONFIG_FILE) already exists, skipping the download."
|
|
||||||
endif
|
|
||||||
else
|
|
||||||
@echo "Data files $(PBF_FILE) already exists, skipping the download."
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
|
|
||||||
.PHONY: generate-bbox-file
|
|
||||||
generate-bbox-file:
|
|
||||||
@$(assert_area_is_given)
|
|
||||||
ifeq (,$(wildcard $(AREA_BBOX_FILE)))
|
|
||||||
@$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools download-osm bbox "$(PBF_FILE)" "$(AREA_BBOX_FILE)"
|
|
||||||
else
|
|
||||||
@echo "Configuration file $(AREA_BBOX_FILE) already exists, no need to regenerate. BBOX=$(BBOX)"
|
|
||||||
endif
|
endif
|
||||||
|
|
||||||
.PHONY: psql
|
.PHONY: psql
|
||||||
psql: start-db-nowait
|
psql: start-db-nowait
|
||||||
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools sh -c 'pgwait && psql.sh'
|
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools sh -c 'pgwait && psql.sh'
|
||||||
|
|
||||||
# Special cache handling for Docker Toolbox on Windows
|
|
||||||
ifeq ($(MSYSTEM),MINGW64)
|
|
||||||
DC_CONFIG_CACHE := -f docker-compose.yml -f docker-compose-$(MSYSTEM).yml
|
|
||||||
DC_OPTS_CACHE := $(strip $(filter-out --user=%,$(DC_OPTS)))
|
|
||||||
else
|
|
||||||
DC_OPTS_CACHE := $(DC_OPTS)
|
|
||||||
endif
|
|
||||||
|
|
||||||
.PHONY: import-osm
|
.PHONY: import-osm
|
||||||
import-osm: all start-db-nowait
|
import-osm: all start-db-nowait
|
||||||
@$(assert_area_is_given)
|
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools sh -c 'pgwait && import-osm $(PBF_FILE)'
|
||||||
$(DOCKER_COMPOSE) $(DC_CONFIG_CACHE) run $(DC_OPTS_CACHE) openmaptiles-tools sh -c 'pgwait && import-osm $(PBF_FILE)'
|
|
||||||
|
|
||||||
.PHONY: update-osm
|
.PHONY: update-osm
|
||||||
update-osm: all start-db-nowait
|
update-osm: all start-db-nowait
|
||||||
@$(assert_area_is_given)
|
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools sh -c 'pgwait && import-update'
|
||||||
$(DOCKER_COMPOSE) $(DC_CONFIG_CACHE) run $(DC_OPTS_CACHE) openmaptiles-tools sh -c 'pgwait && import-update'
|
|
||||||
|
|
||||||
.PHONY: import-diff
|
.PHONY: import-diff
|
||||||
import-diff: all start-db-nowait
|
import-diff: all start-db-nowait
|
||||||
@$(assert_area_is_given)
|
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools sh -c 'pgwait && import-diff'
|
||||||
$(DOCKER_COMPOSE) $(DC_CONFIG_CACHE) run $(DC_OPTS_CACHE) openmaptiles-tools sh -c 'pgwait && import-diff'
|
|
||||||
|
|
||||||
.PHONY: import-data
|
.PHONY: import-data
|
||||||
import-data: start-db
|
import-data: start-db
|
||||||
$(DOCKER_COMPOSE) $(DC_CONFIG_CACHE) run $(DC_OPTS_CACHE) import-data
|
$(DOCKER_COMPOSE) run $(DC_OPTS) import-data
|
||||||
|
|
||||||
.PHONY: import-borders
|
.PHONY: import-borders
|
||||||
import-borders: start-db-nowait
|
import-borders: start-db-nowait
|
||||||
@$(assert_area_is_given)
|
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools sh -c 'pgwait && import-borders'
|
||||||
# If CSV borders file already exists, use it without re-parsing
|
|
||||||
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools sh -c \
|
|
||||||
'pgwait && import-borders $$([ -f "$(BORDERS_CSV_FILE)" ] && echo load $(BORDERS_CSV_FILE) || echo import $(PBF_FILE))'
|
|
||||||
|
|
||||||
.PHONY: import-sql
|
.PHONY: import-sql
|
||||||
import-sql: all start-db-nowait
|
import-sql: all start-db-nowait
|
||||||
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools sh -c 'pgwait && import-sql' | \
|
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools sh -c 'pgwait && import-sql' | \
|
||||||
awk -v s=": WARNING:" '1{print; fflush()} $$0~s{print "\n*** WARNING detected, aborting"; exit(1)}'
|
awk -v s=": WARNING:" '$$0~s{print; print "\n*** WARNING detected, aborting"; exit(1)} 1'
|
||||||
|
|
||||||
|
.PHONY: show-metadata
|
||||||
|
show-metadata: init-dirs
|
||||||
|
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools mbtiles-tools meta-all ./data/tiles.mbtiles
|
||||||
|
|
||||||
.PHONY: generate-tiles
|
.PHONY: generate-tiles
|
||||||
|
ifneq ($(wildcard data/docker-compose-config.yml),)
|
||||||
|
DC_CONFIG_TILES:=-f docker-compose.yml -f ./data/docker-compose-config.yml
|
||||||
|
endif
|
||||||
generate-tiles: all start-db
|
generate-tiles: all start-db
|
||||||
@$(assert_area_is_given)
|
rm -rf data/tiles.mbtiles
|
||||||
@echo "Generating tiles into $(MBTILES_LOCAL_FILE) (will delete if already exists)..."
|
echo "Generating tiles ..."; \
|
||||||
@rm -rf "$(MBTILES_LOCAL_FILE)"
|
$(DOCKER_COMPOSE) $(DC_CONFIG_TILES) run $(DC_OPTS) generate-vectortiles
|
||||||
$(DOCKER_COMPOSE) run $(DC_OPTS) generate-vectortiles
|
|
||||||
@echo "Updating generated tile metadata ..."
|
@echo "Updating generated tile metadata ..."
|
||||||
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools \
|
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools generate-metadata ./data/tiles.mbtiles
|
||||||
mbtiles-tools meta-generate "$(MBTILES_LOCAL_FILE)" $(TILESET_FILE) --auto-minmax --show-ranges
|
|
||||||
|
|
||||||
.PHONY: generate-tiles-pg
|
|
||||||
generate-tiles-pg: all start-db
|
|
||||||
@$(assert_area_is_given)
|
|
||||||
@echo "Generating tiles into $(MBTILES_LOCAL_FILE) (will delete if already exists)..."
|
|
||||||
@rm -rf "$(MBTILES_LOCAL_FILE)"
|
|
||||||
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools generate-tiles
|
|
||||||
@echo "Updating generated tile metadata ..."
|
|
||||||
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools \
|
|
||||||
mbtiles-tools meta-generate "$(MBTILES_LOCAL_FILE)" $(TILESET_FILE) --auto-minmax --show-ranges
|
|
||||||
|
|
||||||
.PHONY: start-tileserver
|
.PHONY: start-tileserver
|
||||||
start-tileserver: init-dirs
|
start-tileserver: init-dirs
|
||||||
@ -477,22 +275,17 @@ start-maputnik: stop-maputnik start-postserve
|
|||||||
stop-maputnik:
|
stop-maputnik:
|
||||||
-docker rm -f maputnik_editor
|
-docker rm -f maputnik_editor
|
||||||
|
|
||||||
# STAT_FUNCTION=frequency|toplength|variance
|
.PHONY: generate-qareports
|
||||||
.PHONY: generate-qa
|
generate-qareports: start-db
|
||||||
generate-qa: all start-db-nowait
|
./qa/run.sh
|
||||||
@echo " "
|
|
||||||
@echo "e.g. make generate-qa STAT_FUNCTION=frequency LAYER=transportation ATTRIBUTE=class"
|
|
||||||
@echo " "
|
|
||||||
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools \
|
|
||||||
layer-stats $(STAT_FUNCTION) $(TILESET_FILE) $(LAYER) $(ATTRIBUTE) -m 0 -n 14 -v
|
|
||||||
|
|
||||||
# generate all etl and mapping graphs
|
# generate all etl and mapping graphs
|
||||||
.PHONY: generate-devdoc
|
.PHONY: generate-devdoc
|
||||||
generate-devdoc: init-dirs
|
generate-devdoc: init-dirs
|
||||||
mkdir -p ./build/devdoc && \
|
mkdir -p ./build/devdoc && \
|
||||||
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools sh -c \
|
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools sh -c \
|
||||||
'generate-etlgraph $(TILESET_FILE) $(GRAPH_PARAMS) && \
|
'generate-etlgraph openmaptiles.yaml $(GRAPH_PARAMS) && \
|
||||||
generate-mapping-graph $(TILESET_FILE) $(GRAPH_PARAMS)'
|
generate-mapping-graph openmaptiles.yaml $(GRAPH_PARAMS)'
|
||||||
|
|
||||||
.PHONY: bash
|
.PHONY: bash
|
||||||
bash: init-dirs
|
bash: init-dirs
|
||||||
@ -500,7 +293,7 @@ bash: init-dirs
|
|||||||
|
|
||||||
.PHONY: import-wikidata
|
.PHONY: import-wikidata
|
||||||
import-wikidata: init-dirs
|
import-wikidata: init-dirs
|
||||||
$(DOCKER_COMPOSE) $(DC_CONFIG_CACHE) run $(DC_OPTS_CACHE) openmaptiles-tools import-wikidata --cache /cache/wikidata-cache.json $(TILESET_FILE)
|
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools import-wikidata --cache /cache/wikidata-cache.json openmaptiles.yaml
|
||||||
|
|
||||||
.PHONY: reset-db-stats
|
.PHONY: reset-db-stats
|
||||||
reset-db-stats: init-dirs
|
reset-db-stats: init-dirs
|
||||||
@ -509,12 +302,12 @@ reset-db-stats: init-dirs
|
|||||||
.PHONY: list-views
|
.PHONY: list-views
|
||||||
list-views: init-dirs
|
list-views: init-dirs
|
||||||
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools psql.sh -v ON_ERROR_STOP=1 -A -F"," -P pager=off -P footer=off \
|
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools psql.sh -v ON_ERROR_STOP=1 -A -F"," -P pager=off -P footer=off \
|
||||||
-c "select viewname from pg_views where schemaname='public' order by viewname;"
|
-c "select schemaname, viewname from pg_views where schemaname='public' order by viewname;"
|
||||||
|
|
||||||
.PHONY: list-tables
|
.PHONY: list-tables
|
||||||
list-tables: init-dirs
|
list-tables: init-dirs
|
||||||
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools psql.sh -v ON_ERROR_STOP=1 -A -F"," -P pager=off -P footer=off \
|
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools psql.sh -v ON_ERROR_STOP=1 -A -F"," -P pager=off -P footer=off \
|
||||||
-c "select tablename from pg_tables where schemaname='public' order by tablename;"
|
-c "select schemaname, tablename from pg_tables where schemaname='public' order by tablename;"
|
||||||
|
|
||||||
.PHONY: psql-list-tables
|
.PHONY: psql-list-tables
|
||||||
psql-list-tables: init-dirs
|
psql-list-tables: init-dirs
|
||||||
@ -560,23 +353,14 @@ remove-docker-images:
|
|||||||
.PHONY: clean-unnecessary-docker
|
.PHONY: clean-unnecessary-docker
|
||||||
clean-unnecessary-docker:
|
clean-unnecessary-docker:
|
||||||
@echo "Deleting unnecessary container(s)..."
|
@echo "Deleting unnecessary container(s)..."
|
||||||
@docker ps -a -q --filter "status=exited" | $(XARGS) docker rm
|
@docker ps -a --filter "status=exited" | $(XARGS) docker rm
|
||||||
@echo "Deleting unnecessary image(s)..."
|
@echo "Deleting unnecessary image(s)..."
|
||||||
@docker images | awk -F" " '/<none>/{print $$3}' | $(XARGS) docker rmi
|
@docker images | grep \<none\> | awk -F" " '{print $$3}' | $(XARGS) docker rmi
|
||||||
|
|
||||||
.PHONY: test-perf-null
|
.PHONY: test-perf-null
|
||||||
test-perf-null: init-dirs
|
test-perf-null: init-dirs
|
||||||
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools test-perf $(TILESET_FILE) --test null --no-color
|
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools test-perf openmaptiles.yaml --test null --no-color
|
||||||
|
|
||||||
.PHONY: build-test-pbf
|
.PHONY: build-test-pbf
|
||||||
build-test-pbf: init-dirs
|
build-test-pbf: init-dirs
|
||||||
docker-compose run $(DC_OPTS) openmaptiles-tools /tileset/.github/workflows/build-test-data.sh
|
docker-compose run $(DC_OPTS) openmaptiles-tools /tileset/.github/workflows/build-test-data.sh
|
||||||
|
|
||||||
.PHONY: debug
|
|
||||||
debug: ## Use this target when developing Makefile itself to verify loaded environment variables
|
|
||||||
@$(assert_area_is_given)
|
|
||||||
@echo file_exists = $(wildcard $(AREA_BBOX_FILE))
|
|
||||||
@echo AREA_BBOX_FILE = $(AREA_BBOX_FILE) , $$AREA_ENV_FILE
|
|
||||||
@echo BBOX = $(BBOX) , $$BBOX
|
|
||||||
@echo MIN_ZOOM = $(MIN_ZOOM) , $$MIN_ZOOM
|
|
||||||
@echo MAX_ZOOM = $(MAX_ZOOM) , $$MAX_ZOOM
|
|
||||||
|
|||||||
@ -363,13 +363,12 @@ This is generating `.mbtiles` for your area : [ MIN_ZOOM: "0" - MAX_ZOOM: "7"
|
|||||||
./quickstart.sh yukon # Yukon, Canada
|
./quickstart.sh yukon # Yukon, Canada
|
||||||
```
|
```
|
||||||
### Using your own OSM data
|
### Using your own OSM data
|
||||||
Mbtiles can be generated from an arbitrary osm.pbf (e.g. for a region that is not covered by an existing extract) by making the `data/` directory and placing an *.osm.pbf (e.g. `mydata.osm.pbf`) inside.
|
Mbtiles can be generated from an arbitrary osm.pbf (e.g. for a region that is not covered by an existing extract) by making the `data/` directory and placing an *-latest.osm.pbf inside. Inside of folder have to be `docker-compose-config.yml` file too, otherwize whole folder `data/` will be deleted and `download-osm` will try to download osm.pbf file from `geofabric`, `osmfr` or `bbbike`.
|
||||||
|
|
||||||
```
|
```
|
||||||
mkdir -p data
|
mkdir -p data
|
||||||
mv mydata.osm.pbf data/
|
mv my-latest.osm.pbf data/
|
||||||
make generate-bbox-file area=mydata
|
./quickstart.sh my
|
||||||
./quickstart.sh mydata
|
|
||||||
```
|
```
|
||||||
|
|
||||||
### Check postserve
|
### Check postserve
|
||||||
@ -385,26 +384,20 @@ and the generated maps are going to be available in webbrowser on [localhost:808
|
|||||||
This is only a quick preview, because your mbtiles only generated to zoom level 7 !
|
This is only a quick preview, because your mbtiles only generated to zoom level 7 !
|
||||||
|
|
||||||
|
|
||||||
### Set which zooms to generate
|
### Change MIN_ZOOM and MAX_ZOOM
|
||||||
|
|
||||||
modify the settings in the `.env` file, the defaults:
|
modify the settings in the `.env` file, the defaults :
|
||||||
* `MIN_ZOOM=0`
|
* QUICKSTART_MIN_ZOOM=0
|
||||||
* `MAX_ZOOM=7`
|
* QUICKSTART_MAX_ZOOM=7
|
||||||
|
|
||||||
|
and re-start `./quickstart.sh `
|
||||||
|
* the new config file re-generating to here ./data/docker-compose-config.yml
|
||||||
|
* Known problems:
|
||||||
|
* If you use same area - then the ./data/docker-compose-config.yml not re-generating, so you have to modify by hand!
|
||||||
|
|
||||||
Hints:
|
Hints:
|
||||||
* Small increments! Never starts with the `MAX_ZOOM = 14`
|
* Small increments! Never starts with the MAX_ZOOM = 14
|
||||||
* The suggested `MAX_ZOOM = 14` - use only with small extracts
|
* The suggested MAX_ZOOM = 14 - use only with small extracts
|
||||||
|
|
||||||
### Set the bounding box to generate
|
|
||||||
|
|
||||||
By default, tile generation is done for the full extent of the area.
|
|
||||||
If you want to generate a tiles for a smaller extent, modify the settings in the `.env` file, the default:
|
|
||||||
* `BBOX=-180.0,-85.0511,180.0,85.0511`
|
|
||||||
|
|
||||||
Delete the `./data/<area>.bbox` file, and re-start `./quickstart.sh <area>`
|
|
||||||
|
|
||||||
Hint:
|
|
||||||
* The [boundingbox.klokantech.com](https://boundingbox.klokantech.com/) site can be used to find a bounding box (CSV format) using a map.
|
|
||||||
|
|
||||||
### Check other commands
|
### Check other commands
|
||||||
|
|
||||||
@ -431,7 +424,7 @@ Hints for developers:
|
|||||||
make psql-list-tables # list all PostgreSQL tables
|
make psql-list-tables # list all PostgreSQL tables
|
||||||
make psql-vacuum-analyze # PostgreSQL: VACUUM ANALYZE
|
make psql-vacuum-analyze # PostgreSQL: VACUUM ANALYZE
|
||||||
make psql-analyze # PostgreSQL: ANALYZE
|
make psql-analyze # PostgreSQL: ANALYZE
|
||||||
make generate-qa # statistics for a given layer's field
|
make generate-qareports # generate reports [./build/qareports]
|
||||||
make generate-devdoc # generate devdoc [./build/devdoc]
|
make generate-devdoc # generate devdoc [./build/devdoc]
|
||||||
make tools-dev # start import-sql /bin/bash terminal
|
make tools-dev # start import-sql /bin/bash terminal
|
||||||
make db-destroy # remove docker containers, PG data volume
|
make db-destroy # remove docker containers, PG data volume
|
||||||
|
|||||||
18
README.md
@ -1,6 +1,6 @@
|
|||||||
## OpenMapTiles [](https://github.com/openmaptiles/openmaptiles/actions)
|
## OpenMapTiles [](https://github.com/openmaptiles/openmaptiles/actions)
|
||||||
|
|
||||||
OpenMapTiles is an extensible and open tile schema based on the OpenStreetMap. This project is used to generate vector tiles for online zoomable maps. OpenMapTiles is about creating a beautiful basemaps with general layers containing topographic information. More information [openmaptiles.org](https://openmaptiles.org/) and [maptiler.com/data/](https://www.maptiler.com/data/).
|
OpenMapTiles is an extensible and open tile schema based on the OpenStreetMap. This project is used to generate vector tiles for online zoomable maps. OpenMapTiles is about creating a beautiful basemaps with general layers containing topographic information. More information [openmaptiles.org](https://openmaptiles.org/) and [openmaptiles.com](https://openmaptiles.com/).
|
||||||
|
|
||||||
We encourage you to collaborate, reuse and adapt existing layers, or add your own layers. You may use our approach for your own vector tile project. Feel free to fork the repo and experiment. The repository is built on top of the [openmaptiles/openmaptiles-tools](https://github.com/openmaptiles/openmaptiles-tools) to simplify vector tile creation.
|
We encourage you to collaborate, reuse and adapt existing layers, or add your own layers. You may use our approach for your own vector tile project. Feel free to fork the repo and experiment. The repository is built on top of the [openmaptiles/openmaptiles-tools](https://github.com/openmaptiles/openmaptiles-tools) to simplify vector tile creation.
|
||||||
|
|
||||||
@ -8,7 +8,7 @@ Please keep in mind that OpenMapTiles schema should display general topographic
|
|||||||
|
|
||||||
- :link: Schema https://openmaptiles.org/schema
|
- :link: Schema https://openmaptiles.org/schema
|
||||||
- :link: Docs https://openmaptiles.org/docs
|
- :link: Docs https://openmaptiles.org/docs
|
||||||
- :link: Data for download: https://www.maptiler.com/data/
|
- :link: Production package: https://openmaptiles.com/production-package/
|
||||||
- :link: Hosting https://www.maptiler.com/cloud/
|
- :link: Hosting https://www.maptiler.com/cloud/
|
||||||
- :link: Create own layer https://github.com/openmaptiles/openmaptiles-skiing
|
- :link: Create own layer https://github.com/openmaptiles/openmaptiles-skiing
|
||||||
- :link: Discuss at the #openmaptiles channel at [OSM Slack](https://osmus-slack.herokuapp.com/)
|
- :link: Discuss at the #openmaptiles channel at [OSM Slack](https://osmus-slack.herokuapp.com/)
|
||||||
@ -83,10 +83,10 @@ make
|
|||||||
```
|
```
|
||||||
|
|
||||||
You can execute the following manual steps (for better understanding)
|
You can execute the following manual steps (for better understanding)
|
||||||
or use the provided `quickstart.sh` script to automatically download and import given area. If area is not given, albania will be imported.
|
or use the provided `quickstart.sh` script.
|
||||||
|
|
||||||
```
|
```
|
||||||
./quickstart.sh <area>
|
./quickstart.sh
|
||||||
```
|
```
|
||||||
|
|
||||||
### Prepare the Database
|
### Prepare the Database
|
||||||
@ -103,10 +103,10 @@ Import external data from [OpenStreetMapData](http://osmdata.openstreetmap.de/),
|
|||||||
make import-data
|
make import-data
|
||||||
```
|
```
|
||||||
|
|
||||||
Download OpenStreetMap data extracts from any source like [Geofabrik](http://download.geofabrik.de/), and store the PBF file in the `./data` directory. To use a specific download source, use `download-geofabrik`, `download-bbbike`, or `download-osmfr`, or use `download` to make it auto-pick the area. You can use `area=planet` for the entire OSM dataset (very large). Note that if you have more than one `data/*.osm.pbf` file, every `make` command will always require `area=...` parameter (or you can just `export area=...` first).
|
[Download OpenStreetMap data extracts](http://download.geofabrik.de/) and store the PBF file in the `./data` directory.
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
make download area=albania
|
make download-geofabrik area=albania
|
||||||
```
|
```
|
||||||
|
|
||||||
[Import OpenStreetMap data](https://github.com/openmaptiles/openmaptiles-tools/tree/master/docker/import-osm) with the mapping rules from
|
[Import OpenStreetMap data](https://github.com/openmaptiles/openmaptiles-tools/tree/master/docker/import-osm) with the mapping rules from
|
||||||
@ -135,11 +135,11 @@ make
|
|||||||
make import-sql
|
make import-sql
|
||||||
```
|
```
|
||||||
|
|
||||||
Now you are ready to **generate the vector tiles**. By default, `./.env` specifies the entire planet BBOX for zooms 0-7, but running `generate-bbox-file` will analyze the data file and set the `BBOX` param to limit tile generation.
|
Now you are ready to **generate the vector tiles**. Using environment variables
|
||||||
|
you can limit the bounding box and zoom levels of what you want to generate (`docker-compose.yml`).
|
||||||
|
|
||||||
```
|
```
|
||||||
make generate-bbox-file # compute data bbox -- not needed for the whole planet
|
make generate-tiles
|
||||||
make generate-tiles # generate tiles
|
|
||||||
```
|
```
|
||||||
|
|
||||||
## License
|
## License
|
||||||
|
|||||||
@ -1,11 +0,0 @@
|
|||||||
# This version must match the MAKE_DC_VERSION in docker-compose.yml
|
|
||||||
version: "3"
|
|
||||||
|
|
||||||
volumes:
|
|
||||||
cache:
|
|
||||||
|
|
||||||
services:
|
|
||||||
|
|
||||||
openmaptiles-tools:
|
|
||||||
volumes:
|
|
||||||
- cache:/cache
|
|
||||||
@ -1,11 +1,11 @@
|
|||||||
# This version must match the MAKE_DC_VERSION value below
|
# This version must match the MAKE_DC_VERSION value below
|
||||||
version: "3"
|
version: "2.3"
|
||||||
|
|
||||||
volumes:
|
volumes:
|
||||||
pgdata:
|
pgdata:
|
||||||
|
|
||||||
networks:
|
networks:
|
||||||
postgres:
|
postgres_conn:
|
||||||
driver: bridge
|
driver: bridge
|
||||||
|
|
||||||
services:
|
services:
|
||||||
@ -16,7 +16,7 @@ services:
|
|||||||
volumes:
|
volumes:
|
||||||
- pgdata:/var/lib/postgresql/data
|
- pgdata:/var/lib/postgresql/data
|
||||||
networks:
|
networks:
|
||||||
- postgres
|
- postgres_conn
|
||||||
ports:
|
ports:
|
||||||
- "5432"
|
- "5432"
|
||||||
env_file: .env-postgres
|
env_file: .env-postgres
|
||||||
@ -25,7 +25,7 @@ services:
|
|||||||
image: "openmaptiles/import-data:${TOOLS_VERSION}"
|
image: "openmaptiles/import-data:${TOOLS_VERSION}"
|
||||||
env_file: .env
|
env_file: .env
|
||||||
networks:
|
networks:
|
||||||
- postgres
|
- postgres_conn
|
||||||
|
|
||||||
openmaptiles-tools:
|
openmaptiles-tools:
|
||||||
image: "openmaptiles/openmaptiles-tools:${TOOLS_VERSION}"
|
image: "openmaptiles/openmaptiles-tools:${TOOLS_VERSION}"
|
||||||
@ -33,27 +33,14 @@ services:
|
|||||||
environment:
|
environment:
|
||||||
# Must match the version of this file (first line)
|
# Must match the version of this file (first line)
|
||||||
# download-osm will use it when generating a composer file
|
# download-osm will use it when generating a composer file
|
||||||
MAKE_DC_VERSION: "3"
|
MAKE_DC_VERSION: "2.3"
|
||||||
# Allow DIFF_MODE, MIN_ZOOM, and MAX_ZOOM to be overwritten from shell
|
# Allow DIFF_MODE to be overwritten from shell
|
||||||
DIFF_MODE: ${DIFF_MODE}
|
DIFF_MODE: ${DIFF_MODE}
|
||||||
MIN_ZOOM: ${MIN_ZOOM}
|
|
||||||
MAX_ZOOM: ${MAX_ZOOM}
|
|
||||||
#Provide BBOX from *.bbox file if exists, else from .env
|
|
||||||
BBOX: ${BBOX}
|
|
||||||
# Imposm configuration file describes how to load updates when enabled
|
|
||||||
IMPOSM_CONFIG_FILE: ${IMPOSM_CONFIG_FILE}
|
|
||||||
# Which files to use during import-borders processing
|
|
||||||
BORDERS_CLEANUP_FILE: ${BORDERS_CLEANUP_FILE}
|
|
||||||
BORDERS_PBF_FILE: ${BORDERS_PBF_FILE}
|
|
||||||
BORDERS_CSV_FILE: ${BORDERS_CSV_FILE}
|
|
||||||
# Control import-sql processes
|
|
||||||
MAX_PARALLEL_PSQL: ${MAX_PARALLEL_PSQL}
|
|
||||||
networks:
|
networks:
|
||||||
- postgres
|
- postgres_conn
|
||||||
volumes:
|
volumes:
|
||||||
- .:/tileset
|
- .:/tileset
|
||||||
- ./data:/import
|
- ./data:/import
|
||||||
- ./data:/export
|
|
||||||
- ./build/sql:/sql
|
- ./build/sql:/sql
|
||||||
- ./build:/mapping
|
- ./build:/mapping
|
||||||
- ./cache:/cache
|
- ./cache:/cache
|
||||||
@ -65,13 +52,8 @@ services:
|
|||||||
- ./data:/export
|
- ./data:/export
|
||||||
- ./build/openmaptiles.tm2source:/tm2source
|
- ./build/openmaptiles.tm2source:/tm2source
|
||||||
networks:
|
networks:
|
||||||
- postgres
|
- postgres_conn
|
||||||
env_file: .env
|
env_file: .env
|
||||||
environment:
|
|
||||||
FILTER_MAPNIK_OUTPUT: ${FILTER_MAPNIK_OUTPUT}
|
|
||||||
MBTILES_NAME: ${MBTILES_FILE}
|
|
||||||
# Control tilelive-copy threads
|
|
||||||
COPY_CONCURRENCY: ${COPY_CONCURRENCY}
|
|
||||||
|
|
||||||
generate-vectortiles:
|
generate-vectortiles:
|
||||||
image: "openmaptiles/generate-vectortiles:${TOOLS_VERSION}"
|
image: "openmaptiles/generate-vectortiles:${TOOLS_VERSION}"
|
||||||
@ -79,26 +61,20 @@ services:
|
|||||||
- ./data:/export
|
- ./data:/export
|
||||||
- ./build/openmaptiles.tm2source:/tm2source
|
- ./build/openmaptiles.tm2source:/tm2source
|
||||||
networks:
|
networks:
|
||||||
- postgres
|
- postgres_conn
|
||||||
env_file: .env
|
env_file: .env
|
||||||
environment:
|
environment:
|
||||||
FILTER_MAPNIK_OUTPUT: ${FILTER_MAPNIK_OUTPUT}
|
|
||||||
MBTILES_NAME: ${MBTILES_FILE}
|
|
||||||
BBOX: ${BBOX}
|
BBOX: ${BBOX}
|
||||||
MIN_ZOOM: ${MIN_ZOOM}
|
MIN_ZOOM: ${MIN_ZOOM}
|
||||||
MAX_ZOOM: ${MAX_ZOOM}
|
MAX_ZOOM: ${MAX_ZOOM}
|
||||||
# Control tilelive-copy threads
|
FILTER_MAPNIK_OUTPUT: ${FILTER_MAPNIK_OUTPUT}
|
||||||
COPY_CONCURRENCY: ${COPY_CONCURRENCY}
|
|
||||||
#
|
|
||||||
|
|
||||||
postserve:
|
postserve:
|
||||||
image: "openmaptiles/openmaptiles-tools:${TOOLS_VERSION}"
|
image: "openmaptiles/openmaptiles-tools:${TOOLS_VERSION}"
|
||||||
command: "postserve ${TILESET_FILE} --verbose --serve=${OMT_HOST:-http://localhost}:${PPORT:-8090}"
|
command: "postserve openmaptiles.yaml --verbose --port ${PPORT:-8090}"
|
||||||
env_file: .env
|
env_file: .env
|
||||||
environment:
|
|
||||||
TILESET_FILE: ${TILESET_FILE}
|
|
||||||
networks:
|
networks:
|
||||||
- postgres
|
- postgres_conn
|
||||||
ports:
|
ports:
|
||||||
- "${PPORT:-8090}:${PPORT:-8090}"
|
- "${PPORT:-8090}:${PPORT:-8090}"
|
||||||
volumes:
|
volumes:
|
||||||
|
|||||||
@ -1,43 +0,0 @@
|
|||||||
|
|
||||||
-- etldoc: layer_aerodrome_label[shape=record fillcolor=lightpink, style="rounded,filled", label="layer_aerodrome_label | <z10_> z10+" ] ;
|
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION layer_aerodrome_label(bbox geometry,
|
|
||||||
zoom_level integer)
|
|
||||||
RETURNS TABLE
|
|
||||||
(
|
|
||||||
osm_id bigint,
|
|
||||||
geometry geometry,
|
|
||||||
name text,
|
|
||||||
name_en text,
|
|
||||||
name_de text,
|
|
||||||
tags hstore,
|
|
||||||
class text,
|
|
||||||
iata text,
|
|
||||||
icao text,
|
|
||||||
ele int,
|
|
||||||
ele_ft int
|
|
||||||
)
|
|
||||||
AS
|
|
||||||
$$
|
|
||||||
SELECT
|
|
||||||
-- etldoc: osm_aerodrome_label_point -> layer_aerodrome_label:z10_
|
|
||||||
osm_id,
|
|
||||||
geometry,
|
|
||||||
name,
|
|
||||||
COALESCE(NULLIF(name_en, ''), name) AS name_en,
|
|
||||||
COALESCE(NULLIF(name_de, ''), name, name_en) AS name_de,
|
|
||||||
tags,
|
|
||||||
CASE
|
|
||||||
%%FIELD_MAPPING: class %%
|
|
||||||
ELSE 'other'
|
|
||||||
END AS class,
|
|
||||||
NULLIF(iata, '') AS iata,
|
|
||||||
NULLIF(icao, '') AS icao,
|
|
||||||
substring(ele FROM E'^(-?\\d+)(\\D|$)')::int AS ele,
|
|
||||||
round(substring(ele FROM E'^(-?\\d+)(\\D|$)')::int * 3.2808399)::int AS ele_ft
|
|
||||||
FROM osm_aerodrome_label_point
|
|
||||||
WHERE geometry && bbox
|
|
||||||
AND zoom_level >= 10;
|
|
||||||
$$ LANGUAGE SQL STABLE
|
|
||||||
-- STRICT
|
|
||||||
PARALLEL SAFE;
|
|
||||||
@ -41,10 +41,10 @@ layer:
|
|||||||
key_field: osm_id
|
key_field: osm_id
|
||||||
key_field_as_attribute: no
|
key_field_as_attribute: no
|
||||||
srid: 900913
|
srid: 900913
|
||||||
query: (SELECT osm_id, geometry, name, name_en, name_de, {name_languages}, class, iata, icao, ele, ele_ft FROM layer_aerodrome_label(!bbox!, z(!scale_denominator!))) AS t
|
query: (SELECT osm_id, geometry, name, name_en, name_de, {name_languages}, class, iata, icao, ele, ele_ft FROM layer_aerodrome_label (!bbox!, z(!scale_denominator!), !pixel_width!)) AS t
|
||||||
schema:
|
schema:
|
||||||
- ./update_aerodrome_label_point.sql
|
- ./update_aerodrome_label_point.sql
|
||||||
- ./aerodrome_label.sql
|
- ./layer.sql
|
||||||
datasources:
|
datasources:
|
||||||
- type: imposm3
|
- type: imposm3
|
||||||
mapping_file: ./mapping.yaml
|
mapping_file: ./mapping.yaml
|
||||||
|
|||||||
41
layers/aerodrome_label/layer.sql
Normal file
@ -0,0 +1,41 @@
|
|||||||
|
|
||||||
|
-- etldoc: layer_aerodrome_label[shape=record fillcolor=lightpink, style="rounded,filled", label="layer_aerodrome_label | <z10_> z10+" ] ;
|
||||||
|
|
||||||
|
CREATE OR REPLACE FUNCTION layer_aerodrome_label(
|
||||||
|
bbox geometry,
|
||||||
|
zoom_level integer,
|
||||||
|
pixel_width numeric)
|
||||||
|
RETURNS TABLE(
|
||||||
|
osm_id bigint,
|
||||||
|
geometry geometry,
|
||||||
|
name text,
|
||||||
|
name_en text,
|
||||||
|
name_de text,
|
||||||
|
tags hstore,
|
||||||
|
class text,
|
||||||
|
iata text,
|
||||||
|
icao text,
|
||||||
|
ele int,
|
||||||
|
ele_ft int) AS
|
||||||
|
$$
|
||||||
|
-- etldoc: osm_aerodrome_label_point -> layer_aerodrome_label:z10_
|
||||||
|
SELECT
|
||||||
|
osm_id,
|
||||||
|
geometry,
|
||||||
|
name,
|
||||||
|
COALESCE(NULLIF(name_en, ''), name) AS name_en,
|
||||||
|
COALESCE(NULLIF(name_de, ''), name, name_en) AS name_de,
|
||||||
|
tags,
|
||||||
|
CASE
|
||||||
|
%%FIELD_MAPPING: class %%
|
||||||
|
ELSE 'other'
|
||||||
|
END AS class,
|
||||||
|
NULLIF(iata, '') AS iata,
|
||||||
|
NULLIF(icao, '') AS icao,
|
||||||
|
substring(ele from E'^(-?\\d+)(\\D|$)')::int AS ele,
|
||||||
|
round(substring(ele from E'^(-?\\d+)(\\D|$)')::int*3.2808399)::int AS ele_ft
|
||||||
|
FROM osm_aerodrome_label_point
|
||||||
|
WHERE geometry && bbox AND zoom_level >= 10;
|
||||||
|
$$
|
||||||
|
LANGUAGE SQL
|
||||||
|
IMMUTABLE PARALLEL SAFE;
|
||||||
@ -1,91 +1,51 @@
|
|||||||
DROP TRIGGER IF EXISTS trigger_flag ON osm_aerodrome_label_point;
|
DROP TRIGGER IF EXISTS trigger_flag ON osm_aerodrome_label_point;
|
||||||
DROP TRIGGER IF EXISTS trigger_store ON osm_aerodrome_label_point;
|
|
||||||
DROP TRIGGER IF EXISTS trigger_refresh ON aerodrome_label.updates;
|
DROP TRIGGER IF EXISTS trigger_refresh ON aerodrome_label.updates;
|
||||||
|
|
||||||
CREATE SCHEMA IF NOT EXISTS aerodrome_label;
|
|
||||||
|
|
||||||
CREATE TABLE IF NOT EXISTS aerodrome_label.osm_ids
|
|
||||||
(
|
|
||||||
osm_id bigint
|
|
||||||
);
|
|
||||||
|
|
||||||
-- etldoc: osm_aerodrome_label_point -> osm_aerodrome_label_point
|
-- etldoc: osm_aerodrome_label_point -> osm_aerodrome_label_point
|
||||||
CREATE OR REPLACE FUNCTION update_aerodrome_label_point(full_update boolean) RETURNS void AS
|
CREATE OR REPLACE FUNCTION update_aerodrome_label_point() RETURNS VOID AS $$
|
||||||
$$
|
BEGIN
|
||||||
UPDATE osm_aerodrome_label_point
|
UPDATE osm_aerodrome_label_point
|
||||||
SET geometry = ST_Centroid(geometry)
|
SET geometry = ST_Centroid(geometry)
|
||||||
WHERE (full_update OR osm_id IN (SELECT osm_id FROM aerodrome_label.osm_ids))
|
WHERE ST_GeometryType(geometry) <> 'ST_Point';
|
||||||
AND ST_GeometryType(geometry) <> 'ST_Point';
|
|
||||||
|
|
||||||
UPDATE osm_aerodrome_label_point
|
UPDATE osm_aerodrome_label_point
|
||||||
SET tags = update_tags(tags, geometry)
|
SET tags = update_tags(tags, geometry)
|
||||||
WHERE (full_update OR osm_id IN (SELECT osm_id FROM aerodrome_label.osm_ids))
|
WHERE COALESCE(tags->'name:latin', tags->'name:nonlatin', tags->'name_int') IS NULL;
|
||||||
AND COALESCE(tags->'name:latin', tags->'name:nonlatin', tags->'name_int') IS NULL
|
END;
|
||||||
AND tags != update_tags(tags, geometry);
|
$$ LANGUAGE plpgsql;
|
||||||
$$ LANGUAGE SQL;
|
|
||||||
|
|
||||||
SELECT update_aerodrome_label_point(true);
|
SELECT update_aerodrome_label_point();
|
||||||
|
|
||||||
-- Handle updates
|
-- Handle updates
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION aerodrome_label.store() RETURNS trigger AS
|
CREATE SCHEMA IF NOT EXISTS aerodrome_label;
|
||||||
$$
|
|
||||||
BEGIN
|
|
||||||
IF (tg_op = 'DELETE') THEN
|
|
||||||
INSERT INTO aerodrome_label.osm_ids VALUES (OLD.osm_id);
|
|
||||||
ELSE
|
|
||||||
INSERT INTO aerodrome_label.osm_ids VALUES (NEW.osm_id);
|
|
||||||
END IF;
|
|
||||||
RETURN NULL;
|
|
||||||
END;
|
|
||||||
$$ LANGUAGE plpgsql;
|
|
||||||
|
|
||||||
CREATE TABLE IF NOT EXISTS aerodrome_label.updates
|
CREATE TABLE IF NOT EXISTS aerodrome_label.updates(id serial primary key, t text, unique (t));
|
||||||
(
|
CREATE OR REPLACE FUNCTION aerodrome_label.flag() RETURNS trigger AS $$
|
||||||
id serial PRIMARY KEY,
|
|
||||||
t text,
|
|
||||||
UNIQUE (t)
|
|
||||||
);
|
|
||||||
CREATE OR REPLACE FUNCTION aerodrome_label.flag() RETURNS trigger AS
|
|
||||||
$$
|
|
||||||
BEGIN
|
BEGIN
|
||||||
INSERT INTO aerodrome_label.updates(t) VALUES ('y') ON CONFLICT(t) DO NOTHING;
|
INSERT INTO aerodrome_label.updates(t) VALUES ('y') ON CONFLICT(t) DO NOTHING;
|
||||||
RETURN NULL;
|
RETURN null;
|
||||||
END;
|
END;
|
||||||
$$ LANGUAGE plpgsql;
|
$$ language plpgsql;
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION aerodrome_label.refresh() RETURNS trigger AS
|
CREATE OR REPLACE FUNCTION aerodrome_label.refresh() RETURNS trigger AS
|
||||||
$$
|
$BODY$
|
||||||
DECLARE
|
BEGIN
|
||||||
t TIMESTAMP WITH TIME ZONE := clock_timestamp();
|
|
||||||
BEGIN
|
|
||||||
RAISE LOG 'Refresh aerodrome_label';
|
RAISE LOG 'Refresh aerodrome_label';
|
||||||
PERFORM update_aerodrome_label_point(false);
|
PERFORM update_aerodrome_label_point();
|
||||||
-- noinspection SqlWithoutWhere
|
|
||||||
DELETE FROM aerodrome_label.osm_ids;
|
|
||||||
-- noinspection SqlWithoutWhere
|
|
||||||
DELETE FROM aerodrome_label.updates;
|
DELETE FROM aerodrome_label.updates;
|
||||||
|
RETURN null;
|
||||||
RAISE LOG 'Refresh aerodrome_label done in %', age(clock_timestamp(), t);
|
END;
|
||||||
RETURN NULL;
|
$BODY$
|
||||||
END;
|
language plpgsql;
|
||||||
$$ LANGUAGE plpgsql;
|
|
||||||
|
|
||||||
CREATE TRIGGER trigger_store
|
|
||||||
AFTER INSERT OR UPDATE OR DELETE
|
|
||||||
ON osm_aerodrome_label_point
|
|
||||||
FOR EACH ROW
|
|
||||||
EXECUTE PROCEDURE aerodrome_label.store();
|
|
||||||
|
|
||||||
CREATE TRIGGER trigger_flag
|
CREATE TRIGGER trigger_flag
|
||||||
AFTER INSERT OR UPDATE OR DELETE
|
AFTER INSERT OR UPDATE OR DELETE ON osm_aerodrome_label_point
|
||||||
ON osm_aerodrome_label_point
|
|
||||||
FOR EACH STATEMENT
|
FOR EACH STATEMENT
|
||||||
EXECUTE PROCEDURE aerodrome_label.flag();
|
EXECUTE PROCEDURE aerodrome_label.flag();
|
||||||
|
|
||||||
CREATE CONSTRAINT TRIGGER trigger_refresh
|
CREATE CONSTRAINT TRIGGER trigger_refresh
|
||||||
AFTER INSERT
|
AFTER INSERT ON aerodrome_label.updates
|
||||||
ON aerodrome_label.updates
|
|
||||||
INITIALLY DEFERRED
|
INITIALLY DEFERRED
|
||||||
FOR EACH ROW
|
FOR EACH ROW
|
||||||
EXECUTE PROCEDURE aerodrome_label.refresh();
|
EXECUTE PROCEDURE aerodrome_label.refresh();
|
||||||
|
|||||||
@ -1,70 +0,0 @@
|
|||||||
-- etldoc: layer_aeroway[shape=record fillcolor=lightpink, style="rounded,filled",
|
|
||||||
-- etldoc: label="layer_aeroway |<z10> z10|<z11> z11|<z12> z12|<z13> z13|<z14_> z14+" ];
|
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION layer_aeroway(bbox geometry, zoom_level int)
|
|
||||||
RETURNS TABLE
|
|
||||||
(
|
|
||||||
geometry geometry,
|
|
||||||
class text,
|
|
||||||
ref text
|
|
||||||
)
|
|
||||||
AS
|
|
||||||
$$
|
|
||||||
SELECT geometry, aeroway AS class, ref
|
|
||||||
FROM (
|
|
||||||
-- etldoc: osm_aeroway_linestring_gen_z10 -> layer_aeroway:z10
|
|
||||||
SELECT geometry, aeroway, ref
|
|
||||||
FROM osm_aeroway_linestring_gen_z10
|
|
||||||
WHERE zoom_level = 10
|
|
||||||
UNION ALL
|
|
||||||
-- etldoc: osm_aeroway_linestring_gen_z11 -> layer_aeroway:z11
|
|
||||||
SELECT geometry, aeroway, ref
|
|
||||||
FROM osm_aeroway_linestring_gen_z11
|
|
||||||
WHERE zoom_level = 11
|
|
||||||
UNION ALL
|
|
||||||
-- etldoc: osm_aeroway_linestring_gen_z12 -> layer_aeroway:z12
|
|
||||||
SELECT geometry, aeroway, ref
|
|
||||||
FROM osm_aeroway_linestring_gen_z12
|
|
||||||
WHERE zoom_level = 12
|
|
||||||
UNION ALL
|
|
||||||
-- etldoc: osm_aeroway_linestring -> layer_aeroway:z13
|
|
||||||
-- etldoc: osm_aeroway_linestring -> layer_aeroway:z14_
|
|
||||||
SELECT geometry, aeroway, ref
|
|
||||||
FROM osm_aeroway_linestring
|
|
||||||
WHERE zoom_level >= 13
|
|
||||||
UNION ALL
|
|
||||||
-- etldoc: osm_aeroway_polygon_gen_z10 -> layer_aeroway:z10
|
|
||||||
SELECT geometry, aeroway, ref
|
|
||||||
FROM osm_aeroway_polygon_gen_z10
|
|
||||||
WHERE zoom_level = 10
|
|
||||||
UNION ALL
|
|
||||||
-- etldoc: osm_aeroway_polygon_gen_z11 -> layer_aeroway:z11
|
|
||||||
SELECT geometry, aeroway, ref
|
|
||||||
FROM osm_aeroway_polygon_gen_z11
|
|
||||||
WHERE zoom_level = 11
|
|
||||||
UNION ALL
|
|
||||||
-- etldoc: osm_aeroway_polygon_gen_z12 -> layer_aeroway:z12
|
|
||||||
SELECT geometry, aeroway, ref
|
|
||||||
FROM osm_aeroway_polygon_gen_z12
|
|
||||||
WHERE zoom_level = 12
|
|
||||||
UNION ALL
|
|
||||||
-- etldoc: osm_aeroway_polygon_gen_z13 -> layer_aeroway:z13
|
|
||||||
SELECT geometry, aeroway, ref
|
|
||||||
FROM osm_aeroway_polygon_gen_z13
|
|
||||||
WHERE zoom_level = 13
|
|
||||||
UNION ALL
|
|
||||||
-- etldoc: osm_aeroway_polygon -> layer_aeroway:z14_
|
|
||||||
SELECT geometry, aeroway, ref
|
|
||||||
FROM osm_aeroway_polygon
|
|
||||||
WHERE zoom_level >= 14
|
|
||||||
UNION ALL
|
|
||||||
|
|
||||||
-- etldoc: osm_aeroway_point -> layer_aeroway:z14_
|
|
||||||
SELECT geometry, aeroway, ref
|
|
||||||
FROM osm_aeroway_point
|
|
||||||
WHERE zoom_level >= 14
|
|
||||||
) AS zoom_levels
|
|
||||||
WHERE geometry && bbox;
|
|
||||||
$$ LANGUAGE SQL STABLE
|
|
||||||
-- STRICT
|
|
||||||
PARALLEL SAFE;
|
|
||||||
@ -19,12 +19,11 @@ layer:
|
|||||||
- helipad
|
- helipad
|
||||||
- taxiway
|
- taxiway
|
||||||
- apron
|
- apron
|
||||||
- gate
|
|
||||||
datasource:
|
datasource:
|
||||||
geometry_field: geometry
|
geometry_field: geometry
|
||||||
query: (SELECT geometry, ref, class FROM layer_aeroway(!bbox!, z(!scale_denominator!))) AS t
|
query: (SELECT geometry, ref, class FROM layer_aeroway(!bbox!, z(!scale_denominator!))) AS t
|
||||||
schema:
|
schema:
|
||||||
- ./aeroway.sql
|
- ./layer.sql
|
||||||
datasources:
|
datasources:
|
||||||
- type: imposm3
|
- type: imposm3
|
||||||
mapping_file: ./mapping.yaml
|
mapping_file: ./mapping.yaml
|
||||||
|
|||||||
|
Before Width: | Height: | Size: 166 KiB After Width: | Height: | Size: 105 KiB |
45
layers/aeroway/layer.sql
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
-- etldoc: layer_aeroway[shape=record fillcolor=lightpink, style="rounded,filled",
|
||||||
|
-- etldoc: label="layer_aeroway |<z10> z10|<z11> z11|<z12> z12|<z13> z13|<z14_> z14+" ];
|
||||||
|
|
||||||
|
CREATE OR REPLACE FUNCTION layer_aeroway(bbox geometry, zoom_level int)
|
||||||
|
RETURNS TABLE(geometry geometry, class text, ref text) AS $$
|
||||||
|
SELECT geometry, aeroway AS class, ref FROM (
|
||||||
|
-- etldoc: osm_aeroway_linestring_gen3 -> layer_aeroway:z10
|
||||||
|
SELECT geometry, aeroway, ref
|
||||||
|
FROM osm_aeroway_linestring_gen3 WHERE zoom_level = 10
|
||||||
|
UNION ALL
|
||||||
|
-- etldoc: osm_aeroway_linestring_gen2 -> layer_aeroway:z11
|
||||||
|
SELECT geometry, aeroway, ref
|
||||||
|
FROM osm_aeroway_linestring_gen2 WHERE zoom_level = 11
|
||||||
|
UNION ALL
|
||||||
|
-- etldoc: osm_aeroway_linestring_gen1 -> layer_aeroway:z12
|
||||||
|
SELECT geometry, aeroway, ref
|
||||||
|
FROM osm_aeroway_linestring_gen1 WHERE zoom_level = 12
|
||||||
|
UNION ALL
|
||||||
|
-- etldoc: osm_aeroway_linestring -> layer_aeroway:z13
|
||||||
|
-- etldoc: osm_aeroway_linestring -> layer_aeroway:z14_
|
||||||
|
SELECT geometry, aeroway, ref
|
||||||
|
FROM osm_aeroway_linestring WHERE zoom_level >= 13
|
||||||
|
UNION ALL
|
||||||
|
|
||||||
|
-- etldoc: osm_aeroway_polygon_gen3 -> layer_aeroway:z10
|
||||||
|
-- etldoc: osm_aeroway_polygon_gen3 -> layer_aeroway:z11
|
||||||
|
SELECT geometry, aeroway, ref
|
||||||
|
FROM osm_aeroway_polygon_gen3 WHERE zoom_level BETWEEN 10 AND 11
|
||||||
|
UNION ALL
|
||||||
|
-- etldoc: osm_aeroway_polygon_gen2 -> layer_aeroway:z12
|
||||||
|
SELECT geometry, aeroway, ref
|
||||||
|
FROM osm_aeroway_polygon_gen2 WHERE zoom_level = 12
|
||||||
|
UNION ALL
|
||||||
|
-- etldoc: osm_aeroway_polygon_gen1 -> layer_aeroway:z13
|
||||||
|
SELECT geometry, aeroway, ref
|
||||||
|
FROM osm_aeroway_polygon_gen1 WHERE zoom_level = 13
|
||||||
|
UNION ALL
|
||||||
|
-- etldoc: osm_aeroway_polygon -> layer_aeroway:z14_
|
||||||
|
SELECT geometry, aeroway, ref
|
||||||
|
FROM osm_aeroway_polygon WHERE zoom_level >= 14
|
||||||
|
) AS zoom_levels
|
||||||
|
WHERE geometry && bbox;
|
||||||
|
$$
|
||||||
|
LANGUAGE SQL IMMUTABLE
|
||||||
|
PARALLEL SAFE;
|
||||||
@ -1,40 +1,34 @@
|
|||||||
generalized_tables:
|
generalized_tables:
|
||||||
# etldoc: osm_aeroway_linestring_gen_z11 -> osm_aeroway_linestring_gen_z10
|
# etldoc: imposm3 -> osm_aeroway_linestring_gen3
|
||||||
aeroway_linestring_gen_z10:
|
aeroway_linestring_gen3:
|
||||||
source: aeroway_linestring_gen_z11
|
source: aeroway_linestring_gen2
|
||||||
tolerance: ZRES11
|
tolerance: ZRES11
|
||||||
|
|
||||||
# etldoc: osm_aeroway_linestring_gen_z12 -> osm_aeroway_linestring_gen_z11
|
# etldoc: imposm3 -> osm_aeroway_linestring_gen2
|
||||||
aeroway_linestring_gen_z11:
|
aeroway_linestring_gen2:
|
||||||
source: aeroway_linestring_gen_z12
|
source: aeroway_linestring_gen1
|
||||||
tolerance: ZRES12
|
tolerance: ZRES12
|
||||||
|
|
||||||
# etldoc: osm_aeroway_linestring -> osm_aeroway_linestring_gen_z12
|
# etldoc: imposm3 -> osm_aeroway_linestring_gen1
|
||||||
aeroway_linestring_gen_z12:
|
aeroway_linestring_gen1:
|
||||||
source: aeroway_linestring
|
source: aeroway_linestring
|
||||||
sql_filter: ST_IsValid(geometry)
|
sql_filter: ST_IsValid(geometry)
|
||||||
tolerance: ZRES13
|
tolerance: ZRES13
|
||||||
|
|
||||||
# etldoc: osm_aeroway_polygon_gen_z11 -> osm_aeroway_polygon_gen_z10
|
# etldoc: imposm3 -> osm_aeroway_polygon_gen3
|
||||||
aeroway_polygon_gen_z10:
|
aeroway_polygon_gen3:
|
||||||
source: aeroway_polygon_gen_z11
|
source: aeroway_polygon_gen2
|
||||||
sql_filter: area>power(ZRES9,2)
|
|
||||||
tolerance: ZRES10
|
|
||||||
|
|
||||||
# etldoc: osm_aeroway_polygon_gen_z12 -> osm_aeroway_polygon_gen_z11
|
|
||||||
aeroway_polygon_gen_z11:
|
|
||||||
source: aeroway_polygon_gen_z12
|
|
||||||
sql_filter: area>power(ZRES10,2)
|
sql_filter: area>power(ZRES10,2)
|
||||||
tolerance: ZRES11
|
tolerance: ZRES11
|
||||||
|
|
||||||
# etldoc: osm_aeroway_polygon_gen_z13 -> osm_aeroway_polygon_gen_z12
|
# etldoc: imposm3 -> osm_aeroway_polygon_gen2
|
||||||
aeroway_polygon_gen_z12:
|
aeroway_polygon_gen2:
|
||||||
source: aeroway_polygon_gen_z13
|
source: aeroway_polygon_gen1
|
||||||
sql_filter: area>power(ZRES11,2)
|
sql_filter: area>power(ZRES11,2)
|
||||||
tolerance: ZRES12
|
tolerance: ZRES12
|
||||||
|
|
||||||
# etldoc: osm_aeroway_polygon -> osm_aeroway_polygon_gen_z13
|
# etldoc: imposm3 -> osm_aeroway_polygon_gen1
|
||||||
aeroway_polygon_gen_z13:
|
aeroway_polygon_gen1:
|
||||||
source: aeroway_polygon
|
source: aeroway_polygon
|
||||||
sql_filter: area>power(ZRES12,2) AND ST_IsValid(geometry)
|
sql_filter: area>power(ZRES12,2) AND ST_IsValid(geometry)
|
||||||
tolerance: ZRES13
|
tolerance: ZRES13
|
||||||
@ -86,19 +80,3 @@ tables:
|
|||||||
aeroway:
|
aeroway:
|
||||||
- runway
|
- runway
|
||||||
- taxiway
|
- taxiway
|
||||||
|
|
||||||
# etldoc: imposm3 -> osm_aeroway_point
|
|
||||||
aeroway_point:
|
|
||||||
type: point
|
|
||||||
columns:
|
|
||||||
- *ref
|
|
||||||
- name: osm_id
|
|
||||||
type: id
|
|
||||||
- name: geometry
|
|
||||||
type: geometry
|
|
||||||
- name: aeroway
|
|
||||||
key: aeroway
|
|
||||||
type: string
|
|
||||||
mapping:
|
|
||||||
aeroway:
|
|
||||||
- gate
|
|
||||||
|
Before Width: | Height: | Size: 32 KiB After Width: | Height: | Size: 31 KiB |
@ -14,10 +14,6 @@ layer:
|
|||||||
The `admin_level` corresponds to the lowest `admin_level`
|
The `admin_level` corresponds to the lowest `admin_level`
|
||||||
the line participates in.
|
the line participates in.
|
||||||
At low zoom levels the Natural Earth boundaries are mapped to the equivalent admin levels.
|
At low zoom levels the Natural Earth boundaries are mapped to the equivalent admin levels.
|
||||||
adm0_l: |
|
|
||||||
State name on the left of the border. For country boundaries only (`admin_level = 2`).
|
|
||||||
adm0_r: |
|
|
||||||
State name on the right of the border. For country boundaries only (`admin_level = 2`).
|
|
||||||
disputed:
|
disputed:
|
||||||
description: |
|
description: |
|
||||||
Mark with `1` if the border is disputed.
|
Mark with `1` if the border is disputed.
|
||||||
@ -50,9 +46,8 @@ layer:
|
|||||||
buffer_size: 4
|
buffer_size: 4
|
||||||
datasource:
|
datasource:
|
||||||
geometry_field: geometry
|
geometry_field: geometry
|
||||||
query: (SELECT geometry, admin_level, adm0_l, adm0_r, disputed, disputed_name, claimed_by, maritime FROM layer_boundary(!bbox!, z(!scale_denominator!))) AS t
|
query: (SELECT geometry, admin_level, disputed, disputed_name, claimed_by, maritime FROM layer_boundary(!bbox!, z(!scale_denominator!))) AS t
|
||||||
schema:
|
schema:
|
||||||
- ./boundary_name.sql
|
|
||||||
- ./boundary.sql
|
- ./boundary.sql
|
||||||
datasources:
|
datasources:
|
||||||
- type: imposm3
|
- type: imposm3
|
||||||
|
|||||||
@ -1,99 +0,0 @@
|
|||||||
DROP TABLE IF EXISTS osm_border_linestring_adm CASCADE;
|
|
||||||
|
|
||||||
-- etldoc: osm_border_linestring -> osm_border_linestring_adm
|
|
||||||
CREATE TABLE IF NOT EXISTS osm_border_linestring_adm AS (
|
|
||||||
WITH
|
|
||||||
-- Prepare lines from osm to be merged
|
|
||||||
multiline AS (
|
|
||||||
SELECT ST_Node(ST_Collect(geometry)) AS geometry,
|
|
||||||
maritime,
|
|
||||||
disputed
|
|
||||||
FROM osm_border_linestring
|
|
||||||
WHERE admin_level = 2
|
|
||||||
AND osm_id NOT IN (SELECT DISTINCT osm_id FROM osm_border_disp_linestring)
|
|
||||||
GROUP BY maritime,
|
|
||||||
disputed
|
|
||||||
),
|
|
||||||
|
|
||||||
mergedline AS (
|
|
||||||
SELECT (ST_Dump(
|
|
||||||
ST_LineMerge(geometry))).geom AS geometry,
|
|
||||||
maritime,
|
|
||||||
disputed
|
|
||||||
FROM multiline
|
|
||||||
),
|
|
||||||
-- Create polygons from all boundaries to preserve real shape of country
|
|
||||||
polyg AS (
|
|
||||||
SELECT (ST_Dump(
|
|
||||||
ST_Polygonize(geometry))).geom AS geometry
|
|
||||||
FROM (
|
|
||||||
SELECT (ST_Dump(
|
|
||||||
ST_LineMerge(geometry))).geom AS geometry
|
|
||||||
FROM (SELECT ST_Node(
|
|
||||||
ST_Collect(geometry)) AS geometry
|
|
||||||
FROM osm_border_linestring
|
|
||||||
WHERE admin_level = 2
|
|
||||||
) nodes
|
|
||||||
) linemerge
|
|
||||||
),
|
|
||||||
|
|
||||||
centroids AS (
|
|
||||||
SELECT polyg.geometry,
|
|
||||||
ne.adm0_a3
|
|
||||||
FROM polyg,
|
|
||||||
ne_10m_admin_0_countries AS ne
|
|
||||||
WHERE ST_Within(
|
|
||||||
ST_PointOnSurface(polyg.geometry), ne.geometry)
|
|
||||||
),
|
|
||||||
|
|
||||||
country_osm_polyg AS (
|
|
||||||
SELECT country.adm0_a3,
|
|
||||||
border.geometry
|
|
||||||
FROM polyg border,
|
|
||||||
centroids country
|
|
||||||
WHERE ST_Within(country.geometry, border.geometry)
|
|
||||||
),
|
|
||||||
|
|
||||||
rights AS (
|
|
||||||
SELECT adm0_r,
|
|
||||||
geometry,
|
|
||||||
maritime,
|
|
||||||
disputed
|
|
||||||
FROM (
|
|
||||||
SELECT b.adm0_a3 AS adm0_r,
|
|
||||||
a.geometry,
|
|
||||||
a.maritime,
|
|
||||||
a.disputed
|
|
||||||
FROM mergedline AS a
|
|
||||||
LEFT JOIN country_osm_polyg AS b
|
|
||||||
-- Create short line on the right of the boundary (mergedline) and find state where line lies.
|
|
||||||
ON ST_Within(
|
|
||||||
ST_OffsetCurve(
|
|
||||||
(ST_LineSubString(a.geometry, 0.3,0.3004)), 70, 'quad_segs=4 join=mitre'), b.geometry)
|
|
||||||
) line_rights
|
|
||||||
)
|
|
||||||
|
|
||||||
SELECT adm0_l,
|
|
||||||
adm0_r,
|
|
||||||
geometry,
|
|
||||||
maritime,
|
|
||||||
2::integer AS admin_level,
|
|
||||||
disputed
|
|
||||||
FROM (
|
|
||||||
SELECT b.adm0_a3 AS adm0_l,
|
|
||||||
r.adm0_r AS adm0_r,
|
|
||||||
r.geometry,
|
|
||||||
r.maritime,
|
|
||||||
r.disputed
|
|
||||||
FROM rights AS r
|
|
||||||
LEFT JOIN country_osm_polyg AS b
|
|
||||||
-- Create short line on the left of the boundary (mergedline) and find state where line lies.
|
|
||||||
ON ST_Within(
|
|
||||||
ST_OffsetCurve(
|
|
||||||
(ST_LineSubString(r.geometry, 0.4,0.4004)), -70, 'quad_segs=4 join=mitre'), b.geometry)
|
|
||||||
) both_lines
|
|
||||||
);
|
|
||||||
|
|
||||||
CREATE INDEX IF NOT EXISTS osm_border_linestring_adm_geom_idx
|
|
||||||
ON osm_border_linestring_adm
|
|
||||||
USING GIST (geometry);
|
|
||||||
|
Before Width: | Height: | Size: 668 KiB After Width: | Height: | Size: 500 KiB |
@ -1,82 +1,70 @@
|
|||||||
generalized_tables:
|
generalized_tables:
|
||||||
|
|
||||||
# etldoc: osm_border_disp_linestring_gen_z2 -> osm_border_disp_linestring_gen_z1
|
# etldoc: osm_border_disp_linestring -> osm_border_disp_linestring_gen11
|
||||||
border_disp_linestring_gen_z1:
|
border_disp_linestring_gen11:
|
||||||
source: border_disp_linestring_gen_z2
|
|
||||||
sql_filter: admin_level = 2
|
|
||||||
tolerance: ZRES2
|
|
||||||
|
|
||||||
# etldoc: osm_border_disp_linestring_gen_z3 -> osm_border_disp_linestring_gen_z2
|
|
||||||
border_disp_linestring_gen_z2:
|
|
||||||
source: border_disp_linestring_gen_z3
|
|
||||||
sql_filter: admin_level = 2
|
|
||||||
tolerance: ZRES3
|
|
||||||
|
|
||||||
# etldoc: osm_border_disp_linestring_gen_z4 -> osm_border_disp_linestring_gen_z3
|
|
||||||
border_disp_linestring_gen_z3:
|
|
||||||
source: border_disp_linestring_gen_z4
|
|
||||||
sql_filter: admin_level = 2
|
|
||||||
tolerance: ZRES4
|
|
||||||
|
|
||||||
# etldoc: osm_border_disp_linestring_gen_z5 -> osm_border_disp_linestring_gen_z4
|
|
||||||
border_disp_linestring_gen_z4:
|
|
||||||
source: border_disp_linestring_gen_z5
|
|
||||||
sql_filter: admin_level = 2
|
|
||||||
tolerance: ZRES5
|
|
||||||
|
|
||||||
# etldoc: osm_border_disp_linestring_gen_z6 -> osm_border_disp_linestring_gen_z5
|
|
||||||
border_disp_linestring_gen_z5:
|
|
||||||
source: border_disp_linestring_gen_z6
|
|
||||||
sql_filter: admin_level = 2
|
|
||||||
tolerance: ZRES6
|
|
||||||
|
|
||||||
# etldoc: osm_border_disp_linestring_gen_z7 -> osm_border_disp_linestring_gen_z6
|
|
||||||
border_disp_linestring_gen_z6:
|
|
||||||
source: border_disp_linestring_gen_z7
|
|
||||||
sql_filter: admin_level = 2
|
|
||||||
tolerance: ZRES7
|
|
||||||
|
|
||||||
# etldoc: osm_border_disp_linestring_gen_z8 -> osm_border_disp_linestring_gen_z7
|
|
||||||
border_disp_linestring_gen_z7:
|
|
||||||
source: border_disp_linestring_gen_z8
|
|
||||||
sql_filter: admin_level = 2
|
|
||||||
tolerance: ZRES8
|
|
||||||
|
|
||||||
# etldoc: osm_border_disp_linestring_gen_z9 -> osm_border_disp_linestring_gen_z8
|
|
||||||
border_disp_linestring_gen_z8:
|
|
||||||
source: border_disp_linestring_gen_z9
|
|
||||||
sql_filter: admin_level = 2
|
|
||||||
tolerance: ZRES9
|
|
||||||
|
|
||||||
# etldoc: osm_border_disp_linestring_gen_z10 -> osm_border_disp_linestring_gen_z9
|
|
||||||
border_disp_linestring_gen_z9:
|
|
||||||
source: border_disp_linestring_gen_z10
|
|
||||||
sql_filter: admin_level = 2
|
|
||||||
tolerance: ZRES10
|
|
||||||
|
|
||||||
# etldoc: osm_border_disp_linestring_gen_z11 -> osm_border_disp_linestring_gen_z10
|
|
||||||
border_disp_linestring_gen_z10:
|
|
||||||
source: border_disp_linestring_gen_z11
|
|
||||||
sql_filter: admin_level = 2
|
|
||||||
tolerance: ZRES11
|
|
||||||
|
|
||||||
# etldoc: osm_border_disp_linestring_gen_z12 -> osm_border_disp_linestring_gen_z11
|
|
||||||
border_disp_linestring_gen_z11:
|
|
||||||
source: border_disp_linestring_gen_z12
|
|
||||||
sql_filter: admin_level = 2
|
|
||||||
tolerance: ZRES12
|
|
||||||
|
|
||||||
# etldoc: osm_border_disp_linestring_gen_z13 -> osm_border_disp_linestring_gen_z12
|
|
||||||
border_disp_linestring_gen_z12:
|
|
||||||
source: border_disp_linestring_gen_z13
|
|
||||||
sql_filter: admin_level = 2
|
|
||||||
tolerance: ZRES13
|
|
||||||
|
|
||||||
# etldoc: osm_border_disp_linestring -> osm_border_disp_linestring_gen_z13
|
|
||||||
border_disp_linestring_gen_z13:
|
|
||||||
source: border_disp_linestring
|
source: border_disp_linestring
|
||||||
sql_filter: admin_level = 2
|
sql_filter: admin_level = 2
|
||||||
tolerance: ZRES14
|
tolerance: 9600
|
||||||
|
|
||||||
|
# etldoc: osm_border_disp_linestring -> osm_border_disp_linestring_gen10
|
||||||
|
border_disp_linestring_gen10:
|
||||||
|
source: border_disp_linestring
|
||||||
|
sql_filter: admin_level = 2
|
||||||
|
tolerance: 4800
|
||||||
|
|
||||||
|
# etldoc: osm_border_disp_linestring -> osm_border_disp_linestring_gen9
|
||||||
|
border_disp_linestring_gen9:
|
||||||
|
source: border_disp_linestring
|
||||||
|
sql_filter: admin_level = 2
|
||||||
|
tolerance: 2400
|
||||||
|
|
||||||
|
# etldoc: osm_border_disp_linestring -> osm_border_disp_linestring_gen8
|
||||||
|
border_disp_linestring_gen8:
|
||||||
|
source: border_disp_linestring
|
||||||
|
sql_filter: admin_level = 2
|
||||||
|
tolerance: 1200
|
||||||
|
|
||||||
|
# etldoc: osm_border_disp_linestring -> osm_border_disp_linestring_gen7
|
||||||
|
border_disp_linestring_gen7:
|
||||||
|
source: border_disp_linestring
|
||||||
|
sql_filter: admin_level = 2
|
||||||
|
tolerance: 600
|
||||||
|
|
||||||
|
# etldoc: osm_border_disp_linestring -> osm_border_disp_linestring_gen6
|
||||||
|
border_disp_linestring_gen6:
|
||||||
|
source: border_disp_linestring
|
||||||
|
sql_filter: admin_level = 2
|
||||||
|
tolerance: 300
|
||||||
|
|
||||||
|
# etldoc: osm_border_disp_linestring -> osm_border_disp_linestring_gen5
|
||||||
|
border_disp_linestring_gen5:
|
||||||
|
source: border_disp_linestring
|
||||||
|
sql_filter: admin_level = 2
|
||||||
|
tolerance: 160
|
||||||
|
|
||||||
|
# etldoc: osm_border_disp_linestring -> osm_border_disp_linestring_gen4
|
||||||
|
border_disp_linestring_gen4:
|
||||||
|
source: border_disp_linestring
|
||||||
|
sql_filter: admin_level = 2
|
||||||
|
tolerance: 80
|
||||||
|
|
||||||
|
# etldoc: osm_border_disp_linestring -> osm_border_disp_linestring_gen3
|
||||||
|
border_disp_linestring_gen3:
|
||||||
|
source: border_disp_linestring
|
||||||
|
sql_filter: admin_level = 2
|
||||||
|
tolerance: 40
|
||||||
|
|
||||||
|
# etldoc: osm_border_disp_linestring -> osm_border_disp_linestring_gen2
|
||||||
|
border_disp_linestring_gen2:
|
||||||
|
source: border_disp_linestring
|
||||||
|
sql_filter: admin_level = 2
|
||||||
|
tolerance: 20
|
||||||
|
|
||||||
|
# etldoc: osm_border_disp_linestring -> osm_border_disp_linestring_gen1
|
||||||
|
border_disp_linestring_gen1:
|
||||||
|
source: border_disp_linestring
|
||||||
|
sql_filter: admin_level = 2
|
||||||
|
tolerance: 10
|
||||||
|
|
||||||
# etldoc: osm_border_disp_relation -> osm_border_disp_linestring
|
# etldoc: osm_border_disp_relation -> osm_border_disp_linestring
|
||||||
border_disp_linestring:
|
border_disp_linestring:
|
||||||
@ -122,3 +110,4 @@ tables:
|
|||||||
#admin_level: ['2']
|
#admin_level: ['2']
|
||||||
admin_level: [__any__]
|
admin_level: [__any__]
|
||||||
claimed_by: [__any__]
|
claimed_by: [__any__]
|
||||||
|
|
||||||
|
|||||||
@ -1,120 +1,95 @@
|
|||||||
-- etldoc: layer_building[shape=record fillcolor=lightpink, style="rounded,filled",
|
-- etldoc: layer_building[shape=record fillcolor=lightpink, style="rounded,filled",
|
||||||
-- etldoc: label="layer_building | <z13> z13 | <z14_> z14+ " ] ;
|
-- etldoc: label="layer_building | <z13> z13 | <z14_> z14+ " ] ;
|
||||||
|
|
||||||
CREATE INDEX IF NOT EXISTS osm_building_relation_building_idx ON osm_building_relation (building) WHERE building = '' AND ST_GeometryType(geometry) = 'ST_Polygon';
|
CREATE INDEX IF NOT EXISTS osm_building_relation_building_idx ON osm_building_relation(building) WHERE building = '' AND ST_GeometryType(geometry) = 'ST_Polygon';
|
||||||
CREATE INDEX IF NOT EXISTS osm_building_relation_member_idx ON osm_building_relation (member) WHERE role = 'outline';
|
CREATE INDEX IF NOT EXISTS osm_building_relation_member_idx ON osm_building_relation(member) WHERE role = 'outline';
|
||||||
|
|
||||||
CREATE OR REPLACE VIEW osm_all_buildings AS
|
CREATE OR REPLACE VIEW osm_all_buildings AS (
|
||||||
(
|
-- etldoc: osm_building_relation -> layer_building:z14_
|
||||||
SELECT
|
-- Buildings built from relations
|
||||||
-- etldoc: osm_building_relation -> layer_building:z14_
|
SELECT member AS osm_id, geometry,
|
||||||
-- Buildings built from relations
|
COALESCE(CleanNumeric(height), CleanNumeric(buildingheight)) as height,
|
||||||
member AS osm_id,
|
COALESCE(CleanNumeric(min_height), CleanNumeric(buildingmin_height)) as min_height,
|
||||||
geometry,
|
COALESCE(CleanNumeric(levels), CleanNumeric(buildinglevels)) as levels,
|
||||||
COALESCE(CleanNumeric(height), CleanNumeric(buildingheight)) AS height,
|
COALESCE(CleanNumeric(min_level), CleanNumeric(buildingmin_level)) as min_level,
|
||||||
COALESCE(CleanNumeric(min_height), CleanNumeric(buildingmin_height)) AS min_height,
|
nullif(material, '') AS material,
|
||||||
COALESCE(CleanNumeric(levels), CleanNumeric(buildinglevels)) AS levels,
|
nullif(colour, '') AS colour,
|
||||||
COALESCE(CleanNumeric(min_level), CleanNumeric(buildingmin_level)) AS min_level,
|
FALSE as hide_3d
|
||||||
nullif(material, '') AS material,
|
FROM
|
||||||
nullif(colour, '') AS colour,
|
osm_building_relation WHERE building = '' AND ST_GeometryType(geometry) = 'ST_Polygon'
|
||||||
FALSE AS hide_3d
|
UNION ALL
|
||||||
FROM osm_building_relation
|
|
||||||
WHERE building = ''
|
|
||||||
AND ST_GeometryType(geometry) = 'ST_Polygon'
|
|
||||||
UNION ALL
|
|
||||||
|
|
||||||
SELECT
|
-- etldoc: osm_building_polygon -> layer_building:z14_
|
||||||
-- etldoc: osm_building_polygon -> layer_building:z14_
|
-- Standalone buildings
|
||||||
-- Standalone buildings
|
SELECT obp.osm_id, obp.geometry,
|
||||||
obp.osm_id,
|
COALESCE(CleanNumeric(obp.height), CleanNumeric(obp.buildingheight)) as height,
|
||||||
obp.geometry,
|
COALESCE(CleanNumeric(obp.min_height), CleanNumeric(obp.buildingmin_height)) as min_height,
|
||||||
COALESCE(CleanNumeric(obp.height), CleanNumeric(obp.buildingheight)) AS height,
|
COALESCE(CleanNumeric(obp.levels), CleanNumeric(obp.buildinglevels)) as levels,
|
||||||
COALESCE(CleanNumeric(obp.min_height), CleanNumeric(obp.buildingmin_height)) AS min_height,
|
COALESCE(CleanNumeric(obp.min_level), CleanNumeric(obp.buildingmin_level)) as min_level,
|
||||||
COALESCE(CleanNumeric(obp.levels), CleanNumeric(obp.buildinglevels)) AS levels,
|
nullif(obp.material, '') AS material,
|
||||||
COALESCE(CleanNumeric(obp.min_level), CleanNumeric(obp.buildingmin_level)) AS min_level,
|
nullif(obp.colour, '') AS colour,
|
||||||
nullif(obp.material, '') AS material,
|
obr.role IS NOT NULL AS hide_3d
|
||||||
nullif(obp.colour, '') AS colour,
|
FROM
|
||||||
obr.role IS NOT NULL AS hide_3d
|
osm_building_polygon obp
|
||||||
FROM osm_building_polygon obp
|
LEFT JOIN osm_building_relation obr ON
|
||||||
LEFT JOIN osm_building_relation obr ON
|
obp.osm_id >= 0 AND
|
||||||
obp.osm_id >= 0 AND
|
obr.member = obp.osm_id AND
|
||||||
obr.member = obp.osm_id AND
|
obr.role = 'outline'
|
||||||
obr.role = 'outline'
|
WHERE ST_GeometryType(obp.geometry) IN ('ST_Polygon', 'ST_MultiPolygon')
|
||||||
WHERE ST_GeometryType(obp.geometry) IN ('ST_Polygon', 'ST_MultiPolygon')
|
);
|
||||||
);
|
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION layer_building(bbox geometry, zoom_level int)
|
CREATE OR REPLACE FUNCTION layer_building(bbox geometry, zoom_level int)
|
||||||
RETURNS TABLE
|
RETURNS TABLE(geometry geometry, osm_id bigint, render_height int, render_min_height int, colour text, hide_3d boolean) AS $$
|
||||||
(
|
SELECT geometry, osm_id, render_height, render_min_height,
|
||||||
geometry geometry,
|
|
||||||
osm_id bigint,
|
|
||||||
render_height int,
|
|
||||||
render_min_height int,
|
|
||||||
colour text,
|
|
||||||
hide_3d boolean
|
|
||||||
)
|
|
||||||
AS
|
|
||||||
$$
|
|
||||||
SELECT geometry,
|
|
||||||
osm_id,
|
|
||||||
render_height,
|
|
||||||
render_min_height,
|
|
||||||
COALESCE(colour, CASE material
|
COALESCE(colour, CASE material
|
||||||
-- Ordered by count from taginfo
|
-- Ordered by count from taginfo
|
||||||
WHEN 'cement_block' THEN '#6a7880'
|
WHEN 'cement_block' THEN '#6a7880'
|
||||||
WHEN 'brick' THEN '#bd8161'
|
WHEN 'brick' THEN '#bd8161'
|
||||||
WHEN 'plaster' THEN '#dadbdb'
|
WHEN 'plaster' THEN '#dadbdb'
|
||||||
WHEN 'wood' THEN '#d48741'
|
WHEN 'wood' THEN '#d48741'
|
||||||
WHEN 'concrete' THEN '#d3c2b0'
|
WHEN 'concrete' THEN '#d3c2b0'
|
||||||
WHEN 'metal' THEN '#b7b1a6'
|
WHEN 'metal' THEN '#b7b1a6'
|
||||||
WHEN 'stone' THEN '#b4a995'
|
WHEN 'stone' THEN '#b4a995'
|
||||||
WHEN 'mud' THEN '#9d8b75'
|
WHEN 'mud' THEN '#9d8b75'
|
||||||
WHEN 'steel' THEN '#b7b1a6' -- same as metal
|
WHEN 'steel' THEN '#b7b1a6' -- same as metal
|
||||||
WHEN 'glass' THEN '#5a81a0'
|
WHEN 'glass' THEN '#5a81a0'
|
||||||
WHEN 'traditional' THEN '#bd8161' -- same as brick
|
WHEN 'traditional' THEN '#bd8161' -- same as brick
|
||||||
WHEN 'masonry' THEN '#bd8161' -- same as brick
|
WHEN 'masonry' THEN '#bd8161' -- same as brick
|
||||||
WHEN 'Brick' THEN '#bd8161' -- same as brick
|
WHEN 'Brick' THEN '#bd8161' -- same as brick
|
||||||
WHEN 'tin' THEN '#b7b1a6' -- same as metal
|
WHEN 'tin' THEN '#b7b1a6' -- same as metal
|
||||||
WHEN 'timber_framing' THEN '#b3b0a9'
|
WHEN 'timber_framing' THEN '#b3b0a9'
|
||||||
WHEN 'sandstone' THEN '#b4a995' -- same as stone
|
WHEN 'sandstone' THEN '#b4a995' -- same as stone
|
||||||
WHEN 'clay' THEN '#9d8b75' -- same as mud
|
WHEN 'clay' THEN '#9d8b75' -- same as mud
|
||||||
END) AS colour,
|
END) AS colour,
|
||||||
CASE WHEN hide_3d THEN TRUE END AS hide_3d
|
CASE WHEN hide_3d THEN TRUE END AS hide_3d
|
||||||
FROM (
|
FROM (
|
||||||
SELECT
|
-- etldoc: osm_building_polygon_gen1 -> layer_building:z13
|
||||||
-- etldoc: osm_building_block_gen_z13 -> layer_building:z13
|
SELECT
|
||||||
osm_id,
|
osm_id, geometry,
|
||||||
geometry,
|
NULL::int AS render_height, NULL::int AS render_min_height,
|
||||||
NULL::int AS render_height,
|
NULL::text AS material, NULL::text AS colour,
|
||||||
NULL::int AS render_min_height,
|
FALSE AS hide_3d
|
||||||
NULL::text AS material,
|
FROM osm_building_polygon_gen1
|
||||||
NULL::text AS colour,
|
WHERE zoom_level = 13 AND geometry && bbox
|
||||||
FALSE AS hide_3d
|
UNION ALL
|
||||||
FROM osm_building_block_gen_z13
|
-- etldoc: osm_building_polygon -> layer_building:z14_
|
||||||
WHERE zoom_level = 13
|
SELECT DISTINCT ON (osm_id)
|
||||||
AND geometry && bbox
|
osm_id, geometry,
|
||||||
UNION ALL
|
ceil(COALESCE(height, levels*3.66, 5))::int AS render_height,
|
||||||
SELECT
|
floor(COALESCE(min_height, min_level*3.66, 0))::int AS render_min_height,
|
||||||
-- etldoc: osm_building_polygon -> layer_building:z14_
|
material,
|
||||||
DISTINCT ON (osm_id) osm_id,
|
colour,
|
||||||
geometry,
|
hide_3d
|
||||||
ceil(COALESCE(height, levels * 3.66, 5))::int AS render_height,
|
FROM osm_all_buildings
|
||||||
floor(COALESCE(min_height, min_level * 3.66, 0))::int AS render_min_height,
|
WHERE
|
||||||
material,
|
(levels IS NULL OR levels < 1000) AND
|
||||||
colour,
|
(min_level IS NULL OR min_level < 1000) AND
|
||||||
hide_3d
|
(height IS NULL OR height < 3000) AND
|
||||||
FROM osm_all_buildings
|
(min_height IS NULL OR min_height < 3000) AND
|
||||||
WHERE (levels IS NULL OR levels < 1000)
|
zoom_level >= 14 AND geometry && bbox
|
||||||
AND (min_level IS NULL OR min_level < 1000)
|
) AS zoom_levels
|
||||||
AND (height IS NULL OR height < 3000)
|
ORDER BY render_height ASC, ST_YMin(geometry) DESC;
|
||||||
AND (min_height IS NULL OR min_height < 3000)
|
$$
|
||||||
AND zoom_level >= 14
|
LANGUAGE SQL IMMUTABLE;
|
||||||
AND geometry && bbox
|
|
||||||
) AS zoom_levels
|
|
||||||
ORDER BY render_height ASC, ST_YMin(geometry) DESC;
|
|
||||||
$$ LANGUAGE SQL STABLE
|
|
||||||
-- STRICT
|
|
||||||
PARALLEL SAFE
|
|
||||||
;
|
|
||||||
|
|
||||||
-- not handled: where a building outline covers building parts
|
-- not handled: where a building outline covers building parts
|
||||||
|
|||||||
@ -20,7 +20,6 @@ layer:
|
|||||||
hide_3d: |
|
hide_3d: |
|
||||||
If True, building (part) should not be rendered in 3D. Currently, [building outlines](https://wiki.openstreetmap.org/wiki/Simple_3D_buildings) are marked as hide_3d.
|
If True, building (part) should not be rendered in 3D. Currently, [building outlines](https://wiki.openstreetmap.org/wiki/Simple_3D_buildings) are marked as hide_3d.
|
||||||
schema:
|
schema:
|
||||||
- ./update_building.sql
|
|
||||||
- ./building.sql
|
- ./building.sql
|
||||||
datasources:
|
datasources:
|
||||||
- type: imposm3
|
- type: imposm3
|
||||||
|
|||||||
|
Before Width: | Height: | Size: 32 KiB After Width: | Height: | Size: 35 KiB |
@ -1,9 +1,9 @@
|
|||||||
#generalized_tables:
|
generalized_tables:
|
||||||
# # etldoc: imposm3 -> osm_building_polygon_gen1
|
# etldoc: imposm3 -> osm_building_polygon_gen1
|
||||||
# building_polygon_gen1:
|
building_polygon_gen1:
|
||||||
# source: building_polygon
|
source: building_polygon
|
||||||
# sql_filter: area>power(ZRES12,2) AND ST_IsValid(geometry)
|
sql_filter: area>power(ZRES12,2) AND ST_IsValid(geometry)
|
||||||
# tolerance: ZRES14
|
tolerance: ZRES14
|
||||||
|
|
||||||
tables:
|
tables:
|
||||||
# etldoc: imposm3 -> osm_building_polygon
|
# etldoc: imposm3 -> osm_building_polygon
|
||||||
|
|||||||
@ -1,185 +0,0 @@
|
|||||||
DROP TRIGGER IF EXISTS trigger_refresh ON buildings.updates;
|
|
||||||
DROP TRIGGER IF EXISTS trigger_flag ON osm_building_polygon;
|
|
||||||
|
|
||||||
-- Creating aggregated building blocks with removed small polygons and small
|
|
||||||
-- holes. Aggregated polygons are simplified by Visvalingam-Whyatt algorithm.
|
|
||||||
-- Aggregating is made block by block using country_osm_grid polygon table.
|
|
||||||
|
|
||||||
-- Function returning recordset for matview.
|
|
||||||
-- Returning recordset of buildings aggregates by zres 14, with removed small
|
|
||||||
-- holes and with removed small buildings/blocks.
|
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION osm_building_block_gen1()
|
|
||||||
RETURNS table
|
|
||||||
(
|
|
||||||
osm_id bigint,
|
|
||||||
geometry geometry
|
|
||||||
)
|
|
||||||
AS
|
|
||||||
$$
|
|
||||||
DECLARE
|
|
||||||
zres14 float := Zres(14);
|
|
||||||
zres12 float := Zres(12);
|
|
||||||
zres14vw float := Zres(14) * Zres(14);
|
|
||||||
polyg_world record;
|
|
||||||
|
|
||||||
BEGIN
|
|
||||||
FOR polyg_world IN
|
|
||||||
SELECT ST_Transform(country.geometry, 3857) AS geometry
|
|
||||||
FROM country_osm_grid country
|
|
||||||
|
|
||||||
LOOP
|
|
||||||
FOR osm_id, geometry IN
|
|
||||||
WITH dta AS ( -- CTE is used because of optimization
|
|
||||||
SELECT o.osm_id,
|
|
||||||
o.geometry,
|
|
||||||
ST_ClusterDBSCAN(o.geometry, eps := zres14, minpoints := 1) OVER () cid
|
|
||||||
FROM osm_building_polygon o
|
|
||||||
WHERE ST_Intersects(o.geometry, polyg_world.geometry)
|
|
||||||
)
|
|
||||||
SELECT (array_agg(dta.osm_id))[1] AS osm_id,
|
|
||||||
ST_Buffer(
|
|
||||||
ST_Union(
|
|
||||||
ST_Buffer(
|
|
||||||
ST_SnapToGrid(dta.geometry, 0.000001)
|
|
||||||
, zres14, 'join=mitre')
|
|
||||||
)
|
|
||||||
, -zres14, 'join=mitre') AS geometry
|
|
||||||
FROM dta
|
|
||||||
GROUP BY cid
|
|
||||||
|
|
||||||
LOOP
|
|
||||||
-- removing holes smaller than
|
|
||||||
IF ST_NumInteriorRings(geometry) > 0 THEN -- only from geometries wih holes
|
|
||||||
geometry := (
|
|
||||||
-- there are some multi-geometries in this layer
|
|
||||||
SELECT ST_Collect(gn)
|
|
||||||
FROM (
|
|
||||||
-- in some cases are "holes" NULL, because all holes are smaller than
|
|
||||||
SELECT COALESCE(
|
|
||||||
-- exterior ring
|
|
||||||
ST_MakePolygon(ST_ExteriorRing(dmp.geom), holes),
|
|
||||||
ST_MakePolygon(ST_ExteriorRing(dmp.geom))
|
|
||||||
) gn
|
|
||||||
|
|
||||||
FROM ST_Dump(geometry) dmp, -- 1 dump polygons
|
|
||||||
LATERAL (
|
|
||||||
SELECT array_agg(ST_Boundary(rg.geom)) holes -- 2 create array
|
|
||||||
FROM ST_DumpRings(dmp.geom) rg -- 3 from rings
|
|
||||||
WHERE rg.path[1] > 0 -- 5 except inner ring
|
|
||||||
AND ST_Area(rg.geom) >= power(zres12, 2) -- 4 bigger than
|
|
||||||
) holes
|
|
||||||
) new_geom
|
|
||||||
);
|
|
||||||
END IF;
|
|
||||||
|
|
||||||
IF ST_Area(geometry) < power(zres12, 2) THEN
|
|
||||||
CONTINUE;
|
|
||||||
END IF;
|
|
||||||
|
|
||||||
-- simplify
|
|
||||||
geometry := ST_SimplifyVW(geometry, zres14vw);
|
|
||||||
|
|
||||||
RETURN NEXT;
|
|
||||||
END LOOP;
|
|
||||||
END LOOP;
|
|
||||||
END;
|
|
||||||
$$ LANGUAGE plpgsql STABLE
|
|
||||||
STRICT
|
|
||||||
PARALLEL SAFE;
|
|
||||||
|
|
||||||
|
|
||||||
DROP MATERIALIZED VIEW IF EXISTS osm_building_block_gen1_dup CASCADE;
|
|
||||||
|
|
||||||
CREATE MATERIALIZED VIEW osm_building_block_gen1_dup AS
|
|
||||||
SELECT *
|
|
||||||
FROM osm_building_block_gen1();
|
|
||||||
|
|
||||||
CREATE INDEX ON osm_building_block_gen1_dup USING gist (geometry);
|
|
||||||
|
|
||||||
-- etldoc: osm_building_polygon -> osm_building_block_gen_z13
|
|
||||||
DROP MATERIALIZED VIEW IF EXISTS osm_building_block_gen_z13;
|
|
||||||
CREATE MATERIALIZED VIEW osm_building_block_gen_z13 AS
|
|
||||||
(
|
|
||||||
WITH
|
|
||||||
counts AS (
|
|
||||||
SELECT count(osm_id) AS counts,
|
|
||||||
osm_id
|
|
||||||
FROM osm_building_block_gen1_dup
|
|
||||||
GROUP BY osm_id
|
|
||||||
),
|
|
||||||
|
|
||||||
duplicates AS (
|
|
||||||
SELECT counts.osm_id
|
|
||||||
FROM counts
|
|
||||||
WHERE counts.counts > 1
|
|
||||||
)
|
|
||||||
|
|
||||||
SELECT osm.osm_id,
|
|
||||||
ST_Union(
|
|
||||||
ST_MakeValid(osm.geometry)) AS geometry
|
|
||||||
FROM osm_building_block_gen1_dup osm,
|
|
||||||
duplicates
|
|
||||||
WHERE osm.osm_id = duplicates.osm_id
|
|
||||||
GROUP BY osm.osm_id
|
|
||||||
|
|
||||||
UNION ALL
|
|
||||||
|
|
||||||
SELECT osm.osm_id,
|
|
||||||
osm.geometry
|
|
||||||
FROM osm_building_block_gen1_dup osm,
|
|
||||||
counts
|
|
||||||
WHERE counts.counts = 1
|
|
||||||
AND osm.osm_id = counts.osm_id
|
|
||||||
);
|
|
||||||
|
|
||||||
CREATE INDEX ON osm_building_block_gen_z13 USING gist (geometry);
|
|
||||||
CREATE UNIQUE INDEX ON osm_building_block_gen_z13 USING btree (osm_id);
|
|
||||||
|
|
||||||
-- Handle updates
|
|
||||||
|
|
||||||
CREATE SCHEMA IF NOT EXISTS buildings;
|
|
||||||
|
|
||||||
CREATE TABLE IF NOT EXISTS buildings.updates
|
|
||||||
(
|
|
||||||
id serial PRIMARY KEY,
|
|
||||||
t text,
|
|
||||||
UNIQUE (t)
|
|
||||||
);
|
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION buildings.flag() RETURNS trigger AS
|
|
||||||
$$
|
|
||||||
BEGIN
|
|
||||||
INSERT INTO buildings.updates(t) VALUES ('y') ON CONFLICT(t) DO NOTHING;
|
|
||||||
RETURN NULL;
|
|
||||||
END;
|
|
||||||
$$ LANGUAGE plpgsql;
|
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION buildings.refresh() RETURNS trigger AS
|
|
||||||
$$
|
|
||||||
DECLARE
|
|
||||||
t TIMESTAMP WITH TIME ZONE := clock_timestamp();
|
|
||||||
BEGIN
|
|
||||||
RAISE LOG 'Refresh buildings block';
|
|
||||||
REFRESH MATERIALIZED VIEW osm_building_block_gen1_dup;
|
|
||||||
REFRESH MATERIALIZED VIEW osm_building_block_gen_z13;
|
|
||||||
-- noinspection SqlWithoutWhere
|
|
||||||
DELETE FROM buildings.updates;
|
|
||||||
|
|
||||||
RAISE LOG 'Update buildings block done in %', age(clock_timestamp(), t);
|
|
||||||
RETURN NULL;
|
|
||||||
END;
|
|
||||||
$$ LANGUAGE plpgsql;
|
|
||||||
|
|
||||||
CREATE TRIGGER trigger_flag
|
|
||||||
AFTER INSERT OR UPDATE OR DELETE
|
|
||||||
ON osm_building_polygon
|
|
||||||
FOR EACH STATEMENT
|
|
||||||
EXECUTE PROCEDURE buildings.flag();
|
|
||||||
|
|
||||||
CREATE CONSTRAINT TRIGGER trigger_refresh
|
|
||||||
AFTER INSERT
|
|
||||||
ON buildings.updates
|
|
||||||
INITIALLY DEFERRED
|
|
||||||
FOR EACH ROW
|
|
||||||
EXECUTE PROCEDURE buildings.refresh();
|
|
||||||
@ -1,23 +0,0 @@
|
|||||||
-- etldoc: layer_housenumber[shape=record fillcolor=lightpink, style="rounded,filled",
|
|
||||||
-- etldoc: label="layer_housenumber | <z14_> z14+" ] ;
|
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION layer_housenumber(bbox geometry, zoom_level integer)
|
|
||||||
RETURNS TABLE
|
|
||||||
(
|
|
||||||
osm_id bigint,
|
|
||||||
geometry geometry,
|
|
||||||
housenumber text
|
|
||||||
)
|
|
||||||
AS
|
|
||||||
$$
|
|
||||||
SELECT
|
|
||||||
-- etldoc: osm_housenumber_point -> layer_housenumber:z14_
|
|
||||||
osm_id,
|
|
||||||
geometry,
|
|
||||||
housenumber
|
|
||||||
FROM osm_housenumber_point
|
|
||||||
WHERE zoom_level >= 14
|
|
||||||
AND geometry && bbox;
|
|
||||||
$$ LANGUAGE SQL STABLE
|
|
||||||
-- STRICT
|
|
||||||
PARALLEL SAFE;
|
|
||||||
@ -13,7 +13,7 @@ layer:
|
|||||||
query: (SELECT geometry, housenumber FROM layer_housenumber(!bbox!, z(!scale_denominator!))) AS t
|
query: (SELECT geometry, housenumber FROM layer_housenumber(!bbox!, z(!scale_denominator!))) AS t
|
||||||
schema:
|
schema:
|
||||||
- ./housenumber_centroid.sql
|
- ./housenumber_centroid.sql
|
||||||
- ./housenumber.sql
|
- ./layer.sql
|
||||||
datasources:
|
datasources:
|
||||||
- type: imposm3
|
- type: imposm3
|
||||||
mapping_file: ./mapping.yaml
|
mapping_file: ./mapping.yaml
|
||||||
|
|||||||
@ -1,91 +1,51 @@
|
|||||||
DROP TRIGGER IF EXISTS trigger_flag ON osm_housenumber_point;
|
DROP TRIGGER IF EXISTS trigger_flag ON osm_housenumber_point;
|
||||||
DROP TRIGGER IF EXISTS trigger_store ON osm_housenumber_point;
|
|
||||||
DROP TRIGGER IF EXISTS trigger_refresh ON housenumber.updates;
|
DROP TRIGGER IF EXISTS trigger_refresh ON housenumber.updates;
|
||||||
|
|
||||||
CREATE SCHEMA IF NOT EXISTS housenumber;
|
|
||||||
|
|
||||||
CREATE TABLE IF NOT EXISTS housenumber.osm_ids
|
|
||||||
(
|
|
||||||
osm_id bigint
|
|
||||||
);
|
|
||||||
|
|
||||||
-- etldoc: osm_housenumber_point -> osm_housenumber_point
|
-- etldoc: osm_housenumber_point -> osm_housenumber_point
|
||||||
CREATE OR REPLACE FUNCTION convert_housenumber_point(full_update boolean) RETURNS void AS
|
CREATE OR REPLACE FUNCTION convert_housenumber_point() RETURNS VOID AS $$
|
||||||
$$
|
BEGIN
|
||||||
UPDATE osm_housenumber_point
|
UPDATE osm_housenumber_point
|
||||||
SET geometry =
|
SET geometry =
|
||||||
CASE
|
CASE WHEN ST_NPoints(ST_ConvexHull(geometry))=ST_NPoints(geometry)
|
||||||
WHEN ST_NPoints(ST_ConvexHull(geometry)) = ST_NPoints(geometry)
|
THEN ST_Centroid(geometry)
|
||||||
THEN ST_Centroid(geometry)
|
ELSE ST_PointOnSurface(geometry)
|
||||||
ELSE ST_PointOnSurface(geometry)
|
END
|
||||||
END
|
WHERE ST_GeometryType(geometry) <> 'ST_Point';
|
||||||
WHERE (full_update OR osm_id IN (SELECT osm_id FROM housenumber.osm_ids))
|
END;
|
||||||
AND ST_GeometryType(geometry) <> 'ST_Point'
|
$$ LANGUAGE plpgsql;
|
||||||
AND ST_IsValid(geometry);
|
|
||||||
$$ LANGUAGE SQL;
|
|
||||||
|
|
||||||
SELECT convert_housenumber_point(true);
|
SELECT convert_housenumber_point();
|
||||||
|
|
||||||
-- Handle updates
|
-- Handle updates
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION housenumber.store() RETURNS trigger AS
|
CREATE SCHEMA IF NOT EXISTS housenumber;
|
||||||
$$
|
|
||||||
BEGIN
|
|
||||||
IF (tg_op = 'DELETE') THEN
|
|
||||||
INSERT INTO housenumber.osm_ids VALUES (OLD.osm_id);
|
|
||||||
ELSE
|
|
||||||
INSERT INTO housenumber.osm_ids VALUES (NEW.osm_id);
|
|
||||||
END IF;
|
|
||||||
RETURN NULL;
|
|
||||||
END;
|
|
||||||
$$ LANGUAGE plpgsql;
|
|
||||||
|
|
||||||
CREATE TABLE IF NOT EXISTS housenumber.updates
|
CREATE TABLE IF NOT EXISTS housenumber.updates(id serial primary key, t text, unique (t));
|
||||||
(
|
CREATE OR REPLACE FUNCTION housenumber.flag() RETURNS trigger AS $$
|
||||||
id serial PRIMARY KEY,
|
|
||||||
t text,
|
|
||||||
UNIQUE (t)
|
|
||||||
);
|
|
||||||
CREATE OR REPLACE FUNCTION housenumber.flag() RETURNS trigger AS
|
|
||||||
$$
|
|
||||||
BEGIN
|
BEGIN
|
||||||
INSERT INTO housenumber.updates(t) VALUES ('y') ON CONFLICT(t) DO NOTHING;
|
INSERT INTO housenumber.updates(t) VALUES ('y') ON CONFLICT(t) DO NOTHING;
|
||||||
RETURN NULL;
|
RETURN null;
|
||||||
END;
|
END;
|
||||||
$$ LANGUAGE plpgsql;
|
$$ language plpgsql;
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION housenumber.refresh() RETURNS trigger AS
|
CREATE OR REPLACE FUNCTION housenumber.refresh() RETURNS trigger AS
|
||||||
$$
|
$BODY$
|
||||||
DECLARE
|
BEGIN
|
||||||
t TIMESTAMP WITH TIME ZONE := clock_timestamp();
|
|
||||||
BEGIN
|
|
||||||
RAISE LOG 'Refresh housenumber';
|
RAISE LOG 'Refresh housenumber';
|
||||||
PERFORM convert_housenumber_point(false);
|
PERFORM convert_housenumber_point();
|
||||||
-- noinspection SqlWithoutWhere
|
|
||||||
DELETE FROM housenumber.osm_ids;
|
|
||||||
-- noinspection SqlWithoutWhere
|
|
||||||
DELETE FROM housenumber.updates;
|
DELETE FROM housenumber.updates;
|
||||||
|
RETURN null;
|
||||||
RAISE LOG 'Refresh housenumber done in %', age(clock_timestamp(), t);
|
END;
|
||||||
RETURN NULL;
|
$BODY$
|
||||||
END;
|
language plpgsql;
|
||||||
$$ LANGUAGE plpgsql;
|
|
||||||
|
|
||||||
CREATE TRIGGER trigger_store
|
|
||||||
AFTER INSERT OR UPDATE OR DELETE
|
|
||||||
ON osm_housenumber_point
|
|
||||||
FOR EACH ROW
|
|
||||||
EXECUTE PROCEDURE housenumber.store();
|
|
||||||
|
|
||||||
CREATE TRIGGER trigger_flag
|
CREATE TRIGGER trigger_flag
|
||||||
AFTER INSERT OR UPDATE OR DELETE
|
AFTER INSERT OR UPDATE OR DELETE ON osm_housenumber_point
|
||||||
ON osm_housenumber_point
|
|
||||||
FOR EACH STATEMENT
|
FOR EACH STATEMENT
|
||||||
EXECUTE PROCEDURE housenumber.flag();
|
EXECUTE PROCEDURE housenumber.flag();
|
||||||
|
|
||||||
CREATE CONSTRAINT TRIGGER trigger_refresh
|
CREATE CONSTRAINT TRIGGER trigger_refresh
|
||||||
AFTER INSERT
|
AFTER INSERT ON housenumber.updates
|
||||||
ON housenumber.updates
|
|
||||||
INITIALLY DEFERRED
|
INITIALLY DEFERRED
|
||||||
FOR EACH ROW
|
FOR EACH ROW
|
||||||
EXECUTE PROCEDURE housenumber.refresh();
|
EXECUTE PROCEDURE housenumber.refresh();
|
||||||
|
|||||||
12
layers/housenumber/layer.sql
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
|
||||||
|
-- etldoc: layer_housenumber[shape=record fillcolor=lightpink, style="rounded,filled",
|
||||||
|
-- etldoc: label="layer_housenumber | <z14_> z14+" ] ;
|
||||||
|
|
||||||
|
CREATE OR REPLACE FUNCTION layer_housenumber(bbox geometry, zoom_level integer)
|
||||||
|
RETURNS TABLE(osm_id bigint, geometry geometry, housenumber text) AS $$
|
||||||
|
-- etldoc: osm_housenumber_point -> layer_housenumber:z14_
|
||||||
|
SELECT osm_id, geometry, housenumber FROM osm_housenumber_point
|
||||||
|
WHERE zoom_level >= 14 AND geometry && bbox;
|
||||||
|
$$
|
||||||
|
LANGUAGE SQL
|
||||||
|
IMMUTABLE PARALLEL SAFE;
|
||||||
|
Before Width: | Height: | Size: 366 KiB After Width: | Height: | Size: 208 KiB |
@ -1,349 +0,0 @@
|
|||||||
DROP TABLE IF EXISTS osm_landcover_gen_z7;
|
|
||||||
DROP TABLE IF EXISTS osm_landcover_gen_z8;
|
|
||||||
DROP TABLE IF EXISTS osm_landcover_gen_z9;
|
|
||||||
DROP TABLE IF EXISTS osm_landcover_gen_z10;
|
|
||||||
DROP TABLE IF EXISTS osm_landcover_gen_z11;
|
|
||||||
DROP TABLE IF EXISTS osm_landcover_gen_z12;
|
|
||||||
DROP TABLE IF EXISTS osm_landcover_gen_z13;
|
|
||||||
DROP TABLE IF EXISTS simplify_vw_z7 CASCADE;
|
|
||||||
DROP TABLE IF EXISTS simplify_vw_z8 CASCADE;
|
|
||||||
DROP TABLE IF EXISTS simplify_vw_z9 CASCADE;
|
|
||||||
DROP TABLE IF EXISTS simplify_vw_z10 CASCADE;
|
|
||||||
DROP TABLE IF EXISTS simplify_vw_z11 CASCADE;
|
|
||||||
DROP TABLE IF EXISTS simplify_vw_z12 CASCADE;
|
|
||||||
DROP TABLE IF EXISTS simplify_vw_z13 CASCADE;
|
|
||||||
|
|
||||||
-- etldoc: osm_landcover_polygon -> osm_landcover_gen_z13
|
|
||||||
CREATE TABLE simplify_vw_z13 AS
|
|
||||||
(
|
|
||||||
SELECT subclass,
|
|
||||||
ST_MakeValid(
|
|
||||||
ST_SnapToGrid(
|
|
||||||
ST_SimplifyVW(geometry, power(zres(13),2)),
|
|
||||||
0.001)) AS geometry
|
|
||||||
FROM osm_landcover_polygon
|
|
||||||
WHERE ST_Area(geometry) > power(zres(10),2)
|
|
||||||
);
|
|
||||||
CREATE INDEX ON simplify_vw_z13 USING GIST (geometry);
|
|
||||||
|
|
||||||
CREATE TABLE osm_landcover_gen_z13 AS
|
|
||||||
(
|
|
||||||
SELECT subclass,
|
|
||||||
ST_MakeValid(
|
|
||||||
(ST_dump(
|
|
||||||
ST_Union(geometry))).geom) AS geometry
|
|
||||||
FROM (
|
|
||||||
SELECT subclass,
|
|
||||||
ST_ClusterDBSCAN(geometry, eps := 0, minpoints := 1) over () AS cid, geometry
|
|
||||||
FROM simplify_vw_z13
|
|
||||||
WHERE ST_NPoints(geometry) < 50
|
|
||||||
AND subclass IN ('wood', 'forest')) union_geom50
|
|
||||||
GROUP BY subclass,
|
|
||||||
cid
|
|
||||||
UNION ALL
|
|
||||||
SELECT subclass, ST_MakeValid((ST_dump(ST_Union(geometry))).geom) AS geometry
|
|
||||||
FROM (
|
|
||||||
SELECT subclass,
|
|
||||||
ST_ClusterDBSCAN(geometry, eps := 0, minpoints := 1) over () AS cid, geometry
|
|
||||||
FROM simplify_vw_z13
|
|
||||||
WHERE ST_NPoints(geometry) >= 50
|
|
||||||
AND ST_NPoints(geometry) < 300
|
|
||||||
AND subclass IN ('wood', 'forest')) union_geom300
|
|
||||||
GROUP BY subclass,
|
|
||||||
cid
|
|
||||||
UNION ALL
|
|
||||||
SELECT subclass,
|
|
||||||
geometry
|
|
||||||
FROM simplify_vw_z13
|
|
||||||
WHERE (ST_NPoints(geometry) >= 300 AND subclass IN ('wood', 'forest'))
|
|
||||||
OR (subclass NOT IN ('wood', 'forest'))
|
|
||||||
);
|
|
||||||
|
|
||||||
CREATE INDEX ON osm_landcover_gen_z13 USING GIST (geometry);
|
|
||||||
|
|
||||||
|
|
||||||
-- etldoc: osm_landcover_gen_z13 -> osm_landcover_gen_z12
|
|
||||||
CREATE TABLE simplify_vw_z12 AS
|
|
||||||
(
|
|
||||||
SELECT subclass,
|
|
||||||
ST_MakeValid(
|
|
||||||
ST_SnapToGrid(
|
|
||||||
ST_SimplifyVW(geometry, power(zres(12),2)),
|
|
||||||
0.001)) AS geometry
|
|
||||||
FROM simplify_vw_z13
|
|
||||||
WHERE ST_Area(geometry) > power(zres(9),2)
|
|
||||||
);
|
|
||||||
CREATE INDEX ON simplify_vw_z12 USING GIST (geometry);
|
|
||||||
|
|
||||||
CREATE TABLE osm_landcover_gen_z12 AS
|
|
||||||
(
|
|
||||||
SELECT subclass,
|
|
||||||
ST_MakeValid(
|
|
||||||
(ST_dump(
|
|
||||||
ST_Union(geometry))).geom) AS geometry
|
|
||||||
FROM (
|
|
||||||
SELECT subclass,
|
|
||||||
ST_ClusterDBSCAN(geometry, eps := 0, minpoints := 1) over () AS cid, geometry
|
|
||||||
FROM simplify_vw_z12
|
|
||||||
WHERE ST_NPoints(geometry) < 50
|
|
||||||
AND subclass IN ('wood', 'forest')) union_geom50
|
|
||||||
GROUP BY subclass,
|
|
||||||
cid
|
|
||||||
UNION ALL
|
|
||||||
SELECT subclass, ST_MakeValid((ST_dump(ST_Union(geometry))).geom) AS geometry
|
|
||||||
FROM (
|
|
||||||
SELECT subclass,
|
|
||||||
ST_ClusterDBSCAN(geometry, eps := 0, minpoints := 1) over () AS cid, geometry
|
|
||||||
FROM simplify_vw_z12
|
|
||||||
WHERE ST_NPoints(geometry) >= 50
|
|
||||||
AND ST_NPoints(geometry) < 300
|
|
||||||
AND subclass IN ('wood', 'forest')) union_geom300
|
|
||||||
GROUP BY subclass,
|
|
||||||
cid
|
|
||||||
UNION ALL
|
|
||||||
SELECT subclass,
|
|
||||||
geometry
|
|
||||||
FROM simplify_vw_z12
|
|
||||||
WHERE (ST_NPoints(geometry) >= 300 AND subclass IN ('wood', 'forest'))
|
|
||||||
OR (subclass NOT IN ('wood', 'forest'))
|
|
||||||
);
|
|
||||||
|
|
||||||
CREATE INDEX ON osm_landcover_gen_z12 USING GIST (geometry);
|
|
||||||
|
|
||||||
|
|
||||||
-- etldoc: osm_landcover_gen_z12 -> osm_landcover_gen_z11
|
|
||||||
CREATE TABLE simplify_vw_z11 AS
|
|
||||||
(
|
|
||||||
SELECT subclass,
|
|
||||||
ST_MakeValid(
|
|
||||||
ST_SnapToGrid(
|
|
||||||
ST_SimplifyVW(geometry, power(zres(11),2)),
|
|
||||||
0.001)) AS geometry
|
|
||||||
FROM simplify_vw_z12
|
|
||||||
WHERE ST_Area(geometry) > power(zres(8),2)
|
|
||||||
);
|
|
||||||
CREATE INDEX ON simplify_vw_z11 USING GIST (geometry);
|
|
||||||
|
|
||||||
CREATE TABLE osm_landcover_gen_z11 AS
|
|
||||||
(
|
|
||||||
SELECT subclass,
|
|
||||||
ST_MakeValid(
|
|
||||||
(ST_dump(
|
|
||||||
ST_Union(geometry))).geom) AS geometry
|
|
||||||
FROM (
|
|
||||||
SELECT subclass,
|
|
||||||
ST_ClusterDBSCAN(geometry, eps := 0, minpoints := 1) over () AS cid, geometry
|
|
||||||
FROM simplify_vw_z11
|
|
||||||
WHERE ST_NPoints(geometry) < 50
|
|
||||||
AND subclass IN ('wood', 'forest')) union_geom50
|
|
||||||
GROUP BY subclass,
|
|
||||||
cid
|
|
||||||
UNION ALL
|
|
||||||
SELECT subclass, ST_MakeValid((ST_dump(ST_Union(geometry))).geom) AS geometry
|
|
||||||
FROM (
|
|
||||||
SELECT subclass,
|
|
||||||
ST_ClusterDBSCAN(geometry, eps := 0, minpoints := 1) over () AS cid, geometry
|
|
||||||
FROM simplify_vw_z11
|
|
||||||
WHERE ST_NPoints(geometry) >= 50
|
|
||||||
AND ST_NPoints(geometry) < 300
|
|
||||||
AND subclass IN ('wood', 'forest')) union_geom300
|
|
||||||
GROUP BY subclass,
|
|
||||||
cid
|
|
||||||
UNION ALL
|
|
||||||
SELECT subclass,
|
|
||||||
geometry
|
|
||||||
FROM simplify_vw_z11
|
|
||||||
WHERE (ST_NPoints(geometry) >= 300 AND subclass IN ('wood', 'forest'))
|
|
||||||
OR (subclass NOT IN ('wood', 'forest'))
|
|
||||||
);
|
|
||||||
|
|
||||||
CREATE INDEX ON osm_landcover_gen_z11 USING GIST (geometry);
|
|
||||||
|
|
||||||
|
|
||||||
-- etldoc: osm_landcover_gen_z11 -> osm_landcover_gen_z10
|
|
||||||
CREATE TABLE simplify_vw_z10 AS
|
|
||||||
(
|
|
||||||
SELECT subclass,
|
|
||||||
ST_MakeValid(
|
|
||||||
ST_SnapToGrid(
|
|
||||||
ST_SimplifyVW(geometry, power(zres(10),2)),
|
|
||||||
0.001)) AS geometry
|
|
||||||
FROM simplify_vw_z11
|
|
||||||
WHERE ST_Area(geometry) > power(zres(8),2)
|
|
||||||
);
|
|
||||||
CREATE INDEX ON simplify_vw_z10 USING GIST (geometry);
|
|
||||||
|
|
||||||
CREATE TABLE osm_landcover_gen_z10 AS
|
|
||||||
(
|
|
||||||
SELECT subclass,
|
|
||||||
ST_MakeValid(
|
|
||||||
(ST_dump(
|
|
||||||
ST_Union(geometry))).geom) AS geometry
|
|
||||||
FROM (
|
|
||||||
SELECT subclass,
|
|
||||||
ST_ClusterDBSCAN(geometry, eps := 0, minpoints := 1) over () AS cid, geometry
|
|
||||||
FROM simplify_vw_z10
|
|
||||||
WHERE ST_NPoints(geometry) < 50
|
|
||||||
AND subclass IN ('wood', 'forest')) union_geom50
|
|
||||||
GROUP BY subclass,
|
|
||||||
cid
|
|
||||||
UNION ALL
|
|
||||||
SELECT subclass, ST_MakeValid((ST_dump(ST_Union(geometry))).geom) AS geometry
|
|
||||||
FROM (
|
|
||||||
SELECT subclass,
|
|
||||||
ST_ClusterDBSCAN(geometry, eps := 0, minpoints := 1) over () AS cid, geometry
|
|
||||||
FROM simplify_vw_z10
|
|
||||||
WHERE ST_NPoints(geometry) >= 50
|
|
||||||
AND ST_NPoints(geometry) < 300
|
|
||||||
AND subclass IN ('wood', 'forest')) union_geom300
|
|
||||||
GROUP BY subclass,
|
|
||||||
cid
|
|
||||||
UNION ALL
|
|
||||||
SELECT subclass,
|
|
||||||
geometry
|
|
||||||
FROM simplify_vw_z10
|
|
||||||
WHERE (ST_NPoints(geometry) >= 300 AND subclass IN ('wood', 'forest'))
|
|
||||||
OR (subclass NOT IN ('wood', 'forest'))
|
|
||||||
);
|
|
||||||
|
|
||||||
CREATE INDEX ON osm_landcover_gen_z10 USING GIST (geometry);
|
|
||||||
|
|
||||||
|
|
||||||
-- etldoc: osm_landcover_gen_z10 -> osm_landcover_gen_z9
|
|
||||||
CREATE TABLE simplify_vw_z9 AS
|
|
||||||
(
|
|
||||||
SELECT subclass,
|
|
||||||
ST_MakeValid(
|
|
||||||
ST_SnapToGrid(
|
|
||||||
ST_SimplifyVW(geometry, power(zres(9),2)),
|
|
||||||
0.001)) AS geometry
|
|
||||||
FROM simplify_vw_z10
|
|
||||||
WHERE ST_Area(geometry) > power(zres(7),2)
|
|
||||||
);
|
|
||||||
CREATE INDEX ON simplify_vw_z9 USING GIST (geometry);
|
|
||||||
|
|
||||||
CREATE TABLE osm_landcover_gen_z9 AS
|
|
||||||
(
|
|
||||||
SELECT subclass,
|
|
||||||
ST_MakeValid(
|
|
||||||
(ST_dump(
|
|
||||||
ST_Union(geometry))).geom) AS geometry
|
|
||||||
FROM (
|
|
||||||
SELECT subclass,
|
|
||||||
ST_ClusterDBSCAN(geometry, eps := 0, minpoints := 1) over () AS cid, geometry
|
|
||||||
FROM simplify_vw_z9
|
|
||||||
WHERE ST_NPoints(geometry) < 50
|
|
||||||
AND subclass IN ('wood', 'forest')) union_geom50
|
|
||||||
GROUP BY subclass,
|
|
||||||
cid
|
|
||||||
UNION ALL
|
|
||||||
SELECT subclass, ST_MakeValid((ST_dump(ST_Union(geometry))).geom) AS geometry
|
|
||||||
FROM (
|
|
||||||
SELECT subclass,
|
|
||||||
ST_ClusterDBSCAN(geometry, eps := 0, minpoints := 1) over () AS cid, geometry
|
|
||||||
FROM simplify_vw_z9
|
|
||||||
WHERE ST_NPoints(geometry) >= 50
|
|
||||||
AND ST_NPoints(geometry) < 300
|
|
||||||
AND subclass IN ('wood', 'forest')) union_geom300
|
|
||||||
GROUP BY subclass,
|
|
||||||
cid
|
|
||||||
UNION ALL
|
|
||||||
SELECT subclass,
|
|
||||||
ST_MakeValid(
|
|
||||||
(ST_Dump(
|
|
||||||
ST_Union(geometry))).geom) AS geometry
|
|
||||||
FROM (
|
|
||||||
SELECT subclass,
|
|
||||||
ST_ClusterDBSCAN(geometry, eps := 0, minpoints := 1) over () AS cid, geometry
|
|
||||||
FROM simplify_vw_z9
|
|
||||||
WHERE ST_NPoints(geometry) >= 300
|
|
||||||
AND subclass IN ('wood', 'forest')) union_geom_rest
|
|
||||||
GROUP BY subclass,
|
|
||||||
cid
|
|
||||||
UNION ALL
|
|
||||||
SELECT subclass,
|
|
||||||
geometry
|
|
||||||
FROM simplify_vw_z9
|
|
||||||
WHERE subclass NOT IN ('wood', 'forest')
|
|
||||||
);
|
|
||||||
|
|
||||||
CREATE INDEX ON osm_landcover_gen_z9 USING GIST (geometry);
|
|
||||||
|
|
||||||
|
|
||||||
-- etldoc: osm_landcover_gen_z9 -> osm_landcover_gen_z8
|
|
||||||
CREATE TABLE simplify_vw_z8 AS
|
|
||||||
(
|
|
||||||
SELECT subclass,
|
|
||||||
ST_MakeValid(
|
|
||||||
ST_SnapToGrid(
|
|
||||||
ST_SimplifyVW(geometry, power(zres(8),2)),
|
|
||||||
0.001)) AS geometry
|
|
||||||
FROM simplify_vw_z9
|
|
||||||
WHERE ST_Area(geometry) > power(zres(6),2)
|
|
||||||
);
|
|
||||||
CREATE INDEX ON simplify_vw_z8 USING GIST (geometry);
|
|
||||||
|
|
||||||
CREATE TABLE osm_landcover_gen_z8 AS
|
|
||||||
(
|
|
||||||
SELECT subclass,
|
|
||||||
ST_MakeValid(
|
|
||||||
(ST_Dump(
|
|
||||||
ST_Union(geometry))).geom) AS geometry
|
|
||||||
FROM
|
|
||||||
(
|
|
||||||
SELECT subclass,
|
|
||||||
ST_ClusterDBSCAN(geometry, eps := 0, minpoints := 1) OVER () AS cid,
|
|
||||||
geometry
|
|
||||||
FROM simplify_vw_z8
|
|
||||||
) union_geom
|
|
||||||
GROUP BY subclass,
|
|
||||||
cid
|
|
||||||
UNION ALL
|
|
||||||
SELECT subclass,
|
|
||||||
geometry
|
|
||||||
FROM simplify_vw_z8
|
|
||||||
WHERE subclass NOT IN ('wood', 'forest')
|
|
||||||
);
|
|
||||||
|
|
||||||
CREATE INDEX ON osm_landcover_gen_z8 USING GIST (geometry);
|
|
||||||
|
|
||||||
|
|
||||||
-- etldoc: osm_landcover_gen_z8 -> osm_landcover_gen_z7
|
|
||||||
CREATE TABLE simplify_vw_z7 AS
|
|
||||||
(
|
|
||||||
SELECT subclass,
|
|
||||||
ST_MakeValid(
|
|
||||||
ST_SnapToGrid(
|
|
||||||
ST_SimplifyVW(geometry, power(zres(7),2)),
|
|
||||||
0.001)) AS geometry
|
|
||||||
FROM simplify_vw_z8
|
|
||||||
WHERE ST_Area(geometry) > power(zres(5),2)
|
|
||||||
);
|
|
||||||
CREATE INDEX ON simplify_vw_z7 USING GIST (geometry);
|
|
||||||
|
|
||||||
CREATE TABLE osm_landcover_gen_z7 AS
|
|
||||||
(
|
|
||||||
SELECT subclass,
|
|
||||||
ST_MakeValid(
|
|
||||||
(ST_Dump(
|
|
||||||
ST_Union(geometry))).geom) AS geometry
|
|
||||||
FROM
|
|
||||||
(
|
|
||||||
SELECT subclass,
|
|
||||||
ST_ClusterDBSCAN(geometry, eps := 0, minpoints := 1) OVER () AS cid,
|
|
||||||
geometry
|
|
||||||
FROM simplify_vw_z7
|
|
||||||
) union_geom
|
|
||||||
GROUP BY subclass,
|
|
||||||
cid
|
|
||||||
);
|
|
||||||
|
|
||||||
CREATE INDEX ON osm_landcover_gen_z7 USING GIST (geometry);
|
|
||||||
|
|
||||||
DROP TABLE IF EXISTS simplify_vw_z7 CASCADE;
|
|
||||||
DROP TABLE IF EXISTS simplify_vw_z8 CASCADE;
|
|
||||||
DROP TABLE IF EXISTS simplify_vw_z9 CASCADE;
|
|
||||||
DROP TABLE IF EXISTS simplify_vw_z10 CASCADE;
|
|
||||||
DROP TABLE IF EXISTS simplify_vw_z11 CASCADE;
|
|
||||||
DROP TABLE IF EXISTS simplify_vw_z12 CASCADE;
|
|
||||||
DROP TABLE IF EXISTS simplify_vw_z13 CASCADE;
|
|
||||||
@ -9,365 +9,127 @@
|
|||||||
--);
|
--);
|
||||||
--CREATE INDEX IF NOT EXISTS landcover_grouped_gen2_geometry_idx ON landcover_grouped_gen2 USING gist(geometry);
|
--CREATE INDEX IF NOT EXISTS landcover_grouped_gen2_geometry_idx ON landcover_grouped_gen2 USING gist(geometry);
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION landcover_class(subclass varchar) RETURNS text AS
|
CREATE OR REPLACE FUNCTION landcover_class(subclass VARCHAR) RETURNS TEXT AS $$
|
||||||
|
SELECT CASE
|
||||||
|
%%FIELD_MAPPING: class %%
|
||||||
|
END;
|
||||||
$$
|
$$
|
||||||
SELECT CASE
|
LANGUAGE SQL
|
||||||
%%FIELD_MAPPING: class %%
|
IMMUTABLE PARALLEL SAFE;
|
||||||
END;
|
|
||||||
$$ LANGUAGE SQL IMMUTABLE
|
|
||||||
-- STRICT
|
|
||||||
PARALLEL SAFE;
|
|
||||||
|
|
||||||
-- ne_50m_antarctic_ice_shelves_polys
|
-- etldoc: ne_110m_glaciated_areas -> landcover_z0
|
||||||
-- etldoc: ne_50m_antarctic_ice_shelves_polys -> ne_50m_antarctic_ice_shelves_polys_gen_z4
|
CREATE OR REPLACE VIEW landcover_z0 AS (
|
||||||
DROP MATERIALIZED VIEW IF EXISTS ne_50m_antarctic_ice_shelves_polys_gen_z4 CASCADE;
|
SELECT NULL::bigint AS osm_id, geometry, 'glacier'::text AS subclass FROM ne_110m_glaciated_areas
|
||||||
CREATE MATERIALIZED VIEW ne_50m_antarctic_ice_shelves_polys_gen_z4 AS
|
);
|
||||||
(
|
|
||||||
SELECT
|
|
||||||
ST_Simplify(geometry, ZRes(6)) as geometry,
|
|
||||||
'ice_shelf'::text AS subclass
|
|
||||||
FROM ne_50m_antarctic_ice_shelves_polys
|
|
||||||
) /* DELAY_MATERIALIZED_VIEW_CREATION */ ;
|
|
||||||
CREATE INDEX IF NOT EXISTS ne_50m_antarctic_ice_shelves_polys_gen_z4_idx ON ne_50m_antarctic_ice_shelves_polys_gen_z4 USING gist (geometry);
|
|
||||||
|
|
||||||
-- ne_110m_glaciated_areas
|
CREATE OR REPLACE VIEW landcover_z2 AS (
|
||||||
-- etldoc: ne_110m_glaciated_areas -> ne_110m_glaciated_areas_gen_z1
|
-- etldoc: ne_50m_glaciated_areas -> landcover_z2
|
||||||
DROP MATERIALIZED VIEW IF EXISTS ne_110m_glaciated_areas_gen_z1 CASCADE;
|
SELECT NULL::bigint AS osm_id, geometry, 'glacier'::text AS subclass FROM ne_50m_glaciated_areas
|
||||||
CREATE MATERIALIZED VIEW ne_110m_glaciated_areas_gen_z1 AS
|
UNION ALL
|
||||||
(
|
-- etldoc: ne_50m_antarctic_ice_shelves_polys -> landcover_z2
|
||||||
SELECT
|
SELECT NULL::bigint AS osm_id, geometry, 'ice_shelf'::text AS subclass FROM ne_50m_antarctic_ice_shelves_polys
|
||||||
ST_Simplify(geometry, ZRes(3)) as geometry,
|
);
|
||||||
'glacier'::text AS subclass
|
|
||||||
FROM ne_110m_glaciated_areas
|
|
||||||
) /* DELAY_MATERIALIZED_VIEW_CREATION */ ;
|
|
||||||
CREATE INDEX IF NOT EXISTS ne_110m_glaciated_areas_gen_z1_idx ON ne_110m_glaciated_areas_gen_z1 USING gist (geometry);
|
|
||||||
|
|
||||||
-- etldoc: ne_110m_glaciated_areas_gen_z1 -> ne_110m_glaciated_areas_gen_z0
|
CREATE OR REPLACE VIEW landcover_z5 AS (
|
||||||
DROP MATERIALIZED VIEW IF EXISTS ne_110m_glaciated_areas_gen_z0 CASCADE;
|
-- etldoc: ne_10m_glaciated_areas -> landcover_z5
|
||||||
CREATE MATERIALIZED VIEW ne_110m_glaciated_areas_gen_z0 AS
|
SELECT NULL::bigint AS osm_id, geometry, 'glacier'::text AS subclass FROM ne_10m_glaciated_areas
|
||||||
(
|
UNION ALL
|
||||||
SELECT
|
-- etldoc: ne_10m_antarctic_ice_shelves_polys -> landcover_z5
|
||||||
ST_Simplify(geometry, ZRes(2)) as geometry,
|
SELECT NULL::bigint AS osm_id, geometry, 'ice_shelf'::text AS subclass FROM ne_10m_antarctic_ice_shelves_polys
|
||||||
subclass
|
);
|
||||||
FROM ne_110m_glaciated_areas_gen_z1
|
|
||||||
) /* DELAY_MATERIALIZED_VIEW_CREATION */ ;
|
|
||||||
CREATE INDEX IF NOT EXISTS ne_110m_glaciated_areas_gen_z0_idx ON ne_110m_glaciated_areas_gen_z0 USING gist (geometry);
|
|
||||||
|
|
||||||
-- etldoc: ne_50m_antarctic_ice_shelves_polys_gen_z4 -> ne_50m_antarctic_ice_shelves_polys_gen_z3
|
CREATE OR REPLACE VIEW landcover_z7 AS (
|
||||||
DROP MATERIALIZED VIEW IF EXISTS ne_50m_antarctic_ice_shelves_polys_gen_z3 CASCADE;
|
-- etldoc: osm_landcover_polygon_gen7 -> landcover_z7
|
||||||
CREATE MATERIALIZED VIEW ne_50m_antarctic_ice_shelves_polys_gen_z3 AS
|
SELECT osm_id, geometry, subclass FROM osm_landcover_polygon_gen7
|
||||||
(
|
);
|
||||||
SELECT
|
|
||||||
ST_Simplify(geometry, ZRes(5)) as geometry,
|
|
||||||
subclass
|
|
||||||
FROM ne_50m_antarctic_ice_shelves_polys_gen_z4
|
|
||||||
) /* DELAY_MATERIALIZED_VIEW_CREATION */ ;
|
|
||||||
CREATE INDEX IF NOT EXISTS ne_50m_antarctic_ice_shelves_polys_gen_z3_idx ON ne_50m_antarctic_ice_shelves_polys_gen_z3 USING gist (geometry);
|
|
||||||
|
|
||||||
-- etldoc: ne_50m_antarctic_ice_shelves_polys_gen_z3 -> ne_50m_antarctic_ice_shelves_polys_gen_z2
|
CREATE OR REPLACE VIEW landcover_z8 AS (
|
||||||
DROP MATERIALIZED VIEW IF EXISTS ne_50m_antarctic_ice_shelves_polys_gen_z2 CASCADE;
|
-- etldoc: osm_landcover_polygon_gen6 -> landcover_z8
|
||||||
CREATE MATERIALIZED VIEW ne_50m_antarctic_ice_shelves_polys_gen_z2 AS
|
SELECT osm_id, geometry, subclass FROM osm_landcover_polygon_gen6
|
||||||
(
|
);
|
||||||
SELECT
|
|
||||||
ST_Simplify(geometry, ZRes(4)) as geometry,
|
|
||||||
subclass
|
|
||||||
FROM ne_50m_antarctic_ice_shelves_polys_gen_z3
|
|
||||||
) /* DELAY_MATERIALIZED_VIEW_CREATION */ ;
|
|
||||||
CREATE INDEX IF NOT EXISTS ne_50m_antarctic_ice_shelves_polys_gen_z2_idx ON ne_50m_antarctic_ice_shelves_polys_gen_z2 USING gist (geometry);
|
|
||||||
|
|
||||||
-- ne_50m_glaciated_areas
|
CREATE OR REPLACE VIEW landcover_z9 AS (
|
||||||
-- etldoc: ne_50m_glaciated_areas -> ne_50m_glaciated_areas_gen_z4
|
-- etldoc: osm_landcover_polygon_gen5 -> landcover_z9
|
||||||
DROP MATERIALIZED VIEW IF EXISTS ne_50m_glaciated_areas_gen_z4 CASCADE;
|
SELECT osm_id, geometry, subclass FROM osm_landcover_polygon_gen5
|
||||||
CREATE MATERIALIZED VIEW ne_50m_glaciated_areas_gen_z4 AS
|
);
|
||||||
(
|
|
||||||
SELECT
|
|
||||||
ST_Simplify(geometry, ZRes(6)) as geometry,
|
|
||||||
'glacier'::text AS subclass
|
|
||||||
FROM ne_50m_glaciated_areas
|
|
||||||
) /* DELAY_MATERIALIZED_VIEW_CREATION */ ;
|
|
||||||
CREATE INDEX IF NOT EXISTS ne_50m_glaciated_areas_gen_z4_idx ON ne_50m_glaciated_areas_gen_z4 USING gist (geometry);
|
|
||||||
|
|
||||||
-- etldoc: ne_50m_glaciated_areas_gen_z4 -> ne_50m_glaciated_areas_gen_z3
|
CREATE OR REPLACE VIEW landcover_z10 AS (
|
||||||
DROP MATERIALIZED VIEW IF EXISTS ne_50m_glaciated_areas_gen_z3 CASCADE;
|
-- etldoc: osm_landcover_polygon_gen4 -> landcover_z10
|
||||||
CREATE MATERIALIZED VIEW ne_50m_glaciated_areas_gen_z3 AS
|
SELECT osm_id, geometry, subclass FROM osm_landcover_polygon_gen4
|
||||||
(
|
);
|
||||||
SELECT
|
|
||||||
ST_Simplify(geometry, ZRes(5)) as geometry,
|
|
||||||
subclass
|
|
||||||
FROM ne_50m_glaciated_areas_gen_z4
|
|
||||||
) /* DELAY_MATERIALIZED_VIEW_CREATION */ ;
|
|
||||||
CREATE INDEX IF NOT EXISTS ne_50m_glaciated_areas_gen_z3_idx ON ne_50m_glaciated_areas_gen_z3 USING gist (geometry);
|
|
||||||
|
|
||||||
-- etldoc: ne_50m_glaciated_areas_gen_z3 -> ne_50m_glaciated_areas_gen_z2
|
CREATE OR REPLACE VIEW landcover_z11 AS (
|
||||||
DROP MATERIALIZED VIEW IF EXISTS ne_50m_glaciated_areas_gen_z2 CASCADE;
|
-- etldoc: osm_landcover_polygon_gen3 -> landcover_z11
|
||||||
CREATE MATERIALIZED VIEW ne_50m_glaciated_areas_gen_z2 AS
|
SELECT osm_id, geometry, subclass FROM osm_landcover_polygon_gen3
|
||||||
(
|
);
|
||||||
SELECT
|
|
||||||
ST_Simplify(geometry, ZRes(4)) as geometry,
|
|
||||||
subclass
|
|
||||||
FROM ne_50m_glaciated_areas_gen_z3
|
|
||||||
) /* DELAY_MATERIALIZED_VIEW_CREATION */ ;
|
|
||||||
CREATE INDEX IF NOT EXISTS ne_50m_glaciated_areas_gen_z2_idx ON ne_50m_glaciated_areas_gen_z2 USING gist (geometry);
|
|
||||||
|
|
||||||
-- ne_10m_glaciated_areas
|
CREATE OR REPLACE VIEW landcover_z12 AS (
|
||||||
-- etldoc: ne_10m_glaciated_areas -> ne_10m_glaciated_areas_gen_z6
|
-- etldoc: osm_landcover_polygon_gen2 -> landcover_z12
|
||||||
DROP MATERIALIZED VIEW IF EXISTS ne_10m_glaciated_areas_gen_z6 CASCADE;
|
SELECT osm_id, geometry, subclass FROM osm_landcover_polygon_gen2
|
||||||
CREATE MATERIALIZED VIEW ne_10m_glaciated_areas_gen_z6 AS
|
);
|
||||||
(
|
|
||||||
SELECT
|
|
||||||
ST_Simplify(geometry, ZRes(8)) as geometry,
|
|
||||||
'glacier'::text AS subclass
|
|
||||||
FROM ne_10m_glaciated_areas
|
|
||||||
) /* DELAY_MATERIALIZED_VIEW_CREATION */ ;
|
|
||||||
CREATE INDEX IF NOT EXISTS ne_10m_glaciated_areas_gen_z6_idx ON ne_10m_glaciated_areas_gen_z6 USING gist (geometry);
|
|
||||||
|
|
||||||
-- etldoc: ne_10m_glaciated_areas_gen_z6 -> ne_10m_glaciated_areas_gen_z5
|
CREATE OR REPLACE VIEW landcover_z13 AS (
|
||||||
DROP MATERIALIZED VIEW IF EXISTS ne_10m_glaciated_areas_gen_z5 CASCADE;
|
-- etldoc: osm_landcover_polygon_gen1 -> landcover_z13
|
||||||
CREATE MATERIALIZED VIEW ne_10m_glaciated_areas_gen_z5 AS
|
SELECT osm_id, geometry, subclass FROM osm_landcover_polygon_gen1
|
||||||
(
|
);
|
||||||
SELECT
|
|
||||||
ST_Simplify(geometry, ZRes(7)) as geometry,
|
|
||||||
subclass
|
|
||||||
FROM ne_10m_glaciated_areas_gen_z6
|
|
||||||
) /* DELAY_MATERIALIZED_VIEW_CREATION */ ;
|
|
||||||
CREATE INDEX IF NOT EXISTS ne_10m_glaciated_areas_gen_z5_idx ON ne_10m_glaciated_areas_gen_z5 USING gist (geometry);
|
|
||||||
|
|
||||||
-- ne_10m_antarctic_ice_shelves_polys
|
CREATE OR REPLACE VIEW landcover_z14 AS (
|
||||||
-- etldoc: ne_10m_antarctic_ice_shelves_polys -> ne_10m_antarctic_ice_shelves_polys_gen_z6
|
-- etldoc: osm_landcover_polygon -> landcover_z14
|
||||||
DROP MATERIALIZED VIEW IF EXISTS ne_10m_antarctic_ice_shelves_polys_gen_z6 CASCADE;
|
SELECT osm_id, geometry, subclass FROM osm_landcover_polygon
|
||||||
CREATE MATERIALIZED VIEW ne_10m_antarctic_ice_shelves_polys_gen_z6 AS
|
);
|
||||||
(
|
|
||||||
SELECT
|
|
||||||
ST_Simplify(geometry, ZRes(8)) as geometry,
|
|
||||||
'ice_shelf'::text AS subclass
|
|
||||||
FROM ne_10m_antarctic_ice_shelves_polys
|
|
||||||
) /* DELAY_MATERIALIZED_VIEW_CREATION */ ;
|
|
||||||
CREATE INDEX IF NOT EXISTS ne_10m_antarctic_ice_shelves_polys_gen_z6_idx ON ne_10m_antarctic_ice_shelves_polys_gen_z6 USING gist (geometry);
|
|
||||||
|
|
||||||
-- etldoc: ne_10m_antarctic_ice_shelves_polys_gen_z6 -> ne_10m_antarctic_ice_shelves_polys_gen_z5
|
-- etldoc: layer_landcover[shape=record fillcolor=lightpink, style="rounded, filled", label="layer_landcover | <z0_1> z0-z1 | <z2_4> z2-z4 | <z5_6> z5-z6 |<z7> z7 |<z8> z8 |<z9> z9 |<z10> z10 |<z11> z11 |<z12> z12|<z13> z13|<z14_> z14+" ] ;
|
||||||
DROP MATERIALIZED VIEW IF EXISTS ne_10m_antarctic_ice_shelves_polys_gen_z5 CASCADE;
|
|
||||||
CREATE MATERIALIZED VIEW ne_10m_antarctic_ice_shelves_polys_gen_z5 AS
|
|
||||||
(
|
|
||||||
SELECT
|
|
||||||
ST_Simplify(geometry, ZRes(7)) as geometry,
|
|
||||||
subclass
|
|
||||||
FROM ne_10m_antarctic_ice_shelves_polys_gen_z6
|
|
||||||
) /* DELAY_MATERIALIZED_VIEW_CREATION */ ;
|
|
||||||
CREATE INDEX IF NOT EXISTS ne_10m_antarctic_ice_shelves_polys_gen_z5_idx ON ne_10m_antarctic_ice_shelves_polys_gen_z5 USING gist (geometry);
|
|
||||||
|
|
||||||
-- etldoc: ne_110m_glaciated_areas_gen_z0 -> landcover_z0
|
|
||||||
CREATE OR REPLACE VIEW landcover_z0 AS
|
|
||||||
(
|
|
||||||
SELECT
|
|
||||||
geometry,
|
|
||||||
subclass
|
|
||||||
FROM ne_110m_glaciated_areas_gen_z0
|
|
||||||
);
|
|
||||||
|
|
||||||
-- etldoc: ne_110m_glaciated_areas_gen_z1 -> landcover_z1
|
|
||||||
CREATE OR REPLACE VIEW landcover_z1 AS
|
|
||||||
(
|
|
||||||
SELECT
|
|
||||||
geometry,
|
|
||||||
subclass
|
|
||||||
FROM ne_110m_glaciated_areas_gen_z1
|
|
||||||
);
|
|
||||||
|
|
||||||
CREATE OR REPLACE VIEW landcover_z2 AS
|
|
||||||
(
|
|
||||||
-- etldoc: ne_50m_glaciated_areas_gen_z2 -> landcover_z2
|
|
||||||
SELECT
|
|
||||||
geometry,
|
|
||||||
subclass
|
|
||||||
FROM ne_50m_glaciated_areas_gen_z2
|
|
||||||
UNION ALL
|
|
||||||
-- etldoc: ne_50m_antarctic_ice_shelves_polys_gen_z2 -> landcover_z2
|
|
||||||
SELECT
|
|
||||||
geometry,
|
|
||||||
subclass
|
|
||||||
FROM ne_50m_antarctic_ice_shelves_polys_gen_z2
|
|
||||||
);
|
|
||||||
|
|
||||||
CREATE OR REPLACE VIEW landcover_z3 AS
|
|
||||||
(
|
|
||||||
-- etldoc: ne_50m_glaciated_areas_gen_z3 -> landcover_z3
|
|
||||||
SELECT
|
|
||||||
geometry,
|
|
||||||
subclass
|
|
||||||
FROM ne_50m_glaciated_areas_gen_z3
|
|
||||||
UNION ALL
|
|
||||||
-- etldoc: ne_50m_antarctic_ice_shelves_polys_gen_z3 -> landcover_z3
|
|
||||||
SELECT
|
|
||||||
geometry,
|
|
||||||
subclass
|
|
||||||
FROM ne_50m_antarctic_ice_shelves_polys_gen_z3
|
|
||||||
);
|
|
||||||
|
|
||||||
CREATE OR REPLACE VIEW landcover_z4 AS
|
|
||||||
(
|
|
||||||
-- etldoc: ne_50m_glaciated_areas_gen_z4 -> landcover_z4
|
|
||||||
SELECT
|
|
||||||
geometry,
|
|
||||||
subclass
|
|
||||||
FROM ne_50m_glaciated_areas_gen_z4
|
|
||||||
UNION ALL
|
|
||||||
-- etldoc: ne_50m_antarctic_ice_shelves_polys_gen_z4 -> landcover_z4
|
|
||||||
SELECT
|
|
||||||
geometry,
|
|
||||||
subclass
|
|
||||||
FROM ne_50m_antarctic_ice_shelves_polys_gen_z4
|
|
||||||
);
|
|
||||||
|
|
||||||
CREATE OR REPLACE VIEW landcover_z5 AS
|
|
||||||
(
|
|
||||||
-- etldoc: ne_10m_glaciated_areas_gen_z5 -> landcover_z5
|
|
||||||
SELECT
|
|
||||||
geometry,
|
|
||||||
subclass
|
|
||||||
FROM ne_10m_glaciated_areas_gen_z5
|
|
||||||
UNION ALL
|
|
||||||
-- etldoc: ne_10m_antarctic_ice_shelves_polys_gen_z5 -> landcover_z5
|
|
||||||
SELECT
|
|
||||||
geometry,
|
|
||||||
subclass
|
|
||||||
FROM ne_10m_antarctic_ice_shelves_polys_gen_z5
|
|
||||||
);
|
|
||||||
|
|
||||||
CREATE OR REPLACE VIEW landcover_z6 AS
|
|
||||||
(
|
|
||||||
-- etldoc: ne_10m_glaciated_areas_gen_z6 -> landcover_z6
|
|
||||||
SELECT
|
|
||||||
geometry,
|
|
||||||
subclass
|
|
||||||
FROM ne_10m_glaciated_areas_gen_z6
|
|
||||||
UNION ALL
|
|
||||||
-- etldoc: ne_10m_antarctic_ice_shelves_polys_gen_z6 -> landcover_z6
|
|
||||||
SELECT
|
|
||||||
geometry,
|
|
||||||
subclass
|
|
||||||
FROM ne_10m_antarctic_ice_shelves_polys_gen_z6
|
|
||||||
);
|
|
||||||
|
|
||||||
-- etldoc: layer_landcover[shape=record fillcolor=lightpink, style="rounded, filled", label="layer_landcover | <z0> z0 | <z1> z1 | <z2> z2 | <z3> z3 | <z4> z4 | <z5> z5 | <z6> z6 |<z7> z7 |<z8> z8 |<z9> z9 |<z10> z10 |<z11> z11 |<z12> z12|<z13> z13|<z14_> z14+" ] ;
|
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION layer_landcover(bbox geometry, zoom_level int)
|
CREATE OR REPLACE FUNCTION layer_landcover(bbox geometry, zoom_level int)
|
||||||
RETURNS TABLE
|
RETURNS TABLE(osm_id bigint, geometry geometry, class text, subclass text) AS $$
|
||||||
(
|
SELECT osm_id, geometry,
|
||||||
geometry geometry,
|
landcover_class(subclass) AS class,
|
||||||
class text,
|
subclass
|
||||||
subclass text
|
FROM (
|
||||||
)
|
-- etldoc: landcover_z0 -> layer_landcover:z0_1
|
||||||
AS
|
SELECT * FROM landcover_z0
|
||||||
|
WHERE zoom_level BETWEEN 0 AND 1 AND geometry && bbox
|
||||||
|
UNION ALL
|
||||||
|
-- etldoc: landcover_z2 -> layer_landcover:z2_4
|
||||||
|
SELECT * FROM landcover_z2
|
||||||
|
WHERE zoom_level BETWEEN 2 AND 4 AND geometry && bbox
|
||||||
|
UNION ALL
|
||||||
|
-- etldoc: landcover_z5 -> layer_landcover:z5_6
|
||||||
|
SELECT * FROM landcover_z5
|
||||||
|
WHERE zoom_level BETWEEN 5 AND 6 AND geometry && bbox
|
||||||
|
UNION ALL
|
||||||
|
-- etldoc: landcover_z7 -> layer_landcover:z7
|
||||||
|
SELECT *
|
||||||
|
FROM landcover_z7 WHERE zoom_level = 7 AND geometry && bbox
|
||||||
|
UNION ALL
|
||||||
|
-- etldoc: landcover_z8 -> layer_landcover:z8
|
||||||
|
SELECT *
|
||||||
|
FROM landcover_z8 WHERE zoom_level = 8 AND geometry && bbox
|
||||||
|
UNION ALL
|
||||||
|
-- etldoc: landcover_z9 -> layer_landcover:z9
|
||||||
|
SELECT *
|
||||||
|
FROM landcover_z9 WHERE zoom_level = 9 AND geometry && bbox
|
||||||
|
UNION ALL
|
||||||
|
-- etldoc: landcover_z10 -> layer_landcover:z10
|
||||||
|
SELECT *
|
||||||
|
FROM landcover_z10 WHERE zoom_level = 10 AND geometry && bbox
|
||||||
|
UNION ALL
|
||||||
|
-- etldoc: landcover_z11 -> layer_landcover:z11
|
||||||
|
SELECT *
|
||||||
|
FROM landcover_z11 WHERE zoom_level = 11 AND geometry && bbox
|
||||||
|
UNION ALL
|
||||||
|
-- etldoc: landcover_z12 -> layer_landcover:z12
|
||||||
|
SELECT *
|
||||||
|
FROM landcover_z12 WHERE zoom_level = 12 AND geometry && bbox
|
||||||
|
UNION ALL
|
||||||
|
-- etldoc: landcover_z13 -> layer_landcover:z13
|
||||||
|
SELECT *
|
||||||
|
FROM landcover_z13 WHERE zoom_level = 13 AND geometry && bbox
|
||||||
|
UNION ALL
|
||||||
|
-- etldoc: landcover_z14 -> layer_landcover:z14_
|
||||||
|
SELECT *
|
||||||
|
FROM landcover_z14 WHERE zoom_level >= 14 AND geometry && bbox
|
||||||
|
) AS zoom_levels;
|
||||||
$$
|
$$
|
||||||
SELECT geometry,
|
LANGUAGE SQL
|
||||||
landcover_class(subclass) AS class,
|
IMMUTABLE PARALLEL SAFE;
|
||||||
subclass
|
|
||||||
FROM (
|
|
||||||
-- etldoc: landcover_z0 -> layer_landcover:z0
|
|
||||||
SELECT geometry,
|
|
||||||
subclass
|
|
||||||
FROM landcover_z0
|
|
||||||
WHERE zoom_level = 0
|
|
||||||
AND geometry && bbox
|
|
||||||
UNION ALL
|
|
||||||
-- etldoc: landcover_z1 -> layer_landcover:z1
|
|
||||||
SELECT geometry,
|
|
||||||
subclass
|
|
||||||
FROM landcover_z1
|
|
||||||
WHERE zoom_level = 1
|
|
||||||
AND geometry && bbox
|
|
||||||
UNION ALL
|
|
||||||
-- etldoc: landcover_z2 -> layer_landcover:z2
|
|
||||||
SELECT geometry,
|
|
||||||
subclass
|
|
||||||
FROM landcover_z2
|
|
||||||
WHERE zoom_level = 2
|
|
||||||
AND geometry && bbox
|
|
||||||
UNION ALL
|
|
||||||
-- etldoc: landcover_z3 -> layer_landcover:z3
|
|
||||||
SELECT geometry,
|
|
||||||
subclass
|
|
||||||
FROM landcover_z3
|
|
||||||
WHERE zoom_level = 3
|
|
||||||
AND geometry && bbox
|
|
||||||
UNION ALL
|
|
||||||
-- etldoc: landcover_z4 -> layer_landcover:z4
|
|
||||||
SELECT geometry,
|
|
||||||
subclass
|
|
||||||
FROM landcover_z4
|
|
||||||
WHERE zoom_level = 4
|
|
||||||
AND geometry && bbox
|
|
||||||
UNION ALL
|
|
||||||
-- etldoc: landcover_z5 -> layer_landcover:z5
|
|
||||||
SELECT geometry,
|
|
||||||
subclass
|
|
||||||
FROM landcover_z5
|
|
||||||
WHERE zoom_level = 5
|
|
||||||
AND geometry && bbox
|
|
||||||
UNION ALL
|
|
||||||
-- etldoc: landcover_z6 -> layer_landcover:z6
|
|
||||||
SELECT geometry,
|
|
||||||
subclass
|
|
||||||
FROM landcover_z6
|
|
||||||
WHERE zoom_level = 6
|
|
||||||
AND geometry && bbox
|
|
||||||
UNION ALL
|
|
||||||
-- etldoc: osm_landcover_gen_z7 -> layer_landcover:z7
|
|
||||||
SELECT geometry,
|
|
||||||
subclass
|
|
||||||
FROM osm_landcover_gen_z7
|
|
||||||
WHERE zoom_level = 7
|
|
||||||
AND geometry && bbox
|
|
||||||
UNION ALL
|
|
||||||
-- etldoc: osm_landcover_gen_z8 -> layer_landcover:z8
|
|
||||||
SELECT geometry,
|
|
||||||
subclass
|
|
||||||
FROM osm_landcover_gen_z8
|
|
||||||
WHERE zoom_level = 8
|
|
||||||
AND geometry && bbox
|
|
||||||
UNION ALL
|
|
||||||
-- etldoc: osm_landcover_gen_z9 -> layer_landcover:z9
|
|
||||||
SELECT geometry,
|
|
||||||
subclass
|
|
||||||
FROM osm_landcover_gen_z9
|
|
||||||
WHERE zoom_level = 9
|
|
||||||
AND geometry && bbox
|
|
||||||
UNION ALL
|
|
||||||
-- etldoc: osm_landcover_gen_z10 -> layer_landcover:z10
|
|
||||||
SELECT geometry,
|
|
||||||
subclass
|
|
||||||
FROM osm_landcover_gen_z10
|
|
||||||
WHERE zoom_level = 10
|
|
||||||
AND geometry && bbox
|
|
||||||
UNION ALL
|
|
||||||
-- etldoc: osm_landcover_gen_z11 -> layer_landcover:z11
|
|
||||||
SELECT geometry,
|
|
||||||
subclass
|
|
||||||
FROM osm_landcover_gen_z11
|
|
||||||
WHERE zoom_level = 11
|
|
||||||
AND geometry && bbox
|
|
||||||
UNION ALL
|
|
||||||
-- etldoc: osm_landcover_gen_z12 -> layer_landcover:z12
|
|
||||||
SELECT geometry,
|
|
||||||
subclass
|
|
||||||
FROM osm_landcover_gen_z12
|
|
||||||
WHERE zoom_level = 12
|
|
||||||
AND geometry && bbox
|
|
||||||
UNION ALL
|
|
||||||
-- etldoc: osm_landcover_gen_z13 -> layer_landcover:z13
|
|
||||||
SELECT geometry,
|
|
||||||
subclass
|
|
||||||
FROM osm_landcover_gen_z13
|
|
||||||
WHERE zoom_level = 13
|
|
||||||
AND geometry && bbox
|
|
||||||
UNION ALL
|
|
||||||
-- etldoc: osm_landcover_polygon -> layer_landcover:z14_
|
|
||||||
SELECT geometry,
|
|
||||||
subclass
|
|
||||||
FROM osm_landcover_polygon
|
|
||||||
WHERE zoom_level >= 14
|
|
||||||
AND geometry && bbox
|
|
||||||
) AS zoom_levels;
|
|
||||||
$$ LANGUAGE SQL STABLE
|
|
||||||
-- STRICT
|
|
||||||
PARALLEL SAFE;
|
|
||||||
|
|||||||
@ -73,7 +73,6 @@ layer:
|
|||||||
geometry_field: geometry
|
geometry_field: geometry
|
||||||
query: (SELECT geometry, class, subclass FROM layer_landcover(!bbox!, z(!scale_denominator!))) AS t
|
query: (SELECT geometry, class, subclass FROM layer_landcover(!bbox!, z(!scale_denominator!))) AS t
|
||||||
schema:
|
schema:
|
||||||
- ./generalized.sql
|
|
||||||
- ./landcover.sql
|
- ./landcover.sql
|
||||||
datasources:
|
datasources:
|
||||||
- type: imposm3
|
- type: imposm3
|
||||||
|
|||||||
@ -1,3 +1,48 @@
|
|||||||
|
|
||||||
|
generalized_tables:
|
||||||
|
|
||||||
|
# etldoc: imposm3 -> osm_landcover_polygon_gen7
|
||||||
|
landcover_polygon_gen7:
|
||||||
|
source: landcover_polygon_gen6
|
||||||
|
sql_filter: area>power(ZRES5,2)
|
||||||
|
tolerance: ZRES7
|
||||||
|
|
||||||
|
# etldoc: imposm3 -> osm_landcover_polygon_gen6
|
||||||
|
landcover_polygon_gen6:
|
||||||
|
source: landcover_polygon_gen5
|
||||||
|
sql_filter: area>power(ZRES6,2)
|
||||||
|
tolerance: ZRES8
|
||||||
|
|
||||||
|
# etldoc: imposm3 -> osm_landcover_polygon_gen5
|
||||||
|
landcover_polygon_gen5:
|
||||||
|
source: landcover_polygon_gen4
|
||||||
|
sql_filter: area>power(ZRES7,2)
|
||||||
|
tolerance: ZRES9
|
||||||
|
|
||||||
|
# etldoc: imposm3 -> osm_landcover_polygon_gen4
|
||||||
|
landcover_polygon_gen4:
|
||||||
|
source: landcover_polygon_gen3
|
||||||
|
sql_filter: area>power(ZRES8,2)
|
||||||
|
tolerance: ZRES10
|
||||||
|
|
||||||
|
# etldoc: imposm3 -> osm_landcover_polygon_gen3
|
||||||
|
landcover_polygon_gen3:
|
||||||
|
source: landcover_polygon_gen2
|
||||||
|
sql_filter: area>power(ZRES8,2)
|
||||||
|
tolerance: ZRES11
|
||||||
|
|
||||||
|
# etldoc: imposm3 -> osm_landcover_polygon_gen2
|
||||||
|
landcover_polygon_gen2:
|
||||||
|
source: landcover_polygon_gen1
|
||||||
|
sql_filter: area>power(ZRES9,2)
|
||||||
|
tolerance: ZRES12
|
||||||
|
|
||||||
|
# etldoc: imposm3 -> osm_landcover_polygon_gen1
|
||||||
|
landcover_polygon_gen1:
|
||||||
|
source: landcover_polygon
|
||||||
|
sql_filter: area>power(ZRES10,2) AND ST_IsValid(geometry)
|
||||||
|
tolerance: ZRES13
|
||||||
|
|
||||||
tables:
|
tables:
|
||||||
# etldoc: imposm3 -> osm_landcover_polygon
|
# etldoc: imposm3 -> osm_landcover_polygon
|
||||||
landcover_polygon:
|
landcover_polygon:
|
||||||
|
|||||||
@ -1,10 +0,0 @@
|
|||||||
## Landmarks
|
|
||||||
|
|
||||||
### Docs
|
|
||||||
This is a custom layer including landmarks (named forests) that can not be classified as a POI
|
|
||||||
|
|
||||||
### Mapping Diagram
|
|
||||||
|
|
||||||
|
|
||||||
### ETL diagram
|
|
||||||
|
|
||||||
@ -1,19 +0,0 @@
|
|||||||
CREATE OR REPLACE FUNCTION lm_class_rank(class text)
|
|
||||||
RETURNS int AS
|
|
||||||
$$
|
|
||||||
SELECT CASE class
|
|
||||||
WHEN 'forest' THEN 120
|
|
||||||
ELSE 1000
|
|
||||||
END;
|
|
||||||
$$ LANGUAGE SQL IMMUTABLE
|
|
||||||
PARALLEL SAFE;
|
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION lm_class(subclass text, mapping_key text)
|
|
||||||
RETURNS text AS
|
|
||||||
$$
|
|
||||||
SELECT CASE
|
|
||||||
%%FIELD_MAPPING: class %%
|
|
||||||
ELSE subclass
|
|
||||||
END;
|
|
||||||
$$ LANGUAGE SQL IMMUTABLE
|
|
||||||
PARALLEL SAFE;
|
|
||||||
|
Before Width: | Height: | Size: 30 KiB |
@ -1,139 +0,0 @@
|
|||||||
layer:
|
|
||||||
id: "landmarks"
|
|
||||||
description: |
|
|
||||||
[Points of interests](http://wiki.openstreetmap.org/wiki/Points_of_interest) containing
|
|
||||||
a of a variety of OpenStreetMap tags. Mostly contains amenities, sport, shop and tourist POIs.
|
|
||||||
buffer_size: 64
|
|
||||||
srs: +proj=merc +a=6378137 +b=6378137 +lat_ts=0.0 +lon_0=0.0 +x_0=0.0 +y_0=0.0 +k=1.0 +units=m +nadgrids=@null +wktext +no_defs +over
|
|
||||||
fields:
|
|
||||||
name: The OSM [`name`](http://wiki.openstreetmap.org/wiki/Key:name) value of the POI.
|
|
||||||
name_en: English name `name:en` if available, otherwise `name`.
|
|
||||||
name_de: German name `name:de` if available, otherwise `name` or `name:en`.
|
|
||||||
class:
|
|
||||||
description: |
|
|
||||||
More general classes of landmarks. If there is no more general `class` for the `subclass`
|
|
||||||
this field will contain the same value as `subclass`.
|
|
||||||
values:
|
|
||||||
shop:
|
|
||||||
subclass: ['accessories', 'antiques', 'beauty', 'bed', 'boutique', 'camera', 'carpet', 'charity', 'chemist',
|
|
||||||
'coffee', 'computer', 'convenience', 'copyshop', 'cosmetics', 'garden_centre', 'doityourself',
|
|
||||||
'erotic', 'electronics', 'fabric', 'florist', 'frozen_food', 'furniture', 'video_games', 'video',
|
|
||||||
'general', 'gift', 'hardware', 'hearing_aids', 'hifi', 'ice_cream', 'interior_decoration',
|
|
||||||
'jewelry', 'kiosk', 'lamps', 'mall', 'massage', 'motorcycle', 'mobile_phone', 'newsagent',
|
|
||||||
'optician', 'outdoor', 'perfumery', 'perfume', 'pet', 'photo', 'second_hand', 'shoes', 'sports',
|
|
||||||
'stationery', 'tailor', 'tattoo', 'ticket', 'tobacco', 'toys', 'travel_agency', 'watches',
|
|
||||||
'weapons', 'wholesale']
|
|
||||||
town_hall:
|
|
||||||
subclass: ['townhall', 'public_building', 'courthouse', 'community_centre']
|
|
||||||
golf:
|
|
||||||
subclass: ['golf', 'golf_course', 'miniature_golf']
|
|
||||||
fast_food:
|
|
||||||
subclass: ['fast_food', 'food_court']
|
|
||||||
park:
|
|
||||||
subclass: ['park', 'bbq']
|
|
||||||
bus:
|
|
||||||
subclass: ['bus_stop', 'bus_station']
|
|
||||||
railway:
|
|
||||||
- __AND__:
|
|
||||||
subclass: 'station'
|
|
||||||
mapping_key: 'railway'
|
|
||||||
- subclass: ['halt', 'tram_stop', 'subway']
|
|
||||||
aerialway:
|
|
||||||
__AND__:
|
|
||||||
subclass: 'station'
|
|
||||||
mapping_key: 'aerialway'
|
|
||||||
entrance:
|
|
||||||
subclass: ['subway_entrance', 'train_station_entrance']
|
|
||||||
campsite:
|
|
||||||
subclass: ['camp_site', 'caravan_site']
|
|
||||||
laundry:
|
|
||||||
subclass: ['laundry', 'dry_cleaning']
|
|
||||||
grocery:
|
|
||||||
subclass: ['supermarket', 'deli', 'delicatessen', 'department_store', 'greengrocer', 'marketplace']
|
|
||||||
library:
|
|
||||||
subclass: ['books', 'library']
|
|
||||||
college:
|
|
||||||
subclass: ['university', 'college']
|
|
||||||
lodging:
|
|
||||||
subclass: ['hotel', 'motel', 'bed_and_breakfast', 'guest_house', 'hostel', 'chalet', 'alpine_hut', 'dormitory']
|
|
||||||
ice_cream:
|
|
||||||
subclass: ['chocolate', 'confectionery']
|
|
||||||
post:
|
|
||||||
subclass: ['post_box', 'post_office']
|
|
||||||
cafe:
|
|
||||||
subclass: ['cafe']
|
|
||||||
school:
|
|
||||||
subclass: ['school', 'kindergarten']
|
|
||||||
alcohol_shop:
|
|
||||||
subclass: ['alcohol', 'beverages', 'wine']
|
|
||||||
bar:
|
|
||||||
subclass: ['bar', 'nightclub']
|
|
||||||
harbor:
|
|
||||||
subclass: ['marina', 'dock']
|
|
||||||
car:
|
|
||||||
subclass: ['car', 'car_repair', 'car_parts', 'taxi']
|
|
||||||
hospital:
|
|
||||||
subclass: ['hospital', 'nursing_home', 'clinic']
|
|
||||||
cemetery:
|
|
||||||
subclass: ['grave_yard', 'cemetery']
|
|
||||||
attraction:
|
|
||||||
subclass: ['attraction', 'viewpoint']
|
|
||||||
beer:
|
|
||||||
subclass: ['biergarten', 'pub']
|
|
||||||
music:
|
|
||||||
subclass: ['music', 'musical_instrument']
|
|
||||||
stadium:
|
|
||||||
subclass: ['american_football', 'stadium', 'soccer']
|
|
||||||
art_gallery:
|
|
||||||
subclass: ['art', 'artwork', 'gallery', 'arts_centre']
|
|
||||||
clothing_store:
|
|
||||||
subclass: ['bag', 'clothes']
|
|
||||||
swimming:
|
|
||||||
subclass: ['swimming_area', 'swimming']
|
|
||||||
castle:
|
|
||||||
subclass: ['castle', 'ruins']
|
|
||||||
subclass:
|
|
||||||
description: |
|
|
||||||
Original value of either the
|
|
||||||
[`amenity`](http://wiki.openstreetmap.org/wiki/Key:amenity),
|
|
||||||
[`barrier`](http://wiki.openstreetmap.org/wiki/Key:barrier),
|
|
||||||
[`historic`](http://wiki.openstreetmap.org/wiki/Key:historic),
|
|
||||||
[`information`](http://wiki.openstreetmap.org/wiki/Key:information),
|
|
||||||
[`landuse`](http://wiki.openstreetmap.org/wiki/Key:landuse),
|
|
||||||
[`leisure`](http://wiki.openstreetmap.org/wiki/Key:leisure),
|
|
||||||
[`railway`](http://wiki.openstreetmap.org/wiki/Key:railway),
|
|
||||||
[`shop`](http://wiki.openstreetmap.org/wiki/Key:shop),
|
|
||||||
[`sport`](http://wiki.openstreetmap.org/wiki/Key:sport),
|
|
||||||
[`station`](http://wiki.openstreetmap.org/wiki/Key:station),
|
|
||||||
[`religion`](http://wiki.openstreetmap.org/wiki/Key:religion),
|
|
||||||
[`tourism`](http://wiki.openstreetmap.org/wiki/Key:tourism),
|
|
||||||
[`aerialway`](http://wiki.openstreetmap.org/wiki/Key:aerialway),
|
|
||||||
[`building`](http://wiki.openstreetmap.org/wiki/Key:building),
|
|
||||||
[`highway`](http://wiki.openstreetmap.org/wiki/Key:highway)
|
|
||||||
or [`waterway`](http://wiki.openstreetmap.org/wiki/Key:waterway)
|
|
||||||
tag. Use this to do more precise styling.
|
|
||||||
rank: |
|
|
||||||
The POIs are ranked ascending according to their importance within a grid. The `rank` value shows the
|
|
||||||
local relative importance of a POI within it's cell in the grid. This can be used to reduce label density at *z14*.
|
|
||||||
Since all POIs already need to be contained at *z14* you can use `less than rank=10` epxression to limit
|
|
||||||
LMs. At some point like *z17* you can show all LMs.
|
|
||||||
level:
|
|
||||||
description: |
|
|
||||||
Original value of [`level`](http://wiki.openstreetmap.org/wiki/Key:level) tag.
|
|
||||||
layer:
|
|
||||||
description: |
|
|
||||||
Original value of [`layer`](http://wiki.openstreetmap.org/wiki/Key:layer) tag.
|
|
||||||
datasource:
|
|
||||||
geometry_field: geometry
|
|
||||||
key_field: osm_id
|
|
||||||
key_field_as_attribute: no
|
|
||||||
srid: 900913
|
|
||||||
query: (SELECT osm_id, geometry, name, name_en, name_de, {name_languages}, class, subclass, layer, level, rank FROM layer_lm(!bbox!, z(!scale_denominator!), !pixel_width!)) AS t
|
|
||||||
schema:
|
|
||||||
- ./class.sql
|
|
||||||
- ./update_lm_polygon.sql
|
|
||||||
- ./update_lm_point.sql
|
|
||||||
- ./layer.sql
|
|
||||||
datasources:
|
|
||||||
- type: imposm3
|
|
||||||
mapping_file: ./mapping.yaml
|
|
||||||
@ -1,85 +0,0 @@
|
|||||||
-- etldoc: layer_lm[shape=record fillcolor=lightpink, style="rounded,filled",
|
|
||||||
-- etldoc: label="layer_lm | <z12> z12 | <z13> z13 | <z14_> z14+" ] ;
|
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION layer_lm(bbox geometry, zoom_level integer, pixel_width numeric)
|
|
||||||
RETURNS TABLE
|
|
||||||
(
|
|
||||||
osm_id bigint,
|
|
||||||
geometry geometry,
|
|
||||||
name text,
|
|
||||||
name_en text,
|
|
||||||
name_de text,
|
|
||||||
tags hstore,
|
|
||||||
class text,
|
|
||||||
subclass text,
|
|
||||||
layer integer,
|
|
||||||
level integer,
|
|
||||||
"rank" int
|
|
||||||
)
|
|
||||||
AS
|
|
||||||
$$
|
|
||||||
SELECT osm_id_hash AS osm_id,
|
|
||||||
geometry,
|
|
||||||
NULLIF(name, '') AS name,
|
|
||||||
COALESCE(NULLIF(name_en, ''), name) AS name_en,
|
|
||||||
COALESCE(NULLIF(name_de, ''), name, name_en) AS name_de,
|
|
||||||
tags,
|
|
||||||
lm_class(subclass, mapping_key) AS class,
|
|
||||||
subclass AS subclass,
|
|
||||||
NULLIF(layer, 0) AS layer,
|
|
||||||
"level",
|
|
||||||
row_number() OVER (
|
|
||||||
PARTITION BY LabelGrid(geometry, 100 * pixel_width)
|
|
||||||
ORDER BY CASE WHEN name = '' THEN 2000 ELSE lm_class_rank(lm_class(subclass, mapping_key)) END ASC
|
|
||||||
)::int AS "rank"
|
|
||||||
FROM (
|
|
||||||
-- etldoc: osm_lm_point -> layer_lm:z12
|
|
||||||
-- etldoc: osm_lm_point -> layer_lm:z13
|
|
||||||
SELECT *,
|
|
||||||
osm_id * 10 AS osm_id_hash
|
|
||||||
FROM osm_lm_point
|
|
||||||
WHERE geometry && bbox
|
|
||||||
AND zoom_level BETWEEN 12 AND 13
|
|
||||||
AND ((subclass = 'station' AND mapping_key = 'railway')
|
|
||||||
OR subclass IN ('halt', 'ferry_terminal'))
|
|
||||||
|
|
||||||
UNION ALL
|
|
||||||
|
|
||||||
-- etldoc: osm_lm_point -> layer_lm:z14_
|
|
||||||
SELECT *,
|
|
||||||
osm_id * 10 AS osm_id_hash
|
|
||||||
FROM osm_lm_point
|
|
||||||
WHERE geometry && bbox
|
|
||||||
AND zoom_level >= 14
|
|
||||||
|
|
||||||
UNION ALL
|
|
||||||
|
|
||||||
-- etldoc: osm_lm_polygon -> layer_lm:z12
|
|
||||||
-- etldoc: osm_lm_polygon -> layer_lm:z13
|
|
||||||
SELECT *,
|
|
||||||
CASE
|
|
||||||
WHEN osm_id < 0 THEN -osm_id * 10 + 4
|
|
||||||
ELSE osm_id * 10 + 1
|
|
||||||
END AS osm_id_hash
|
|
||||||
FROM osm_lm_polygon
|
|
||||||
WHERE geometry && bbox
|
|
||||||
AND zoom_level BETWEEN 12 AND 13
|
|
||||||
AND ((subclass = 'station' AND mapping_key = 'railway')
|
|
||||||
OR subclass IN ('halt', 'ferry_terminal'))
|
|
||||||
|
|
||||||
UNION ALL
|
|
||||||
|
|
||||||
-- etldoc: osm_lm_polygon -> layer_lm:z14_
|
|
||||||
SELECT *,
|
|
||||||
CASE
|
|
||||||
WHEN osm_id < 0 THEN -osm_id * 10 + 4
|
|
||||||
ELSE osm_id * 10 + 1
|
|
||||||
END AS osm_id_hash
|
|
||||||
FROM osm_lm_polygon
|
|
||||||
WHERE geometry && bbox
|
|
||||||
AND zoom_level >= 14
|
|
||||||
) AS lm_union
|
|
||||||
ORDER BY "rank"
|
|
||||||
$$ LANGUAGE SQL STABLE
|
|
||||||
PARALLEL SAFE;
|
|
||||||
-- TODO: Check if the above can be made STRICT -- i.e. if pixel_width could be NULL
|
|
||||||
@ -1,74 +0,0 @@
|
|||||||
|
|
||||||
# imposm3 mapping file for https://github.com/osm2vectortiles/imposm3
|
|
||||||
# Warning: this is not the official imposm3
|
|
||||||
|
|
||||||
# landuse values , see http://taginfo.openstreetmap.org/keys/landuse#values
|
|
||||||
def_lm_mapping_landuse: &lm_mapping_landuse
|
|
||||||
- forest
|
|
||||||
|
|
||||||
def_poi_fields: &lm_fields
|
|
||||||
- name: osm_id
|
|
||||||
type: id
|
|
||||||
- name: geometry
|
|
||||||
type: geometry
|
|
||||||
- name: name
|
|
||||||
key: name
|
|
||||||
type: string
|
|
||||||
- name: name_en
|
|
||||||
key: name:en
|
|
||||||
type: string
|
|
||||||
- name: name_de
|
|
||||||
key: name:de
|
|
||||||
type: string
|
|
||||||
- name: tags
|
|
||||||
type: hstore_tags
|
|
||||||
- name: subclass
|
|
||||||
type: mapping_value
|
|
||||||
- name: mapping_key
|
|
||||||
type: mapping_key
|
|
||||||
- name: station
|
|
||||||
key: station
|
|
||||||
type: string
|
|
||||||
- name: funicular
|
|
||||||
key: funicular
|
|
||||||
type: string
|
|
||||||
- name: information
|
|
||||||
key: information
|
|
||||||
type: string
|
|
||||||
- name: uic_ref
|
|
||||||
key: uic_ref
|
|
||||||
type: string
|
|
||||||
- name: religion
|
|
||||||
key: religion
|
|
||||||
type: string
|
|
||||||
- name: level
|
|
||||||
key: level
|
|
||||||
type: integer
|
|
||||||
- name: layer
|
|
||||||
key: layer
|
|
||||||
type: integer
|
|
||||||
- name: sport
|
|
||||||
key: sport
|
|
||||||
type: string
|
|
||||||
|
|
||||||
def_lm_mapping: &lm_mapping
|
|
||||||
landuse: *lm_mapping_landuse
|
|
||||||
|
|
||||||
tables:
|
|
||||||
# etldoc: imposm3 -> osm_lm_point
|
|
||||||
lm_point:
|
|
||||||
type: point
|
|
||||||
columns: *lm_fields
|
|
||||||
filters:
|
|
||||||
require:
|
|
||||||
name: ["__any__"]
|
|
||||||
mapping: *lm_mapping
|
|
||||||
|
|
||||||
# etldoc: imposm3 -> osm_lm_polygon
|
|
||||||
lm_polygon:
|
|
||||||
type: polygon
|
|
||||||
columns: *lm_fields
|
|
||||||
filters:
|
|
||||||
require:
|
|
||||||
name: ["__any__"]
|
|
||||||
mapping: *lm_mapping
|
|
||||||
|
Before Width: | Height: | Size: 1.3 MiB |
@ -1,69 +0,0 @@
|
|||||||
DROP TRIGGER IF EXISTS trigger_flag ON osm_lm_point;
|
|
||||||
DROP TRIGGER IF EXISTS trigger_refresh ON lm_point.updates;
|
|
||||||
|
|
||||||
-- etldoc: osm_lm_point -> osm_lm_point
|
|
||||||
CREATE OR REPLACE FUNCTION update_osm_lm_point() RETURNS void AS
|
|
||||||
$$
|
|
||||||
BEGIN
|
|
||||||
UPDATE osm_lm_point
|
|
||||||
SET subclass = 'subway'
|
|
||||||
WHERE station = 'subway'
|
|
||||||
AND subclass = 'station';
|
|
||||||
|
|
||||||
UPDATE osm_lm_point
|
|
||||||
SET subclass = 'halt'
|
|
||||||
WHERE funicular = 'yes'
|
|
||||||
AND subclass = 'station';
|
|
||||||
|
|
||||||
UPDATE osm_lm_point
|
|
||||||
SET tags = update_tags(tags, geometry)
|
|
||||||
WHERE COALESCE(tags->'name:latin', tags->'name:nonlatin', tags->'name_int') IS NULL;
|
|
||||||
|
|
||||||
END;
|
|
||||||
$$ LANGUAGE plpgsql;
|
|
||||||
|
|
||||||
SELECT update_osm_lm_point();
|
|
||||||
|
|
||||||
-- Handle updates
|
|
||||||
|
|
||||||
CREATE SCHEMA IF NOT EXISTS lm_point;
|
|
||||||
|
|
||||||
CREATE TABLE IF NOT EXISTS lm_point.updates
|
|
||||||
(
|
|
||||||
id serial PRIMARY KEY,
|
|
||||||
t text,
|
|
||||||
UNIQUE (t)
|
|
||||||
);
|
|
||||||
CREATE OR REPLACE FUNCTION lm_point.flag() RETURNS trigger AS
|
|
||||||
$$
|
|
||||||
BEGIN
|
|
||||||
INSERT INTO lm_point.updates(t) VALUES ('y') ON CONFLICT(t) DO NOTHING;
|
|
||||||
RETURN NULL;
|
|
||||||
END;
|
|
||||||
$$ LANGUAGE plpgsql;
|
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION lm_point.refresh() RETURNS trigger AS
|
|
||||||
$$
|
|
||||||
BEGIN
|
|
||||||
RAISE LOG 'Refresh lm_point';
|
|
||||||
PERFORM update_osm_lm_point();
|
|
||||||
REFRESH MATERIALIZED VIEW osm_lm_stop_centroid;
|
|
||||||
REFRESH MATERIALIZED VIEW osm_lm_stop_rank;
|
|
||||||
-- noinspection SqlWithoutWhere
|
|
||||||
DELETE FROM lm_point.updates;
|
|
||||||
RETURN NULL;
|
|
||||||
END;
|
|
||||||
$$ LANGUAGE plpgsql;
|
|
||||||
|
|
||||||
CREATE TRIGGER trigger_flag
|
|
||||||
AFTER INSERT OR UPDATE OR DELETE
|
|
||||||
ON osm_lm_point
|
|
||||||
FOR EACH STATEMENT
|
|
||||||
EXECUTE PROCEDURE lm_point.flag();
|
|
||||||
|
|
||||||
CREATE CONSTRAINT TRIGGER trigger_refresh
|
|
||||||
AFTER INSERT
|
|
||||||
ON lm_point.updates
|
|
||||||
INITIALLY DEFERRED
|
|
||||||
FOR EACH ROW
|
|
||||||
EXECUTE PROCEDURE lm_point.refresh();
|
|
||||||
@ -1,78 +0,0 @@
|
|||||||
DROP TRIGGER IF EXISTS trigger_flag ON osm_lm_polygon;
|
|
||||||
DROP TRIGGER IF EXISTS trigger_refresh ON lm_polygon.updates;
|
|
||||||
|
|
||||||
-- etldoc: osm_lm_polygon -> osm_lm_polygon
|
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION update_lm_polygon() RETURNS void AS
|
|
||||||
$$
|
|
||||||
BEGIN
|
|
||||||
UPDATE osm_lm_polygon
|
|
||||||
SET geometry =
|
|
||||||
CASE
|
|
||||||
WHEN ST_NPoints(ST_ConvexHull(geometry)) = ST_NPoints(geometry)
|
|
||||||
THEN ST_Centroid(geometry)
|
|
||||||
ELSE ST_PointOnSurface(geometry)
|
|
||||||
END
|
|
||||||
WHERE ST_GeometryType(geometry) <> 'ST_Point';
|
|
||||||
|
|
||||||
UPDATE osm_lm_polygon
|
|
||||||
SET subclass = 'subway'
|
|
||||||
WHERE station = 'subway'
|
|
||||||
AND subclass = 'station';
|
|
||||||
|
|
||||||
UPDATE osm_lm_polygon
|
|
||||||
SET subclass = 'halt'
|
|
||||||
WHERE funicular = 'yes'
|
|
||||||
AND subclass = 'station';
|
|
||||||
|
|
||||||
UPDATE osm_lm_polygon
|
|
||||||
SET tags = update_tags(tags, geometry)
|
|
||||||
WHERE COALESCE(tags->'name:latin', tags->'name:nonlatin', tags->'name_int') IS NULL;
|
|
||||||
|
|
||||||
ANALYZE osm_lm_polygon;
|
|
||||||
END;
|
|
||||||
$$ LANGUAGE plpgsql;
|
|
||||||
|
|
||||||
SELECT update_lm_polygon();
|
|
||||||
|
|
||||||
-- Handle updates
|
|
||||||
|
|
||||||
CREATE SCHEMA IF NOT EXISTS lm_polygon;
|
|
||||||
|
|
||||||
CREATE TABLE IF NOT EXISTS lm_polygon.updates
|
|
||||||
(
|
|
||||||
id serial PRIMARY KEY,
|
|
||||||
t text,
|
|
||||||
UNIQUE (t)
|
|
||||||
);
|
|
||||||
CREATE OR REPLACE FUNCTION lm_polygon.flag() RETURNS trigger AS
|
|
||||||
$$
|
|
||||||
BEGIN
|
|
||||||
INSERT INTO lm_polygon.updates(t) VALUES ('y') ON CONFLICT(t) DO NOTHING;
|
|
||||||
RETURN NULL;
|
|
||||||
END;
|
|
||||||
$$ LANGUAGE plpgsql;
|
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION lm_polygon.refresh() RETURNS trigger AS
|
|
||||||
$$
|
|
||||||
BEGIN
|
|
||||||
RAISE LOG 'Refresh lm_polygon';
|
|
||||||
PERFORM update_lm_polygon();
|
|
||||||
-- noinspection SqlWithoutWhere
|
|
||||||
DELETE FROM lm_polygon.updates;
|
|
||||||
RETURN NULL;
|
|
||||||
END;
|
|
||||||
$$ LANGUAGE plpgsql;
|
|
||||||
|
|
||||||
CREATE TRIGGER trigger_flag
|
|
||||||
AFTER INSERT OR UPDATE OR DELETE
|
|
||||||
ON osm_lm_polygon
|
|
||||||
FOR EACH STATEMENT
|
|
||||||
EXECUTE PROCEDURE lm_polygon.flag();
|
|
||||||
|
|
||||||
CREATE CONSTRAINT TRIGGER trigger_refresh
|
|
||||||
AFTER INSERT
|
|
||||||
ON lm_polygon.updates
|
|
||||||
INITIALLY DEFERRED
|
|
||||||
FOR EACH ROW
|
|
||||||
EXECUTE PROCEDURE lm_polygon.refresh();
|
|
||||||
|
Before Width: | Height: | Size: 176 KiB After Width: | Height: | Size: 158 KiB |
@ -1,210 +1,113 @@
|
|||||||
-- ne_50m_urban_areas
|
-- etldoc: ne_50m_urban_areas -> landuse_z4
|
||||||
-- etldoc: ne_50m_urban_areas -> ne_50m_urban_areas_gen_z5
|
CREATE OR REPLACE VIEW landuse_z4 AS (
|
||||||
DROP MATERIALIZED VIEW IF EXISTS ne_50m_urban_areas_gen_z5 CASCADE;
|
SELECT NULL::bigint AS osm_id, geometry, 'residential'::text AS landuse, NULL::text AS amenity, NULL::text AS leisure, NULL::text AS tourism, NULL::text AS place, NULL::text AS waterway
|
||||||
CREATE MATERIALIZED VIEW ne_50m_urban_areas_gen_z5 AS
|
FROM ne_50m_urban_areas
|
||||||
(
|
WHERE scalerank <= 2
|
||||||
SELECT
|
);
|
||||||
NULL::bigint AS osm_id,
|
|
||||||
ST_Simplify(geometry, ZRes(7)) as geometry,
|
|
||||||
'residential'::text AS landuse,
|
|
||||||
NULL::text AS amenity,
|
|
||||||
NULL::text AS leisure,
|
|
||||||
NULL::text AS tourism,
|
|
||||||
NULL::text AS place,
|
|
||||||
NULL::text AS waterway,
|
|
||||||
NULL::text AS man_made,
|
|
||||||
scalerank
|
|
||||||
FROM ne_50m_urban_areas
|
|
||||||
) /* DELAY_MATERIALIZED_VIEW_CREATION */ ;
|
|
||||||
CREATE INDEX IF NOT EXISTS ne_50m_urban_areas_gen_z5_idx ON ne_50m_urban_areas_gen_z5 USING gist (geometry);
|
|
||||||
|
|
||||||
-- etldoc: ne_50m_urban_areas_gen_z5 -> ne_50m_urban_areas_gen_z4
|
-- etldoc: ne_50m_urban_areas -> landuse_z5
|
||||||
DROP MATERIALIZED VIEW IF EXISTS ne_50m_urban_areas_gen_z4 CASCADE;
|
CREATE OR REPLACE VIEW landuse_z5 AS (
|
||||||
CREATE MATERIALIZED VIEW ne_50m_urban_areas_gen_z4 AS
|
SELECT NULL::bigint AS osm_id, geometry, 'residential'::text AS landuse, NULL::text AS amenity, NULL::text AS leisure, NULL::text AS tourism, NULL::text AS place, NULL::text AS waterway
|
||||||
(
|
FROM ne_50m_urban_areas
|
||||||
SELECT
|
);
|
||||||
osm_id,
|
|
||||||
ST_Simplify(geometry, ZRes(6)) as geometry,
|
-- etldoc: osm_landuse_polygon_gen7 -> landuse_z6
|
||||||
landuse,
|
CREATE OR REPLACE VIEW landuse_z6 AS (
|
||||||
amenity,
|
SELECT osm_id, geometry, landuse, amenity, leisure, tourism, place, waterway
|
||||||
leisure,
|
FROM osm_landuse_polygon_gen7
|
||||||
tourism,
|
);
|
||||||
place,
|
|
||||||
waterway,
|
-- etldoc: osm_landuse_polygon_gen6 -> landuse_z8
|
||||||
man_made
|
CREATE OR REPLACE VIEW landuse_z8 AS (
|
||||||
FROM ne_50m_urban_areas_gen_z5
|
SELECT osm_id, geometry, landuse, amenity, leisure, tourism, place, waterway
|
||||||
WHERE scalerank <= 2
|
FROM osm_landuse_polygon_gen6
|
||||||
) /* DELAY_MATERIALIZED_VIEW_CREATION */ ;
|
);
|
||||||
CREATE INDEX IF NOT EXISTS ne_50m_urban_areas_gen_z4_idx ON ne_50m_urban_areas_gen_z4 USING gist (geometry);
|
|
||||||
|
-- etldoc: osm_landuse_polygon_gen5 -> landuse_z9
|
||||||
|
CREATE OR REPLACE VIEW landuse_z9 AS (
|
||||||
|
SELECT osm_id, geometry, landuse, amenity, leisure, tourism, place, waterway
|
||||||
|
FROM osm_landuse_polygon_gen5
|
||||||
|
);
|
||||||
|
|
||||||
|
-- etldoc: osm_landuse_polygon_gen4 -> landuse_z10
|
||||||
|
CREATE OR REPLACE VIEW landuse_z10 AS (
|
||||||
|
SELECT osm_id, geometry, landuse, amenity, leisure, tourism, place, waterway
|
||||||
|
FROM osm_landuse_polygon_gen4
|
||||||
|
);
|
||||||
|
|
||||||
|
-- etldoc: osm_landuse_polygon_gen3 -> landuse_z11
|
||||||
|
CREATE OR REPLACE VIEW landuse_z11 AS (
|
||||||
|
SELECT osm_id, geometry, landuse, amenity, leisure, tourism, place, waterway
|
||||||
|
FROM osm_landuse_polygon_gen3
|
||||||
|
);
|
||||||
|
|
||||||
|
-- etldoc: osm_landuse_polygon_gen2 -> landuse_z12
|
||||||
|
CREATE OR REPLACE VIEW landuse_z12 AS (
|
||||||
|
SELECT osm_id, geometry, landuse, amenity, leisure, tourism, place, waterway
|
||||||
|
FROM osm_landuse_polygon_gen2
|
||||||
|
);
|
||||||
|
|
||||||
|
-- etldoc: osm_landuse_polygon_gen1 -> landuse_z13
|
||||||
|
CREATE OR REPLACE VIEW landuse_z13 AS (
|
||||||
|
SELECT osm_id, geometry, landuse, amenity, leisure, tourism, place, waterway
|
||||||
|
FROM osm_landuse_polygon_gen1
|
||||||
|
);
|
||||||
|
|
||||||
|
-- etldoc: osm_landuse_polygon -> landuse_z14
|
||||||
|
CREATE OR REPLACE VIEW landuse_z14 AS (
|
||||||
|
SELECT osm_id, geometry, landuse, amenity, leisure, tourism, place, waterway
|
||||||
|
FROM osm_landuse_polygon
|
||||||
|
);
|
||||||
|
|
||||||
-- etldoc: layer_landuse[shape=record fillcolor=lightpink, style="rounded,filled",
|
-- etldoc: layer_landuse[shape=record fillcolor=lightpink, style="rounded,filled",
|
||||||
-- etldoc: label="layer_landuse |<z4> z4|<z5> z5|<z6> z6|<z7> z7|<z8> z8|<z9> z9|<z10> z10|<z11> z11|<z12> z12|<z13> z13|<z14> z14+" ] ;
|
-- etldoc: label="layer_landuse |<z4> z4|<z5>z5|<z6>z6|<z7>z7| <z8> z8 |<z9> z9 |<z10> z10 |<z11> z11|<z12> z12|<z13> z13|<z14> z14+" ] ;
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION layer_landuse(bbox geometry, zoom_level int)
|
CREATE OR REPLACE FUNCTION layer_landuse(bbox geometry, zoom_level int)
|
||||||
RETURNS TABLE
|
RETURNS TABLE(osm_id bigint, geometry geometry, class text) AS $$
|
||||||
(
|
SELECT osm_id, geometry,
|
||||||
osm_id bigint,
|
COALESCE(
|
||||||
geometry geometry,
|
NULLIF(landuse, ''),
|
||||||
class text
|
NULLIF(amenity, ''),
|
||||||
)
|
NULLIF(leisure, ''),
|
||||||
AS
|
NULLIF(tourism, ''),
|
||||||
|
NULLIF(place, ''),
|
||||||
|
NULLIF(waterway, '')
|
||||||
|
) AS class
|
||||||
|
FROM (
|
||||||
|
-- etldoc: landuse_z4 -> layer_landuse:z4
|
||||||
|
SELECT * FROM landuse_z4
|
||||||
|
WHERE zoom_level = 4
|
||||||
|
UNION ALL
|
||||||
|
-- etldoc: landuse_z5 -> layer_landuse:z5
|
||||||
|
SELECT * FROM landuse_z5
|
||||||
|
WHERE zoom_level = 5
|
||||||
|
UNION ALL
|
||||||
|
-- etldoc: landuse_z6 -> layer_landuse:z6
|
||||||
|
-- etldoc: landuse_z6 -> layer_landuse:z7
|
||||||
|
SELECT * FROM landuse_z6 WHERE zoom_level BETWEEN 6 AND 7
|
||||||
|
UNION ALL
|
||||||
|
-- etldoc: landuse_z8 -> layer_landuse:z8
|
||||||
|
SELECT * FROM landuse_z8 WHERE zoom_level = 8
|
||||||
|
UNION ALL
|
||||||
|
-- etldoc: landuse_z9 -> layer_landuse:z9
|
||||||
|
SELECT * FROM landuse_z9 WHERE zoom_level = 9
|
||||||
|
UNION ALL
|
||||||
|
-- etldoc: landuse_z10 -> layer_landuse:z10
|
||||||
|
SELECT * FROM landuse_z10 WHERE zoom_level = 10
|
||||||
|
UNION ALL
|
||||||
|
-- etldoc: landuse_z11 -> layer_landuse:z11
|
||||||
|
SELECT * FROM landuse_z11 WHERE zoom_level = 11
|
||||||
|
UNION ALL
|
||||||
|
-- etldoc: landuse_z12 -> layer_landuse:z12
|
||||||
|
SELECT * FROM landuse_z12 WHERE zoom_level = 12
|
||||||
|
UNION ALL
|
||||||
|
-- etldoc: landuse_z13 -> layer_landuse:z13
|
||||||
|
SELECT * FROM landuse_z13 WHERE zoom_level = 13
|
||||||
|
UNION ALL
|
||||||
|
-- etldoc: landuse_z14 -> layer_landuse:z14
|
||||||
|
SELECT * FROM landuse_z14 WHERE zoom_level >= 14
|
||||||
|
) AS zoom_levels
|
||||||
|
WHERE geometry && bbox;
|
||||||
$$
|
$$
|
||||||
SELECT osm_id,
|
LANGUAGE SQL
|
||||||
geometry,
|
IMMUTABLE PARALLEL SAFE;
|
||||||
COALESCE(
|
|
||||||
NULLIF(landuse, ''),
|
|
||||||
NULLIF(amenity, ''),
|
|
||||||
NULLIF(leisure, ''),
|
|
||||||
NULLIF(tourism, ''),
|
|
||||||
NULLIF(place, ''),
|
|
||||||
NULLIF(waterway, ''),
|
|
||||||
NULLIF(man_made, '')
|
|
||||||
) AS class
|
|
||||||
FROM (
|
|
||||||
-- etldoc: ne_50m_urban_areas_gen_z4 -> layer_landuse:z4
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry,
|
|
||||||
landuse,
|
|
||||||
amenity,
|
|
||||||
leisure,
|
|
||||||
tourism,
|
|
||||||
place,
|
|
||||||
waterway,
|
|
||||||
man_made
|
|
||||||
FROM ne_50m_urban_areas_gen_z4
|
|
||||||
WHERE zoom_level = 4
|
|
||||||
UNION ALL
|
|
||||||
-- etldoc: ne_50m_urban_areas_gen_z5 -> layer_landuse:z5
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry,
|
|
||||||
landuse,
|
|
||||||
amenity,
|
|
||||||
leisure,
|
|
||||||
tourism,
|
|
||||||
place,
|
|
||||||
waterway,
|
|
||||||
man_made
|
|
||||||
FROM ne_50m_urban_areas_gen_z5
|
|
||||||
WHERE zoom_level = 5
|
|
||||||
UNION ALL
|
|
||||||
-- etldoc: osm_landuse_polygon_gen_z6 -> layer_landuse:z6
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry,
|
|
||||||
landuse,
|
|
||||||
amenity,
|
|
||||||
leisure,
|
|
||||||
tourism,
|
|
||||||
place,
|
|
||||||
waterway,
|
|
||||||
man_made
|
|
||||||
FROM osm_landuse_polygon_gen_z6
|
|
||||||
WHERE zoom_level = 6
|
|
||||||
UNION ALL
|
|
||||||
-- etldoc: osm_landuse_polygon_gen_z7 -> layer_landuse:z7
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry,
|
|
||||||
landuse,
|
|
||||||
amenity,
|
|
||||||
leisure,
|
|
||||||
tourism,
|
|
||||||
place,
|
|
||||||
waterway,
|
|
||||||
man_made
|
|
||||||
FROM osm_landuse_polygon_gen_z7
|
|
||||||
WHERE zoom_level = 7
|
|
||||||
UNION ALL
|
|
||||||
-- etldoc: osm_landuse_polygon_gen_z8 -> layer_landuse:z8
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry,
|
|
||||||
landuse,
|
|
||||||
amenity,
|
|
||||||
leisure,
|
|
||||||
tourism,
|
|
||||||
place,
|
|
||||||
waterway,
|
|
||||||
man_made
|
|
||||||
FROM osm_landuse_polygon_gen_z8
|
|
||||||
WHERE zoom_level = 8
|
|
||||||
UNION ALL
|
|
||||||
-- etldoc: osm_landuse_polygon_gen_z9 -> layer_landuse:z9
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry,
|
|
||||||
landuse,
|
|
||||||
amenity,
|
|
||||||
leisure,
|
|
||||||
tourism,
|
|
||||||
place,
|
|
||||||
waterway,
|
|
||||||
man_made
|
|
||||||
FROM osm_landuse_polygon_gen_z9
|
|
||||||
WHERE zoom_level = 9
|
|
||||||
UNION ALL
|
|
||||||
-- etldoc: osm_landuse_polygon_gen_z10 -> layer_landuse:z10
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry,
|
|
||||||
landuse,
|
|
||||||
amenity,
|
|
||||||
leisure,
|
|
||||||
tourism,
|
|
||||||
place,
|
|
||||||
waterway,
|
|
||||||
man_made
|
|
||||||
FROM osm_landuse_polygon_gen_z10
|
|
||||||
WHERE zoom_level = 10
|
|
||||||
UNION ALL
|
|
||||||
-- etldoc: osm_landuse_polygon_gen_z11 -> layer_landuse:z11
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry,
|
|
||||||
landuse,
|
|
||||||
amenity,
|
|
||||||
leisure,
|
|
||||||
tourism,
|
|
||||||
place,
|
|
||||||
waterway,
|
|
||||||
man_made
|
|
||||||
FROM osm_landuse_polygon_gen_z11
|
|
||||||
WHERE zoom_level = 11
|
|
||||||
UNION ALL
|
|
||||||
-- etldoc: osm_landuse_polygon_gen_z12 -> layer_landuse:z12
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry,
|
|
||||||
landuse,
|
|
||||||
amenity,
|
|
||||||
leisure,
|
|
||||||
tourism,
|
|
||||||
place,
|
|
||||||
waterway,
|
|
||||||
man_made
|
|
||||||
FROM osm_landuse_polygon_gen_z12
|
|
||||||
WHERE zoom_level = 12
|
|
||||||
UNION ALL
|
|
||||||
-- etldoc: osm_landuse_polygon_gen_z13 -> layer_landuse:z13
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry,
|
|
||||||
landuse,
|
|
||||||
amenity,
|
|
||||||
leisure,
|
|
||||||
tourism,
|
|
||||||
place,
|
|
||||||
waterway,
|
|
||||||
man_made
|
|
||||||
FROM osm_landuse_polygon_gen_z13
|
|
||||||
WHERE zoom_level = 13
|
|
||||||
UNION ALL
|
|
||||||
-- etldoc: osm_landuse_polygon -> layer_landuse:z14
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry,
|
|
||||||
landuse,
|
|
||||||
amenity,
|
|
||||||
leisure,
|
|
||||||
tourism,
|
|
||||||
place,
|
|
||||||
waterway,
|
|
||||||
man_made
|
|
||||||
FROM osm_landuse_polygon
|
|
||||||
WHERE zoom_level >= 14
|
|
||||||
) AS zoom_levels
|
|
||||||
WHERE geometry && bbox;
|
|
||||||
$$ LANGUAGE SQL STABLE
|
|
||||||
-- STRICT
|
|
||||||
PARALLEL SAFE;
|
|
||||||
|
|||||||
@ -22,7 +22,6 @@ layer:
|
|||||||
- residential
|
- residential
|
||||||
- commercial
|
- commercial
|
||||||
- industrial
|
- industrial
|
||||||
- garages
|
|
||||||
- retail
|
- retail
|
||||||
- bus_station
|
- bus_station
|
||||||
- school
|
- school
|
||||||
@ -38,17 +37,11 @@ layer:
|
|||||||
- theme_park
|
- theme_park
|
||||||
- zoo
|
- zoo
|
||||||
- suburb
|
- suburb
|
||||||
- quarter
|
|
||||||
- neighbourhood
|
- neighbourhood
|
||||||
- dam
|
- dam
|
||||||
- sports_centre
|
- sports_centre
|
||||||
- parking
|
- parking
|
||||||
- motorcycle_parking
|
|
||||||
- bicycle_parking
|
|
||||||
- religious
|
- religious
|
||||||
- prison
|
|
||||||
- wastewater_plant
|
|
||||||
- water_works
|
|
||||||
datasource:
|
datasource:
|
||||||
geometry_field: geometry
|
geometry_field: geometry
|
||||||
query: (SELECT geometry, class FROM layer_landuse(!bbox!, z(!scale_denominator!))) AS t
|
query: (SELECT geometry, class FROM layer_landuse(!bbox!, z(!scale_denominator!))) AS t
|
||||||
|
|||||||
@ -1,41 +1,35 @@
|
|||||||
generalized_tables:
|
generalized_tables:
|
||||||
# etldoc: osm_landuse_polygon_gen_z7 -> osm_landuse_polygon_gen_z6
|
# etldoc: imposm3 -> osm_landuse_polygon_gen7
|
||||||
landuse_polygon_gen_z6:
|
landuse_polygon_gen7:
|
||||||
source: landuse_polygon_gen_z7
|
source: landuse_polygon_gen6
|
||||||
tolerance: ZRES6
|
|
||||||
sql_filter: area>power(ZRES6,2)
|
|
||||||
# etldoc: osm_landuse_polygon_gen_z8 -> osm_landuse_polygon_gen_z7
|
|
||||||
landuse_polygon_gen_z7:
|
|
||||||
source: landuse_polygon_gen_z8
|
|
||||||
tolerance: ZRES7
|
tolerance: ZRES7
|
||||||
sql_filter: area>power(ZRES6,2)
|
# etldoc: imposm3 -> osm_landuse_polygon_gen6
|
||||||
# etldoc: osm_landuse_polygon_gen_z9 -> osm_landuse_polygon_gen_z8
|
landuse_polygon_gen6:
|
||||||
landuse_polygon_gen_z8:
|
source: landuse_polygon_gen5
|
||||||
source: landuse_polygon_gen_z9
|
sql_filter: area>power(ZRES6,2) AND (landuse='residential' OR place='suburb' OR place='neighbourhood')
|
||||||
sql_filter: area>power(ZRES6,2) AND (landuse='residential' OR place='suburb' OR place='quarter' OR place='neighbourhood')
|
|
||||||
tolerance: ZRES8
|
tolerance: ZRES8
|
||||||
# etldoc: osm_landuse_polygon_gen_z10 -> osm_landuse_polygon_gen_z9
|
# etldoc: imposm3 -> osm_landuse_polygon_gen5
|
||||||
landuse_polygon_gen_z9:
|
landuse_polygon_gen5:
|
||||||
source: landuse_polygon_gen_z10
|
source: landuse_polygon_gen4
|
||||||
sql_filter: area>power(ZRES7,2)
|
sql_filter: area>power(ZRES7,2)
|
||||||
tolerance: ZRES9
|
tolerance: ZRES9
|
||||||
# etldoc: osm_landuse_polygon_gen_z11 -> osm_landuse_polygon_gen_z10
|
# etldoc: imposm3 -> osm_landuse_polygon_gen4
|
||||||
landuse_polygon_gen_z10:
|
landuse_polygon_gen4:
|
||||||
source: landuse_polygon_gen_z11
|
source: landuse_polygon_gen3
|
||||||
sql_filter: area>power(ZRES8,2)
|
sql_filter: area>power(ZRES8,2)
|
||||||
tolerance: ZRES10
|
tolerance: ZRES10
|
||||||
# etldoc: osm_landuse_polygon_gen_z12 -> osm_landuse_polygon_gen_z11
|
# etldoc: imposm3 -> osm_landuse_polygon_gen3
|
||||||
landuse_polygon_gen_z11:
|
landuse_polygon_gen3:
|
||||||
source: landuse_polygon_gen_z12
|
source: landuse_polygon_gen2
|
||||||
sql_filter: area>power(ZRES9,2)
|
sql_filter: area>power(ZRES9,2)
|
||||||
tolerance: ZRES11
|
tolerance: ZRES11
|
||||||
# etldoc: osm_landuse_polygon_gen_z13 -> osm_landuse_polygon_gen_z12
|
# etldoc: imposm3 -> osm_landuse_polygon_gen2
|
||||||
landuse_polygon_gen_z12:
|
landuse_polygon_gen2:
|
||||||
source: landuse_polygon_gen_z13
|
source: landuse_polygon_gen1
|
||||||
sql_filter: area>power(ZRES10,2)
|
sql_filter: area>power(ZRES10,2)
|
||||||
tolerance: ZRES12
|
tolerance: ZRES12
|
||||||
# etldoc: osm_landuse_polygon -> osm_landuse_polygon_gen_z13
|
# etldoc: imposm3 -> osm_landuse_polygon_gen1
|
||||||
landuse_polygon_gen_z13:
|
landuse_polygon_gen1:
|
||||||
source: landuse_polygon
|
source: landuse_polygon
|
||||||
sql_filter: area>power(ZRES11,2) AND ST_IsValid(geometry)
|
sql_filter: area>power(ZRES11,2) AND ST_IsValid(geometry)
|
||||||
tolerance: ZRES13
|
tolerance: ZRES13
|
||||||
@ -69,9 +63,6 @@ tables:
|
|||||||
type: string
|
type: string
|
||||||
- name: area
|
- name: area
|
||||||
type: area
|
type: area
|
||||||
- name: man_made
|
|
||||||
key: man_made
|
|
||||||
type: string
|
|
||||||
mapping:
|
mapping:
|
||||||
landuse:
|
landuse:
|
||||||
- railway
|
- railway
|
||||||
@ -84,7 +75,6 @@ tables:
|
|||||||
- garages
|
- garages
|
||||||
- retail
|
- retail
|
||||||
- religious
|
- religious
|
||||||
- construction
|
|
||||||
amenity:
|
amenity:
|
||||||
- bus_station
|
- bus_station
|
||||||
- school
|
- school
|
||||||
@ -94,9 +84,6 @@ tables:
|
|||||||
- library
|
- library
|
||||||
- hospital
|
- hospital
|
||||||
- parking
|
- parking
|
||||||
- prison
|
|
||||||
- motorcycle_parking
|
|
||||||
- bicycle_parking
|
|
||||||
- animal_training
|
- animal_training
|
||||||
leisure:
|
leisure:
|
||||||
- stadium
|
- stadium
|
||||||
@ -110,10 +97,6 @@ tables:
|
|||||||
- picnic_site
|
- picnic_site
|
||||||
place:
|
place:
|
||||||
- suburb
|
- suburb
|
||||||
- quarter
|
|
||||||
- neighbourhood
|
- neighbourhood
|
||||||
waterway:
|
waterway:
|
||||||
- dam
|
- dam
|
||||||
man_made:
|
|
||||||
- wastewater_plant
|
|
||||||
- water_works
|
|
||||||
|
|||||||
|
Before Width: | Height: | Size: 69 KiB After Width: | Height: | Size: 67 KiB |
57
layers/mountain_peak/layer.sql
Normal file
@ -0,0 +1,57 @@
|
|||||||
|
|
||||||
|
-- etldoc: layer_mountain_peak[shape=record fillcolor=lightpink,
|
||||||
|
-- etldoc: style="rounded,filled", label="layer_mountain_peak | <z7_> z7+" ] ;
|
||||||
|
|
||||||
|
CREATE OR REPLACE FUNCTION layer_mountain_peak(
|
||||||
|
bbox geometry,
|
||||||
|
zoom_level integer,
|
||||||
|
pixel_width numeric)
|
||||||
|
RETURNS TABLE(
|
||||||
|
osm_id bigint,
|
||||||
|
geometry geometry,
|
||||||
|
name text,
|
||||||
|
name_en text,
|
||||||
|
name_de text,
|
||||||
|
class text,
|
||||||
|
tags hstore,
|
||||||
|
ele int,
|
||||||
|
ele_ft int,
|
||||||
|
"rank" int) AS
|
||||||
|
$$
|
||||||
|
-- etldoc: osm_peak_point -> layer_mountain_peak:z7_
|
||||||
|
SELECT
|
||||||
|
osm_id,
|
||||||
|
geometry,
|
||||||
|
name,
|
||||||
|
name_en,
|
||||||
|
name_de,
|
||||||
|
tags -> 'natural' AS class,
|
||||||
|
tags,
|
||||||
|
ele::int,
|
||||||
|
ele_ft::int,
|
||||||
|
rank::int FROM (
|
||||||
|
SELECT osm_id, geometry, name,
|
||||||
|
COALESCE(NULLIF(name_en, ''), name) AS name_en,
|
||||||
|
COALESCE(NULLIF(name_de, ''), name, name_en) AS name_de,
|
||||||
|
tags,
|
||||||
|
substring(ele from E'^(-?\\d+)(\\D|$)')::int AS ele,
|
||||||
|
round(substring(ele from E'^(-?\\d+)(\\D|$)')::int*3.2808399)::int AS ele_ft,
|
||||||
|
row_number() OVER (
|
||||||
|
PARTITION BY LabelGrid(geometry, 100 * pixel_width)
|
||||||
|
ORDER BY (
|
||||||
|
substring(ele from E'^(-?\\d+)(\\D|$)')::int +
|
||||||
|
(CASE WHEN NULLIF(wikipedia, '') is not null THEN 10000 ELSE 0 END) +
|
||||||
|
(CASE WHEN NULLIF(name, '') is not null THEN 10000 ELSE 0 END)
|
||||||
|
) DESC
|
||||||
|
)::int AS "rank"
|
||||||
|
FROM osm_peak_point
|
||||||
|
WHERE geometry && bbox
|
||||||
|
AND ele is not null
|
||||||
|
AND ele ~ E'^-?\\d{1,4}(\\D|$)'
|
||||||
|
) AS ranked_peaks
|
||||||
|
WHERE zoom_level >= 7 AND (rank <= 5 OR zoom_level >= 14)
|
||||||
|
ORDER BY "rank" ASC;
|
||||||
|
|
||||||
|
$$
|
||||||
|
LANGUAGE SQL
|
||||||
|
IMMUTABLE PARALLEL SAFE;
|
||||||
@ -1,62 +0,0 @@
|
|||||||
-- etldoc: layer_mountain_peak[shape=record fillcolor=lightpink,
|
|
||||||
-- etldoc: style="rounded,filled", label="layer_mountain_peak | <z7_> z7+" ] ;
|
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION layer_mountain_peak(bbox geometry,
|
|
||||||
zoom_level integer,
|
|
||||||
pixel_width numeric)
|
|
||||||
RETURNS TABLE
|
|
||||||
(
|
|
||||||
osm_id bigint,
|
|
||||||
geometry geometry,
|
|
||||||
name text,
|
|
||||||
name_en text,
|
|
||||||
name_de text,
|
|
||||||
class text,
|
|
||||||
tags hstore,
|
|
||||||
ele int,
|
|
||||||
ele_ft int,
|
|
||||||
"rank" int
|
|
||||||
)
|
|
||||||
AS
|
|
||||||
$$
|
|
||||||
SELECT
|
|
||||||
-- etldoc: osm_peak_point -> layer_mountain_peak:z7_
|
|
||||||
osm_id,
|
|
||||||
geometry,
|
|
||||||
name,
|
|
||||||
name_en,
|
|
||||||
name_de,
|
|
||||||
tags->'natural' AS class,
|
|
||||||
tags,
|
|
||||||
ele::int,
|
|
||||||
ele_ft::int,
|
|
||||||
rank::int
|
|
||||||
FROM (
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry,
|
|
||||||
name,
|
|
||||||
COALESCE(NULLIF(name_en, ''), name) AS name_en,
|
|
||||||
COALESCE(NULLIF(name_de, ''), name, name_en) AS name_de,
|
|
||||||
tags,
|
|
||||||
substring(ele FROM E'^(-?\\d+)(\\D|$)')::int AS ele,
|
|
||||||
round(substring(ele FROM E'^(-?\\d+)(\\D|$)')::int * 3.2808399)::int AS ele_ft,
|
|
||||||
row_number() OVER (
|
|
||||||
PARTITION BY LabelGrid(geometry, 100 * pixel_width)
|
|
||||||
ORDER BY (
|
|
||||||
substring(ele FROM E'^(-?\\d+)(\\D|$)')::int +
|
|
||||||
(CASE WHEN NULLIF(wikipedia, '') IS NOT NULL THEN 10000 ELSE 0 END) +
|
|
||||||
(CASE WHEN NULLIF(name, '') IS NOT NULL THEN 10000 ELSE 0 END)
|
|
||||||
) DESC
|
|
||||||
)::int AS "rank"
|
|
||||||
FROM osm_peak_point
|
|
||||||
WHERE geometry && bbox
|
|
||||||
AND ele IS NOT NULL
|
|
||||||
AND ele ~ E'^-?\\d{1,4}(\\D|$)'
|
|
||||||
) AS ranked_peaks
|
|
||||||
WHERE zoom_level >= 7
|
|
||||||
AND (rank <= 5 OR zoom_level >= 14)
|
|
||||||
ORDER BY "rank" ASC;
|
|
||||||
|
|
||||||
$$ LANGUAGE SQL STABLE
|
|
||||||
PARALLEL SAFE;
|
|
||||||
-- TODO: Check if the above can be made STRICT -- i.e. if pixel_width could be NULL
|
|
||||||
@ -25,7 +25,7 @@ layer:
|
|||||||
query: (SELECT osm_id, geometry, name, name_en, name_de, {name_languages}, class, ele, ele_ft, rank FROM layer_mountain_peak(!bbox!, z(!scale_denominator!), !pixel_width!)) AS t
|
query: (SELECT osm_id, geometry, name, name_en, name_de, {name_languages}, class, ele, ele_ft, rank FROM layer_mountain_peak(!bbox!, z(!scale_denominator!), !pixel_width!)) AS t
|
||||||
schema:
|
schema:
|
||||||
- ./update_peak_point.sql
|
- ./update_peak_point.sql
|
||||||
- ./mountain_peak.sql
|
- ./layer.sql
|
||||||
datasources:
|
datasources:
|
||||||
- type: imposm3
|
- type: imposm3
|
||||||
mapping_file: ./mapping.yaml
|
mapping_file: ./mapping.yaml
|
||||||
|
|||||||
@ -1,86 +1,48 @@
|
|||||||
DROP TRIGGER IF EXISTS trigger_flag ON osm_peak_point;
|
DROP TRIGGER IF EXISTS trigger_flag ON osm_peak_point;
|
||||||
DROP TRIGGER IF EXISTS trigger_store ON osm_peak_point;
|
|
||||||
DROP TRIGGER IF EXISTS trigger_refresh ON mountain_peak_point.updates;
|
DROP TRIGGER IF EXISTS trigger_refresh ON mountain_peak_point.updates;
|
||||||
|
|
||||||
CREATE SCHEMA IF NOT EXISTS mountain_peak_point;
|
|
||||||
|
|
||||||
CREATE TABLE IF NOT EXISTS mountain_peak_point.osm_ids
|
|
||||||
(
|
|
||||||
osm_id bigint
|
|
||||||
);
|
|
||||||
|
|
||||||
-- etldoc: osm_peak_point -> osm_peak_point
|
-- etldoc: osm_peak_point -> osm_peak_point
|
||||||
CREATE OR REPLACE FUNCTION update_osm_peak_point(full_update boolean) RETURNS void AS
|
CREATE OR REPLACE FUNCTION update_osm_peak_point() RETURNS VOID AS $$
|
||||||
$$
|
BEGIN
|
||||||
UPDATE osm_peak_point
|
UPDATE osm_peak_point
|
||||||
SET tags = update_tags(tags, geometry)
|
SET tags = update_tags(tags, geometry)
|
||||||
WHERE (full_update OR osm_id IN (SELECT osm_id FROM mountain_peak_point.osm_ids))
|
WHERE COALESCE(tags->'name:latin', tags->'name:nonlatin', tags->'name_int') IS NULL;
|
||||||
AND COALESCE(tags -> 'name:latin', tags -> 'name:nonlatin', tags -> 'name_int') IS NULL
|
|
||||||
AND tags != update_tags(tags, geometry)
|
|
||||||
$$ LANGUAGE SQL;
|
|
||||||
|
|
||||||
SELECT update_osm_peak_point(true);
|
END;
|
||||||
|
$$ LANGUAGE plpgsql;
|
||||||
|
|
||||||
|
SELECT update_osm_peak_point();
|
||||||
|
|
||||||
-- Handle updates
|
-- Handle updates
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION mountain_peak_point.store() RETURNS trigger AS
|
CREATE SCHEMA IF NOT EXISTS mountain_peak_point;
|
||||||
$$
|
|
||||||
BEGIN
|
|
||||||
IF (tg_op = 'DELETE') THEN
|
|
||||||
INSERT INTO mountain_peak_point.osm_ids VALUES (OLD.osm_id);
|
|
||||||
ELSE
|
|
||||||
INSERT INTO mountain_peak_point.osm_ids VALUES (NEW.osm_id);
|
|
||||||
END IF;
|
|
||||||
RETURN NULL;
|
|
||||||
END;
|
|
||||||
$$ LANGUAGE plpgsql;
|
|
||||||
|
|
||||||
CREATE TABLE IF NOT EXISTS mountain_peak_point.updates
|
CREATE TABLE IF NOT EXISTS mountain_peak_point.updates(id serial primary key, t text, unique (t));
|
||||||
(
|
CREATE OR REPLACE FUNCTION mountain_peak_point.flag() RETURNS trigger AS $$
|
||||||
id serial PRIMARY KEY,
|
|
||||||
t text,
|
|
||||||
UNIQUE (t)
|
|
||||||
);
|
|
||||||
CREATE OR REPLACE FUNCTION mountain_peak_point.flag() RETURNS trigger AS
|
|
||||||
$$
|
|
||||||
BEGIN
|
BEGIN
|
||||||
INSERT INTO mountain_peak_point.updates(t) VALUES ('y') ON CONFLICT(t) DO NOTHING;
|
INSERT INTO mountain_peak_point.updates(t) VALUES ('y') ON CONFLICT(t) DO NOTHING;
|
||||||
RETURN NULL;
|
RETURN null;
|
||||||
END;
|
END;
|
||||||
$$ LANGUAGE plpgsql;
|
$$ language plpgsql;
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION mountain_peak_point.refresh() RETURNS trigger AS
|
CREATE OR REPLACE FUNCTION mountain_peak_point.refresh() RETURNS trigger AS
|
||||||
$$
|
$BODY$
|
||||||
DECLARE
|
BEGIN
|
||||||
t TIMESTAMP WITH TIME ZONE := clock_timestamp();
|
|
||||||
BEGIN
|
|
||||||
RAISE LOG 'Refresh mountain_peak_point';
|
RAISE LOG 'Refresh mountain_peak_point';
|
||||||
PERFORM update_osm_peak_point(false);
|
PERFORM update_osm_peak_point();
|
||||||
-- noinspection SqlWithoutWhere
|
|
||||||
DELETE FROM mountain_peak_point.osm_ids;
|
|
||||||
-- noinspection SqlWithoutWhere
|
|
||||||
DELETE FROM mountain_peak_point.updates;
|
DELETE FROM mountain_peak_point.updates;
|
||||||
|
RETURN null;
|
||||||
RAISE LOG 'Refresh mountain_peak_point done in %', age(clock_timestamp(), t);
|
END;
|
||||||
RETURN NULL;
|
$BODY$
|
||||||
END;
|
language plpgsql;
|
||||||
$$ LANGUAGE plpgsql;
|
|
||||||
|
|
||||||
CREATE TRIGGER trigger_store
|
|
||||||
AFTER INSERT OR UPDATE OR DELETE
|
|
||||||
ON osm_peak_point
|
|
||||||
FOR EACH ROW
|
|
||||||
EXECUTE PROCEDURE mountain_peak_point.store();
|
|
||||||
|
|
||||||
CREATE TRIGGER trigger_flag
|
CREATE TRIGGER trigger_flag
|
||||||
AFTER INSERT OR UPDATE OR DELETE
|
AFTER INSERT OR UPDATE OR DELETE ON osm_peak_point
|
||||||
ON osm_peak_point
|
|
||||||
FOR EACH STATEMENT
|
FOR EACH STATEMENT
|
||||||
EXECUTE PROCEDURE mountain_peak_point.flag();
|
EXECUTE PROCEDURE mountain_peak_point.flag();
|
||||||
|
|
||||||
CREATE CONSTRAINT TRIGGER trigger_refresh
|
CREATE CONSTRAINT TRIGGER trigger_refresh
|
||||||
AFTER INSERT
|
AFTER INSERT ON mountain_peak_point.updates
|
||||||
ON mountain_peak_point.updates
|
|
||||||
INITIALLY DEFERRED
|
INITIALLY DEFERRED
|
||||||
FOR EACH ROW
|
FOR EACH ROW
|
||||||
EXECUTE PROCEDURE mountain_peak_point.refresh();
|
EXECUTE PROCEDURE mountain_peak_point.refresh();
|
||||||
|
|||||||
|
Before Width: | Height: | Size: 144 KiB After Width: | Height: | Size: 138 KiB |
135
layers/park/layer.sql
Normal file
@ -0,0 +1,135 @@
|
|||||||
|
-- etldoc: layer_park[shape=record fillcolor=lightpink, style="rounded,filled",
|
||||||
|
-- etldoc: label="layer_park |<z6> z6 |<z7> z7 |<z8> z8 |<z9> z9 |<z10> z10 |<z11> z11 |<z12> z12|<z13> z13|<z14> z14+" ] ;
|
||||||
|
|
||||||
|
CREATE OR REPLACE FUNCTION layer_park(bbox geometry, zoom_level int, pixel_width numeric)
|
||||||
|
RETURNS TABLE(osm_id bigint, geometry geometry, class text, name text, name_en text, name_de text, tags hstore, rank int) AS $$
|
||||||
|
SELECT osm_id, geometry, class, name, name_en, name_de, tags, rank
|
||||||
|
FROM (
|
||||||
|
SELECT osm_id, geometry,
|
||||||
|
COALESCE(
|
||||||
|
LOWER(REPLACE(NULLIF(protection_title, ''), ' ', '_')),
|
||||||
|
NULLIF(boundary, ''),
|
||||||
|
NULLIF(leisure, '')
|
||||||
|
) AS class,
|
||||||
|
name, name_en, name_de, tags,
|
||||||
|
NULL::int as rank
|
||||||
|
FROM (
|
||||||
|
-- etldoc: osm_park_polygon_gen8 -> layer_park:z6
|
||||||
|
SELECT osm_id, geometry, name, name_en, name_de, tags, leisure, boundary, protection_title
|
||||||
|
FROM osm_park_polygon_gen8
|
||||||
|
WHERE zoom_level = 6 AND geometry && bbox
|
||||||
|
UNION ALL
|
||||||
|
-- etldoc: osm_park_polygon_gen7 -> layer_park:z7
|
||||||
|
SELECT osm_id, geometry, name, name_en, name_de, tags, leisure, boundary, protection_title
|
||||||
|
FROM osm_park_polygon_gen7
|
||||||
|
WHERE zoom_level = 7 AND geometry && bbox
|
||||||
|
UNION ALL
|
||||||
|
-- etldoc: osm_park_polygon_gen6 -> layer_park:z8
|
||||||
|
SELECT osm_id, geometry, name, name_en, name_de, tags, leisure, boundary, protection_title
|
||||||
|
FROM osm_park_polygon_gen6
|
||||||
|
WHERE zoom_level = 8 AND geometry && bbox
|
||||||
|
UNION ALL
|
||||||
|
-- etldoc: osm_park_polygon_gen5 -> layer_park:z9
|
||||||
|
SELECT osm_id, geometry, name, name_en, name_de, tags, leisure, boundary, protection_title
|
||||||
|
FROM osm_park_polygon_gen5
|
||||||
|
WHERE zoom_level = 9 AND geometry && bbox
|
||||||
|
UNION ALL
|
||||||
|
-- etldoc: osm_park_polygon_gen4 -> layer_park:z10
|
||||||
|
SELECT osm_id, geometry, name, name_en, name_de, tags, leisure, boundary, protection_title
|
||||||
|
FROM osm_park_polygon_gen4
|
||||||
|
WHERE zoom_level = 10 AND geometry && bbox
|
||||||
|
UNION ALL
|
||||||
|
-- etldoc: osm_park_polygon_gen3 -> layer_park:z11
|
||||||
|
SELECT osm_id, geometry, name, name_en, name_de, tags, leisure, boundary, protection_title
|
||||||
|
FROM osm_park_polygon_gen3
|
||||||
|
WHERE zoom_level = 11 AND geometry && bbox
|
||||||
|
UNION ALL
|
||||||
|
-- etldoc: osm_park_polygon_gen2 -> layer_park:z12
|
||||||
|
SELECT osm_id, geometry, name, name_en, name_de, tags, leisure, boundary, protection_title
|
||||||
|
FROM osm_park_polygon_gen2
|
||||||
|
WHERE zoom_level = 12 AND geometry && bbox
|
||||||
|
UNION ALL
|
||||||
|
-- etldoc: osm_park_polygon_gen1 -> layer_park:z13
|
||||||
|
SELECT osm_id, geometry, name, name_en, name_de, tags, leisure, boundary, protection_title
|
||||||
|
FROM osm_park_polygon_gen1
|
||||||
|
WHERE zoom_level = 13 AND geometry && bbox
|
||||||
|
UNION ALL
|
||||||
|
-- etldoc: osm_park_polygon -> layer_park:z14
|
||||||
|
SELECT osm_id, geometry, name, name_en, name_de, tags, leisure, boundary, protection_title
|
||||||
|
FROM osm_park_polygon
|
||||||
|
WHERE zoom_level >= 14 AND geometry && bbox
|
||||||
|
) AS park_polygon
|
||||||
|
|
||||||
|
UNION ALL
|
||||||
|
SELECT osm_id, geometry_point AS geometry,
|
||||||
|
COALESCE(
|
||||||
|
LOWER(REPLACE(NULLIF(protection_title, ''), ' ', '_')),
|
||||||
|
NULLIF(boundary, ''),
|
||||||
|
NULLIF(leisure, '')
|
||||||
|
) AS class,
|
||||||
|
name, name_en, name_de, tags,
|
||||||
|
row_number() OVER (
|
||||||
|
PARTITION BY LabelGrid(geometry_point, 100 * pixel_width)
|
||||||
|
ORDER BY
|
||||||
|
(CASE WHEN boundary = 'national_park' THEN true ELSE false END) DESC,
|
||||||
|
(COALESCE(NULLIF(tags->'wikipedia', ''), NULLIF(tags->'wikidata', '')) IS NOT NULL) DESC,
|
||||||
|
area DESC
|
||||||
|
)::int AS "rank"
|
||||||
|
FROM (
|
||||||
|
-- etldoc: osm_park_polygon_gen8 -> layer_park:z6
|
||||||
|
SELECT osm_id, geometry_point, name, name_en, name_de, tags, leisure, boundary, protection_title, area
|
||||||
|
FROM osm_park_polygon_gen8
|
||||||
|
WHERE zoom_level = 6 AND geometry_point && bbox
|
||||||
|
UNION ALL
|
||||||
|
|
||||||
|
-- etldoc: osm_park_polygon_gen7 -> layer_park:z7
|
||||||
|
SELECT osm_id, geometry_point, name, name_en, name_de, tags, leisure, boundary, protection_title, area
|
||||||
|
FROM osm_park_polygon_gen7
|
||||||
|
WHERE zoom_level = 7 AND geometry_point && bbox
|
||||||
|
UNION ALL
|
||||||
|
|
||||||
|
-- etldoc: osm_park_polygon_gen6 -> layer_park:z8
|
||||||
|
SELECT osm_id, geometry_point, name, name_en, name_de, tags, leisure, boundary, protection_title, area
|
||||||
|
FROM osm_park_polygon_gen6
|
||||||
|
WHERE zoom_level = 8 AND geometry_point && bbox
|
||||||
|
UNION ALL
|
||||||
|
|
||||||
|
-- etldoc: osm_park_polygon_gen5 -> layer_park:z9
|
||||||
|
SELECT osm_id, geometry_point, name, name_en, name_de, tags, leisure, boundary, protection_title, area
|
||||||
|
FROM osm_park_polygon_gen5
|
||||||
|
WHERE zoom_level = 9 AND geometry_point && bbox
|
||||||
|
UNION ALL
|
||||||
|
|
||||||
|
-- etldoc: osm_park_polygon_gen4 -> layer_park:z10
|
||||||
|
SELECT osm_id, geometry_point, name, name_en, name_de, tags, leisure, boundary, protection_title, area
|
||||||
|
FROM osm_park_polygon_gen4
|
||||||
|
WHERE zoom_level = 10 AND geometry_point && bbox
|
||||||
|
UNION ALL
|
||||||
|
|
||||||
|
-- etldoc: osm_park_polygon_gen3 -> layer_park:z11
|
||||||
|
SELECT osm_id, geometry_point, name, name_en, name_de, tags, leisure, boundary, protection_title, area
|
||||||
|
FROM osm_park_polygon_gen3
|
||||||
|
WHERE zoom_level = 11 AND geometry_point && bbox
|
||||||
|
UNION ALL
|
||||||
|
|
||||||
|
-- etldoc: osm_park_polygon_gen2 -> layer_park:z12
|
||||||
|
SELECT osm_id, geometry_point, name, name_en, name_de, tags, leisure, boundary, protection_title, area
|
||||||
|
FROM osm_park_polygon_gen2
|
||||||
|
WHERE zoom_level = 12 AND geometry_point && bbox
|
||||||
|
UNION ALL
|
||||||
|
|
||||||
|
-- etldoc: osm_park_polygon_gen1 -> layer_park:z13
|
||||||
|
SELECT osm_id, geometry_point, name, name_en, name_de, tags, leisure, boundary, protection_title, area
|
||||||
|
FROM osm_park_polygon_gen1
|
||||||
|
WHERE zoom_level = 13 AND geometry_point && bbox
|
||||||
|
UNION ALL
|
||||||
|
|
||||||
|
-- etldoc: osm_park_polygon -> layer_park:z14
|
||||||
|
SELECT osm_id, geometry_point, name, name_en, name_de, tags, leisure, boundary, protection_title, area
|
||||||
|
FROM osm_park_polygon
|
||||||
|
WHERE zoom_level >= 14 AND geometry_point && bbox
|
||||||
|
) AS park_point
|
||||||
|
) AS park_all;
|
||||||
|
$$
|
||||||
|
LANGUAGE SQL
|
||||||
|
IMMUTABLE PARALLEL SAFE;
|
||||||
@ -1,48 +1,48 @@
|
|||||||
generalized_tables:
|
generalized_tables:
|
||||||
# etldoc: osm_park_polygon_gen_z7 -> osm_park_polygon_gen_z6
|
# etldoc: imposm3 -> osm_park_polygon_gen8
|
||||||
park_polygon_gen_z6:
|
park_polygon_gen8:
|
||||||
source: park_polygon_gen_z7
|
source: park_polygon_gen7
|
||||||
sql_filter: area>power(ZRES5,2)
|
sql_filter: area>power(ZRES5,2)
|
||||||
tolerance: ZRES8
|
tolerance: ZRES8
|
||||||
|
|
||||||
# etldoc: osm_park_polygon_gen_z8 -> osm_park_polygon_gen_z7
|
# etldoc: imposm3 -> osm_park_polygon_gen7
|
||||||
park_polygon_gen_z7:
|
park_polygon_gen7:
|
||||||
source: park_polygon_gen_z8
|
source: park_polygon_gen6
|
||||||
sql_filter: area>power(ZRES6,2)
|
sql_filter: area>power(ZRES6,2)
|
||||||
tolerance: ZRES8
|
tolerance: ZRES8
|
||||||
|
|
||||||
# etldoc: osm_park_polygon_gen_z9 -> osm_park_polygon_gen_z8
|
# etldoc: imposm3 -> osm_park_polygon_gen6
|
||||||
park_polygon_gen_z8:
|
park_polygon_gen6:
|
||||||
source: park_polygon_gen_z9
|
source: park_polygon_gen5
|
||||||
sql_filter: area>power(ZRES7,2)
|
sql_filter: area>power(ZRES7,2)
|
||||||
tolerance: ZRES9
|
tolerance: ZRES9
|
||||||
|
|
||||||
# etldoc: osm_park_polygon_gen_z10 -> osm_park_polygon_gen_z9
|
# etldoc: imposm3 -> osm_park_polygon_gen5
|
||||||
park_polygon_gen_z9:
|
park_polygon_gen5:
|
||||||
source: park_polygon_gen_z10
|
source: park_polygon_gen4
|
||||||
sql_filter: area>power(ZRES8,2)
|
sql_filter: area>power(ZRES8,2)
|
||||||
tolerance: ZRES10
|
tolerance: ZRES10
|
||||||
|
|
||||||
# etldoc: osm_park_polygon_gen_z11 -> osm_park_polygon_gen_z10
|
# etldoc: imposm3 -> osm_park_polygon_gen4
|
||||||
park_polygon_gen_z10:
|
park_polygon_gen4:
|
||||||
source: park_polygon_gen_z11
|
source: park_polygon_gen3
|
||||||
sql_filter: area>power(ZRES9,2)
|
sql_filter: area>power(ZRES9,2)
|
||||||
tolerance: ZRES11
|
tolerance: ZRES11
|
||||||
|
|
||||||
# etldoc: osm_park_polygon_gen_z12 -> osm_park_polygon_gen_z11
|
# etldoc: imposm3 -> osm_park_polygon_gen3
|
||||||
park_polygon_gen_z11:
|
park_polygon_gen3:
|
||||||
source: park_polygon_gen_z12
|
source: park_polygon_gen2
|
||||||
sql_filter: area>power(ZRES10,2)
|
sql_filter: area>power(ZRES10,2)
|
||||||
tolerance: ZRES11
|
tolerance: ZRES11
|
||||||
|
|
||||||
# etldoc: osm_park_polygon_gen_z13 -> osm_park_polygon_gen_z12
|
# etldoc: imposm3 -> osm_park_polygon_gen2
|
||||||
park_polygon_gen_z12:
|
park_polygon_gen2:
|
||||||
source: park_polygon_gen_z13
|
source: park_polygon_gen1
|
||||||
sql_filter: area>power(ZRES11,2)
|
sql_filter: area>power(ZRES11,2)
|
||||||
tolerance: ZRES12
|
tolerance: ZRES12
|
||||||
|
|
||||||
# etldoc: osm_park_polygon -> osm_park_polygon_gen_z13
|
# etldoc: imposm3 -> osm_park_polygon_gen1
|
||||||
park_polygon_gen_z13:
|
park_polygon_gen1:
|
||||||
source: park_polygon
|
source: park_polygon
|
||||||
sql_filter: area>power(ZRES12,2) AND ST_IsValid(geometry)
|
sql_filter: area>power(ZRES12,2) AND ST_IsValid(geometry)
|
||||||
tolerance: ZRES13
|
tolerance: ZRES13
|
||||||
|
|||||||
@ -1,341 +0,0 @@
|
|||||||
-- etldoc: layer_park[shape=record fillcolor=lightpink, style="rounded,filled",
|
|
||||||
-- etldoc: label="layer_park |<z6> z6 |<z7> z7 |<z8> z8 |<z9> z9 |<z10> z10 |<z11> z11 |<z12> z12|<z13> z13|<z14> z14+" ] ;
|
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION layer_park(bbox geometry, zoom_level int, pixel_width numeric)
|
|
||||||
RETURNS TABLE
|
|
||||||
(
|
|
||||||
osm_id bigint,
|
|
||||||
geometry geometry,
|
|
||||||
class text,
|
|
||||||
name text,
|
|
||||||
name_en text,
|
|
||||||
name_de text,
|
|
||||||
tags hstore,
|
|
||||||
rank int
|
|
||||||
)
|
|
||||||
AS
|
|
||||||
$$
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry,
|
|
||||||
class,
|
|
||||||
name,
|
|
||||||
name_en,
|
|
||||||
name_de,
|
|
||||||
tags,
|
|
||||||
rank
|
|
||||||
FROM (
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry,
|
|
||||||
COALESCE(
|
|
||||||
LOWER(REPLACE(NULLIF(protection_title, ''), ' ', '_')),
|
|
||||||
NULLIF(boundary, ''),
|
|
||||||
NULLIF(leisure, '')
|
|
||||||
) AS class,
|
|
||||||
name,
|
|
||||||
name_en,
|
|
||||||
name_de,
|
|
||||||
tags,
|
|
||||||
NULL::int AS rank
|
|
||||||
FROM (
|
|
||||||
-- etldoc: osm_park_polygon_gen_z6 -> layer_park:z6
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry,
|
|
||||||
name,
|
|
||||||
name_en,
|
|
||||||
name_de,
|
|
||||||
tags,
|
|
||||||
leisure,
|
|
||||||
boundary,
|
|
||||||
protection_title
|
|
||||||
FROM osm_park_polygon_gen_z6
|
|
||||||
WHERE zoom_level = 6
|
|
||||||
AND geometry && bbox
|
|
||||||
UNION ALL
|
|
||||||
-- etldoc: osm_park_polygon_gen_z7 -> layer_park:z7
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry,
|
|
||||||
name,
|
|
||||||
name_en,
|
|
||||||
name_de,
|
|
||||||
tags,
|
|
||||||
leisure,
|
|
||||||
boundary,
|
|
||||||
protection_title
|
|
||||||
FROM osm_park_polygon_gen_z7
|
|
||||||
WHERE zoom_level = 7
|
|
||||||
AND geometry && bbox
|
|
||||||
UNION ALL
|
|
||||||
-- etldoc: osm_park_polygon_gen_z8 -> layer_park:z8
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry,
|
|
||||||
name,
|
|
||||||
name_en,
|
|
||||||
name_de,
|
|
||||||
tags,
|
|
||||||
leisure,
|
|
||||||
boundary,
|
|
||||||
protection_title
|
|
||||||
FROM osm_park_polygon_gen_z8
|
|
||||||
WHERE zoom_level = 8
|
|
||||||
AND geometry && bbox
|
|
||||||
UNION ALL
|
|
||||||
-- etldoc: osm_park_polygon_gen_z9 -> layer_park:z9
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry,
|
|
||||||
name,
|
|
||||||
name_en,
|
|
||||||
name_de,
|
|
||||||
tags,
|
|
||||||
leisure,
|
|
||||||
boundary,
|
|
||||||
protection_title
|
|
||||||
FROM osm_park_polygon_gen_z9
|
|
||||||
WHERE zoom_level = 9
|
|
||||||
AND geometry && bbox
|
|
||||||
UNION ALL
|
|
||||||
-- etldoc: osm_park_polygon_gen_z10 -> layer_park:z10
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry,
|
|
||||||
name,
|
|
||||||
name_en,
|
|
||||||
name_de,
|
|
||||||
tags,
|
|
||||||
leisure,
|
|
||||||
boundary,
|
|
||||||
protection_title
|
|
||||||
FROM osm_park_polygon_gen_z10
|
|
||||||
WHERE zoom_level = 10
|
|
||||||
AND geometry && bbox
|
|
||||||
UNION ALL
|
|
||||||
-- etldoc: osm_park_polygon_gen_z11 -> layer_park:z11
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry,
|
|
||||||
name,
|
|
||||||
name_en,
|
|
||||||
name_de,
|
|
||||||
tags,
|
|
||||||
leisure,
|
|
||||||
boundary,
|
|
||||||
protection_title
|
|
||||||
FROM osm_park_polygon_gen_z11
|
|
||||||
WHERE zoom_level = 11
|
|
||||||
AND geometry && bbox
|
|
||||||
UNION ALL
|
|
||||||
-- etldoc: osm_park_polygon_gen_z12 -> layer_park:z12
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry,
|
|
||||||
name,
|
|
||||||
name_en,
|
|
||||||
name_de,
|
|
||||||
tags,
|
|
||||||
leisure,
|
|
||||||
boundary,
|
|
||||||
protection_title
|
|
||||||
FROM osm_park_polygon_gen_z12
|
|
||||||
WHERE zoom_level = 12
|
|
||||||
AND geometry && bbox
|
|
||||||
UNION ALL
|
|
||||||
-- etldoc: osm_park_polygon_gen_z13 -> layer_park:z13
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry,
|
|
||||||
name,
|
|
||||||
name_en,
|
|
||||||
name_de,
|
|
||||||
tags,
|
|
||||||
leisure,
|
|
||||||
boundary,
|
|
||||||
protection_title
|
|
||||||
FROM osm_park_polygon_gen_z13
|
|
||||||
WHERE zoom_level = 13
|
|
||||||
AND geometry && bbox
|
|
||||||
UNION ALL
|
|
||||||
-- etldoc: osm_park_polygon -> layer_park:z14
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry,
|
|
||||||
name,
|
|
||||||
name_en,
|
|
||||||
name_de,
|
|
||||||
tags,
|
|
||||||
leisure,
|
|
||||||
boundary,
|
|
||||||
protection_title
|
|
||||||
FROM osm_park_polygon
|
|
||||||
WHERE zoom_level >= 14
|
|
||||||
AND geometry && bbox
|
|
||||||
) AS park_polygon
|
|
||||||
|
|
||||||
UNION ALL
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry_point AS geometry,
|
|
||||||
COALESCE(
|
|
||||||
LOWER(REPLACE(NULLIF(protection_title, ''), ' ', '_')),
|
|
||||||
NULLIF(boundary, ''),
|
|
||||||
NULLIF(leisure, '')
|
|
||||||
) AS class,
|
|
||||||
name,
|
|
||||||
name_en,
|
|
||||||
name_de,
|
|
||||||
tags,
|
|
||||||
row_number() OVER (
|
|
||||||
PARTITION BY LabelGrid(geometry_point, 100 * pixel_width)
|
|
||||||
ORDER BY
|
|
||||||
(CASE WHEN boundary = 'national_park' THEN TRUE ELSE FALSE END) DESC,
|
|
||||||
(COALESCE(NULLIF(tags->'wikipedia', ''), NULLIF(tags->'wikidata', '')) IS NOT NULL) DESC,
|
|
||||||
area DESC
|
|
||||||
)::int AS "rank"
|
|
||||||
FROM (
|
|
||||||
-- etldoc: osm_park_polygon_gen_z6 -> layer_park:z6
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry_point,
|
|
||||||
name,
|
|
||||||
name_en,
|
|
||||||
name_de,
|
|
||||||
tags,
|
|
||||||
leisure,
|
|
||||||
boundary,
|
|
||||||
protection_title,
|
|
||||||
area
|
|
||||||
FROM osm_park_polygon_gen_z6
|
|
||||||
WHERE zoom_level = 6
|
|
||||||
AND geometry_point && bbox
|
|
||||||
AND area > 70000*2^(20-zoom_level)
|
|
||||||
UNION ALL
|
|
||||||
|
|
||||||
-- etldoc: osm_park_polygon_gen_z7 -> layer_park:z7
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry_point,
|
|
||||||
name,
|
|
||||||
name_en,
|
|
||||||
name_de,
|
|
||||||
tags,
|
|
||||||
leisure,
|
|
||||||
boundary,
|
|
||||||
protection_title,
|
|
||||||
area
|
|
||||||
FROM osm_park_polygon_gen_z7
|
|
||||||
WHERE zoom_level = 7
|
|
||||||
AND geometry_point && bbox
|
|
||||||
AND area > 70000*2^(20-zoom_level)
|
|
||||||
UNION ALL
|
|
||||||
|
|
||||||
-- etldoc: osm_park_polygon_gen_z8 -> layer_park:z8
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry_point,
|
|
||||||
name,
|
|
||||||
name_en,
|
|
||||||
name_de,
|
|
||||||
tags,
|
|
||||||
leisure,
|
|
||||||
boundary,
|
|
||||||
protection_title,
|
|
||||||
area
|
|
||||||
FROM osm_park_polygon_gen_z8
|
|
||||||
WHERE zoom_level = 8
|
|
||||||
AND geometry_point && bbox
|
|
||||||
AND area > 70000*2^(20-zoom_level)
|
|
||||||
UNION ALL
|
|
||||||
|
|
||||||
-- etldoc: osm_park_polygon_gen_z9 -> layer_park:z9
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry_point,
|
|
||||||
name,
|
|
||||||
name_en,
|
|
||||||
name_de,
|
|
||||||
tags,
|
|
||||||
leisure,
|
|
||||||
boundary,
|
|
||||||
protection_title,
|
|
||||||
area
|
|
||||||
FROM osm_park_polygon_gen_z9
|
|
||||||
WHERE zoom_level = 9
|
|
||||||
AND geometry_point && bbox
|
|
||||||
AND area > 70000*2^(20-zoom_level)
|
|
||||||
UNION ALL
|
|
||||||
|
|
||||||
-- etldoc: osm_park_polygon_gen_z10 -> layer_park:z10
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry_point,
|
|
||||||
name,
|
|
||||||
name_en,
|
|
||||||
name_de,
|
|
||||||
tags,
|
|
||||||
leisure,
|
|
||||||
boundary,
|
|
||||||
protection_title,
|
|
||||||
area
|
|
||||||
FROM osm_park_polygon_gen_z10
|
|
||||||
WHERE zoom_level = 10
|
|
||||||
AND geometry_point && bbox
|
|
||||||
AND area > 70000*2^(20-zoom_level)
|
|
||||||
UNION ALL
|
|
||||||
|
|
||||||
-- etldoc: osm_park_polygon_gen_z11 -> layer_park:z11
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry_point,
|
|
||||||
name,
|
|
||||||
name_en,
|
|
||||||
name_de,
|
|
||||||
tags,
|
|
||||||
leisure,
|
|
||||||
boundary,
|
|
||||||
protection_title,
|
|
||||||
area
|
|
||||||
FROM osm_park_polygon_gen_z11
|
|
||||||
WHERE zoom_level = 11
|
|
||||||
AND geometry_point && bbox
|
|
||||||
AND area > 70000*2^(20-zoom_level)
|
|
||||||
UNION ALL
|
|
||||||
|
|
||||||
-- etldoc: osm_park_polygon_gen_z12 -> layer_park:z12
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry_point,
|
|
||||||
name,
|
|
||||||
name_en,
|
|
||||||
name_de,
|
|
||||||
tags,
|
|
||||||
leisure,
|
|
||||||
boundary,
|
|
||||||
protection_title,
|
|
||||||
area
|
|
||||||
FROM osm_park_polygon_gen_z12
|
|
||||||
WHERE zoom_level = 12
|
|
||||||
AND geometry_point && bbox
|
|
||||||
AND area > 70000*2^(20-zoom_level)
|
|
||||||
UNION ALL
|
|
||||||
|
|
||||||
-- etldoc: osm_park_polygon_gen_z13 -> layer_park:z13
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry_point,
|
|
||||||
name,
|
|
||||||
name_en,
|
|
||||||
name_de,
|
|
||||||
tags,
|
|
||||||
leisure,
|
|
||||||
boundary,
|
|
||||||
protection_title,
|
|
||||||
area
|
|
||||||
FROM osm_park_polygon_gen_z13
|
|
||||||
WHERE zoom_level = 13
|
|
||||||
AND geometry_point && bbox
|
|
||||||
AND area > 70000*2^(20-zoom_level)
|
|
||||||
UNION ALL
|
|
||||||
|
|
||||||
-- etldoc: osm_park_polygon -> layer_park:z14
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry_point,
|
|
||||||
name,
|
|
||||||
name_en,
|
|
||||||
name_de,
|
|
||||||
tags,
|
|
||||||
leisure,
|
|
||||||
boundary,
|
|
||||||
protection_title,
|
|
||||||
area
|
|
||||||
FROM osm_park_polygon
|
|
||||||
WHERE zoom_level >= 14
|
|
||||||
AND geometry_point && bbox
|
|
||||||
) AS park_point
|
|
||||||
) AS park_all;
|
|
||||||
$$ LANGUAGE SQL STABLE
|
|
||||||
PARALLEL SAFE;
|
|
||||||
-- TODO: Check if the above can be made STRICT -- i.e. if pixel_width could be NULL
|
|
||||||
@ -26,7 +26,7 @@ layer:
|
|||||||
query: (SELECT geometry, class, name, name_en, name_de, {name_languages}, rank FROM layer_park(!bbox!, z(!scale_denominator!), !pixel_width!)) AS t
|
query: (SELECT geometry, class, name, name_en, name_de, {name_languages}, rank FROM layer_park(!bbox!, z(!scale_denominator!), !pixel_width!)) AS t
|
||||||
schema:
|
schema:
|
||||||
- ./update_park_polygon.sql
|
- ./update_park_polygon.sql
|
||||||
- ./park.sql
|
- ./layer.sql
|
||||||
datasources:
|
datasources:
|
||||||
- type: imposm3
|
- type: imposm3
|
||||||
mapping_file: ./mapping.yaml
|
mapping_file: ./mapping.yaml
|
||||||
|
|||||||
@ -1,156 +1,140 @@
|
|||||||
ALTER TABLE osm_park_polygon
|
ALTER TABLE osm_park_polygon ADD COLUMN IF NOT EXISTS geometry_point geometry;
|
||||||
ADD COLUMN IF NOT EXISTS geometry_point geometry;
|
ALTER TABLE osm_park_polygon_gen1 ADD COLUMN IF NOT EXISTS geometry_point geometry;
|
||||||
ALTER TABLE osm_park_polygon_gen_z13
|
ALTER TABLE osm_park_polygon_gen2 ADD COLUMN IF NOT EXISTS geometry_point geometry;
|
||||||
ADD COLUMN IF NOT EXISTS geometry_point geometry;
|
ALTER TABLE osm_park_polygon_gen3 ADD COLUMN IF NOT EXISTS geometry_point geometry;
|
||||||
ALTER TABLE osm_park_polygon_gen_z12
|
ALTER TABLE osm_park_polygon_gen4 ADD COLUMN IF NOT EXISTS geometry_point geometry;
|
||||||
ADD COLUMN IF NOT EXISTS geometry_point geometry;
|
ALTER TABLE osm_park_polygon_gen5 ADD COLUMN IF NOT EXISTS geometry_point geometry;
|
||||||
ALTER TABLE osm_park_polygon_gen_z11
|
ALTER TABLE osm_park_polygon_gen6 ADD COLUMN IF NOT EXISTS geometry_point geometry;
|
||||||
ADD COLUMN IF NOT EXISTS geometry_point geometry;
|
ALTER TABLE osm_park_polygon_gen7 ADD COLUMN IF NOT EXISTS geometry_point geometry;
|
||||||
ALTER TABLE osm_park_polygon_gen_z10
|
ALTER TABLE osm_park_polygon_gen8 ADD COLUMN IF NOT EXISTS geometry_point geometry;
|
||||||
ADD COLUMN IF NOT EXISTS geometry_point geometry;
|
|
||||||
ALTER TABLE osm_park_polygon_gen_z9
|
|
||||||
ADD COLUMN IF NOT EXISTS geometry_point geometry;
|
|
||||||
ALTER TABLE osm_park_polygon_gen_z8
|
|
||||||
ADD COLUMN IF NOT EXISTS geometry_point geometry;
|
|
||||||
ALTER TABLE osm_park_polygon_gen_z7
|
|
||||||
ADD COLUMN IF NOT EXISTS geometry_point geometry;
|
|
||||||
ALTER TABLE osm_park_polygon_gen_z6
|
|
||||||
ADD COLUMN IF NOT EXISTS geometry_point geometry;
|
|
||||||
|
|
||||||
DROP TRIGGER IF EXISTS update_row ON osm_park_polygon;
|
DROP TRIGGER IF EXISTS update_row ON osm_park_polygon;
|
||||||
DROP TRIGGER IF EXISTS update_row ON osm_park_polygon_gen_z13;
|
DROP TRIGGER IF EXISTS update_row ON osm_park_polygon_gen1;
|
||||||
DROP TRIGGER IF EXISTS update_row ON osm_park_polygon_gen_z12;
|
DROP TRIGGER IF EXISTS update_row ON osm_park_polygon_gen2;
|
||||||
DROP TRIGGER IF EXISTS update_row ON osm_park_polygon_gen_z11;
|
DROP TRIGGER IF EXISTS update_row ON osm_park_polygon_gen3;
|
||||||
DROP TRIGGER IF EXISTS update_row ON osm_park_polygon_gen_z10;
|
DROP TRIGGER IF EXISTS update_row ON osm_park_polygon_gen4;
|
||||||
DROP TRIGGER IF EXISTS update_row ON osm_park_polygon_gen_z9;
|
DROP TRIGGER IF EXISTS update_row ON osm_park_polygon_gen5;
|
||||||
DROP TRIGGER IF EXISTS update_row ON osm_park_polygon_gen_z8;
|
DROP TRIGGER IF EXISTS update_row ON osm_park_polygon_gen6;
|
||||||
DROP TRIGGER IF EXISTS update_row ON osm_park_polygon_gen_z7;
|
DROP TRIGGER IF EXISTS update_row ON osm_park_polygon_gen7;
|
||||||
DROP TRIGGER IF EXISTS update_row ON osm_park_polygon_gen_z6;
|
DROP TRIGGER IF EXISTS update_row ON osm_park_polygon_gen8;
|
||||||
|
|
||||||
-- etldoc: osm_park_polygon -> osm_park_polygon
|
-- etldoc: osm_park_polygon -> osm_park_polygon
|
||||||
-- etldoc: osm_park_polygon_gen_z13 -> osm_park_polygon_gen_z13
|
-- etldoc: osm_park_polygon_gen1 -> osm_park_polygon_gen1
|
||||||
-- etldoc: osm_park_polygon_gen_z12 -> osm_park_polygon_gen_z12
|
-- etldoc: osm_park_polygon_gen2 -> osm_park_polygon_gen2
|
||||||
-- etldoc: osm_park_polygon_gen_z11 -> osm_park_polygon_gen_z11
|
-- etldoc: osm_park_polygon_gen3 -> osm_park_polygon_gen3
|
||||||
-- etldoc: osm_park_polygon_gen_z10 -> osm_park_polygon_gen_z10
|
-- etldoc: osm_park_polygon_gen4 -> osm_park_polygon_gen4
|
||||||
-- etldoc: osm_park_polygon_gen_z9 -> osm_park_polygon_gen_z9
|
-- etldoc: osm_park_polygon_gen5 -> osm_park_polygon_gen5
|
||||||
-- etldoc: osm_park_polygon_gen_z8 -> osm_park_polygon_gen_z8
|
-- etldoc: osm_park_polygon_gen6 -> osm_park_polygon_gen6
|
||||||
-- etldoc: osm_park_polygon_gen_z7 -> osm_park_polygon_gen_z7
|
-- etldoc: osm_park_polygon_gen7 -> osm_park_polygon_gen7
|
||||||
-- etldoc: osm_park_polygon_gen_z6 -> osm_park_polygon_gen_z6
|
-- etldoc: osm_park_polygon_gen8 -> osm_park_polygon_gen8
|
||||||
CREATE OR REPLACE FUNCTION update_osm_park_polygon() RETURNS void AS
|
CREATE OR REPLACE FUNCTION update_osm_park_polygon() RETURNS VOID AS $$
|
||||||
$$
|
|
||||||
BEGIN
|
BEGIN
|
||||||
UPDATE osm_park_polygon
|
UPDATE osm_park_polygon
|
||||||
SET tags = update_tags(tags, geometry),
|
SET tags = update_tags(tags, geometry),
|
||||||
geometry_point = st_centroid(geometry);
|
geometry_point = st_centroid(geometry);
|
||||||
|
|
||||||
UPDATE osm_park_polygon_gen_z13
|
UPDATE osm_park_polygon_gen1
|
||||||
SET tags = update_tags(tags, geometry),
|
SET tags = update_tags(tags, geometry),
|
||||||
geometry_point = st_centroid(geometry);
|
geometry_point = st_centroid(geometry);
|
||||||
|
|
||||||
UPDATE osm_park_polygon_gen_z12
|
UPDATE osm_park_polygon_gen2
|
||||||
SET tags = update_tags(tags, geometry),
|
SET tags = update_tags(tags, geometry),
|
||||||
geometry_point = st_centroid(geometry);
|
geometry_point = st_centroid(geometry);
|
||||||
|
|
||||||
UPDATE osm_park_polygon_gen_z11
|
UPDATE osm_park_polygon_gen3
|
||||||
SET tags = update_tags(tags, geometry),
|
SET tags = update_tags(tags, geometry),
|
||||||
geometry_point = st_centroid(geometry);
|
geometry_point = st_centroid(geometry);
|
||||||
|
|
||||||
UPDATE osm_park_polygon_gen_z10
|
UPDATE osm_park_polygon_gen4
|
||||||
SET tags = update_tags(tags, geometry),
|
SET tags = update_tags(tags, geometry),
|
||||||
geometry_point = st_centroid(geometry);
|
geometry_point = st_centroid(geometry);
|
||||||
|
|
||||||
UPDATE osm_park_polygon_gen_z9
|
UPDATE osm_park_polygon_gen5
|
||||||
SET tags = update_tags(tags, geometry),
|
SET tags = update_tags(tags, geometry),
|
||||||
geometry_point = st_centroid(geometry);
|
geometry_point = st_centroid(geometry);
|
||||||
|
|
||||||
UPDATE osm_park_polygon_gen_z8
|
UPDATE osm_park_polygon_gen6
|
||||||
SET tags = update_tags(tags, geometry),
|
SET tags = update_tags(tags, geometry),
|
||||||
geometry_point = st_centroid(geometry);
|
geometry_point = st_centroid(geometry);
|
||||||
|
|
||||||
UPDATE osm_park_polygon_gen_z7
|
UPDATE osm_park_polygon_gen7
|
||||||
SET tags = update_tags(tags, geometry),
|
SET tags = update_tags(tags, geometry),
|
||||||
geometry_point = st_centroid(geometry);
|
geometry_point = st_centroid(geometry);
|
||||||
|
|
||||||
UPDATE osm_park_polygon_gen_z6
|
UPDATE osm_park_polygon_gen8
|
||||||
SET tags = update_tags(tags, geometry),
|
SET tags = update_tags(tags, geometry),
|
||||||
geometry_point = st_centroid(geometry);
|
geometry_point = st_centroid(geometry);
|
||||||
|
|
||||||
END;
|
END;
|
||||||
$$ LANGUAGE plpgsql;
|
$$ LANGUAGE plpgsql;
|
||||||
|
|
||||||
SELECT update_osm_park_polygon();
|
SELECT update_osm_park_polygon();
|
||||||
CREATE INDEX IF NOT EXISTS osm_park_polygon_point_geom_idx ON osm_park_polygon USING gist (geometry_point);
|
CREATE INDEX IF NOT EXISTS osm_park_polygon_point_geom_idx ON osm_park_polygon USING gist(geometry_point);
|
||||||
CREATE INDEX IF NOT EXISTS osm_park_polygon_gen_z13_point_geom_idx ON osm_park_polygon_gen_z13 USING gist (geometry_point);
|
CREATE INDEX IF NOT EXISTS osm_park_polygon_gen1_point_geom_idx ON osm_park_polygon_gen1 USING gist(geometry_point);
|
||||||
CREATE INDEX IF NOT EXISTS osm_park_polygon_gen_z12_point_geom_idx ON osm_park_polygon_gen_z12 USING gist (geometry_point);
|
CREATE INDEX IF NOT EXISTS osm_park_polygon_gen2_point_geom_idx ON osm_park_polygon_gen2 USING gist(geometry_point);
|
||||||
CREATE INDEX IF NOT EXISTS osm_park_polygon_gen_z11_point_geom_idx ON osm_park_polygon_gen_z11 USING gist (geometry_point);
|
CREATE INDEX IF NOT EXISTS osm_park_polygon_gen3_point_geom_idx ON osm_park_polygon_gen3 USING gist(geometry_point);
|
||||||
CREATE INDEX IF NOT EXISTS osm_park_polygon_gen_z10_point_geom_idx ON osm_park_polygon_gen_z10 USING gist (geometry_point);
|
CREATE INDEX IF NOT EXISTS osm_park_polygon_gen4_point_geom_idx ON osm_park_polygon_gen4 USING gist(geometry_point);
|
||||||
CREATE INDEX IF NOT EXISTS osm_park_polygon_gen_z9_point_geom_idx ON osm_park_polygon_gen_z9 USING gist (geometry_point);
|
CREATE INDEX IF NOT EXISTS osm_park_polygon_gen5_point_geom_idx ON osm_park_polygon_gen5 USING gist(geometry_point);
|
||||||
CREATE INDEX IF NOT EXISTS osm_park_polygon_gen_z8_point_geom_idx ON osm_park_polygon_gen_z8 USING gist (geometry_point);
|
CREATE INDEX IF NOT EXISTS osm_park_polygon_gen6_point_geom_idx ON osm_park_polygon_gen6 USING gist(geometry_point);
|
||||||
CREATE INDEX IF NOT EXISTS osm_park_polygon_gen_z7_point_geom_idx ON osm_park_polygon_gen_z7 USING gist (geometry_point);
|
CREATE INDEX IF NOT EXISTS osm_park_polygon_gen7_point_geom_idx ON osm_park_polygon_gen7 USING gist(geometry_point);
|
||||||
CREATE INDEX IF NOT EXISTS osm_park_polygon_gen_z6_point_geom_idx ON osm_park_polygon_gen_z6 USING gist (geometry_point);
|
CREATE INDEX IF NOT EXISTS osm_park_polygon_gen8_point_geom_idx ON osm_park_polygon_gen8 USING gist(geometry_point);
|
||||||
|
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION update_osm_park_polygon_row()
|
CREATE OR REPLACE FUNCTION update_osm_park_polygon_row()
|
||||||
RETURNS trigger
|
RETURNS TRIGGER
|
||||||
AS
|
AS
|
||||||
$$
|
$BODY$
|
||||||
BEGIN
|
BEGIN
|
||||||
NEW.tags = update_tags(NEW.tags, NEW.geometry);
|
NEW.tags = update_tags(NEW.tags, NEW.geometry);
|
||||||
NEW.geometry_point = st_centroid(NEW.geometry);
|
NEW.geometry_point = st_centroid(NEW.geometry);
|
||||||
RETURN NEW;
|
RETURN NEW;
|
||||||
END;
|
END;
|
||||||
$$ LANGUAGE plpgsql;
|
$BODY$
|
||||||
|
LANGUAGE plpgsql;
|
||||||
|
|
||||||
CREATE TRIGGER update_row
|
CREATE TRIGGER update_row
|
||||||
BEFORE INSERT OR UPDATE
|
BEFORE INSERT OR UPDATE ON osm_park_polygon
|
||||||
ON osm_park_polygon
|
FOR EACH ROW
|
||||||
FOR EACH ROW
|
|
||||||
EXECUTE PROCEDURE update_osm_park_polygon_row();
|
EXECUTE PROCEDURE update_osm_park_polygon_row();
|
||||||
|
|
||||||
CREATE TRIGGER update_row
|
CREATE TRIGGER update_row
|
||||||
BEFORE INSERT OR UPDATE
|
BEFORE INSERT OR UPDATE ON osm_park_polygon_gen1
|
||||||
ON osm_park_polygon_gen_z13
|
FOR EACH ROW
|
||||||
FOR EACH ROW
|
|
||||||
EXECUTE PROCEDURE update_osm_park_polygon_row();
|
EXECUTE PROCEDURE update_osm_park_polygon_row();
|
||||||
|
|
||||||
CREATE TRIGGER update_row
|
CREATE TRIGGER update_row
|
||||||
BEFORE INSERT OR UPDATE
|
BEFORE INSERT OR UPDATE ON osm_park_polygon_gen2
|
||||||
ON osm_park_polygon_gen_z12
|
FOR EACH ROW
|
||||||
FOR EACH ROW
|
|
||||||
EXECUTE PROCEDURE update_osm_park_polygon_row();
|
EXECUTE PROCEDURE update_osm_park_polygon_row();
|
||||||
|
|
||||||
CREATE TRIGGER update_row
|
CREATE TRIGGER update_row
|
||||||
BEFORE INSERT OR UPDATE
|
BEFORE INSERT OR UPDATE ON osm_park_polygon_gen3
|
||||||
ON osm_park_polygon_gen_z11
|
FOR EACH ROW
|
||||||
FOR EACH ROW
|
|
||||||
EXECUTE PROCEDURE update_osm_park_polygon_row();
|
EXECUTE PROCEDURE update_osm_park_polygon_row();
|
||||||
|
|
||||||
CREATE TRIGGER update_row
|
CREATE TRIGGER update_row
|
||||||
BEFORE INSERT OR UPDATE
|
BEFORE INSERT OR UPDATE ON osm_park_polygon_gen4
|
||||||
ON osm_park_polygon_gen_z10
|
FOR EACH ROW
|
||||||
FOR EACH ROW
|
|
||||||
EXECUTE PROCEDURE update_osm_park_polygon_row();
|
EXECUTE PROCEDURE update_osm_park_polygon_row();
|
||||||
|
|
||||||
CREATE TRIGGER update_row
|
CREATE TRIGGER update_row
|
||||||
BEFORE INSERT OR UPDATE
|
BEFORE INSERT OR UPDATE ON osm_park_polygon_gen5
|
||||||
ON osm_park_polygon_gen_z9
|
FOR EACH ROW
|
||||||
FOR EACH ROW
|
|
||||||
EXECUTE PROCEDURE update_osm_park_polygon_row();
|
EXECUTE PROCEDURE update_osm_park_polygon_row();
|
||||||
|
|
||||||
CREATE TRIGGER update_row
|
CREATE TRIGGER update_row
|
||||||
BEFORE INSERT OR UPDATE
|
BEFORE INSERT OR UPDATE ON osm_park_polygon_gen6
|
||||||
ON osm_park_polygon_gen_z8
|
FOR EACH ROW
|
||||||
FOR EACH ROW
|
|
||||||
EXECUTE PROCEDURE update_osm_park_polygon_row();
|
EXECUTE PROCEDURE update_osm_park_polygon_row();
|
||||||
|
|
||||||
CREATE TRIGGER update_row
|
CREATE TRIGGER update_row
|
||||||
BEFORE INSERT OR UPDATE
|
BEFORE INSERT OR UPDATE ON osm_park_polygon_gen7
|
||||||
ON osm_park_polygon_gen_z7
|
FOR EACH ROW
|
||||||
FOR EACH ROW
|
|
||||||
EXECUTE PROCEDURE update_osm_park_polygon_row();
|
EXECUTE PROCEDURE update_osm_park_polygon_row();
|
||||||
|
|
||||||
CREATE TRIGGER update_row
|
CREATE TRIGGER update_row
|
||||||
BEFORE INSERT OR UPDATE
|
BEFORE INSERT OR UPDATE ON osm_park_polygon_gen8
|
||||||
ON osm_park_polygon_gen_z6
|
FOR EACH ROW
|
||||||
FOR EACH ROW
|
|
||||||
EXECUTE PROCEDURE update_osm_park_polygon_row();
|
EXECUTE PROCEDURE update_osm_park_polygon_row();
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@ -1,10 +1,9 @@
|
|||||||
CREATE OR REPLACE FUNCTION normalize_capital_level(capital text)
|
CREATE OR REPLACE FUNCTION normalize_capital_level(capital TEXT)
|
||||||
RETURNS int AS
|
RETURNS INT AS $$
|
||||||
|
SELECT CASE
|
||||||
|
WHEN capital IN ('yes', '2') THEN 2
|
||||||
|
WHEN capital = '4' THEN 4
|
||||||
|
END;
|
||||||
$$
|
$$
|
||||||
SELECT CASE
|
LANGUAGE SQL
|
||||||
WHEN capital IN ('yes', '2') THEN 2
|
IMMUTABLE STRICT PARALLEL SAFE;
|
||||||
WHEN capital = '4' THEN 4
|
|
||||||
END;
|
|
||||||
$$ LANGUAGE SQL IMMUTABLE
|
|
||||||
STRICT
|
|
||||||
PARALLEL SAFE;
|
|
||||||
|
|||||||
@ -1,79 +1,57 @@
|
|||||||
|
|
||||||
-- etldoc: layer_city[shape=record fillcolor=lightpink, style="rounded,filled",
|
-- etldoc: layer_city[shape=record fillcolor=lightpink, style="rounded,filled",
|
||||||
-- etldoc: label="layer_city | <z2_14> z2-z14+" ] ;
|
-- etldoc: label="layer_city | <z2_14> z2-z14+" ] ;
|
||||||
|
|
||||||
-- etldoc: osm_city_point -> layer_city:z2_14
|
-- etldoc: osm_city_point -> layer_city:z2_14
|
||||||
CREATE OR REPLACE FUNCTION layer_city(bbox geometry, zoom_level int, pixel_width numeric)
|
CREATE OR REPLACE FUNCTION layer_city(bbox geometry, zoom_level int, pixel_width numeric)
|
||||||
RETURNS TABLE
|
RETURNS TABLE(osm_id bigint, geometry geometry, name text, name_en text, name_de text, tags hstore, place city_place, "rank" int, capital int) AS $$
|
||||||
(
|
SELECT * FROM (
|
||||||
osm_id bigint,
|
SELECT osm_id, geometry, name,
|
||||||
geometry geometry,
|
COALESCE(NULLIF(name_en, ''), name) AS name_en,
|
||||||
name text,
|
COALESCE(NULLIF(name_de, ''), name, name_en) AS name_de,
|
||||||
name_en text,
|
tags,
|
||||||
name_de text,
|
place, "rank", normalize_capital_level(capital) AS capital
|
||||||
tags hstore,
|
FROM osm_city_point
|
||||||
place city_place,
|
WHERE geometry && bbox
|
||||||
"rank" int,
|
AND ((zoom_level = 2 AND "rank" = 1)
|
||||||
capital int
|
OR (zoom_level BETWEEN 3 AND 7 AND "rank" <= zoom_level + 1)
|
||||||
)
|
)
|
||||||
AS
|
UNION ALL
|
||||||
|
SELECT osm_id, geometry, name,
|
||||||
|
COALESCE(NULLIF(name_en, ''), name) AS name_en,
|
||||||
|
COALESCE(NULLIF(name_de, ''), name, name_en) AS name_de,
|
||||||
|
tags,
|
||||||
|
place,
|
||||||
|
COALESCE("rank", gridrank + 10),
|
||||||
|
normalize_capital_level(capital) AS capital
|
||||||
|
FROM (
|
||||||
|
SELECT osm_id, geometry, name,
|
||||||
|
COALESCE(NULLIF(name_en, ''), name) AS name_en,
|
||||||
|
COALESCE(NULLIF(name_de, ''), name, name_en) AS name_de,
|
||||||
|
tags,
|
||||||
|
place, "rank", capital,
|
||||||
|
row_number() OVER (
|
||||||
|
PARTITION BY LabelGrid(geometry, 128 * pixel_width)
|
||||||
|
ORDER BY "rank" ASC NULLS LAST,
|
||||||
|
place ASC NULLS LAST,
|
||||||
|
population DESC NULLS LAST,
|
||||||
|
length(name) ASC
|
||||||
|
)::int AS gridrank
|
||||||
|
FROM osm_city_point
|
||||||
|
WHERE geometry && bbox
|
||||||
|
AND ((zoom_level = 7 AND place <= 'town'::city_place
|
||||||
|
OR (zoom_level BETWEEN 8 AND 10 AND place <= 'village'::city_place)
|
||||||
|
|
||||||
|
OR (zoom_level BETWEEN 11 AND 13 AND place <= 'suburb'::city_place)
|
||||||
|
OR (zoom_level >= 14)
|
||||||
|
))
|
||||||
|
) AS ranked_places
|
||||||
|
WHERE (zoom_level BETWEEN 7 AND 8 AND (gridrank <= 4 OR "rank" IS NOT NULL))
|
||||||
|
OR (zoom_level = 9 AND (gridrank <= 8 OR "rank" IS NOT NULL))
|
||||||
|
OR (zoom_level = 10 AND (gridrank <= 12 OR "rank" IS NOT NULL))
|
||||||
|
OR (zoom_level BETWEEN 11 AND 12 AND (gridrank <= 14 OR "rank" IS NOT NULL))
|
||||||
|
OR (zoom_level >= 13)
|
||||||
|
) as city_all;
|
||||||
$$
|
$$
|
||||||
SELECT *
|
LANGUAGE SQL
|
||||||
FROM (
|
IMMUTABLE PARALLEL SAFE;
|
||||||
SELECT osm_id,
|
|
||||||
geometry,
|
|
||||||
name,
|
|
||||||
COALESCE(NULLIF(name_en, ''), name) AS name_en,
|
|
||||||
COALESCE(NULLIF(name_de, ''), name, name_en) AS name_de,
|
|
||||||
tags,
|
|
||||||
place,
|
|
||||||
"rank",
|
|
||||||
normalize_capital_level(capital) AS capital
|
|
||||||
FROM osm_city_point
|
|
||||||
WHERE geometry && bbox
|
|
||||||
AND ((zoom_level = 2 AND "rank" = 1)
|
|
||||||
OR (zoom_level BETWEEN 3 AND 7 AND "rank" <= zoom_level + 1)
|
|
||||||
)
|
|
||||||
UNION ALL
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry,
|
|
||||||
name,
|
|
||||||
COALESCE(NULLIF(name_en, ''), name) AS name_en,
|
|
||||||
COALESCE(NULLIF(name_de, ''), name, name_en) AS name_de,
|
|
||||||
tags,
|
|
||||||
place,
|
|
||||||
COALESCE("rank", gridrank + 10),
|
|
||||||
normalize_capital_level(capital) AS capital
|
|
||||||
FROM (
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry,
|
|
||||||
name,
|
|
||||||
COALESCE(NULLIF(name_en, ''), name) AS name_en,
|
|
||||||
COALESCE(NULLIF(name_de, ''), name, name_en) AS name_de,
|
|
||||||
tags,
|
|
||||||
place,
|
|
||||||
"rank",
|
|
||||||
capital,
|
|
||||||
row_number() OVER (
|
|
||||||
PARTITION BY LabelGrid(geometry, 128 * pixel_width)
|
|
||||||
ORDER BY "rank" ASC NULLS LAST,
|
|
||||||
place ASC NULLS LAST,
|
|
||||||
population DESC NULLS LAST,
|
|
||||||
length(name) ASC
|
|
||||||
)::int AS gridrank
|
|
||||||
FROM osm_city_point
|
|
||||||
WHERE geometry && bbox
|
|
||||||
AND ((zoom_level = 7 AND place <= 'town'::city_place
|
|
||||||
OR (zoom_level BETWEEN 8 AND 10 AND place <= 'village'::city_place)
|
|
||||||
OR (zoom_level BETWEEN 11 AND 13 AND place <= 'suburb'::city_place)
|
|
||||||
OR (zoom_level >= 14)
|
|
||||||
))
|
|
||||||
) AS ranked_places
|
|
||||||
WHERE (zoom_level BETWEEN 7 AND 8 AND (gridrank <= 4 OR "rank" IS NOT NULL))
|
|
||||||
OR (zoom_level = 9 AND (gridrank <= 8 OR "rank" IS NOT NULL))
|
|
||||||
OR (zoom_level = 10 AND (gridrank <= 12 OR "rank" IS NOT NULL))
|
|
||||||
OR (zoom_level BETWEEN 11 AND 12 AND (gridrank <= 14 OR "rank" IS NOT NULL))
|
|
||||||
OR (zoom_level >= 13)
|
|
||||||
) AS city_all;
|
|
||||||
$$ LANGUAGE SQL STABLE
|
|
||||||
-- STRICT
|
|
||||||
PARALLEL SAFE;
|
|
||||||
|
|||||||
@ -1,12 +1,11 @@
|
|||||||
CREATE OR REPLACE FUNCTION island_rank(area real) RETURNS int AS
|
CREATE OR REPLACE FUNCTION island_rank(area REAL) RETURNS INT AS $$
|
||||||
|
SELECT CASE
|
||||||
|
WHEN area < 10000000 THEN 6
|
||||||
|
WHEN area BETWEEN 1000000 AND 15000000 THEN 5
|
||||||
|
WHEN area BETWEEN 15000000 AND 40000000 THEN 4
|
||||||
|
WHEN area > 40000000 THEN 3
|
||||||
|
ELSE 7
|
||||||
|
END;
|
||||||
$$
|
$$
|
||||||
SELECT CASE
|
LANGUAGE SQL
|
||||||
WHEN area < 10000000 THEN 6
|
IMMUTABLE STRICT PARALLEL SAFE;
|
||||||
WHEN area BETWEEN 1000000 AND 15000000 THEN 5
|
|
||||||
WHEN area BETWEEN 15000000 AND 40000000 THEN 4
|
|
||||||
WHEN area > 40000000 THEN 3
|
|
||||||
ELSE 7
|
|
||||||
END;
|
|
||||||
$$ LANGUAGE SQL IMMUTABLE
|
|
||||||
STRICT
|
|
||||||
PARALLEL SAFE;
|
|
||||||
|
|||||||
101
layers/place/layer.sql
Normal file
@ -0,0 +1,101 @@
|
|||||||
|
|
||||||
|
-- etldoc: layer_place[shape=record fillcolor=lightpink, style="rounded,filled",
|
||||||
|
-- etldoc: label="layer_place | <z0_3> z0-3|<z4_7> z4-7|<z8_11> z8-11| <z12_14> z12-z14+" ] ;
|
||||||
|
|
||||||
|
CREATE OR REPLACE FUNCTION layer_place(bbox geometry, zoom_level int, pixel_width numeric)
|
||||||
|
RETURNS TABLE(osm_id bigint, geometry geometry, name text, name_en text,
|
||||||
|
name_de text, tags hstore, class text, "rank" int, capital INT, iso_a2
|
||||||
|
TEXT) AS $$
|
||||||
|
SELECT * FROM (
|
||||||
|
|
||||||
|
-- etldoc: osm_continent_point -> layer_place:z0_3
|
||||||
|
SELECT
|
||||||
|
osm_id*10, geometry, name,
|
||||||
|
COALESCE(NULLIF(name_en, ''), name) AS name_en,
|
||||||
|
COALESCE(NULLIF(name_de, ''), name, name_en) AS name_de,
|
||||||
|
tags,
|
||||||
|
'continent' AS class, 1 AS "rank", NULL::int AS capital,
|
||||||
|
NULL::text AS iso_a2
|
||||||
|
FROM osm_continent_point
|
||||||
|
WHERE geometry && bbox AND zoom_level < 4
|
||||||
|
UNION ALL
|
||||||
|
|
||||||
|
-- etldoc: osm_country_point -> layer_place:z0_3
|
||||||
|
-- etldoc: osm_country_point -> layer_place:z4_7
|
||||||
|
-- etldoc: osm_country_point -> layer_place:z8_11
|
||||||
|
-- etldoc: osm_country_point -> layer_place:z12_14
|
||||||
|
SELECT
|
||||||
|
osm_id*10, geometry, name,
|
||||||
|
COALESCE(NULLIF(name_en, ''), name) AS name_en,
|
||||||
|
COALESCE(NULLIF(name_de, ''), name, name_en) AS name_de,
|
||||||
|
tags,
|
||||||
|
'country' AS class, "rank", NULL::int AS capital,
|
||||||
|
iso3166_1_alpha_2 AS iso_a2
|
||||||
|
FROM osm_country_point
|
||||||
|
WHERE geometry && bbox AND "rank" <= zoom_level + 1 AND name <> ''
|
||||||
|
UNION ALL
|
||||||
|
|
||||||
|
-- etldoc: osm_state_point -> layer_place:z0_3
|
||||||
|
-- etldoc: osm_state_point -> layer_place:z4_7
|
||||||
|
-- etldoc: osm_state_point -> layer_place:z8_11
|
||||||
|
-- etldoc: osm_state_point -> layer_place:z12_14
|
||||||
|
SELECT
|
||||||
|
osm_id*10, geometry, name,
|
||||||
|
COALESCE(NULLIF(name_en, ''), name) AS name_en,
|
||||||
|
COALESCE(NULLIF(name_de, ''), name, name_en) AS name_de,
|
||||||
|
tags,
|
||||||
|
'state' AS class, "rank", NULL::int AS capital,
|
||||||
|
NULL::text AS iso_a2
|
||||||
|
FROM osm_state_point
|
||||||
|
WHERE geometry && bbox AND
|
||||||
|
name <> '' AND
|
||||||
|
("rank" + 2 <= zoom_level) AND (
|
||||||
|
zoom_level >= 5 OR
|
||||||
|
is_in_country IN ('United Kingdom', 'USA', 'Россия', 'Brasil', 'China', 'India') OR
|
||||||
|
is_in_country_code IN ('AU', 'CN', 'IN', 'BR', 'US'))
|
||||||
|
UNION ALL
|
||||||
|
|
||||||
|
-- etldoc: osm_island_point -> layer_place:z12_14
|
||||||
|
SELECT
|
||||||
|
osm_id*10, geometry, name,
|
||||||
|
COALESCE(NULLIF(name_en, ''), name) AS name_en,
|
||||||
|
COALESCE(NULLIF(name_de, ''), name, name_en) AS name_de,
|
||||||
|
tags,
|
||||||
|
'island' AS class, 7 AS "rank", NULL::int AS capital,
|
||||||
|
NULL::text AS iso_a2
|
||||||
|
FROM osm_island_point
|
||||||
|
WHERE zoom_level >= 12
|
||||||
|
AND geometry && bbox
|
||||||
|
UNION ALL
|
||||||
|
|
||||||
|
-- etldoc: osm_island_polygon -> layer_place:z8_11
|
||||||
|
-- etldoc: osm_island_polygon -> layer_place:z12_14
|
||||||
|
SELECT
|
||||||
|
osm_id*10, geometry, name,
|
||||||
|
COALESCE(NULLIF(name_en, ''), name) AS name_en,
|
||||||
|
COALESCE(NULLIF(name_de, ''), name, name_en) AS name_de,
|
||||||
|
tags,
|
||||||
|
'island' AS class, island_rank(area) AS "rank", NULL::int AS capital,
|
||||||
|
NULL::text AS iso_a2
|
||||||
|
FROM osm_island_polygon
|
||||||
|
WHERE geometry && bbox AND
|
||||||
|
((zoom_level = 8 AND island_rank(area) <= 3)
|
||||||
|
OR (zoom_level = 9 AND island_rank(area) <= 4)
|
||||||
|
OR (zoom_level >= 10))
|
||||||
|
UNION ALL
|
||||||
|
|
||||||
|
-- etldoc: layer_city -> layer_place:z0_3
|
||||||
|
-- etldoc: layer_city -> layer_place:z4_7
|
||||||
|
-- etldoc: layer_city -> layer_place:z8_11
|
||||||
|
-- etldoc: layer_city -> layer_place:z12_14
|
||||||
|
SELECT
|
||||||
|
osm_id*10, geometry, name, name_en, name_de,
|
||||||
|
tags,
|
||||||
|
place::text AS class, "rank", capital,
|
||||||
|
NULL::text AS iso_a2
|
||||||
|
FROM layer_city(bbox, zoom_level, pixel_width)
|
||||||
|
ORDER BY "rank" ASC
|
||||||
|
) AS place_all
|
||||||
|
$$
|
||||||
|
LANGUAGE SQL
|
||||||
|
IMMUTABLE PARALLEL SAFE;
|
||||||
@ -174,6 +174,5 @@ tables:
|
|||||||
- village
|
- village
|
||||||
- hamlet
|
- hamlet
|
||||||
- suburb
|
- suburb
|
||||||
- quarter
|
|
||||||
- neighbourhood
|
- neighbourhood
|
||||||
- isolated_dwelling
|
- isolated_dwelling
|
||||||
|
|||||||
|
Before Width: | Height: | Size: 51 KiB After Width: | Height: | Size: 50 KiB |
@ -1,143 +0,0 @@
|
|||||||
-- etldoc: layer_place[shape=record fillcolor=lightpink, style="rounded,filled",
|
|
||||||
-- etldoc: label="layer_place | <z0_3> z0-3|<z4_7> z4-7|<z8_11> z8-11| <z12_14> z12-z14+" ] ;
|
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION layer_place(bbox geometry, zoom_level int, pixel_width numeric)
|
|
||||||
RETURNS TABLE
|
|
||||||
(
|
|
||||||
osm_id bigint,
|
|
||||||
geometry geometry,
|
|
||||||
name text,
|
|
||||||
name_en text,
|
|
||||||
name_de text,
|
|
||||||
tags hstore,
|
|
||||||
class text,
|
|
||||||
"rank" int,
|
|
||||||
capital int,
|
|
||||||
iso_a2 text
|
|
||||||
)
|
|
||||||
AS
|
|
||||||
$$
|
|
||||||
SELECT *
|
|
||||||
FROM (
|
|
||||||
SELECT
|
|
||||||
-- etldoc: osm_continent_point -> layer_place:z0_3
|
|
||||||
osm_id * 10 AS osm_id,
|
|
||||||
geometry,
|
|
||||||
name,
|
|
||||||
COALESCE(NULLIF(name_en, ''), name) AS name_en,
|
|
||||||
COALESCE(NULLIF(name_de, ''), name, name_en) AS name_de,
|
|
||||||
tags,
|
|
||||||
'continent' AS class,
|
|
||||||
1 AS "rank",
|
|
||||||
NULL::int AS capital,
|
|
||||||
NULL::text AS iso_a2
|
|
||||||
FROM osm_continent_point
|
|
||||||
WHERE geometry && bbox
|
|
||||||
AND zoom_level < 4
|
|
||||||
|
|
||||||
UNION ALL
|
|
||||||
|
|
||||||
SELECT
|
|
||||||
-- etldoc: osm_country_point -> layer_place:z0_3
|
|
||||||
-- etldoc: osm_country_point -> layer_place:z4_7
|
|
||||||
-- etldoc: osm_country_point -> layer_place:z8_11
|
|
||||||
-- etldoc: osm_country_point -> layer_place:z12_14
|
|
||||||
osm_id * 10 AS osm_id,
|
|
||||||
geometry,
|
|
||||||
name,
|
|
||||||
COALESCE(NULLIF(name_en, ''), name) AS name_en,
|
|
||||||
COALESCE(NULLIF(name_de, ''), name, name_en) AS name_de,
|
|
||||||
tags,
|
|
||||||
'country' AS class,
|
|
||||||
"rank",
|
|
||||||
NULL::int AS capital,
|
|
||||||
iso3166_1_alpha_2 AS iso_a2
|
|
||||||
FROM osm_country_point
|
|
||||||
WHERE geometry && bbox
|
|
||||||
AND "rank" <= zoom_level + 1
|
|
||||||
AND name <> ''
|
|
||||||
|
|
||||||
UNION ALL
|
|
||||||
|
|
||||||
SELECT
|
|
||||||
-- etldoc: osm_state_point -> layer_place:z0_3
|
|
||||||
-- etldoc: osm_state_point -> layer_place:z4_7
|
|
||||||
-- etldoc: osm_state_point -> layer_place:z8_11
|
|
||||||
-- etldoc: osm_state_point -> layer_place:z12_14
|
|
||||||
osm_id * 10 AS osm_id,
|
|
||||||
geometry,
|
|
||||||
name,
|
|
||||||
COALESCE(NULLIF(name_en, ''), name) AS name_en,
|
|
||||||
COALESCE(NULLIF(name_de, ''), name, name_en) AS name_de,
|
|
||||||
tags,
|
|
||||||
'state' AS class,
|
|
||||||
"rank",
|
|
||||||
NULL::int AS capital,
|
|
||||||
NULL::text AS iso_a2
|
|
||||||
FROM osm_state_point
|
|
||||||
WHERE geometry && bbox
|
|
||||||
AND name <> ''
|
|
||||||
AND zoom_level > 1
|
|
||||||
|
|
||||||
UNION ALL
|
|
||||||
|
|
||||||
SELECT
|
|
||||||
-- etldoc: osm_island_point -> layer_place:z12_14
|
|
||||||
osm_id * 10 AS osm_id,
|
|
||||||
geometry,
|
|
||||||
name,
|
|
||||||
COALESCE(NULLIF(name_en, ''), name) AS name_en,
|
|
||||||
COALESCE(NULLIF(name_de, ''), name, name_en) AS name_de,
|
|
||||||
tags,
|
|
||||||
'island' AS class,
|
|
||||||
7 AS "rank",
|
|
||||||
NULL::int AS capital,
|
|
||||||
NULL::text AS iso_a2
|
|
||||||
FROM osm_island_point
|
|
||||||
WHERE zoom_level >= 12
|
|
||||||
AND geometry && bbox
|
|
||||||
|
|
||||||
UNION ALL
|
|
||||||
|
|
||||||
SELECT
|
|
||||||
-- etldoc: osm_island_polygon -> layer_place:z8_11
|
|
||||||
-- etldoc: osm_island_polygon -> layer_place:z12_14
|
|
||||||
osm_id * 10 AS osm_id,
|
|
||||||
geometry,
|
|
||||||
name,
|
|
||||||
COALESCE(NULLIF(name_en, ''), name) AS name_en,
|
|
||||||
COALESCE(NULLIF(name_de, ''), name, name_en) AS name_de,
|
|
||||||
tags,
|
|
||||||
'island' AS class,
|
|
||||||
island_rank(area) AS "rank",
|
|
||||||
NULL::int AS capital,
|
|
||||||
NULL::text AS iso_a2
|
|
||||||
FROM osm_island_polygon
|
|
||||||
WHERE geometry && bbox
|
|
||||||
AND ((zoom_level = 8 AND island_rank(area) <= 3)
|
|
||||||
OR (zoom_level = 9 AND island_rank(area) <= 4)
|
|
||||||
OR (zoom_level >= 10))
|
|
||||||
|
|
||||||
UNION ALL
|
|
||||||
|
|
||||||
SELECT
|
|
||||||
-- etldoc: layer_city -> layer_place:z0_3
|
|
||||||
-- etldoc: layer_city -> layer_place:z4_7
|
|
||||||
-- etldoc: layer_city -> layer_place:z8_11
|
|
||||||
-- etldoc: layer_city -> layer_place:z12_14
|
|
||||||
osm_id * 10 AS osm_id,
|
|
||||||
geometry,
|
|
||||||
name,
|
|
||||||
name_en,
|
|
||||||
name_de,
|
|
||||||
tags,
|
|
||||||
place::text AS class,
|
|
||||||
"rank",
|
|
||||||
capital,
|
|
||||||
NULL::text AS iso_a2
|
|
||||||
FROM layer_city(bbox, zoom_level, pixel_width)
|
|
||||||
ORDER BY "rank" ASC
|
|
||||||
) AS place_all
|
|
||||||
$$ LANGUAGE SQL STABLE
|
|
||||||
PARALLEL SAFE;
|
|
||||||
-- TODO: Check if the above can be made STRICT -- i.e. if pixel_width could be NULL
|
|
||||||
@ -32,12 +32,11 @@ layer:
|
|||||||
- village
|
- village
|
||||||
- hamlet
|
- hamlet
|
||||||
- suburb
|
- suburb
|
||||||
- quarter
|
|
||||||
- neighbourhood
|
- neighbourhood
|
||||||
- isolated_dwelling
|
- isolated_dwelling
|
||||||
iso_a2:
|
iso_a2:
|
||||||
description: |
|
description: |
|
||||||
Two-letter country code [ISO 3166-1 alpha-2](https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2). Available only for `class=country`.
|
Two-letter country code [ISO 3166-1 alpha-2](https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2).
|
||||||
Original value of the
|
Original value of the
|
||||||
[`country_code_iso3166_1_alpha_2`](http://wiki.openstreetmap.org/wiki/Tag:place%3Dcountry) tag.
|
[`country_code_iso3166_1_alpha_2`](http://wiki.openstreetmap.org/wiki/Tag:place%3Dcountry) tag.
|
||||||
rank:
|
rank:
|
||||||
@ -73,7 +72,7 @@ schema:
|
|||||||
- ./update_island_point.sql
|
- ./update_island_point.sql
|
||||||
- ./update_state_point.sql
|
- ./update_state_point.sql
|
||||||
- ./update_city_point.sql
|
- ./update_city_point.sql
|
||||||
- ./place.sql
|
- ./layer.sql
|
||||||
datasources:
|
datasources:
|
||||||
- type: imposm3
|
- type: imposm3
|
||||||
mapping_file: ./mapping.yaml
|
mapping_file: ./mapping.yaml
|
||||||
|
|||||||
@ -1,11 +1,9 @@
|
|||||||
DO
|
DO $$
|
||||||
$$
|
BEGIN
|
||||||
BEGIN
|
IF NOT EXISTS (SELECT 1 FROM pg_type WHERE typname = 'city_place') THEN
|
||||||
IF NOT EXISTS(SELECT 1 FROM pg_type WHERE typname = 'city_place') THEN
|
CREATE TYPE city_place AS ENUM ('city', 'town', 'village', 'hamlet', 'suburb', 'neighbourhood', 'isolated_dwelling');
|
||||||
CREATE TYPE city_place AS enum ('city', 'town', 'village', 'hamlet', 'suburb', 'quarter', 'neighbourhood', 'isolated_dwelling');
|
END IF;
|
||||||
END IF;
|
END
|
||||||
END
|
|
||||||
$$;
|
$$;
|
||||||
|
|
||||||
ALTER TABLE osm_city_point
|
ALTER TABLE osm_city_point ALTER COLUMN place TYPE city_place USING place::city_place;
|
||||||
ALTER COLUMN place TYPE city_place USING place::city_place;
|
|
||||||
|
|||||||
@ -1,116 +1,87 @@
|
|||||||
DROP TRIGGER IF EXISTS trigger_flag ON osm_city_point;
|
DROP TRIGGER IF EXISTS trigger_flag ON osm_city_point;
|
||||||
DROP TRIGGER IF EXISTS trigger_store ON osm_city_point;
|
|
||||||
DROP TRIGGER IF EXISTS trigger_refresh ON place_city.updates;
|
DROP TRIGGER IF EXISTS trigger_refresh ON place_city.updates;
|
||||||
|
|
||||||
CREATE EXTENSION IF NOT EXISTS unaccent;
|
CREATE EXTENSION IF NOT EXISTS unaccent;
|
||||||
|
|
||||||
CREATE SCHEMA IF NOT EXISTS place_city;
|
CREATE OR REPLACE FUNCTION update_osm_city_point() RETURNS VOID AS $$
|
||||||
|
BEGIN
|
||||||
|
|
||||||
CREATE TABLE IF NOT EXISTS place_city.osm_ids
|
-- Clear OSM key:rank ( https://github.com/openmaptiles/openmaptiles/issues/108 )
|
||||||
(
|
-- etldoc: osm_city_point -> osm_city_point
|
||||||
osm_id bigint
|
UPDATE osm_city_point AS osm SET "rank" = NULL WHERE "rank" IS NOT NULL;
|
||||||
);
|
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION update_osm_city_point(full_update boolean) RETURNS void AS
|
-- etldoc: ne_10m_populated_places -> osm_city_point
|
||||||
$$
|
-- etldoc: osm_city_point -> osm_city_point
|
||||||
-- etldoc: ne_10m_populated_places -> osm_city_point
|
|
||||||
-- etldoc: osm_city_point -> osm_city_point
|
|
||||||
|
|
||||||
WITH important_city_point AS (
|
WITH important_city_point AS (
|
||||||
SELECT osm.osm_id, ne.scalerank
|
SELECT osm.geometry, osm.osm_id, osm.name, osm.name_en, ne.scalerank, ne.labelrank
|
||||||
FROM osm_city_point AS osm
|
FROM ne_10m_populated_places AS ne, osm_city_point AS osm
|
||||||
-- Clear OSM key:rank ( https://github.com/openmaptiles/openmaptiles/issues/108 )
|
WHERE
|
||||||
LEFT JOIN ne_10m_populated_places AS ne ON
|
(
|
||||||
(
|
(osm.tags ? 'wikidata' AND osm.tags->'wikidata' = ne.wikidataid) OR
|
||||||
(osm.tags ? 'wikidata' AND osm.tags->'wikidata' = ne.wikidataid) OR
|
ne.name ILIKE osm.name OR
|
||||||
lower(osm.name) IN (lower(ne.name), lower(ne.namealt), lower(ne.meganame), lower(ne.gn_ascii), lower(ne.nameascii)) OR
|
ne.name ILIKE osm.name_en OR
|
||||||
lower(osm.name_en) IN (lower(ne.name), lower(ne.namealt), lower(ne.meganame), lower(ne.gn_ascii), lower(ne.nameascii)) OR
|
ne.namealt ILIKE osm.name OR
|
||||||
ne.name = unaccent(osm.name)
|
ne.namealt ILIKE osm.name_en OR
|
||||||
)
|
ne.meganame ILIKE osm.name OR
|
||||||
AND osm.place IN ('city', 'town', 'village')
|
ne.meganame ILIKE osm.name_en OR
|
||||||
AND ST_DWithin(ne.geometry, osm.geometry, 50000)
|
ne.gn_ascii ILIKE osm.name OR
|
||||||
)
|
ne.gn_ascii ILIKE osm.name_en OR
|
||||||
UPDATE osm_city_point AS osm
|
ne.nameascii ILIKE osm.name OR
|
||||||
-- Move scalerank to range 1 to 10 and merge scalerank 5 with 6 since not enough cities
|
ne.nameascii ILIKE osm.name_en OR
|
||||||
-- are in the scalerank 5 bucket
|
ne.name = unaccent(osm.name)
|
||||||
SET "rank" = CASE WHEN scalerank <= 5 THEN scalerank + 1 ELSE scalerank END
|
)
|
||||||
FROM important_city_point AS ne
|
AND osm.place IN ('city', 'town', 'village')
|
||||||
WHERE (full_update OR osm.osm_id IN (SELECT osm_id FROM place_city.osm_ids))
|
AND ST_DWithin(ne.geometry, osm.geometry, 50000)
|
||||||
AND rank IS DISTINCT FROM CASE WHEN scalerank <= 5 THEN scalerank + 1 ELSE scalerank END
|
)
|
||||||
AND osm.osm_id = ne.osm_id;
|
UPDATE osm_city_point AS osm
|
||||||
|
-- Move scalerank to range 1 to 10 and merge scalerank 5 with 6 since not enough cities
|
||||||
|
-- are in the scalerank 5 bucket
|
||||||
|
SET "rank" = CASE WHEN scalerank <= 5 THEN scalerank + 1 ELSE scalerank END
|
||||||
|
FROM important_city_point AS ne
|
||||||
|
WHERE osm.osm_id = ne.osm_id;
|
||||||
|
|
||||||
UPDATE osm_city_point
|
UPDATE osm_city_point
|
||||||
SET tags = update_tags(tags, geometry)
|
SET tags = update_tags(tags, geometry)
|
||||||
WHERE (full_update OR osm_id IN (SELECT osm_id FROM place_city.osm_ids))
|
WHERE COALESCE(tags->'name:latin', tags->'name:nonlatin', tags->'name_int') IS NULL;
|
||||||
AND COALESCE(tags->'name:latin', tags->'name:nonlatin', tags->'name_int') IS NULL
|
|
||||||
AND tags != update_tags(tags, geometry);
|
|
||||||
|
|
||||||
$$ LANGUAGE SQL;
|
END;
|
||||||
|
$$ LANGUAGE plpgsql;
|
||||||
|
|
||||||
SELECT update_osm_city_point(true);
|
SELECT update_osm_city_point();
|
||||||
|
|
||||||
CREATE INDEX IF NOT EXISTS osm_city_point_rank_idx ON osm_city_point ("rank");
|
CREATE INDEX IF NOT EXISTS osm_city_point_rank_idx ON osm_city_point("rank");
|
||||||
|
|
||||||
-- Handle updates
|
-- Handle updates
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION place_city.store() RETURNS trigger AS
|
CREATE SCHEMA IF NOT EXISTS place_city;
|
||||||
$$
|
|
||||||
BEGIN
|
|
||||||
IF (tg_op = 'DELETE') THEN
|
|
||||||
INSERT INTO place_city.osm_ids VALUES (OLD.osm_id);
|
|
||||||
ELSE
|
|
||||||
INSERT INTO place_city.osm_ids VALUES (NEW.osm_id);
|
|
||||||
END IF;
|
|
||||||
RETURN NULL;
|
|
||||||
END;
|
|
||||||
$$ LANGUAGE plpgsql;
|
|
||||||
|
|
||||||
CREATE TABLE IF NOT EXISTS place_city.updates
|
CREATE TABLE IF NOT EXISTS place_city.updates(id serial primary key, t text, unique (t));
|
||||||
(
|
CREATE OR REPLACE FUNCTION place_city.flag() RETURNS trigger AS $$
|
||||||
id serial PRIMARY KEY,
|
|
||||||
t text,
|
|
||||||
UNIQUE (t)
|
|
||||||
);
|
|
||||||
CREATE OR REPLACE FUNCTION place_city.flag() RETURNS trigger AS
|
|
||||||
$$
|
|
||||||
BEGIN
|
BEGIN
|
||||||
INSERT INTO place_city.updates(t) VALUES ('y') ON CONFLICT(t) DO NOTHING;
|
INSERT INTO place_city.updates(t) VALUES ('y') ON CONFLICT(t) DO NOTHING;
|
||||||
RETURN NULL;
|
RETURN null;
|
||||||
END;
|
END;
|
||||||
$$ LANGUAGE plpgsql;
|
$$ language plpgsql;
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION place_city.refresh() RETURNS trigger AS
|
CREATE OR REPLACE FUNCTION place_city.refresh() RETURNS trigger AS
|
||||||
$$
|
$BODY$
|
||||||
DECLARE
|
BEGIN
|
||||||
t TIMESTAMP WITH TIME ZONE := clock_timestamp();
|
|
||||||
BEGIN
|
|
||||||
RAISE LOG 'Refresh place_city rank';
|
RAISE LOG 'Refresh place_city rank';
|
||||||
PERFORM update_osm_city_point(false);
|
PERFORM update_osm_city_point();
|
||||||
-- noinspection SqlWithoutWhere
|
|
||||||
DELETE FROM place_city.osm_ids;
|
|
||||||
-- noinspection SqlWithoutWhere
|
|
||||||
DELETE FROM place_city.updates;
|
DELETE FROM place_city.updates;
|
||||||
|
RETURN null;
|
||||||
RAISE LOG 'Refresh place_city done in %', age(clock_timestamp(), t);
|
END;
|
||||||
RETURN NULL;
|
$BODY$
|
||||||
END;
|
language plpgsql;
|
||||||
$$ LANGUAGE plpgsql;
|
|
||||||
|
|
||||||
CREATE TRIGGER trigger_store
|
|
||||||
AFTER INSERT OR UPDATE OR DELETE
|
|
||||||
ON osm_city_point
|
|
||||||
FOR EACH ROW
|
|
||||||
EXECUTE PROCEDURE place_city.store();
|
|
||||||
|
|
||||||
CREATE TRIGGER trigger_flag
|
CREATE TRIGGER trigger_flag
|
||||||
AFTER INSERT OR UPDATE OR DELETE
|
AFTER INSERT OR UPDATE OR DELETE ON osm_city_point
|
||||||
ON osm_city_point
|
|
||||||
FOR EACH STATEMENT
|
FOR EACH STATEMENT
|
||||||
EXECUTE PROCEDURE place_city.flag();
|
EXECUTE PROCEDURE place_city.flag();
|
||||||
|
|
||||||
CREATE CONSTRAINT TRIGGER trigger_refresh
|
CREATE CONSTRAINT TRIGGER trigger_refresh
|
||||||
AFTER INSERT
|
AFTER INSERT ON place_city.updates
|
||||||
ON place_city.updates
|
|
||||||
INITIALLY DEFERRED
|
INITIALLY DEFERRED
|
||||||
FOR EACH ROW
|
FOR EACH ROW
|
||||||
EXECUTE PROCEDURE place_city.refresh();
|
EXECUTE PROCEDURE place_city.refresh();
|
||||||
@ -1,86 +1,48 @@
|
|||||||
DROP TRIGGER IF EXISTS trigger_flag ON osm_continent_point;
|
DROP TRIGGER IF EXISTS trigger_flag ON osm_continent_point;
|
||||||
DROP TRIGGER IF EXISTS trigger_store ON osm_continent_point;
|
|
||||||
DROP TRIGGER IF EXISTS trigger_refresh ON place_continent_point.updates;
|
DROP TRIGGER IF EXISTS trigger_refresh ON place_continent_point.updates;
|
||||||
|
|
||||||
CREATE SCHEMA IF NOT EXISTS place_continent_point;
|
|
||||||
|
|
||||||
CREATE TABLE IF NOT EXISTS place_continent_point.osm_ids
|
|
||||||
(
|
|
||||||
osm_id bigint
|
|
||||||
);
|
|
||||||
|
|
||||||
-- etldoc: osm_continent_point -> osm_continent_point
|
-- etldoc: osm_continent_point -> osm_continent_point
|
||||||
CREATE OR REPLACE FUNCTION update_osm_continent_point(full_update boolean) RETURNS void AS
|
CREATE OR REPLACE FUNCTION update_osm_continent_point() RETURNS VOID AS $$
|
||||||
$$
|
BEGIN
|
||||||
UPDATE osm_continent_point
|
UPDATE osm_continent_point
|
||||||
SET tags = update_tags(tags, geometry)
|
SET tags = update_tags(tags, geometry)
|
||||||
WHERE (full_update OR osm_id IN (SELECT osm_id FROM place_continent_point.osm_ids))
|
WHERE COALESCE(tags->'name:latin', tags->'name:nonlatin', tags->'name_int') IS NULL;
|
||||||
AND COALESCE(tags->'name:latin', tags->'name:nonlatin', tags->'name_int') IS NULL
|
|
||||||
AND tags != update_tags(tags, geometry);
|
|
||||||
$$ LANGUAGE SQL;
|
|
||||||
|
|
||||||
SELECT update_osm_continent_point(true);
|
END;
|
||||||
|
$$ LANGUAGE plpgsql;
|
||||||
|
|
||||||
|
SELECT update_osm_continent_point();
|
||||||
|
|
||||||
-- Handle updates
|
-- Handle updates
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION place_continent_point.store() RETURNS trigger AS
|
CREATE SCHEMA IF NOT EXISTS place_continent_point;
|
||||||
$$
|
|
||||||
BEGIN
|
|
||||||
IF (tg_op = 'DELETE') THEN
|
|
||||||
INSERT INTO place_continent_point.osm_ids VALUES (OLD.osm_id);
|
|
||||||
ELSE
|
|
||||||
INSERT INTO place_continent_point.osm_ids VALUES (NEW.osm_id);
|
|
||||||
END IF;
|
|
||||||
RETURN NULL;
|
|
||||||
END;
|
|
||||||
$$ LANGUAGE plpgsql;
|
|
||||||
|
|
||||||
CREATE TABLE IF NOT EXISTS place_continent_point.updates
|
CREATE TABLE IF NOT EXISTS place_continent_point.updates(id serial primary key, t text, unique (t));
|
||||||
(
|
CREATE OR REPLACE FUNCTION place_continent_point.flag() RETURNS trigger AS $$
|
||||||
id serial PRIMARY KEY,
|
|
||||||
t text,
|
|
||||||
UNIQUE (t)
|
|
||||||
);
|
|
||||||
CREATE OR REPLACE FUNCTION place_continent_point.flag() RETURNS trigger AS
|
|
||||||
$$
|
|
||||||
BEGIN
|
BEGIN
|
||||||
INSERT INTO place_continent_point.updates(t) VALUES ('y') ON CONFLICT(t) DO NOTHING;
|
INSERT INTO place_continent_point.updates(t) VALUES ('y') ON CONFLICT(t) DO NOTHING;
|
||||||
RETURN NULL;
|
RETURN null;
|
||||||
END;
|
END;
|
||||||
$$ LANGUAGE plpgsql;
|
$$ language plpgsql;
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION place_continent_point.refresh() RETURNS trigger AS
|
CREATE OR REPLACE FUNCTION place_continent_point.refresh() RETURNS trigger AS
|
||||||
$$
|
$BODY$
|
||||||
DECLARE
|
BEGIN
|
||||||
t TIMESTAMP WITH TIME ZONE := clock_timestamp();
|
|
||||||
BEGIN
|
|
||||||
RAISE LOG 'Refresh place_continent_point';
|
RAISE LOG 'Refresh place_continent_point';
|
||||||
PERFORM update_osm_continent_point(false);
|
PERFORM update_osm_continent_point();
|
||||||
-- noinspection SqlWithoutWhere
|
|
||||||
DELETE FROM place_continent_point.osm_ids;
|
|
||||||
-- noinspection SqlWithoutWhere
|
|
||||||
DELETE FROM place_continent_point.updates;
|
DELETE FROM place_continent_point.updates;
|
||||||
|
RETURN null;
|
||||||
RAISE LOG 'Refresh place_continent_point done in %', age(clock_timestamp(), t);
|
END;
|
||||||
RETURN NULL;
|
$BODY$
|
||||||
END;
|
language plpgsql;
|
||||||
$$ LANGUAGE plpgsql;
|
|
||||||
|
|
||||||
CREATE TRIGGER trigger_store
|
|
||||||
AFTER INSERT OR UPDATE OR DELETE
|
|
||||||
ON osm_continent_point
|
|
||||||
FOR EACH ROW
|
|
||||||
EXECUTE PROCEDURE place_continent_point.store();
|
|
||||||
|
|
||||||
CREATE TRIGGER trigger_flag
|
CREATE TRIGGER trigger_flag
|
||||||
AFTER INSERT OR UPDATE OR DELETE
|
AFTER INSERT OR UPDATE OR DELETE ON osm_continent_point
|
||||||
ON osm_continent_point
|
|
||||||
FOR EACH STATEMENT
|
FOR EACH STATEMENT
|
||||||
EXECUTE PROCEDURE place_continent_point.flag();
|
EXECUTE PROCEDURE place_continent_point.flag();
|
||||||
|
|
||||||
CREATE CONSTRAINT TRIGGER trigger_refresh
|
CREATE CONSTRAINT TRIGGER trigger_refresh
|
||||||
AFTER INSERT
|
AFTER INSERT ON place_continent_point.updates
|
||||||
ON place_continent_point.updates
|
|
||||||
INITIALLY DEFERRED
|
INITIALLY DEFERRED
|
||||||
FOR EACH ROW
|
FOR EACH ROW
|
||||||
EXECUTE PROCEDURE place_continent_point.refresh();
|
EXECUTE PROCEDURE place_continent_point.refresh();
|
||||||
|
|||||||
@ -1,165 +1,119 @@
|
|||||||
DROP TRIGGER IF EXISTS trigger_flag ON osm_country_point;
|
DROP TRIGGER IF EXISTS trigger_flag ON osm_country_point;
|
||||||
DROP TRIGGER IF EXISTS trigger_store ON osm_country_point;
|
|
||||||
DROP TRIGGER IF EXISTS trigger_refresh ON place_country.updates;
|
DROP TRIGGER IF EXISTS trigger_refresh ON place_country.updates;
|
||||||
|
|
||||||
CREATE SCHEMA IF NOT EXISTS place_country;
|
ALTER TABLE osm_country_point DROP CONSTRAINT IF EXISTS osm_country_point_rank_constraint;
|
||||||
|
|
||||||
CREATE TABLE IF NOT EXISTS place_country.osm_ids
|
|
||||||
(
|
|
||||||
osm_id bigint
|
|
||||||
);
|
|
||||||
|
|
||||||
-- etldoc: ne_10m_admin_0_countries -> osm_country_point
|
-- etldoc: ne_10m_admin_0_countries -> osm_country_point
|
||||||
-- etldoc: osm_country_point -> osm_country_point
|
-- etldoc: osm_country_point -> osm_country_point
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION update_osm_country_point(full_update boolean) RETURNS void AS
|
CREATE OR REPLACE FUNCTION update_osm_country_point() RETURNS VOID AS $$
|
||||||
$$
|
BEGIN
|
||||||
UPDATE osm_country_point AS osm
|
|
||||||
SET "rank" = 7,
|
|
||||||
iso3166_1_alpha_2 = COALESCE(
|
|
||||||
NULLIF(osm.country_code_iso3166_1_alpha_2, ''),
|
|
||||||
NULLIF(osm.iso3166_1_alpha_2, ''),
|
|
||||||
NULLIF(osm.iso3166_1, '')
|
|
||||||
)
|
|
||||||
WHERE (full_update OR osm_id IN (SELECT osm_id FROM place_country.osm_ids))
|
|
||||||
AND rank IS NULL;
|
|
||||||
|
|
||||||
WITH important_country_point AS (
|
UPDATE osm_country_point AS osm
|
||||||
SELECT osm.geometry,
|
SET
|
||||||
osm.osm_id,
|
"rank" = 7,
|
||||||
osm.name,
|
iso3166_1_alpha_2 = COALESCE(
|
||||||
COALESCE(NULLIF(osm.name_en, ''), ne.name) AS name_en,
|
NULLIF(osm.country_code_iso3166_1_alpha_2, ''),
|
||||||
ne.scalerank,
|
NULLIF(osm.iso3166_1_alpha_2, ''),
|
||||||
ne.labelrank
|
NULLIF(osm.iso3166_1, '')
|
||||||
FROM ne_10m_admin_0_countries AS ne,
|
|
||||||
osm_country_point AS osm
|
|
||||||
WHERE
|
|
||||||
-- We match only countries with ISO codes to eliminate disputed countries
|
|
||||||
iso3166_1_alpha_2 IS NOT NULL
|
|
||||||
-- that lies inside polygon of sovereign country
|
|
||||||
AND ST_Within(osm.geometry, ne.geometry)
|
|
||||||
)
|
)
|
||||||
UPDATE osm_country_point AS osm
|
;
|
||||||
-- Normalize both scalerank and labelrank into a ranking system from 1 to 6
|
|
||||||
-- where the ranks are still distributed uniform enough across all countries
|
|
||||||
SET "rank" = LEAST(6, CEILING((scalerank + labelrank) / 2.0))
|
|
||||||
FROM important_country_point AS ne
|
|
||||||
WHERE (full_update OR osm.osm_id IN (SELECT osm_id FROM place_country.osm_ids))
|
|
||||||
AND rank = 7
|
|
||||||
AND osm.osm_id = ne.osm_id;
|
|
||||||
|
|
||||||
-- Repeat the step for archipelago countries like Philippines or Indonesia
|
WITH important_country_point AS (
|
||||||
-- whose label point is not within country's polygon
|
SELECT osm.geometry, osm.osm_id, osm.name, COALESCE(NULLIF(osm.name_en, ''), ne.name) AS name_en, ne.scalerank, ne.labelrank
|
||||||
WITH important_country_point AS (
|
FROM ne_10m_admin_0_countries AS ne, osm_country_point AS osm
|
||||||
SELECT osm.osm_id,
|
WHERE
|
||||||
|
-- We match only countries with ISO codes to eliminate disputed countries
|
||||||
|
iso3166_1_alpha_2 IS NOT NULL
|
||||||
|
-- that lies inside polygon of sovereign country
|
||||||
|
AND ST_Within(osm.geometry, ne.geometry)
|
||||||
|
)
|
||||||
|
UPDATE osm_country_point AS osm
|
||||||
|
-- Normalize both scalerank and labelrank into a ranking system from 1 to 6
|
||||||
|
-- where the ranks are still distributed uniform enough across all countries
|
||||||
|
SET "rank" = LEAST(6, CEILING((scalerank + labelrank)/2.0))
|
||||||
|
FROM important_country_point AS ne
|
||||||
|
WHERE osm.osm_id = ne.osm_id;
|
||||||
|
|
||||||
|
-- Repeat the step for archipelago countries like Philippines or Indonesia
|
||||||
|
-- whose label point is not within country's polygon
|
||||||
|
WITH important_country_point AS (
|
||||||
|
SELECT
|
||||||
|
osm.osm_id,
|
||||||
-- osm.name,
|
-- osm.name,
|
||||||
ne.scalerank,
|
ne.scalerank,
|
||||||
ne.labelrank,
|
ne.labelrank,
|
||||||
-- ST_Distance(osm.geometry, ne.geometry) AS distance,
|
-- ST_Distance(osm.geometry, ne.geometry) AS distance,
|
||||||
ROW_NUMBER()
|
ROW_NUMBER()
|
||||||
OVER (
|
OVER (
|
||||||
PARTITION BY osm.osm_id
|
PARTITION BY osm.osm_id
|
||||||
ORDER BY
|
ORDER BY
|
||||||
ST_Distance(osm.geometry, ne.geometry)
|
ST_Distance(osm.geometry, ne.geometry)
|
||||||
) AS rk
|
) AS rk
|
||||||
FROM osm_country_point osm,
|
FROM osm_country_point osm,
|
||||||
ne_10m_admin_0_countries AS ne
|
ne_10m_admin_0_countries AS ne
|
||||||
WHERE iso3166_1_alpha_2 IS NOT NULL
|
WHERE
|
||||||
AND NOT (osm."rank" BETWEEN 1 AND 6)
|
iso3166_1_alpha_2 IS NOT NULL
|
||||||
)
|
AND NOT (osm."rank" BETWEEN 1 AND 6)
|
||||||
UPDATE osm_country_point AS osm
|
)
|
||||||
-- Normalize both scalerank and labelrank into a ranking system from 1 to 6
|
UPDATE osm_country_point AS osm
|
||||||
-- where the ranks are still distributed uniform enough across all countries
|
-- Normalize both scalerank and labelrank into a ranking system from 1 to 6
|
||||||
SET "rank" = LEAST(6, CEILING((ne.scalerank + ne.labelrank) / 2.0))
|
-- where the ranks are still distributed uniform enough across all countries
|
||||||
FROM important_country_point AS ne
|
SET "rank" = LEAST(6, CEILING((ne.scalerank + ne.labelrank)/2.0))
|
||||||
WHERE (full_update OR osm.osm_id IN (SELECT osm_id FROM place_country.osm_ids))
|
FROM important_country_point AS ne
|
||||||
AND rank = 7
|
WHERE osm.osm_id = ne.osm_id AND ne.rk = 1;
|
||||||
AND osm.osm_id = ne.osm_id
|
|
||||||
AND ne.rk = 1;
|
|
||||||
|
|
||||||
UPDATE osm_country_point AS osm
|
UPDATE osm_country_point AS osm
|
||||||
SET "rank" = 6
|
SET "rank" = 6
|
||||||
WHERE (full_update OR osm_id IN (SELECT osm_id FROM place_country.osm_ids))
|
WHERE "rank" = 7;
|
||||||
AND "rank" = 7;
|
|
||||||
|
|
||||||
-- TODO: This shouldn't be necessary? The rank function makes something wrong...
|
-- TODO: This shouldn't be necessary? The rank function makes something wrong...
|
||||||
UPDATE osm_country_point AS osm
|
UPDATE osm_country_point AS osm
|
||||||
SET "rank" = 1
|
SET "rank" = 1
|
||||||
WHERE (full_update OR osm_id IN (SELECT osm_id FROM place_country.osm_ids))
|
WHERE "rank" = 0;
|
||||||
AND "rank" = 0;
|
|
||||||
|
|
||||||
UPDATE osm_country_point
|
UPDATE osm_country_point
|
||||||
SET tags = update_tags(tags, geometry)
|
SET tags = update_tags(tags, geometry)
|
||||||
WHERE (full_update OR osm_id IN (SELECT osm_id FROM place_country.osm_ids))
|
WHERE COALESCE(tags->'name:latin', tags->'name:nonlatin', tags->'name_int') IS NULL;
|
||||||
AND COALESCE(tags->'name:latin', tags->'name:nonlatin', tags->'name_int') IS NULL
|
|
||||||
AND tags != update_tags(tags, geometry);
|
|
||||||
|
|
||||||
$$ LANGUAGE SQL;
|
END;
|
||||||
|
$$ LANGUAGE plpgsql;
|
||||||
|
|
||||||
SELECT update_osm_country_point(true);
|
SELECT update_osm_country_point();
|
||||||
|
|
||||||
CREATE INDEX IF NOT EXISTS osm_country_point_rank_idx ON osm_country_point ("rank");
|
-- ALTER TABLE osm_country_point ADD CONSTRAINT osm_country_point_rank_constraint CHECK("rank" BETWEEN 1 AND 6);
|
||||||
|
CREATE INDEX IF NOT EXISTS osm_country_point_rank_idx ON osm_country_point("rank");
|
||||||
|
|
||||||
-- Handle updates
|
-- Handle updates
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION place_country.store() RETURNS trigger AS
|
CREATE SCHEMA IF NOT EXISTS place_country;
|
||||||
$$
|
|
||||||
BEGIN
|
|
||||||
IF (tg_op = 'DELETE') THEN
|
|
||||||
INSERT INTO place_country.osm_ids VALUES (OLD.osm_id);
|
|
||||||
ELSE
|
|
||||||
INSERT INTO place_country.osm_ids VALUES (NEW.osm_id);
|
|
||||||
END IF;
|
|
||||||
RETURN NULL;
|
|
||||||
END;
|
|
||||||
$$ LANGUAGE plpgsql;
|
|
||||||
|
|
||||||
CREATE TABLE IF NOT EXISTS place_country.updates
|
CREATE TABLE IF NOT EXISTS place_country.updates(id serial primary key, t text, unique (t));
|
||||||
(
|
CREATE OR REPLACE FUNCTION place_country.flag() RETURNS trigger AS $$
|
||||||
id serial PRIMARY KEY,
|
|
||||||
t text,
|
|
||||||
UNIQUE (t)
|
|
||||||
);
|
|
||||||
CREATE OR REPLACE FUNCTION place_country.flag() RETURNS trigger AS
|
|
||||||
$$
|
|
||||||
BEGIN
|
BEGIN
|
||||||
INSERT INTO place_country.updates(t) VALUES ('y') ON CONFLICT(t) DO NOTHING;
|
INSERT INTO place_country.updates(t) VALUES ('y') ON CONFLICT(t) DO NOTHING;
|
||||||
RETURN NULL;
|
RETURN null;
|
||||||
END;
|
END;
|
||||||
$$ LANGUAGE plpgsql;
|
$$ language plpgsql;
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION place_country.refresh() RETURNS trigger AS
|
CREATE OR REPLACE FUNCTION place_country.refresh() RETURNS trigger AS
|
||||||
$$
|
$BODY$
|
||||||
DECLARE
|
BEGIN
|
||||||
t TIMESTAMP WITH TIME ZONE := clock_timestamp();
|
|
||||||
BEGIN
|
|
||||||
RAISE LOG 'Refresh place_country rank';
|
RAISE LOG 'Refresh place_country rank';
|
||||||
PERFORM update_osm_country_point(false);
|
PERFORM update_osm_country_point();
|
||||||
-- noinspection SqlWithoutWhere
|
|
||||||
DELETE FROM place_country.osm_ids;
|
|
||||||
-- noinspection SqlWithoutWhere
|
|
||||||
DELETE FROM place_country.updates;
|
DELETE FROM place_country.updates;
|
||||||
|
RETURN null;
|
||||||
RAISE LOG 'Refresh place_country done in %', age(clock_timestamp(), t);
|
END;
|
||||||
RETURN NULL;
|
$BODY$
|
||||||
END;
|
language plpgsql;
|
||||||
$$ LANGUAGE plpgsql;
|
|
||||||
|
|
||||||
CREATE TRIGGER trigger_store
|
|
||||||
AFTER INSERT OR UPDATE OR DELETE
|
|
||||||
ON osm_country_point
|
|
||||||
FOR EACH ROW
|
|
||||||
EXECUTE PROCEDURE place_country.store();
|
|
||||||
|
|
||||||
CREATE TRIGGER trigger_flag
|
CREATE TRIGGER trigger_flag
|
||||||
AFTER INSERT OR UPDATE OR DELETE
|
AFTER INSERT OR UPDATE OR DELETE ON osm_country_point
|
||||||
ON osm_country_point
|
|
||||||
FOR EACH STATEMENT
|
FOR EACH STATEMENT
|
||||||
EXECUTE PROCEDURE place_country.flag();
|
EXECUTE PROCEDURE place_country.flag();
|
||||||
|
|
||||||
CREATE CONSTRAINT TRIGGER trigger_refresh
|
CREATE CONSTRAINT TRIGGER trigger_refresh
|
||||||
AFTER INSERT
|
AFTER INSERT ON place_country.updates
|
||||||
ON place_country.updates
|
|
||||||
INITIALLY DEFERRED
|
INITIALLY DEFERRED
|
||||||
FOR EACH ROW
|
FOR EACH ROW
|
||||||
EXECUTE PROCEDURE place_country.refresh();
|
EXECUTE PROCEDURE place_country.refresh();
|
||||||
|
|||||||
@ -1,86 +1,48 @@
|
|||||||
DROP TRIGGER IF EXISTS trigger_flag ON osm_island_point;
|
DROP TRIGGER IF EXISTS trigger_flag ON osm_island_point;
|
||||||
DROP TRIGGER IF EXISTS trigger_store ON osm_island_point;
|
|
||||||
DROP TRIGGER IF EXISTS trigger_refresh ON place_island_point.updates;
|
DROP TRIGGER IF EXISTS trigger_refresh ON place_island_point.updates;
|
||||||
|
|
||||||
CREATE SCHEMA IF NOT EXISTS place_island_point;
|
|
||||||
|
|
||||||
CREATE TABLE IF NOT EXISTS place_island_point.osm_ids
|
|
||||||
(
|
|
||||||
osm_id bigint
|
|
||||||
);
|
|
||||||
|
|
||||||
-- etldoc: osm_island_point -> osm_island_point
|
-- etldoc: osm_island_point -> osm_island_point
|
||||||
CREATE OR REPLACE FUNCTION update_osm_island_point(full_update boolean) RETURNS void AS
|
CREATE OR REPLACE FUNCTION update_osm_island_point() RETURNS VOID AS $$
|
||||||
$$
|
BEGIN
|
||||||
UPDATE osm_island_point
|
UPDATE osm_island_point
|
||||||
SET tags = update_tags(tags, geometry)
|
SET tags = update_tags(tags, geometry)
|
||||||
WHERE (full_update OR osm_id IN (SELECT osm_id FROM place_island_point.osm_ids))
|
WHERE COALESCE(tags->'name:latin', tags->'name:nonlatin', tags->'name_int') IS NULL;
|
||||||
AND COALESCE(tags->'name:latin', tags->'name:nonlatin', tags->'name_int') IS NULL
|
|
||||||
AND tags != update_tags(tags, geometry);
|
|
||||||
$$ LANGUAGE SQL;
|
|
||||||
|
|
||||||
SELECT update_osm_island_point(true);
|
END;
|
||||||
|
$$ LANGUAGE plpgsql;
|
||||||
|
|
||||||
|
SELECT update_osm_island_point();
|
||||||
|
|
||||||
-- Handle updates
|
-- Handle updates
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION place_island_point.store() RETURNS trigger AS
|
CREATE SCHEMA IF NOT EXISTS place_island_point;
|
||||||
$$
|
|
||||||
BEGIN
|
|
||||||
IF (tg_op = 'DELETE') THEN
|
|
||||||
INSERT INTO place_island_point.osm_ids VALUES (OLD.osm_id);
|
|
||||||
ELSE
|
|
||||||
INSERT INTO place_island_point.osm_ids VALUES (NEW.osm_id);
|
|
||||||
END IF;
|
|
||||||
RETURN NULL;
|
|
||||||
END;
|
|
||||||
$$ LANGUAGE plpgsql;
|
|
||||||
|
|
||||||
CREATE TABLE IF NOT EXISTS place_island_point.updates
|
CREATE TABLE IF NOT EXISTS place_island_point.updates(id serial primary key, t text, unique (t));
|
||||||
(
|
CREATE OR REPLACE FUNCTION place_island_point.flag() RETURNS trigger AS $$
|
||||||
id serial PRIMARY KEY,
|
|
||||||
t text,
|
|
||||||
UNIQUE (t)
|
|
||||||
);
|
|
||||||
CREATE OR REPLACE FUNCTION place_island_point.flag() RETURNS trigger AS
|
|
||||||
$$
|
|
||||||
BEGIN
|
BEGIN
|
||||||
INSERT INTO place_island_point.updates(t) VALUES ('y') ON CONFLICT(t) DO NOTHING;
|
INSERT INTO place_island_point.updates(t) VALUES ('y') ON CONFLICT(t) DO NOTHING;
|
||||||
RETURN NULL;
|
RETURN null;
|
||||||
END;
|
END;
|
||||||
$$ LANGUAGE plpgsql;
|
$$ language plpgsql;
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION place_island_point.refresh() RETURNS trigger AS
|
CREATE OR REPLACE FUNCTION place_island_point.refresh() RETURNS trigger AS
|
||||||
$$
|
$BODY$
|
||||||
DECLARE
|
BEGIN
|
||||||
t TIMESTAMP WITH TIME ZONE := clock_timestamp();
|
|
||||||
BEGIN
|
|
||||||
RAISE LOG 'Refresh place_island_point';
|
RAISE LOG 'Refresh place_island_point';
|
||||||
PERFORM update_osm_island_point(false);
|
PERFORM update_osm_island_point();
|
||||||
-- noinspection SqlWithoutWhere
|
|
||||||
DELETE FROM place_island_point.osm_ids;
|
|
||||||
-- noinspection SqlWithoutWhere
|
|
||||||
DELETE FROM place_island_point.updates;
|
DELETE FROM place_island_point.updates;
|
||||||
|
RETURN null;
|
||||||
RAISE LOG 'Refresh place_island_point done in %', age(clock_timestamp(), t);
|
END;
|
||||||
RETURN NULL;
|
$BODY$
|
||||||
END;
|
language plpgsql;
|
||||||
$$ LANGUAGE plpgsql;
|
|
||||||
|
|
||||||
CREATE TRIGGER trigger_store
|
|
||||||
AFTER INSERT OR UPDATE OR DELETE
|
|
||||||
ON osm_island_point
|
|
||||||
FOR EACH ROW
|
|
||||||
EXECUTE PROCEDURE place_island_point.store();
|
|
||||||
|
|
||||||
CREATE TRIGGER trigger_flag
|
CREATE TRIGGER trigger_flag
|
||||||
AFTER INSERT OR UPDATE OR DELETE
|
AFTER INSERT OR UPDATE OR DELETE ON osm_island_point
|
||||||
ON osm_island_point
|
|
||||||
FOR EACH STATEMENT
|
FOR EACH STATEMENT
|
||||||
EXECUTE PROCEDURE place_island_point.flag();
|
EXECUTE PROCEDURE place_island_point.flag();
|
||||||
|
|
||||||
CREATE CONSTRAINT TRIGGER trigger_refresh
|
CREATE CONSTRAINT TRIGGER trigger_refresh
|
||||||
AFTER INSERT
|
AFTER INSERT ON place_island_point.updates
|
||||||
ON place_island_point.updates
|
|
||||||
INITIALLY DEFERRED
|
INITIALLY DEFERRED
|
||||||
FOR EACH ROW
|
FOR EACH ROW
|
||||||
EXECUTE PROCEDURE place_island_point.refresh();
|
EXECUTE PROCEDURE place_island_point.refresh();
|
||||||
|
|||||||
@ -1,93 +1,51 @@
|
|||||||
DROP TRIGGER IF EXISTS trigger_flag ON osm_island_polygon;
|
DROP TRIGGER IF EXISTS trigger_flag ON osm_island_polygon;
|
||||||
DROP TRIGGER IF EXISTS trigger_store ON osm_island_polygon;
|
|
||||||
DROP TRIGGER IF EXISTS trigger_refresh ON place_island_polygon.updates;
|
DROP TRIGGER IF EXISTS trigger_refresh ON place_island_polygon.updates;
|
||||||
|
|
||||||
CREATE SCHEMA IF NOT EXISTS place_island_polygon;
|
|
||||||
|
|
||||||
CREATE TABLE IF NOT EXISTS place_island_polygon.osm_ids
|
|
||||||
(
|
|
||||||
osm_id bigint
|
|
||||||
);
|
|
||||||
|
|
||||||
-- etldoc: osm_island_polygon -> osm_island_polygon
|
-- etldoc: osm_island_polygon -> osm_island_polygon
|
||||||
CREATE OR REPLACE FUNCTION update_osm_island_polygon(full_update boolean) RETURNS void AS
|
CREATE OR REPLACE FUNCTION update_osm_island_polygon() RETURNS VOID AS $$
|
||||||
$$
|
BEGIN
|
||||||
UPDATE osm_island_polygon
|
UPDATE osm_island_polygon SET geometry=ST_PointOnSurface(geometry) WHERE ST_GeometryType(geometry) <> 'ST_Point';
|
||||||
SET geometry = ST_PointOnSurface(geometry)
|
|
||||||
WHERE (full_update OR osm_id IN (SELECT osm_id FROM place_island_polygon.osm_ids))
|
|
||||||
AND ST_GeometryType(geometry) <> 'ST_Point'
|
|
||||||
AND ST_IsValid(geometry);
|
|
||||||
|
|
||||||
UPDATE osm_island_polygon
|
UPDATE osm_island_polygon
|
||||||
SET tags = update_tags(tags, geometry)
|
SET tags = update_tags(tags, geometry)
|
||||||
WHERE (full_update OR osm_id IN (SELECT osm_id FROM place_island_polygon.osm_ids))
|
WHERE COALESCE(tags->'name:latin', tags->'name:nonlatin', tags->'name_int') IS NULL;
|
||||||
AND COALESCE(tags->'name:latin', tags->'name:nonlatin', tags->'name_int') IS NULL
|
|
||||||
AND tags != update_tags(tags, geometry);
|
|
||||||
|
|
||||||
$$ LANGUAGE SQL;
|
ANALYZE osm_island_polygon;
|
||||||
|
END;
|
||||||
|
$$ LANGUAGE plpgsql;
|
||||||
|
|
||||||
SELECT update_osm_island_polygon(true);
|
SELECT update_osm_island_polygon();
|
||||||
|
|
||||||
-- Handle updates
|
-- Handle updates
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION place_island_polygon.store() RETURNS trigger AS
|
CREATE SCHEMA IF NOT EXISTS place_island_polygon;
|
||||||
$$
|
|
||||||
BEGIN
|
|
||||||
IF (tg_op = 'DELETE') THEN
|
|
||||||
INSERT INTO place_island_polygon.osm_ids VALUES (OLD.osm_id);
|
|
||||||
ELSE
|
|
||||||
INSERT INTO place_island_polygon.osm_ids VALUES (NEW.osm_id);
|
|
||||||
END IF;
|
|
||||||
RETURN NULL;
|
|
||||||
END;
|
|
||||||
$$ LANGUAGE plpgsql;
|
|
||||||
|
|
||||||
CREATE TABLE IF NOT EXISTS place_island_polygon.updates
|
CREATE TABLE IF NOT EXISTS place_island_polygon.updates(id serial primary key, t text, unique (t));
|
||||||
(
|
CREATE OR REPLACE FUNCTION place_island_polygon.flag() RETURNS trigger AS $$
|
||||||
id serial PRIMARY KEY,
|
|
||||||
t text,
|
|
||||||
UNIQUE (t)
|
|
||||||
);
|
|
||||||
CREATE OR REPLACE FUNCTION place_island_polygon.flag() RETURNS trigger AS
|
|
||||||
$$
|
|
||||||
BEGIN
|
BEGIN
|
||||||
INSERT INTO place_island_polygon.updates(t) VALUES ('y') ON CONFLICT(t) DO NOTHING;
|
INSERT INTO place_island_polygon.updates(t) VALUES ('y') ON CONFLICT(t) DO NOTHING;
|
||||||
RETURN NULL;
|
RETURN null;
|
||||||
END;
|
END;
|
||||||
$$ LANGUAGE plpgsql;
|
$$ language plpgsql;
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION place_island_polygon.refresh() RETURNS trigger AS
|
CREATE OR REPLACE FUNCTION place_island_polygon.refresh() RETURNS trigger AS
|
||||||
$$
|
$BODY$
|
||||||
DECLARE
|
BEGIN
|
||||||
t TIMESTAMP WITH TIME ZONE := clock_timestamp();
|
|
||||||
BEGIN
|
|
||||||
RAISE LOG 'Refresh place_island_polygon';
|
RAISE LOG 'Refresh place_island_polygon';
|
||||||
PERFORM update_osm_island_polygon(false);
|
PERFORM update_osm_island_polygon();
|
||||||
-- noinspection SqlWithoutWhere
|
|
||||||
DELETE FROM place_island_polygon.osm_ids;
|
|
||||||
-- noinspection SqlWithoutWhere
|
|
||||||
DELETE FROM place_island_polygon.updates;
|
DELETE FROM place_island_polygon.updates;
|
||||||
|
RETURN null;
|
||||||
RAISE LOG 'Refresh place_island_polygon done in %', age(clock_timestamp(), t);
|
END;
|
||||||
RETURN NULL;
|
$BODY$
|
||||||
END;
|
language plpgsql;
|
||||||
$$ LANGUAGE plpgsql;
|
|
||||||
|
|
||||||
CREATE TRIGGER trigger_store
|
|
||||||
AFTER INSERT OR UPDATE OR DELETE
|
|
||||||
ON osm_island_polygon
|
|
||||||
FOR EACH ROW
|
|
||||||
EXECUTE PROCEDURE place_island_polygon.store();
|
|
||||||
|
|
||||||
CREATE TRIGGER trigger_flag
|
CREATE TRIGGER trigger_flag
|
||||||
AFTER INSERT OR UPDATE OR DELETE
|
AFTER INSERT OR UPDATE OR DELETE ON osm_island_polygon
|
||||||
ON osm_island_polygon
|
|
||||||
FOR EACH STATEMENT
|
FOR EACH STATEMENT
|
||||||
EXECUTE PROCEDURE place_island_polygon.flag();
|
EXECUTE PROCEDURE place_island_polygon.flag();
|
||||||
|
|
||||||
CREATE CONSTRAINT TRIGGER trigger_refresh
|
CREATE CONSTRAINT TRIGGER trigger_refresh
|
||||||
AFTER INSERT
|
AFTER INSERT ON place_island_polygon.updates
|
||||||
ON place_island_polygon.updates
|
|
||||||
INITIALLY DEFERRED
|
INITIALLY DEFERRED
|
||||||
FOR EACH ROW
|
FOR EACH ROW
|
||||||
EXECUTE PROCEDURE place_island_polygon.refresh();
|
EXECUTE PROCEDURE place_island_polygon.refresh();
|
||||||
|
|||||||
@ -1,127 +1,79 @@
|
|||||||
DROP TRIGGER IF EXISTS trigger_flag ON osm_state_point;
|
DROP TRIGGER IF EXISTS trigger_flag ON osm_state_point;
|
||||||
DROP TRIGGER IF EXISTS trigger_store ON osm_state_point;
|
|
||||||
DROP TRIGGER IF EXISTS trigger_refresh ON place_state.updates;
|
DROP TRIGGER IF EXISTS trigger_refresh ON place_state.updates;
|
||||||
|
|
||||||
CREATE SCHEMA IF NOT EXISTS place_state;
|
ALTER TABLE osm_state_point DROP CONSTRAINT IF EXISTS osm_state_point_rank_constraint;
|
||||||
|
|
||||||
CREATE TABLE IF NOT EXISTS place_state.osm_ids
|
|
||||||
(
|
|
||||||
osm_id bigint
|
|
||||||
);
|
|
||||||
|
|
||||||
-- etldoc: ne_10m_admin_1_states_provinces -> osm_state_point
|
-- etldoc: ne_10m_admin_1_states_provinces -> osm_state_point
|
||||||
-- etldoc: osm_state_point -> osm_state_point
|
-- etldoc: osm_state_point -> osm_state_point
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION update_osm_state_point(full_update boolean) RETURNS void AS
|
CREATE OR REPLACE FUNCTION update_osm_state_point() RETURNS VOID AS $$
|
||||||
$$
|
BEGIN
|
||||||
WITH important_state_point AS (
|
|
||||||
SELECT osm.geometry,
|
|
||||||
osm.osm_id,
|
|
||||||
osm.name,
|
|
||||||
COALESCE(NULLIF(osm.name_en, ''), ne.name) AS name_en,
|
|
||||||
ne.scalerank,
|
|
||||||
ne.labelrank,
|
|
||||||
ne.datarank
|
|
||||||
FROM ne_10m_admin_1_states_provinces AS ne,
|
|
||||||
osm_state_point AS osm
|
|
||||||
WHERE
|
|
||||||
-- We only match whether the point is within the Natural Earth polygon
|
|
||||||
-- because name matching is difficult
|
|
||||||
ST_Within(osm.geometry, ne.geometry)
|
|
||||||
-- We leave out leess important states
|
|
||||||
AND ne.scalerank <= 3
|
|
||||||
AND ne.labelrank <= 2
|
|
||||||
)
|
|
||||||
UPDATE osm_state_point AS osm
|
|
||||||
-- Normalize both scalerank and labelrank into a ranking system from 1 to 6.
|
|
||||||
SET "rank" = LEAST(6, CEILING((scalerank + labelrank + datarank) / 3.0))
|
|
||||||
FROM important_state_point AS ne
|
|
||||||
WHERE (full_update OR osm.osm_id IN (SELECT osm_id FROM place_state.osm_ids))
|
|
||||||
AND rank IS NULL
|
|
||||||
AND osm.osm_id = ne.osm_id;
|
|
||||||
|
|
||||||
-- TODO: This shouldn't be necessary? The rank function makes something wrong...
|
WITH important_state_point AS (
|
||||||
UPDATE osm_state_point AS osm
|
SELECT osm.geometry, osm.osm_id, osm.name, COALESCE(NULLIF(osm.name_en, ''), ne.name) AS name_en, ne.scalerank, ne.labelrank, ne.datarank
|
||||||
SET "rank" = 1
|
FROM ne_10m_admin_1_states_provinces AS ne, osm_state_point AS osm
|
||||||
WHERE (full_update OR osm_id IN (SELECT osm_id FROM place_state.osm_ids))
|
WHERE
|
||||||
AND "rank" = 0;
|
-- We only match whether the point is within the Natural Earth polygon
|
||||||
|
-- because name matching is difficult
|
||||||
|
ST_Within(osm.geometry, ne.geometry)
|
||||||
|
-- We leave out leess important states
|
||||||
|
AND ne.scalerank <= 3 AND ne.labelrank <= 2
|
||||||
|
)
|
||||||
|
UPDATE osm_state_point AS osm
|
||||||
|
-- Normalize both scalerank and labelrank into a ranking system from 1 to 6.
|
||||||
|
SET "rank" = LEAST(6, CEILING((scalerank + labelrank + datarank)/3.0))
|
||||||
|
FROM important_state_point AS ne
|
||||||
|
WHERE osm.osm_id = ne.osm_id;
|
||||||
|
|
||||||
DELETE FROM osm_state_point
|
-- TODO: This shouldn't be necessary? The rank function makes something wrong...
|
||||||
WHERE (full_update OR osm_id IN (SELECT osm_id FROM place_state.osm_ids))
|
UPDATE osm_state_point AS osm
|
||||||
AND "rank" IS NULL;
|
SET "rank" = 1
|
||||||
|
WHERE "rank" = 0;
|
||||||
|
|
||||||
UPDATE osm_state_point
|
DELETE FROM osm_state_point WHERE "rank" IS NULL;
|
||||||
SET tags = update_tags(tags, geometry)
|
|
||||||
WHERE (full_update OR osm_id IN (SELECT osm_id FROM place_state.osm_ids))
|
|
||||||
AND COALESCE(tags->'name:latin', tags->'name:nonlatin', tags->'name_int') IS NULL
|
|
||||||
AND tags != update_tags(tags, geometry);
|
|
||||||
|
|
||||||
$$ LANGUAGE SQL;
|
UPDATE osm_state_point
|
||||||
|
SET tags = update_tags(tags, geometry)
|
||||||
|
WHERE COALESCE(tags->'name:latin', tags->'name:nonlatin', tags->'name_int') IS NULL;
|
||||||
|
|
||||||
SELECT update_osm_state_point(true);
|
END;
|
||||||
|
$$ LANGUAGE plpgsql;
|
||||||
|
|
||||||
CREATE INDEX IF NOT EXISTS osm_state_point_rank_idx ON osm_state_point ("rank");
|
SELECT update_osm_state_point();
|
||||||
|
|
||||||
|
-- ALTER TABLE osm_state_point ADD CONSTRAINT osm_state_point_rank_constraint CHECK("rank" BETWEEN 1 AND 6);
|
||||||
|
CREATE INDEX IF NOT EXISTS osm_state_point_rank_idx ON osm_state_point("rank");
|
||||||
|
|
||||||
-- Handle updates
|
-- Handle updates
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION place_state.store() RETURNS trigger AS
|
CREATE SCHEMA IF NOT EXISTS place_state;
|
||||||
$$
|
|
||||||
BEGIN
|
|
||||||
IF (tg_op = 'DELETE') THEN
|
|
||||||
INSERT INTO place_state.osm_ids VALUES (OLD.osm_id);
|
|
||||||
ELSE
|
|
||||||
INSERT INTO place_state.osm_ids VALUES (NEW.osm_id);
|
|
||||||
END IF;
|
|
||||||
RETURN NULL;
|
|
||||||
END;
|
|
||||||
$$ LANGUAGE plpgsql;
|
|
||||||
|
|
||||||
CREATE TABLE IF NOT EXISTS place_state.updates
|
CREATE TABLE IF NOT EXISTS place_state.updates(id serial primary key, t text, unique (t));
|
||||||
(
|
CREATE OR REPLACE FUNCTION place_state.flag() RETURNS trigger AS $$
|
||||||
id serial PRIMARY KEY,
|
|
||||||
t text,
|
|
||||||
UNIQUE (t)
|
|
||||||
);
|
|
||||||
CREATE OR REPLACE FUNCTION place_state.flag() RETURNS trigger AS
|
|
||||||
$$
|
|
||||||
BEGIN
|
BEGIN
|
||||||
INSERT INTO place_state.updates(t) VALUES ('y') ON CONFLICT(t) DO NOTHING;
|
INSERT INTO place_state.updates(t) VALUES ('y') ON CONFLICT(t) DO NOTHING;
|
||||||
RETURN NULL;
|
RETURN null;
|
||||||
END;
|
END;
|
||||||
$$ LANGUAGE plpgsql;
|
$$ language plpgsql;
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION place_state.refresh() RETURNS trigger AS
|
CREATE OR REPLACE FUNCTION place_state.refresh() RETURNS trigger AS
|
||||||
$$
|
$BODY$
|
||||||
DECLARE
|
BEGIN
|
||||||
t TIMESTAMP WITH TIME ZONE := clock_timestamp();
|
|
||||||
BEGIN
|
|
||||||
RAISE LOG 'Refresh place_state rank';
|
RAISE LOG 'Refresh place_state rank';
|
||||||
PERFORM update_osm_state_point(false);
|
PERFORM update_osm_state_point();
|
||||||
-- noinspection SqlWithoutWhere
|
|
||||||
DELETE FROM place_state.osm_ids;
|
|
||||||
-- noinspection SqlWithoutWhere
|
|
||||||
DELETE FROM place_state.updates;
|
DELETE FROM place_state.updates;
|
||||||
|
RETURN null;
|
||||||
RAISE LOG 'Refresh place_state done in %', age(clock_timestamp(), t);
|
END;
|
||||||
RETURN NULL;
|
$BODY$
|
||||||
END;
|
language plpgsql;
|
||||||
$$ LANGUAGE plpgsql;
|
|
||||||
|
|
||||||
CREATE TRIGGER trigger_store
|
|
||||||
AFTER INSERT OR UPDATE OR DELETE
|
|
||||||
ON osm_state_point
|
|
||||||
FOR EACH ROW
|
|
||||||
EXECUTE PROCEDURE place_state.store();
|
|
||||||
|
|
||||||
CREATE TRIGGER trigger_flag
|
CREATE TRIGGER trigger_flag
|
||||||
AFTER INSERT OR UPDATE OR DELETE
|
AFTER INSERT OR UPDATE OR DELETE ON osm_state_point
|
||||||
ON osm_state_point
|
|
||||||
FOR EACH STATEMENT
|
FOR EACH STATEMENT
|
||||||
EXECUTE PROCEDURE place_state.flag();
|
EXECUTE PROCEDURE place_state.flag();
|
||||||
|
|
||||||
CREATE CONSTRAINT TRIGGER trigger_refresh
|
CREATE CONSTRAINT TRIGGER trigger_refresh
|
||||||
AFTER INSERT
|
AFTER INSERT ON place_state.updates
|
||||||
ON place_state.updates
|
|
||||||
INITIALLY DEFERRED
|
INITIALLY DEFERRED
|
||||||
FOR EACH ROW
|
FOR EACH ROW
|
||||||
EXECUTE PROCEDURE place_state.refresh();
|
EXECUTE PROCEDURE place_state.refresh();
|
||||||
|
|||||||
@ -1,83 +1,40 @@
|
|||||||
CREATE OR REPLACE FUNCTION poi_class_rank(class text, subclass text)
|
CREATE OR REPLACE FUNCTION poi_class_rank(class TEXT)
|
||||||
RETURNS int AS
|
RETURNS INT AS $$
|
||||||
|
SELECT CASE class
|
||||||
|
WHEN 'hospital' THEN 20
|
||||||
|
WHEN 'railway' THEN 40
|
||||||
|
WHEN 'bus' THEN 50
|
||||||
|
WHEN 'attraction' THEN 70
|
||||||
|
WHEN 'harbor' THEN 75
|
||||||
|
WHEN 'college' THEN 80
|
||||||
|
WHEN 'school' THEN 85
|
||||||
|
WHEN 'stadium' THEN 90
|
||||||
|
WHEN 'zoo' THEN 95
|
||||||
|
WHEN 'town_hall' THEN 100
|
||||||
|
WHEN 'campsite' THEN 110
|
||||||
|
WHEN 'cemetery' THEN 115
|
||||||
|
WHEN 'park' THEN 120
|
||||||
|
WHEN 'library' THEN 130
|
||||||
|
WHEN 'police' THEN 135
|
||||||
|
WHEN 'post' THEN 140
|
||||||
|
WHEN 'golf' THEN 150
|
||||||
|
WHEN 'shop' THEN 400
|
||||||
|
WHEN 'grocery' THEN 500
|
||||||
|
WHEN 'fast_food' THEN 600
|
||||||
|
WHEN 'clothing_store' THEN 700
|
||||||
|
WHEN 'bar' THEN 800
|
||||||
|
ELSE 1000
|
||||||
|
END;
|
||||||
$$
|
$$
|
||||||
SELECT CASE class
|
LANGUAGE SQL
|
||||||
WHEN 'hospital' THEN 20
|
IMMUTABLE PARALLEL SAFE;
|
||||||
WHEN 'airport' THEN 30
|
|
||||||
WHEN 'railway' THEN 40
|
|
||||||
WHEN 'aerialway' THEN 40
|
|
||||||
WHEN 'heliport' THEN 45
|
|
||||||
WHEN 'taxi' THEN 50
|
|
||||||
WHEN 'harbor' THEN 55
|
|
||||||
WHEN 'library' THEN 60
|
|
||||||
WHEN 'bus' THEN
|
|
||||||
CASE subclass
|
|
||||||
WHEN 'bus_station' THEN 70
|
|
||||||
ELSE 72
|
|
||||||
END
|
|
||||||
WHEN 'attraction' THEN 75
|
|
||||||
WHEN 'college' THEN 80
|
|
||||||
WHEN 'school' THEN 85
|
|
||||||
WHEN 'stadium' THEN 90
|
|
||||||
WHEN 'zoo' THEN 95
|
|
||||||
WHEN 'town_hall' THEN 100
|
|
||||||
WHEN 'campsite' THEN 110
|
|
||||||
WHEN 'cemetery' THEN 115
|
|
||||||
WHEN 'park' THEN 120
|
|
||||||
WHEN 'library' THEN 130
|
|
||||||
WHEN 'police' THEN 135
|
|
||||||
WHEN 'post' THEN 140
|
|
||||||
WHEN 'golf' THEN 150
|
|
||||||
WHEN 'entrance' THEN 250
|
|
||||||
WHEN 'parking' THEN 300
|
|
||||||
WHEN 'car_parking' THEN 300
|
|
||||||
WHEN 'fuel' THEN 350
|
|
||||||
WHEN 'charging_station' THEN 355
|
|
||||||
WHEN 'bicycle_parking' THEN 360
|
|
||||||
WHEN 'motorcycle_parking' THEN 360
|
|
||||||
WHEN 'bank' THEN 380
|
|
||||||
WHEN 'art_gallery' THEN 400
|
|
||||||
WHEN 'information' THEN 420
|
|
||||||
WHEN 'fast_food' THEN 430
|
|
||||||
WHEN 'ice_cream' THEN 430
|
|
||||||
WHEN 'bar' THEN 450
|
|
||||||
WHEN 'cafe' THEN 450
|
|
||||||
WHEN 'grocery' THEN 450
|
|
||||||
WHEN 'bakery' THEN 475
|
|
||||||
WHEN 'community_centre' THEN 500
|
|
||||||
WHEN 'shop' THEN 600
|
|
||||||
WHEN 'optician' THEN 600
|
|
||||||
WHEN 'furniture' THEN 600
|
|
||||||
WHEN 'jewelry' THEN 600
|
|
||||||
WHEN 'toys' THEN 600
|
|
||||||
WHEN 'newsagent' THEN 600
|
|
||||||
WHEN 'paint' THEN 600
|
|
||||||
WHEN 'electronics' THEN 600
|
|
||||||
WHEN 'garden_centre' THEN 600
|
|
||||||
WHEN 'mobile_phone' THEN 600
|
|
||||||
WHEN 'shoes' THEN 600
|
|
||||||
WHEN 'clothing_store' THEN 600
|
|
||||||
WHEN 'florist' THEN 600
|
|
||||||
WHEN 'laundry' THEN 700
|
|
||||||
WHEN 'dog_park' THEN 800
|
|
||||||
WHEN 'pitch' THEN 800
|
|
||||||
WHEN 'power_tower' then 900
|
|
||||||
WHEN 'wind_mill' then 900
|
|
||||||
WHEN 'water_tower' then 900
|
|
||||||
WHEN 'communications_tower' then 900
|
|
||||||
WHEN 'wind_turbine' then 900
|
|
||||||
WHEN 'shelter' then 3000
|
|
||||||
ELSE 1000
|
|
||||||
END;
|
|
||||||
$$ LANGUAGE SQL IMMUTABLE
|
|
||||||
PARALLEL SAFE;
|
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION poi_class(subclass text, mapping_key text, subtype text)
|
CREATE OR REPLACE FUNCTION poi_class(subclass TEXT, mapping_key TEXT)
|
||||||
RETURNS text AS
|
RETURNS TEXT AS $$
|
||||||
|
SELECT CASE
|
||||||
|
%%FIELD_MAPPING: class %%
|
||||||
|
ELSE subclass
|
||||||
|
END;
|
||||||
$$
|
$$
|
||||||
SELECT CASE
|
LANGUAGE SQL
|
||||||
%%FIELD_MAPPING: class %%
|
IMMUTABLE PARALLEL SAFE;
|
||||||
ELSE subclass
|
|
||||||
END;
|
|
||||||
$$ LANGUAGE SQL IMMUTABLE
|
|
||||||
PARALLEL SAFE;
|
|
||||||
|
|||||||
75
layers/poi/layer.sql
Normal file
@ -0,0 +1,75 @@
|
|||||||
|
|
||||||
|
-- etldoc: layer_poi[shape=record fillcolor=lightpink, style="rounded,filled",
|
||||||
|
-- etldoc: label="layer_poi | <z12> z12 | <z13> z13 | <z14_> z14+" ] ;
|
||||||
|
|
||||||
|
CREATE OR REPLACE FUNCTION layer_poi(bbox geometry, zoom_level integer, pixel_width numeric)
|
||||||
|
RETURNS TABLE(osm_id bigint, geometry geometry, name text, name_en text, name_de text, tags hstore, class text, subclass text, agg_stop integer, layer integer, level integer, indoor integer, "rank" int) AS $$
|
||||||
|
SELECT osm_id_hash AS osm_id, geometry, NULLIF(name, '') AS name,
|
||||||
|
COALESCE(NULLIF(name_en, ''), name) AS name_en,
|
||||||
|
COALESCE(NULLIF(name_de, ''), name, name_en) AS name_de,
|
||||||
|
tags,
|
||||||
|
poi_class(subclass, mapping_key) AS class,
|
||||||
|
CASE
|
||||||
|
WHEN subclass = 'information'
|
||||||
|
THEN NULLIF(information, '')
|
||||||
|
WHEN subclass = 'place_of_worship'
|
||||||
|
THEN NULLIF(religion, '')
|
||||||
|
WHEN subclass = 'pitch'
|
||||||
|
THEN NULLIF(sport, '')
|
||||||
|
ELSE subclass
|
||||||
|
END AS subclass,
|
||||||
|
agg_stop,
|
||||||
|
NULLIF(layer, 0) AS layer,
|
||||||
|
"level",
|
||||||
|
CASE WHEN indoor=TRUE THEN 1 END as indoor,
|
||||||
|
row_number() OVER (
|
||||||
|
PARTITION BY LabelGrid(geometry, 100 * pixel_width)
|
||||||
|
ORDER BY CASE WHEN name = '' THEN 2000 ELSE poi_class_rank(poi_class(subclass, mapping_key)) END ASC
|
||||||
|
)::int AS "rank"
|
||||||
|
FROM (
|
||||||
|
-- etldoc: osm_poi_point -> layer_poi:z12
|
||||||
|
-- etldoc: osm_poi_point -> layer_poi:z13
|
||||||
|
SELECT *,
|
||||||
|
osm_id*10 AS osm_id_hash FROM osm_poi_point
|
||||||
|
WHERE geometry && bbox
|
||||||
|
AND zoom_level BETWEEN 12 AND 13
|
||||||
|
AND ((subclass='station' AND mapping_key = 'railway')
|
||||||
|
OR subclass IN ('halt', 'ferry_terminal'))
|
||||||
|
UNION ALL
|
||||||
|
|
||||||
|
-- etldoc: osm_poi_point -> layer_poi:z14_
|
||||||
|
SELECT *,
|
||||||
|
osm_id*10 AS osm_id_hash FROM osm_poi_point
|
||||||
|
WHERE geometry && bbox
|
||||||
|
AND zoom_level >= 14
|
||||||
|
|
||||||
|
UNION ALL
|
||||||
|
-- etldoc: osm_poi_polygon -> layer_poi:z12
|
||||||
|
-- etldoc: osm_poi_polygon -> layer_poi:z13
|
||||||
|
SELECT *,
|
||||||
|
NULL::INTEGER AS agg_stop,
|
||||||
|
CASE WHEN osm_id<0 THEN -osm_id*10+4
|
||||||
|
ELSE osm_id*10+1
|
||||||
|
END AS osm_id_hash
|
||||||
|
FROM osm_poi_polygon
|
||||||
|
WHERE geometry && bbox
|
||||||
|
AND zoom_level BETWEEN 12 AND 13
|
||||||
|
AND ((subclass='station' AND mapping_key = 'railway')
|
||||||
|
OR subclass IN ('halt', 'ferry_terminal'))
|
||||||
|
|
||||||
|
UNION ALL
|
||||||
|
-- etldoc: osm_poi_polygon -> layer_poi:z14_
|
||||||
|
SELECT *,
|
||||||
|
NULL::INTEGER AS agg_stop,
|
||||||
|
CASE WHEN osm_id<0 THEN -osm_id*10+4
|
||||||
|
ELSE osm_id*10+1
|
||||||
|
END AS osm_id_hash
|
||||||
|
FROM osm_poi_polygon
|
||||||
|
WHERE geometry && bbox
|
||||||
|
AND zoom_level >= 14
|
||||||
|
) as poi_union
|
||||||
|
ORDER BY "rank"
|
||||||
|
;
|
||||||
|
$$
|
||||||
|
LANGUAGE SQL
|
||||||
|
IMMUTABLE PARALLEL SAFE;
|
||||||
@ -21,7 +21,6 @@ def_poi_mapping_amenity: &poi_mapping_amenity
|
|||||||
- clinic
|
- clinic
|
||||||
- college
|
- college
|
||||||
- community_centre
|
- community_centre
|
||||||
- social_facility
|
|
||||||
- courthouse
|
- courthouse
|
||||||
- dentist
|
- dentist
|
||||||
- doctors
|
- doctors
|
||||||
@ -63,7 +62,6 @@ def_poi_mapping_amenity: &poi_mapping_amenity
|
|||||||
- university
|
- university
|
||||||
- veterinary
|
- veterinary
|
||||||
- waste_basket
|
- waste_basket
|
||||||
- charging_station
|
|
||||||
|
|
||||||
# barrier values , see http://taginfo.openstreetmap.org/keys/barrier#values
|
# barrier values , see http://taginfo.openstreetmap.org/keys/barrier#values
|
||||||
def_poi_mapping_barrier: &poi_mapping_barrier
|
def_poi_mapping_barrier: &poi_mapping_barrier
|
||||||
@ -79,13 +77,10 @@ def_poi_mapping_barrier: &poi_mapping_barrier
|
|||||||
# building values , see http://taginfo.openstreetmap.org/keys/building#values
|
# building values , see http://taginfo.openstreetmap.org/keys/building#values
|
||||||
def_poi_mapping_building: &poi_mapping_building
|
def_poi_mapping_building: &poi_mapping_building
|
||||||
- dormitory
|
- dormitory
|
||||||
- office
|
|
||||||
- industrial
|
|
||||||
|
|
||||||
# highway values , see http://taginfo.openstreetmap.org/keys/highway#values
|
# highway values , see http://taginfo.openstreetmap.org/keys/highway#values
|
||||||
def_poi_mapping_highway: &poi_mapping_highway
|
def_poi_mapping_highway: &poi_mapping_highway
|
||||||
- bus_stop
|
- bus_stop
|
||||||
- speed_camera
|
|
||||||
|
|
||||||
# historic values , see http://taginfo.openstreetmap.org/keys/historic#values
|
# historic values , see http://taginfo.openstreetmap.org/keys/historic#values
|
||||||
def_poi_mapping_historic: &poi_mapping_historic
|
def_poi_mapping_historic: &poi_mapping_historic
|
||||||
@ -119,7 +114,6 @@ def_poi_mapping_leisure: &poi_mapping_leisure
|
|||||||
- swimming_area
|
- swimming_area
|
||||||
- swimming_pool
|
- swimming_pool
|
||||||
- water_park
|
- water_park
|
||||||
- nature_reserve
|
|
||||||
|
|
||||||
# railway values , see http://taginfo.openstreetmap.org/keys/railway#values
|
# railway values , see http://taginfo.openstreetmap.org/keys/railway#values
|
||||||
def_poi_mapping_railway: &poi_mapping_railway
|
def_poi_mapping_railway: &poi_mapping_railway
|
||||||
@ -322,24 +316,6 @@ def_poi_mapping_tourism: &poi_mapping_tourism
|
|||||||
def_poi_mapping_waterway: &poi_mapping_waterway
|
def_poi_mapping_waterway: &poi_mapping_waterway
|
||||||
- dock
|
- dock
|
||||||
|
|
||||||
# aeroway values , see http://taginfo.openstreetmap.org/keys/aeroway#values
|
|
||||||
def_poi_mapping_aeroway: &poi_mapping_aeroway
|
|
||||||
- helipad
|
|
||||||
- aerodrome
|
|
||||||
|
|
||||||
# aeroway values , see http://taginfo.openstreetmap.org/keys/aeroway#values
|
|
||||||
def_poi_mapping_power: &poi_mapping_power
|
|
||||||
- generator
|
|
||||||
- tower
|
|
||||||
|
|
||||||
def_poi_mapping_man_made: &poi_mapping_man_made
|
|
||||||
- communications_tower
|
|
||||||
- water_tower
|
|
||||||
- wind_mill
|
|
||||||
|
|
||||||
def_poi_mapping_emergency: &poi_mapping_emergency
|
|
||||||
- defibrillator
|
|
||||||
|
|
||||||
def_poi_fields: &poi_fields
|
def_poi_fields: &poi_fields
|
||||||
- name: osm_id
|
- name: osm_id
|
||||||
type: id
|
type: id
|
||||||
@ -387,12 +363,6 @@ def_poi_fields: &poi_fields
|
|||||||
- name: sport
|
- name: sport
|
||||||
key: sport
|
key: sport
|
||||||
type: string
|
type: string
|
||||||
- name: power
|
|
||||||
key: power
|
|
||||||
type: string
|
|
||||||
- name: source
|
|
||||||
key: "generator:source"
|
|
||||||
type: string
|
|
||||||
|
|
||||||
def_poi_mapping: &poi_mapping
|
def_poi_mapping: &poi_mapping
|
||||||
aerialway: *poi_mapping_aerialway
|
aerialway: *poi_mapping_aerialway
|
||||||
@ -408,10 +378,6 @@ def_poi_mapping: &poi_mapping
|
|||||||
sport: *poi_mapping_sport
|
sport: *poi_mapping_sport
|
||||||
tourism: *poi_mapping_tourism
|
tourism: *poi_mapping_tourism
|
||||||
waterway: *poi_mapping_waterway
|
waterway: *poi_mapping_waterway
|
||||||
aeroway: *poi_mapping_aeroway
|
|
||||||
power: *poi_mapping_power
|
|
||||||
man_made: *poi_mapping_man_made
|
|
||||||
emergency: *poi_mapping_emergency
|
|
||||||
|
|
||||||
tables:
|
tables:
|
||||||
# etldoc: imposm3 -> osm_poi_point
|
# etldoc: imposm3 -> osm_poi_point
|
||||||
|
|||||||
@ -1,127 +0,0 @@
|
|||||||
-- etldoc: layer_poi[shape=record fillcolor=lightpink, style="rounded,filled",
|
|
||||||
-- etldoc: label="layer_poi | <z12> z12 | <z13> z13 | <z14_> z14+" ] ;
|
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION layer_poi(bbox geometry, zoom_level integer, pixel_width numeric)
|
|
||||||
RETURNS TABLE
|
|
||||||
(
|
|
||||||
osm_id bigint,
|
|
||||||
geometry geometry,
|
|
||||||
name text,
|
|
||||||
name_en text,
|
|
||||||
name_de text,
|
|
||||||
tags hstore,
|
|
||||||
class text,
|
|
||||||
subclass text,
|
|
||||||
agg_stop integer,
|
|
||||||
layer integer,
|
|
||||||
level integer,
|
|
||||||
indoor integer,
|
|
||||||
"rank" int
|
|
||||||
)
|
|
||||||
AS
|
|
||||||
$$
|
|
||||||
SELECT osm_id_hash AS osm_id,
|
|
||||||
geometry,
|
|
||||||
NULLIF(name, '') AS name,
|
|
||||||
COALESCE(NULLIF(name_en, ''), name) AS name_en,
|
|
||||||
COALESCE(NULLIF(name_de, ''), name, name_en) AS name_de,
|
|
||||||
tags,
|
|
||||||
poi_class(subclass, mapping_key, subtype) AS class,
|
|
||||||
CASE
|
|
||||||
WHEN subclass = 'information'
|
|
||||||
THEN NULLIF(information, '')
|
|
||||||
WHEN subclass = 'place_of_worship'
|
|
||||||
THEN NULLIF(religion, '')
|
|
||||||
WHEN subclass = 'pitch'
|
|
||||||
THEN NULLIF(sport, '')
|
|
||||||
WHEN subclass = 'sports_centre'
|
|
||||||
THEN NULLIF(sport, subclass)
|
|
||||||
ELSE subclass
|
|
||||||
END AS subclass,
|
|
||||||
agg_stop,
|
|
||||||
NULLIF(layer, 0) AS layer,
|
|
||||||
"level",
|
|
||||||
CASE WHEN indoor = TRUE THEN 1 END AS indoor,
|
|
||||||
row_number() OVER (
|
|
||||||
PARTITION BY LabelGrid(geometry, 100 * pixel_width)
|
|
||||||
ORDER BY
|
|
||||||
CASE
|
|
||||||
WHEN name = ''
|
|
||||||
THEN 2000
|
|
||||||
ELSE poi_class_rank(poi_class(
|
|
||||||
subclass,
|
|
||||||
mapping_key,
|
|
||||||
subtype
|
|
||||||
), subclass) END ASC
|
|
||||||
)::int AS "rank"
|
|
||||||
FROM (
|
|
||||||
-- Intermediate mapping for subtype and filtering out nameless industrial/office buildings
|
|
||||||
SELECT *,
|
|
||||||
CASE
|
|
||||||
WHEN subclass = 'information'
|
|
||||||
THEN NULLIF(information, '')
|
|
||||||
WHEN subclass = 'place_of_worship'
|
|
||||||
THEN NULLIF(religion, '')
|
|
||||||
WHEN subclass = 'pitch'
|
|
||||||
THEN NULLIF(sport, '')
|
|
||||||
WHEN subclass = 'sports_centre'
|
|
||||||
THEN NULLIF(sport, '')
|
|
||||||
WHEN subclass = 'generator' AND mapping_key = 'power'
|
|
||||||
THEN NULLIF(source, '')
|
|
||||||
ELSE subclass
|
|
||||||
END as subtype
|
|
||||||
FROM (
|
|
||||||
-- etldoc: osm_poi_point -> layer_poi:z12
|
|
||||||
-- etldoc: osm_poi_point -> layer_poi:z13
|
|
||||||
SELECT *,
|
|
||||||
osm_id * 10 AS osm_id_hash
|
|
||||||
FROM osm_poi_point
|
|
||||||
WHERE geometry && bbox
|
|
||||||
AND zoom_level BETWEEN 12 AND 13
|
|
||||||
AND ((subclass = 'station' AND mapping_key = 'railway')
|
|
||||||
OR subclass IN ('halt', 'ferry_terminal'))
|
|
||||||
|
|
||||||
UNION ALL
|
|
||||||
|
|
||||||
-- etldoc: osm_poi_point -> layer_poi:z14_
|
|
||||||
SELECT *,
|
|
||||||
osm_id * 10 AS osm_id_hash
|
|
||||||
FROM osm_poi_point
|
|
||||||
WHERE geometry && bbox
|
|
||||||
AND zoom_level >= 14
|
|
||||||
|
|
||||||
UNION ALL
|
|
||||||
|
|
||||||
-- etldoc: osm_poi_polygon -> layer_poi:z12
|
|
||||||
-- etldoc: osm_poi_polygon -> layer_poi:z13
|
|
||||||
SELECT *,
|
|
||||||
NULL::integer AS agg_stop,
|
|
||||||
CASE
|
|
||||||
WHEN osm_id < 0 THEN -osm_id * 10 + 4
|
|
||||||
ELSE osm_id * 10 + 1
|
|
||||||
END AS osm_id_hash
|
|
||||||
FROM osm_poi_polygon
|
|
||||||
WHERE geometry && bbox
|
|
||||||
AND zoom_level BETWEEN 12 AND 13
|
|
||||||
AND ((subclass = 'station' AND mapping_key = 'railway')
|
|
||||||
OR subclass IN ('halt', 'ferry_terminal'))
|
|
||||||
|
|
||||||
UNION ALL
|
|
||||||
|
|
||||||
-- etldoc: osm_poi_polygon -> layer_poi:z14_
|
|
||||||
SELECT *,
|
|
||||||
NULL::integer AS agg_stop,
|
|
||||||
CASE
|
|
||||||
WHEN osm_id < 0 THEN -osm_id * 10 + 4
|
|
||||||
ELSE osm_id * 10 + 1
|
|
||||||
END AS osm_id_hash
|
|
||||||
FROM osm_poi_polygon
|
|
||||||
WHERE geometry && bbox
|
|
||||||
AND zoom_level >= 14
|
|
||||||
) AS poi_union_raw
|
|
||||||
WHERE NOT (mapping_key = 'building' AND (subclass = 'office' OR subclass = 'industrial') AND coalesce(name, name_en, '') = '')
|
|
||||||
) AS poi_union
|
|
||||||
ORDER BY "rank"
|
|
||||||
$$ LANGUAGE SQL STABLE
|
|
||||||
PARALLEL SAFE;
|
|
||||||
-- TODO: Check if the above can be made STRICT -- i.e. if pixel_width could be NULL
|
|
||||||
@ -18,41 +18,15 @@ layer:
|
|||||||
values:
|
values:
|
||||||
shop:
|
shop:
|
||||||
subclass: ['accessories', 'antiques', 'beauty', 'bed', 'boutique', 'camera', 'carpet', 'charity', 'chemist',
|
subclass: ['accessories', 'antiques', 'beauty', 'bed', 'boutique', 'camera', 'carpet', 'charity', 'chemist',
|
||||||
'coffee', 'computer', 'convenience', 'copyshop', 'cosmetics',
|
'coffee', 'computer', 'convenience', 'copyshop', 'cosmetics', 'garden_centre', 'doityourself',
|
||||||
'erotic', 'fabric', 'frozen_food', 'video_games', 'video', 'general', 'gift',
|
'erotic', 'electronics', 'fabric', 'florist', 'frozen_food', 'furniture', 'video_games', 'video',
|
||||||
'hearing_aids', 'hifi', 'interior_decoration', 'kiosk', 'lamps', 'mall', 'massage','outdoor',
|
'general', 'gift', 'hardware', 'hearing_aids', 'hifi', 'ice_cream', 'interior_decoration',
|
||||||
'perfumery', 'perfume', 'pet', 'photo', 'second_hand', 'sports', 'stationery', 'tailor', 'tattoo',
|
'jewelry', 'kiosk', 'lamps', 'mall', 'massage', 'motorcycle', 'mobile_phone', 'newsagent',
|
||||||
'ticket', 'tobacco', 'travel_agency', 'watches', 'weapons', 'wholesale']
|
'optician', 'outdoor', 'perfumery', 'perfume', 'pet', 'photo', 'second_hand', 'shoes', 'sports',
|
||||||
optician:
|
'stationery', 'tailor', 'tattoo', 'ticket', 'tobacco', 'toys', 'travel_agency', 'watches',
|
||||||
subclass: ['optician']
|
'weapons', 'wholesale']
|
||||||
toys:
|
|
||||||
subclass: ['toys']
|
|
||||||
jewelry:
|
|
||||||
subclass: ['jewelry']
|
|
||||||
furniture:
|
|
||||||
subclass: ['furniture']
|
|
||||||
newsagent:
|
|
||||||
subclass: ['newsagent']
|
|
||||||
paint:
|
|
||||||
subclass: ['paint']
|
|
||||||
beverages:
|
|
||||||
subclass: ['beverages']
|
|
||||||
electronics:
|
|
||||||
subclass: ['electronics']
|
|
||||||
garden_centre:
|
|
||||||
subclass: ['garden_centre']
|
|
||||||
mobile_phone:
|
|
||||||
subclass: ['mobile_phone']
|
|
||||||
shoes:
|
|
||||||
subclass: ['shoes']
|
|
||||||
hardware:
|
|
||||||
subclass: ['hardware', 'doityourself']
|
|
||||||
florist:
|
|
||||||
subclass: ['florist']
|
|
||||||
town_hall:
|
town_hall:
|
||||||
subclass: ['townhall', 'public_building', 'courthouse']
|
subclass: ['townhall', 'public_building', 'courthouse', 'community_centre']
|
||||||
community_centre:
|
|
||||||
subclass: ['community_centre', 'social_facility']
|
|
||||||
golf:
|
golf:
|
||||||
subclass: ['golf', 'golf_course', 'miniature_golf']
|
subclass: ['golf', 'golf_course', 'miniature_golf']
|
||||||
fast_food:
|
fast_food:
|
||||||
@ -85,7 +59,7 @@ layer:
|
|||||||
lodging:
|
lodging:
|
||||||
subclass: ['hotel', 'motel', 'bed_and_breakfast', 'guest_house', 'hostel', 'chalet', 'alpine_hut', 'dormitory']
|
subclass: ['hotel', 'motel', 'bed_and_breakfast', 'guest_house', 'hostel', 'chalet', 'alpine_hut', 'dormitory']
|
||||||
ice_cream:
|
ice_cream:
|
||||||
subclass: ['chocolate', 'confectionery', 'ice_cream']
|
subclass: ['chocolate', 'confectionery']
|
||||||
post:
|
post:
|
||||||
subclass: ['post_box', 'post_office']
|
subclass: ['post_box', 'post_office']
|
||||||
cafe:
|
cafe:
|
||||||
@ -98,14 +72,8 @@ layer:
|
|||||||
subclass: ['bar', 'nightclub']
|
subclass: ['bar', 'nightclub']
|
||||||
harbor:
|
harbor:
|
||||||
subclass: ['marina', 'dock']
|
subclass: ['marina', 'dock']
|
||||||
taxi:
|
car:
|
||||||
subclass: ['taxi']
|
subclass: ['car', 'car_repair', 'car_parts', 'taxi']
|
||||||
motorcycle_dealer:
|
|
||||||
subclass: ['motorcycle']
|
|
||||||
car_dealer:
|
|
||||||
subclass: ['car', 'car_parts']
|
|
||||||
car_repair:
|
|
||||||
subclass: ['car_repair']
|
|
||||||
hospital:
|
hospital:
|
||||||
subclass: ['hospital', 'nursing_home', 'clinic']
|
subclass: ['hospital', 'nursing_home', 'clinic']
|
||||||
cemetery:
|
cemetery:
|
||||||
@ -126,25 +94,6 @@ layer:
|
|||||||
subclass: ['swimming_area', 'swimming']
|
subclass: ['swimming_area', 'swimming']
|
||||||
castle:
|
castle:
|
||||||
subclass: ['castle', 'ruins']
|
subclass: ['castle', 'ruins']
|
||||||
airport:
|
|
||||||
subclass: ['aerodrome']
|
|
||||||
heliport:
|
|
||||||
subclass: ['helipad']
|
|
||||||
wind_turbine:
|
|
||||||
__AND__:
|
|
||||||
subclass: ['generator']
|
|
||||||
subtype: ['wind']
|
|
||||||
mapping_key: ['power']
|
|
||||||
communications_tower:
|
|
||||||
subclass: ['communications_tower']
|
|
||||||
water_tower:
|
|
||||||
subclass: ['water_tower']
|
|
||||||
wind_mill:
|
|
||||||
subclass: ['wind_mill']
|
|
||||||
power_tower:
|
|
||||||
subclass: ['tower']
|
|
||||||
industry:
|
|
||||||
subclass: ['industrial']
|
|
||||||
subclass:
|
subclass:
|
||||||
description: |
|
description: |
|
||||||
Original value of either the
|
Original value of either the
|
||||||
@ -201,7 +150,7 @@ schema:
|
|||||||
- ./poi_stop_agg.sql
|
- ./poi_stop_agg.sql
|
||||||
- ./update_poi_polygon.sql
|
- ./update_poi_polygon.sql
|
||||||
- ./update_poi_point.sql
|
- ./update_poi_point.sql
|
||||||
- ./poi.sql
|
- ./layer.sql
|
||||||
datasources:
|
datasources:
|
||||||
- type: imposm3
|
- type: imposm3
|
||||||
mapping_file: ./mapping.yaml
|
mapping_file: ./mapping.yaml
|
||||||
|
|||||||
@ -1,31 +1,35 @@
|
|||||||
DROP MATERIALIZED VIEW IF EXISTS osm_poi_stop_centroid CASCADE;
|
DROP MATERIALIZED VIEW IF EXISTS osm_poi_stop_centroid CASCADE;
|
||||||
CREATE MATERIALIZED VIEW osm_poi_stop_centroid AS
|
CREATE MATERIALIZED VIEW osm_poi_stop_centroid AS (
|
||||||
(
|
SELECT
|
||||||
SELECT uic_ref,
|
uic_ref,
|
||||||
count(*) AS count,
|
count(*) as count,
|
||||||
CASE WHEN count(*) > 2 THEN ST_Centroid(ST_UNION(geometry)) END AS centroid
|
CASE WHEN count(*) > 2 THEN ST_Centroid(ST_UNION(geometry)) END AS centroid
|
||||||
FROM osm_poi_point
|
FROM osm_poi_point
|
||||||
WHERE nullif(uic_ref, '') IS NOT NULL
|
WHERE
|
||||||
AND subclass IN ('bus_stop', 'bus_station', 'tram_stop', 'subway')
|
nullif(uic_ref, '') IS NOT NULL
|
||||||
GROUP BY uic_ref
|
AND subclass IN ('bus_stop', 'bus_station', 'tram_stop', 'subway')
|
||||||
HAVING count(*) > 1
|
GROUP BY
|
||||||
) /* DELAY_MATERIALIZED_VIEW_CREATION */;
|
uic_ref
|
||||||
|
HAVING
|
||||||
|
count(*) > 1
|
||||||
|
) /* DELAY_MATERIALIZED_VIEW_CREATION */;
|
||||||
|
|
||||||
DROP MATERIALIZED VIEW IF EXISTS osm_poi_stop_rank CASCADE;
|
DROP MATERIALIZED VIEW IF EXISTS osm_poi_stop_rank CASCADE;
|
||||||
CREATE MATERIALIZED VIEW osm_poi_stop_rank AS
|
CREATE MATERIALIZED VIEW osm_poi_stop_rank AS (
|
||||||
(
|
SELECT
|
||||||
SELECT p.osm_id,
|
p.osm_id,
|
||||||
-- p.uic_ref,
|
-- p.uic_ref,
|
||||||
-- p.subclass,
|
-- p.subclass,
|
||||||
ROW_NUMBER()
|
ROW_NUMBER()
|
||||||
OVER (
|
OVER (
|
||||||
PARTITION BY p.uic_ref
|
PARTITION BY p.uic_ref
|
||||||
ORDER BY
|
ORDER BY
|
||||||
p.subclass :: public_transport_stop_type NULLS LAST,
|
p.subclass :: public_transport_stop_type NULLS LAST,
|
||||||
ST_Distance(c.centroid, p.geometry)
|
ST_Distance(c.centroid, p.geometry)
|
||||||
) AS rk
|
) AS rk
|
||||||
FROM osm_poi_point p
|
FROM osm_poi_point p
|
||||||
INNER JOIN osm_poi_stop_centroid c ON (p.uic_ref = c.uic_ref)
|
INNER JOIN osm_poi_stop_centroid c ON (p.uic_ref = c.uic_ref)
|
||||||
WHERE subclass IN ('bus_stop', 'bus_station', 'tram_stop', 'subway')
|
WHERE
|
||||||
ORDER BY p.uic_ref, rk
|
subclass IN ('bus_stop', 'bus_station', 'tram_stop', 'subway')
|
||||||
) /* DELAY_MATERIALIZED_VIEW_CREATION */;
|
ORDER BY p.uic_ref, rk
|
||||||
|
) /* DELAY_MATERIALIZED_VIEW_CREATION */;
|
||||||
|
|||||||
@ -1,12 +1,11 @@
|
|||||||
DO
|
DO $$
|
||||||
$$
|
BEGIN
|
||||||
BEGIN
|
IF NOT EXISTS (SELECT 1
|
||||||
IF NOT EXISTS(SELECT 1
|
FROM pg_type
|
||||||
FROM pg_type
|
WHERE typname = 'public_transport_stop_type') THEN
|
||||||
WHERE typname = 'public_transport_stop_type') THEN
|
CREATE TYPE public_transport_stop_type AS ENUM (
|
||||||
CREATE TYPE public_transport_stop_type AS enum (
|
'subway', 'tram_stop', 'bus_station', 'bus_stop'
|
||||||
'subway', 'tram_stop', 'bus_station', 'bus_stop'
|
);
|
||||||
);
|
END IF;
|
||||||
END IF;
|
END
|
||||||
END
|
|
||||||
$$;
|
$$;
|
||||||
|
|||||||
@ -2,99 +2,83 @@ DROP TRIGGER IF EXISTS trigger_flag ON osm_poi_point;
|
|||||||
DROP TRIGGER IF EXISTS trigger_refresh ON poi_point.updates;
|
DROP TRIGGER IF EXISTS trigger_refresh ON poi_point.updates;
|
||||||
|
|
||||||
-- etldoc: osm_poi_point -> osm_poi_point
|
-- etldoc: osm_poi_point -> osm_poi_point
|
||||||
CREATE OR REPLACE FUNCTION update_osm_poi_point() RETURNS void AS
|
CREATE OR REPLACE FUNCTION update_osm_poi_point() RETURNS VOID AS $$
|
||||||
$$
|
|
||||||
BEGIN
|
BEGIN
|
||||||
UPDATE osm_poi_point
|
UPDATE osm_poi_point
|
||||||
SET subclass = 'subway'
|
SET subclass = 'subway'
|
||||||
WHERE station = 'subway'
|
WHERE station = 'subway' and subclass='station';
|
||||||
AND subclass = 'station';
|
|
||||||
|
|
||||||
UPDATE osm_poi_point
|
UPDATE osm_poi_point
|
||||||
SET subclass = 'halt'
|
SET subclass = 'halt'
|
||||||
WHERE funicular = 'yes'
|
WHERE funicular = 'yes' and subclass='station';
|
||||||
AND subclass = 'station';
|
|
||||||
|
|
||||||
UPDATE osm_poi_point
|
UPDATE osm_poi_point
|
||||||
SET tags = update_tags(tags, geometry)
|
SET tags = update_tags(tags, geometry)
|
||||||
WHERE COALESCE(tags->'name:latin', tags->'name:nonlatin', tags->'name_int') IS NULL;
|
WHERE COALESCE(tags->'name:latin', tags->'name:nonlatin', tags->'name_int') IS NULL;
|
||||||
|
|
||||||
END;
|
END;
|
||||||
$$ LANGUAGE plpgsql;
|
$$ LANGUAGE plpgsql;
|
||||||
|
|
||||||
SELECT update_osm_poi_point();
|
SELECT update_osm_poi_point();
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION update_osm_poi_point_agg() RETURNS void AS
|
CREATE OR REPLACE FUNCTION update_osm_poi_point_agg() RETURNS VOID AS $$
|
||||||
$$
|
|
||||||
BEGIN
|
BEGIN
|
||||||
UPDATE osm_poi_point p
|
UPDATE osm_poi_point p
|
||||||
SET agg_stop = CASE
|
SET agg_stop = CASE
|
||||||
WHEN p.subclass IN ('bus_stop', 'bus_station', 'tram_stop', 'subway')
|
WHEN p.subclass IN ('bus_stop', 'bus_station', 'tram_stop', 'subway')
|
||||||
THEN 1
|
THEN 1
|
||||||
END;
|
END;
|
||||||
|
|
||||||
UPDATE osm_poi_point p
|
UPDATE osm_poi_point p
|
||||||
SET agg_stop = (
|
SET agg_stop = (
|
||||||
CASE
|
CASE
|
||||||
WHEN p.subclass IN ('bus_stop', 'bus_station', 'tram_stop', 'subway')
|
WHEN p.subclass IN ('bus_stop', 'bus_station', 'tram_stop', 'subway')
|
||||||
AND r.rk IS NULL OR r.rk = 1
|
AND r.rk IS NULL OR r.rk = 1
|
||||||
THEN 1
|
THEN 1
|
||||||
END)
|
END)
|
||||||
FROM osm_poi_stop_rank r
|
FROM osm_poi_stop_rank r
|
||||||
WHERE p.osm_id = r.osm_id;
|
WHERE p.osm_id = r.osm_id
|
||||||
|
;
|
||||||
|
|
||||||
END;
|
END;
|
||||||
$$ LANGUAGE plpgsql;
|
$$ LANGUAGE plpgsql;
|
||||||
|
|
||||||
ALTER TABLE osm_poi_point
|
ALTER TABLE osm_poi_point ADD COLUMN IF NOT EXISTS agg_stop INTEGER DEFAULT NULL;
|
||||||
ADD COLUMN IF NOT EXISTS agg_stop integer DEFAULT NULL;
|
|
||||||
SELECT update_osm_poi_point_agg();
|
SELECT update_osm_poi_point_agg();
|
||||||
|
|
||||||
-- Handle updates
|
-- Handle updates
|
||||||
|
|
||||||
CREATE SCHEMA IF NOT EXISTS poi_point;
|
CREATE SCHEMA IF NOT EXISTS poi_point;
|
||||||
|
|
||||||
CREATE TABLE IF NOT EXISTS poi_point.updates
|
CREATE TABLE IF NOT EXISTS poi_point.updates(id serial primary key, t text, unique (t));
|
||||||
(
|
CREATE OR REPLACE FUNCTION poi_point.flag() RETURNS trigger AS $$
|
||||||
id serial PRIMARY KEY,
|
|
||||||
t text,
|
|
||||||
UNIQUE (t)
|
|
||||||
);
|
|
||||||
CREATE OR REPLACE FUNCTION poi_point.flag() RETURNS trigger AS
|
|
||||||
$$
|
|
||||||
BEGIN
|
BEGIN
|
||||||
INSERT INTO poi_point.updates(t) VALUES ('y') ON CONFLICT(t) DO NOTHING;
|
INSERT INTO poi_point.updates(t) VALUES ('y') ON CONFLICT(t) DO NOTHING;
|
||||||
RETURN NULL;
|
RETURN null;
|
||||||
END;
|
END;
|
||||||
$$ LANGUAGE plpgsql;
|
$$ language plpgsql;
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION poi_point.refresh() RETURNS trigger AS
|
CREATE OR REPLACE FUNCTION poi_point.refresh() RETURNS trigger AS
|
||||||
$$
|
$BODY$
|
||||||
DECLARE
|
BEGIN
|
||||||
t TIMESTAMP WITH TIME ZONE := clock_timestamp();
|
|
||||||
BEGIN
|
|
||||||
RAISE LOG 'Refresh poi_point';
|
RAISE LOG 'Refresh poi_point';
|
||||||
PERFORM update_osm_poi_point();
|
PERFORM update_osm_poi_point();
|
||||||
REFRESH MATERIALIZED VIEW osm_poi_stop_centroid;
|
REFRESH MATERIALIZED VIEW osm_poi_stop_centroid;
|
||||||
REFRESH MATERIALIZED VIEW osm_poi_stop_rank;
|
REFRESH MATERIALIZED VIEW osm_poi_stop_rank;
|
||||||
PERFORM update_osm_poi_point_agg();
|
PERFORM update_osm_poi_point_agg();
|
||||||
-- noinspection SqlWithoutWhere
|
|
||||||
DELETE FROM poi_point.updates;
|
DELETE FROM poi_point.updates;
|
||||||
|
RETURN null;
|
||||||
RAISE LOG 'Refresh poi_point done in %', age(clock_timestamp(), t);
|
END;
|
||||||
RETURN NULL;
|
$BODY$
|
||||||
END;
|
language plpgsql;
|
||||||
$$ LANGUAGE plpgsql;
|
|
||||||
|
|
||||||
CREATE TRIGGER trigger_flag
|
CREATE TRIGGER trigger_flag
|
||||||
AFTER INSERT OR UPDATE OR DELETE
|
AFTER INSERT OR UPDATE OR DELETE ON osm_poi_point
|
||||||
ON osm_poi_point
|
|
||||||
FOR EACH STATEMENT
|
FOR EACH STATEMENT
|
||||||
EXECUTE PROCEDURE poi_point.flag();
|
EXECUTE PROCEDURE poi_point.flag();
|
||||||
|
|
||||||
CREATE CONSTRAINT TRIGGER trigger_refresh
|
CREATE CONSTRAINT TRIGGER trigger_refresh
|
||||||
AFTER INSERT
|
AFTER INSERT ON poi_point.updates
|
||||||
ON poi_point.updates
|
|
||||||
INITIALLY DEFERRED
|
INITIALLY DEFERRED
|
||||||
FOR EACH ROW
|
FOR EACH ROW
|
||||||
EXECUTE PROCEDURE poi_point.refresh();
|
EXECUTE PROCEDURE poi_point.refresh();
|
||||||
|
|||||||
@ -1,111 +1,66 @@
|
|||||||
DROP TRIGGER IF EXISTS trigger_flag ON osm_poi_polygon;
|
DROP TRIGGER IF EXISTS trigger_flag ON osm_poi_polygon;
|
||||||
DROP TRIGGER IF EXISTS trigger_store ON osm_poi_polygon;
|
|
||||||
DROP TRIGGER IF EXISTS trigger_refresh ON poi_polygon.updates;
|
DROP TRIGGER IF EXISTS trigger_refresh ON poi_polygon.updates;
|
||||||
|
|
||||||
CREATE SCHEMA IF NOT EXISTS poi_polygon;
|
|
||||||
|
|
||||||
CREATE TABLE IF NOT EXISTS poi_polygon.osm_ids
|
|
||||||
(
|
|
||||||
osm_id bigint
|
|
||||||
);
|
|
||||||
|
|
||||||
-- etldoc: osm_poi_polygon -> osm_poi_polygon
|
-- etldoc: osm_poi_polygon -> osm_poi_polygon
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION update_poi_polygon(full_update boolean) RETURNS void AS
|
CREATE OR REPLACE FUNCTION update_poi_polygon() RETURNS VOID AS $$
|
||||||
$$
|
BEGIN
|
||||||
UPDATE osm_poi_polygon
|
UPDATE osm_poi_polygon
|
||||||
SET geometry =
|
SET geometry =
|
||||||
CASE
|
CASE WHEN ST_NPoints(ST_ConvexHull(geometry))=ST_NPoints(geometry)
|
||||||
WHEN ST_NPoints(ST_ConvexHull(geometry)) = ST_NPoints(geometry)
|
THEN ST_Centroid(geometry)
|
||||||
THEN ST_Centroid(geometry)
|
ELSE ST_PointOnSurface(geometry)
|
||||||
ELSE ST_PointOnSurface(geometry)
|
END
|
||||||
END
|
WHERE ST_GeometryType(geometry) <> 'ST_Point';
|
||||||
WHERE (full_update OR osm_id IN (SELECT osm_id FROM poi_polygon.osm_ids))
|
|
||||||
AND ST_GeometryType(geometry) <> 'ST_Point'
|
|
||||||
AND ST_IsValid(geometry);
|
|
||||||
|
|
||||||
UPDATE osm_poi_polygon
|
UPDATE osm_poi_polygon
|
||||||
SET subclass = 'subway'
|
SET subclass = 'subway'
|
||||||
WHERE (full_update OR osm_id IN (SELECT osm_id FROM poi_polygon.osm_ids))
|
WHERE station = 'subway' and subclass='station';
|
||||||
AND station = 'subway'
|
|
||||||
AND subclass = 'station';
|
|
||||||
|
|
||||||
UPDATE osm_poi_polygon
|
UPDATE osm_poi_polygon
|
||||||
SET subclass = 'halt'
|
SET subclass = 'halt'
|
||||||
WHERE (full_update OR osm_id IN (SELECT osm_id FROM poi_polygon.osm_ids))
|
WHERE funicular = 'yes' and subclass='station';
|
||||||
AND funicular = 'yes'
|
|
||||||
AND subclass = 'station';
|
|
||||||
|
|
||||||
UPDATE osm_poi_polygon
|
UPDATE osm_poi_polygon
|
||||||
SET tags = update_tags(tags, geometry)
|
SET tags = update_tags(tags, geometry)
|
||||||
WHERE (full_update OR osm_id IN (SELECT osm_id FROM poi_polygon.osm_ids))
|
WHERE COALESCE(tags->'name:latin', tags->'name:nonlatin', tags->'name_int') IS NULL;
|
||||||
AND COALESCE(tags->'name:latin', tags->'name:nonlatin', tags->'name_int') IS NULL
|
|
||||||
AND tags != update_tags(tags, geometry);
|
|
||||||
|
|
||||||
$$ LANGUAGE SQL;
|
ANALYZE osm_poi_polygon;
|
||||||
|
END;
|
||||||
|
$$ LANGUAGE plpgsql;
|
||||||
|
|
||||||
SELECT update_poi_polygon(true);
|
SELECT update_poi_polygon();
|
||||||
|
|
||||||
-- Handle updates
|
-- Handle updates
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION poi_polygon.store() RETURNS trigger AS
|
CREATE SCHEMA IF NOT EXISTS poi_polygon;
|
||||||
$$
|
|
||||||
BEGIN
|
|
||||||
IF (tg_op = 'DELETE') THEN
|
|
||||||
INSERT INTO poi_polygon.osm_ids VALUES (OLD.osm_id);
|
|
||||||
ELSE
|
|
||||||
INSERT INTO poi_polygon.osm_ids VALUES (NEW.osm_id);
|
|
||||||
END IF;
|
|
||||||
RETURN NULL;
|
|
||||||
END;
|
|
||||||
$$ LANGUAGE plpgsql;
|
|
||||||
|
|
||||||
CREATE TABLE IF NOT EXISTS poi_polygon.updates
|
CREATE TABLE IF NOT EXISTS poi_polygon.updates(id serial primary key, t text, unique (t));
|
||||||
(
|
CREATE OR REPLACE FUNCTION poi_polygon.flag() RETURNS trigger AS $$
|
||||||
id serial PRIMARY KEY,
|
|
||||||
t text,
|
|
||||||
UNIQUE (t)
|
|
||||||
);
|
|
||||||
CREATE OR REPLACE FUNCTION poi_polygon.flag() RETURNS trigger AS
|
|
||||||
$$
|
|
||||||
BEGIN
|
BEGIN
|
||||||
INSERT INTO poi_polygon.updates(t) VALUES ('y') ON CONFLICT(t) DO NOTHING;
|
INSERT INTO poi_polygon.updates(t) VALUES ('y') ON CONFLICT(t) DO NOTHING;
|
||||||
RETURN NULL;
|
RETURN null;
|
||||||
END;
|
END;
|
||||||
$$ LANGUAGE plpgsql;
|
$$ language plpgsql;
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION poi_polygon.refresh() RETURNS trigger AS
|
CREATE OR REPLACE FUNCTION poi_polygon.refresh() RETURNS trigger AS
|
||||||
$$
|
$BODY$
|
||||||
DECLARE
|
BEGIN
|
||||||
t TIMESTAMP WITH TIME ZONE := clock_timestamp();
|
|
||||||
BEGIN
|
|
||||||
RAISE LOG 'Refresh poi_polygon';
|
RAISE LOG 'Refresh poi_polygon';
|
||||||
PERFORM update_poi_polygon(false);
|
PERFORM update_poi_polygon();
|
||||||
-- noinspection SqlWithoutWhere
|
|
||||||
DELETE FROM poi_polygon.osm_ids;
|
|
||||||
-- noinspection SqlWithoutWhere
|
|
||||||
DELETE FROM poi_polygon.updates;
|
DELETE FROM poi_polygon.updates;
|
||||||
|
RETURN null;
|
||||||
RAISE LOG 'Refresh poi_polygon done in %', age(clock_timestamp(), t);
|
END;
|
||||||
RETURN NULL;
|
$BODY$
|
||||||
END;
|
language plpgsql;
|
||||||
$$ LANGUAGE plpgsql;
|
|
||||||
|
|
||||||
CREATE TRIGGER trigger_store
|
|
||||||
AFTER INSERT OR UPDATE OR DELETE
|
|
||||||
ON osm_poi_polygon
|
|
||||||
FOR EACH ROW
|
|
||||||
EXECUTE PROCEDURE poi_polygon.store();
|
|
||||||
|
|
||||||
CREATE TRIGGER trigger_flag
|
CREATE TRIGGER trigger_flag
|
||||||
AFTER INSERT OR UPDATE OR DELETE
|
AFTER INSERT OR UPDATE OR DELETE ON osm_poi_polygon
|
||||||
ON osm_poi_polygon
|
|
||||||
FOR EACH STATEMENT
|
FOR EACH STATEMENT
|
||||||
EXECUTE PROCEDURE poi_polygon.flag();
|
EXECUTE PROCEDURE poi_polygon.flag();
|
||||||
|
|
||||||
CREATE CONSTRAINT TRIGGER trigger_refresh
|
CREATE CONSTRAINT TRIGGER trigger_refresh
|
||||||
AFTER INSERT
|
AFTER INSERT ON poi_polygon.updates
|
||||||
ON poi_polygon.updates
|
|
||||||
INITIALLY DEFERRED
|
INITIALLY DEFERRED
|
||||||
FOR EACH ROW
|
FOR EACH ROW
|
||||||
EXECUTE PROCEDURE poi_polygon.refresh();
|
EXECUTE PROCEDURE poi_polygon.refresh();
|
||||||
|
|||||||
@ -1,58 +1,51 @@
|
|||||||
CREATE OR REPLACE FUNCTION brunnel(is_bridge bool, is_tunnel bool, is_ford bool) RETURNS text AS
|
CREATE OR REPLACE FUNCTION brunnel(is_bridge BOOL, is_tunnel BOOL, is_ford BOOL) RETURNS TEXT AS $$
|
||||||
|
SELECT CASE
|
||||||
|
WHEN is_bridge THEN 'bridge'
|
||||||
|
WHEN is_tunnel THEN 'tunnel'
|
||||||
|
WHEN is_ford THEN 'ford'
|
||||||
|
END;
|
||||||
$$
|
$$
|
||||||
SELECT CASE
|
LANGUAGE SQL
|
||||||
WHEN is_bridge THEN 'bridge'
|
IMMUTABLE STRICT PARALLEL SAFE;
|
||||||
WHEN is_tunnel THEN 'tunnel'
|
|
||||||
WHEN is_ford THEN 'ford'
|
|
||||||
END;
|
|
||||||
$$ LANGUAGE SQL IMMUTABLE
|
|
||||||
STRICT
|
|
||||||
PARALLEL SAFE;
|
|
||||||
|
|
||||||
-- The classes for highways are derived from the classes used in ClearTables
|
-- The classes for highways are derived from the classes used in ClearTables
|
||||||
-- https://github.com/ClearTables/ClearTables/blob/master/transportation.lua
|
-- https://github.com/ClearTables/ClearTables/blob/master/transportation.lua
|
||||||
CREATE OR REPLACE FUNCTION highway_class(highway text, public_transport text, construction text) RETURNS text AS
|
CREATE OR REPLACE FUNCTION highway_class(highway TEXT, public_transport TEXT, construction TEXT) RETURNS TEXT AS $$
|
||||||
|
SELECT CASE
|
||||||
|
%%FIELD_MAPPING: class %%
|
||||||
|
END;
|
||||||
$$
|
$$
|
||||||
SELECT CASE
|
LANGUAGE SQL
|
||||||
%%FIELD_MAPPING: class %%
|
IMMUTABLE PARALLEL SAFE;
|
||||||
END;
|
|
||||||
$$ LANGUAGE SQL IMMUTABLE
|
|
||||||
PARALLEL SAFE;
|
|
||||||
|
|
||||||
-- The classes for railways are derived from the classes used in ClearTables
|
-- The classes for railways are derived from the classes used in ClearTables
|
||||||
-- https://github.com/ClearTables/ClearTables/blob/master/transportation.lua
|
-- https://github.com/ClearTables/ClearTables/blob/master/transportation.lua
|
||||||
CREATE OR REPLACE FUNCTION railway_class(railway text) RETURNS text AS
|
CREATE OR REPLACE FUNCTION railway_class(railway TEXT) RETURNS TEXT AS $$
|
||||||
|
SELECT CASE
|
||||||
|
WHEN railway IN ('rail', 'narrow_gauge', 'preserved', 'funicular') THEN 'rail'
|
||||||
|
WHEN railway IN ('subway', 'light_rail', 'monorail', 'tram') THEN 'transit'
|
||||||
|
END;
|
||||||
$$
|
$$
|
||||||
SELECT CASE
|
LANGUAGE SQL
|
||||||
WHEN railway IN ('rail', 'narrow_gauge', 'preserved', 'funicular') THEN 'rail'
|
IMMUTABLE STRICT PARALLEL SAFE;
|
||||||
WHEN railway IN ('subway', 'light_rail', 'monorail', 'tram') THEN 'transit'
|
|
||||||
END;
|
|
||||||
$$ LANGUAGE SQL IMMUTABLE
|
|
||||||
STRICT
|
|
||||||
PARALLEL SAFE;
|
|
||||||
|
|
||||||
-- Limit service to only the most important values to ensure
|
-- Limit service to only the most important values to ensure
|
||||||
-- we always know the values of service
|
-- we always know the values of service
|
||||||
CREATE OR REPLACE FUNCTION service_value(service text) RETURNS text AS
|
CREATE OR REPLACE FUNCTION service_value(service TEXT) RETURNS TEXT AS $$
|
||||||
|
SELECT CASE
|
||||||
|
WHEN service IN ('spur', 'yard', 'siding', 'crossover', 'driveway', 'alley', 'parking_aisle') THEN service
|
||||||
|
END;
|
||||||
$$
|
$$
|
||||||
SELECT CASE
|
LANGUAGE SQL
|
||||||
WHEN service IN ('spur', 'yard', 'siding', 'crossover', 'driveway', 'alley', 'parking_aisle') THEN service
|
IMMUTABLE STRICT PARALLEL SAFE;
|
||||||
END;
|
|
||||||
$$ LANGUAGE SQL IMMUTABLE
|
|
||||||
STRICT
|
|
||||||
PARALLEL SAFE;
|
|
||||||
|
|
||||||
-- Limit surface to only the most important values to ensure
|
-- Limit surface to only the most important values to ensure
|
||||||
-- we always know the values of surface
|
-- we always know the values of surface
|
||||||
CREATE OR REPLACE FUNCTION surface_value(surface text) RETURNS text AS
|
CREATE OR REPLACE FUNCTION surface_value(surface TEXT) RETURNS TEXT AS $$
|
||||||
|
SELECT CASE
|
||||||
|
WHEN surface IN ('paved', 'asphalt', 'cobblestone', 'concrete', 'concrete:lanes', 'concrete:plates', 'metal', 'paving_stones', 'sett', 'unhewn_cobblestone', 'wood') THEN 'paved'
|
||||||
|
WHEN surface IN ('unpaved', 'compacted', 'dirt', 'earth', 'fine_gravel', 'grass', 'grass_paver', 'gravel', 'gravel_turf', 'ground', 'ice', 'mud', 'pebblestone', 'salt', 'sand', 'snow', 'woodchips') THEN 'unpaved'
|
||||||
|
END;
|
||||||
$$
|
$$
|
||||||
SELECT CASE
|
LANGUAGE SQL
|
||||||
WHEN surface IN ('paved', 'asphalt', 'cobblestone', 'concrete', 'concrete:lanes', 'concrete:plates', 'metal',
|
IMMUTABLE STRICT PARALLEL SAFE;
|
||||||
'paving_stones', 'sett', 'unhewn_cobblestone', 'wood') THEN 'paved'
|
|
||||||
WHEN surface IN ('unpaved', 'compacted', 'dirt', 'earth', 'fine_gravel', 'grass', 'grass_paver', 'gravel',
|
|
||||||
'gravel_turf', 'ground', 'ice', 'mud', 'pebblestone', 'salt', 'sand', 'snow', 'woodchips')
|
|
||||||
THEN 'unpaved'
|
|
||||||
END;
|
|
||||||
$$ LANGUAGE SQL IMMUTABLE
|
|
||||||
STRICT
|
|
||||||
PARALLEL SAFE;
|
|
||||||
|
|||||||
|
Before Width: | Height: | Size: 531 KiB After Width: | Height: | Size: 491 KiB |
373
layers/transportation/layer.sql
Normal file
@ -0,0 +1,373 @@
|
|||||||
|
CREATE OR REPLACE FUNCTION highway_is_link(highway TEXT) RETURNS BOOLEAN AS $$
|
||||||
|
SELECT highway LIKE '%_link';
|
||||||
|
$$
|
||||||
|
LANGUAGE SQL
|
||||||
|
IMMUTABLE STRICT PARALLEL SAFE;
|
||||||
|
|
||||||
|
|
||||||
|
-- etldoc: layer_transportation[shape=record fillcolor=lightpink, style="rounded,filled",
|
||||||
|
-- etldoc: label="<sql> layer_transportation |<z4> z4 |<z5> z5 |<z6> z6 |<z7> z7 |<z8> z8 |<z9> z9 |<z10> z10 |<z11> z11 |<z12> z12|<z13> z13|<z14_> z14+" ] ;
|
||||||
|
CREATE OR REPLACE FUNCTION layer_transportation(bbox geometry, zoom_level int)
|
||||||
|
RETURNS TABLE(osm_id bigint, geometry geometry, class text, subclass text,
|
||||||
|
ramp int, oneway int, brunnel TEXT, service TEXT, layer INT, level INT,
|
||||||
|
indoor INT, bicycle TEXT, foot TEXT, horse TEXT, mtb_scale TEXT, surface TEXT) AS $$
|
||||||
|
SELECT
|
||||||
|
osm_id, geometry,
|
||||||
|
CASE
|
||||||
|
WHEN NULLIF(highway, '') IS NOT NULL OR NULLIF(public_transport, '') IS NOT NULL THEN highway_class(highway, public_transport, construction)
|
||||||
|
WHEN NULLIF(railway, '') IS NOT NULL THEN railway_class(railway)
|
||||||
|
WHEN NULLIF(aerialway, '') IS NOT NULL THEN aerialway
|
||||||
|
WHEN NULLIF(shipway, '') IS NOT NULL THEN shipway
|
||||||
|
WHEN NULLIF(man_made, '') IS NOT NULL THEN man_made
|
||||||
|
END AS class,
|
||||||
|
CASE
|
||||||
|
WHEN railway IS NOT NULL THEN railway
|
||||||
|
WHEN (highway IS NOT NULL OR public_transport IS NOT NULL)
|
||||||
|
AND highway_class(highway, public_transport, construction) = 'path'
|
||||||
|
THEN COALESCE(NULLIF(public_transport, ''), highway)
|
||||||
|
END AS subclass,
|
||||||
|
-- All links are considered as ramps as well
|
||||||
|
CASE WHEN highway_is_link(highway) OR highway = 'steps'
|
||||||
|
THEN 1 ELSE is_ramp::int END AS ramp,
|
||||||
|
is_oneway::int AS oneway,
|
||||||
|
brunnel(is_bridge, is_tunnel, is_ford) AS brunnel,
|
||||||
|
NULLIF(service, '') AS service,
|
||||||
|
NULLIF(layer, 0) AS layer,
|
||||||
|
"level",
|
||||||
|
CASE WHEN indoor=TRUE THEN 1 END as indoor,
|
||||||
|
NULLIF(bicycle, '') AS bicycle,
|
||||||
|
NULLIF(foot, '') AS foot,
|
||||||
|
NULLIF(horse, '') AS horse,
|
||||||
|
NULLIF(mtb_scale, '') AS mtb_scale,
|
||||||
|
NULLIF(surface, '') AS surface
|
||||||
|
FROM (
|
||||||
|
-- etldoc: osm_transportation_merge_linestring_gen7 -> layer_transportation:z4
|
||||||
|
SELECT
|
||||||
|
osm_id, geometry,
|
||||||
|
highway, construction, NULL AS railway, NULL AS aerialway, NULL AS shipway,
|
||||||
|
NULL AS public_transport, NULL AS service,
|
||||||
|
NULL::boolean AS is_bridge, NULL::boolean AS is_tunnel,
|
||||||
|
NULL::boolean AS is_ford,
|
||||||
|
NULL::boolean AS is_ramp, NULL::int AS is_oneway, NULL as man_made,
|
||||||
|
NULL::int AS layer, NULL::int AS level, NULL::boolean AS indoor,
|
||||||
|
NULL as bicycle, NULL as foot, NULL as horse, NULL as mtb_scale,
|
||||||
|
NULL AS surface, z_order
|
||||||
|
FROM osm_transportation_merge_linestring_gen7
|
||||||
|
WHERE zoom_level = 4
|
||||||
|
UNION ALL
|
||||||
|
|
||||||
|
-- etldoc: osm_transportation_merge_linestring_gen6 -> layer_transportation:z5
|
||||||
|
SELECT
|
||||||
|
osm_id, geometry,
|
||||||
|
highway, construction, NULL AS railway, NULL AS aerialway, NULL AS shipway,
|
||||||
|
NULL AS public_transport, NULL AS service,
|
||||||
|
NULL::boolean AS is_bridge, NULL::boolean AS is_tunnel,
|
||||||
|
NULL::boolean AS is_ford,
|
||||||
|
NULL::boolean AS is_ramp, NULL::int AS is_oneway, NULL as man_made,
|
||||||
|
NULL::int AS layer, NULL::int AS level, NULL::boolean AS indoor,
|
||||||
|
NULL as bicycle, NULL as foot, NULL as horse, NULL as mtb_scale,
|
||||||
|
NULL AS surface, z_order
|
||||||
|
FROM osm_transportation_merge_linestring_gen6
|
||||||
|
WHERE zoom_level = 5
|
||||||
|
UNION ALL
|
||||||
|
|
||||||
|
-- etldoc: osm_transportation_merge_linestring_gen5 -> layer_transportation:z6
|
||||||
|
SELECT
|
||||||
|
osm_id, geometry,
|
||||||
|
highway, construction, NULL AS railway, NULL AS aerialway, NULL AS shipway,
|
||||||
|
NULL AS public_transport, NULL AS service,
|
||||||
|
NULL::boolean AS is_bridge, NULL::boolean AS is_tunnel,
|
||||||
|
NULL::boolean AS is_ford,
|
||||||
|
NULL::boolean AS is_ramp, NULL::int AS is_oneway, NULL as man_made,
|
||||||
|
NULL::int AS layer, NULL::int AS level, NULL::boolean AS indoor,
|
||||||
|
NULL as bicycle, NULL as foot, NULL as horse, NULL as mtb_scale,
|
||||||
|
NULL AS surface, z_order
|
||||||
|
FROM osm_transportation_merge_linestring_gen5
|
||||||
|
WHERE zoom_level = 6
|
||||||
|
UNION ALL
|
||||||
|
|
||||||
|
-- etldoc: osm_transportation_merge_linestring_gen4 -> layer_transportation:z7
|
||||||
|
SELECT
|
||||||
|
osm_id, geometry,
|
||||||
|
highway, construction, NULL AS railway, NULL AS aerialway, NULL AS shipway,
|
||||||
|
NULL AS public_transport, NULL AS service,
|
||||||
|
NULL::boolean AS is_bridge, NULL::boolean AS is_tunnel,
|
||||||
|
NULL::boolean AS is_ford,
|
||||||
|
NULL::boolean AS is_ramp, NULL::int AS is_oneway, NULL as man_made,
|
||||||
|
NULL::int AS layer, NULL::int AS level, NULL::boolean AS indoor,
|
||||||
|
NULL as bicycle, NULL as foot, NULL as horse, NULL as mtb_scale,
|
||||||
|
NULL AS surface, z_order
|
||||||
|
FROM osm_transportation_merge_linestring_gen4
|
||||||
|
WHERE zoom_level = 7
|
||||||
|
UNION ALL
|
||||||
|
|
||||||
|
-- etldoc: osm_transportation_merge_linestring_gen3 -> layer_transportation:z8
|
||||||
|
SELECT
|
||||||
|
osm_id, geometry,
|
||||||
|
highway, construction, NULL AS railway, NULL AS aerialway, NULL AS shipway,
|
||||||
|
NULL AS public_transport, NULL AS service,
|
||||||
|
NULL::boolean AS is_bridge, NULL::boolean AS is_tunnel,
|
||||||
|
NULL::boolean AS is_ford,
|
||||||
|
NULL::boolean AS is_ramp, NULL::int AS is_oneway, NULL as man_made,
|
||||||
|
NULL::int AS layer, NULL::int AS level, NULL::boolean AS indoor,
|
||||||
|
NULL as bicycle, NULL as foot, NULL as horse, NULL as mtb_scale,
|
||||||
|
NULL AS surface, z_order
|
||||||
|
FROM osm_transportation_merge_linestring_gen3
|
||||||
|
WHERE zoom_level = 8
|
||||||
|
UNION ALL
|
||||||
|
|
||||||
|
-- etldoc: osm_highway_linestring_gen2 -> layer_transportation:z9
|
||||||
|
-- etldoc: osm_highway_linestring_gen2 -> layer_transportation:z10
|
||||||
|
SELECT
|
||||||
|
osm_id, geometry,
|
||||||
|
highway, construction, NULL AS railway, NULL AS aerialway, NULL AS shipway,
|
||||||
|
NULL AS public_transport, NULL AS service,
|
||||||
|
NULL::boolean AS is_bridge, NULL::boolean AS is_tunnel,
|
||||||
|
NULL::boolean AS is_ford,
|
||||||
|
NULL::boolean AS is_ramp, NULL::int AS is_oneway, NULL as man_made,
|
||||||
|
layer, NULL::int AS level, NULL::boolean AS indoor,
|
||||||
|
bicycle, foot, horse, mtb_scale,
|
||||||
|
NULL AS surface, z_order
|
||||||
|
FROM osm_highway_linestring_gen2
|
||||||
|
WHERE zoom_level BETWEEN 9 AND 10
|
||||||
|
AND st_length(geometry)>zres(11)
|
||||||
|
UNION ALL
|
||||||
|
|
||||||
|
-- etldoc: osm_highway_linestring_gen1 -> layer_transportation:z11
|
||||||
|
SELECT
|
||||||
|
osm_id, geometry,
|
||||||
|
highway, construction, NULL AS railway, NULL AS aerialway, NULL AS shipway,
|
||||||
|
NULL AS public_transport, NULL AS service,
|
||||||
|
NULL::boolean AS is_bridge, NULL::boolean AS is_tunnel,
|
||||||
|
NULL::boolean AS is_ford,
|
||||||
|
NULL::boolean AS is_ramp, NULL::int AS is_oneway, NULL as man_made,
|
||||||
|
layer, NULL::int AS level, NULL::boolean AS indoor,
|
||||||
|
bicycle, foot, horse, mtb_scale,
|
||||||
|
NULL AS surface, z_order
|
||||||
|
FROM osm_highway_linestring_gen1
|
||||||
|
WHERE zoom_level = 11
|
||||||
|
AND st_length(geometry)>zres(12)
|
||||||
|
UNION ALL
|
||||||
|
|
||||||
|
-- etldoc: osm_highway_linestring -> layer_transportation:z12
|
||||||
|
-- etldoc: osm_highway_linestring -> layer_transportation:z13
|
||||||
|
-- etldoc: osm_highway_linestring -> layer_transportation:z14_
|
||||||
|
SELECT
|
||||||
|
osm_id, geometry,
|
||||||
|
highway, construction, NULL AS railway, NULL AS aerialway, NULL AS shipway,
|
||||||
|
public_transport, service_value(service) AS service,
|
||||||
|
is_bridge, is_tunnel, is_ford, is_ramp, is_oneway, man_made,
|
||||||
|
layer,
|
||||||
|
CASE WHEN highway IN ('footway', 'steps') THEN "level" END AS "level",
|
||||||
|
CASE WHEN highway IN ('footway', 'steps') THEN indoor END AS indoor,
|
||||||
|
bicycle, foot, horse, mtb_scale,
|
||||||
|
surface_value(surface) AS "surface",
|
||||||
|
z_order
|
||||||
|
FROM osm_highway_linestring
|
||||||
|
WHERE NOT is_area AND (
|
||||||
|
zoom_level = 12 AND (
|
||||||
|
highway_class(highway, public_transport, construction) NOT IN ('track', 'path', 'minor')
|
||||||
|
OR highway IN ('unclassified', 'residential')
|
||||||
|
) AND man_made <> 'pier'
|
||||||
|
OR zoom_level = 13
|
||||||
|
AND (
|
||||||
|
highway_class(highway, public_transport, construction) NOT IN ('track', 'path') AND man_made <> 'pier'
|
||||||
|
OR
|
||||||
|
man_made = 'pier' AND NOT ST_IsClosed(geometry)
|
||||||
|
)
|
||||||
|
OR zoom_level >= 14
|
||||||
|
AND (
|
||||||
|
man_made <> 'pier'
|
||||||
|
OR
|
||||||
|
NOT ST_IsClosed(geometry)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
UNION ALL
|
||||||
|
|
||||||
|
-- etldoc: osm_railway_linestring_gen5 -> layer_transportation:z8
|
||||||
|
SELECT
|
||||||
|
osm_id, geometry,
|
||||||
|
NULL AS highway, NULL AS construction, railway, NULL AS aerialway, NULL AS shipway,
|
||||||
|
NULL AS public_transport, service_value(service) AS service,
|
||||||
|
NULL::boolean AS is_bridge, NULL::boolean AS is_tunnel,
|
||||||
|
NULL::boolean AS is_ford,
|
||||||
|
NULL::boolean AS is_ramp, NULL::int AS is_oneway, NULL as man_made,
|
||||||
|
NULL::int AS layer, NULL::int AS level, NULL::boolean AS indoor,
|
||||||
|
NULL as bicycle, NULL as foot, NULL as horse, NULL as mtb_scale,
|
||||||
|
NULL as surface, z_order
|
||||||
|
FROM osm_railway_linestring_gen5
|
||||||
|
WHERE zoom_level = 8
|
||||||
|
AND railway='rail' AND service = '' and usage='main'
|
||||||
|
UNION ALL
|
||||||
|
|
||||||
|
-- etldoc: osm_railway_linestring_gen4 -> layer_transportation:z9
|
||||||
|
SELECT
|
||||||
|
osm_id, geometry,
|
||||||
|
NULL AS highway, NULL AS construction, railway, NULL AS aerialway, NULL AS shipway,
|
||||||
|
NULL AS public_transport, service_value(service) AS service,
|
||||||
|
NULL::boolean AS is_bridge, NULL::boolean AS is_tunnel,
|
||||||
|
NULL::boolean AS is_ford,
|
||||||
|
NULL::boolean AS is_ramp, NULL::int AS is_oneway, NULL as man_made,
|
||||||
|
layer, NULL::int AS level, NULL::boolean AS indoor,
|
||||||
|
NULL as bicycle, NULL as foot, NULL as horse, NULL as mtb_scale,
|
||||||
|
NULL AS surface, z_order
|
||||||
|
FROM osm_railway_linestring_gen4
|
||||||
|
WHERE zoom_level = 9
|
||||||
|
AND railway='rail' AND service = '' and usage='main'
|
||||||
|
UNION ALL
|
||||||
|
|
||||||
|
-- etldoc: osm_railway_linestring_gen3 -> layer_transportation:z10
|
||||||
|
SELECT
|
||||||
|
osm_id, geometry,
|
||||||
|
NULL AS highway, NULL AS construction, railway, NULL AS aerialway, NULL AS shipway,
|
||||||
|
NULL AS public_transport, service_value(service) AS service,
|
||||||
|
is_bridge, is_tunnel, is_ford, is_ramp, is_oneway, NULL as man_made,
|
||||||
|
layer, NULL::int AS level, NULL::boolean AS indoor,
|
||||||
|
NULL as bicycle, NULL as foot, NULL as horse, NULL as mtb_scale,
|
||||||
|
NULL AS surface, z_order
|
||||||
|
FROM osm_railway_linestring_gen3
|
||||||
|
WHERE zoom_level = 10
|
||||||
|
AND railway IN ('rail', 'narrow_gauge') AND service = ''
|
||||||
|
UNION ALL
|
||||||
|
|
||||||
|
-- etldoc: osm_railway_linestring_gen2 -> layer_transportation:z11
|
||||||
|
SELECT
|
||||||
|
osm_id, geometry,
|
||||||
|
NULL AS highway, NULL AS construction, railway, NULL AS aerialway, NULL AS shipway,
|
||||||
|
NULL AS public_transport, service_value(service) AS service,
|
||||||
|
is_bridge, is_tunnel, is_ford, is_ramp, is_oneway, NULL as man_made,
|
||||||
|
layer, NULL::int AS level, NULL::boolean AS indoor,
|
||||||
|
NULL as bicycle, NULL as foot, NULL as horse, NULL as mtb_scale,
|
||||||
|
NULL as surface, z_order
|
||||||
|
FROM osm_railway_linestring_gen2
|
||||||
|
WHERE zoom_level = 11
|
||||||
|
AND railway IN ('rail', 'narrow_gauge', 'light_rail') AND service = ''
|
||||||
|
UNION ALL
|
||||||
|
|
||||||
|
-- etldoc: osm_railway_linestring_gen1 -> layer_transportation:z12
|
||||||
|
SELECT
|
||||||
|
osm_id, geometry,
|
||||||
|
NULL AS highway, NULL AS construction, railway, NULL AS aerialway, NULL AS shipway,
|
||||||
|
NULL AS public_transport, service_value(service) AS service,
|
||||||
|
is_bridge, is_tunnel, is_ford, is_ramp, is_oneway, NULL as man_made,
|
||||||
|
layer, NULL::int AS level, NULL::boolean AS indoor,
|
||||||
|
NULL as bicycle, NULL as foot, NULL as horse, NULL as mtb_scale,
|
||||||
|
NULL as surface, z_order
|
||||||
|
FROM osm_railway_linestring_gen1
|
||||||
|
WHERE zoom_level = 12
|
||||||
|
AND railway IN ('rail', 'narrow_gauge', 'light_rail') AND service = ''
|
||||||
|
UNION ALL
|
||||||
|
|
||||||
|
-- etldoc: osm_railway_linestring -> layer_transportation:z13
|
||||||
|
-- etldoc: osm_railway_linestring -> layer_transportation:z14_
|
||||||
|
SELECT
|
||||||
|
osm_id, geometry,
|
||||||
|
NULL AS highway, NULL AS construction, railway, NULL AS aerialway, NULL AS shipway,
|
||||||
|
NULL AS public_transport, service_value(service) AS service,
|
||||||
|
is_bridge, is_tunnel, is_ford, is_ramp, is_oneway, NULL as man_made,
|
||||||
|
layer, NULL::int AS level, NULL::boolean AS indoor,
|
||||||
|
NULL as bicycle, NULL as foot, NULL as horse, NULL as mtb_scale,
|
||||||
|
NULL as surface, z_order
|
||||||
|
FROM osm_railway_linestring
|
||||||
|
WHERE zoom_level = 13
|
||||||
|
AND railway IN ('rail', 'narrow_gauge', 'light_rail') AND service = ''
|
||||||
|
OR zoom_Level >= 14
|
||||||
|
UNION ALL
|
||||||
|
|
||||||
|
-- etldoc: osm_aerialway_linestring_gen1 -> layer_transportation:z12
|
||||||
|
SELECT
|
||||||
|
osm_id, geometry,
|
||||||
|
NULL AS highway, NULL AS construction, NULL as railway, aerialway, NULL AS shipway,
|
||||||
|
NULL AS public_transport, service_value(service) AS service,
|
||||||
|
is_bridge, is_tunnel, is_ford, is_ramp, is_oneway, NULL as man_made,
|
||||||
|
layer, NULL::int AS level, NULL::boolean AS indoor,
|
||||||
|
NULL as bicycle, NULL as foot, NULL as horse, NULL as mtb_scale,
|
||||||
|
NULL AS surface, z_order
|
||||||
|
FROM osm_aerialway_linestring_gen1
|
||||||
|
WHERE zoom_level = 12
|
||||||
|
UNION ALL
|
||||||
|
|
||||||
|
-- etldoc: osm_aerialway_linestring -> layer_transportation:z13
|
||||||
|
-- etldoc: osm_aerialway_linestring -> layer_transportation:z14_
|
||||||
|
SELECT
|
||||||
|
osm_id, geometry,
|
||||||
|
NULL AS highway, NULL AS construction, NULL as railway, aerialway, NULL AS shipway,
|
||||||
|
NULL AS public_transport, service_value(service) AS service,
|
||||||
|
is_bridge, is_tunnel, is_ford, is_ramp, is_oneway, NULL as man_made,
|
||||||
|
layer, NULL::int AS level, NULL::boolean AS indoor,
|
||||||
|
NULL as bicycle, NULL as foot, NULL as horse, NULL as mtb_scale,
|
||||||
|
NULL AS surface, z_order
|
||||||
|
FROM osm_aerialway_linestring
|
||||||
|
WHERE zoom_level >= 13
|
||||||
|
UNION ALL
|
||||||
|
|
||||||
|
-- etldoc: osm_shipway_linestring_gen2 -> layer_transportation:z11
|
||||||
|
SELECT
|
||||||
|
osm_id, geometry,
|
||||||
|
NULL AS highway, NULL AS construction, NULL AS railway, NULL AS aerialway, shipway,
|
||||||
|
NULL AS public_transport, service_value(service) AS service,
|
||||||
|
is_bridge, is_tunnel, is_ford, is_ramp, is_oneway, NULL as man_made,
|
||||||
|
layer, NULL::int AS level, NULL::boolean AS indoor,
|
||||||
|
NULL as bicycle, NULL as foot, NULL as horse, NULL as mtb_scale,
|
||||||
|
NULL AS surface, z_order
|
||||||
|
FROM osm_shipway_linestring_gen2
|
||||||
|
WHERE zoom_level = 11
|
||||||
|
UNION ALL
|
||||||
|
|
||||||
|
-- etldoc: osm_shipway_linestring_gen1 -> layer_transportation:z12
|
||||||
|
SELECT
|
||||||
|
osm_id, geometry,
|
||||||
|
NULL AS highway, NULL AS construction, NULL AS railway, NULL AS aerialway, shipway,
|
||||||
|
NULL AS public_transport, service_value(service) AS service,
|
||||||
|
is_bridge, is_tunnel, is_ford, is_ramp, is_oneway, NULL as man_made,
|
||||||
|
layer, NULL::int AS level, NULL::boolean AS indoor,
|
||||||
|
NULL as bicycle, NULL as foot, NULL as horse, NULL as mtb_scale,
|
||||||
|
NULL AS surface, z_order
|
||||||
|
FROM osm_shipway_linestring_gen1
|
||||||
|
WHERE zoom_level = 12
|
||||||
|
UNION ALL
|
||||||
|
|
||||||
|
-- etldoc: osm_shipway_linestring -> layer_transportation:z13
|
||||||
|
-- etldoc: osm_shipway_linestring -> layer_transportation:z14_
|
||||||
|
SELECT
|
||||||
|
osm_id, geometry,
|
||||||
|
NULL AS highway, NULL AS construction, NULL AS railway, NULL AS aerialway, shipway,
|
||||||
|
NULL AS public_transport, service_value(service) AS service,
|
||||||
|
is_bridge, is_tunnel, is_ford, is_ramp, is_oneway, NULL as man_made,
|
||||||
|
layer, NULL::int AS level, NULL::boolean AS indoor,
|
||||||
|
NULL as bicycle, NULL as foot, NULL as horse, NULL as mtb_scale,
|
||||||
|
NULL AS surface, z_order
|
||||||
|
FROM osm_shipway_linestring
|
||||||
|
WHERE zoom_level >= 13
|
||||||
|
UNION ALL
|
||||||
|
|
||||||
|
-- NOTE: We limit the selection of polys because we need to be
|
||||||
|
-- careful to net get false positives here because
|
||||||
|
-- it is possible that closed linestrings appear both as
|
||||||
|
-- highway linestrings and as polygon
|
||||||
|
-- etldoc: osm_highway_polygon -> layer_transportation:z13
|
||||||
|
-- etldoc: osm_highway_polygon -> layer_transportation:z14_
|
||||||
|
SELECT
|
||||||
|
osm_id, geometry,
|
||||||
|
highway, NULL AS construction, NULL AS railway, NULL AS aerialway, NULL AS shipway,
|
||||||
|
public_transport, NULL AS service,
|
||||||
|
CASE WHEN man_made IN ('bridge') THEN TRUE
|
||||||
|
ELSE FALSE
|
||||||
|
END AS is_bridge, FALSE AS is_tunnel, FALSE AS is_ford,
|
||||||
|
FALSE AS is_ramp, FALSE::int AS is_oneway, man_made,
|
||||||
|
layer, NULL::int AS level, NULL::boolean AS indoor,
|
||||||
|
NULL as bicycle, NULL as foot, NULL as horse, NULL as mtb_scale,
|
||||||
|
NULL AS surface, z_order
|
||||||
|
FROM osm_highway_polygon
|
||||||
|
-- We do not want underground pedestrian areas for now
|
||||||
|
WHERE zoom_level >= 13
|
||||||
|
AND (
|
||||||
|
man_made IN ('bridge', 'pier')
|
||||||
|
OR (is_area AND COALESCE(layer, 0) >= 0)
|
||||||
|
)
|
||||||
|
) AS zoom_levels
|
||||||
|
WHERE geometry && bbox
|
||||||
|
ORDER BY z_order ASC;
|
||||||
|
$$
|
||||||
|
LANGUAGE SQL
|
||||||
|
IMMUTABLE PARALLEL SAFE;
|
||||||
@ -1,61 +1,55 @@
|
|||||||
generalized_tables:
|
generalized_tables:
|
||||||
# etldoc: osm_railway_linestring_gen_z9 -> osm_railway_linestring_gen_z8
|
# etldoc: imposm3 -> osm_railway_linestring_gen5
|
||||||
railway_linestring_gen_z8:
|
railway_linestring_gen5:
|
||||||
source: railway_linestring_gen_z9
|
source: railway_linestring_gen4
|
||||||
tolerance: ZRES9
|
tolerance: ZRES9
|
||||||
|
|
||||||
# etldoc: osm_railway_linestring_gen_z10 -> osm_railway_linestring_gen_z9
|
# etldoc: imposm3 -> osm_railway_linestring_gen4
|
||||||
railway_linestring_gen_z9:
|
railway_linestring_gen4:
|
||||||
source: railway_linestring_gen_z10
|
source: railway_linestring_gen3
|
||||||
tolerance: ZRES10
|
tolerance: ZRES10
|
||||||
|
|
||||||
# etldoc: osm_railway_linestring_gen_z11 -> osm_railway_linestring_gen_z10
|
# etldoc: imposm3 -> osm_railway_linestring_gen3
|
||||||
railway_linestring_gen_z10:
|
railway_linestring_gen3:
|
||||||
source: railway_linestring_gen_z11
|
source: railway_linestring_gen2
|
||||||
tolerance: ZRES11
|
tolerance: ZRES11
|
||||||
|
|
||||||
# etldoc: osm_railway_linestring_gen_z12 -> osm_railway_linestring_gen_z11
|
# etldoc: imposm3 -> osm_railway_linestring_gen2
|
||||||
railway_linestring_gen_z11:
|
railway_linestring_gen2:
|
||||||
source: railway_linestring_gen_z12
|
source: railway_linestring_gen1
|
||||||
tolerance: ZRES12
|
tolerance: ZRES12
|
||||||
|
|
||||||
# etldoc: osm_railway_linestring -> osm_railway_linestring_gen_z12
|
# etldoc: imposm3 -> osm_railway_linestring_gen1
|
||||||
railway_linestring_gen_z12:
|
railway_linestring_gen1:
|
||||||
source: railway_linestring
|
source: railway_linestring
|
||||||
sql_filter: railway IN ('rail', 'narrow_gauge', 'light_rail') AND service='' AND ST_IsValid(geometry)
|
sql_filter: railway IN ('rail', 'narrow_gauge', 'light_rail') AND service='' AND ST_IsValid(geometry)
|
||||||
tolerance: ZRES13
|
tolerance: ZRES13
|
||||||
|
|
||||||
# etldoc: osm_aerialway_linestring -> osm_aerialway_linestring_gen_z12
|
# etldoc: imposm3 -> osm_aerialway_linestring_gen1
|
||||||
aerialway_linestring_gen_z12:
|
aerialway_linestring_gen1:
|
||||||
source: aerialway_linestring
|
source: aerialway_linestring
|
||||||
sql_filter: ST_IsValid(geometry)
|
sql_filter: ST_IsValid(geometry)
|
||||||
tolerance: ZRES13
|
tolerance: ZRES13
|
||||||
|
|
||||||
# etldoc: osm_shipway_linestring_gen_z12 -> osm_shipway_linestring_gen_z11
|
# etldoc: imposm3 -> osm_shipway_linestring_gen2
|
||||||
shipway_linestring_gen_z11:
|
shipway_linestring_gen2:
|
||||||
source: shipway_linestring_gen_z12
|
source: shipway_linestring_gen1
|
||||||
tolerance: ZRES12
|
tolerance: ZRES12
|
||||||
|
|
||||||
# etldoc: osm_shipway_linestring -> osm_shipway_linestring_gen_z12
|
# etldoc: imposm3 -> osm_shipway_linestring_gen1
|
||||||
shipway_linestring_gen_z12:
|
shipway_linestring_gen1:
|
||||||
source: shipway_linestring
|
source: shipway_linestring
|
||||||
sql_filter: ST_IsValid(geometry)
|
sql_filter: ST_IsValid(geometry)
|
||||||
tolerance: ZRES13
|
tolerance: ZRES13
|
||||||
|
|
||||||
# etldoc: osm_highway_linestring_gen_z10 -> osm_highway_linestring_gen_z9
|
# etldoc: imposm3 -> osm_highway_linestring_gen2
|
||||||
highway_linestring_gen_z9:
|
highway_linestring_gen2:
|
||||||
source: highway_linestring_gen_z10
|
source: highway_linestring_gen1
|
||||||
sql_filter: (highway IN ('motorway', 'trunk', 'primary', 'secondary', 'motorway_link', 'trunk_link', 'primary_link', 'secondary_link') OR highway = 'construction' AND construction IN ('motorway', 'trunk', 'primary', 'secondary', 'motorway_link', 'trunk_link', 'primary_link', 'secondary_link')) AND NOT is_area
|
|
||||||
tolerance: ZRES10
|
|
||||||
|
|
||||||
# etldoc: osm_highway_linestring_gen_z11 -> osm_highway_linestring_gen_z10
|
|
||||||
highway_linestring_gen_z10:
|
|
||||||
source: highway_linestring_gen_z11
|
|
||||||
sql_filter: (highway IN ('motorway', 'trunk', 'primary', 'secondary', 'motorway_link', 'trunk_link', 'primary_link', 'secondary_link') OR highway = 'construction' AND construction IN ('motorway', 'trunk', 'primary', 'secondary', 'motorway_link', 'trunk_link', 'primary_link', 'secondary_link')) AND NOT is_area
|
sql_filter: (highway IN ('motorway', 'trunk', 'primary', 'secondary', 'motorway_link', 'trunk_link', 'primary_link', 'secondary_link') OR highway = 'construction' AND construction IN ('motorway', 'trunk', 'primary', 'secondary', 'motorway_link', 'trunk_link', 'primary_link', 'secondary_link')) AND NOT is_area
|
||||||
tolerance: ZRES11
|
tolerance: ZRES11
|
||||||
|
|
||||||
# etldoc: osm_highway_linestring -> osm_highway_linestring_gen_z11
|
# etldoc: imposm3 -> osm_highway_linestring_gen1
|
||||||
highway_linestring_gen_z11:
|
highway_linestring_gen1:
|
||||||
source: highway_linestring
|
source: highway_linestring
|
||||||
sql_filter: (highway IN ('motorway', 'trunk', 'primary', 'secondary', 'tertiary', 'motorway_link', 'trunk_link', 'primary_link', 'secondary_link', 'tertiary_link') OR highway = 'construction' AND construction IN ('motorway', 'trunk', 'primary', 'secondary', 'tertiary', 'motorway_link', 'trunk_link', 'primary_link', 'secondary_link', 'tertiary_link')) AND NOT is_area AND ST_IsValid(geometry)
|
sql_filter: (highway IN ('motorway', 'trunk', 'primary', 'secondary', 'tertiary', 'motorway_link', 'trunk_link', 'primary_link', 'secondary_link', 'tertiary_link') OR highway = 'construction' AND construction IN ('motorway', 'trunk', 'primary', 'secondary', 'tertiary', 'motorway_link', 'trunk_link', 'primary_link', 'secondary_link', 'tertiary_link')) AND NOT is_area AND ST_IsValid(geometry)
|
||||||
tolerance: ZRES12
|
tolerance: ZRES12
|
||||||
|
|||||||
@ -1,734 +0,0 @@
|
|||||||
CREATE OR REPLACE FUNCTION highway_is_link(highway text) RETURNS boolean AS
|
|
||||||
$$
|
|
||||||
SELECT highway LIKE '%_link';
|
|
||||||
$$ LANGUAGE SQL IMMUTABLE
|
|
||||||
STRICT
|
|
||||||
PARALLEL SAFE;
|
|
||||||
|
|
||||||
|
|
||||||
-- etldoc: layer_transportation[shape=record fillcolor=lightpink, style="rounded,filled",
|
|
||||||
-- etldoc: label="<sql> layer_transportation |<z4> z4 |<z5> z5 |<z6> z6 |<z7> z7 |<z8> z8 |<z9> z9 |<z10> z10 |<z11> z11 |<z12> z12|<z13> z13|<z14_> z14+" ] ;
|
|
||||||
CREATE OR REPLACE FUNCTION layer_transportation(bbox geometry, zoom_level int)
|
|
||||||
RETURNS TABLE
|
|
||||||
(
|
|
||||||
osm_id bigint,
|
|
||||||
geometry geometry,
|
|
||||||
class text,
|
|
||||||
subclass text,
|
|
||||||
ramp int,
|
|
||||||
oneway int,
|
|
||||||
brunnel text,
|
|
||||||
service text,
|
|
||||||
layer int,
|
|
||||||
level int,
|
|
||||||
indoor int,
|
|
||||||
bicycle text,
|
|
||||||
foot text,
|
|
||||||
horse text,
|
|
||||||
mtb_scale text,
|
|
||||||
surface text
|
|
||||||
)
|
|
||||||
AS
|
|
||||||
$$
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry,
|
|
||||||
CASE
|
|
||||||
WHEN NULLIF(highway, '') IS NOT NULL OR NULLIF(public_transport, '') IS NOT NULL
|
|
||||||
THEN highway_class(highway, public_transport, construction)
|
|
||||||
WHEN NULLIF(railway, '') IS NOT NULL THEN railway_class(railway)
|
|
||||||
WHEN NULLIF(aerialway, '') IS NOT NULL THEN 'aerialway'
|
|
||||||
WHEN NULLIF(shipway, '') IS NOT NULL THEN shipway
|
|
||||||
WHEN NULLIF(man_made, '') IS NOT NULL THEN man_made
|
|
||||||
END AS class,
|
|
||||||
CASE
|
|
||||||
WHEN railway IS NOT NULL THEN railway
|
|
||||||
WHEN (highway IS NOT NULL OR public_transport IS NOT NULL)
|
|
||||||
AND highway_class(highway, public_transport, construction) = 'path'
|
|
||||||
THEN COALESCE(NULLIF(public_transport, ''), highway)
|
|
||||||
WHEN aerialway IS NOT NULL THEN aerialway
|
|
||||||
END AS subclass,
|
|
||||||
-- All links are considered as ramps as well
|
|
||||||
CASE
|
|
||||||
WHEN highway_is_link(highway) OR highway = 'steps'
|
|
||||||
THEN 1
|
|
||||||
ELSE is_ramp::int END AS ramp,
|
|
||||||
is_oneway::int AS oneway,
|
|
||||||
brunnel(is_bridge, is_tunnel, is_ford) AS brunnel,
|
|
||||||
NULLIF(service, '') AS service,
|
|
||||||
NULLIF(layer, 0) AS layer,
|
|
||||||
"level",
|
|
||||||
CASE WHEN indoor = TRUE THEN 1 END AS indoor,
|
|
||||||
NULLIF(bicycle, '') AS bicycle,
|
|
||||||
NULLIF(foot, '') AS foot,
|
|
||||||
NULLIF(horse, '') AS horse,
|
|
||||||
NULLIF(mtb_scale, '') AS mtb_scale,
|
|
||||||
NULLIF(surface, '') AS surface
|
|
||||||
FROM (
|
|
||||||
-- etldoc: osm_transportation_merge_linestring_gen_z4 -> layer_transportation:z4
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry,
|
|
||||||
highway,
|
|
||||||
construction,
|
|
||||||
NULL AS railway,
|
|
||||||
NULL AS aerialway,
|
|
||||||
NULL AS shipway,
|
|
||||||
NULL AS public_transport,
|
|
||||||
NULL AS service,
|
|
||||||
is_bridge,
|
|
||||||
is_tunnel,
|
|
||||||
is_ford,
|
|
||||||
NULL::boolean AS is_ramp,
|
|
||||||
NULL::int AS is_oneway,
|
|
||||||
NULL AS man_made,
|
|
||||||
NULL::int AS layer,
|
|
||||||
NULL::int AS level,
|
|
||||||
NULL::boolean AS indoor,
|
|
||||||
NULL AS bicycle,
|
|
||||||
NULL AS foot,
|
|
||||||
NULL AS horse,
|
|
||||||
NULL AS mtb_scale,
|
|
||||||
NULL AS surface,
|
|
||||||
z_order
|
|
||||||
FROM osm_transportation_merge_linestring_gen_z4
|
|
||||||
WHERE zoom_level = 4
|
|
||||||
UNION ALL
|
|
||||||
|
|
||||||
-- etldoc: osm_transportation_merge_linestring_gen_z5 -> layer_transportation:z5
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry,
|
|
||||||
highway,
|
|
||||||
construction,
|
|
||||||
NULL AS railway,
|
|
||||||
NULL AS aerialway,
|
|
||||||
NULL AS shipway,
|
|
||||||
NULL AS public_transport,
|
|
||||||
NULL AS service,
|
|
||||||
is_bridge,
|
|
||||||
is_tunnel,
|
|
||||||
is_ford,
|
|
||||||
NULL::boolean AS is_ramp,
|
|
||||||
NULL::int AS is_oneway,
|
|
||||||
NULL AS man_made,
|
|
||||||
NULL::int AS layer,
|
|
||||||
NULL::int AS level,
|
|
||||||
NULL::boolean AS indoor,
|
|
||||||
NULL AS bicycle,
|
|
||||||
NULL AS foot,
|
|
||||||
NULL AS horse,
|
|
||||||
NULL AS mtb_scale,
|
|
||||||
NULL AS surface,
|
|
||||||
z_order
|
|
||||||
FROM osm_transportation_merge_linestring_gen_z5
|
|
||||||
WHERE zoom_level = 5
|
|
||||||
UNION ALL
|
|
||||||
|
|
||||||
-- etldoc: osm_transportation_merge_linestring_gen_z6 -> layer_transportation:z6
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry,
|
|
||||||
highway,
|
|
||||||
construction,
|
|
||||||
NULL AS railway,
|
|
||||||
NULL AS aerialway,
|
|
||||||
NULL AS shipway,
|
|
||||||
NULL AS public_transport,
|
|
||||||
NULL AS service,
|
|
||||||
is_bridge,
|
|
||||||
is_tunnel,
|
|
||||||
is_ford,
|
|
||||||
NULL::boolean AS is_ramp,
|
|
||||||
NULL::int AS is_oneway,
|
|
||||||
NULL AS man_made,
|
|
||||||
NULL::int AS layer,
|
|
||||||
NULL::int AS level,
|
|
||||||
NULL::boolean AS indoor,
|
|
||||||
NULL AS bicycle,
|
|
||||||
NULL AS foot,
|
|
||||||
NULL AS horse,
|
|
||||||
NULL AS mtb_scale,
|
|
||||||
NULL AS surface,
|
|
||||||
z_order
|
|
||||||
FROM osm_transportation_merge_linestring_gen_z6
|
|
||||||
WHERE zoom_level = 6
|
|
||||||
UNION ALL
|
|
||||||
|
|
||||||
-- etldoc: osm_transportation_merge_linestring_gen_z7 -> layer_transportation:z7
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry,
|
|
||||||
highway,
|
|
||||||
construction,
|
|
||||||
NULL AS railway,
|
|
||||||
NULL AS aerialway,
|
|
||||||
NULL AS shipway,
|
|
||||||
NULL AS public_transport,
|
|
||||||
NULL AS service,
|
|
||||||
is_bridge,
|
|
||||||
is_tunnel,
|
|
||||||
is_ford,
|
|
||||||
NULL::boolean AS is_ramp,
|
|
||||||
NULL::int AS is_oneway,
|
|
||||||
NULL AS man_made,
|
|
||||||
NULL::int AS layer,
|
|
||||||
NULL::int AS level,
|
|
||||||
NULL::boolean AS indoor,
|
|
||||||
NULL AS bicycle,
|
|
||||||
NULL AS foot,
|
|
||||||
NULL AS horse,
|
|
||||||
NULL AS mtb_scale,
|
|
||||||
NULL AS surface,
|
|
||||||
z_order
|
|
||||||
FROM osm_transportation_merge_linestring_gen_z7
|
|
||||||
WHERE zoom_level = 7
|
|
||||||
UNION ALL
|
|
||||||
|
|
||||||
-- etldoc: osm_transportation_merge_linestring_gen_z8 -> layer_transportation:z8
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry,
|
|
||||||
highway,
|
|
||||||
construction,
|
|
||||||
NULL AS railway,
|
|
||||||
NULL AS aerialway,
|
|
||||||
NULL AS shipway,
|
|
||||||
NULL AS public_transport,
|
|
||||||
NULL AS service,
|
|
||||||
is_bridge,
|
|
||||||
is_tunnel,
|
|
||||||
is_ford,
|
|
||||||
NULL::boolean AS is_ramp,
|
|
||||||
NULL::int AS is_oneway,
|
|
||||||
NULL AS man_made,
|
|
||||||
NULL::int AS layer,
|
|
||||||
NULL::int AS level,
|
|
||||||
NULL::boolean AS indoor,
|
|
||||||
NULL AS bicycle,
|
|
||||||
NULL AS foot,
|
|
||||||
NULL AS horse,
|
|
||||||
NULL AS mtb_scale,
|
|
||||||
NULL AS surface,
|
|
||||||
z_order
|
|
||||||
FROM osm_transportation_merge_linestring_gen_z8
|
|
||||||
WHERE zoom_level = 8
|
|
||||||
UNION ALL
|
|
||||||
|
|
||||||
-- etldoc: osm_highway_linestring_gen_z9 -> layer_transportation:z9
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry,
|
|
||||||
highway,
|
|
||||||
construction,
|
|
||||||
NULL AS railway,
|
|
||||||
NULL AS aerialway,
|
|
||||||
NULL AS shipway,
|
|
||||||
NULL AS public_transport,
|
|
||||||
NULL AS service,
|
|
||||||
is_bridge,
|
|
||||||
is_tunnel,
|
|
||||||
is_ford,
|
|
||||||
NULL::boolean AS is_ramp,
|
|
||||||
NULL::int AS is_oneway,
|
|
||||||
NULL AS man_made,
|
|
||||||
layer,
|
|
||||||
NULL::int AS level,
|
|
||||||
NULL::boolean AS indoor,
|
|
||||||
bicycle,
|
|
||||||
foot,
|
|
||||||
horse,
|
|
||||||
mtb_scale,
|
|
||||||
NULL AS surface,
|
|
||||||
z_order
|
|
||||||
FROM osm_highway_linestring_gen_z9
|
|
||||||
WHERE zoom_level = 9
|
|
||||||
AND ST_Length(geometry) > ZRes(11)
|
|
||||||
UNION ALL
|
|
||||||
|
|
||||||
-- etldoc: osm_highway_linestring_gen_z10 -> layer_transportation:z10
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry,
|
|
||||||
highway,
|
|
||||||
construction,
|
|
||||||
NULL AS railway,
|
|
||||||
NULL AS aerialway,
|
|
||||||
NULL AS shipway,
|
|
||||||
NULL AS public_transport,
|
|
||||||
NULL AS service,
|
|
||||||
is_bridge,
|
|
||||||
is_tunnel,
|
|
||||||
is_ford,
|
|
||||||
NULL::boolean AS is_ramp,
|
|
||||||
NULL::int AS is_oneway,
|
|
||||||
NULL AS man_made,
|
|
||||||
layer,
|
|
||||||
NULL::int AS level,
|
|
||||||
NULL::boolean AS indoor,
|
|
||||||
bicycle,
|
|
||||||
foot,
|
|
||||||
horse,
|
|
||||||
mtb_scale,
|
|
||||||
NULL AS surface,
|
|
||||||
z_order
|
|
||||||
FROM osm_highway_linestring_gen_z10
|
|
||||||
WHERE zoom_level = 10
|
|
||||||
AND ST_Length(geometry) > ZRes(11)
|
|
||||||
UNION ALL
|
|
||||||
|
|
||||||
-- etldoc: osm_highway_linestring_gen_z11 -> layer_transportation:z11
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry,
|
|
||||||
highway,
|
|
||||||
construction,
|
|
||||||
NULL AS railway,
|
|
||||||
NULL AS aerialway,
|
|
||||||
NULL AS shipway,
|
|
||||||
NULL AS public_transport,
|
|
||||||
NULL AS service,
|
|
||||||
is_bridge,
|
|
||||||
is_tunnel,
|
|
||||||
is_ford,
|
|
||||||
NULL::boolean AS is_ramp,
|
|
||||||
NULL::int AS is_oneway,
|
|
||||||
NULL AS man_made,
|
|
||||||
layer,
|
|
||||||
NULL::int AS level,
|
|
||||||
NULL::boolean AS indoor,
|
|
||||||
bicycle,
|
|
||||||
foot,
|
|
||||||
horse,
|
|
||||||
mtb_scale,
|
|
||||||
NULL AS surface,
|
|
||||||
z_order
|
|
||||||
FROM osm_highway_linestring_gen_z11
|
|
||||||
WHERE zoom_level = 11
|
|
||||||
AND ST_Length(geometry) > ZRes(12)
|
|
||||||
UNION ALL
|
|
||||||
|
|
||||||
-- etldoc: osm_highway_linestring -> layer_transportation:z12
|
|
||||||
-- etldoc: osm_highway_linestring -> layer_transportation:z13
|
|
||||||
-- etldoc: osm_highway_linestring -> layer_transportation:z14_
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry,
|
|
||||||
highway,
|
|
||||||
construction,
|
|
||||||
NULL AS railway,
|
|
||||||
NULL AS aerialway,
|
|
||||||
NULL AS shipway,
|
|
||||||
public_transport,
|
|
||||||
service_value(service) AS service,
|
|
||||||
is_bridge,
|
|
||||||
is_tunnel,
|
|
||||||
is_ford,
|
|
||||||
is_ramp,
|
|
||||||
is_oneway,
|
|
||||||
man_made,
|
|
||||||
layer,
|
|
||||||
CASE WHEN highway IN ('footway', 'steps') THEN "level" END AS "level",
|
|
||||||
CASE WHEN highway IN ('footway', 'steps') THEN indoor END AS indoor,
|
|
||||||
bicycle,
|
|
||||||
foot,
|
|
||||||
horse,
|
|
||||||
mtb_scale,
|
|
||||||
surface_value(surface) AS "surface",
|
|
||||||
z_order
|
|
||||||
FROM osm_highway_linestring
|
|
||||||
WHERE NOT is_area
|
|
||||||
AND (
|
|
||||||
zoom_level = 12 AND (
|
|
||||||
highway_class(highway, public_transport, construction) NOT IN ('track', 'path', 'minor')
|
|
||||||
OR highway IN ('unclassified', 'residential')
|
|
||||||
) AND man_made <> 'pier'
|
|
||||||
OR zoom_level = 13
|
|
||||||
AND (
|
|
||||||
highway_class(highway, public_transport, construction) NOT IN ('track', 'path') AND
|
|
||||||
man_made <> 'pier'
|
|
||||||
OR
|
|
||||||
man_made = 'pier' AND NOT ST_IsClosed(geometry)
|
|
||||||
)
|
|
||||||
OR zoom_level >= 14
|
|
||||||
AND (
|
|
||||||
man_made <> 'pier'
|
|
||||||
OR
|
|
||||||
NOT ST_IsClosed(geometry)
|
|
||||||
)
|
|
||||||
)
|
|
||||||
UNION ALL
|
|
||||||
|
|
||||||
-- etldoc: osm_railway_linestring_gen_z8 -> layer_transportation:z8
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry,
|
|
||||||
NULL AS highway,
|
|
||||||
NULL AS construction,
|
|
||||||
railway,
|
|
||||||
NULL AS aerialway,
|
|
||||||
NULL AS shipway,
|
|
||||||
NULL AS public_transport,
|
|
||||||
service_value(service) AS service,
|
|
||||||
NULL::boolean AS is_bridge,
|
|
||||||
NULL::boolean AS is_tunnel,
|
|
||||||
NULL::boolean AS is_ford,
|
|
||||||
NULL::boolean AS is_ramp,
|
|
||||||
NULL::int AS is_oneway,
|
|
||||||
NULL AS man_made,
|
|
||||||
NULL::int AS layer,
|
|
||||||
NULL::int AS level,
|
|
||||||
NULL::boolean AS indoor,
|
|
||||||
NULL AS bicycle,
|
|
||||||
NULL AS foot,
|
|
||||||
NULL AS horse,
|
|
||||||
NULL AS mtb_scale,
|
|
||||||
NULL AS surface,
|
|
||||||
z_order
|
|
||||||
FROM osm_railway_linestring_gen_z8
|
|
||||||
WHERE zoom_level = 8
|
|
||||||
AND railway = 'rail'
|
|
||||||
AND service = ''
|
|
||||||
AND usage = 'main'
|
|
||||||
UNION ALL
|
|
||||||
|
|
||||||
-- etldoc: osm_railway_linestring_gen_z9 -> layer_transportation:z9
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry,
|
|
||||||
NULL AS highway,
|
|
||||||
NULL AS construction,
|
|
||||||
railway,
|
|
||||||
NULL AS aerialway,
|
|
||||||
NULL AS shipway,
|
|
||||||
NULL AS public_transport,
|
|
||||||
service_value(service) AS service,
|
|
||||||
NULL::boolean AS is_bridge,
|
|
||||||
NULL::boolean AS is_tunnel,
|
|
||||||
NULL::boolean AS is_ford,
|
|
||||||
NULL::boolean AS is_ramp,
|
|
||||||
NULL::int AS is_oneway,
|
|
||||||
NULL AS man_made,
|
|
||||||
layer,
|
|
||||||
NULL::int AS level,
|
|
||||||
NULL::boolean AS indoor,
|
|
||||||
NULL AS bicycle,
|
|
||||||
NULL AS foot,
|
|
||||||
NULL AS horse,
|
|
||||||
NULL AS mtb_scale,
|
|
||||||
NULL AS surface,
|
|
||||||
z_order
|
|
||||||
FROM osm_railway_linestring_gen_z9
|
|
||||||
WHERE zoom_level = 9
|
|
||||||
AND railway = 'rail'
|
|
||||||
AND service = ''
|
|
||||||
AND usage = 'main'
|
|
||||||
UNION ALL
|
|
||||||
|
|
||||||
-- etldoc: osm_railway_linestring_gen_z10 -> layer_transportation:z10
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry,
|
|
||||||
NULL AS highway,
|
|
||||||
NULL AS construction,
|
|
||||||
railway,
|
|
||||||
NULL AS aerialway,
|
|
||||||
NULL AS shipway,
|
|
||||||
NULL AS public_transport,
|
|
||||||
service_value(service) AS service,
|
|
||||||
is_bridge,
|
|
||||||
is_tunnel,
|
|
||||||
is_ford,
|
|
||||||
is_ramp,
|
|
||||||
is_oneway,
|
|
||||||
NULL AS man_made,
|
|
||||||
layer,
|
|
||||||
NULL::int AS level,
|
|
||||||
NULL::boolean AS indoor,
|
|
||||||
NULL AS bicycle,
|
|
||||||
NULL AS foot,
|
|
||||||
NULL AS horse,
|
|
||||||
NULL AS mtb_scale,
|
|
||||||
NULL AS surface,
|
|
||||||
z_order
|
|
||||||
FROM osm_railway_linestring_gen_z10
|
|
||||||
WHERE zoom_level = 10
|
|
||||||
AND railway IN ('rail', 'narrow_gauge')
|
|
||||||
AND service = ''
|
|
||||||
UNION ALL
|
|
||||||
|
|
||||||
-- etldoc: osm_railway_linestring_gen_z11 -> layer_transportation:z11
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry,
|
|
||||||
NULL AS highway,
|
|
||||||
NULL AS construction,
|
|
||||||
railway,
|
|
||||||
NULL AS aerialway,
|
|
||||||
NULL AS shipway,
|
|
||||||
NULL AS public_transport,
|
|
||||||
service_value(service) AS service,
|
|
||||||
is_bridge,
|
|
||||||
is_tunnel,
|
|
||||||
is_ford,
|
|
||||||
is_ramp,
|
|
||||||
is_oneway,
|
|
||||||
NULL AS man_made,
|
|
||||||
layer,
|
|
||||||
NULL::int AS level,
|
|
||||||
NULL::boolean AS indoor,
|
|
||||||
NULL AS bicycle,
|
|
||||||
NULL AS foot,
|
|
||||||
NULL AS horse,
|
|
||||||
NULL AS mtb_scale,
|
|
||||||
NULL AS surface,
|
|
||||||
z_order
|
|
||||||
FROM osm_railway_linestring_gen_z11
|
|
||||||
WHERE zoom_level = 11
|
|
||||||
AND railway IN ('rail', 'narrow_gauge', 'light_rail')
|
|
||||||
AND service = ''
|
|
||||||
UNION ALL
|
|
||||||
|
|
||||||
-- etldoc: osm_railway_linestring_gen_z12 -> layer_transportation:z12
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry,
|
|
||||||
NULL AS highway,
|
|
||||||
NULL AS construction,
|
|
||||||
railway,
|
|
||||||
NULL AS aerialway,
|
|
||||||
NULL AS shipway,
|
|
||||||
NULL AS public_transport,
|
|
||||||
service_value(service) AS service,
|
|
||||||
is_bridge,
|
|
||||||
is_tunnel,
|
|
||||||
is_ford,
|
|
||||||
is_ramp,
|
|
||||||
is_oneway,
|
|
||||||
NULL AS man_made,
|
|
||||||
layer,
|
|
||||||
NULL::int AS level,
|
|
||||||
NULL::boolean AS indoor,
|
|
||||||
NULL AS bicycle,
|
|
||||||
NULL AS foot,
|
|
||||||
NULL AS horse,
|
|
||||||
NULL AS mtb_scale,
|
|
||||||
NULL AS surface,
|
|
||||||
z_order
|
|
||||||
FROM osm_railway_linestring_gen_z12
|
|
||||||
WHERE zoom_level = 12
|
|
||||||
AND railway IN ('rail', 'narrow_gauge', 'light_rail')
|
|
||||||
AND service = ''
|
|
||||||
UNION ALL
|
|
||||||
|
|
||||||
-- etldoc: osm_railway_linestring -> layer_transportation:z13
|
|
||||||
-- etldoc: osm_railway_linestring -> layer_transportation:z14_
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry,
|
|
||||||
NULL AS highway,
|
|
||||||
NULL AS construction,
|
|
||||||
railway,
|
|
||||||
NULL AS aerialway,
|
|
||||||
NULL AS shipway,
|
|
||||||
NULL AS public_transport,
|
|
||||||
service_value(service) AS service,
|
|
||||||
is_bridge,
|
|
||||||
is_tunnel,
|
|
||||||
is_ford,
|
|
||||||
is_ramp,
|
|
||||||
is_oneway,
|
|
||||||
NULL AS man_made,
|
|
||||||
layer,
|
|
||||||
NULL::int AS level,
|
|
||||||
NULL::boolean AS indoor,
|
|
||||||
NULL AS bicycle,
|
|
||||||
NULL AS foot,
|
|
||||||
NULL AS horse,
|
|
||||||
NULL AS mtb_scale,
|
|
||||||
NULL AS surface,
|
|
||||||
z_order
|
|
||||||
FROM osm_railway_linestring
|
|
||||||
WHERE zoom_level = 13
|
|
||||||
AND railway IN ('rail', 'narrow_gauge', 'light_rail')
|
|
||||||
AND service = ''
|
|
||||||
OR zoom_level >= 14
|
|
||||||
UNION ALL
|
|
||||||
|
|
||||||
-- etldoc: osm_aerialway_linestring_gen_z12 -> layer_transportation:z12
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry,
|
|
||||||
NULL AS highway,
|
|
||||||
NULL AS construction,
|
|
||||||
NULL AS railway,
|
|
||||||
aerialway,
|
|
||||||
NULL AS shipway,
|
|
||||||
NULL AS public_transport,
|
|
||||||
service_value(service) AS service,
|
|
||||||
is_bridge,
|
|
||||||
is_tunnel,
|
|
||||||
is_ford,
|
|
||||||
is_ramp,
|
|
||||||
is_oneway,
|
|
||||||
NULL AS man_made,
|
|
||||||
layer,
|
|
||||||
NULL::int AS level,
|
|
||||||
NULL::boolean AS indoor,
|
|
||||||
NULL AS bicycle,
|
|
||||||
NULL AS foot,
|
|
||||||
NULL AS horse,
|
|
||||||
NULL AS mtb_scale,
|
|
||||||
NULL AS surface,
|
|
||||||
z_order
|
|
||||||
FROM osm_aerialway_linestring_gen_z12
|
|
||||||
WHERE zoom_level = 12
|
|
||||||
UNION ALL
|
|
||||||
|
|
||||||
-- etldoc: osm_aerialway_linestring -> layer_transportation:z13
|
|
||||||
-- etldoc: osm_aerialway_linestring -> layer_transportation:z14_
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry,
|
|
||||||
NULL AS highway,
|
|
||||||
NULL AS construction,
|
|
||||||
NULL AS railway,
|
|
||||||
aerialway,
|
|
||||||
NULL AS shipway,
|
|
||||||
NULL AS public_transport,
|
|
||||||
service_value(service) AS service,
|
|
||||||
is_bridge,
|
|
||||||
is_tunnel,
|
|
||||||
is_ford,
|
|
||||||
is_ramp,
|
|
||||||
is_oneway,
|
|
||||||
NULL AS man_made,
|
|
||||||
layer,
|
|
||||||
NULL::int AS level,
|
|
||||||
NULL::boolean AS indoor,
|
|
||||||
NULL AS bicycle,
|
|
||||||
NULL AS foot,
|
|
||||||
NULL AS horse,
|
|
||||||
NULL AS mtb_scale,
|
|
||||||
NULL AS surface,
|
|
||||||
z_order
|
|
||||||
FROM osm_aerialway_linestring
|
|
||||||
WHERE zoom_level >= 13
|
|
||||||
UNION ALL
|
|
||||||
|
|
||||||
-- etldoc: osm_shipway_linestring_gen_z11 -> layer_transportation:z11
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry,
|
|
||||||
NULL AS highway,
|
|
||||||
NULL AS construction,
|
|
||||||
NULL AS railway,
|
|
||||||
NULL AS aerialway,
|
|
||||||
shipway,
|
|
||||||
NULL AS public_transport,
|
|
||||||
service_value(service) AS service,
|
|
||||||
is_bridge,
|
|
||||||
is_tunnel,
|
|
||||||
is_ford,
|
|
||||||
is_ramp,
|
|
||||||
is_oneway,
|
|
||||||
NULL AS man_made,
|
|
||||||
layer,
|
|
||||||
NULL::int AS level,
|
|
||||||
NULL::boolean AS indoor,
|
|
||||||
NULL AS bicycle,
|
|
||||||
NULL AS foot,
|
|
||||||
NULL AS horse,
|
|
||||||
NULL AS mtb_scale,
|
|
||||||
NULL AS surface,
|
|
||||||
z_order
|
|
||||||
FROM osm_shipway_linestring_gen_z11
|
|
||||||
WHERE zoom_level = 11
|
|
||||||
UNION ALL
|
|
||||||
|
|
||||||
-- etldoc: osm_shipway_linestring_gen_z12 -> layer_transportation:z12
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry,
|
|
||||||
NULL AS highway,
|
|
||||||
NULL AS construction,
|
|
||||||
NULL AS railway,
|
|
||||||
NULL AS aerialway,
|
|
||||||
shipway,
|
|
||||||
NULL AS public_transport,
|
|
||||||
service_value(service) AS service,
|
|
||||||
is_bridge,
|
|
||||||
is_tunnel,
|
|
||||||
is_ford,
|
|
||||||
is_ramp,
|
|
||||||
is_oneway,
|
|
||||||
NULL AS man_made,
|
|
||||||
layer,
|
|
||||||
NULL::int AS level,
|
|
||||||
NULL::boolean AS indoor,
|
|
||||||
NULL AS bicycle,
|
|
||||||
NULL AS foot,
|
|
||||||
NULL AS horse,
|
|
||||||
NULL AS mtb_scale,
|
|
||||||
NULL AS surface,
|
|
||||||
z_order
|
|
||||||
FROM osm_shipway_linestring_gen_z12
|
|
||||||
WHERE zoom_level = 12
|
|
||||||
UNION ALL
|
|
||||||
|
|
||||||
-- etldoc: osm_shipway_linestring -> layer_transportation:z13
|
|
||||||
-- etldoc: osm_shipway_linestring -> layer_transportation:z14_
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry,
|
|
||||||
NULL AS highway,
|
|
||||||
NULL AS construction,
|
|
||||||
NULL AS railway,
|
|
||||||
NULL AS aerialway,
|
|
||||||
shipway,
|
|
||||||
NULL AS public_transport,
|
|
||||||
service_value(service) AS service,
|
|
||||||
is_bridge,
|
|
||||||
is_tunnel,
|
|
||||||
is_ford,
|
|
||||||
is_ramp,
|
|
||||||
is_oneway,
|
|
||||||
NULL AS man_made,
|
|
||||||
layer,
|
|
||||||
NULL::int AS level,
|
|
||||||
NULL::boolean AS indoor,
|
|
||||||
NULL AS bicycle,
|
|
||||||
NULL AS foot,
|
|
||||||
NULL AS horse,
|
|
||||||
NULL AS mtb_scale,
|
|
||||||
NULL AS surface,
|
|
||||||
z_order
|
|
||||||
FROM osm_shipway_linestring
|
|
||||||
WHERE zoom_level >= 13
|
|
||||||
UNION ALL
|
|
||||||
|
|
||||||
-- NOTE: We limit the selection of polys because we need to be
|
|
||||||
-- careful to net get false positives here because
|
|
||||||
-- it is possible that closed linestrings appear both as
|
|
||||||
-- highway linestrings and as polygon
|
|
||||||
-- etldoc: osm_highway_polygon -> layer_transportation:z13
|
|
||||||
-- etldoc: osm_highway_polygon -> layer_transportation:z14_
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry,
|
|
||||||
highway,
|
|
||||||
NULL AS construction,
|
|
||||||
NULL AS railway,
|
|
||||||
NULL AS aerialway,
|
|
||||||
NULL AS shipway,
|
|
||||||
public_transport,
|
|
||||||
NULL AS service,
|
|
||||||
CASE
|
|
||||||
WHEN man_made IN ('bridge') THEN TRUE
|
|
||||||
ELSE FALSE
|
|
||||||
END AS is_bridge,
|
|
||||||
FALSE AS is_tunnel,
|
|
||||||
FALSE AS is_ford,
|
|
||||||
FALSE AS is_ramp,
|
|
||||||
FALSE::int AS is_oneway,
|
|
||||||
man_made,
|
|
||||||
layer,
|
|
||||||
NULL::int AS level,
|
|
||||||
NULL::boolean AS indoor,
|
|
||||||
NULL AS bicycle,
|
|
||||||
NULL AS foot,
|
|
||||||
NULL AS horse,
|
|
||||||
NULL AS mtb_scale,
|
|
||||||
NULL AS surface,
|
|
||||||
z_order
|
|
||||||
FROM osm_highway_polygon
|
|
||||||
-- We do not want underground pedestrian areas for now
|
|
||||||
WHERE zoom_level >= 13
|
|
||||||
AND (
|
|
||||||
man_made IN ('bridge', 'pier')
|
|
||||||
OR (is_area AND COALESCE(layer, 0) >= 0)
|
|
||||||
)
|
|
||||||
) AS zoom_levels
|
|
||||||
WHERE geometry && bbox
|
|
||||||
ORDER BY z_order ASC;
|
|
||||||
$$ LANGUAGE SQL STABLE
|
|
||||||
-- STRICT
|
|
||||||
PARALLEL SAFE;
|
|
||||||
@ -178,7 +178,7 @@ layer:
|
|||||||
schema:
|
schema:
|
||||||
- ./class.sql
|
- ./class.sql
|
||||||
- ./update_transportation_merge.sql
|
- ./update_transportation_merge.sql
|
||||||
- ./transportation.sql
|
- ./layer.sql
|
||||||
datasources:
|
datasources:
|
||||||
- type: imposm3
|
- type: imposm3
|
||||||
mapping_file: ./mapping.yaml
|
mapping_file: ./mapping.yaml
|
||||||
|
|||||||
@ -1,3 +1,11 @@
|
|||||||
|
DROP MATERIALIZED VIEW IF EXISTS osm_transportation_merge_linestring CASCADE;
|
||||||
|
DROP MATERIALIZED VIEW IF EXISTS osm_transportation_merge_linestring_gen3 CASCADE;
|
||||||
|
DROP MATERIALIZED VIEW IF EXISTS osm_transportation_merge_linestring_gen4 CASCADE;
|
||||||
|
DROP MATERIALIZED VIEW IF EXISTS osm_transportation_merge_linestring_gen5 CASCADE;
|
||||||
|
DROP MATERIALIZED VIEW IF EXISTS osm_transportation_merge_linestring_gen6 CASCADE;
|
||||||
|
DROP MATERIALIZED VIEW IF EXISTS osm_transportation_merge_linestring_gen7 CASCADE;
|
||||||
|
|
||||||
|
|
||||||
DROP TRIGGER IF EXISTS trigger_flag_transportation ON osm_highway_linestring;
|
DROP TRIGGER IF EXISTS trigger_flag_transportation ON osm_highway_linestring;
|
||||||
DROP TRIGGER IF EXISTS trigger_refresh ON transportation.updates;
|
DROP TRIGGER IF EXISTS trigger_refresh ON transportation.updates;
|
||||||
|
|
||||||
@ -8,184 +16,134 @@ DROP TRIGGER IF EXISTS trigger_refresh ON transportation.updates;
|
|||||||
|
|
||||||
|
|
||||||
-- Improve performance of the sql in transportation_name/network_type.sql
|
-- Improve performance of the sql in transportation_name/network_type.sql
|
||||||
|
CREATE INDEX IF NOT EXISTS osm_highway_linestring_highway_idx
|
||||||
|
ON osm_highway_linestring(highway);
|
||||||
|
|
||||||
|
-- Improve performance of the sql below
|
||||||
CREATE INDEX IF NOT EXISTS osm_highway_linestring_highway_partial_idx
|
CREATE INDEX IF NOT EXISTS osm_highway_linestring_highway_partial_idx
|
||||||
ON osm_highway_linestring (highway)
|
ON osm_highway_linestring(highway)
|
||||||
WHERE highway IN ('motorway', 'trunk', 'primary', 'construction');
|
WHERE highway IN ('motorway','trunk', 'primary', 'construction');
|
||||||
|
|
||||||
-- etldoc: osm_highway_linestring -> osm_transportation_merge_linestring
|
-- etldoc: osm_highway_linestring -> osm_transportation_merge_linestring
|
||||||
DROP MATERIALIZED VIEW IF EXISTS osm_transportation_merge_linestring CASCADE;
|
CREATE MATERIALIZED VIEW osm_transportation_merge_linestring AS (
|
||||||
CREATE MATERIALIZED VIEW osm_transportation_merge_linestring AS
|
SELECT
|
||||||
(
|
(ST_Dump(geometry)).geom AS geometry,
|
||||||
SELECT (ST_Dump(geometry)).geom AS geometry,
|
NULL::bigint AS osm_id,
|
||||||
NULL::bigint AS osm_id,
|
highway, construction,
|
||||||
highway,
|
z_order
|
||||||
construction,
|
FROM (
|
||||||
is_bridge,
|
SELECT
|
||||||
is_tunnel,
|
ST_LineMerge(ST_Collect(geometry)) AS geometry,
|
||||||
is_ford,
|
highway, construction,
|
||||||
z_order
|
min(z_order) AS z_order
|
||||||
FROM (
|
FROM osm_highway_linestring
|
||||||
SELECT ST_LineMerge(ST_Collect(geometry)) AS geometry,
|
WHERE (highway IN ('motorway','trunk', 'primary') OR highway = 'construction' AND construction IN ('motorway','trunk', 'primary'))
|
||||||
highway,
|
AND ST_IsValid(geometry)
|
||||||
construction,
|
group by highway, construction
|
||||||
is_bridge,
|
) AS highway_union
|
||||||
is_tunnel,
|
) /* DELAY_MATERIALIZED_VIEW_CREATION */;
|
||||||
is_ford,
|
|
||||||
min(z_order) AS z_order
|
|
||||||
FROM osm_highway_linestring
|
|
||||||
WHERE (highway IN ('motorway', 'trunk', 'primary') OR
|
|
||||||
highway = 'construction' AND construction IN ('motorway', 'trunk', 'primary'))
|
|
||||||
AND ST_IsValid(geometry)
|
|
||||||
GROUP BY highway, construction, is_bridge, is_tunnel, is_ford
|
|
||||||
) AS highway_union
|
|
||||||
) /* DELAY_MATERIALIZED_VIEW_CREATION */;
|
|
||||||
CREATE INDEX IF NOT EXISTS osm_transportation_merge_linestring_geometry_idx
|
CREATE INDEX IF NOT EXISTS osm_transportation_merge_linestring_geometry_idx
|
||||||
ON osm_transportation_merge_linestring USING gist (geometry);
|
ON osm_transportation_merge_linestring USING gist(geometry);
|
||||||
|
CREATE INDEX IF NOT EXISTS osm_transportation_merge_linestring_highway_partial_idx
|
||||||
|
ON osm_transportation_merge_linestring(highway, construction)
|
||||||
|
WHERE highway IN ('motorway','trunk', 'primary', 'construction');
|
||||||
|
|
||||||
-- etldoc: osm_transportation_merge_linestring -> osm_transportation_merge_linestring_gen_z8
|
-- etldoc: osm_transportation_merge_linestring -> osm_transportation_merge_linestring_gen3
|
||||||
DROP MATERIALIZED VIEW IF EXISTS osm_transportation_merge_linestring_gen_z8 CASCADE;
|
CREATE MATERIALIZED VIEW osm_transportation_merge_linestring_gen3 AS (
|
||||||
CREATE MATERIALIZED VIEW osm_transportation_merge_linestring_gen_z8 AS
|
SELECT ST_Simplify(geometry, 120) AS geometry, osm_id, highway, construction, z_order
|
||||||
(
|
FROM osm_transportation_merge_linestring
|
||||||
SELECT ST_Simplify(geometry, ZRes(10)) AS geometry,
|
WHERE highway IN ('motorway','trunk', 'primary')
|
||||||
osm_id,
|
OR highway = 'construction' AND construction IN ('motorway','trunk', 'primary')
|
||||||
highway,
|
) /* DELAY_MATERIALIZED_VIEW_CREATION */;
|
||||||
construction,
|
CREATE INDEX IF NOT EXISTS osm_transportation_merge_linestring_gen3_geometry_idx
|
||||||
is_bridge,
|
ON osm_transportation_merge_linestring_gen3 USING gist(geometry);
|
||||||
is_tunnel,
|
CREATE INDEX IF NOT EXISTS osm_transportation_merge_linestring_gen3_highway_partial_idx
|
||||||
is_ford,
|
ON osm_transportation_merge_linestring_gen3(highway, construction)
|
||||||
z_order
|
WHERE highway IN ('motorway','trunk', 'primary', 'construction');
|
||||||
FROM osm_transportation_merge_linestring
|
|
||||||
WHERE highway IN ('motorway', 'trunk', 'primary')
|
|
||||||
OR highway = 'construction' AND construction IN ('motorway', 'trunk', 'primary')
|
|
||||||
) /* DELAY_MATERIALIZED_VIEW_CREATION */;
|
|
||||||
CREATE INDEX IF NOT EXISTS osm_transportation_merge_linestring_gen_z8_geometry_idx
|
|
||||||
ON osm_transportation_merge_linestring_gen_z8 USING gist (geometry);
|
|
||||||
|
|
||||||
-- etldoc: osm_transportation_merge_linestring_gen_z8 -> osm_transportation_merge_linestring_gen_z7
|
-- etldoc: osm_transportation_merge_linestring_gen3 -> osm_transportation_merge_linestring_gen4
|
||||||
DROP MATERIALIZED VIEW IF EXISTS osm_transportation_merge_linestring_gen_z7 CASCADE;
|
CREATE MATERIALIZED VIEW osm_transportation_merge_linestring_gen4 AS (
|
||||||
CREATE MATERIALIZED VIEW osm_transportation_merge_linestring_gen_z7 AS
|
SELECT ST_Simplify(geometry, 200) AS geometry, osm_id, highway, construction, z_order
|
||||||
(
|
FROM osm_transportation_merge_linestring_gen3
|
||||||
SELECT ST_Simplify(geometry, ZRes(9)) AS geometry,
|
WHERE (highway IN ('motorway','trunk', 'primary') OR highway = 'construction' AND construction IN ('motorway','trunk', 'primary'))
|
||||||
osm_id,
|
AND ST_Length(geometry) > 50
|
||||||
highway,
|
) /* DELAY_MATERIALIZED_VIEW_CREATION */;
|
||||||
construction,
|
CREATE INDEX IF NOT EXISTS osm_transportation_merge_linestring_gen4_geometry_idx
|
||||||
is_bridge,
|
ON osm_transportation_merge_linestring_gen4 USING gist(geometry);
|
||||||
is_tunnel,
|
CREATE INDEX IF NOT EXISTS osm_transportation_merge_linestring_gen4_highway_partial_idx
|
||||||
is_ford,
|
ON osm_transportation_merge_linestring_gen4(highway, construction)
|
||||||
z_order
|
WHERE highway IN ('motorway','trunk', 'primary', 'construction');
|
||||||
FROM osm_transportation_merge_linestring_gen_z8
|
|
||||||
WHERE (highway IN ('motorway', 'trunk', 'primary') OR
|
|
||||||
highway = 'construction' AND construction IN ('motorway', 'trunk', 'primary'))
|
|
||||||
AND ST_Length(geometry) > 50
|
|
||||||
) /* DELAY_MATERIALIZED_VIEW_CREATION */;
|
|
||||||
CREATE INDEX IF NOT EXISTS osm_transportation_merge_linestring_gen_z7_geometry_idx
|
|
||||||
ON osm_transportation_merge_linestring_gen_z7 USING gist (geometry);
|
|
||||||
|
|
||||||
-- etldoc: osm_transportation_merge_linestring_gen_z7 -> osm_transportation_merge_linestring_gen_z6
|
-- etldoc: osm_transportation_merge_linestring_gen4 -> osm_transportation_merge_linestring_gen5
|
||||||
DROP MATERIALIZED VIEW IF EXISTS osm_transportation_merge_linestring_gen_z6 CASCADE;
|
CREATE MATERIALIZED VIEW osm_transportation_merge_linestring_gen5 AS (
|
||||||
CREATE MATERIALIZED VIEW osm_transportation_merge_linestring_gen_z6 AS
|
SELECT ST_Simplify(geometry, 500) AS geometry, osm_id, highway, construction, z_order
|
||||||
(
|
FROM osm_transportation_merge_linestring_gen4
|
||||||
SELECT ST_Simplify(geometry, ZRes(8)) AS geometry,
|
WHERE (highway IN ('motorway','trunk') OR highway = 'construction' AND construction IN ('motorway','trunk'))
|
||||||
osm_id,
|
AND ST_Length(geometry) > 100
|
||||||
highway,
|
) /* DELAY_MATERIALIZED_VIEW_CREATION */;
|
||||||
construction,
|
CREATE INDEX IF NOT EXISTS osm_transportation_merge_linestring_gen5_geometry_idx
|
||||||
is_bridge,
|
ON osm_transportation_merge_linestring_gen5 USING gist(geometry);
|
||||||
is_tunnel,
|
CREATE INDEX IF NOT EXISTS osm_transportation_merge_linestring_gen5_highway_partial_idx
|
||||||
is_ford,
|
ON osm_transportation_merge_linestring_gen5(highway, construction)
|
||||||
z_order
|
WHERE highway IN ('motorway','trunk', 'construction');
|
||||||
FROM osm_transportation_merge_linestring_gen_z7
|
|
||||||
WHERE (highway IN ('motorway', 'trunk') OR highway = 'construction' AND construction IN ('motorway', 'trunk'))
|
|
||||||
AND ST_Length(geometry) > 100
|
|
||||||
) /* DELAY_MATERIALIZED_VIEW_CREATION */;
|
|
||||||
CREATE INDEX IF NOT EXISTS osm_transportation_merge_linestring_gen_z6_geometry_idx
|
|
||||||
ON osm_transportation_merge_linestring_gen_z6 USING gist (geometry);
|
|
||||||
|
|
||||||
-- etldoc: osm_transportation_merge_linestring_gen_z6 -> osm_transportation_merge_linestring_gen_z5
|
-- etldoc: osm_transportation_merge_linestring_gen5 -> osm_transportation_merge_linestring_gen6
|
||||||
DROP MATERIALIZED VIEW IF EXISTS osm_transportation_merge_linestring_gen_z5 CASCADE;
|
CREATE MATERIALIZED VIEW osm_transportation_merge_linestring_gen6 AS (
|
||||||
CREATE MATERIALIZED VIEW osm_transportation_merge_linestring_gen_z5 AS
|
SELECT ST_Simplify(geometry, 1000) AS geometry, osm_id, highway, construction, z_order
|
||||||
(
|
FROM osm_transportation_merge_linestring_gen5
|
||||||
SELECT ST_Simplify(geometry, ZRes(7)) AS geometry,
|
WHERE (highway IN ('motorway','trunk') OR highway = 'construction' AND construction IN ('motorway','trunk')) AND ST_Length(geometry) > 500
|
||||||
osm_id,
|
) /* DELAY_MATERIALIZED_VIEW_CREATION */;
|
||||||
highway,
|
CREATE INDEX IF NOT EXISTS osm_transportation_merge_linestring_gen6_geometry_idx
|
||||||
construction,
|
ON osm_transportation_merge_linestring_gen6 USING gist(geometry);
|
||||||
is_bridge,
|
CREATE INDEX IF NOT EXISTS osm_transportation_merge_linestring_gen6_highway_partial_idx
|
||||||
is_tunnel,
|
ON osm_transportation_merge_linestring_gen6(highway, construction)
|
||||||
is_ford,
|
WHERE highway IN ('motorway','trunk', 'construction');
|
||||||
z_order
|
|
||||||
FROM osm_transportation_merge_linestring_gen_z6
|
|
||||||
WHERE (highway IN ('motorway', 'trunk') OR highway = 'construction' AND construction IN ('motorway', 'trunk'))
|
|
||||||
AND ST_Length(geometry) > 500
|
|
||||||
) /* DELAY_MATERIALIZED_VIEW_CREATION */;
|
|
||||||
CREATE INDEX IF NOT EXISTS osm_transportation_merge_linestring_gen_z5_geometry_idx
|
|
||||||
ON osm_transportation_merge_linestring_gen_z5 USING gist (geometry);
|
|
||||||
|
|
||||||
-- etldoc: osm_transportation_merge_linestring_gen_z5 -> osm_transportation_merge_linestring_gen_z4
|
-- etldoc: osm_transportation_merge_linestring_gen6 -> osm_transportation_merge_linestring_gen7
|
||||||
DROP MATERIALIZED VIEW IF EXISTS osm_transportation_merge_linestring_gen_z4 CASCADE;
|
CREATE MATERIALIZED VIEW osm_transportation_merge_linestring_gen7 AS (
|
||||||
CREATE MATERIALIZED VIEW osm_transportation_merge_linestring_gen_z4 AS
|
SELECT ST_Simplify(geometry, 2000) AS geometry, osm_id, highway, construction, z_order
|
||||||
(
|
FROM osm_transportation_merge_linestring_gen6
|
||||||
SELECT ST_Simplify(geometry, ZRes(6)) AS geometry,
|
WHERE (highway = 'motorway' OR highway = 'construction' AND construction = 'motorway') AND ST_Length(geometry) > 1000
|
||||||
osm_id,
|
) /* DELAY_MATERIALIZED_VIEW_CREATION */;
|
||||||
highway,
|
CREATE INDEX IF NOT EXISTS osm_transportation_merge_linestring_gen7_geometry_idx
|
||||||
construction,
|
ON osm_transportation_merge_linestring_gen7 USING gist(geometry);
|
||||||
is_bridge,
|
|
||||||
is_tunnel,
|
|
||||||
is_ford,
|
|
||||||
z_order
|
|
||||||
FROM osm_transportation_merge_linestring_gen_z5
|
|
||||||
WHERE (highway = 'motorway' OR highway = 'construction' AND construction = 'motorway')
|
|
||||||
AND ST_Length(geometry) > 1000
|
|
||||||
) /* DELAY_MATERIALIZED_VIEW_CREATION */;
|
|
||||||
CREATE INDEX IF NOT EXISTS osm_transportation_merge_linestring_gen_z4_geometry_idx
|
|
||||||
ON osm_transportation_merge_linestring_gen_z4 USING gist (geometry);
|
|
||||||
|
|
||||||
|
|
||||||
-- Handle updates
|
-- Handle updates
|
||||||
|
|
||||||
CREATE SCHEMA IF NOT EXISTS transportation;
|
CREATE SCHEMA IF NOT EXISTS transportation;
|
||||||
|
|
||||||
CREATE TABLE IF NOT EXISTS transportation.updates
|
CREATE TABLE IF NOT EXISTS transportation.updates(id serial primary key, t text, unique (t));
|
||||||
(
|
CREATE OR REPLACE FUNCTION transportation.flag() RETURNS trigger AS $$
|
||||||
id serial PRIMARY KEY,
|
|
||||||
t text,
|
|
||||||
UNIQUE (t)
|
|
||||||
);
|
|
||||||
CREATE OR REPLACE FUNCTION transportation.flag() RETURNS trigger AS
|
|
||||||
$$
|
|
||||||
BEGIN
|
BEGIN
|
||||||
INSERT INTO transportation.updates(t) VALUES ('y') ON CONFLICT(t) DO NOTHING;
|
INSERT INTO transportation.updates(t) VALUES ('y') ON CONFLICT(t) DO NOTHING;
|
||||||
RETURN NULL;
|
RETURN null;
|
||||||
END;
|
END;
|
||||||
$$ LANGUAGE plpgsql;
|
$$ language plpgsql;
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION transportation.refresh() RETURNS trigger AS
|
CREATE OR REPLACE FUNCTION transportation.refresh() RETURNS trigger AS
|
||||||
$$
|
$BODY$
|
||||||
DECLARE
|
BEGIN
|
||||||
t TIMESTAMP WITH TIME ZONE := clock_timestamp();
|
RAISE NOTICE 'Refresh transportation';
|
||||||
BEGIN
|
|
||||||
RAISE LOG 'Refresh transportation';
|
|
||||||
REFRESH MATERIALIZED VIEW osm_transportation_merge_linestring;
|
REFRESH MATERIALIZED VIEW osm_transportation_merge_linestring;
|
||||||
REFRESH MATERIALIZED VIEW osm_transportation_merge_linestring_gen_z8;
|
REFRESH MATERIALIZED VIEW osm_transportation_merge_linestring_gen3;
|
||||||
REFRESH MATERIALIZED VIEW osm_transportation_merge_linestring_gen_z7;
|
REFRESH MATERIALIZED VIEW osm_transportation_merge_linestring_gen4;
|
||||||
REFRESH MATERIALIZED VIEW osm_transportation_merge_linestring_gen_z6;
|
REFRESH MATERIALIZED VIEW osm_transportation_merge_linestring_gen5;
|
||||||
REFRESH MATERIALIZED VIEW osm_transportation_merge_linestring_gen_z5;
|
REFRESH MATERIALIZED VIEW osm_transportation_merge_linestring_gen6;
|
||||||
REFRESH MATERIALIZED VIEW osm_transportation_merge_linestring_gen_z4;
|
REFRESH MATERIALIZED VIEW osm_transportation_merge_linestring_gen7;
|
||||||
-- noinspection SqlWithoutWhere
|
|
||||||
DELETE FROM transportation.updates;
|
DELETE FROM transportation.updates;
|
||||||
|
RETURN null;
|
||||||
RAISE LOG 'Refresh transportation done in %', age(clock_timestamp(), t);
|
END;
|
||||||
RETURN NULL;
|
$BODY$
|
||||||
END;
|
language plpgsql;
|
||||||
$$ LANGUAGE plpgsql;
|
|
||||||
|
|
||||||
CREATE TRIGGER trigger_flag_transportation
|
CREATE TRIGGER trigger_flag_transportation
|
||||||
AFTER INSERT OR UPDATE OR DELETE
|
AFTER INSERT OR UPDATE OR DELETE ON osm_highway_linestring
|
||||||
ON osm_highway_linestring
|
|
||||||
FOR EACH STATEMENT
|
FOR EACH STATEMENT
|
||||||
EXECUTE PROCEDURE transportation.flag();
|
EXECUTE PROCEDURE transportation.flag();
|
||||||
|
|
||||||
CREATE CONSTRAINT TRIGGER trigger_refresh
|
CREATE CONSTRAINT TRIGGER trigger_refresh
|
||||||
AFTER INSERT
|
AFTER INSERT ON transportation.updates
|
||||||
ON transportation.updates
|
|
||||||
INITIALLY DEFERRED
|
INITIALLY DEFERRED
|
||||||
FOR EACH ROW
|
FOR EACH ROW
|
||||||
EXECUTE PROCEDURE transportation.refresh();
|
EXECUTE PROCEDURE transportation.refresh();
|
||||||
|
|||||||
|
Before Width: | Height: | Size: 225 KiB After Width: | Height: | Size: 334 KiB |
131
layers/transportation_name/layer.sql
Normal file
@ -0,0 +1,131 @@
|
|||||||
|
|
||||||
|
-- etldoc: layer_transportation_name[shape=record fillcolor=lightpink, style="rounded,filled",
|
||||||
|
-- etldoc: label="layer_transportation_name | <z6> z6 | <z7> z7 | <z8> z8 |<z9> z9 |<z10> z10 |<z11> z11 |<z12> z12|<z13> z13|<z14_> z14+" ] ;
|
||||||
|
|
||||||
|
CREATE OR REPLACE FUNCTION layer_transportation_name(bbox geometry, zoom_level integer)
|
||||||
|
RETURNS TABLE(osm_id bigint, geometry geometry, name text, name_en text,
|
||||||
|
name_de text, tags hstore, ref text, ref_length int, network text, class
|
||||||
|
text, subclass text, layer INT, level INT, indoor INT) AS $$
|
||||||
|
SELECT osm_id, geometry,
|
||||||
|
NULLIF(name, '') AS name,
|
||||||
|
COALESCE(NULLIF(name_en, ''), name) AS name_en,
|
||||||
|
COALESCE(NULLIF(name_de, ''), name, name_en) AS name_de,
|
||||||
|
tags,
|
||||||
|
NULLIF(ref, ''), NULLIF(LENGTH(ref), 0) AS ref_length,
|
||||||
|
--TODO: The road network of the road is not yet implemented
|
||||||
|
case
|
||||||
|
when network is not null
|
||||||
|
then network::text
|
||||||
|
when length(coalesce(ref, ''))>0
|
||||||
|
then 'road'
|
||||||
|
end as network,
|
||||||
|
highway_class(highway, '', construction) AS class,
|
||||||
|
CASE
|
||||||
|
WHEN highway IS NOT NULL AND highway_class(highway, '', construction) = 'path'
|
||||||
|
THEN highway
|
||||||
|
END AS subclass,
|
||||||
|
NULLIF(layer, 0) AS layer,
|
||||||
|
"level",
|
||||||
|
CASE WHEN indoor=TRUE THEN 1 END as indoor
|
||||||
|
FROM (
|
||||||
|
|
||||||
|
-- etldoc: osm_transportation_name_linestring_gen4 -> layer_transportation_name:z6
|
||||||
|
SELECT *,
|
||||||
|
NULL::int AS layer, NULL::int AS level, NULL::boolean AS indoor
|
||||||
|
FROM osm_transportation_name_linestring_gen4
|
||||||
|
WHERE zoom_level = 6
|
||||||
|
UNION ALL
|
||||||
|
|
||||||
|
-- etldoc: osm_transportation_name_linestring_gen3 -> layer_transportation_name:z7
|
||||||
|
SELECT *,
|
||||||
|
NULL::int AS layer, NULL::int AS level, NULL::boolean AS indoor
|
||||||
|
FROM osm_transportation_name_linestring_gen3
|
||||||
|
WHERE zoom_level = 7
|
||||||
|
UNION ALL
|
||||||
|
|
||||||
|
-- etldoc: osm_transportation_name_linestring_gen2 -> layer_transportation_name:z8
|
||||||
|
SELECT *,
|
||||||
|
NULL::int AS layer, NULL::int AS level, NULL::boolean AS indoor
|
||||||
|
FROM osm_transportation_name_linestring_gen2
|
||||||
|
WHERE zoom_level = 8
|
||||||
|
UNION ALL
|
||||||
|
|
||||||
|
-- etldoc: osm_transportation_name_linestring_gen1 -> layer_transportation_name:z9
|
||||||
|
-- etldoc: osm_transportation_name_linestring_gen1 -> layer_transportation_name:z10
|
||||||
|
-- etldoc: osm_transportation_name_linestring_gen1 -> layer_transportation_name:z11
|
||||||
|
SELECT *,
|
||||||
|
NULL::int AS layer, NULL::int AS level, NULL::boolean AS indoor
|
||||||
|
FROM osm_transportation_name_linestring_gen1
|
||||||
|
WHERE zoom_level BETWEEN 9 AND 11
|
||||||
|
UNION ALL
|
||||||
|
|
||||||
|
-- etldoc: osm_transportation_name_linestring -> layer_transportation_name:z12
|
||||||
|
SELECT
|
||||||
|
geometry,
|
||||||
|
osm_id,
|
||||||
|
name,
|
||||||
|
name_en,
|
||||||
|
name_de,
|
||||||
|
"tags",
|
||||||
|
ref,
|
||||||
|
highway,
|
||||||
|
construction,
|
||||||
|
network,
|
||||||
|
z_order,
|
||||||
|
layer,
|
||||||
|
"level",
|
||||||
|
indoor
|
||||||
|
FROM osm_transportation_name_linestring
|
||||||
|
WHERE zoom_level = 12
|
||||||
|
AND LineLabel(zoom_level, COALESCE(NULLIF(name, ''), ref), geometry)
|
||||||
|
AND highway_class(highway, '', construction) NOT IN ('minor', 'track', 'path')
|
||||||
|
AND NOT highway_is_link(highway)
|
||||||
|
UNION ALL
|
||||||
|
|
||||||
|
-- etldoc: osm_transportation_name_linestring -> layer_transportation_name:z13
|
||||||
|
SELECT
|
||||||
|
geometry,
|
||||||
|
osm_id,
|
||||||
|
name,
|
||||||
|
name_en,
|
||||||
|
name_de,
|
||||||
|
"tags",
|
||||||
|
ref,
|
||||||
|
highway,
|
||||||
|
construction,
|
||||||
|
network,
|
||||||
|
z_order,
|
||||||
|
layer,
|
||||||
|
"level",
|
||||||
|
indoor
|
||||||
|
FROM osm_transportation_name_linestring
|
||||||
|
WHERE zoom_level = 13
|
||||||
|
AND LineLabel(zoom_level, COALESCE(NULLIF(name, ''), ref), geometry)
|
||||||
|
AND highway_class(highway, '', construction) NOT IN ('track', 'path')
|
||||||
|
UNION ALL
|
||||||
|
|
||||||
|
-- etldoc: osm_transportation_name_linestring -> layer_transportation_name:z14_
|
||||||
|
SELECT
|
||||||
|
geometry,
|
||||||
|
osm_id,
|
||||||
|
name,
|
||||||
|
name_en,
|
||||||
|
name_de,
|
||||||
|
"tags",
|
||||||
|
ref,
|
||||||
|
highway,
|
||||||
|
construction,
|
||||||
|
network,
|
||||||
|
z_order,
|
||||||
|
layer,
|
||||||
|
"level",
|
||||||
|
indoor
|
||||||
|
FROM osm_transportation_name_linestring
|
||||||
|
WHERE zoom_level >= 14
|
||||||
|
|
||||||
|
) AS zoom_levels
|
||||||
|
WHERE geometry && bbox
|
||||||
|
ORDER BY z_order ASC;
|
||||||
|
$$
|
||||||
|
LANGUAGE SQL
|
||||||
|
IMMUTABLE PARALLEL SAFE;
|
||||||
@ -1,33 +1,30 @@
|
|||||||
DROP TRIGGER IF EXISTS trigger_store_transportation_route_member ON osm_route_member;
|
DROP MATERIALIZED VIEW IF EXISTS osm_transportation_name_network CASCADE;
|
||||||
DROP TRIGGER IF EXISTS trigger_store_transportation_highway_linestring ON osm_highway_linestring;
|
DROP MATERIALIZED VIEW IF EXISTS osm_transportation_name_linestring CASCADE;
|
||||||
DROP TRIGGER IF EXISTS trigger_flag_transportation_name ON transportation_name.network_changes;
|
DROP MATERIALIZED VIEW IF EXISTS osm_transportation_name_linestring_gen1 CASCADE;
|
||||||
DROP TRIGGER IF EXISTS trigger_refresh_network ON transportation_name.updates_network;
|
DROP MATERIALIZED VIEW IF EXISTS osm_transportation_name_linestring_gen2 CASCADE;
|
||||||
|
DROP MATERIALIZED VIEW IF EXISTS osm_transportation_name_linestring_gen3 CASCADE;
|
||||||
|
DROP MATERIALIZED VIEW IF EXISTS osm_transportation_name_linestring_gen4 CASCADE;
|
||||||
|
|
||||||
DROP TRIGGER IF EXISTS trigger_store_transportation_name_network ON osm_transportation_name_network;
|
DO $$
|
||||||
DROP TRIGGER IF EXISTS trigger_flag_name ON transportation_name.name_changes;
|
BEGIN
|
||||||
DROP TRIGGER IF EXISTS trigger_refresh_name ON transportation_name.updates_name;
|
IF NOT EXISTS (SELECT 1 FROM pg_type WHERE typname = 'route_network_type') THEN
|
||||||
|
CREATE TYPE route_network_type AS ENUM (
|
||||||
DO
|
'us-interstate', 'us-highway', 'us-state',
|
||||||
|
'ca-transcanada',
|
||||||
|
'gb-motorway', 'gb-trunk'
|
||||||
|
);
|
||||||
|
END IF;
|
||||||
|
END
|
||||||
$$
|
$$
|
||||||
BEGIN
|
;
|
||||||
IF NOT EXISTS(SELECT 1 FROM pg_type WHERE typname = 'route_network_type') THEN
|
|
||||||
CREATE TYPE route_network_type AS enum (
|
|
||||||
'us-interstate', 'us-highway', 'us-state',
|
|
||||||
'ca-transcanada',
|
|
||||||
'gb-motorway', 'gb-trunk'
|
|
||||||
);
|
|
||||||
END IF;
|
|
||||||
END
|
|
||||||
$$;
|
|
||||||
|
|
||||||
DO
|
DO $$
|
||||||
$$
|
|
||||||
BEGIN
|
BEGIN
|
||||||
BEGIN
|
BEGIN
|
||||||
ALTER TABLE osm_route_member
|
ALTER TABLE osm_route_member ADD COLUMN network_type route_network_type;
|
||||||
ADD COLUMN network_type route_network_type;
|
|
||||||
EXCEPTION
|
EXCEPTION
|
||||||
WHEN duplicate_column THEN RAISE NOTICE 'column network_type already exists in network_type.';
|
WHEN duplicate_column THEN RAISE NOTICE 'column network_type already exists in network_type.';
|
||||||
END;
|
END;
|
||||||
END;
|
END;
|
||||||
$$;
|
$$
|
||||||
|
;
|
||||||
|
|||||||
@ -1,157 +0,0 @@
|
|||||||
-- etldoc: layer_transportation_name[shape=record fillcolor=lightpink, style="rounded,filled",
|
|
||||||
-- etldoc: label="layer_transportation_name | <z6> z6 | <z7> z7 | <z8> z8 |<z9> z9 |<z10> z10 |<z11> z11 |<z12> z12|<z13> z13|<z14_> z14+" ] ;
|
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION layer_transportation_name(bbox geometry, zoom_level integer)
|
|
||||||
RETURNS TABLE
|
|
||||||
(
|
|
||||||
osm_id bigint,
|
|
||||||
geometry geometry,
|
|
||||||
name text,
|
|
||||||
name_en text,
|
|
||||||
name_de text,
|
|
||||||
tags hstore,
|
|
||||||
ref text,
|
|
||||||
ref_length int,
|
|
||||||
network text,
|
|
||||||
class text,
|
|
||||||
subclass text,
|
|
||||||
brunnel text,
|
|
||||||
layer int,
|
|
||||||
level int,
|
|
||||||
indoor int
|
|
||||||
)
|
|
||||||
AS
|
|
||||||
$$
|
|
||||||
SELECT osm_id,
|
|
||||||
geometry,
|
|
||||||
name,
|
|
||||||
COALESCE(name_en, name) AS name_en,
|
|
||||||
COALESCE(name_de, name, name_en) AS name_de,
|
|
||||||
tags,
|
|
||||||
ref,
|
|
||||||
NULLIF(LENGTH(ref), 0) AS ref_length,
|
|
||||||
--TODO: The road network of the road is not yet implemented
|
|
||||||
CASE
|
|
||||||
WHEN network IS NOT NULL
|
|
||||||
THEN network::text
|
|
||||||
WHEN length(coalesce(ref, '')) > 0
|
|
||||||
THEN 'road'
|
|
||||||
END AS network,
|
|
||||||
highway_class(highway, '', construction) AS class,
|
|
||||||
CASE
|
|
||||||
WHEN highway IS NOT NULL AND highway_class(highway, '', construction) = 'path'
|
|
||||||
THEN highway
|
|
||||||
END AS subclass,
|
|
||||||
brunnel,
|
|
||||||
NULLIF(layer, 0) AS layer,
|
|
||||||
"level",
|
|
||||||
CASE WHEN indoor = TRUE THEN 1 END AS indoor
|
|
||||||
FROM (
|
|
||||||
|
|
||||||
-- etldoc: osm_transportation_name_linestring_gen4 -> layer_transportation_name:z6
|
|
||||||
SELECT *,
|
|
||||||
NULL::int AS layer,
|
|
||||||
NULL::int AS level,
|
|
||||||
NULL::boolean AS indoor
|
|
||||||
FROM osm_transportation_name_linestring_gen4
|
|
||||||
WHERE zoom_level = 6
|
|
||||||
UNION ALL
|
|
||||||
|
|
||||||
-- etldoc: osm_transportation_name_linestring_gen3 -> layer_transportation_name:z7
|
|
||||||
SELECT *,
|
|
||||||
NULL::int AS layer,
|
|
||||||
NULL::int AS level,
|
|
||||||
NULL::boolean AS indoor
|
|
||||||
FROM osm_transportation_name_linestring_gen3
|
|
||||||
WHERE zoom_level = 7
|
|
||||||
UNION ALL
|
|
||||||
|
|
||||||
-- etldoc: osm_transportation_name_linestring_gen2 -> layer_transportation_name:z8
|
|
||||||
SELECT *,
|
|
||||||
NULL::int AS layer,
|
|
||||||
NULL::int AS level,
|
|
||||||
NULL::boolean AS indoor
|
|
||||||
FROM osm_transportation_name_linestring_gen2
|
|
||||||
WHERE zoom_level = 8
|
|
||||||
UNION ALL
|
|
||||||
|
|
||||||
-- etldoc: osm_transportation_name_linestring_gen1 -> layer_transportation_name:z9
|
|
||||||
-- etldoc: osm_transportation_name_linestring_gen1 -> layer_transportation_name:z10
|
|
||||||
-- etldoc: osm_transportation_name_linestring_gen1 -> layer_transportation_name:z11
|
|
||||||
SELECT *,
|
|
||||||
NULL::int AS layer,
|
|
||||||
NULL::int AS level,
|
|
||||||
NULL::boolean AS indoor
|
|
||||||
FROM osm_transportation_name_linestring_gen1
|
|
||||||
WHERE zoom_level BETWEEN 9 AND 11
|
|
||||||
UNION ALL
|
|
||||||
|
|
||||||
-- etldoc: osm_transportation_name_linestring -> layer_transportation_name:z12
|
|
||||||
SELECT geometry,
|
|
||||||
osm_id,
|
|
||||||
name,
|
|
||||||
name_en,
|
|
||||||
name_de,
|
|
||||||
"tags",
|
|
||||||
ref,
|
|
||||||
highway,
|
|
||||||
construction,
|
|
||||||
brunnel,
|
|
||||||
network,
|
|
||||||
z_order,
|
|
||||||
layer,
|
|
||||||
"level",
|
|
||||||
indoor
|
|
||||||
FROM osm_transportation_name_linestring
|
|
||||||
WHERE zoom_level = 12
|
|
||||||
AND LineLabel(zoom_level, COALESCE(name, ref), geometry)
|
|
||||||
AND highway_class(highway, '', construction) NOT IN ('minor', 'track', 'path')
|
|
||||||
AND NOT highway_is_link(highway)
|
|
||||||
UNION ALL
|
|
||||||
|
|
||||||
-- etldoc: osm_transportation_name_linestring -> layer_transportation_name:z13
|
|
||||||
SELECT geometry,
|
|
||||||
osm_id,
|
|
||||||
name,
|
|
||||||
name_en,
|
|
||||||
name_de,
|
|
||||||
"tags",
|
|
||||||
ref,
|
|
||||||
highway,
|
|
||||||
construction,
|
|
||||||
brunnel,
|
|
||||||
network,
|
|
||||||
z_order,
|
|
||||||
layer,
|
|
||||||
"level",
|
|
||||||
indoor
|
|
||||||
FROM osm_transportation_name_linestring
|
|
||||||
WHERE zoom_level = 13
|
|
||||||
AND LineLabel(zoom_level, COALESCE(name, ref), geometry)
|
|
||||||
AND highway_class(highway, '', construction) NOT IN ('track', 'path')
|
|
||||||
UNION ALL
|
|
||||||
|
|
||||||
-- etldoc: osm_transportation_name_linestring -> layer_transportation_name:z14_
|
|
||||||
SELECT geometry,
|
|
||||||
osm_id,
|
|
||||||
name,
|
|
||||||
name_en,
|
|
||||||
name_de,
|
|
||||||
"tags",
|
|
||||||
ref,
|
|
||||||
highway,
|
|
||||||
construction,
|
|
||||||
brunnel,
|
|
||||||
network,
|
|
||||||
z_order,
|
|
||||||
layer,
|
|
||||||
"level",
|
|
||||||
indoor
|
|
||||||
FROM osm_transportation_name_linestring
|
|
||||||
WHERE zoom_level >= 14
|
|
||||||
) AS zoom_levels
|
|
||||||
WHERE geometry && bbox
|
|
||||||
ORDER BY z_order ASC;
|
|
||||||
$$ LANGUAGE SQL STABLE
|
|
||||||
-- STRICT
|
|
||||||
PARALLEL SAFE;
|
|
||||||
@ -69,13 +69,6 @@ layer:
|
|||||||
- bridleway
|
- bridleway
|
||||||
- corridor
|
- corridor
|
||||||
- platform
|
- platform
|
||||||
brunnel:
|
|
||||||
description: |
|
|
||||||
Mark whether way is a bridge, a tunnel or a ford.
|
|
||||||
values:
|
|
||||||
- bridge
|
|
||||||
- tunnel
|
|
||||||
- ford
|
|
||||||
level:
|
level:
|
||||||
description: |
|
description: |
|
||||||
Experimental feature! Filled only for steps and footways. Original
|
Experimental feature! Filled only for steps and footways. Original
|
||||||
@ -93,12 +86,12 @@ layer:
|
|||||||
datasource:
|
datasource:
|
||||||
geometry_field: geometry
|
geometry_field: geometry
|
||||||
srid: 900913
|
srid: 900913
|
||||||
query: (SELECT geometry, name, name_en, name_de, {name_languages}, ref, ref_length, network::text, class::text, subclass, brunnel, layer, level, indoor FROM layer_transportation_name(!bbox!, z(!scale_denominator!))) AS t
|
query: (SELECT geometry, name, name_en, name_de, {name_languages}, ref, ref_length, network::text, class::text, subclass, layer, level, indoor FROM layer_transportation_name(!bbox!, z(!scale_denominator!))) AS t
|
||||||
schema:
|
schema:
|
||||||
- ./network_type.sql
|
- ./network_type.sql
|
||||||
- ./update_route_member.sql
|
- ./update_route_member.sql
|
||||||
- ./update_transportation_name.sql
|
- ./update_transportation_name.sql
|
||||||
- ./transportation_name.sql
|
- ./layer.sql
|
||||||
datasources:
|
datasources:
|
||||||
- type: imposm3
|
- type: imposm3
|
||||||
mapping_file: ../transportation/mapping.yaml
|
mapping_file: ../transportation/mapping.yaml
|
||||||
|
|||||||
@ -1,93 +1,68 @@
|
|||||||
CREATE TABLE IF NOT EXISTS ne_10m_admin_0_bg_buffer AS
|
DROP TRIGGER IF EXISTS trigger_flag_transportation_name ON osm_route_member;
|
||||||
SELECT ST_Buffer(geometry, 10000)
|
|
||||||
FROM ne_10m_admin_0_countries
|
|
||||||
WHERE iso_a2 = 'GB';
|
|
||||||
|
|
||||||
CREATE OR REPLACE VIEW gbr_route_members_view AS
|
|
||||||
SELECT 0,
|
|
||||||
osm_id,
|
|
||||||
substring(ref FROM E'^[AM][0-9AM()]+'),
|
|
||||||
CASE WHEN highway = 'motorway' THEN 'omt-gb-motorway' ELSE 'omt-gb-trunk' END
|
|
||||||
FROM osm_highway_linestring
|
|
||||||
WHERE length(ref) > 0
|
|
||||||
AND ST_Intersects(geometry, (SELECT * FROM ne_10m_admin_0_bg_buffer))
|
|
||||||
AND highway IN ('motorway', 'trunk')
|
|
||||||
;
|
|
||||||
-- Create GBR relations (so we can use it in the same way as other relations)
|
|
||||||
DELETE
|
|
||||||
FROM osm_route_member
|
|
||||||
WHERE network IN ('omt-gb-motorway', 'omt-gb-trunk');
|
|
||||||
-- etldoc: osm_highway_linestring -> osm_route_member
|
|
||||||
INSERT INTO osm_route_member (osm_id, member, ref, network)
|
|
||||||
SELECT *
|
|
||||||
FROM gbr_route_members_view;
|
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION osm_route_member_network_type(network text, name text, ref text) RETURNS route_network_type AS
|
-- create GBR relations (so we can use it in the same way as other relations)
|
||||||
$$
|
CREATE OR REPLACE FUNCTION update_gbr_route_members() RETURNS VOID AS $$
|
||||||
SELECT CASE
|
DECLARE gbr_geom geometry;
|
||||||
WHEN network = 'US:I' THEN 'us-interstate'::route_network_type
|
|
||||||
WHEN network = 'US:US' THEN 'us-highway'::route_network_type
|
|
||||||
WHEN network LIKE 'US:__' THEN 'us-state'::route_network_type
|
|
||||||
-- https://en.wikipedia.org/wiki/Trans-Canada_Highway
|
|
||||||
-- TODO: improve hierarchical queries using
|
|
||||||
-- http://www.openstreetmap.org/relation/1307243
|
|
||||||
-- however the relation does not cover the whole Trans-Canada_Highway
|
|
||||||
WHEN
|
|
||||||
(network = 'CA:transcanada') OR
|
|
||||||
(network = 'CA:BC:primary' AND ref IN ('16')) OR
|
|
||||||
(name = 'Yellowhead Highway (AB)' AND ref IN ('16')) OR
|
|
||||||
(network = 'CA:SK:primary' AND ref IN ('16')) OR
|
|
||||||
(network = 'CA:ON:primary' AND ref IN ('17', '417')) OR
|
|
||||||
(name = 'Route Transcanadienne') OR
|
|
||||||
(network = 'CA:NB:primary' AND ref IN ('2', '16')) OR
|
|
||||||
(network = 'CA:PE' AND ref IN ('1')) OR
|
|
||||||
(network = 'CA:NS' AND ref IN ('104', '105')) OR
|
|
||||||
(network = 'CA:NL:R' AND ref IN ('1')) OR
|
|
||||||
(name = 'Trans-Canada Highway')
|
|
||||||
THEN 'ca-transcanada'::route_network_type
|
|
||||||
WHEN network = 'omt-gb-motorway' THEN 'gb-motorway'::route_network_type
|
|
||||||
WHEN network = 'omt-gb-trunk' THEN 'gb-trunk'::route_network_type
|
|
||||||
END;
|
|
||||||
$$ LANGUAGE sql IMMUTABLE
|
|
||||||
PARALLEL SAFE;
|
|
||||||
|
|
||||||
-- etldoc: osm_route_member -> osm_route_member
|
|
||||||
-- see http://wiki.openstreetmap.org/wiki/Relation:route#Road_routes
|
|
||||||
UPDATE osm_route_member
|
|
||||||
SET network_type = osm_route_member_network_type(network, name, ref)
|
|
||||||
WHERE network != ''
|
|
||||||
AND network_type IS DISTINCT FROM osm_route_member_network_type(network, name, ref)
|
|
||||||
;
|
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION update_osm_route_member() RETURNS void AS
|
|
||||||
$$
|
|
||||||
BEGIN
|
BEGIN
|
||||||
DELETE
|
SELECT st_buffer(geometry, 10000) INTO gbr_geom FROM ne_10m_admin_0_countries where iso_a2 = 'GB';
|
||||||
FROM osm_route_member AS r
|
DELETE FROM osm_route_member WHERE network IN ('omt-gb-motorway', 'omt-gb-trunk');
|
||||||
USING
|
|
||||||
transportation_name.network_changes AS c
|
|
||||||
WHERE network IN ('omt-gb-motorway', 'omt-gb-trunk')
|
|
||||||
AND r.osm_id = c.osm_id;
|
|
||||||
|
|
||||||
INSERT INTO osm_route_member (osm_id, member, ref, network)
|
INSERT INTO osm_route_member (osm_id, member, ref, network)
|
||||||
SELECT r.*
|
SELECT 0, osm_id, substring(ref FROM E'^[AM][0-9AM()]+'),
|
||||||
FROM gbr_route_members_view AS r
|
CASE WHEN highway = 'motorway' THEN 'omt-gb-motorway' ELSE 'omt-gb-trunk' END
|
||||||
JOIN transportation_name.network_changes AS c ON
|
FROM osm_highway_linestring
|
||||||
r.osm_id = c.osm_id;
|
WHERE
|
||||||
|
length(ref)>0 AND
|
||||||
UPDATE
|
ST_Intersects(geometry, gbr_geom) AND
|
||||||
osm_route_member AS r
|
highway IN ('motorway', 'trunk')
|
||||||
SET network_type = osm_route_member_network_type(network, name, ref)
|
;
|
||||||
FROM transportation_name.network_changes AS c
|
|
||||||
WHERE network != ''
|
|
||||||
AND network_type IS DISTINCT FROM osm_route_member_network_type(network, name, ref)
|
|
||||||
AND r.member = c.osm_id;
|
|
||||||
END;
|
END;
|
||||||
$$ LANGUAGE plpgsql;
|
$$ LANGUAGE plpgsql;
|
||||||
|
|
||||||
CREATE INDEX IF NOT EXISTS osm_route_member_network_idx ON osm_route_member ("network");
|
|
||||||
CREATE INDEX IF NOT EXISTS osm_route_member_member_idx ON osm_route_member ("member");
|
|
||||||
CREATE INDEX IF NOT EXISTS osm_route_member_name_idx ON osm_route_member ("name");
|
|
||||||
CREATE INDEX IF NOT EXISTS osm_route_member_ref_idx ON osm_route_member ("ref");
|
|
||||||
|
|
||||||
CREATE INDEX IF NOT EXISTS osm_route_member_network_type_idx ON osm_route_member ("network_type");
|
-- etldoc: osm_route_member -> osm_route_member
|
||||||
|
CREATE OR REPLACE FUNCTION update_osm_route_member() RETURNS VOID AS $$
|
||||||
|
BEGIN
|
||||||
|
PERFORM update_gbr_route_members();
|
||||||
|
|
||||||
|
-- see http://wiki.openstreetmap.org/wiki/Relation:route#Road_routes
|
||||||
|
UPDATE osm_route_member
|
||||||
|
SET network_type =
|
||||||
|
CASE
|
||||||
|
WHEN network = 'US:I' THEN 'us-interstate'::route_network_type
|
||||||
|
WHEN network = 'US:US' THEN 'us-highway'::route_network_type
|
||||||
|
WHEN network LIKE 'US:__' THEN 'us-state'::route_network_type
|
||||||
|
-- https://en.wikipedia.org/wiki/Trans-Canada_Highway
|
||||||
|
-- TODO: improve hierarchical queries using
|
||||||
|
-- http://www.openstreetmap.org/relation/1307243
|
||||||
|
-- however the relation does not cover the whole Trans-Canada_Highway
|
||||||
|
WHEN
|
||||||
|
(network = 'CA:transcanada') OR
|
||||||
|
(network = 'CA:BC:primary' AND ref IN ('16')) OR
|
||||||
|
(name = 'Yellowhead Highway (AB)' AND ref IN ('16')) OR
|
||||||
|
(network = 'CA:SK:primary' AND ref IN ('16')) OR
|
||||||
|
(network = 'CA:ON:primary' AND ref IN ('17', '417')) OR
|
||||||
|
(name = 'Route Transcanadienne') OR
|
||||||
|
(network = 'CA:NB:primary' AND ref IN ('2', '16')) OR
|
||||||
|
(network = 'CA:PE' AND ref IN ('1')) OR
|
||||||
|
(network = 'CA:NS' AND ref IN ('104', '105')) OR
|
||||||
|
(network = 'CA:NL:R' AND ref IN ('1')) OR
|
||||||
|
(name = 'Trans-Canada Highway')
|
||||||
|
THEN 'ca-transcanada'::route_network_type
|
||||||
|
WHEN network = 'omt-gb-motorway' THEN 'gb-motorway'::route_network_type
|
||||||
|
WHEN network = 'omt-gb-trunk' THEN 'gb-trunk'::route_network_type
|
||||||
|
END
|
||||||
|
;
|
||||||
|
|
||||||
|
END;
|
||||||
|
$$ LANGUAGE plpgsql;
|
||||||
|
|
||||||
|
CREATE INDEX IF NOT EXISTS osm_route_member_network_idx ON osm_route_member("network");
|
||||||
|
CREATE INDEX IF NOT EXISTS osm_route_member_member_idx ON osm_route_member("member");
|
||||||
|
CREATE INDEX IF NOT EXISTS osm_route_member_name_idx ON osm_route_member("name");
|
||||||
|
CREATE INDEX IF NOT EXISTS osm_route_member_ref_idx ON osm_route_member("ref");
|
||||||
|
|
||||||
|
SELECT update_osm_route_member();
|
||||||
|
|
||||||
|
CREATE INDEX IF NOT EXISTS osm_route_member_network_type_idx ON osm_route_member("network_type");
|
||||||
|
|||||||
@ -1,3 +1,6 @@
|
|||||||
|
DROP TRIGGER IF EXISTS trigger_flag_transportation_name ON osm_highway_linestring;
|
||||||
|
DROP TRIGGER IF EXISTS trigger_refresh ON transportation_name.updates;
|
||||||
|
|
||||||
-- Instead of using relations to find out the road names we
|
-- Instead of using relations to find out the road names we
|
||||||
-- stitch together the touching ways with the same name
|
-- stitch together the touching ways with the same name
|
||||||
-- to allow for nice label rendering
|
-- to allow for nice label rendering
|
||||||
@ -6,654 +9,165 @@
|
|||||||
|
|
||||||
-- etldoc: osm_highway_linestring -> osm_transportation_name_network
|
-- etldoc: osm_highway_linestring -> osm_transportation_name_network
|
||||||
-- etldoc: osm_route_member -> osm_transportation_name_network
|
-- etldoc: osm_route_member -> osm_transportation_name_network
|
||||||
CREATE TABLE IF NOT EXISTS osm_transportation_name_network AS
|
CREATE MATERIALIZED VIEW osm_transportation_name_network AS (
|
||||||
SELECT
|
SELECT
|
||||||
geometry,
|
hl.geometry,
|
||||||
osm_id,
|
hl.osm_id,
|
||||||
name,
|
CASE WHEN length(hl.name)>15 THEN osml10n_street_abbrev_all(hl.name) ELSE hl.name END AS "name",
|
||||||
name_en,
|
CASE WHEN length(hl.name_en)>15 THEN osml10n_street_abbrev_en(hl.name_en) ELSE hl.name_en END AS "name_en",
|
||||||
name_de,
|
CASE WHEN length(hl.name_de)>15 THEN osml10n_street_abbrev_de(hl.name_de) ELSE hl.name_de END AS "name_de",
|
||||||
tags,
|
hl.tags,
|
||||||
ref,
|
rm.network_type,
|
||||||
highway,
|
CASE
|
||||||
construction,
|
WHEN (rm.network_type is not null AND nullif(rm.ref::text, '') is not null)
|
||||||
brunnel,
|
then rm.ref::text
|
||||||
"level",
|
else hl.ref
|
||||||
layer,
|
end as ref,
|
||||||
indoor,
|
hl.highway,
|
||||||
network_type,
|
hl.construction,
|
||||||
z_order
|
CASE WHEN highway IN ('footway', 'steps') THEN layer END AS layer,
|
||||||
FROM (
|
CASE WHEN highway IN ('footway', 'steps') THEN "level" END AS "level",
|
||||||
SELECT hl.geometry,
|
CASE WHEN highway IN ('footway', 'steps') THEN indoor END AS indoor,
|
||||||
hl.osm_id,
|
ROW_NUMBER() OVER(PARTITION BY hl.osm_id
|
||||||
CASE WHEN length(hl.name) > 15 THEN osml10n_street_abbrev_all(hl.name) ELSE NULLIF(hl.name, '') END AS "name",
|
ORDER BY rm.network_type) AS "rank",
|
||||||
CASE WHEN length(hl.name_en) > 15 THEN osml10n_street_abbrev_en(hl.name_en) ELSE NULLIF(hl.name_en, '') END AS "name_en",
|
hl.z_order
|
||||||
CASE WHEN length(hl.name_de) > 15 THEN osml10n_street_abbrev_de(hl.name_de) ELSE NULLIF(hl.name_de, '') END AS "name_de",
|
FROM osm_highway_linestring hl
|
||||||
slice_language_tags(hl.tags) AS tags,
|
left join osm_route_member rm on (rm.member = hl.osm_id)
|
||||||
rm.network_type,
|
) /* DELAY_MATERIALIZED_VIEW_CREATION */;
|
||||||
CASE
|
CREATE INDEX IF NOT EXISTS osm_transportation_name_network_geometry_idx ON osm_transportation_name_network USING gist(geometry);
|
||||||
WHEN rm.network_type IS NOT NULL AND nullif(rm.ref::text, '') IS NOT NULL
|
|
||||||
THEN rm.ref::text
|
|
||||||
ELSE NULLIF(hl.ref, '')
|
|
||||||
END AS ref,
|
|
||||||
hl.highway,
|
|
||||||
hl.construction,
|
|
||||||
brunnel(hl.is_bridge, hl.is_tunnel, hl.is_ford) AS brunnel,
|
|
||||||
CASE WHEN highway IN ('footway', 'steps') THEN layer END AS layer,
|
|
||||||
CASE WHEN highway IN ('footway', 'steps') THEN level END AS level,
|
|
||||||
CASE WHEN highway IN ('footway', 'steps') THEN indoor END AS indoor,
|
|
||||||
ROW_NUMBER() OVER (PARTITION BY hl.osm_id
|
|
||||||
ORDER BY rm.network_type) AS "rank",
|
|
||||||
hl.z_order
|
|
||||||
FROM osm_highway_linestring hl
|
|
||||||
LEFT JOIN osm_route_member rm ON
|
|
||||||
rm.member = hl.osm_id
|
|
||||||
WHERE (hl.name <> '' OR hl.ref <> '')
|
|
||||||
AND NULLIF(hl.highway, '') IS NOT NULL
|
|
||||||
) AS t
|
|
||||||
WHERE ("rank" = 1 OR "rank" IS NULL);
|
|
||||||
CREATE INDEX IF NOT EXISTS osm_transportation_name_network_osm_id_idx ON osm_transportation_name_network (osm_id);
|
|
||||||
CREATE INDEX IF NOT EXISTS osm_transportation_name_network_name_ref_idx ON osm_transportation_name_network (coalesce(name, ''), coalesce(ref, ''));
|
|
||||||
CREATE INDEX IF NOT EXISTS osm_transportation_name_network_geometry_idx ON osm_transportation_name_network USING gist (geometry);
|
|
||||||
|
|
||||||
|
|
||||||
-- etldoc: osm_transportation_name_network -> osm_transportation_name_linestring
|
-- etldoc: osm_transportation_name_network -> osm_transportation_name_linestring
|
||||||
CREATE TABLE IF NOT EXISTS osm_transportation_name_linestring AS
|
CREATE MATERIALIZED VIEW osm_transportation_name_linestring AS (
|
||||||
SELECT (ST_Dump(geometry)).geom AS geometry,
|
SELECT
|
||||||
NULL::bigint AS osm_id,
|
(ST_Dump(geometry)).geom AS geometry,
|
||||||
name,
|
NULL::bigint AS osm_id,
|
||||||
name_en,
|
name,
|
||||||
name_de,
|
name_en,
|
||||||
tags || get_basic_names(tags, geometry) AS "tags",
|
name_de,
|
||||||
ref,
|
tags || get_basic_names(tags, geometry) AS "tags",
|
||||||
highway,
|
ref,
|
||||||
construction,
|
highway,
|
||||||
brunnel,
|
construction,
|
||||||
"level",
|
"level",
|
||||||
layer,
|
layer,
|
||||||
indoor,
|
indoor,
|
||||||
network_type AS network,
|
network_type AS network,
|
||||||
z_order
|
z_order
|
||||||
FROM (
|
FROM (
|
||||||
SELECT ST_LineMerge(ST_Collect(geometry)) AS geometry,
|
SELECT
|
||||||
name,
|
ST_LineMerge(ST_Collect(geometry)) AS geometry,
|
||||||
name_en,
|
name,
|
||||||
name_de,
|
name_en,
|
||||||
tags || hstore( -- store results of osml10n_street_abbrev_* above
|
name_de,
|
||||||
ARRAY ['name', name, 'name:en', name_en, 'name:de', name_de]) AS tags,
|
hstore(string_agg(nullif(slice_language_tags(tags || hstore(ARRAY['name', name, 'name:en', name_en, 'name:de', name_de]))::text, ''), ','))
|
||||||
ref,
|
AS "tags",
|
||||||
highway,
|
ref,
|
||||||
construction,
|
highway,
|
||||||
brunnel,
|
construction,
|
||||||
"level",
|
"level",
|
||||||
layer,
|
layer,
|
||||||
indoor,
|
indoor,
|
||||||
network_type,
|
network_type,
|
||||||
min(z_order) AS z_order
|
min(z_order) AS z_order
|
||||||
FROM osm_transportation_name_network
|
FROM osm_transportation_name_network
|
||||||
GROUP BY name, name_en, name_de, tags, ref, highway, construction, brunnel, "level", layer, indoor, network_type
|
WHERE ("rank"=1 OR "rank" is null)
|
||||||
) AS highway_union
|
AND (name <> '' OR ref <> '')
|
||||||
;
|
AND NULLIF(highway, '') IS NOT NULL
|
||||||
CREATE INDEX IF NOT EXISTS osm_transportation_name_linestring_name_ref_idx ON osm_transportation_name_linestring (coalesce(name, ''), coalesce(ref, ''));
|
group by name, name_en, name_de, ref, highway, construction, "level", layer, indoor, network_type
|
||||||
CREATE INDEX IF NOT EXISTS osm_transportation_name_linestring_geometry_idx ON osm_transportation_name_linestring USING gist (geometry);
|
) AS highway_union
|
||||||
|
) /* DELAY_MATERIALIZED_VIEW_CREATION */;
|
||||||
|
CREATE INDEX IF NOT EXISTS osm_transportation_name_linestring_geometry_idx ON osm_transportation_name_linestring USING gist(geometry);
|
||||||
|
|
||||||
CREATE INDEX IF NOT EXISTS osm_transportation_name_linestring_highway_partial_idx
|
CREATE INDEX IF NOT EXISTS osm_transportation_name_linestring_highway_partial_idx
|
||||||
ON osm_transportation_name_linestring (highway, construction)
|
ON osm_transportation_name_linestring(highway, construction)
|
||||||
WHERE highway IN ('motorway', 'trunk', 'construction');
|
WHERE highway IN ('motorway','trunk', 'construction');
|
||||||
|
|
||||||
-- etldoc: osm_transportation_name_linestring -> osm_transportation_name_linestring_gen1
|
-- etldoc: osm_transportation_name_linestring -> osm_transportation_name_linestring_gen1
|
||||||
CREATE OR REPLACE VIEW osm_transportation_name_linestring_gen1_view AS
|
CREATE MATERIALIZED VIEW osm_transportation_name_linestring_gen1 AS (
|
||||||
SELECT ST_Simplify(geometry, 50) AS geometry,
|
SELECT ST_Simplify(geometry, 50) AS geometry, osm_id, name, name_en, name_de, tags, ref, highway, construction, network, z_order
|
||||||
osm_id,
|
FROM osm_transportation_name_linestring
|
||||||
name,
|
WHERE (highway IN ('motorway','trunk') OR highway = 'construction' AND construction IN ('motorway','trunk')) AND ST_Length(geometry) > 8000
|
||||||
name_en,
|
) /* DELAY_MATERIALIZED_VIEW_CREATION */;
|
||||||
name_de,
|
CREATE INDEX IF NOT EXISTS osm_transportation_name_linestring_gen1_geometry_idx ON osm_transportation_name_linestring_gen1 USING gist(geometry);
|
||||||
tags,
|
|
||||||
ref,
|
|
||||||
highway,
|
|
||||||
construction,
|
|
||||||
brunnel,
|
|
||||||
network,
|
|
||||||
z_order
|
|
||||||
FROM osm_transportation_name_linestring
|
|
||||||
WHERE (highway IN ('motorway', 'trunk') OR highway = 'construction' AND construction IN ('motorway', 'trunk'))
|
|
||||||
AND ST_Length(geometry) > 8000
|
|
||||||
;
|
|
||||||
CREATE TABLE IF NOT EXISTS osm_transportation_name_linestring_gen1 AS
|
|
||||||
SELECT *
|
|
||||||
FROM osm_transportation_name_linestring_gen1_view;
|
|
||||||
CREATE INDEX IF NOT EXISTS osm_transportation_name_linestring_gen1_name_ref_idx ON osm_transportation_name_linestring_gen1((coalesce(name, ref)));
|
|
||||||
CREATE INDEX IF NOT EXISTS osm_transportation_name_linestring_gen1_geometry_idx ON osm_transportation_name_linestring_gen1 USING gist (geometry);
|
|
||||||
|
|
||||||
CREATE INDEX IF NOT EXISTS osm_transportation_name_linestring_gen1_highway_partial_idx
|
CREATE INDEX IF NOT EXISTS osm_transportation_name_linestring_gen1_highway_partial_idx
|
||||||
ON osm_transportation_name_linestring_gen1 (highway, construction)
|
ON osm_transportation_name_linestring_gen1(highway, construction)
|
||||||
WHERE highway IN ('motorway', 'trunk', 'construction');
|
WHERE highway IN ('motorway','trunk', 'construction');
|
||||||
|
|
||||||
-- etldoc: osm_transportation_name_linestring_gen1 -> osm_transportation_name_linestring_gen2
|
-- etldoc: osm_transportation_name_linestring_gen1 -> osm_transportation_name_linestring_gen2
|
||||||
CREATE OR REPLACE VIEW osm_transportation_name_linestring_gen2_view AS
|
CREATE MATERIALIZED VIEW osm_transportation_name_linestring_gen2 AS (
|
||||||
SELECT ST_Simplify(geometry, 120) AS geometry,
|
SELECT ST_Simplify(geometry, 120) AS geometry, osm_id, name, name_en, name_de, tags, ref, highway, construction, network, z_order
|
||||||
osm_id,
|
FROM osm_transportation_name_linestring_gen1
|
||||||
name,
|
WHERE (highway IN ('motorway','trunk') OR highway = 'construction' AND construction IN ('motorway','trunk')) AND ST_Length(geometry) > 14000
|
||||||
name_en,
|
) /* DELAY_MATERIALIZED_VIEW_CREATION */;
|
||||||
name_de,
|
CREATE INDEX IF NOT EXISTS osm_transportation_name_linestring_gen2_geometry_idx ON osm_transportation_name_linestring_gen2 USING gist(geometry);
|
||||||
tags,
|
|
||||||
ref,
|
|
||||||
highway,
|
|
||||||
construction,
|
|
||||||
brunnel,
|
|
||||||
network,
|
|
||||||
z_order
|
|
||||||
FROM osm_transportation_name_linestring_gen1
|
|
||||||
WHERE (highway IN ('motorway', 'trunk') OR highway = 'construction' AND construction IN ('motorway', 'trunk'))
|
|
||||||
AND ST_Length(geometry) > 14000
|
|
||||||
;
|
|
||||||
CREATE TABLE IF NOT EXISTS osm_transportation_name_linestring_gen2 AS
|
|
||||||
SELECT *
|
|
||||||
FROM osm_transportation_name_linestring_gen2_view;
|
|
||||||
CREATE INDEX IF NOT EXISTS osm_transportation_name_linestring_gen2_name_ref_idx ON osm_transportation_name_linestring_gen2((coalesce(name, ref)));
|
|
||||||
CREATE INDEX IF NOT EXISTS osm_transportation_name_linestring_gen2_geometry_idx ON osm_transportation_name_linestring_gen2 USING gist (geometry);
|
|
||||||
|
|
||||||
CREATE INDEX IF NOT EXISTS osm_transportation_name_linestring_gen2_highway_partial_idx
|
CREATE INDEX IF NOT EXISTS osm_transportation_name_linestring_gen2_highway_partial_idx
|
||||||
ON osm_transportation_name_linestring_gen2 (highway, construction)
|
ON osm_transportation_name_linestring_gen2(highway, construction)
|
||||||
WHERE highway IN ('motorway', 'trunk', 'construction');
|
WHERE highway IN ('motorway','trunk', 'construction');
|
||||||
|
|
||||||
-- etldoc: osm_transportation_name_linestring_gen2 -> osm_transportation_name_linestring_gen3
|
-- etldoc: osm_transportation_name_linestring_gen2 -> osm_transportation_name_linestring_gen3
|
||||||
CREATE OR REPLACE VIEW osm_transportation_name_linestring_gen3_view AS
|
CREATE MATERIALIZED VIEW osm_transportation_name_linestring_gen3 AS (
|
||||||
SELECT ST_Simplify(geometry, 200) AS geometry,
|
SELECT ST_Simplify(geometry, 200) AS geometry, osm_id, name, name_en, name_de, tags, ref, highway, construction, network, z_order
|
||||||
osm_id,
|
FROM osm_transportation_name_linestring_gen2
|
||||||
name,
|
WHERE (highway = 'motorway' OR highway = 'construction' AND construction = 'motorway') AND ST_Length(geometry) > 20000
|
||||||
name_en,
|
) /* DELAY_MATERIALIZED_VIEW_CREATION */;
|
||||||
name_de,
|
CREATE INDEX IF NOT EXISTS osm_transportation_name_linestring_gen3_geometry_idx ON osm_transportation_name_linestring_gen3 USING gist(geometry);
|
||||||
tags,
|
|
||||||
ref,
|
|
||||||
highway,
|
|
||||||
construction,
|
|
||||||
brunnel,
|
|
||||||
network,
|
|
||||||
z_order
|
|
||||||
FROM osm_transportation_name_linestring_gen2
|
|
||||||
WHERE (highway = 'motorway' OR highway = 'construction' AND construction = 'motorway')
|
|
||||||
AND ST_Length(geometry) > 20000
|
|
||||||
;
|
|
||||||
CREATE TABLE IF NOT EXISTS osm_transportation_name_linestring_gen3 AS
|
|
||||||
SELECT *
|
|
||||||
FROM osm_transportation_name_linestring_gen3_view;
|
|
||||||
CREATE INDEX IF NOT EXISTS osm_transportation_name_linestring_gen3_name_ref_idx ON osm_transportation_name_linestring_gen3((coalesce(name, ref)));
|
|
||||||
CREATE INDEX IF NOT EXISTS osm_transportation_name_linestring_gen3_geometry_idx ON osm_transportation_name_linestring_gen3 USING gist (geometry);
|
|
||||||
|
|
||||||
CREATE INDEX IF NOT EXISTS osm_transportation_name_linestring_gen3_highway_partial_idx
|
CREATE INDEX IF NOT EXISTS osm_transportation_name_linestring_gen3_highway_partial_idx
|
||||||
ON osm_transportation_name_linestring_gen3 (highway, construction)
|
ON osm_transportation_name_linestring_gen3(highway, construction)
|
||||||
WHERE highway IN ('motorway', 'construction');
|
WHERE highway IN ('motorway', 'construction');
|
||||||
|
|
||||||
-- etldoc: osm_transportation_name_linestring_gen3 -> osm_transportation_name_linestring_gen4
|
-- etldoc: osm_transportation_name_linestring_gen3 -> osm_transportation_name_linestring_gen4
|
||||||
CREATE OR REPLACE VIEW osm_transportation_name_linestring_gen4_view AS
|
CREATE MATERIALIZED VIEW osm_transportation_name_linestring_gen4 AS (
|
||||||
SELECT ST_Simplify(geometry, 500) AS geometry,
|
SELECT ST_Simplify(geometry, 500) AS geometry, osm_id, name, name_en, name_de, tags, ref, highway, construction, network, z_order
|
||||||
osm_id,
|
FROM osm_transportation_name_linestring_gen3
|
||||||
name,
|
WHERE (highway = 'motorway' OR highway = 'construction' AND construction = 'motorway') AND ST_Length(geometry) > 20000
|
||||||
name_en,
|
) /* DELAY_MATERIALIZED_VIEW_CREATION */;
|
||||||
name_de,
|
CREATE INDEX IF NOT EXISTS osm_transportation_name_linestring_gen4_geometry_idx ON osm_transportation_name_linestring_gen4 USING gist(geometry);
|
||||||
tags,
|
|
||||||
ref,
|
|
||||||
highway,
|
|
||||||
construction,
|
|
||||||
brunnel,
|
|
||||||
network,
|
|
||||||
z_order
|
|
||||||
FROM osm_transportation_name_linestring_gen3
|
|
||||||
WHERE (highway = 'motorway' OR highway = 'construction' AND construction = 'motorway')
|
|
||||||
AND ST_Length(geometry) > 20000
|
|
||||||
;
|
|
||||||
CREATE TABLE IF NOT EXISTS osm_transportation_name_linestring_gen4 AS
|
|
||||||
SELECT *
|
|
||||||
FROM osm_transportation_name_linestring_gen4_view;
|
|
||||||
CREATE INDEX IF NOT EXISTS osm_transportation_name_linestring_gen4_name_ref_idx ON osm_transportation_name_linestring_gen4((coalesce(name, ref)));
|
|
||||||
CREATE INDEX IF NOT EXISTS osm_transportation_name_linestring_gen4_geometry_idx ON osm_transportation_name_linestring_gen4 USING gist (geometry);
|
|
||||||
|
|
||||||
-- Handle updates
|
-- Handle updates
|
||||||
|
|
||||||
CREATE SCHEMA IF NOT EXISTS transportation_name;
|
CREATE SCHEMA IF NOT EXISTS transportation_name;
|
||||||
|
|
||||||
-- Trigger to update "osm_transportation_name_network" from "osm_route_member" and "osm_highway_linestring"
|
CREATE TABLE IF NOT EXISTS transportation_name.updates(id serial primary key, t text, unique (t));
|
||||||
|
CREATE OR REPLACE FUNCTION transportation_name.flag() RETURNS trigger AS $$
|
||||||
CREATE TABLE IF NOT EXISTS transportation_name.network_changes
|
|
||||||
(
|
|
||||||
osm_id bigint,
|
|
||||||
UNIQUE (osm_id)
|
|
||||||
);
|
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION transportation_name.route_member_store() RETURNS trigger AS
|
|
||||||
$$
|
|
||||||
BEGIN
|
BEGIN
|
||||||
INSERT INTO transportation_name.network_changes(osm_id)
|
INSERT INTO transportation_name.updates(t) VALUES ('y') ON CONFLICT(t) DO NOTHING;
|
||||||
VALUES (CASE WHEN tg_op IN ('DELETE', 'UPDATE') THEN old.member ELSE new.member END)
|
RETURN null;
|
||||||
ON CONFLICT(osm_id) DO NOTHING;
|
|
||||||
|
|
||||||
RETURN NULL;
|
|
||||||
END;
|
END;
|
||||||
$$ LANGUAGE plpgsql;
|
$$ language plpgsql;
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION transportation_name.highway_linestring_store() RETURNS trigger AS
|
CREATE OR REPLACE FUNCTION transportation_name.refresh() RETURNS trigger AS
|
||||||
$$
|
$BODY$
|
||||||
BEGIN
|
BEGIN
|
||||||
INSERT INTO transportation_name.network_changes(osm_id)
|
RAISE LOG 'Refresh transportation_name';
|
||||||
VALUES (CASE WHEN tg_op IN ('DELETE', 'UPDATE') THEN old.osm_id ELSE new.osm_id END)
|
|
||||||
ON CONFLICT(osm_id) DO NOTHING;
|
|
||||||
|
|
||||||
RETURN NULL;
|
|
||||||
END;
|
|
||||||
$$ LANGUAGE plpgsql;
|
|
||||||
|
|
||||||
CREATE TABLE IF NOT EXISTS transportation_name.updates_network
|
|
||||||
(
|
|
||||||
id serial PRIMARY KEY,
|
|
||||||
t text,
|
|
||||||
UNIQUE (t)
|
|
||||||
);
|
|
||||||
CREATE OR REPLACE FUNCTION transportation_name.flag_network() RETURNS trigger AS
|
|
||||||
$$
|
|
||||||
BEGIN
|
|
||||||
INSERT INTO transportation_name.updates_network(t) VALUES ('y') ON CONFLICT(t) DO NOTHING;
|
|
||||||
RETURN NULL;
|
|
||||||
END;
|
|
||||||
$$ LANGUAGE plpgsql;
|
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION transportation_name.refresh_network() RETURNS trigger AS
|
|
||||||
$$
|
|
||||||
DECLARE
|
|
||||||
t TIMESTAMP WITH TIME ZONE := clock_timestamp();
|
|
||||||
BEGIN
|
|
||||||
RAISE LOG 'Refresh transportation_name_network';
|
|
||||||
PERFORM update_osm_route_member();
|
PERFORM update_osm_route_member();
|
||||||
|
REFRESH MATERIALIZED VIEW osm_transportation_name_network;
|
||||||
-- REFRESH osm_transportation_name_network
|
REFRESH MATERIALIZED VIEW osm_transportation_name_linestring;
|
||||||
DELETE
|
REFRESH MATERIALIZED VIEW osm_transportation_name_linestring_gen1;
|
||||||
FROM osm_transportation_name_network AS n
|
REFRESH MATERIALIZED VIEW osm_transportation_name_linestring_gen2;
|
||||||
USING
|
REFRESH MATERIALIZED VIEW osm_transportation_name_linestring_gen3;
|
||||||
transportation_name.network_changes AS c
|
REFRESH MATERIALIZED VIEW osm_transportation_name_linestring_gen4;
|
||||||
WHERE n.osm_id = c.osm_id;
|
DELETE FROM transportation_name.updates;
|
||||||
|
RETURN null;
|
||||||
INSERT INTO osm_transportation_name_network
|
END;
|
||||||
SELECT
|
$BODY$
|
||||||
geometry,
|
language plpgsql;
|
||||||
osm_id,
|
|
||||||
name,
|
|
||||||
name_en,
|
|
||||||
name_de,
|
|
||||||
tags,
|
|
||||||
ref,
|
|
||||||
highway,
|
|
||||||
construction,
|
|
||||||
brunnel,
|
|
||||||
level,
|
|
||||||
layer,
|
|
||||||
indoor,
|
|
||||||
network_type,
|
|
||||||
z_order
|
|
||||||
FROM (
|
|
||||||
SELECT hl.geometry,
|
|
||||||
hl.osm_id,
|
|
||||||
CASE WHEN length(hl.name) > 15 THEN osml10n_street_abbrev_all(hl.name) ELSE NULLIF(hl.name, '') END AS name,
|
|
||||||
CASE WHEN length(hl.name_en) > 15 THEN osml10n_street_abbrev_en(hl.name_en) ELSE NULLIF(hl.name_en, '') END AS name_en,
|
|
||||||
CASE WHEN length(hl.name_de) > 15 THEN osml10n_street_abbrev_de(hl.name_de) ELSE NULLIF(hl.name_de, '') END AS name_de,
|
|
||||||
slice_language_tags(hl.tags) AS tags,
|
|
||||||
rm.network_type,
|
|
||||||
CASE
|
|
||||||
WHEN rm.network_type IS NOT NULL AND NULLIF(rm.ref::text, '') IS NOT NULL
|
|
||||||
THEN rm.ref::text
|
|
||||||
ELSE NULLIF(hl.ref, '')
|
|
||||||
END AS ref,
|
|
||||||
hl.highway,
|
|
||||||
hl.construction,
|
|
||||||
brunnel(hl.is_bridge, hl.is_tunnel, hl.is_ford) AS brunnel,
|
|
||||||
CASE WHEN highway IN ('footway', 'steps') THEN layer END AS layer,
|
|
||||||
CASE WHEN highway IN ('footway', 'steps') THEN level END AS level,
|
|
||||||
CASE WHEN highway IN ('footway', 'steps') THEN indoor END AS indoor,
|
|
||||||
ROW_NUMBER() OVER (PARTITION BY hl.osm_id
|
|
||||||
ORDER BY rm.network_type) AS "rank",
|
|
||||||
hl.z_order
|
|
||||||
FROM osm_highway_linestring hl
|
|
||||||
JOIN transportation_name.network_changes AS c ON
|
|
||||||
hl.osm_id = c.osm_id
|
|
||||||
LEFT JOIN osm_route_member rm ON
|
|
||||||
rm.member = hl.osm_id
|
|
||||||
WHERE (hl.name <> '' OR hl.ref <> '')
|
|
||||||
AND NULLIF(hl.highway, '') IS NOT NULL
|
|
||||||
) AS t
|
|
||||||
WHERE ("rank" = 1 OR "rank" IS NULL);
|
|
||||||
|
|
||||||
-- noinspection SqlWithoutWhere
|
|
||||||
DELETE FROM transportation_name.network_changes;
|
|
||||||
-- noinspection SqlWithoutWhere
|
|
||||||
DELETE FROM transportation_name.updates_network;
|
|
||||||
|
|
||||||
RAISE LOG 'Refresh transportation_name network done in %', age(clock_timestamp(), t);
|
|
||||||
RETURN NULL;
|
|
||||||
END;
|
|
||||||
$$ LANGUAGE plpgsql;
|
|
||||||
|
|
||||||
|
|
||||||
CREATE TRIGGER trigger_store_transportation_route_member
|
|
||||||
AFTER INSERT OR UPDATE OR DELETE
|
|
||||||
ON osm_route_member
|
|
||||||
FOR EACH ROW
|
|
||||||
EXECUTE PROCEDURE transportation_name.route_member_store();
|
|
||||||
|
|
||||||
CREATE TRIGGER trigger_store_transportation_highway_linestring
|
|
||||||
AFTER INSERT OR UPDATE OR DELETE
|
|
||||||
ON osm_highway_linestring
|
|
||||||
FOR EACH ROW
|
|
||||||
EXECUTE PROCEDURE transportation_name.highway_linestring_store();
|
|
||||||
|
|
||||||
CREATE TRIGGER trigger_flag_transportation_name
|
CREATE TRIGGER trigger_flag_transportation_name
|
||||||
AFTER INSERT
|
AFTER INSERT OR UPDATE OR DELETE ON osm_route_member
|
||||||
ON transportation_name.network_changes
|
|
||||||
FOR EACH STATEMENT
|
FOR EACH STATEMENT
|
||||||
EXECUTE PROCEDURE transportation_name.flag_network();
|
EXECUTE PROCEDURE transportation_name.flag();
|
||||||
|
|
||||||
CREATE CONSTRAINT TRIGGER trigger_refresh_network
|
CREATE TRIGGER trigger_flag_transportation_name
|
||||||
AFTER INSERT
|
AFTER INSERT OR UPDATE OR DELETE ON osm_highway_linestring
|
||||||
ON transportation_name.updates_network
|
FOR EACH STATEMENT
|
||||||
|
EXECUTE PROCEDURE transportation_name.flag();
|
||||||
|
|
||||||
|
CREATE CONSTRAINT TRIGGER trigger_refresh
|
||||||
|
AFTER INSERT ON transportation_name.updates
|
||||||
INITIALLY DEFERRED
|
INITIALLY DEFERRED
|
||||||
FOR EACH ROW
|
FOR EACH ROW
|
||||||
EXECUTE PROCEDURE transportation_name.refresh_network();
|
EXECUTE PROCEDURE transportation_name.refresh();
|
||||||
|
|
||||||
-- Trigger to update "osm_transportation_name_linestring" from "osm_transportation_name_network"
|
|
||||||
|
|
||||||
CREATE TABLE IF NOT EXISTS transportation_name.name_changes
|
|
||||||
(
|
|
||||||
id serial PRIMARY KEY,
|
|
||||||
is_old boolean,
|
|
||||||
osm_id bigint,
|
|
||||||
name character varying,
|
|
||||||
name_en character varying,
|
|
||||||
name_de character varying,
|
|
||||||
ref character varying,
|
|
||||||
highway character varying,
|
|
||||||
construction character varying,
|
|
||||||
brunnel character varying,
|
|
||||||
level integer,
|
|
||||||
layer integer,
|
|
||||||
indoor boolean,
|
|
||||||
network_type route_network_type
|
|
||||||
);
|
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION transportation_name.name_network_store() RETURNS trigger AS
|
|
||||||
$$
|
|
||||||
BEGIN
|
|
||||||
IF (tg_op IN ('DELETE', 'UPDATE'))
|
|
||||||
THEN
|
|
||||||
INSERT INTO transportation_name.name_changes(is_old, osm_id, name, name_en, name_de, ref, highway, construction,
|
|
||||||
brunnel, level, layer, indoor, network_type)
|
|
||||||
VALUES (TRUE, old.osm_id, old.name, old.name_en, old.name_de, old.ref, old.highway, old.construction,
|
|
||||||
old.brunnel, old.level, old.layer, old.indoor, old.network_type);
|
|
||||||
END IF;
|
|
||||||
IF (tg_op IN ('UPDATE', 'INSERT'))
|
|
||||||
THEN
|
|
||||||
INSERT INTO transportation_name.name_changes(is_old, osm_id, name, name_en, name_de, ref, highway, construction,
|
|
||||||
brunnel, level, layer, indoor, network_type)
|
|
||||||
VALUES (FALSE, new.osm_id, new.name, new.name_en, new.name_de, new.ref, new.highway, new.construction,
|
|
||||||
new.brunnel, new.level, new.layer, new.indoor, new.network_type);
|
|
||||||
END IF;
|
|
||||||
RETURN NULL;
|
|
||||||
END;
|
|
||||||
$$ LANGUAGE plpgsql;
|
|
||||||
|
|
||||||
CREATE TABLE IF NOT EXISTS transportation_name.updates_name
|
|
||||||
(
|
|
||||||
id serial PRIMARY KEY,
|
|
||||||
t text,
|
|
||||||
UNIQUE (t)
|
|
||||||
);
|
|
||||||
CREATE OR REPLACE FUNCTION transportation_name.flag_name() RETURNS trigger AS
|
|
||||||
$$
|
|
||||||
BEGIN
|
|
||||||
INSERT INTO transportation_name.updates_name(t) VALUES ('y') ON CONFLICT(t) DO NOTHING;
|
|
||||||
RETURN NULL;
|
|
||||||
END;
|
|
||||||
$$ LANGUAGE plpgsql;
|
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION transportation_name.refresh_name() RETURNS trigger AS
|
|
||||||
$BODY$
|
|
||||||
DECLARE
|
|
||||||
t TIMESTAMP WITH TIME ZONE := clock_timestamp();
|
|
||||||
BEGIN
|
|
||||||
RAISE LOG 'Refresh transportation_name';
|
|
||||||
|
|
||||||
-- REFRESH osm_transportation_name_linestring
|
|
||||||
|
|
||||||
-- Compact the change history to keep only the first and last version, and then uniq version of row
|
|
||||||
CREATE TEMP TABLE name_changes_compact AS
|
|
||||||
SELECT DISTINCT ON (name, name_en, name_de, ref, highway, construction, brunnel, level, layer, indoor, network_type)
|
|
||||||
name,
|
|
||||||
name_en,
|
|
||||||
name_de,
|
|
||||||
ref,
|
|
||||||
highway,
|
|
||||||
construction,
|
|
||||||
brunnel,
|
|
||||||
level,
|
|
||||||
layer,
|
|
||||||
indoor,
|
|
||||||
network_type,
|
|
||||||
coalesce(name, ref) AS name_ref
|
|
||||||
FROM ((
|
|
||||||
SELECT DISTINCT ON (osm_id) *
|
|
||||||
FROM transportation_name.name_changes
|
|
||||||
WHERE is_old
|
|
||||||
ORDER BY osm_id,
|
|
||||||
id ASC
|
|
||||||
)
|
|
||||||
UNION ALL
|
|
||||||
(
|
|
||||||
SELECT DISTINCT ON (osm_id) *
|
|
||||||
FROM transportation_name.name_changes
|
|
||||||
WHERE NOT is_old
|
|
||||||
ORDER BY osm_id,
|
|
||||||
id DESC
|
|
||||||
)) AS t;
|
|
||||||
|
|
||||||
DELETE
|
|
||||||
FROM osm_transportation_name_linestring AS n
|
|
||||||
USING name_changes_compact AS c
|
|
||||||
WHERE coalesce(n.name, '') = coalesce(c.name, '')
|
|
||||||
AND coalesce(n.ref, '') = coalesce(c.ref, '')
|
|
||||||
AND n.name_en IS NOT DISTINCT FROM c.name_en
|
|
||||||
AND n.name_de IS NOT DISTINCT FROM c.name_de
|
|
||||||
AND n.highway IS NOT DISTINCT FROM c.highway
|
|
||||||
AND n.construction IS NOT DISTINCT FROM c.construction
|
|
||||||
AND n.brunnel IS NOT DISTINCT FROM c.brunnel
|
|
||||||
AND n.level IS NOT DISTINCT FROM c.level
|
|
||||||
AND n.layer IS NOT DISTINCT FROM c.layer
|
|
||||||
AND n.indoor IS NOT DISTINCT FROM c.indoor
|
|
||||||
AND n.network IS NOT DISTINCT FROM c.network_type;
|
|
||||||
|
|
||||||
INSERT INTO osm_transportation_name_linestring
|
|
||||||
SELECT (ST_Dump(geometry)).geom AS geometry,
|
|
||||||
NULL::bigint AS osm_id,
|
|
||||||
name,
|
|
||||||
name_en,
|
|
||||||
name_de,
|
|
||||||
tags || get_basic_names(tags, geometry) AS tags,
|
|
||||||
ref,
|
|
||||||
highway,
|
|
||||||
construction,
|
|
||||||
brunnel,
|
|
||||||
level,
|
|
||||||
layer,
|
|
||||||
indoor,
|
|
||||||
network_type AS network,
|
|
||||||
z_order
|
|
||||||
FROM (
|
|
||||||
SELECT ST_LineMerge(ST_Collect(n.geometry)) AS geometry,
|
|
||||||
n.name,
|
|
||||||
n.name_en,
|
|
||||||
n.name_de,
|
|
||||||
hstore(string_agg(nullif(slice_language_tags(tags ||
|
|
||||||
hstore(ARRAY ['name', n.name, 'name:en', n.name_en, 'name:de', n.name_de]))::text,
|
|
||||||
''), ',')) AS tags,
|
|
||||||
n.ref,
|
|
||||||
n.highway,
|
|
||||||
n.construction,
|
|
||||||
n.brunnel,
|
|
||||||
n.level,
|
|
||||||
n.layer,
|
|
||||||
n.indoor,
|
|
||||||
n.network_type,
|
|
||||||
min(n.z_order) AS z_order
|
|
||||||
FROM osm_transportation_name_network AS n
|
|
||||||
JOIN name_changes_compact AS c ON
|
|
||||||
coalesce(n.name, '') = coalesce(c.name, '')
|
|
||||||
AND coalesce(n.ref, '') = coalesce(c.ref, '')
|
|
||||||
AND n.name_en IS NOT DISTINCT FROM c.name_en
|
|
||||||
AND n.name_de IS NOT DISTINCT FROM c.name_de
|
|
||||||
AND n.highway IS NOT DISTINCT FROM c.highway
|
|
||||||
AND n.construction IS NOT DISTINCT FROM c.construction
|
|
||||||
AND n.brunnel IS NOT DISTINCT FROM c.brunnel
|
|
||||||
AND n.level IS NOT DISTINCT FROM c.level
|
|
||||||
AND n.layer IS NOT DISTINCT FROM c.layer
|
|
||||||
AND n.indoor IS NOT DISTINCT FROM c.indoor
|
|
||||||
AND n.network_type IS NOT DISTINCT FROM c.network_type
|
|
||||||
GROUP BY n.name, n.name_en, n.name_de, n.ref, n.highway, n.construction, n.brunnel, n.level, n.layer, n.indoor, n.network_type
|
|
||||||
) AS highway_union;
|
|
||||||
|
|
||||||
-- REFRESH osm_transportation_name_linestring_gen1
|
|
||||||
DELETE FROM osm_transportation_name_linestring_gen1 AS n
|
|
||||||
USING name_changes_compact AS c
|
|
||||||
WHERE
|
|
||||||
coalesce(n.name, n.ref) = c.name_ref
|
|
||||||
AND n.name IS NOT DISTINCT FROM c.name
|
|
||||||
AND n.name_en IS NOT DISTINCT FROM c.name_en
|
|
||||||
AND n.name_de IS NOT DISTINCT FROM c.name_de
|
|
||||||
AND n.ref IS NOT DISTINCT FROM c.ref
|
|
||||||
AND n.highway IS NOT DISTINCT FROM c.highway
|
|
||||||
AND n.construction IS NOT DISTINCT FROM c.construction
|
|
||||||
AND n.brunnel IS NOT DISTINCT FROM c.brunnel
|
|
||||||
AND n.network IS NOT DISTINCT FROM c.network_type;
|
|
||||||
|
|
||||||
INSERT INTO osm_transportation_name_linestring_gen1
|
|
||||||
SELECT n.*
|
|
||||||
FROM osm_transportation_name_linestring_gen1_view AS n
|
|
||||||
JOIN name_changes_compact AS c ON
|
|
||||||
coalesce(n.name, n.ref) = c.name_ref
|
|
||||||
AND n.name IS NOT DISTINCT FROM c.name
|
|
||||||
AND n.name_en IS NOT DISTINCT FROM c.name_en
|
|
||||||
AND n.name_de IS NOT DISTINCT FROM c.name_de
|
|
||||||
AND n.ref IS NOT DISTINCT FROM c.ref
|
|
||||||
AND n.highway IS NOT DISTINCT FROM c.highway
|
|
||||||
AND n.construction IS NOT DISTINCT FROM c.construction
|
|
||||||
AND n.brunnel IS NOT DISTINCT FROM c.brunnel
|
|
||||||
AND n.network IS NOT DISTINCT FROM c.network_type;
|
|
||||||
|
|
||||||
-- REFRESH osm_transportation_name_linestring_gen2
|
|
||||||
DELETE FROM osm_transportation_name_linestring_gen2 AS n
|
|
||||||
USING name_changes_compact AS c
|
|
||||||
WHERE
|
|
||||||
coalesce(n.name, n.ref) = c.name_ref
|
|
||||||
AND n.name IS NOT DISTINCT FROM c.name
|
|
||||||
AND n.name_en IS NOT DISTINCT FROM c.name_en
|
|
||||||
AND n.name_de IS NOT DISTINCT FROM c.name_de
|
|
||||||
AND n.ref IS NOT DISTINCT FROM c.ref
|
|
||||||
AND n.highway IS NOT DISTINCT FROM c.highway
|
|
||||||
AND n.construction IS NOT DISTINCT FROM c.construction
|
|
||||||
AND n.brunnel IS NOT DISTINCT FROM c.brunnel
|
|
||||||
AND n.network IS NOT DISTINCT FROM c.network_type;
|
|
||||||
|
|
||||||
INSERT INTO osm_transportation_name_linestring_gen2
|
|
||||||
SELECT n.*
|
|
||||||
FROM osm_transportation_name_linestring_gen2_view AS n
|
|
||||||
JOIN name_changes_compact AS c ON
|
|
||||||
coalesce(n.name, n.ref) = c.name_ref
|
|
||||||
AND n.name IS NOT DISTINCT FROM c.name
|
|
||||||
AND n.name_en IS NOT DISTINCT FROM c.name_en
|
|
||||||
AND n.name_de IS NOT DISTINCT FROM c.name_de
|
|
||||||
AND n.ref IS NOT DISTINCT FROM c.ref
|
|
||||||
AND n.highway IS NOT DISTINCT FROM c.highway
|
|
||||||
AND n.construction IS NOT DISTINCT FROM c.construction
|
|
||||||
AND n.brunnel IS NOT DISTINCT FROM c.brunnel
|
|
||||||
AND n.network IS NOT DISTINCT FROM c.network_type;
|
|
||||||
|
|
||||||
-- REFRESH osm_transportation_name_linestring_gen3
|
|
||||||
DELETE FROM osm_transportation_name_linestring_gen3 AS n
|
|
||||||
USING name_changes_compact AS c
|
|
||||||
WHERE
|
|
||||||
coalesce(n.name, n.ref) = c.name_ref
|
|
||||||
AND n.name IS NOT DISTINCT FROM c.name
|
|
||||||
AND n.name_en IS NOT DISTINCT FROM c.name_en
|
|
||||||
AND n.name_de IS NOT DISTINCT FROM c.name_de
|
|
||||||
AND n.ref IS NOT DISTINCT FROM c.ref
|
|
||||||
AND n.highway IS NOT DISTINCT FROM c.highway
|
|
||||||
AND n.construction IS NOT DISTINCT FROM c.construction
|
|
||||||
AND n.brunnel IS NOT DISTINCT FROM c.brunnel
|
|
||||||
AND n.network IS NOT DISTINCT FROM c.network_type;
|
|
||||||
|
|
||||||
INSERT INTO osm_transportation_name_linestring_gen3
|
|
||||||
SELECT n.*
|
|
||||||
FROM osm_transportation_name_linestring_gen3_view AS n
|
|
||||||
JOIN name_changes_compact AS c ON
|
|
||||||
coalesce(n.name, n.ref) = c.name_ref
|
|
||||||
AND n.name IS NOT DISTINCT FROM c.name
|
|
||||||
AND n.name_en IS NOT DISTINCT FROM c.name_en
|
|
||||||
AND n.name_de IS NOT DISTINCT FROM c.name_de
|
|
||||||
AND n.ref IS NOT DISTINCT FROM c.ref
|
|
||||||
AND n.highway IS NOT DISTINCT FROM c.highway
|
|
||||||
AND n.construction IS NOT DISTINCT FROM c.construction
|
|
||||||
AND n.brunnel IS NOT DISTINCT FROM c.brunnel
|
|
||||||
AND n.network IS NOT DISTINCT FROM c.network_type;
|
|
||||||
|
|
||||||
-- REFRESH osm_transportation_name_linestring_gen4
|
|
||||||
DELETE FROM osm_transportation_name_linestring_gen4 AS n
|
|
||||||
USING name_changes_compact AS c
|
|
||||||
WHERE
|
|
||||||
coalesce(n.name, n.ref) = c.name_ref
|
|
||||||
AND n.name IS NOT DISTINCT FROM c.name
|
|
||||||
AND n.name_en IS NOT DISTINCT FROM c.name_en
|
|
||||||
AND n.name_de IS NOT DISTINCT FROM c.name_de
|
|
||||||
AND n.ref IS NOT DISTINCT FROM c.ref
|
|
||||||
AND n.highway IS NOT DISTINCT FROM c.highway
|
|
||||||
AND n.construction IS NOT DISTINCT FROM c.construction
|
|
||||||
AND n.brunnel IS NOT DISTINCT FROM c.brunnel
|
|
||||||
AND n.network IS NOT DISTINCT FROM c.network_type;
|
|
||||||
|
|
||||||
INSERT INTO osm_transportation_name_linestring_gen4
|
|
||||||
SELECT n.*
|
|
||||||
FROM osm_transportation_name_linestring_gen4_view AS n
|
|
||||||
JOIN name_changes_compact AS c ON
|
|
||||||
coalesce(n.name, n.ref) = c.name_ref
|
|
||||||
AND n.name IS NOT DISTINCT FROM c.name
|
|
||||||
AND n.name_en IS NOT DISTINCT FROM c.name_en
|
|
||||||
AND n.name_de IS NOT DISTINCT FROM c.name_de
|
|
||||||
AND n.ref IS NOT DISTINCT FROM c.ref
|
|
||||||
AND n.highway IS NOT DISTINCT FROM c.highway
|
|
||||||
AND n.construction IS NOT DISTINCT FROM c.construction
|
|
||||||
AND n.brunnel IS NOT DISTINCT FROM c.brunnel
|
|
||||||
AND n.network IS NOT DISTINCT FROM c.network_type;
|
|
||||||
|
|
||||||
DROP TABLE name_changes_compact;
|
|
||||||
DELETE FROM transportation_name.name_changes;
|
|
||||||
DELETE FROM transportation_name.updates_name;
|
|
||||||
|
|
||||||
RAISE LOG 'Refresh transportation_name done in %', age(clock_timestamp(), t);
|
|
||||||
RETURN NULL;
|
|
||||||
END;
|
|
||||||
$BODY$
|
|
||||||
LANGUAGE plpgsql;
|
|
||||||
|
|
||||||
|
|
||||||
CREATE TRIGGER trigger_store_transportation_name_network
|
|
||||||
AFTER INSERT OR UPDATE OR DELETE
|
|
||||||
ON osm_transportation_name_network
|
|
||||||
FOR EACH ROW
|
|
||||||
EXECUTE PROCEDURE transportation_name.name_network_store();
|
|
||||||
|
|
||||||
CREATE TRIGGER trigger_flag_name
|
|
||||||
AFTER INSERT
|
|
||||||
ON transportation_name.name_changes
|
|
||||||
FOR EACH STATEMENT
|
|
||||||
EXECUTE PROCEDURE transportation_name.flag_name();
|
|
||||||
|
|
||||||
CREATE CONSTRAINT TRIGGER trigger_refresh_name
|
|
||||||
AFTER INSERT
|
|
||||||
ON transportation_name.updates_name
|
|
||||||
INITIALLY DEFERRED
|
|
||||||
FOR EACH ROW
|
|
||||||
EXECUTE PROCEDURE transportation_name.refresh_name();
|
|
||||||
|
|||||||
|
Before Width: | Height: | Size: 406 KiB After Width: | Height: | Size: 298 KiB |
@ -1,38 +1,39 @@
|
|||||||
generalized_tables:
|
generalized_tables:
|
||||||
# etldoc: osm_water_polygon_gen_z7 -> osm_water_polygon_gen_z6
|
|
||||||
water_polygon_gen_z6:
|
# etldoc: imposm3 -> osm_water_polygon_gen6
|
||||||
source: water_polygon_gen_z7
|
water_polygon_gen6:
|
||||||
|
source: water_polygon_gen5
|
||||||
sql_filter: area>power(ZRES5,2)
|
sql_filter: area>power(ZRES5,2)
|
||||||
tolerance: ZRES7
|
tolerance: ZRES7
|
||||||
|
|
||||||
# etldoc: osm_water_polygon_gen_z8 -> osm_water_polygon_gen_z7
|
# etldoc: imposm3 -> osm_water_polygon_gen5
|
||||||
water_polygon_gen_z7:
|
water_polygon_gen5:
|
||||||
source: water_polygon_gen_z8
|
source: water_polygon_gen4
|
||||||
sql_filter: area>power(ZRES6,2)
|
sql_filter: area>power(ZRES6,2)
|
||||||
tolerance: ZRES8
|
tolerance: ZRES8
|
||||||
|
|
||||||
# etldoc: osm_water_polygon_gen_z9 -> osm_water_polygon_gen_z8
|
# etldoc: imposm3 -> osm_water_polygon_gen4
|
||||||
water_polygon_gen_z8:
|
water_polygon_gen4:
|
||||||
source: water_polygon_gen_z9
|
source: water_polygon_gen3
|
||||||
sql_filter: area>power(ZRES7,2)
|
sql_filter: area>power(ZRES7,2)
|
||||||
tolerance: ZRES9
|
tolerance: ZRES9
|
||||||
|
|
||||||
# etldoc: osm_water_polygon_gen_z10 -> osm_water_polygon_gen_z9
|
# etldoc: imposm3 -> osm_water_polygon_gen3
|
||||||
water_polygon_gen_z9:
|
water_polygon_gen3:
|
||||||
source: water_polygon_gen_z10
|
source: water_polygon_gen2
|
||||||
sql_filter: area>power(ZRES8,2)
|
sql_filter: area>power(ZRES8,2)
|
||||||
tolerance: ZRES10
|
tolerance: ZRES10
|
||||||
|
|
||||||
# etldoc: osm_water_polygon_gen_z11 -> osm_water_polygon_gen_z10
|
# etldoc: imposm3 -> osm_water_polygon_gen2
|
||||||
water_polygon_gen_z10:
|
water_polygon_gen2:
|
||||||
source: water_polygon_gen_z11
|
source: water_polygon_gen1
|
||||||
sql_filter: area>power(ZRES9,2)
|
sql_filter: area>power(ZRES9,2)
|
||||||
tolerance: ZRES11
|
tolerance: ZRES11
|
||||||
|
|
||||||
# etldoc: osm_water_polygon -> osm_water_polygon_gen_z11
|
# etldoc: imposm3 -> osm_water_polygon_gen1
|
||||||
water_polygon_gen_z11:
|
water_polygon_gen1:
|
||||||
source: water_polygon
|
source: water_polygon
|
||||||
sql_filter: area>power(ZRES10,2)
|
sql_filter: area>power(ZRES10,2) AND ST_IsValid(geometry)
|
||||||
tolerance: ZRES12
|
tolerance: ZRES12
|
||||||
|
|
||||||
tunnel_field: &tunnel
|
tunnel_field: &tunnel
|
||||||
@ -87,7 +88,6 @@ tables:
|
|||||||
landuse:
|
landuse:
|
||||||
- reservoir
|
- reservoir
|
||||||
- basin
|
- basin
|
||||||
- salt_pond
|
|
||||||
leisure:
|
leisure:
|
||||||
- swimming_pool
|
- swimming_pool
|
||||||
natural:
|
natural:
|
||||||
|
|||||||