[matlab] 4.M函数

时间:2023-03-09 17:44:24
[matlab] 4.M函数

函数文件的编写

新建一个函数文件

函数的第一行的格式 :function [输出的参数] =函数名 (输入的参数)

输入和输出的参数可以有多个

保存函数文件的时候,注意文件名要和函数名一样

函数头和函数体之间可以有多行%开始的注释,说明函数的使用方法,当执行 help 函数名 的时候会显示这些注释 ,直到遇到第一个非注释行为止

%% 注意输入的参数。函数fun以及给定的区间[a,b],求出精确度为ep的零点x_star,k为迭代次数 ;
function [x_star,k] = bisect1(fun,a,b,ep)
%二分法求方程的近似值
if nargin<4 % nargin,nargout 是函数文件里的固有变量,意思是输入(输出)参数的个数
ep=1e-5; % 如果bisect1只输入前三个参数,那么精确度默认为1e-5
end
fa=feval(fun,a);fb=feval(fun,b); %函数fun 在点a,b 处的函数值
if(fa*fb>0) %如果a,b之间不存在零解
disp('error');
x_star=NaN;
k=NaN;
else
k=1; % 迭代次数初始化
while abs((b-a)/2)>ep %区间大于精确度的话就迭代
x=(a+b)/2;
fx=feval(fun,x);
if fa*fx<0 %[a,x]区间存在零解
b=x;fb=fx; %缩小b的上限
else
a=x;fa=fx; %如果无解,加大a的下限
end
k=k+1; %每循环一次 迭代加一
end
x_star=(a+b)/2; %把最后的结果赋值给输出的x_star
end

bisect1.m

fun=inline('x^3-x-1','x'); %定义函数
[x_star,k]=bisect1(fun,1,15,0.0000005)

main.m

[matlab] 4.M函数