С Новым годом! Форум программистов, компьютерный форум, киберфорум
Delphi для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.83/18: Рейтинг темы: голосов - 18, средняя оценка - 4.83
0 / 0 / 0
Регистрация: 10.11.2018
Сообщений: 70
1
Delphi 6-7

Написать программу вычисления первой и второй производной табличной функции с помощью полинома Ньютона или Лагранжа

18.01.2019, 11:46. Показов 3530. Ответов 1
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
изменить пример

Delphi
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
{$APPTYPE CONSOLE}
uses sysutils;
const max=50;
type
        TInterval=array[1..2,1..max] of real; {Сетка интерполяции}
    {1 строка - значения узлов в сетке интерполяции
     2 строка - значения функции в узлах интерполяции}
 
        TIntervalOutput=array[1..4,1..max] of real;
    {1 строка - значения узлов в сетке интерполяции
     2 строка - значения функции в узлах интерполяции
     3 строка - значения первой производной функции
     4 строка - значения второй производной функции}
 
 
function f(x:real):real;
{Основная функция}
 begin
 f:=exp(x*x);
 end;
 
 
procedure Newton(x:TInterval; N1,N2:integer; A1,B1:real; var Y:TIntervalOutput);
{Метод Ньютона для интерполирования}
var
    g,h:real;
    i:integer;
 
    function New1(i:integer):real;
    {вычисление очередного члена первой формулы Ньютона - рекурсивна
     вход - порядковый номер}
    begin
        if i=1 then New1:=g else New1:=(New1(i-1)*(g-i+1))/i;
    end;
 
    function d(i,n:integer):real;
    {вычисление конечных разностей - рекурсивна
     вход - номер строки и столбца в таблице разностей}
    begin
        if i=1 then d:=X[2,n+1]-X[2,n] else d:=d(i-1,n+1)-d(i-1,n);
    end;
 
    function newton1(UzelX:real):real;
    {реализация первой формулы Ньютона}
    var
        Next,t1,t2,s:real; {очередной член ф. Ньютона}
        i,n:integer;
    begin
        i:=1;
        n:=trunc((UzelX-x[1,1])/(x[1,2]-x[1,1]))+1; {номер строки таблицы}
        S:=X[2,n];  {сумма членов}
        g:=(UzelX-x[1,n])/(x[1,2]-x[1,1]);
        repeat
            t1:=New1(i);
            t2:=d(i,n);
            Next:=t1*t2;
            S:=S+Next;
            inc(i);
        until (i>(N1-n));  {до конца таблицы}
        Newton1:=S;
    end;
 
    function New2(i:integer):real;
    {вычисление очередного члена второй формулы Ньютона - рекурсивна
     вход - порядковый номер}
    begin
        if i=1 then New2:=g else New2:=(New2(i-1)*(g+i-1))/i;
    end;
 
    function newton2(UzelX:real):real;
    {реализация второй формулы Ньютона}
    var
        Next,t1,t2,s:real;   {очередной член ф. Ньютона}
        n,i:integer;
    begin
        n:=trunc((UzelX-X[1,1])/(x[1,2]-x[1,1])+2);    {номер строки таблицы}
        if n>n1 then n:=n1;  {если за пределами таблицы - экстраполяция}
        g:=(UzelX-X[1,n])/(x[1,2]-x[1,1]);
        S:=x[2,n];  {сумма членов}
        i:=1;
        repeat
            t1:=New2(i);
            t2:=d(i,n-i+1);
            Next:=t1*t2;
            S:=S+Next;
            inc(i);
        until (i>n);  {до конца табл}
        Newton2:=S;
    end;
 
begin
    h:=(B1-A1)/N2;
    for i:=1 to N2 do
    begin
        y[1,i]:=A1+h*(i-1);  {Заполнение таблицы значений}
        if y[1,i]>((x[1,N1]+x[1,1])/2) then y[2,i]:=newton2(y[1,i])
            else y[2,i]:=newton1(y[1,i]);
    end;
 
    {Вычисление первой производной с помощью конечно-разностных отношений}
    y[3,1]:=(y[2,2]-y[2,1])/h;
    for i:=2 to N2-1 do y[3,i]:=(y[2,i+1]-y[2,i-1])/(2*h);
    y[3,N2]:=(y[2,N2]-y[2,N2-1])/h;
 
    {Вычисление второй производной с помощью конечно-разностных отношений}
    for i:=2 to N2-1 do y[4,i]:=(y[2,i+1]-2*y[2,i]+y[2,i-1])/(h*h);
