annotate doc/interpreter/geometry.txi @ 7007:6304d9ea0a30

[project @ 2007-10-11 16:26:36 by jwe]
author jwe
date Thu, 11 Oct 2007 16:26:37 +0000
parents 8b0cfeb06365
children fd42779a8428
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.
7007
6304d9ea0a30 [project @ 2007-10-11 16:26:36 by jwe]
jwe
parents: 7001
diff changeset
44 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
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
6855
a052825889a0 [project @ 2007-09-01 00:08:16 by dbateman]
dbateman
parents: 6847
diff changeset
65 @ifset HAVE_QHULL
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
66 @ifnotinfo
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
67 @noindent
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
68 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
69
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
70 @float Figure,fig:delaunay
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
71 @image{delaunay,8cm}
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
72 @caption{Delaunay triangulation of a random set of points}
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
73 @end float
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
74 @end ifnotinfo
6855
a052825889a0 [project @ 2007-09-01 00:08:16 by dbateman]
dbateman
parents: 6847
diff changeset
75 @end ifset
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
76
6823
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
77 @menu
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
78 * Plotting the Triangulation::
6823
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
79 * Identifying points in Triangulation::
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
80 @end menu
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
81
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
82 @node Plotting the Triangulation
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
83 @subsection Plotting the Triangulation
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
84
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
85 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
86 Delaunay triangulation of a 2-dimensional set of points.
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(triplot)
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 @DOCSTRING(trimesh)
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
91
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
92 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
93 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
94 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
95 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
96
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
97 @example
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
98 @group
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
99 rand ("state", 2)
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
100 x = rand (20, 1);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
101 y = rand (20, 1);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
102 tri = delaunay (x, y);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
103 triplot (tri, x, y);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
104 @end group
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
105 @end example
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
106
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
107 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
108 2-dimensions.
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
109 @ifnotinfo
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
110 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
111
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
112 @float Figure,fig:triplot
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
113 @image{triplot,8cm}
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
114 @caption{Delaunay triangulation of a random set of points}
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
115 @end float
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
116 @end ifnotinfo
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
117
6823
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
118 @node Identifying points in Triangulation
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
119 @subsection Identifying points in Triangulation
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
120
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
121 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
122 N-dimensional space is within the Delaunay tessellation of a set of
6823
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
123 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
124 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
125 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
126 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
127 an N-dimensional tessellation.
6823
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
128
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
129 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
130 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
131 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
132 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
133 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
134 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
135 coordinates defining the point @var{p} is given by
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
136
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
137 @example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
138 @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
139 @end example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
140
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
141 @noindent
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
142 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
143 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
144 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
145 @code{@var{beta}(@var{i})} an additional criteria of
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
146
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
147 @example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
148 sum (@var{beta}(1:@var{N}+1)) == 1
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
149 @end example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
150
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
151 @noindent
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
152 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
153
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
154 @example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
155 @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
156 - ones(@var{N}, 1) * @var{t}(end, :)
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
157 @end example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
158
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
159 @noindent
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
160 Solving for @var{beta} we can then write
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
161
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
162 @example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
163 @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
164 - ones(@var{N}, 1) * @var{t}(end, :))
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
165 @var{beta}(end) = sum(@var{beta}(1:end-1))
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
166 @end example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
167
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
168 @noindent
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
169 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
170 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
171 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
172 in the N-Simplex
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
173
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
174 @example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
175 0 <= @var{beta}(@var{i}) <= 1
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
176 @end example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
177
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
178 @noindent
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
179 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
180 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
181 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
182 @var{beta}. This is exactly the implementation used in
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
183 @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
184 Barycentric coordinates are not explicitly formed.
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(tsearch)
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 @DOCSTRING(tsearchn)
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
189
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
190 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
191 triangulation
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
192
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
193 @example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
194 @group
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
195 @var{x} = [-1; -1; 1; 1];
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
196 @var{y} = [-1; 1; -1; 1];
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
197 @var{tri} = [1, 2, 3; 2, 3, 1];
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
198 @end group
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
199 @end example
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 @noindent
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
202 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
203 which triangle a point falls in like
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
204
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
205 @example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
206 @group
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{} 1
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
209 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
210 @result{} 2
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 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
216
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
217 @example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
218 @group
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
219 tsearch (@var{x}, @var{y}, @var{tri}, 2, 2)
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
220 @result{} NaN
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
221 @end group
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
222 @end example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
223
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
224 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
225 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
226 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
227 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
228 N-simplex within which the desired point is found.
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(dsearch)
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 @DOCSTRING(dsearchn)
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
233
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
234 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
235 @var{x}, @var{y} and @var{tri} is
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 @example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
238 @group
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
239 dsearch (@var{x}, @var{y}, @var{tri}, -2, -2)
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
240 @result{} 1
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
241 @end group
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
242 @end example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
243
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
244 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
245 then @code{dsearchn} can be used as
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 @example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
248 @group
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
249 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
250 @result{} NaN
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
251 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
252 @result{} 1
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
253 @end group
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
254 @end example
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
255
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
256 @noindent
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
257 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
258
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
259 @node Voronoi Diagrams
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
260 @section Voronoi Diagrams
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
261
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
262 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
263 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
264 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
265 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
266 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
267 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
268 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
269 simplicies of the Delaunay tessellation.
6823
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(voronoi)
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
272
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
273 @DOCSTRING(voronoin)
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
274
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
275 An example of the use of @code{voronoi} is
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
276
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
277 @example
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
278 @group
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
279 rand("state",9);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
280 x = rand(10,1);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
281 y = rand(10,1);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
282 tri = delaunay (x, y);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
283 [vx, vy] = voronoi (x, y, tri);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
284 triplot (tri, x, y, "b");
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
285 hold on;
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
286 plot (vx, vy, "r");
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
287 @end group
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
288 @end example
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
289
6855
a052825889a0 [project @ 2007-09-01 00:08:16 by dbateman]
dbateman
parents: 6847
diff changeset
290 @ifset HAVE_QHULL
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
291 @ifnotinfo
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
292 @noindent
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
293 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
294 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
295 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
296 diagram clearer.
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
297
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
298 @float Figure,fig:voronoi
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
299 @image{voronoi,8cm}
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
300 @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
301 @end float
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
302 @end ifnotinfo
6855
a052825889a0 [project @ 2007-09-01 00:08:16 by dbateman]
dbateman
parents: 6847
diff changeset
303 @end ifset
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
304
6847
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
305 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
306 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
307 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
308
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
309 @DOCSTRING(polyarea)
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 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
312
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
313 @example
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
314 @group
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
315 rand ("state", 2);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
316 x = rand (10, 1);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
317 y = rand (10, 1);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
318 [c, f] = voronoin ([x, y]);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
319 af = zeros (size(f));
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
320 for i = 1 : length (f)
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
321 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
322 endfor
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
323 @end group
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
324 @end example
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 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
327
6847
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
328 @DOCSTRING(inpolygon)
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
329
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
330 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
331
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
332 @example
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
333 @group
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
334 randn ("state", 2);
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
335 x = randn (100, 1);
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
336 y = randn (100, 1);
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
337 vx = cos (pi * [-1 : 0.1: 1]);
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
338 vy = sin (pi * [-1 : 0.1 : 1]);
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
339 in = inpolygon (x, y, vx, vy);
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
340 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
341 axis ([-2, 2, -2, 2]);
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
342 @end group
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
343 @end example
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
344
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
345 @ifnotinfo
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
346 @noindent
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
347 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
348
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
349 @float Figure,fig:inpolygon
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
350 @image{inpolygon,8cm}
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
351 @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
352 points inside a polygon}
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
353 @end float
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
354 @end ifnotinfo
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
355
6823
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
356 @node Convex Hull
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
357 @section Convex Hull
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
358
7001
8b0cfeb06365 [project @ 2007-10-10 18:02:59 by jwe]
jwe
parents: 6855
diff changeset
359 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
360 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
361 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
362 N-dimensional sets of points.
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
363
6823
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
364 @DOCSTRING(convhull)
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
365
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
366 @DOCSTRING(convhulln)
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
367
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
368 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
369
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
370 @example
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
371 @group
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
372 x = -3:0.05:3;
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
373 y = abs (sin (x));
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
374 k = convhull (x, y);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
375 plot (x(k), y(k), "r-", x, y, "b+");
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
376 axis ([-3.05, 3.05, -0.05, 1.05]);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
377 @end group
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
378 @end example
6823
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
379
6855
a052825889a0 [project @ 2007-09-01 00:08:16 by dbateman]
dbateman
parents: 6847
diff changeset
380 @ifset HAVE_QHULL
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
381 @ifnotinfo
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
382 @noindent
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
383 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
384
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
385 @float Figure,fig:convhull
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
386 @image{convhull,8cm}
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
387 @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
388 @end float
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
389 @end ifnotinfo
6855
a052825889a0 [project @ 2007-09-01 00:08:16 by dbateman]
dbateman
parents: 6847
diff changeset
390 @end ifset
6823
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
391
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
392 @node Interpolation on Scattered Data
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
393 @section Interpolation on Scattered Data
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
394
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
395 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
396 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
397 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
398 @code{delaunay}, @code{delaunay3} or @code{delaunayn}. Then the
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
399 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
400 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
401 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
402 interpolation are @code{griddata}, @code{griddata3} and
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
403 @code{griddatan}.
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
404
6823
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
405 @DOCSTRING(griddata)
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
406
9fddcc586065 [project @ 2007-08-24 08:27:27 by dbateman]
dbateman
parents: 6558
diff changeset
407 @DOCSTRING(griddata3)
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 @DOCSTRING(griddatan)
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
410
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
411 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
412
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
413 @example
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
414 @group
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
415 rand("state",1);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
416 x=2*rand(1000,1)-1;
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
417 y=2*rand(size(x))-1;
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
418 z=sin(2*(x.^2+y.^2));
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
419 [xx,yy]=meshgrid(linspace(-1,1,32));
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
420 griddata(x,y,z,xx,yy);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
421 @end group
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
422 @end example
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
423
6855
a052825889a0 [project @ 2007-09-01 00:08:16 by dbateman]
dbateman
parents: 6847
diff changeset
424 @ifset HAVE_QHULL
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
425 @noindent
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
426 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
427 grid.
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
428 @ifnotinfo
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
429 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
430
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
431 @float Figure,fig:griddata
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
432 @image{griddata,8cm}
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
433 @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
434 @end float
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents: 6823
diff changeset
435 @end ifnotinfo
6855
a052825889a0 [project @ 2007-09-01 00:08:16 by dbateman]
dbateman
parents: 6847
diff changeset
436 @end ifset