我正在为simpson的规则编写一个Matlab程序当程序到达left_simpson = Simpson(a,c,(e1)/2,level, level_max);
时,我一直收到许多输出的错误.settinf left_simpson
到Simpson(a,c,(e1)/2,level, level_max);
有什么问题?
function Simpson(a,b,e1,level, level_max)
level = level + 1;
h = b - a;
c = (a+b)/2;
one_simpson = h*(f(a) + 4*f(c) + f(b))/6;
d = (a+c)/2;
e = (c+b)/2;
two_simpson = h*(f(a) + 4*f(d) + 2*f(c) + 4*f(e))/2;
if level >= level_max
disp('h')
simpson_result = two_simpson;
disp('maximum levels reached')
disp(simpson_result);
if abs(two_simpson - one_simpson) < 15*e1
simpson_result = two_simpson + (two_simpson - one_simpson)/15;
else
left_simpson = Simpson(a,c,(e1)/2,level, level_max);
right_simpson = Simpson(c,b,(e1)/2,level, level_max);
simpson_result = left_simpson + right_simpson;
end
end
答案 0 :(得分:5)
您的函数语句是代码中的第一行,它不会声明Simpson返回的内容。我不知道Matlab对这样的声明做了什么。我认为你应该重新编写Simpson来显式返回一个值或值。请查看Matlab文档,了解如何执行此操作。
一旦你宣布了辛普森的回归,你就可以避免“太多输出”的问题。