MobilityDB 1.1
tpoint_tempspatialrels.h
Go to the documentation of this file.
1/*****************************************************************************
2 *
3 * This MobilityDB code is provided under The PostgreSQL License.
4 * Copyright (c) 2016-2023, 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-2023, 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 __TPOINT_TEMPSPATIALRELS_H__
35#define __TPOINT_TEMPSPATIALRELS_H__
36
37/* PostgreSQL */
38#include <postgres.h>
39/* MEOS */
40#include "general/temporal.h"
41
42/* Compute either the tintersects or the tdisjoint relationship */
43#define TINTERSECTS true
44#define TDISJOINT false
45
46/*****************************************************************************/
47
49 const GSERIALIZED *gs, bool tinter, bool atvalue, Datum value);
51 const Temporal *sync2, Datum dist, bool atvalue, Datum value);
52extern int tdwithin_tpointsegm_tpointsegm(Datum sv1, Datum ev1, Datum sv2,
53 Datum ev2, TimestampTz lower, TimestampTz upper, double dist, bool hasz,
54 datum_func3 func, TimestampTz *t1, TimestampTz *t2);
55
56/*****************************************************************************/
57
58#endif
Datum(* datum_func3)(Datum, Datum, Datum)
Definition: temporal.h:368
Temporal * tinterrel_tpoint_geo(const Temporal *temp, const GSERIALIZED *gs, bool tinter, bool restr, bool atvalue)
Evaluates tintersects/tdisjoint for a temporal point and a geometry.
Definition: tpoint_tempspatialrels.c:455
Temporal * tdwithin_tpoint_tpoint1(const Temporal *sync1, const Temporal *sync2, double dist, bool restr, bool atvalue)
Return a temporal Boolean that states whether the temporal points are within the given distance.
Definition: tpoint_tempspatialrels.c:1218
int tdwithin_tpointsegm_tpointsegm(Datum sv1, Datum ev1, Datum sv2, Datum ev2, TimestampTz lower, TimestampTz upper, double dist, bool hasz, datum_func3 func, TimestampTz *t1, TimestampTz *t2)
Return the timestamps at which EITHER the segments of the two temporal points OR a segment of a tempo...
Definition: tpoint_tempspatialrels.c:602
int64 TimestampTz
Definition: pg_ext_defs.in.h:19
uintptr_t Datum
Definition: pg_ext_defs.in.h:4
Definition: postgis_ext_defs.in.h:139
Structure to represent the common structure of temporal values of any temporal subtype.
Definition: meos.h:136