2021-05-19 22:57:50 +03:00
|
|
|
\set ON_ERROR_STOP on
|
|
|
|
SET plpgsql.extra_errors TO 'all';
|
|
|
|
|
|
|
|
-- wm_bbox clips a geometry by a bounding box around a given object,
|
|
|
|
-- matching dimensions of A-class paper (1 by sqrt(2)).
|
|
|
|
drop function if exists wm_bbox;
|
|
|
|
create function wm_bbox(
|
|
|
|
center geometry,
|
|
|
|
scaledwidth float
|
|
|
|
) returns geometry as $$
|
|
|
|
declare
|
|
|
|
halfX float;
|
|
|
|
halfY float;
|
|
|
|
begin
|
|
|
|
halfX = scaledwidth / 2;
|
|
|
|
halfY = halfX * sqrt(2);
|
|
|
|
return st_envelope(
|
|
|
|
st_union(
|
|
|
|
st_translate(center, halfX, halfY),
|
|
|
|
st_translate(center, -halfX, -halfY)
|
|
|
|
)
|
|
|
|
);
|
|
|
|
end $$ language plpgsql;
|
|
|
|
|
|
|
|
-- wm_quadrant divides the given geometry to 4 rectangles
|
|
|
|
-- and returns the requested quadrant following cartesian
|
|
|
|
-- convention:
|
|
|
|
-- +----------+
|
|
|
|
-- | II | I |
|
|
|
|
--- +----------+
|
|
|
|
-- | III | IV |
|
|
|
|
-- +-----+----+
|
|
|
|
-- matching dimensions of A-class paper (1 by sqrt(2).
|
|
|
|
drop function if exists wm_quadrant;
|
|
|
|
create function wm_quadrant(
|
|
|
|
geom geometry,
|
|
|
|
quadrant integer
|
|
|
|
) returns geometry as $$
|
|
|
|
declare
|
|
|
|
xmin float;
|
|
|
|
xmax float;
|
|
|
|
ymin float;
|
|
|
|
ymax float;
|
|
|
|
begin
|
|
|
|
xmin = st_xmin(geom);
|
|
|
|
xmax = st_xmax(geom);
|
|
|
|
ymin = st_ymin(geom);
|
|
|
|
ymax = st_ymax(geom);
|
|
|
|
|
|
|
|
if quadrant = 1 or quadrant = 2 then
|
|
|
|
ymin = (ymin + ymax)/2;
|
|
|
|
else
|
|
|
|
ymax = (ymin + ymax)/2;
|
|
|
|
end if;
|
|
|
|
|
|
|
|
if quadrant = 2 or quadrant = 3 then
|
|
|
|
xmax = (xmin + xmax)/2;
|
|
|
|
else
|
|
|
|
xmin = (xmin + xmax)/2;
|
|
|
|
end if;
|
|
|
|
|
|
|
|
return st_intersection(
|
|
|
|
geom,
|
|
|
|
st_makeenvelope(xmin, ymin, xmax, ymax, st_srid(geom))
|
|
|
|
);
|
|
|
|
end $$ language plpgsql;
|
|
|
|
|
|
|
|
|
2021-05-19 22:57:51 +03:00
|
|
|
delete from wm_debug where name like 'salvis%';
|
2021-05-19 22:57:50 +03:00
|
|
|
delete from wm_visuals where name like 'salvis%';
|
|
|
|
insert into wm_visuals(name, way) values('salvis', (
|
2021-05-19 22:57:50 +03:00
|
|
|
with multismall as (
|
|
|
|
select st_intersection(
|
|
|
|
(select st_union(way) from wm_rivers where name in ('Šalčia', 'Visinčia')),
|
|
|
|
wm_bbox(
|
|
|
|
st_closestpoint(
|
|
|
|
(select way from wm_rivers where name='Šalčia'),
|
|
|
|
(select way from wm_rivers where name='Visinčia')
|
|
|
|
),
|
|
|
|
:scaledwidth
|
|
|
|
)
|
|
|
|
) ways
|
2021-05-19 22:57:50 +03:00
|
|
|
)
|
2021-05-19 22:57:50 +03:00
|
|
|
-- protecting against very small bends that were cut
|
|
|
|
-- in the corner of the picture
|
|
|
|
select st_union(a.geom)
|
|
|
|
from st_dump((select ways from multismall)) a
|
|
|
|
where st_length(a.geom) >= 100
|
2021-05-19 22:57:50 +03:00
|
|
|
));
|
|
|
|
|
2021-05-19 22:57:50 +03:00
|
|
|
do $$
|
|
|
|
declare fig6b1 geometry;
|
|
|
|
declare fig6b2 geometry;
|
|
|
|
declare sclong geometry;
|
|
|
|
declare scshort geometry;
|
|
|
|
begin
|
2021-05-19 22:57:51 +03:00
|
|
|
delete from wm_debug where name like 'fig6-%' or name like 'selfcrossing-1%';
|
2021-05-19 22:57:50 +03:00
|
|
|
delete from wm_visuals where name like 'fig6-%' or name like 'selfcrossing-1%';
|
|
|
|
|
|
|
|
select way from wm_debug where name='fig6' and stage='bbends' and gen=1 into fig6b1 limit 1 offset 0;
|
|
|
|
select way from wm_debug where name='fig6' and stage='bbends' and gen=1 into fig6b2 limit 1 offset 2;
|
|
|
|
insert into wm_visuals (name, way) values('fig6-baseline', st_makeline(st_startpoint(fig6b2), st_endpoint(fig6b2)));
|
|
|
|
insert into wm_visuals (name, way) values('fig6-newline', st_makeline(st_endpoint(fig6b1), st_endpoint(fig6b2)));
|
|
|
|
|
|
|
|
select way from wm_debug where name='selfcrossing-1' and stage='bbends' and gen=1 into sclong limit 1 offset 1;
|
|
|
|
select way from wm_debug where name='selfcrossing-1' and stage='bbends' and gen=1 into scshort limit 1 offset 4;
|
|
|
|
insert into wm_visuals (name, way) values('selfcrossing-1-baseline', st_makeline(st_startpoint(sclong), st_endpoint(sclong)));
|
|
|
|
insert into wm_visuals (name, way) values('selfcrossing-1-newline', st_makeline(st_startpoint(sclong), st_endpoint(scshort)));
|
|
|
|
end $$ language plpgsql;
|
|
|
|
|
|
|
|
|
2021-05-19 22:57:50 +03:00
|
|
|
do $$
|
|
|
|
declare
|
|
|
|
i integer;
|
|
|
|
geom1 geometry;
|
|
|
|
geom2 geometry;
|
2021-05-19 22:57:50 +03:00
|
|
|
geom3 geometry;
|
2021-05-19 22:57:50 +03:00
|
|
|
begin
|
|
|
|
foreach i in array array[16, 64, 256] loop
|
|
|
|
geom1 = st_simplify((select way from wm_visuals where name='salvis'), i);
|
|
|
|
geom2 = st_simplifyvw((select way from wm_visuals where name='salvis'), i*i);
|
|
|
|
insert into wm_visuals(name, way) values
|
|
|
|
('salvis-douglas-' || i, geom1),
|
|
|
|
('salvis-douglas-' || i || '-chaikin', st_chaikinsmoothing(geom1, 5)),
|
|
|
|
('salvis-visvalingam-' || i, geom2),
|
2021-05-19 22:57:50 +03:00
|
|
|
('salvis-visvalingam-' || i || '-chaikin', st_chaikinsmoothing(geom2, 5));
|
|
|
|
end loop;
|
2021-05-19 22:57:51 +03:00
|
|
|
-- 220 doesn't work, because there is an exaggerated bend
|
|
|
|
-- near Šalčia-Žeimena crossing, and it "exaggerates" to the
|
|
|
|
-- other river.
|
|
|
|
-- cross-river crossing detection should be more robust --- and
|
|
|
|
-- the current problems are described in the paper.
|
|
|
|
foreach i in array array[75, 220] loop
|
2021-05-19 22:57:51 +03:00
|
|
|
geom3 = st_simplifywm((select way from wm_visuals where name='salvis'), i, 50, 'salvis-wm-' || i);
|
2021-05-19 22:57:50 +03:00
|
|
|
insert into wm_visuals(name, way) values
|
2021-05-19 22:57:50 +03:00
|
|
|
('salvis-wm-' || i, geom3);
|
2021-05-19 22:57:50 +03:00
|
|
|
end loop;
|
|
|
|
end $$ language plpgsql;
|