MobilityDB 1.3
Loading...
Searching...
No Matches
tgeo_distance.h
Go to the documentation of this file.
1/*****************************************************************************
2 *
3 * This MobilityDB code is provided under The PostgreSQL License.
4 * Copyright (c) 2016-2025, Université libre de Bruxelles and MobilityDB
5 * contributors
6 *
7 * MobilityDB includes portions of PostGIS version 3 source code released
8 * under the GNU General Public License (GPLv2 or later).
9 * Copyright (c) 2001-2025, PostGIS contributors
10 *
11 * Permission to use, copy, modify, and distribute this software and its
12 * documentation for any purpose, without fee, and without a written
13 * agreement is hereby granted, provided that the above copyright notice and
14 * this paragraph and the following two paragraphs appear in all copies.
15 *
16 * IN NO EVENT SHALL UNIVERSITE LIBRE DE BRUXELLES BE LIABLE TO ANY PARTY FOR
17 * DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES, INCLUDING
18 * LOST PROFITS, ARISING OUT OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION,
19 * EVEN IF UNIVERSITE LIBRE DE BRUXELLES HAS BEEN ADVISED OF THE POSSIBILITY
20 * OF SUCH DAMAGE.
21 *
22 * UNIVERSITE LIBRE DE BRUXELLES SPECIFICALLY DISCLAIMS ANY WARRANTIES,
23 * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY
24 * AND FITNESS FOR A PARTICULAR PURPOSE. THE SOFTWARE PROVIDED HEREUNDER IS ON
25 * AN "AS IS" BASIS, AND UNIVERSITE LIBRE DE BRUXELLES HAS NO OBLIGATIONS TO
26 * PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS.
27 *
28 *****************************************************************************/
29
34#ifndef __TGEO_DISTANCE_H__
35#define __TGEO_DISTANCE_H__
36
37/* PostgreSQL */
38#include <postgres.h>
39/* PostGIS */
40#include <liblwgeom.h>
41/* MEOS */
42#include <meos.h>
43#include "temporal/temporal.h"
44
45/*****************************************************************************/
46
47extern bool point3d_min_dist(const POINT3DZ *p1, const POINT3DZ *p2,
48 const POINT3DZ *p3, const POINT3DZ *p4, double *fraction);
49
50extern int tgeompointsegm_distance_turnpt(Datum start1, Datum end1,
51 Datum start2, Datum end2, Datum param UNUSED, TimestampTz lower, TimestampTz upper,
52 TimestampTz *t1, TimestampTz *t2);
53extern int tgeogpointsegm_distance_turnpt(Datum start1, Datum end1,
54 Datum start2, Datum end2, Datum param UNUSED, TimestampTz lower, TimestampTz upper,
55 TimestampTz *t1, TimestampTz *t2);
56
57extern double tnumberinst_distance(const TInstant *inst1,
58 const TInstant *inst2);
59extern double tinstant_distance(const TInstant *inst1, const TInstant *inst2,
60 datum_func2 func);
61
62/*****************************************************************************/
63
64#endif /* __TGEO_DISTANCE_H__ */
Datum(* datum_func2)(Datum, Datum)
Definition: temporal.h:296
#define UNUSED
Definition: temporal.h:75
External API of the Mobility Engine Open Source (MEOS) library.
int64 TimestampTz
Definition: postgres_ext_defs.in.h:22
uintptr_t Datum
Definition: postgres_ext_defs.in.h:7
Definition: postgis_ext_defs.in.h:122
Structure to represent temporal values of instant subtype.
Definition: meos.h:185
double tinstant_distance(const TInstant *inst1, const TInstant *inst2, datum_func2 func)
Return the distance between two temporal instants.
Definition: temporal_analytics.c:713
double tnumberinst_distance(const TInstant *inst1, const TInstant *inst2)
Return the distance between two temporal instants.
Definition: tnumber_distance.c:60
int tgeogpointsegm_distance_turnpt(Datum start1, Datum end1, Datum start2, Datum end2, Datum param UNUSED, TimestampTz lower, TimestampTz upper, TimestampTz *t1, TimestampTz *t2)
Return 1 if the single timestamp at which the two temporal geography point segments are at the minimu...
Definition: tgeo_distance.c:307
bool point3d_min_dist(const POINT3DZ *p1, const POINT3DZ *p2, const POINT3DZ *p3, const POINT3DZ *p4, double *fraction)
Distance functions for temporal points.
Definition: tgeo_distance.c:212
int tgeompointsegm_distance_turnpt(Datum start1, Datum end1, Datum start2, Datum end2, Datum param UNUSED, TimestampTz lower, TimestampTz upper, TimestampTz *t1, TimestampTz *t2)
Return 1 the timestamp at which two temporal geometry point segments are at the minimum distance.
Definition: tgeo_distance.c:261