Базисные сплайны
Список литературы
1. Вержбицкий В.М. Основы численных методов – М.:Высш. шк., 2002.
2. Завьялов Ю.С., Квасов Б.И., Мирошниченко В.Л. Методы сплайн – функций - М.: Наука, 1980. 352 с
3. Бахвалов Н. С., Жидков Е. П., Кобельков Г. М. Численные методы. Учебное пособие. - 4-е издание – М.- СПб.: Физматлит, Невский диалект, Лаборатория базовых знаний, 2003
4. Препарата Ф., Шейм
ос М. Вычислительная геометрия. Введение. - Мир, 1989
5. Колмогоров А. Н., Фомин С. В. Элементы теории функций и функционального анализа - М.: Наука, 1976
Приложение
Листинг программы.
#include<conio.h>
#include<iostream>
using namespace std;
double KubichSplain ( int n, double *X, double *Y, double Xp )
{
double *Q, *L, *A, *B, *C, *D, DXp, Yp;
int i, j, k;
Q = new double [n];
L = new double [n];
A = new double [n];
B = new double [n];
C = new double [n];
D = new double [n];
for(i=0;i<n;i++)
if(Xp<=X[i])
{
k=i;
break;
}
Q[1] = (-1) * (X[2]-X[1])/2*(X[1]-X[0] + X[2]-X[1]);
L[1] = (3*(Y[2]-Y[1])/(X[2]-X[1]) - 3*(Y[1]-Y[0])/(X[1]-X[0])) / (2*(X[1]-X[0] + X[2]-X[1]));
C[n-1]=0;
C[0]=0;
for(i=3; i<n; i++)
{
Q[i-1]=(-1) * (X[i]-X[i-1]) / (2*(X[i-1]-X[i-2]+X[i]-X[i-1])+(X[i-1]-X[i-2])*Q[i-2]);
L[i-1]=(3*((Y[i]-Y[i-1])/(X[i]-X[i-1])-(Y[i-1]+Y[i-2])/
(X[i-1]-X[i-2]))-(X[i-1]-X[i-2])*L[i-2])/(2*(X[i-1]-X[i-2]+X[i]-X[i-1])+(X[i-1]-X[i-2])*Q[i-2]);
}
for(i=n-1; i>=2; i--)
C[i-1]=Q[i-1]*C[i]+L[i-1];
A[0]=Y[0];
for(i=1;i<n;i++)
{
A[i]=Y[i];
D[i]=(C[i]-C[i-1])/3.*(X[i]-X[i-1]);
B[i]=(Y[i]-Y[i-1])/(X[i]-X[i-1])+2.*(X[i]-X[i-1])*C[i]/3.+(X[i]-X[i-1])*C[i-1]/3.;
}
DXp=Xp-X[k];
//получение значения интерполирующей функции
Yp = A[k] + B[k]*DXp + C[k]*DXp*DXp + D[k]*DXp*DXp*DXp;
delete []A;
delete []B;
delete []C;
delete []D;
delete []Q;
delete []L;
return Yp;
}
void main ( void )
{
double *X, *Y, Xp;
int n, i;
system("CLS");
cout << "Enter n: ";
cin >> n;
X = new double [n];
Y = new double [n];
for ( i = 0; i < n; i ++ )
{
cout << "X[ " << i+1 << " ] = ";
cin >> X[i];
}
for ( i = 0; i < n; i ++ )
{
cout << "Y( " << X[i] << " ) = ";
cin >> Y[i];
}
cout << "Xp = ";
cin >> Xp;
cout << "Y( " << Xp << " ) = " << KubichSplain ( n, X, Y, Xp )<<"\n";
getch();
delete []X;
delete []Y;
}
Другие рефераты на тему «Математика»:
Поиск рефератов
Последние рефераты раздела
- Анализ надёжности и резервирование технической системы
- Алгоритм решения Диофантовых уравнений
- Алгебраическое доказательство теоремы Пифагора
- Алгоритм муравья
- Векторная алгебра и аналитическая геометрия
- Зарождение и создание теории действительного числа
- Вероятностные процессы и математическая статистика в автоматизированных системах