Очень нужна помощь.. В общем суть- вычислить интеграл методом симпсона.. Я написала,всё считает,но, оказываетсЯ,еще нужен эпсилон- точность,которую надо забивать при расчете( напр. 0,1 ;0,01 и т.д.). Я не могу сообразить как вставить эпсилон сюда.. Я учусь только программировать, подошла к преподу- а он даже объяснить ничего не может((надеюсь на вашу помощь.... уже долго сижу с этой проблемой и никак не могу понять... вот мой код:
Код:
program Simpson;
uses crt;
{integriruemaya funkciya}
function F(x:Real):Real;
begin
F:=exp(2*sin(x)) * sin(5 + 2* cos(x) );
end;
var a,b,h,x: real;
i,n: integer; {n-chislo tochek na interv}
integ: real;
begin
clrscr;
{interval integrirovaniya}
a:=0;
b:=2*pi;
{osnovnaya programma}
write ('Vvedite kolichestvo razbieniy intervala (chetnoe) n= '); readln(n);
if (n mod 2) > 0 then
begin
n:=n+1;
writeln('Chislo n bilo vvedeno nechetnoe i bilo zameneno na n=',n);
end;
h:=(b-a)/n;
integ:=F(a)+F(b)+4*F(a+h);
for i:=1 to (n div 2 ) -1 do
begin
x:=a+2*h*i;
integ:=integ + 2*F(x) + 4*F(x+h);
end;
integ:=h*integ/3;
writeln('Integral= ',integ:10:6);
readln;
end.