Mercurial > hg > octave-lyh
annotate scripts/plot/ellipsoid.m @ 17051:3e1b24a2454a
cylinder.m, ellipsoid.m, rectangle.m, sphere.m: Update to use new __plt_get_axis_arg__.
* scripts/plot/cylinder.m, scripts/plot/ellipsoid.m, scripts/plot/rectangle.m,
scripts/plot/sphere.m: Update to use new __plt_get_axis_arg__.
Rename ax to hax.
author | Pantxo Diribarne <pantxo.diribarne@gmail.com> |
---|---|
date | Tue, 23 Jul 2013 16:06:07 +0200 |
parents | 11949c9795a0 |
children | eaab03308c0b |
rev | line source |
---|---|
14138
72c96de7a403
maint: update copyright notices for 2012
John W. Eaton <jwe@octave.org>
parents:
14092
diff
changeset
|
1 ## Copyright (C) 2007-2012 Sylvain Pelissier |
7306 | 2 ## |
3 ## This file is part of Octave. | |
7305 | 4 ## |
7306 | 5 ## Octave is free software; you can redistribute it and/or modify it |
6 ## under the terms of the GNU General Public License as published by | |
7 ## the Free Software Foundation; either version 3 of the License, or (at | |
8 ## your option) any later version. | |
7305 | 9 ## |
7306 | 10 ## Octave is distributed in the hope that it will be useful, but |
11 ## WITHOUT ANY WARRANTY; without even the implied warranty of | |
12 ## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | |
13 ## General Public License for more details. | |
7305 | 14 ## |
15 ## You should have received a copy of the GNU General Public License | |
7306 | 16 ## along with Octave; see the file COPYING. If not, see |
17 ## <http://www.gnu.org/licenses/>. | |
7305 | 18 |
19 ## -*- texinfo -*- | |
11563
3c6e8aaa9555
Grammarcheck m-files before 3.4 release.
Rik <octave@nomad.inbox5.com>
parents:
11523
diff
changeset
|
20 ## @deftypefn {Function File} {[@var{x}, @var{y}, @var{z}] =} ellipsoid (@var{xc}, @var{yc}, @var{zc}, @var{xr}, @var{yr}, @var{zr}, @var{n}) |
7305 | 21 ## @deftypefnx {Function File} {} ellipsoid (@var{h}, @dots{}) |
7306 | 22 ## Generate three matrices in @code{meshgrid} format that define an |
9040
dbd0c77e575e
Cleanup documentation file plot.texi
Rik <rdrider0-list@yahoo.com>
parents:
8920
diff
changeset
|
23 ## ellipsoid. Called with no return arguments, @code{ellipsoid} calls |
7306 | 24 ## directly @code{surf (@var{x}, @var{y}, @var{z})}. If an axes handle |
9040
dbd0c77e575e
Cleanup documentation file plot.texi
Rik <rdrider0-list@yahoo.com>
parents:
8920
diff
changeset
|
25 ## is passed as the first argument, the surface is plotted to this |
7306 | 26 ## set of axes. |
7305 | 27 ## @seealso{sphere} |
28 ## @end deftypefn | |
29 | |
7306 | 30 ## Author: Sylvain Pelissier <sylvain.pelissier@gmail.com> |
31 | |
32 function [xx, yy, zz] = ellipsoid (varargin) | |
7305 | 33 |
17051
3e1b24a2454a
cylinder.m, ellipsoid.m, rectangle.m, sphere.m: Update to use new __plt_get_axis_arg__.
Pantxo Diribarne <pantxo.diribarne@gmail.com>
parents:
14237
diff
changeset
|
34 [hax, varargin, nargin] = __plt_get_axis_arg__ ("ellipsoid", varargin{:}); |
7305 | 35 |
36 if (nargin != 6 && nargin != 7) | |
37 print_usage (); | |
38 endif | |
39 | |
40 xc = varargin{1}; | |
41 yc = varargin{2}; | |
42 zc = varargin{3}; | |
43 xr = varargin{4}; | |
44 yr = varargin{5}; | |
45 zr = varargin{6}; | |
46 | |
8274
967c15c5e265
ellipsoid.m: fix default argument check
Soren Hauberg <hauberg@gmail.com>
parents:
7306
diff
changeset
|
47 if (nargin == 6) |
7305 | 48 n = 20; |
49 else | |
50 n = varargin{7}; | |
51 endif | |
52 | |
53 theta = linspace (0, 2 * pi, n + 1); | |
54 phi = linspace (-pi / 2, pi / 2, n + 1); | |
55 [theta, phi] = meshgrid (theta, phi); | |
56 | |
57 x = xr .* cos (phi) .* cos (theta) + xc; | |
58 y = yr .* cos (phi) .* sin (theta) + yc; | |
59 z = zr .* sin (phi) + zc; | |
60 | |
61 if (nargout > 0) | |
62 xx = x; | |
63 yy = y; | |
64 zz = z; | |
65 else | |
17051
3e1b24a2454a
cylinder.m, ellipsoid.m, rectangle.m, sphere.m: Update to use new __plt_get_axis_arg__.
Pantxo Diribarne <pantxo.diribarne@gmail.com>
parents:
14237
diff
changeset
|
66 oldfig = ifelse (isempty (hax), [], get (0, "currentfigure")); |
3e1b24a2454a
cylinder.m, ellipsoid.m, rectangle.m, sphere.m: Update to use new __plt_get_axis_arg__.
Pantxo Diribarne <pantxo.diribarne@gmail.com>
parents:
14237
diff
changeset
|
67 unwind_protect |
3e1b24a2454a
cylinder.m, ellipsoid.m, rectangle.m, sphere.m: Update to use new __plt_get_axis_arg__.
Pantxo Diribarne <pantxo.diribarne@gmail.com>
parents:
14237
diff
changeset
|
68 hax = newplot (hax); |
3e1b24a2454a
cylinder.m, ellipsoid.m, rectangle.m, sphere.m: Update to use new __plt_get_axis_arg__.
Pantxo Diribarne <pantxo.diribarne@gmail.com>
parents:
14237
diff
changeset
|
69 |
3e1b24a2454a
cylinder.m, ellipsoid.m, rectangle.m, sphere.m: Update to use new __plt_get_axis_arg__.
Pantxo Diribarne <pantxo.diribarne@gmail.com>
parents:
14237
diff
changeset
|
70 surf (hax, x, y, z); |
3e1b24a2454a
cylinder.m, ellipsoid.m, rectangle.m, sphere.m: Update to use new __plt_get_axis_arg__.
Pantxo Diribarne <pantxo.diribarne@gmail.com>
parents:
14237
diff
changeset
|
71 |
3e1b24a2454a
cylinder.m, ellipsoid.m, rectangle.m, sphere.m: Update to use new __plt_get_axis_arg__.
Pantxo Diribarne <pantxo.diribarne@gmail.com>
parents:
14237
diff
changeset
|
72 unwind_protect_cleanup |
3e1b24a2454a
cylinder.m, ellipsoid.m, rectangle.m, sphere.m: Update to use new __plt_get_axis_arg__.
Pantxo Diribarne <pantxo.diribarne@gmail.com>
parents:
14237
diff
changeset
|
73 if (! isempty (oldfig)) |
3e1b24a2454a
cylinder.m, ellipsoid.m, rectangle.m, sphere.m: Update to use new __plt_get_axis_arg__.
Pantxo Diribarne <pantxo.diribarne@gmail.com>
parents:
14237
diff
changeset
|
74 set (0, "currentfigure", oldfig); |
3e1b24a2454a
cylinder.m, ellipsoid.m, rectangle.m, sphere.m: Update to use new __plt_get_axis_arg__.
Pantxo Diribarne <pantxo.diribarne@gmail.com>
parents:
14237
diff
changeset
|
75 endif |
3e1b24a2454a
cylinder.m, ellipsoid.m, rectangle.m, sphere.m: Update to use new __plt_get_axis_arg__.
Pantxo Diribarne <pantxo.diribarne@gmail.com>
parents:
14237
diff
changeset
|
76 end_unwind_protect |
7305 | 77 endif |
78 | |
79 endfunction | |
80 | |
14237
11949c9795a0
Revamp %!demos in m-files to use Octave coding conventions on spacing, etc.
Rik <octave@nomad.inbox5.com>
parents:
14138
diff
changeset
|
81 |
7305 | 82 %!demo |
14237
11949c9795a0
Revamp %!demos in m-files to use Octave coding conventions on spacing, etc.
Rik <octave@nomad.inbox5.com>
parents:
14138
diff
changeset
|
83 %! clf; |
7305 | 84 %! ellipsoid (0, 0, 1, 2, 3, 4, 20); |
14237
11949c9795a0
Revamp %!demos in m-files to use Octave coding conventions on spacing, etc.
Rik <octave@nomad.inbox5.com>
parents:
14138
diff
changeset
|
85 |