postgis/regress/sql-mm-multisurface.sql
2007-08-09 16:56:37 +00:00

559 lines
22 KiB
SQL

SELECT 'ndims01', ndims(geomfromewkt('MULTISURFACE(CURVEPOLYGON(CIRCULARSTRING(
-2 0 0 0,
-1 -1 1 2,
0 0 2 4,
1 -1 3 6,
2 0 4 8,
0 2 2 4,
-2 0 0 0),
(-1 0 1 2,
0 0.5 2 4,
1 0 3 6,
0 1 3 4,
-1 0 1 2)),
((7 8 7 8,
10 10 5 5,
6 14 3 1,
4 11 4 6,
7 8 7 8)))'));
SELECT 'geometrytype01', geometrytype(geomfromewkt('MULTISURFACE(CURVEPOLYGON(CIRCULARSTRING(
-2 0 0 0,
-1 -1 1 2,
0 0 2 4,
1 -1 3 6,
2 0 4 8,
0 2 2 4,
-2 0 0 0),
(-1 0 1 2,
0 0.5 2 4,
1 0 3 6,
0 1 3 4,
-1 0 1 2)),
((7 8 7 8,
10 10 5 5,
6 14 3 1,
4 11 4 6,
7 8 7 8),
(9 9 7 8,
8 12 7 8,
7 10 7 8,
9 9 7 8)))'));
SELECT 'ndims02', ndims(geomfromewkt('MULTISURFACE(CURVEPOLYGON(CIRCULARSTRING(
-2 0 0,
-1 -1 1,
0 0 2,
1 -1 3,
2 0 4,
0 2 2,
-2 0 0),
(-1 0 1,
0 0.5 2,
1 0 3,
0 1 3,
-1 0 1)),
((7 8 7,
10 10 5,
6 14 3,
4 11 4,
7 8 7),
(9 9 7,
8 12 7,
7 10 7,
9 9 7)))'));
SELECT 'geometrytype02', geometrytype(geomfromewkt('MULTISURFACE(CURVEPOLYGON(CIRCULARSTRING(
-2 0 0,
-1 -1 1,
0 0 2,
1 -1 3,
2 0 4,
0 2 2,
-2 0 0),
(-1 0 1,
0 0.5 2,
1 0 3,
0 1 3,
-1 0 1)),
((7 8 7,
10 10 5,
6 14 3,
4 11 4,
7 8 7),
(9 9 7,
8 12 7,
7 10 7,
9 9 7)))'));
SELECT 'ndims03', ndims(geomfromewkt('MULTISURFACEM(CURVEPOLYGON(CIRCULARSTRING(
-2 0 0,
-1 -1 2,
0 0 4,
1 -1 6,
2 0 8,
0 2 4,
-2 0 0),
(-1 0 2,
0 0.5 4,
1 0 6,
0 1 4,
-1 0 2)),
((7 8 8,
10 10 5,
6 14 1,
4 11 6,
7 8 8),
(9 9 8,
8 12 8,
7 10 8,
9 9 8)))'));
SELECT 'geometrytype03', geometrytype(geomfromewkt('MULTISURFACEM(CURVEPOLYGON(CIRCULARSTRING(
-2 0 0,
-1 -1 2,
0 0 4,
1 -1 6,
2 0 8,
0 2 4,
-2 0 0),
(-1 0 2,
0 0.5 4,
1 0 6,
0 1 4,
-1 0 2)),
((7 8 8,
10 10 5,
6 14 1,
4 11 6,
7 8 8)))'));
SELECT 'ndims04', ndims(geomfromewkt('MULTISURFACE(CURVEPOLYGON(CIRCULARSTRING(
-2 0,
-1 -1,
0 0,
1 -1,
2 0,
0 2,
-2 0),
(-1 0,
0 0.5,
1 0,
0 1,
-1 0)),
((7 8,
10 10,
6 14,
4 11,
7 8)))'));
SELECT 'geometrytype04', geometrytype(geomfromewkt('MULTISURFACE(CURVEPOLYGON(CIRCULARSTRING(
-2 0,
-1 -1,
0 0,
1 -1,
2 0,
0 2,
-2 0),
(-1 0,
0 0.5,
1 0,
0 1,
-1 0)),
((7 8,
10 10,
6 14,
4 11,
7 8)))'));
-- Repeat these tests with the new function names.
SELECT 'ndims01', ST_ndims(ST_geomfromewkt('MULTISURFACE(CURVEPOLYGON(CIRCULARSTRING(
-2 0 0 0,
-1 -1 1 2,
0 0 2 4,
1 -1 3 6,
2 0 4 8,
0 2 2 4,
-2 0 0 0),
(-1 0 1 2,
0 0.5 2 4,
1 0 3 6,
0 1 3 4,
-1 0 1 2)),
((7 8 7 8,
10 10 5 5,
6 14 3 1,
4 11 4 6,
7 8 7 8)))'));
SELECT 'geometrytype01', geometrytype(ST_geomfromewkt('MULTISURFACE(CURVEPOLYGON(CIRCULARSTRING(
-2 0 0 0,
-1 -1 1 2,
0 0 2 4,
1 -1 3 6,
2 0 4 8,
0 2 2 4,
-2 0 0 0),
(-1 0 1 2,
0 0.5 2 4,
1 0 3 6,
0 1 3 4,
-1 0 1 2)),
((7 8 7 8,
10 10 5 5,
6 14 3 1,
4 11 4 6,
7 8 7 8),
(9 9 7 8,
8 12 7 8,
7 10 7 8,
9 9 7 8)))'));
SELECT 'ndims02', ST_ndims(ST_geomfromewkt('MULTISURFACE(CURVEPOLYGON(CIRCULARSTRING(
-2 0 0,
-1 -1 1,
0 0 2,
1 -1 3,
2 0 4,
0 2 2,
-2 0 0),
(-1 0 1,
0 0.5 2,
1 0 3,
0 1 3,
-1 0 1)),
((7 8 7,
10 10 5,
6 14 3,
4 11 4,
7 8 7),
(9 9 7,
8 12 7,
7 10 7,
9 9 7)))'));
SELECT 'geometrytype02', geometrytype(ST_geomfromewkt('MULTISURFACE(CURVEPOLYGON(CIRCULARSTRING(
-2 0 0,
-1 -1 1,
0 0 2,
1 -1 3,
2 0 4,
0 2 2,
-2 0 0),
(-1 0 1,
0 0.5 2,
1 0 3,
0 1 3,
-1 0 1)),
((7 8 7,
10 10 5,
6 14 3,
4 11 4,
7 8 7),
(9 9 7,
8 12 7,
7 10 7,
9 9 7)))'));
SELECT 'ndims03', ST_ndims(ST_geomfromewkt('MULTISURFACEM(CURVEPOLYGON(CIRCULARSTRING(
-2 0 0,
-1 -1 2,
0 0 4,
1 -1 6,
2 0 8,
0 2 4,
-2 0 0),
(-1 0 2,
0 0.5 4,
1 0 6,
0 1 4,
-1 0 2)),
((7 8 8,
10 10 5,
6 14 1,
4 11 6,
7 8 8),
(9 9 8,
8 12 8,
7 10 8,
9 9 8)))'));
SELECT 'geometrytype03', geometrytype(ST_geomfromewkt('MULTISURFACEM(CURVEPOLYGON(CIRCULARSTRING(
-2 0 0,
-1 -1 2,
0 0 4,
1 -1 6,
2 0 8,
0 2 4,
-2 0 0),
(-1 0 2,
0 0.5 4,
1 0 6,
0 1 4,
-1 0 2)),
((7 8 8,
10 10 5,
6 14 1,
4 11 6,
7 8 8)))'));
SELECT 'ndims04', ST_ndims(ST_geomfromewkt('MULTISURFACE(CURVEPOLYGON(CIRCULARSTRING(
-2 0,
-1 -1,
0 0,
1 -1,
2 0,
0 2,
-2 0),
(-1 0,
0 0.5,
1 0,
0 1,
-1 0)),
((7 8,
10 10,
6 14,
4 11,
7 8)))'));
SELECT 'geometrytype04', geometrytype(ST_geomfromewkt('MULTISURFACE(CURVEPOLYGON(CIRCULARSTRING(
-2 0,
-1 -1,
0 0,
1 -1,
2 0,
0 2,
-2 0),
(-1 0,
0 0.5,
1 0,
0 1,
-1 0)),
((7 8,
10 10,
6 14,
4 11,
7 8)))'));
CREATE TABLE public.multisurface (id INTEGER, description VARCHAR);
SELECT AddGeometryColumn('public', 'multisurface', 'the_geom_2d', -1, 'MULTISURFACE', 2);
SELECT AddGeometryColumn('public', 'multisurface', 'the_geom_3dm', -1, 'MULTISURFACEM', 3);
SELECT AddGeometryColumn('public', 'multisurface', 'the_geom_3dz', -1, 'MULTISURFACE', 3);
SELECT AddGeometryColumn('public', 'multisurface', 'the_geom_4d', -1, 'MULTISURFACE', 4);
INSERT INTO public.multisurface (
id, description
) VALUES (
1, 'multisurface');
UPDATE public.multisurface
SET the_geom_4d = ST_geomfromewkt('MULTISURFACE(CURVEPOLYGON(CIRCULARSTRING(
-2 0 0 0,
-1 -1 1 2,
0 0 2 4,
1 -1 3 6,
2 0 4 8,
0 2 2 4,
-2 0 0 0),
(-1 0 1 2,
0 0.5 2 4,
1 0 3 6,
0 1 3 4,
-1 0 1 2)),
((7 8 7 8,
10 10 5 5,
6 14 3 1,
4 11 4 6,
7 8 7 8)))')
WHERE id = 1;
UPDATE public.multisurface
SET the_geom_3dz = ST_geomfromewkt('MULTISURFACE(CURVEPOLYGON(CIRCULARSTRING(
-2 0 0,
-1 -1 1,
0 0 2,
1 -1 3,
2 0 4,
0 2 2,
-2 0 0),
(-1 0 1,
0 0.5 2,
1 0 3,
0 1 3,
-1 0 1)),
((7 8 7,
10 10 5,
6 14 3,
4 11 4,
7 8 7)))')
WHERE id = 1;
UPDATE public.multisurface
SET the_geom_3dm = ST_geomfromewkt('MULTISURFACEM(CURVEPOLYGON(CIRCULARSTRING(
-2 0 0,
-1 -1 2,
0 0 4,
1 -1 6,
2 0 8,
0 2 4,
-2 0 0),
(-1 0 2,
0 0.5 4,
1 0 6,
0 1 4,
-1 0 2)),
((7 8 8,
10 10 5,
6 14 1,
4 11 6,
7 8 8)))')
WHERE id = 1;
UPDATE public.multisurface
SET the_geom_2d = ST_geomfromewkt('MULTISURFACE(CURVEPOLYGON(CIRCULARSTRING(
-2 0,
-1 -1,
0 0,
1 -1,
2 0,
0 2,
-2 0),
(-1 0,
0 0.5,
1 0,
0 1,
-1 0)),
((7 8,
10 10,
6 14,
4 11,
7 8)))')
WHERE id = 1;
SELECT 'astext01', astext(the_geom_2d) FROM public.multisurface;
SELECT 'astext02', astext(the_geom_3dm) FROM public.multisurface;
SELECT 'astext03', astext(the_geom_3dz) FROM public.multisurface;
SELECT 'astext04', astext(the_geom_4d) FROM public.multisurface;
SELECT 'asewkt01', asewkt(the_geom_2d) FROM public.multisurface;
SELECT 'asewkt02', asewkt(the_geom_3dm) FROM public.multisurface;
SELECT 'asewkt03', asewkt(the_geom_3dz) FROM public.multisurface;
SELECT 'asewkt04', asewkt(the_geom_4d) FROM public.multisurface;
-- These tests will fail on different architectures
-- We need a way to handle multiple byte orderings
--SELECT 'asbinary01', encode(asbinary(the_geom_2d), 'hex') FROM public.multisurface;
--SELECT 'asbinary02', encode(asbinary(the_geom_3dm), 'hex') FROM public.multisurface;
--SELECT 'asbinary03', encode(asbinary(the_geom_3dz), 'hex') FROM public.multisurface;
--SELECT 'asbinary04', encode(asbinary(the_geom_4d), 'hex') FROM public.multisurface;
--
--SELECT 'asewkb01', encode(asewkb(the_geom_2d), 'hex') FROM public.multisurface;
--SELECT 'asewkb02', encode(asewkb(the_geom_3dm), 'hex') FROM public.multisurface;
--SELECT 'asewkb03', encode(asewkb(the_geom_3dz), 'hex') FROM public.multisurface;
--SELECT 'asewkb04', encode(asewkb(the_geom_4d), 'hex') FROM public.multisurface;
SELECT 'ST_CurveToLine-201', asewkt(snapToGrid(ST_CurveToLine(the_geom_2d, 2), 'POINT(0 0 0 0)'::geometry, 1e-8, 1e-8, 1e-8, 1e-8)) FROM public.multisurface;
SELECT 'ST_CurveToLine-202', asewkt(snapToGrid(ST_CurveToLine(the_geom_3dm, 2), 'POINT(0 0 0 0)'::geometry, 1e-8, 1e-8, 1e-8, 1e-8)) FROM public.multisurface;
SELECT 'ST_CurveToLine-203', asewkt(snapToGrid(ST_CurveToLine(the_geom_3dz, 2), 'POINT(0 0 0 0)'::geometry, 1e-8, 1e-8, 1e-8, 1e-8)) FROM public.multisurface;
SELECT 'ST_CurveToLine-204', asewkt(snapToGrid(ST_CurveToLine(the_geom_4d, 2), 'POINT(0 0 0 0)'::geometry, 1e-8, 1e-8, 1e-8, 1e-8)) FROM public.multisurface;
SELECT 'ST_CurveToLine-401', asewkt(snapToGrid(ST_CurveToLine(the_geom_2d, 4), 'POINT(0 0 0 0)'::geometry, 1e-8, 1e-8, 1e-8, 1e-8)) FROM public.multisurface;
SELECT 'ST_CurveToLine-402', asewkt(snapToGrid(ST_CurveToLine(the_geom_3dm, 4), 'POINT(0 0 0 0)'::geometry, 1e-8, 1e-8, 1e-8, 1e-8)) FROM public.multisurface;
SELECT 'ST_CurveToLine-403', asewkt(snapToGrid(ST_CurveToLine(the_geom_3dz, 4), 'POINT(0 0 0 0)'::geometry, 1e-8, 1e-8, 1e-8, 1e-8)) FROM public.multisurface;
SELECT 'ST_CurveToLine-404', asewkt(snapToGrid(ST_CurveToLine(the_geom_4d, 4), 'POINT(0 0 0 0)'::geometry, 1e-8, 1e-8, 1e-8, 1e-8)) FROM public.multisurface;
SELECT 'ST_CurveToLine01', asewkt(snapToGrid(ST_CurveToLine(the_geom_2d), 'POINT(0 0 0 0)'::geometry, 1e-8, 1e-8, 1e-8, 1e-8)) FROM public.multisurface;
SELECT 'ST_CurveToLine02', asewkt(snapToGrid(ST_CurveToLine(the_geom_3dm), 'POINT(0 0 0 0)'::geometry, 1e-8, 1e-8, 1e-8, 1e-8)) FROM public.multisurface;
SELECT 'ST_CurveToLine03', asewkt(snapToGrid(ST_CurveToLine(the_geom_3dz), 'POINT(0 0 0 0)'::geometry, 1e-8, 1e-8, 1e-8, 1e-8)) FROM public.multisurface;
SELECT 'ST_CurveToLine04', asewkt(snapToGrid(ST_CurveToLine(the_geom_4d), 'POINT(0 0 0 0)'::geometry, 1e-8, 1e-8, 1e-8, 1e-8)) FROM public.multisurface;
SELECT 'box2d01', box2d(the_geom_2d) FROM public.multisurface;
SELECT 'box2d02', box2d(the_geom_3dm) FROM public.multisurface;
SELECT 'box2d03', box2d(the_geom_3dz) FROM public.multisurface;
SELECT 'box2d04', box2d(the_geom_4d) FROM public.multisurface;
SELECT 'box3d01', box3d(the_geom_2d) FROM public.multisurface;
SELECT 'box3d02', box3d(the_geom_3dm) FROM public.multisurface;
SELECT 'box3d03', box3d(the_geom_3dz) FROM public.multisurface;
SELECT 'box3d04', box3d(the_geom_4d) FROM public.multisurface;
SELECT 'isValid01', isValid(the_geom_2d) FROM public.multisurface;
SELECT 'isValid02', isValid(the_geom_3dm) FROM public.multisurface;
SELECT 'isValid03', isValid(the_geom_3dz) FROM public.multisurface;
SELECT 'isValid04', isValid(the_geom_4d) FROM public.multisurface;
SELECT 'dimension01', dimension(the_geom_2d) FROM public.multisurface;
SELECT 'dimension02', dimension(the_geom_3dm) FROM public.multisurface;
SELECT 'dimension03', dimension(the_geom_3dz) FROM public.multisurface;
SELECT 'dimension04', dimension(the_geom_4d) FROM public.multisurface;
SELECT 'numGeometries01', numGeometries(the_geom_2d) FROM public.multisurface;
SELECT 'numGeometries02', numGeometries(the_geom_3dm) FROM public.multisurface;
SELECT 'numGeometries03', numGeometries(the_geom_3dz) FROM public.multisurface;
SELECT 'numGeometries04', numGeometries(the_geom_4d) FROM public.multisurface;
SELECT 'geometryN-201', asEWKT(geometryN(the_geom_2d, 2)) FROM public.multisurface;
SELECT 'geometryN-202', asEWKT(geometryN(the_geom_3dm, 2)) FROM public.multisurface;
SELECT 'geometryN-203', asEWKT(geometryN(the_geom_3dz, 2)) FROM public.multisurface;
SELECT 'geometryN-204', asEWKT(geometryN(the_geom_4d, 2)) FROM public.multisurface;
SELECT 'geometryN-301', (geometryN(the_geom_2d, 3) is null) FROM public.multisurface;
SELECT 'geometryN-302', (geometryN(the_geom_3dm, 3) is null) FROM public.multisurface;
SELECT 'geometryN-303', (geometryN(the_geom_3dz, 3) is null) FROM public.multisurface;
SELECT 'geometryN-304', (geometryN(the_geom_4d, 3) is null) FROM public.multisurface;
-- TODO: ST_SnapToGrid is required to remove platform dependent precision
-- issues. Until ST_SnapToGrid is updated to work against curves, these
-- tests cannot be run.
--SELECT 'ST_LineToCurve01', asewkt(ST_LineToCurve(ST_CurveToLine(the_geom_2d))) FROM public.multisurface;
--SELECT 'ST_LineToCurve02', asewkt(ST_LineToCurve(ST_CurveToLine(the_geom_3dm))) FROM public.multisurface;
--SELECT 'ST_LineToCurve03', asewkt(ST_LineToCurve(ST_CurveToLine(the_geom_3dz))) FROM public.multisurface;
--SELECT 'ST_LineToCurve04', asewkt(ST_LineToCurve(ST_CurveToLine(the_geom_4d))) FROM public.multisurface;
-- Repeat tests with new function names.
SELECT 'astext01', ST_astext(the_geom_2d) FROM public.multisurface;
SELECT 'astext02', ST_astext(the_geom_3dm) FROM public.multisurface;
SELECT 'astext03', ST_astext(the_geom_3dz) FROM public.multisurface;
SELECT 'astext04', ST_astext(the_geom_4d) FROM public.multisurface;
SELECT 'asewkt01', ST_asewkt(the_geom_2d) FROM public.multisurface;
SELECT 'asewkt02', ST_asewkt(the_geom_3dm) FROM public.multisurface;
SELECT 'asewkt03', ST_asewkt(the_geom_3dz) FROM public.multisurface;
SELECT 'asewkt04', ST_asewkt(the_geom_4d) FROM public.multisurface;
-- These tests will fail on different architectures
-- We need a way to handle multiple byte orderings
--SELECT 'asbinary01', encode(ST_asbinary(the_geom_2d), 'hex') FROM public.multisurface;
--SELECT 'asbinary02', encode(ST_asbinary(the_geom_3dm), 'hex') FROM public.multisurface;
--SELECT 'asbinary03', encode(ST_asbinary(the_geom_3dz), 'hex') FROM public.multisurface;
--SELECT 'asbinary04', encode(ST_asbinary(the_geom_4d), 'hex') FROM public.multisurface;
--
--SELECT 'asewkb01', encode(ST_asewkb(the_geom_2d), 'hex') FROM public.multisurface;
--SELECT 'asewkb02', encode(ST_asewkb(the_geom_3dm), 'hex') FROM public.multisurface;
--SELECT 'asewkb03', encode(ST_asewkb(the_geom_3dz), 'hex') FROM public.multisurface;
--SELECT 'asewkb04', encode(ST_asewkb(the_geom_4d), 'hex') FROM public.multisurface;
SELECT 'box2d01', ST_box2d(the_geom_2d) FROM public.multisurface;
SELECT 'box2d02', ST_box2d(the_geom_3dm) FROM public.multisurface;
SELECT 'box2d03', ST_box2d(the_geom_3dz) FROM public.multisurface;
SELECT 'box2d04', ST_box2d(the_geom_4d) FROM public.multisurface;
SELECT 'box3d01', ST_box3d(the_geom_2d) FROM public.multisurface;
SELECT 'box3d02', ST_box3d(the_geom_3dm) FROM public.multisurface;
SELECT 'box3d03', ST_box3d(the_geom_3dz) FROM public.multisurface;
SELECT 'box3d04', ST_box3d(the_geom_4d) FROM public.multisurface;
SELECT 'isValid01', ST_isValid(the_geom_2d) FROM public.multisurface;
SELECT 'isValid02', ST_isValid(the_geom_3dm) FROM public.multisurface;
SELECT 'isValid03', ST_isValid(the_geom_3dz) FROM public.multisurface;
SELECT 'isValid04', ST_isValid(the_geom_4d) FROM public.multisurface;
SELECT 'dimension01', ST_dimension(the_geom_2d) FROM public.multisurface;
SELECT 'dimension02', ST_dimension(the_geom_3dm) FROM public.multisurface;
SELECT 'dimension03', ST_dimension(the_geom_3dz) FROM public.multisurface;
SELECT 'dimension04', ST_dimension(the_geom_4d) FROM public.multisurface;
SELECT 'numGeometries01', ST_numGeometries(the_geom_2d) FROM public.multisurface;
SELECT 'numGeometries02', ST_numGeometries(the_geom_3dm) FROM public.multisurface;
SELECT 'numGeometries03', ST_numGeometries(the_geom_3dz) FROM public.multisurface;
SELECT 'numGeometries04', ST_numGeometries(the_geom_4d) FROM public.multisurface;
SELECT 'geometryN-201', ST_asEWKT(ST_geometryN(the_geom_2d, 2)) FROM public.multisurface;
SELECT 'geometryN-202', ST_asEWKT(ST_geometryN(the_geom_3dm, 2)) FROM public.multisurface;
SELECT 'geometryN-203', ST_asEWKT(ST_geometryN(the_geom_3dz, 2)) FROM public.multisurface;
SELECT 'geometryN-204', ST_asEWKT(ST_geometryN(the_geom_4d, 2)) FROM public.multisurface;
SELECT 'geometryN-301', (ST_geometryN(the_geom_2d, 3) is null) FROM public.multisurface;
SELECT 'geometryN-302', (ST_geometryN(the_geom_3dm, 3) is null) FROM public.multisurface;
SELECT 'geometryN-303', (ST_geometryN(the_geom_3dz, 3) is null) FROM public.multisurface;
SELECT 'geometryN-304', (ST_geometryN(the_geom_4d, 3) is null) FROM public.multisurface;
SELECT DropGeometryColumn('public', 'multisurface', 'the_geom_2d');
SELECT DropGeometryColumn('public', 'multisurface', 'the_geom_3dm');
SELECT DropGeometryColumn('public', 'multisurface', 'the_geom_3dz');
SELECT DropGeometryColumn('public', 'multisurface', 'the_geom_4d');
DROP TABLE public.multisurface;