1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42
|
// Scilab ( http://www.scilab.org/ ) - This file is part of Scilab
// Copyright (C) INRIA
// This file must be used under the terms of the CeCILL.
// This source file is licensed as described in the file COPYING, which
// you should have received as part of this distribution. The terms
// are also available at
// http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt
function fplot3d(xr,yr,f,theta,alpha,leg,flag,ebox)
// fplot3d(xr,yr,f,teta,alpha,leg,[flag,ebox])
// Trace la surface d\'efinie par un external f ( ex macro [z]=f(x,y))
// on calcule d'abord f sur la grille definie par xr.yr
// xr et yr sont des vecteurs implicites donnant les
// abscisses et les ordonn\'ees des points de la grille
// -teta, alpha : sont les angles en coordonn\'ees spheriques du
// point d'observation
// -flag et ebox (voir plot3d)
// Exemple : taper fplot3d() pour voir un exemple
//!
[lhs,rhs]=argn(0)
if rhs <= 0 then // demo
deff("[z]=Surf(x,y)","z=sin(x)*cos(y)");
t=-%pi:0.3:%pi;
fplot3d(t,t,Surf,35,45,"X@Y@Z");
return
end
if rhs<3 then
error(msprintf(gettext("%s: Wrong number of input argument(s): At least %d expected.\n"), "fplot3d", 3));
end;
opts=[]
if exists('theta','local')==1 then opts=[opts,'theta=theta'],end
if exists('alpha','local')==1 then opts=[opts,'alpha=alpha'],end
if exists('leg' ,'local')==1 then opts=[opts,'leg=leg'] ,end
if exists('flag' ,'local')==1 then opts=[opts,'flag=flag'] ,end
if exists('ebox' ,'local')==1 then opts=[opts,'ebox=ebox'] ,end
if type(f)==11 then comp(f),end;
execstr('plot3d(xr,yr,feval(xr,yr,f),'+strcat(opts,',')+')')
endfunction
|