资源描述:
《Matlab 第七讲:编程基础II( 函数 )课件.ppt》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、数学软件Matlab——Matlab编程(函数)1内容提要函数文件的定义递归函数函数参数的可调性局部变量与全局变量子函数函数句柄、内联函数、匿名函数2M文件根据调用方式的不同可以分为两类Script:脚本文件,直接输入文件名即可运行Function:函数文件Matlab编程供其它M文件调用,通常带输入参数和输出参数3function输出形参列表=函数名(输入形参列表)%注释说明部分(可选)函数体语句第一行为引导行,表示该M文件是函数文件函数名的命名规则与变量名相同(必须以字母开头)当输出形参多于一
2、个时,用方括号括起来函数文件函数文件一般格式函数必须是一个单独的M文件函数文件的文件名必须与函数名一致4函数文件(f2cf.m):例:将华氏温度转化为摄氏温度:编程示例clear;f=input('Pleaseinputf:');c=5*(f-32)/9;fprintf('c=%g',c)脚本文件(f2cs.m):functionc=f2cf(f)c=5*(f-32)/9;5函数文件举例function[a,b]=myswap(x,y)%swapxandya=y;b=x;例:交换两个变量的值m
3、yswap.m函数可以有多个输入参数和多个输出参数也可以没有输入参数或输出参数6functionprintyh(n)%打印杨辉三角形,本函数没有输出参数yh=1;disp(yh);ifn==1,return;endyh=[1,1];disp(yh);fork=3:nyh_old=yh;k2=ceil(k/2);fori=2:k2yh(i)=yh_old(i-1)+yh_old(i);endyh(k2+1:k)=yh(k-k2:-1:1);disp(yh);end函数文件举例例:打印杨辉三角形pri
4、ntyh.m7函数调用的一般格式输出实参列表=函数名(输入实参列表)函数调用时,实参的顺序应与函数定义时形参的顺序一致实参与形参之间的结合是通过值传递实现的函数可以嵌套调用,即一个函数可以被其它函数调用,甚至可以被它自身调用,此时称为递归调用函数所传递的参数具有可调性,Matlab用两个永久变量nargin和nargout分别记录调用该函数时的输入实参和输出实参的个数函数调用8%函数文件myfactor.mfunctiony=myfactor(n)ifn<=1y=1;elsey=n*myfac
5、tor(n-1);end例:利用函数的递归调用计算n!递归函数举例9%main.mclear;s=0;n=10;fori=1:ns=s+myfactor(i);endfprintf('s=%d',s)例:计算1!+2!+…+10!递归函数举例10%ex4nargin.mfunctiony=ex4nargin(a,b)ifnargin==1y=a;elseifnargin==2y=a*b;end参数的可调性举例例:nargin和nargout的使用%ex4nargout.mfunction[p,
6、q]=ex4nargout(a,b)ifnargout==1p=a+b;elseifnargout==2p=a+b;q=a-b;end>>y1=ex4nargin(3)>>y2=ex4nargin(3,4)>>x=ex4nargout(5,3)>>[x,y]=ex4nargin(5,3)11内容提要函数文件的定义递归函数函数参数的可调性局部变量与全局变量子函数函数句柄、内联函数、匿名函数12局部变量:只能在其被定义的M文件中使用全局变量:可以在多个M文件中使用Matlab中,变量默认是局部变量局部
7、变量与全局变量局部变量与全局变量局部变量Matlab中,变量默认是局部变量,即一个M文件中定义的变量不能被其它M文件引用当函数调用完毕后,该函数文件中所定义的所有局部变量都将被释放,即全部被清除函数通过输入和输出参数与其它M文件进行数据传递13程序示例%main.mclear;a=1;b=3;z=mysquaresum(a,b);fprintf('z=%d',z);disp(mysum)%ERROR%mysquaresum.mfunctionmysum=mysquaresum(x,y)mysu
8、m=x^2+y^2;mysum=a^2+b^2;%ERROR14局部变量与全局变量全局变量global变量名列表全局变量的定义或声明变量名列表中的各个变量用空格隔开,不能用逗号!在需要使用全局变量的所有M文件中,都要进行声明定义全局变量是M文件间传递信息的一种手段15程序示例%main.mclear;globalab;%声明ab是全局变量a=1;b=3;z=mysquaresum();fprintf('z=%d',z);disp(mysum);%ERROR,mysum不是全局变