annotate doc/interpreter/geometry.txi @ 6832:3c500bc71e14

[project @ 2007-08-25 00:35:33 by dbateman]
author dbateman
date Sat, 25 Aug 2007 00:35:43 +0000
parents 9fddcc586065
children 956148c0d388
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
6558
e0e1c6df5ab2 [project @ 2007-04-20 19:33:24 by jwe]
jwe
parents:
diff changeset
1 @c Copyright (C) 2007 John W. Eaton
6823
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
2 @c Copyright (C) 2007 David Bateman
6558
e0e1c6df5ab2 [project @ 2007-04-20 19:33:24 by jwe]
jwe
parents:
diff changeset
3 @c This is part of the Octave manual.
e0e1c6df5ab2 [project @ 2007-04-20 19:33:24 by jwe]
jwe
parents:
diff changeset
4 @c For copying conditions, see the file gpl.texi.
e0e1c6df5ab2 [project @ 2007-04-20 19:33:24 by jwe]
jwe
parents:
diff changeset
5
e0e1c6df5ab2 [project @ 2007-04-20 19:33:24 by jwe]
jwe
parents:
diff changeset
6 @node Geometry
e0e1c6df5ab2 [project @ 2007-04-20 19:33:24 by jwe]
jwe
parents:
diff changeset
7 @chapter Geometry
e0e1c6df5ab2 [project @ 2007-04-20 19:33:24 by jwe]
jwe
parents:
diff changeset
8
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
9 Much of geometry code in Octave is based on the QHull @footnote{Barber,
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
10 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
11 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
12 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
13 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
14 @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
15
6823
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
16 @menu
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
17 * Delaunay Triangulation::
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
18 * Voronoi Diagrams::
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
19 * Convex Hull::
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
20 * Interpolation on Scattered Data::
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
21 @end menu
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
22
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
23 @node Delaunay Triangulation
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
24 @section Delaunay Triangulation
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
25
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
26 The Delaunay triangulation is constructed from a set of
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
27 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
28 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
29 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
30 points falls within any of the circum-circles.
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
31
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
32 In general there are only three points on the circumference of any
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
33 circum-circle. However, in the some cases, and in particular for the
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
34 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
35 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
36
6823
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
37 @DOCSTRING(delaunay)
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
38
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
39 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
40 given by @code{delaunay3} and @code{delaunayn} respectively.
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
41 @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
42 Delaunay circum-circle criteria. Similarly, @code{delaunayn} returns the
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
43 N-dimensional simplex satisfying the Delaunay circum-circle criteria.
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
44 The N-dimensional extension of a triangulation is called a tesselation.
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
45
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
46 @DOCSTRING(delaunay3)
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
47
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
48 @DOCSTRING(delaunayn)
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
49
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
50 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
51
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
52 @example
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
53 @group
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
54 rand ("state", 2);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
55 x = rand (10, 1);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
56 y = rand (10, 1);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
57 T = delaunay (x, y);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
58 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
59 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
60 axis ([0, 1, 0, 1]);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
61 plot(X, Y, "b", x, y, "r*");
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
62 @end group
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
63 @end example
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 @ifnotinfo
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
66 @noindent
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
67 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
68
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
69 @float Figure,fig:delaunay
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
70 @image{delaunay,8cm}
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
71 @caption{Delaunay triangulation of a random set of points}
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
72 @end float
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
73 @end ifnotinfo
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
74
6823
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
75 @menu
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
76 * Plotting the Triangulation::
6823
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
77 * Identifying points in Triangulation::
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
78 @end menu
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
79
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
80 @node Plotting the Triangulation
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
81 @subsection Plotting the Triangulation
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 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
84 Delaunay triangulation of a 2-dimensional set of points.
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
85
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
86 @DOCSTRING(triplot)
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
87
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
88 @DOCSTRING(trimesh)
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
89
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
90 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
91 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
92 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
93 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
94
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
95 @example
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
96 @group
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
97 rand ("state", 2)
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
98 x = rand (20, 1);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
99 y = rand (20, 1);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
100 tri = delaunay (x, y);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
101 triplot (tri, x, y);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
102 @end group
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
103 @end example
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 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
106 2-dimensions.
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
107 @ifnotinfo
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
108 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
109
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
110 @float Figure,fig:triplot
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
111 @image{triplot,8cm}
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
112 @caption{Delaunay triangulation of a random set of points}
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
113 @end float
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
114 @end ifnotinfo
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
115
6823
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
116 @node Identifying points in Triangulation
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
117 @subsection Identifying points in Triangulation
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
118
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
119 It is often necessary to identify whether a particular point in the
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
120 N-dimensional space is within the Delaunay tesselation of a set of
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
121 points in this N-dimensional space, and if so which N-Simplex contains
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
122 the point and which point in the tesselation is closest to the desired
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
123 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
124 function in a triangulation, and @code{tsearchn} and @code{dsearchn} in
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
125 an N-dimensional tesselation.
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
126
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
127 To identify whether a particular point represented by a vector @var{p}
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
128 falls within one of the simplices of an N-Simplex, we can write the
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
129 Cartesian coordinates of the point in a parametric form with respect to
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
130 the N-Simplex. This parametric form is called the Barycentric
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
131 Coordinates of the point. If the points defining the N-Simplex are given
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
132 by @code{@var{N} + 1} vectors @var{t}(@var{i},:), then the Barycentric
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
133 coordinates defining the point @var{p} is given by
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
134
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
135 @example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
136 @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
137 @end example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
138
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
139 @noindent
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
140 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
141 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
142 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
143 @code{@var{beta}(@var{i})} an additional criteria of
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
144
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
145 @example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
146 sum (@var{beta}(1:@var{N}+1)) == 1
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
147 @end example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
148
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
149 @noindent
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
150 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
151
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
152 @example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
153 @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
154 - ones(@var{N}, 1) * @var{t}(end, :)
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
155 @end example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
156
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
157 @noindent
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
158 Solving for @var{beta} we can then write
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 @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
162 - ones(@var{N}, 1) * @var{t}(end, :))
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
163 @var{beta}(end) = sum(@var{beta}(1:end-1))
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
164 @end example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
165
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
166 @noindent
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
167 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
168 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
169 important property of the Barycentric coordinates is that for all points
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
170 in the N-Simplex
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 @example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
173 0 <= @var{beta}(@var{i}) <= 1
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
174 @end example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
175
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
176 @noindent
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
177 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
178 only needs to express each point in terms of the Barycentric coordinates
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
179 of each of the simplices of the N-Simplex and test the values of
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
180 @var{beta}. This is exactly the implementation used in
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
181 @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
182 Barycentric coordinates are not explicitly formed.
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
183
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
184 @DOCSTRING(tsearch)
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
185
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
186 @DOCSTRING(tsearchn)
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
187
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
188 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
189 triangulation
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 @example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
192 @group
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
193 @var{x} = [-1; -1; 1; 1];
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
194 @var{y} = [-1; 1; -1; 1];
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
195 @var{tri} = [1, 2, 3; 2, 3, 1];
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
196 @end group
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
197 @end example
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 @noindent
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
200 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
201 which triangle a point falls in like
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 @example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
204 @group
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
205 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
206 @result{} 1
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
207 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
208 @result{} 2
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
209 @end group
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
210 @end example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
211
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
212 @noindent
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
213 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
214
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
215 @example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
216 @group
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
217 tsearch (@var{x}, @var{y}, @var{tri}, 2, 2)
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
218 @result{} NaN
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
219 @end group
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
220 @end example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
221
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
222 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
223 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
224 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
225 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
226 N-simplex within which the desired point is found.
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
227
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
228 @DOCSTRING(dsearch)
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 @DOCSTRING(dsearchn)
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
231
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
232 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
233 @var{x}, @var{y} and @var{tri} is
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
234
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
235 @example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
236 @group
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
237 dsearch (@var{x}, @var{y}, @var{tri}, -2, -2)
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
238 @result{} 1
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
239 @end group
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
240 @end example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
241
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
242 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
243 then @code{dsearchn} can be used as
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 @example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
246 @group
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
247 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
248 @result{} NaN
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
249 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
250 @result{} 1
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
251 @end group
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
252 @end example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
253
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
254 @noindent
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
255 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
256
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
257 @node Voronoi Diagrams
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
258 @section Voronoi Diagrams
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 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
261 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
262 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
263 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
264 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
265 Delaunay triangulation of a set of points, in that the vertexes of the
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
266 Voronoi tessellation are the center's of the circum-circles of the
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
267 simplicies of the Delaunay tessellation.
6823
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 @DOCSTRING(voronoi)
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
270
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
271 @DOCSTRING(voronoin)
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
272
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
273 An example of the use of @code{voronoi} is
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
274
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
275 @example
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
276 @group
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
277 rand("state",9);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
278 x = rand(10,1);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
279 y = rand(10,1);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
280 tri = delaunay (x, y);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
281 [vx, vy] = voronoi (x, y, tri);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
282 triplot (tri, x, y, "b");
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
283 hold on;
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
284 plot (vx, vy, "r");
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
285 @end group
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
286 @end example
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
287
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
288 @ifnotinfo
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
289 @noindent
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
290 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
291 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
292 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
293 diagram clearer.
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
294
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
295 @float Figure,fig:voronoi
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
296 @image{voronoi,8cm}
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
297 @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
298 @end float
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
299 @end ifnotinfo
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
300
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
301 Additional information about the size of the facets of a Voronoi diagram
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
302 can be had with the @code{polyarea} function.
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
303
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
304 @DOCSTRING(polyarea)
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
305
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
306 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
307
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
308 @example
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
309 @group
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
310 rand ("state", 2);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
311 x = rand (10, 1);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
312 y = rand (10, 1);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
313 [c, f] = voronoin ([x, y]);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
314 af = zeros (size(f));
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
315 for i = 1 : length (f)
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
316 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
317 endfor
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
318 @end group
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
319 @end example
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
320
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
321 Facets of the Voronoi diagram with a vertex at infinity have infinity area.
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
322
6823
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
323 @node Convex Hull
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
324 @section Convex Hull
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
325
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
326 The convex hull of a set of points, is the minimum convex envelope
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
327 containing all of the points. Octave has the functions @code{convhull}
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
328 and @code{convhulln} to calculate the convec hull of 2-dimensional and
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
329 N-dimensional sets of points.
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
330
6823
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
331 @DOCSTRING(convhull)
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
332
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
333 @DOCSTRING(convhulln)
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
334
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
335 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
336
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
337 @example
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
338 @group
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
339 x = -3:0.05:3;
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
340 y = abs (sin (x));
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
341 k = convhull (x, y);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
342 plot (x(k), y(k), "r-", x, y, "b+");
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
343 axis ([-3.05, 3.05, -0.05, 1.05]);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
344 @end group
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
345 @end example
6823
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
346
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
347 @ifnotinfo
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
348 @noindent
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
349 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
350
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
351 @float Figure,fig:convhull
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
352 @image{convhull,8cm}
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
353 @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
354 @end float
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
355 @end ifnotinfo
6823
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
356
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
357 @node Interpolation on Scattered Data
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
358 @section Interpolation on Scattered Data
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
359
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
360 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
361 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
362 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
363 @code{delaunay}, @code{delaunay3} or @code{delaunayn}. Then the
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
364 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
365 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
366 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
367 interpolation are @code{griddata}, @code{griddata3} and
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
368 @code{griddatan}.
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
369
6823
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
370 @DOCSTRING(griddata)
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
371
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
372 @DOCSTRING(griddata3)
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
373
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
374 @DOCSTRING(griddatan)
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
375
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
376 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
377
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
378 @example
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
379 @group
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
380 rand("state",1);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
381 x=2*rand(1000,1)-1;
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
382 y=2*rand(size(x))-1;
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
383 z=sin(2*(x.^2+y.^2));
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
384 [xx,yy]=meshgrid(linspace(-1,1,32));
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
385 griddata(x,y,z,xx,yy);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
386 @end group
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
387 @end example
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
388
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
389 @noindent
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
390 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
391 grid.
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
392 @ifnotinfo
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
393 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
394
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
395 @float Figure,fig:griddata
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
396 @image{griddata,8cm}
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
397 @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
398 @end float
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
399 @end ifnotinfo