annotate doc/interpreter/geometry.txi @ 8920:eb63fbe60fab

update copyright notices
author John W. Eaton <jwe@octave.org>
date Sat, 07 Mar 2009 10:41:27 -0500
parents 8ae26422a6ce
children e9dc2ed2ec0f
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
8920
eb63fbe60fab update copyright notices
John W. Eaton <jwe@octave.org>
parents: 8480
diff changeset
1 @c Copyright (C) 2007, 2008, 2009 John W. Eaton and David Bateman
7018
fd42779a8428 [project @ 2007-10-13 00:52:12 by jwe]
jwe
parents: 7007
diff changeset
2 @c
fd42779a8428 [project @ 2007-10-13 00:52:12 by jwe]
jwe
parents: 7007
diff changeset
3 @c This file is part of Octave.
fd42779a8428 [project @ 2007-10-13 00:52:12 by jwe]
jwe
parents: 7007
diff changeset
4 @c
fd42779a8428 [project @ 2007-10-13 00:52:12 by jwe]
jwe
parents: 7007
diff changeset
5 @c Octave is free software; you can redistribute it and/or modify it
fd42779a8428 [project @ 2007-10-13 00:52:12 by jwe]
jwe
parents: 7007
diff changeset
6 @c under the terms of the GNU General Public License as published by the
fd42779a8428 [project @ 2007-10-13 00:52:12 by jwe]
jwe
parents: 7007
diff changeset
7 @c Free Software Foundation; either version 3 of the License, or (at
fd42779a8428 [project @ 2007-10-13 00:52:12 by jwe]
jwe
parents: 7007
diff changeset
8 @c your option) any later version.
fd42779a8428 [project @ 2007-10-13 00:52:12 by jwe]
jwe
parents: 7007
diff changeset
9 @c
fd42779a8428 [project @ 2007-10-13 00:52:12 by jwe]
jwe
parents: 7007
diff changeset
10 @c Octave is distributed in the hope that it will be useful, but WITHOUT
fd42779a8428 [project @ 2007-10-13 00:52:12 by jwe]
jwe
parents: 7007
diff changeset
11 @c ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
fd42779a8428 [project @ 2007-10-13 00:52:12 by jwe]
jwe
parents: 7007
diff changeset
12 @c FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
fd42779a8428 [project @ 2007-10-13 00:52:12 by jwe]
jwe
parents: 7007
diff changeset
13 @c for more details.
fd42779a8428 [project @ 2007-10-13 00:52:12 by jwe]
jwe
parents: 7007
diff changeset
14 @c
fd42779a8428 [project @ 2007-10-13 00:52:12 by jwe]
jwe
parents: 7007
diff changeset
15 @c You should have received a copy of the GNU General Public License
fd42779a8428 [project @ 2007-10-13 00:52:12 by jwe]
jwe
parents: 7007
diff changeset
16 @c along with Octave; see the file COPYING. If not, see
fd42779a8428 [project @ 2007-10-13 00:52:12 by jwe]
jwe
parents: 7007
diff changeset
17 @c <http://www.gnu.org/licenses/>.
6558
e0e1c6df5ab2 [project @ 2007-04-20 19:33:24 by jwe]
jwe
parents:
diff changeset
18
e0e1c6df5ab2 [project @ 2007-04-20 19:33:24 by jwe]
jwe
parents:
diff changeset
19 @node Geometry
e0e1c6df5ab2 [project @ 2007-04-20 19:33:24 by jwe]
jwe
parents:
diff changeset
20 @chapter Geometry
e0e1c6df5ab2 [project @ 2007-04-20 19:33:24 by jwe]
jwe
parents:
diff changeset
21
8347
fa78cb8d8a5c corrections for typos
Brian Gough<bjg@network-theory.co.uk>
parents: 7984
diff changeset
22 Much of geometry code in Octave is based on the QHull library@footnote{Barber,
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
23 C.B., Dobkin, D.P., and Huhdanpaa, H.T., "The Quickhull algorithm for
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
24 convex hulls," ACM Trans. on Mathematical Software, 22(4):469-483, Dec
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
25 1996, @url{http://www.qhull.org}}. Some of the documentation for Qhull,
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
26 particularly for the options that can be passed to @code{delaunay},
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
27 @code{voronoi} and @code{convhull}, etc, is relevant to Octave users.
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
28
6823
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
29 @menu
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
30 * Delaunay Triangulation::
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
31 * Voronoi Diagrams::
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
32 * Convex Hull::
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
33 * Interpolation on Scattered Data::
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
34 @end menu
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
35
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
36 @node Delaunay Triangulation
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
37 @section Delaunay Triangulation
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
38
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
39 The Delaunay triangulation is constructed from a set of
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
40 circum-circles. These circum-circles are chosen so that there are at
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
41 least three of the points in the set to triangulation on the
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
42 circumference of the circum-circle. None of the points in the set of
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
43 points falls within any of the circum-circles.
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
44
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
45 In general there are only three points on the circumference of any
8434
7ceb99b0abbf Removed typo from geometry.txi
Francesco Potortì <pot@gnu.org>
parents: 8347
diff changeset
46 circum-circle. However, in some cases, and in particular for the
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
47 case of a regular grid, 4 or more points can be on a single
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
48 circum-circle. In this case the Delaunay triangulation is not unique.
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
49
6823
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
50 @DOCSTRING(delaunay)
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
51
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
52 The 3- and N-dimensional extension of the Delaunay triangulation are
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
53 given by @code{delaunay3} and @code{delaunayn} respectively.
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
54 @code{delaunay3} returns a set of tetrahedra that satisfy the
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
55 Delaunay circum-circle criteria. Similarly, @code{delaunayn} returns the
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
56 N-dimensional simplex satisfying the Delaunay circum-circle criteria.
7007
6304d9ea0a30 [project @ 2007-10-11 16:26:36 by jwe]
jwe
parents: 7001
diff changeset
57 The N-dimensional extension of a triangulation is called a tessellation.
6823
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
58
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
59 @DOCSTRING(delaunay3)
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
60
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
61 @DOCSTRING(delaunayn)
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
62
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
63 An example of a Delaunay triangulation of a set of points is
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
64
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
65 @example
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
66 @group
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
67 rand ("state", 2);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
68 x = rand (10, 1);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
69 y = rand (10, 1);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
70 T = delaunay (x, y);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
71 X = [ x(T(:,1)); x(T(:,2)); x(T(:,3)); x(T(:,1)) ];
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
72 Y = [ y(T(:,1)); y(T(:,2)); y(T(:,3)); y(T(:,1)) ];
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
73 axis ([0, 1, 0, 1]);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
74 plot(X, Y, "b", x, y, "r*");
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
75 @end group
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
76 @end example
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
77
6855
a052825889a0 [project @ 2007-09-01 00:08:16 by dbateman]
dbateman
parents: 6847
diff changeset
78 @ifset HAVE_QHULL
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
79 @ifnotinfo
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
80 @noindent
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
81 The result of which can be seen in @ref{fig:delaunay}.
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
82
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
83 @float Figure,fig:delaunay
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
84 @image{delaunay,8cm}
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
85 @caption{Delaunay triangulation of a random set of points}
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
86 @end float
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
87 @end ifnotinfo
6855
a052825889a0 [project @ 2007-09-01 00:08:16 by dbateman]
dbateman
parents: 6847
diff changeset
88 @end ifset
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
89
6823
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
90 @menu
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
91 * Plotting the Triangulation::
6823
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
92 * Identifying points in Triangulation::
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
93 @end menu
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
94
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
95 @node Plotting the Triangulation
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
96 @subsection Plotting the Triangulation
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
97
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
98 Octave has the functions @code{triplot} and @code{trimesh} to plot the
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
99 Delaunay triangulation of a 2-dimensional set of points.
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
100
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
101 @DOCSTRING(triplot)
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
102
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
103 @DOCSTRING(trimesh)
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
104
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
105 The difference between @code{triplot} and @code{trimesh} is that the
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
106 former only plots the 2-dimensional triangulation itself, whereas the
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
107 second plots the value of some function @code{f (@var{x}, @var{y})}.
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
108 An example of the use of the @code{triplot} function is
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
109
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
110 @example
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
111 @group
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
112 rand ("state", 2)
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
113 x = rand (20, 1);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
114 y = rand (20, 1);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
115 tri = delaunay (x, y);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
116 triplot (tri, x, y);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
117 @end group
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
118 @end example
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
119
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
120 that plot the Delaunay triangulation of a set of random points in
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
121 2-dimensions.
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
122 @ifnotinfo
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
123 The output of the above can be seen in @ref{fig:triplot}.
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
124
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
125 @float Figure,fig:triplot
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
126 @image{triplot,8cm}
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
127 @caption{Delaunay triangulation of a random set of points}
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
128 @end float
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
129 @end ifnotinfo
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
130
6823
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
131 @node Identifying points in Triangulation
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
132 @subsection Identifying points in Triangulation
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
133
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
134 It is often necessary to identify whether a particular point in the
7007
6304d9ea0a30 [project @ 2007-10-11 16:26:36 by jwe]
jwe
parents: 7001
diff changeset
135 N-dimensional space is within the Delaunay tessellation of a set of
8480
8ae26422a6ce [docs] N-Simplex => N-simplex
Brian Gough <bjg@gnu.org>
parents: 8434
diff changeset
136 points in this N-dimensional space, and if so which N-simplex contains
7007
6304d9ea0a30 [project @ 2007-10-11 16:26:36 by jwe]
jwe
parents: 7001
diff changeset
137 the point and which point in the tessellation is closest to the desired
6823
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
138 point. The functions @code{tsearch} and @code{dsearch} perform this
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
139 function in a triangulation, and @code{tsearchn} and @code{dsearchn} in
7007
6304d9ea0a30 [project @ 2007-10-11 16:26:36 by jwe]
jwe
parents: 7001
diff changeset
140 an N-dimensional tessellation.
6823
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
141
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
142 To identify whether a particular point represented by a vector @var{p}
8480
8ae26422a6ce [docs] N-Simplex => N-simplex
Brian Gough <bjg@gnu.org>
parents: 8434
diff changeset
143 falls within one of the simplices of an N-simplex, we can write the
6823
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
144 Cartesian coordinates of the point in a parametric form with respect to
8480
8ae26422a6ce [docs] N-Simplex => N-simplex
Brian Gough <bjg@gnu.org>
parents: 8434
diff changeset
145 the N-simplex. This parametric form is called the Barycentric
8ae26422a6ce [docs] N-Simplex => N-simplex
Brian Gough <bjg@gnu.org>
parents: 8434
diff changeset
146 Coordinates of the point. If the points defining the N-simplex are given
6823
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
147 by @code{@var{N} + 1} vectors @var{t}(@var{i},:), then the Barycentric
8347
fa78cb8d8a5c corrections for typos
Brian Gough<bjg@network-theory.co.uk>
parents: 7984
diff changeset
148 coordinates defining the point @var{p} are given by
6823
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
149
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
150 @example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
151 @var{p} = sum (@var{beta}(1:@var{N}+1) * @var{t}(1:@var{N}+1),:)
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
152 @end example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
153
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
154 @noindent
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
155 where there are @code{@var{N} + 1} values @code{@var{beta}(@var{i})}
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
156 that together as a vector represent the Barycentric coordinates of the
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
157 point @var{p}. To ensure a unique solution for the values of
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
158 @code{@var{beta}(@var{i})} an additional criteria of
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
159
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
160 @example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
161 sum (@var{beta}(1:@var{N}+1)) == 1
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
162 @end example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
163
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
164 @noindent
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
165 is imposed, and we can therefore write the above as
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
166
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
167 @example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
168 @var{p} - @var{t}(end, :) = @var{beta}(1:end-1) * (@var{t}(1:end-1, :)
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
169 - ones(@var{N}, 1) * @var{t}(end, :)
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
170 @end example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
171
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
172 @noindent
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
173 Solving for @var{beta} we can then write
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
174
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
175 @example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
176 @var{beta}(1:end-1) = (@var{p} - @var{t}(end, :)) / (@var{t}(1:end-1, :)
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
177 - ones(@var{N}, 1) * @var{t}(end, :))
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
178 @var{beta}(end) = sum(@var{beta}(1:end-1))
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
179 @end example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
180
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
181 @noindent
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
182 which gives the formula for the conversion of the Cartesian coordinates
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
183 of the point @var{p} to the Barycentric coordinates @var{beta}. An
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
184 important property of the Barycentric coordinates is that for all points
8480
8ae26422a6ce [docs] N-Simplex => N-simplex
Brian Gough <bjg@gnu.org>
parents: 8434
diff changeset
185 in the N-simplex
6823
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
186
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
187 @example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
188 0 <= @var{beta}(@var{i}) <= 1
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
189 @end example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
190
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
191 @noindent
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
192 Therefore, the test in @code{tsearch} and @code{tsearchn} essentially
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
193 only needs to express each point in terms of the Barycentric coordinates
8480
8ae26422a6ce [docs] N-Simplex => N-simplex
Brian Gough <bjg@gnu.org>
parents: 8434
diff changeset
194 of each of the simplices of the N-simplex and test the values of
6823
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
195 @var{beta}. This is exactly the implementation used in
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
196 @code{tsearchn}. @code{tsearch} is optimized for 2-dimensions and the
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
197 Barycentric coordinates are not explicitly formed.
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
198
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
199 @DOCSTRING(tsearch)
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
200
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
201 @DOCSTRING(tsearchn)
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
202
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
203 An example of the use of @code{tsearch} can be seen with the simple
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
204 triangulation
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
205
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
206 @example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
207 @group
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
208 @var{x} = [-1; -1; 1; 1];
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
209 @var{y} = [-1; 1; -1; 1];
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
210 @var{tri} = [1, 2, 3; 2, 3, 1];
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
211 @end group
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
212 @end example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
213
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
214 @noindent
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
215 consisting of two triangles defined by @var{tri}. We can then identify
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
216 which triangle a point falls in like
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
217
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
218 @example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
219 @group
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
220 tsearch (@var{x}, @var{y}, @var{tri}, -0.5, -0.5)
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
221 @result{} 1
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
222 tsearch (@var{x}, @var{y}, @var{tri}, 0.5, 0.5)
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
223 @result{} 2
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
224 @end group
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
225 @end example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
226
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
227 @noindent
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
228 and we can confirm that a point doesn't lie within one of the triangles like
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
229
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
230 @example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
231 @group
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
232 tsearch (@var{x}, @var{y}, @var{tri}, 2, 2)
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
233 @result{} NaN
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
234 @end group
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
235 @end example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
236
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
237 The @code{dsearch} and @code{dsearchn} find the closest point in a
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
238 tessellation to the desired point. The desired point does not
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
239 necessarily have to be in the tessellation, and even if it the returned
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
240 point of the tessellation does not have to be one of the vertexes of the
6823
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
241 N-simplex within which the desired point is found.
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
242
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
243 @DOCSTRING(dsearch)
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
244
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
245 @DOCSTRING(dsearchn)
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
246
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
247 An example of the use of @code{dsearch}, using the above values of
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
248 @var{x}, @var{y} and @var{tri} is
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
249
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
250 @example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
251 @group
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
252 dsearch (@var{x}, @var{y}, @var{tri}, -2, -2)
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
253 @result{} 1
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
254 @end group
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
255 @end example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
256
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
257 If you wish the points that are outside the tessellation to be flagged,
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
258 then @code{dsearchn} can be used as
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
259
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
260 @example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
261 @group
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
262 dsearchn ([@var{x}, @var{y}], @var{tri}, [-2, -2], NaN)
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
263 @result{} NaN
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
264 dsearchn ([@var{x}, @var{y}], @var{tri}, [-0.5, -0.5], NaN)
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
265 @result{} 1
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
266 @end group
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
267 @end example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
268
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
269 @noindent
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
270 where the point outside the tessellation are then flagged with @code{NaN}.
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
271
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
272 @node Voronoi Diagrams
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
273 @section Voronoi Diagrams
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
274
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
275 A Voronoi diagram or Voronoi tessellation of a set of points @var{s} in
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
276 an N-dimensional space, is the tessellation of the N-dimensional space
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
277 such that all points in @code{@var{v}(@var{p})}, a partitions of the
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
278 tessellation where @var{p} is a member of @var{s}, are closer to @var{p}
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
279 than any other point in @var{s}. The Voronoi diagram is related to the
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
280 Delaunay triangulation of a set of points, in that the vertexes of the
8347
fa78cb8d8a5c corrections for typos
Brian Gough<bjg@network-theory.co.uk>
parents: 7984
diff changeset
281 Voronoi tessellation are the centers of the circum-circles of the
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
282 simplicies of the Delaunay tessellation.
6823
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
283
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
284 @DOCSTRING(voronoi)
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
285
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
286 @DOCSTRING(voronoin)
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
287
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
288 An example of the use of @code{voronoi} is
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
289
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
290 @example
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
291 @group
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
292 rand("state",9);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
293 x = rand(10,1);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
294 y = rand(10,1);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
295 tri = delaunay (x, y);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
296 [vx, vy] = voronoi (x, y, tri);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
297 triplot (tri, x, y, "b");
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
298 hold on;
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
299 plot (vx, vy, "r");
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
300 @end group
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
301 @end example
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
302
6855
a052825889a0 [project @ 2007-09-01 00:08:16 by dbateman]
dbateman
parents: 6847
diff changeset
303 @ifset HAVE_QHULL
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
304 @ifnotinfo
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
305 @noindent
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
306 The result of which can be seen in @ref{fig:voronoi}. Note that the
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
307 circum-circle of one of the triangles has been added to this figure, to
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
308 make the relationship between the Delaunay tessellation and the Voronoi
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
309 diagram clearer.
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
310
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
311 @float Figure,fig:voronoi
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
312 @image{voronoi,8cm}
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
313 @caption{Delaunay triangulation and Voronoi diagram of a random set of points}
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
314 @end float
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
315 @end ifnotinfo
6855
a052825889a0 [project @ 2007-09-01 00:08:16 by dbateman]
dbateman
parents: 6847
diff changeset
316 @end ifset
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
317
6847
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
318 Additional information about the size of the facets of a Voronoi
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
319 diagram, and which points of a set of points is in a polygon can be had
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
320 with the @code{polyarea} and @code{inpolygon} functions respectively.
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
321
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
322 @DOCSTRING(polyarea)
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
323
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
324 An example of the use of @code{polyarea} might be
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
325
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
326 @example
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
327 @group
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
328 rand ("state", 2);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
329 x = rand (10, 1);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
330 y = rand (10, 1);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
331 [c, f] = voronoin ([x, y]);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
332 af = zeros (size(f));
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
333 for i = 1 : length (f)
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
334 af(i) = polyarea (c (f @{i, :@}, 1), c (f @{i, :@}, 2));
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
335 endfor
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
336 @end group
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
337 @end example
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
338
7984
bbaa5d7d0143 Some documentation updates
David Bateman <dbateman@free.fr>
parents: 7018
diff changeset
339 Facets of the Voronoi diagram with a vertex at infinity have infinity
bbaa5d7d0143 Some documentation updates
David Bateman <dbateman@free.fr>
parents: 7018
diff changeset
340 area. A simplified version of @code{polyarea} for rectangles is
bbaa5d7d0143 Some documentation updates
David Bateman <dbateman@free.fr>
parents: 7018
diff changeset
341 available with @code{rectint}
bbaa5d7d0143 Some documentation updates
David Bateman <dbateman@free.fr>
parents: 7018
diff changeset
342
bbaa5d7d0143 Some documentation updates
David Bateman <dbateman@free.fr>
parents: 7018
diff changeset
343 @DOCSTRING(rectint)
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
344
6847
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
345 @DOCSTRING(inpolygon)
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
346
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
347 An example of the use of @code{inpolygon} might be
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
348
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
349 @example
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
350 @group
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
351 randn ("state", 2);
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
352 x = randn (100, 1);
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
353 y = randn (100, 1);
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
354 vx = cos (pi * [-1 : 0.1: 1]);
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
355 vy = sin (pi * [-1 : 0.1 : 1]);
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
356 in = inpolygon (x, y, vx, vy);
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
357 plot(vx, vy, x(in), y(in), "r+", x(!in), y(!in), "bo");
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
358 axis ([-2, 2, -2, 2]);
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
359 @end group
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
360 @end example
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
361
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
362 @ifnotinfo
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
363 @noindent
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
364 The result of which can be seen in @ref{fig:inpolygon}.
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
365
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
366 @float Figure,fig:inpolygon
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
367 @image{inpolygon,8cm}
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
368 @caption{Demonstration of the @code{inpolygon} function to determine the
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
369 points inside a polygon}
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
370 @end float
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
371 @end ifnotinfo
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
372
6823
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
373 @node Convex Hull
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
374 @section Convex Hull
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
375
7001
8b0cfeb06365 [project @ 2007-10-10 18:02:59 by jwe]
jwe
parents: 6855
diff changeset
376 The convex hull of a set of points is the minimum convex envelope
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
377 containing all of the points. Octave has the functions @code{convhull}
7007
6304d9ea0a30 [project @ 2007-10-11 16:26:36 by jwe]
jwe
parents: 7001
diff changeset
378 and @code{convhulln} to calculate the convex hull of 2-dimensional and
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
379 N-dimensional sets of points.
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
380
6823
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
381 @DOCSTRING(convhull)
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
382
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
383 @DOCSTRING(convhulln)
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
384
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
385 An example of the use of @code{convhull} is
6823
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
386
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
387 @example
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
388 @group
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
389 x = -3:0.05:3;
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
390 y = abs (sin (x));
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
391 k = convhull (x, y);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
392 plot (x(k), y(k), "r-", x, y, "b+");
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
393 axis ([-3.05, 3.05, -0.05, 1.05]);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
394 @end group
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
395 @end example
6823
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
396
6855
a052825889a0 [project @ 2007-09-01 00:08:16 by dbateman]
dbateman
parents: 6847
diff changeset
397 @ifset HAVE_QHULL
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
398 @ifnotinfo
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
399 @noindent
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
400 The output of the above can be seen in @ref{fig:convhull}.
6823
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
401
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
402 @float Figure,fig:convhull
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
403 @image{convhull,8cm}
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
404 @caption{The convex hull of a simple set of points}
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
405 @end float
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
406 @end ifnotinfo
6855
a052825889a0 [project @ 2007-09-01 00:08:16 by dbateman]
dbateman
parents: 6847
diff changeset
407 @end ifset
6823
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
408
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
409 @node Interpolation on Scattered Data
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
410 @section Interpolation on Scattered Data
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
411
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
412 An important use of the Delaunay tessellation is that it can be used to
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
413 interpolate from scattered data to an arbitrary set of points. To do
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
414 this the N-simplex of the known set of points is calculated with
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
415 @code{delaunay}, @code{delaunay3} or @code{delaunayn}. Then the
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
416 simplicies in to which the desired points are found are
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
417 identified. Finally the vertices of the simplicies are used to
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
418 interpolate to the desired points. The functions that perform this
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
419 interpolation are @code{griddata}, @code{griddata3} and
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
420 @code{griddatan}.
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
421
6823
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
422 @DOCSTRING(griddata)
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
423
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
424 @DOCSTRING(griddata3)
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
425
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
426 @DOCSTRING(griddatan)
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
427
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
428 An example of the use of the @code{griddata} function is
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
429
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
430 @example
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
431 @group
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
432 rand("state",1);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
433 x=2*rand(1000,1)-1;
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
434 y=2*rand(size(x))-1;
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
435 z=sin(2*(x.^2+y.^2));
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
436 [xx,yy]=meshgrid(linspace(-1,1,32));
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
437 griddata(x,y,z,xx,yy);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
438 @end group
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
439 @end example
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
440
6855
a052825889a0 [project @ 2007-09-01 00:08:16 by dbateman]
dbateman
parents: 6847
diff changeset
441 @ifset HAVE_QHULL
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
442 @noindent
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
443 that interpolates from a random scattering of points, to a uniform
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
444 grid.
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
445 @ifnotinfo
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
446 The output of the above can be seen in @ref{fig:griddata}.
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
447
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
448 @float Figure,fig:griddata
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
449 @image{griddata,8cm}
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
450 @caption{Interpolation from a scattered data to a regular grid}
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
451 @end float
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
452 @end ifnotinfo
6855
a052825889a0 [project @ 2007-09-01 00:08:16 by dbateman]
dbateman
parents: 6847
diff changeset
453 @end ifset