Форум программистов, компьютерный форум, киберфорум
C++ Builder
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
0 / 0 / 0
Регистрация: 18.03.2015
Сообщений: 14
1

Интерполяция по новой формуле

11.04.2017, 14:37. Показов 1062. Ответов 0
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Здравствуйте,помогите пожалуйста, есть программа - интерполяция по формуле лагранжа, все работает, только формула нужна иная для интерполяции - интерполяция по эрмиту, вот формула
Интерполяция по новой формуле
, где Wn(x)=(x-x1)(x-x2).....(x-xn). Кусок который нужно изменить выделен жирным шрифтом
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
//---------------------------------------------------------------------------
 
#include <vcl.h>
#include <fstream>
#include <vector>
#pragma hdrstop
 
#include "Unit1.h"
//---------------------------------------------------------------------------
#pragma package(smart_init)
#pragma resource "*.dfm"
TForm1 *Form1;
//---------------------------------------------------------------------------
__fastcall TForm1::TForm1(TComponent* Owner)
        : TForm(Owner)
{
}
//---------------------------------------------------------------------------
using namespace std;
 
vector<double> X,Y;                                                             // Векторы для исходных данных
 
[B]double Lagrange(double arg)                                                     // Интерполирование по Лагранжу
{
double P,Res=0;
for(int i=0;i<X.size();i++)
 {
 P=1;
 for(int j=0;j<X.size();j++)
  if(i!=j) P*=(arg-X[j])/(X[i]-X[j]);
 Res+=P*Y[i];
 }
return Res;
}[/B]
 
void __fastcall TForm1::Button1Click(TObject *Sender)                           // Обработка
{
if(!OpenDialog1->Execute()) return;                                             // Файл не выбран - завершить
Chart1->Series[0]->Clear();                                                     // Инициализация всех параметров
Chart1->Series[1]->Clear();
Edit2->Clear();
Edit3->Clear();
Button2->Enabled=true;
Edit1->Text=OpenDialog1->FileName;
double x,y;
ifstream F(OpenDialog1->FileName.c_str());                                      // Открытие файла
while(!F.eof())                                                                 // Чтение файла до конца
 {
 F>>x>>y;
 if(F.fail())                                                                   // Если Некорректные данные
  {
  Chart1->Series[1]->Clear();                                                   // то очистить график
  Beep();                                                       
  ShowMessage("Ошибка файла данных!");                                          // вывести сообщение
  F.close();                                                                    // закрыть файл
  return;                                                                       // и выйти
  }
 X.push_back(x);                                                                // Сохранение данных в векторы
 Y.push_back(y);
 Chart1->Series[1]->AddXY(x,y);                                                 // Вывод точки на график
 }
F.close();                                                                      // закрытие файла
Button2->Enabled=true;
Application->ProcessMessages();                                                 // Немедленное отображение точек
x=Chart1->BottomAxis->Minimum;                                                  // Построение графика интерполяции
y=(Chart1->BottomAxis->Maximum-x)/Screen->Width;                                // Число точек графика - ширина экрана (максимально возможное)
for(int i=0;i<Screen->Width;i++)
 {
 Chart1->Series[0]->AddXY(x,Lagrange(x));                                       // Вычисление и добавление очередной точки
 x+=y;
 }
}
//---------------------------------------------------------------------------
void __fastcall TForm1::Button2Click(TObject *Sender)                           // Интерполяция в произвольной точке
{
double x;
Edit3->Clear();
try
 {x=StrToFloat(Edit2->Text);}                                                   // Ввод аргумента
catch(...)                                                                      // Ошибка - вывод сообщение
 {
 Beep();
 ShowMessage("Некорректный аргумент!");
 Edit2->SetFocus();
 return;
 }
Edit3->Text=FloatToStr(Lagrange(x));                                            // Расчёт и вывод результата
}
//--------------
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
11.04.2017, 14:37
Ответы с готовыми решениями:

интерполяция по формуле лагранжа
Здравствуйте! Помогите, пожалуйста, написать программу. Мне нужно написать программу интерполяции по формуле лагранжа. У меня...

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

