annotate doc/interpreter/geometryimages.m @ 6878:ceb2e732b0fb

[project @ 2007-09-07 18:04:34 by jwe]
author jwe
date Fri, 07 Sep 2007 18:04:34 +0000
parents a052825889a0
children fd42779a8428
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
1 function geometryimages (nm, typ)
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
2 bury_output ();
6878
ceb2e732b0fb [project @ 2007-09-07 18:04:34 by jwe]
jwe
parents: 6855
diff changeset
3 if (isempty (findstr (octave_config_info ("DEFS"), "HAVE_QHULL"))
ceb2e732b0fb [project @ 2007-09-07 18:04:34 by jwe]
jwe
parents: 6855
diff changeset
4 && (strcmp (nm, "voronoi") || strcmp (nm, "griddata")
ceb2e732b0fb [project @ 2007-09-07 18:04:34 by jwe]
jwe
parents: 6855
diff changeset
5 || strcmp (nm, "convhull") || strcmp (nm, "delaunay")
ceb2e732b0fb [project @ 2007-09-07 18:04:34 by jwe]
jwe
parents: 6855
diff changeset
6 || strcmp (nm, "triplot")))
6855
a052825889a0 [project @ 2007-09-01 00:08:16 by dbateman]
dbateman
parents: 6847
diff changeset
7 sombreroimage (nm, typ);
a052825889a0 [project @ 2007-09-01 00:08:16 by dbateman]
dbateman
parents: 6847
diff changeset
8 elseif (strcmp (nm, "voronoi"))
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
9 rand("state",9);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
10 x = rand(10,1);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
11 y = rand(10,1);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
12 tri = delaunay (x, y);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
13 [vx, vy] = voronoi (x, y, tri);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
14 triplot (tri, x, y, "b");
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
15 hold on;
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
16 plot (vx, vy, "r");
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
17 [r, c] = tri2circ (tri(end,:), x, y);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
18 pc = [-1:0.01:1];
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
19 xc = r * sin(pi*pc) + c(1);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
20 yc = r * cos(pi*pc) + c(2);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
21 plot (xc, yc, "g-", "LineWidth", 3);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
22 axis([0, 1, 0, 1]);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
23 legend ("Delaunay Triangulation", "Voronoi Diagram");
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
24 print (strcat (nm, ".", typ), strcat ("-d", typ))
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
25 elseif (strcmp (nm, "triplot"))
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
26 rand ("state", 2)
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
27 x = rand (20, 1);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
28 y = rand (20, 1);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
29 tri = delaunay (x, y);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
30 triplot (tri, x, y);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
31 print (strcat (nm, ".", typ), strcat ("-d", typ))
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
32 elseif (strcmp (nm, "griddata"))
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
33 rand("state",1);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
34 x=2*rand(1000,1)-1;
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
35 y=2*rand(size(x))-1;
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
36 z=sin(2*(x.^2+y.^2));
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
37 [xx,yy]=meshgrid(linspace(-1,1,32));
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
38 griddata(x,y,z,xx,yy);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
39 print (strcat (nm, ".", typ), strcat ("-d", typ))
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
40 elseif (strcmp (nm, "convhull"))
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
41 x = -3:0.05:3;
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
42 y = abs (sin (x));
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
43 k = convhull (x, y);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
44 plot (x(k),y(k),'r-',x,y,'b+');
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
45 axis ([-3.05, 3.05, -0.05, 1.05]);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
46 print (strcat (nm, ".", typ), strcat ("-d", typ))
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
47 elseif (strcmp (nm, "delaunay"))
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
48 rand ("state", 1);
6847
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
49 x = rand (1, 10);
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
50 y = rand (1, 10);
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
51 T = delaunay (x, y);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
52 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:
diff changeset
53 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:
diff changeset
54 axis ([0, 1, 0, 1]);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
55 plot(X, Y, "b", x, y, "r*");
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
56 print (strcat (nm, ".", typ), strcat ("-d", typ))
6847
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
57 elseif (strcmp (nm, "inpolygon"))
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
58 randn ("state", 2);
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
59 x = randn (100, 1);
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
60 y = randn (100, 1);
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
61 vx = cos (pi * [-1 : 0.1: 1]);
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
62 vy = sin (pi * [-1 : 0.1 : 1]);
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
63 in = inpolygon (x, y, vx, vy);
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
64 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
65 axis ([-2, 2, -2, 2]);
956148c0d388 [project @ 2007-08-30 07:39:32 by dbateman]
dbateman
parents: 6832
diff changeset
66 print (strcat (nm, ".", typ), strcat ("-d", typ))
6832
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
67 else
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
68 error ("unrecognized plot requested");
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
69 endif
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
70 bury_output ();
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
71 endfunction
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
72
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
73 function [r, c] = tri2circ (tri, xx, yy)
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
74 x = xx(tri);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
75 y = yy(tri);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
76 m = (y(1:end-1) - y(2:end)) ./ (x(1:end-1) - x(2:end));
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
77 xc = (prod(m) .* (y(1) - y(end)) + m(end)*(x(1)+x(2)) - m(1)*(x(2)+x(3))) ...
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
78 ./ (2 * (m(end) - m(1)));
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
79 yc = - (xc - (x(2) + x(3))./2) ./ m(end) + (y(2) + y(3)) / 2;
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
80 c = [xc, yc];
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
81 r = sqrt ((xc - x(1)).^2 + (yc - y(1)).^2);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
82 endfunction
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
83
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
84 ## Use this function before plotting commands and after every call to
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
85 ## print since print() resets output to stdout (unfortunately, gnpulot
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
86 ## can't pop output as it can the terminal type).
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
87 function bury_output ()
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
88 f = figure (1);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
89 set (f, "visible", "off");
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
90 endfunction
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
91 function geometryimages (nm, typ)
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
92 bury_output ();
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
93 if (strcmp (nm, "voronoi"))
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
94 rand("state",9);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
95 x = rand(10,1);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
96 y = rand(10,1);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
97 tri = delaunay (x, y);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
98 [vx, vy] = voronoi (x, y, tri);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
99 triplot (tri, x, y, "b");
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
100 hold on;
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
101 plot (vx, vy, "r");
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
102 [r, c] = tri2circ (tri(end,:), x, y);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
103 pc = [-1:0.01:1];
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
104 xc = r * sin(pi*pc) + c(1);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
105 yc = r * cos(pi*pc) + c(2);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
106 plot (xc, yc, "g-", "LineWidth", 3);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
107 axis([0, 1, 0, 1]);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
108 legend ("Delaunay Triangulation", "Voronoi Diagram");
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
109 print (strcat (nm, ".", typ), strcat ("-d", typ))
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
110 elseif (strcmp (nm, "triplot"))
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
111 rand ("state", 2)
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
112 x = rand (20, 1);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
113 y = rand (20, 1);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
114 tri = delaunay (x, y);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
115 triplot (tri, x, y);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
116 print (strcat (nm, ".", typ), strcat ("-d", typ))
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
117 elseif (strcmp (nm, "griddata"))
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
118 rand("state",1);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
119 x=2*rand(1000,1)-1;
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
120 y=2*rand(size(x))-1;
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
121 z=sin(2*(x.^2+y.^2));
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
122 [xx,yy]=meshgrid(linspace(-1,1,32));
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
123 griddata(x,y,z,xx,yy);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
124 print (strcat (nm, ".", typ), strcat ("-d", typ))
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
125 else
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
126 error ("unrecognized plot requested");
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
127 endif
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
128 bury_output ();
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
129 endfunction
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
130
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
131 function [r, c] = tri2circ (tri, xx, yy)
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
132 x = xx(tri);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
133 y = yy(tri);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
134 m = (y(1:end-1) - y(2:end)) ./ (x(1:end-1) - x(2:end));
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
135 xc = (prod(m) .* (y(1) - y(end)) + m(end)*(x(1)+x(2)) - m(1)*(x(2)+x(3))) ...
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
136 ./ (2 * (m(end) - m(1)));
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
137 yc = - (xc - (x(2) + x(3))./2) ./ m(end) + (y(2) + y(3)) / 2;
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
138 c = [xc, yc];
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
139 r = sqrt ((xc - x(1)).^2 + (yc - y(1)).^2);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
140 endfunction
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
141
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
142 ## Use this function before plotting commands and after every call to
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
143 ## print since print() resets output to stdout (unfortunately, gnpulot
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
144 ## can't pop output as it can the terminal type).
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
145 function bury_output ()
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
146 f = figure (1);
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
147 set (f, "visible", "off");
3c500bc71e14 [project @ 2007-08-25 00:35:33 by dbateman]
dbateman
parents:
diff changeset
148 endfunction
6855
a052825889a0 [project @ 2007-09-01 00:08:16 by dbateman]
dbateman
parents: 6847
diff changeset
149
a052825889a0 [project @ 2007-09-01 00:08:16 by dbateman]
dbateman
parents: 6847
diff changeset
150 function sombreroimage (nm, typ)
a052825889a0 [project @ 2007-09-01 00:08:16 by dbateman]
dbateman
parents: 6847
diff changeset
151 if (strcmp (typ, "txt"))
a052825889a0 [project @ 2007-09-01 00:08:16 by dbateman]
dbateman
parents: 6847
diff changeset
152 fid = fopen (sprintf ("%s.txt", nm), "wt");
a052825889a0 [project @ 2007-09-01 00:08:16 by dbateman]
dbateman
parents: 6847
diff changeset
153 fputs (fid, "+-----------------------------+\n");
a052825889a0 [project @ 2007-09-01 00:08:16 by dbateman]
dbateman
parents: 6847
diff changeset
154 fputs (fid, "| Image unavailable because |\n");
a052825889a0 [project @ 2007-09-01 00:08:16 by dbateman]
dbateman
parents: 6847
diff changeset
155 fputs (fid, "| of a missing QHULL library. |\n");
a052825889a0 [project @ 2007-09-01 00:08:16 by dbateman]
dbateman
parents: 6847
diff changeset
156 fputs (fid, "+-----------------------------+\n");
a052825889a0 [project @ 2007-09-01 00:08:16 by dbateman]
dbateman
parents: 6847
diff changeset
157 fclose (fid);
a052825889a0 [project @ 2007-09-01 00:08:16 by dbateman]
dbateman
parents: 6847
diff changeset
158 return;
a052825889a0 [project @ 2007-09-01 00:08:16 by dbateman]
dbateman
parents: 6847
diff changeset
159 else ## if (!strcmp (typ, "txt"))
a052825889a0 [project @ 2007-09-01 00:08:16 by dbateman]
dbateman
parents: 6847
diff changeset
160
a052825889a0 [project @ 2007-09-01 00:08:16 by dbateman]
dbateman
parents: 6847
diff changeset
161 bury_output ();
a052825889a0 [project @ 2007-09-01 00:08:16 by dbateman]
dbateman
parents: 6847
diff changeset
162
a052825889a0 [project @ 2007-09-01 00:08:16 by dbateman]
dbateman
parents: 6847
diff changeset
163 x = y = linspace (-8, 8, 41)';
a052825889a0 [project @ 2007-09-01 00:08:16 by dbateman]
dbateman
parents: 6847
diff changeset
164 [xx, yy] = meshgrid (x, y);
a052825889a0 [project @ 2007-09-01 00:08:16 by dbateman]
dbateman
parents: 6847
diff changeset
165 r = sqrt (xx .^ 2 + yy .^ 2) + eps;
a052825889a0 [project @ 2007-09-01 00:08:16 by dbateman]
dbateman
parents: 6847
diff changeset
166 z = sin (r) ./ r;
a052825889a0 [project @ 2007-09-01 00:08:16 by dbateman]
dbateman
parents: 6847
diff changeset
167 unwind_protect
a052825889a0 [project @ 2007-09-01 00:08:16 by dbateman]
dbateman
parents: 6847
diff changeset
168 mesh (x, y, z);
a052825889a0 [project @ 2007-09-01 00:08:16 by dbateman]
dbateman
parents: 6847
diff changeset
169 title ("Sorry, graphics not available because octave was\\ncompiled without the QHULL library.");
a052825889a0 [project @ 2007-09-01 00:08:16 by dbateman]
dbateman
parents: 6847
diff changeset
170 unwind_protect_cleanup
a052825889a0 [project @ 2007-09-01 00:08:16 by dbateman]
dbateman
parents: 6847
diff changeset
171 print (strcat (nm, ".", typ), strcat ("-d", typ));
a052825889a0 [project @ 2007-09-01 00:08:16 by dbateman]
dbateman
parents: 6847
diff changeset
172 bury_output ();
a052825889a0 [project @ 2007-09-01 00:08:16 by dbateman]
dbateman
parents: 6847
diff changeset
173 end_unwind_protect
a052825889a0 [project @ 2007-09-01 00:08:16 by dbateman]
dbateman
parents: 6847
diff changeset
174 endif
a052825889a0 [project @ 2007-09-01 00:08:16 by dbateman]
dbateman
parents: 6847
diff changeset
175 endfunction