Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.63/56: Рейтинг темы: голосов - 56, средняя оценка - 4.63
zloyprog

Интерполяция функции по Ньютону

23.09.2010, 14:06. Показов 11299. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
помогите составить хотя бы набросить текст проги для вычесление функции f(t) интерполяции ф-и нахождения полинома по ньютону для 2 узлов n1 n2 c шагом h=0.1 (узлы n1=5 , t1=0.5 , t2=1, t3=1.5, t4=2, t5=2.5).(численные методы дисциплна)спс
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
23.09.2010, 14:06
Ответы с готовыми решениями:

Интерполяция заданной функции второй формулой Ньютона (обратная интерполяция)
Программа накапливает ошибку, да и первые значения совсем уже "приближённые". Явно что-то упустил. Посмотрите со стороны. #include...

Интерполяция по Ньютону
Привет форумчане, сижу и ламаю голову над Интерполяцией по Ньютону понимаешь ли, и чет ниче не работает, после дохождения до 3тей формы и...

Интерполяция по Ньютону
Здравствуйте, записал интерполяцию по Ньютону, но не понимаю в чем проблема и почему не работает данная программа. procedure...

1
0 / 0 / 1
Регистрация: 12.07.2017
Сообщений: 1
18.12.2010, 14:56
Лучший ответ Сообщение было отмечено как решение

Решение

может не совсем корректно, но я придумал вот такой код

C++
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
#include <cstdlib>
#include <iostream>
#include <math.h>
#include <conio.h>
#include <locale>
 
using namespace std;
///////////////////////////////////////////////////////////////////////////////
// Некоторые глобальные переменные
///////////////////////////////////////////////////////////////////////////////
const int maxN = 50;
int N;
double x[maxN]; // Точки на [A,B]
double yd[maxN],yt[maxN],Temp[maxN],fuctor[maxN]; // Коэфициенты при многочленах для Интерполяции
double mnog[maxN]; // Многочлен по теореме Виетта
double inter[maxN]; // Интерполяционный многочлен Ньютона
///////////////////////////////////////////////////////////////////////////////
// Структура для теоремы Виетта
struct kf
{
    int por;
    double zna4;
};
kf koef1[maxN*maxN];
kf koef2[maxN*maxN];
// 1/n!
double fuct_1(int q)
{
    double temp=1;
    for(int j=2;j<=q;j++)temp/=j;
    return (temp);
}
///////////////////////////////////////////////////////////////////////////////
// Свободная функция
double fFree(double x)
{
    return ( exp( 0.5*x ) );
}
///////////////////////////////////////////////////////////////////////////////
// Построение многочленов по теореме Виетта
///////////////////////////////////////////////////////////////////////////////
// Находим конечные разности
void dy()
{
    double yt[maxN], yk[maxN];
    for(int i = 0; i<=N; i++)yt[i] = Temp[i];
    for(int k=0;k<=N;k++)
    {
        yd[k] = yt[0];
        for(int i=0;i<N-k;i++)
        {
            yk[i] = yt[i+1] - yt[i];
            yt[i] = yk[i];
        }
    }
}
// Находим коэфициенты при многочленах
void Ci()
{
    dy();
    for(int i=0;i<=N;i++)yd[i]*=pow(h,-i)*fuctor[i];
}
// Находит сумму попарных произведений
double sum(int n,int q)
{
    double s=0;
    for(int ii=0;ii<=n;ii++)s+=koef1[ii].zna4;
    if( q%2 == 0 ) s = -s;
    return ( s );
}
// Коэфициенты многочлена по теореме Виетта
void TVietta(int w)
{
    for(int i=0; i <= N; i++)mnog[i] = 0;
    for(int i=0; i <= N-w; i++)
    {
        koef1[i].zna4 = x[i];
        koef1[i].por = i;
    }
    mnog[N-w+1] = 1;    
    for(int i=0; i<=N-w; i++)mnog[N-w]+=x[i];mnog[N-w]=-mnog[N-w];
    int l = N-w;
    int soka=1;
 
while( soka <= N-w )
{
    int m = l;
    l = -1;
    for(int i = 0; i <= m; i++)
    {
        for(int j = koef1[i].por+1; j <= N-w; j++)
        {
            l++;
            koef2[l].zna4 = koef1[i].zna4 * x[j];
            koef2[l].por = j;
        }
    }
    for(int i = 0; i <= l; i++)
    {
        koef1[i].zna4 = koef2[i].zna4;
        koef1[i].por = koef2[i].por;
    }
    mnog[N-w-soka] = sum(l,soka);
    soka++;
}
}
// Интерполяция по Ньютону, собственно строим сам многочлен
void Interpol_P(int r)
{
    Ci();
    for(int e = 0; e <= N; e++)inter[e] = 0;
    for(int e = 0; e <= N; e++)
    {
        TVietta( e+1 );
        for(int i = 0; i <= N-e; i++)inter[i] += yd[N-e]*mnog[i];
    }
    if(r != 0)for(int e = 0; e <= N; e++)printf("X^%1.1i:  %4.25f\n",e,inter[e]);
}
///////////////////////////////////////////////////////////////////////////////
// Интерполяция свободной функции
///////////////////////////////////////////////////////////////////////////////
void Interpol_fFree()
{
   for(int i=0;i<=N;i++)
   {
           Temp[i]=fFree(x[i]);
           fuctor[i]=fuct_1(i);
   }
   Interpol_P(1);
}
int main()
{
    N = 10;
    h = (2.0-1.0)/N;
    for(int i = 0; i <= N; i++)x[i] = 1 + i * h;
    Interpol_fFree();
    return (0);
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
18.12.2010, 14:56
Помогаю со студенческими работами здесь

Сделать интерполяцию по Лагранжу и Ньютону
Нужно сделать в Mathcade Интерполяцию по Лагранжу и Ньютона.

Интерполяция функции
Писал программу по двум методам интерполяции функции: по Лагранжу и линейно. Составил 2 модуля считывания/вывода массива и линейной...

Интерполяция функции
Доброго времени суток. Прошу подскажите: в чем идея сплайн интерполяции. Я нашел следущую формулировку идеи :Основная идея...

Интерполяция функции
Здравствуйте, необходимо выполнить интерполяцию функцию несколькими способами. 1. Линейная интерполяция 2. Интерполяция сплайнами 3....

Интерполяция функции
Есть функция: f(x) = Sin(2Pix3), xmin=0, xmax=1, n=6 Необходимо создать программы глобальной и сплайновой интерполяции на языке...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru