ST_ClosestPointOfApproach — 二つのラインの最も近くなる内挿補間点のM値を返します。
float8 ST_ClosestPointOfApproach(
geometry track1, geometry track2)
;
与えられたラインの最も近くなる内挿補間点のM値を返します。入力は妥当なトラジェクトリでなければなりません。ST_IsValidTrajectoryで確認します。トラジェクトリのM値範囲が重ならない場合にはNULLを返します。
与えられたM値における実際の点を得るにはST_LocateAlongを参照して下さい。
初出: 2.2.0
This function supports 3d and will not drop the z-index.
-- 10:00から11:00まで移動する二つの物体の最接近する時刻を返します WITH inp AS ( SELECT ST_AddMeasure('LINESTRING Z (0 0 0, 10 0 5)'::geometry, extract(epoch from '2015-05-26 10:00'::timestamptz), extract(epoch from '2015-05-26 11:00'::timestamptz) ) a, ST_AddMeasure('LINESTRING Z (0 2 10, 12 1 2)'::geometry, extract(epoch from '2015-05-26 10:00'::timestamptz), extract(epoch from '2015-05-26 11:00'::timestamptz) ) b ), cpa AS ( SELECT ST_ClosestPointOfApproach(a,b) m FROM inp ), points AS ( SELECT ST_Force3DZ(ST_GeometryN(ST_LocateAlong(a,m),1)) pa, ST_Force3DZ(ST_GeometryN(ST_LocateAlong(b,m),1)) pb FROM inp, cpa ) SELECT to_timestamp(m) t, ST_Distance(pa,pb) distance FROM points, cpa; t | distance -------------------------------+------------------ 2015-05-26 10:45:31.034483+02 | 1.96036833151395