File: coords.h

package info (click to toggle)
oregano 0.84.41%2Bdfsg.1-1
  • links: PTS, VCS
  • area: main
  • in suites: bullseye, buster
  • size: 11,856 kB
  • sloc: ansic: 22,476; python: 14,159; xml: 1,184; awk: 386; sh: 57; perl: 20; makefile: 17
file content (102 lines) | stat: -rw-r--r-- 2,581 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
/*
 * coords.c
 *
 *
 * Authors:
 *  Richard Hult <rhult@hem.passagen.se>
 *  Ricardo Markiewicz <rmarkie@fi.uba.ar>
 *  Andres de Barbara <adebarbara@fi.uba.ar>
 *  Marc Lorber <lorber.marc@wanadoo.fr>
 *  Bernhard Schuster <bernhard@ahoi.io>
 *
 * Web page: https://ahoi.io/project/oregano
 *
 * Copyright (C) 1999-2001  Richard Hult
 * Copyright (C) 2003,2004  Ricardo Markiewicz
 * Copyright (C) 2009-2012  Marc Lorber
 * Copyright (C) 2012-2013  Bernhard Schuster
 *
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the GNU General Public License as
 * published by the Free Software Foundation; either version 2 of the
 * License, or (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * General Public License for more details.
 *
 * You should have received a copy of the GNU General Public
 * License along with this program; if not, write to the
 * Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
 * Boston, MA 02110-1301, USA.
 */

#ifndef __COORDS_H
#define __COORDS_H

#define COORDS_DELTA (1e-5)

#include <glib.h>
#include <math.h>

typedef struct _Coords
{
	gdouble x;
	gdouble y;
} Coords;

Coords *coords_new (gdouble x, gdouble y);

Coords *coords_new_copy (const Coords *c);

void coords_destroy (Coords *c);

/*
 * Adds b to a and returns a pointer to a which holds now the result
 */
Coords *coords_add (Coords *a, const Coords *b);

/*
 * Adds b to a and returns a ptr to a Coord struct which has to be freed by
 * either coords_destroy
 */
Coords *coords_sum_new (const Coords *a, const Coords *b);

Coords *coords_set (Coords *a, const Coords *val);

/*
 *
 */
Coords coords_sum (const Coords *a, const Coords *b);

Coords coords_sub (const Coords *a, const Coords *b);

/*
 * calculates the average of two points
 */
Coords coords_average (const Coords *a, const Coords *b);

gdouble coords_cross (const Coords *a, const Coords *b);

gdouble coords_dot (const Coords *a, const Coords *b);

gdouble coords_euclid (const Coords *a);

gdouble coords_euclid2 (const Coords *a);

gdouble coords_distance (const Coords *a, const Coords *b);

gboolean coords_equal (const Coords *a, const Coords *b);

/*
 * used for GHashTable key hashing
 */
guint coords_hash (gconstpointer v);

/*
 * used for comparsion in GHashTable
 */
gint coords_compare (const Coords *a, const Coords *b);

#endif /* __COORDS_H */