Не получается интерполяция по формуле Бесселя
Входные данные (x, y): (1 , 6); (2,7); (3,9); (4,4); (5,5) Составляю таблицу: Вот непосредственно сама формула бесселя...

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
11.04.2017, 14:37
Помогаю со студенческими работами здесь

Найти элементы новой матрицы, каждый из которой определяются по формуле
Дана единичная матрица Е {{1, 1, 1, 1}, _ {1, 1, 1, 1}, _ ...

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

Интерполяция полиномом Лагранжа и кусочная интерполяция
столкнулась с такой проблемой: написала интерполяцию Лагранжа x=; y=2*cos(x); function =inter(a,x,y) n=length(x); p=0; ...

Каждый из интегралов вычислить по формуле прямоугольника, по формуле трапеции и по формуле Симпсона
Каждый из интегралов вычислить по формуле прямоугольника, по формуле трапеции и по формуле Симпсона. Интегралы: ∫xe2xdx, пределы...

После добавления в БД новой строчки надо распечатать или просмотреть отчёт с новой строчкой по клику на кнопку
Вопрос такой: У меня Отчёт сделан с помощью rave ADOQuery1 подключен к RvDataSetConnection1 который подключен к RvProject1 После...


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему

Редактор формул (кликните на картинку в правом углу, чтобы закрыть)
Новые блоги и статьи
Вопросы на собеседовании по Android
mobDevWorks 14.03.2025
По данным статистики, Android занимает более 70% мирового рынка мобильных операционных систем, что делает платформу привлекательной как для начинающих разработчиков, так и для опытных профессионалов. . . .
Лучшие игровые движки для Python
py-thonny 14.03.2025
Python обеспечивает разработчиков игр мощными движками и фреймворками, которые позволяют воплотить практически любую идею — от простой аркады до визуального романа с разветвленным сюжетом. Главное. . .
Бессерверный JavaScript: Разработка масштабируемых API с AWS Lambda
run.dev 14.03.2025
Но что такое бессерверные вычисления на самом деле? По сути, это модель облачных вычислений, где разработчик фокусируется исключительно на создании бизнес-логики, не тратя время на настройку. . .
Безопасность кода в C++26: Менеджеры ресурсов и висячие ссылки
NullReferenced 14.03.2025
C++ всегда был языком, предоставляющим разработчикам большие возможности и гибкость, но вместе с тем требующим ответственности. Одной из самых коварных проблем даже для опытных программистов остаются. . .
smart-agent proper interface settings (2025)
jigi33 14.03.2025
Smart-agent proper interface settings (mart 2025). (see screenshots to look at "Etalon" ARM)
Продвинутые настройки JVM
Javaican 14.03.2025
Стандартные параметры запуска JVM хороши для повседневной разработки, но совершенно недостаточны для высоконагруженных систем. Представьте, что вы запускаете финансовую платформу, обрабатывающую. . .
CI/CD для приложений Java с Azure DevOps и Docker
Mr. Docker 14.03.2025
Разработка современных Java-приложений немыслима без системы непрерывной интеграции и доставки (CI/ CD). Azure DevOps в сочетании с Docker предоставляет мощный инструментарий для создания таких. . .
Разработка на PHP и интернет вещей (IoT)
Jason-Webb 14.03.2025
Интернет вещей (IoT) произвел настоящую революцию в способах взаимодействия устройств с окружающим миром. В эпоху, когда холодильники сами заказывают молоко, а термостаты учатся вашим привычкам,. . .
Node.js 20: Новые возможности и улучшения производительно­сти
Reangularity 14.03.2025
Что же принёс нам релиз Node. js 20? В первую очередь, это существенные улучшения в производительности. Движок V8 получил серьёзные оптимизации, благодаря чему JavaScript-код выполняется заметно. . .
Безопасность кластеров Apache Kafka
Javaican 14.03.2025
Apache Kafka стал одним из ключевых компонентов современных архитектур, обрабатывающих потоки данных в режиме реального времени. Его используют тысячи компаний от стартапов до технологических. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru
Выделить код Копировать код Сохранить код Нормальный размер Увеличенный размер