Как стать автором
Обновить

Представление произвольных полиномов в виде конечных разностей с произвольным шагом

Время на прочтение3 мин
Количество просмотров5.6K

Введение


В данной статье рассматривается возможность представление произвольного полинома произвольной целой степени n в виде конечных разностей. Подход в данной статье отличается от уже имеющихся тем, что все формулы выводятся для произвольного полинома с произвольными коэффициентами, а также тем, что в качестве интервала между точками используется произвольный, а не единичный интервал. Полученные формулы универсальны, и могут без изменения использоваться как для вычисления «будущих», так и «прошлых» значений полинома. То есть, например, для любой кривой, выраженной квадратичным уравнением с произвольными коэффициентами, можно вычислить все значения имея лишь 3 заранее известных значения y, взятые через произвольный равный интервал φ. Как следствие, вводится утверждение, что через (n+1) равноотстоящих точек может быть проведена одна и только одна кривая, выраженная полиномом степени n.

Disclaimer


Я не математик, я просто программист с 20-ти летним стажем. Я провёл самостоятельные исследования, но не нашёл таких же выводов, что сделал я в этой статье. Буду признателен за любые замечания и «наводки» на существующие разработки, выводы которых аналогичны (или близки) к моим.

Общая информация


Для начала приведу общую формулу для вычисления функции S(t), заданной полиномом степени n и выраженной через (n+1) предыдущих значений, взятых через равный интервал φ:

$S(t)=\sum_{k=1}^{n+1}(-1)^{k-1}C_{n+1}^kS(t-k\varphi)$


То есть, например, для полинома степени n=1 (обычной линии) такая формула будет иметь вид:

$S(t)=2S(t-\varphi)-S(t-2\varphi)$


Для полинома степени n=2 такая формула будет иметь вид:

$S(t)=3S(t-\varphi)-3S(t-2\varphi)+S(t-3\varphi)$


И так далее. Подробное математическое доказательство приведено в данном документе. Также мною был подготовлен проверочный код, выполненный в виде кода на JavaScript. Получить его можно по этой ссылке. В этой же статье я покажу некоторые практические выводы и варианты использования полученных уравнений.

Построение полиномов степени 2


Для общего понимания «полином степени 2» выражается с помощью следующей формулы:

$S(t)=Q_2 t^2+Q_1 t+Q_0$


Однако, как оказалось, можно вычислить все значения данного полинома (на самом деле можно вычислить только значения полинома в узлах с неким произвольным шагом φ) с помощью уравнения «в конечных разностях»:

$S(t)=3S(t-\varphi)-3S(t-2\varphi)+S(t-3\varphi)$


То есть на основании любых трёх значения функции S(t), взятых через равный произвольный интервал φ, можно получить все значения полинома. Покажем это на реальных данных. Пусть реальный полином будет выражаться следующей функцией:

$R(t)=1t^2+2t+3$


Теперь вычислим значения функции R(t) в точках t=111, t=115 и t=119. То есть шаг φ в данном случае равен 4. Полученные значения будут R(111)=12546, R(115)=13458 и R(119)=14402. Теперь вычислим следующие два значения полинома, используя уравнение с конечными разностями:

$R(123)=3R(119)-3R(115)+R(111)=15378$


$R(127)=3R(123)-3R(119)+R(115)=16386$


Нетрудно посчитать, что значения, вычисленные с помощью формулы в конечных разностях, полностью совпадают со значениями, вычисленными с помощью «стандартной» формулы для полинома второй степени.

Также формула в конечных разностях позволяется вычислять значения «назад» без изменения самой формулы. Например, для вычисления R(107) и R(103) получаем следующее:

$R(107)=3R(111)-3R(115)+R(119)=11666$


$R(103)=3R(107)-3R(111)+R(115)=10818$


Опять же нетрудно посчитать, что значения, полученные с помощью формул конечных разностей, полностью совпадают со значениями, вычисленными с помощью «стандартной» формулы для полинома второй степени.

Для всех последующих степеней результаты будут аналогичные. Мною были проверены полиномы вплоть до 99-ой степени: результаты, полученные с помощью «стандартных» формул, полностью совпадают с результатами, полученным с помощью конечных разностей.

Дополнение


Хотел бы также отметить, что для построения полинома степени n не обязательно иметь именно (n+1) равноотстоящих точек — можно сколь угодно больше (обозначим как (m+1)). Но в этом случае потребуется использовать формулу для полинома степени m. Это можно иллюстрировать следующим примером:

$Q_2x^2+Q_1x+Q_0 = 0x^4+0x^3+Q_2x^2+Q_1x+Q_0$


То есть для полинома второй степени можно использовать формулы от полинома четвёртой и третьей степеней — результат всё-равно будет корректный.

Выводы


Формулы в конечных разностях позволяют вычислять (и выражать в виде формулы) любой полином функции любой целой степени. Для уравнения в конечных разностях неважно, какие именно коэффициенты были использованы при каких степенях полинома. Для уравнения в конечных разностях неважно, через какой промежуток были взяты начальные точки – интервал может быть сколь угодно малым, или сколь угодно большим. Вычисления в конечных разностях обладают потенциально более высокой точностью по сравнению с вычислением через «стандартные» формулы (из-за отсутствия степенных функций). Функция для полинома в конечных разностях выражается без степенных функций и, как следствие, может иметь только одно значение при заданных переменных. И, следовательно, через (n+1) равноотстоящих точек может быть проведена одна и только одна кривая, выраженная полиномом степени n.
Теги:
Хабы:
Всего голосов 20: ↑18 и ↓2+16
Комментарии49

Публикации

Истории

Ближайшие события