• Добро пожаловать на компьютерный форум Tehnari.ru. Здесь разбираемся с проблемами ПК и ноутбуков: Windows, драйверы, «железо», сборка и апгрейд, софт и безопасность. Форум работает много лет, сейчас он переехал на новый движок, но старые темы и аккаунты мы постарались сохранить максимально аккуратно.

    Форум не связан с магазинами и сервисами – мы ничего не продаём и не даём «рекламу под видом совета». Отвечают обычные участники и модераторы, которые следят за порядком и качеством подсказок.

    Если вы у нас впервые, загляните на страницу о форуме и правила – там коротко описано, как задать вопрос так, чтобы быстро получить ответ. Чтобы создавать темы и писать сообщения, сначала зарегистрируйтесь, а затем войдите под своим логином.

    Не знаете, с чего начать? Создайте тему с описанием проблемы – подскажем и при необходимости перенесём её в подходящий раздел.
    Задать вопрос Новые сообщения Как правильно спросить
    Если пришли по старой ссылке со старого Tehnari.ru – вы на нужном месте, просто продолжайте обсуждение.

Помогите пожалуйста решить задачу в Pascal

Darik102rus

Ученик
Регистрация
26 Апр 2013
Сообщения
11
Реакции
0
Баллы
0
Помогите пожалуйста решить задачу в Pascal

С помощью формулы Симпсона вычислить интеграл:
При различных значениях параметра z (значение параметра вводится с клавиатуры) вычислить значение интеграла на заданном отрезке при различных значениях точности ε, задаваемых с клавиатуры.
 

Вложения

  • 4.webp
    4.webp
    2.4 KB · Просмотры: 85
С помощью формулы Симпсона вычислить интеграл:
С помощью формулы Симпсона ВЫЧИСЛЕН интеграл! Да еще (для сравнения) вычислено точное значение, благо интеграл - берущийся. Формат вывода построен так, что в численном решении отображается число значащих цифр, определяемое заданной точностью.
Код:
Const
 a=0.1;
 b=0.8;

Var
 z,Eps:Real;

Function F(p,q:Real):Real;
begin
 F:=p*p/Sqr(p*p*p+q*q*q);
end;

Function Antiderivative(p,q:Real):Real;
begin
 Antiderivative:=-1.0/3/(p*p*p+q*q*q);
end;


Procedure Simpson;
var
 i,N:Integer;
 Sum1,Sum2,h:Real;
begin
 N:=2;
 h:=(b-a)/(2*N);
 Sum1:=(F(a,z)+F(b,z))/3*h;
 for i:=1 to N do
  Sum1:=Sum1+4.0*h/3.0*F(a+h*(2*i-1),z);
 for i:=2 to N do
  Sum1:=Sum1+2.0*h/3.0*F(a+h*(2*i-2),z);
 Sum2:=Sum1;
 Repeat
  Sum1:=Sum2;
  N:=N*2;
  h:=(b-a)/(2*N);
  Sum2:=(F(a,z)+F(b,z))/3*h;
  for i:=1 to N do
   Sum2:=Sum2+4.0*h/3.0*F(a+h*(2*i-1),z);
  for i:=2 to N do
   Sum2:=Sum2+2.0*h/3.0*F(a+h*(2*i-2),z);
 Until ABS(Sum2-Sum1)<Eps;
 WriteLn('Simpson:        ', Sum2:0:(Round(-Ln(Eps)/Ln(10))+1));
end;

Begin
 Write('z = ');
 Readln(z);
 Write('Eps = ');
 Readln(Eps);
 Simpson;
 WriteLn('Accurate value: ', (Antiderivative(b,z)-Antiderivative(a,z)):0:8);
 ReadLn;
End.
 
Спасибо большое за помощь)
 
Назад
Сверху