end;
 
 
procedure Lagrange(x:TInterval; N1,N2:integer; A1,B1:real; var Y:TIntervalOutput);
{Интерполяция по формуле Лагранжа}
 
    function L(i,j: integer; UzelX:real):real;
    {Функция вычисления очередного коэффициента формулы Лагранжа по схеме Эйткена - рекурсивна}
    begin
        if j=0 then
    L:=(x[2,i]*(x[1,i+1]-UzelX)-X[2,i+1]*(X[1,i]-UzelX))/(X[1,i+1]-X[1,i])
        else
    L:=(L(i,j-1,UzelX)*(X[1,i+j+1]-UzelX)-L(i+1,j-1,UzelX)*(X[1,i]-UzelX))/(X[1,i+j+1]-X[1,i]);
    end;
 
var
    h:real;
    i:integer;
begin
    h:=(B1-A1)/N2;
    for i:=1 to N2 do
    begin
        y[1,i]:=A1+h*(i-1);
        y[2,i]:=L(1,N1-1,y[1,i])
    end;
 
    {Вычисление первой производной с помощью конечно-разностных отношений}
    y[3,1]:=(y[2,2]-y[2,1])/h;
    for i:=2 to N2-1 do y[3,i]:=(y[2,i+1]-y[2,i-1])/(2*h);
    y[3,N2]:=(y[2,N2]-y[2,N2-1])/h;
 
    {Вычисление второй производной с помощью конечно-разностных отношений}
    for i:=2 to N2-1 do y[4,i]:=(y[2,i+1]-2*y[2,i]+y[2,i-1])/(h*h);
end;
 
var
    A,B,A1,B1,h:real;
    N1,N2,Method,i:integer;
    x:TInterval;
    y:TIntervalOutput;
