1 // Copyright 2002 David Hilvert <dhilvert@auricle.dyndns.org>,
2 // <dhilvert@ugcs.caltech.edu>
4 /* This file is part of the Anti-Lamenessing Engine.
6 The Anti-Lamenessing Engine is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation; either version 2 of the License, or
9 (at your option) any later version.
11 The Anti-Lamenessing Engine is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
16 You should have received a copy of the GNU General Public License
17 along with the Anti-Lamenessing Engine; if not, write to the Free Software
18 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
25 * Structure to describe a point
36 point(ale_pos x0
, ale_pos x1
) {
41 const ale_pos
&operator[](int i
) const {
48 ale_pos
&operator[](int i
) {
55 point
operator+(point p
) const {
56 return point(p
[0] + x
[0], p
[1] + x
[1]);
59 point
operator-(point p
) const {
60 return point(x
[0] - p
[0], x
[1] - p
[1]);
63 point
operator-() const {
64 return point(-x
[0], -x
[1]);
67 point
operator+=(point p
) {
68 (*this) = (*this) + p
;
73 point
operator-=(point p
) {
74 (*this) = (*this) - p
;
79 point
mult(ale_real d
) const {
80 return point(x
[0] * d
, x
[1] * d
);
83 point
operator*(point p
) const {
85 * element-wise multiplication
87 return point(x
[0] * p
[0], x
[1] * p
[1]);
90 point
operator *=(ale_real d
) {
95 point
operator/(ale_real d
) const {
96 return point(x
[0] / d
, x
[1] / d
);
99 ale_pos
normsq() const {
100 return x
[0] * x
[0] + x
[1] * x
[1];
103 ale_pos
norm() const {
104 return sqrt(normsq());
107 ale_pos
absmaxnorm() const {
108 ale_pos a
= fabs(x
[0]);
109 ale_pos b
= fabs(x
[1]);
111 return (a
> b
) ? a
: b
;
114 ale_pos
lengthtosq(point p
) const {
115 point diff
= operator-(p
);
117 return diff
[0] * diff
[0] + diff
[1] * diff
[1];
119 ale_pos
lengthto(point p
) const {
120 return sqrt(lengthtosq(p
));
123 ale_pos
dproduct(point p
) const {
124 return (x
[0] * p
[0] + x
[1] * p
[1]);
127 ale_pos
anglebetw(point p
, point q
) {
129 * by the law of cosines, the cosine is equal to:
131 * (lengthtosq(p) + lengthtosq(q) - p.lengthtosq(q))
132 * / (2 * lengthto(p) * lengthto(q))
135 ale_pos to_p
= lengthtosq(p
);
136 ale_pos to_q
= lengthtosq(q
);
138 ale_pos cos_of
= (to_p
+ to_q
- p
.lengthtosq(q
))
139 / (2 * sqrt(to_p
) * sqrt(to_q
));
144 static point
posinf() {
150 assert (isinf(a
) == +1);
155 static point
neginf() {
158 assert (isinf(n
[0]) == -1);
163 void accumulate_max(point p
) {
164 for (int d
= 0; d
< 2; d
++)
169 void accumulate_min(point p
) {
170 for (int d
= 0; d
< 2; d
++)
175 static point
undefined() {
183 int defined() const {
189 return (::finite(x
[0])
193 static int defined(const point
&p
) {
199 inline point
operator*(const point
&p
, double d
) {
202 inline point
operator*(double d
, const point
&p
) {
205 inline point
operator*(float d
, const point
&p
) {