begin
    Writeln;
    Write('Vvedite nachalo intervala f(x): ');
    Readln(A);
    Write('Vvedite konec intervala f(x): ');
    Readln(B);
    Write('Vvedite kolichestvo uzlov: ');
    Readln(N1);
    Write('Vvedite nachalo intervala interpolyacii: ');
    Readln(A1);
    Write('Vvedite konec intervala interpolyacii: ');
    Readln(B1);
    Write('Vvedite kolichestvo uzlov intervala interpolyacii: ');
    Readln(N2);
    Write('Metod (1-Newton, 2-Lagrange): ');
    Readln(Method);
  if Method=2 then A:=A+0.001;
    h:=(B-A)/N1;
    for i:=1 to N1 do
    begin
        x[1,i]:=A+h*(i-1);
        x[2,i]:=f(x[1,i]);
    end;
    case Method of
        1: Newton(x,N1,N2,A1,B1,Y);
        2: Lagrange(x,N1,N2,A1,B1,Y);
    end;
 
    {вывод результатов}
    Writeln('Metod: ', Method);
    for i:=1 to N2 do
        writeln('x',i:2,'=',y[1,i]:2:4,'  y',i:2,'=',y[2,i]:2:4,'  y',#39,i:2,'=',y[3,i]:2:4,'  y',#39#39,i:2,'=',y[4,i]:2:4);
    writeln;
    for i:=1 to N1 do
        writeln('x',i:2,'=',x[1,i]:2:4,'  y',i:2,'=',x[2,i]:2:4);
    readln;
end.
этот пример для
Задание
Написать программу интерполяции таблично заданной функции
с помощью полиномов Ньютона или Лагранжа. Входные данные:
• исходная сетка узлов интерполяции;
• значения интерполируемой функции;
• новая сетка узлов, на которой необходимо вычислить значения функции;
• порядок полинома.
Выходные данные:
• новая сетка;
• значения полинома на новой сетке;
• погрешность интерполирования
мне надо ее изменить в
Задание
Написать программу вычисления первой и второй производной табличной функции с помощью полинома Ньютона или Лагранжа.
Входные данные:
• исходная сетка узлов функции;
• значения дифференцируемой функции;
• новая сетка узлов, на которой необходимо вычислить значения
• производных функции;
• порядок полинома.
Выходные данные:
• новая сетка;
• значения производных полинома на новой сетке;
• погрешность дифференцирования.
можно ли несколькими строчками или все переделывать
Миниатюры
Написать программу вычисления первой и второй производной табличной функции с помощью полинома Ньютона или Лагранжа  
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
18.01.2019, 11:46
Ответы с готовыми решениями:

Вычисление первой производной функции в первом потоке, а второй производной - во втором
Здравствуйте, помогите создать поток который вычесляет первую производную, а второй поток вторую...

Подскажите формулу для нахождения второй производной в точке x1 с помощью полинома Лагранжа шестой степени
Здравствуйте! Функция задана семью точками. Подскажите, пожалуйста, формулу для нахождения второй...

Вычисление первой и второй производной табличной функции.
Написать программу вычисления первой и второй производной табличной функции с помощью полинома...

Задача интерполяции методом полинома Ньютона и полинома Лагранжа
Решить задачу интерполяции методом полинома Ньютона и полинома Лагранжа 1 2 4 ...

1
0 / 0 / 0
Регистрация: 10.11.2018
Сообщений: 70
18.01.2019, 11:54  [ТС] 2
или хотя бы как вычисляется
• значения дифференцируемой функции;
• погрешность дифференцирования.
0
18.01.2019, 11:54
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
18.01.2019, 11:54
Помогаю со студенческими работами здесь

Интерполирование функции с помощью полинома Лагранжа при равномерной сетке узлов
Здравствуйте. Необходимо написать m-файл-функцию для интерполирования функции на отрезке с...

Вычисление значения первой и второй производной функции f(x)
Составить программу для вычисления значения первой и второй производной функции f (x) в точке Х =...

Надо написать программу для Полинома Лагранжа
Надо написать программу для Полинома Лагранжа Дано по 4 значения х и у. Я вычислил полином для х=3...

Исследовать функции на экстремум с помощью первой производной
Привет! Нужно исследовать функции на экстремум с помощью первой производной. Помогите пожалуйста!...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Что такое HCL Notes и как с ним работать
InfoMaster 10.01.2025
HCL Notes (ранее известный как IBM Notes и Lotus Notes) представляет собой комплексную платформу для совместной работы и обмена информацией в корпоративной среде. Это многофункциональное решение,. . .
Как работать с Git из Windows и Visual Studio
InfoMaster 10.01.2025
Работа с Git в Windows Работа с Git в операционной системе Windows может быть осуществлена с помощью различных инструментов, каждый из которых обладает своими уникальными возможностями и. . .
Аналог оператора switch case в Python
InfoMaster 10.01.2025
Оператор switch case используется в программировании для выбора одного из нескольких вариантов исполнения кода. Однако в языке Python этот оператор отсутствует. Понимание аналогов switch case в. . .
Отличия абстрактного класса от интерфейса
InfoMaster 10.01.2025
В современной разработке программного обеспечения существуют два основных механизма реализации абстракции: абстрактные классы и интерфейсы. Эти инструменты, хотя и схожи в своей основной цели -. . .
Как работать в Git
InfoMaster 10.01.2025
Git — это одна из наиболее популярных систем контроля версий, которая активно используется разработчиками по всему миру. Она позволяет эффективно управлять изменениями в коде, координировать работу. . .
Реализация передвижения персонажа в Unity3d на C#
InfoMaster 10.01.2025
Реализация передвижения персонажа в Unity3D начинается с правильной настройки проекта. Этот этап критически важен для создания отзывчивого и плавного управления. Рассмотрим основные шаги для создания. . .
Docker: руководство для начинающих
InfoMaster 10.01.2025
В современном мире разработки программного обеспечения контейнеризация стала неотъемлемой частью процесса создания и развертывания приложений. Docker, как ведущая платформа контейнеризации, произвела. . .
Книги и учебные ресурсы по C#
InfoMaster 08.01.2025
Базовые учебники и руководства Одной из лучших книг для начинающих является "C# 10 и . NET 6 для начинающих" Эндрю Троелсена и Филиппа Джепикса . Книга последовательно раскрывает основные концепции. . .
Что такое NullReferenceEx­­­ception и как исправить?
InfoMaster 08.01.2025
NullReferenceException - одно из самых распространенных исключений, с которым сталкиваются разработчики на C#. Это исключение возникает при попытке обратиться к членам объекта (методам, свойствам или. . .
Что такое Null Pointer Exception (NPE) и как это исправить?
InfoMaster 08.01.2025
Null Pointer Exception (NPE) - это одно из самых распространенных исключений в Java, которое возникает при попытке использовать ссылку на объект, значение которой равно null. Это исключение относится. . .
Русский язык в консоли C++
InfoMaster 08.01.2025
При разработке программ на C++ одной из частых проблем, с которой сталкиваются русскоязычные программисты, является корректное отображение кириллицы в консольных приложениях. Эта проблема особенно. . .
Telegram бот на C#
InfoMaster 08.01.2025
Разработка ботов для Telegram стала неотъемлемой частью современной экосистемы мессенджеров. C# предоставляет мощный и удобный инструментарий для создания разнообразных ботов, от простых. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru