Линейная интерполяция - Linear interpolation

Учитывая две красные точки, синяя линия представляет собой линейный интерполянт между точками, а значение у в Икс можно найти с помощью линейной интерполяции.

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

Линейная интерполяция между двумя известными точками

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

Если две известные точки заданы координатами и , то линейный интерполянт прямая линия между этими точками. Для стоимости Икс в интервале , Значение у по прямой определяется из уравнения уклонов

которое геометрически выводится из рисунка справа. Это частный случай полиномиальная интерполяция с участием п = 1.

Решение этого уравнения для у, что является неизвестным значением при Икс, дает

что является формулой линейной интерполяции в интервале . За пределами этого интервала формула идентична линейная экстраполяция.

Эту формулу также можно понимать как средневзвешенное значение. Веса обратно пропорциональны расстоянию от конечных точек до неизвестной точки; более близкая точка имеет большее влияние, чем более удаленная. Таким образом, веса равны и , которые представляют собой нормированные расстояния между неизвестной точкой и каждой из конечных точек. Поскольку их сумма равна 1,

что дает формулу линейной интерполяции, приведенную выше.

Интерполяция набора данных

Линейная интерполяция по набору данных (красные точки) состоит из частей линейных интерполяций (синие линии).

Линейная интерполяция по набору точек данных (Икс0, у0), (Икс1, у1), ..., (Иксп, уп) определяется как объединение линейных интерполянтов между каждой парой точек данных. Это приводит к непрерывная кривая, с разрывной производной (в общем случае), таким образом класс дифференцируемости .

Линейная интерполяция как приближение

Линейная интерполяция часто используется для аппроксимации значения некоторых функция ж используя два известных значения этой функции в других точках. В ошибка этого приближения определяется как

где п обозначает линейную интерполяцию многочлен определено выше:

Это можно доказать, используя Теорема Ролля что если ж имеет непрерывную вторую производную, то погрешность не превышает

То есть приближение между двумя точками данной функции ухудшается со второй производной аппроксимируемой функции. Это также интуитивно верно: чем «изогнутее» функция, тем хуже становятся аппроксимации, сделанные с помощью простой линейной интерполяции.

История и приложения

Линейная интерполяция использовалась с древних времен для заполнения пробелов в таблицах. Предположим, у вас есть таблица, в которой перечислено население какой-либо страны в 1970, 1980, 1990 и 2000 годах, и вы хотите оценить население в 1994 году. Линейная интерполяция - простой способ сделать это. Техника использования линейной интерполяции для составления таблиц, как полагали, использовалась Вавилонские астрономы и математики в Селевкид Месопотамия (последние три века до нашей эры), а также Греческий астроном и математик, Гиппарх (2 век до нашей эры). Описание линейной интерполяции можно найти в древних Китайский математический текст называется Девять глав математического искусства (九章 算術),[1] датируется с 200 г. до н.э. по 100 г. н.э., а Альмагест (2 век нашей эры) Птолемей.

Основная операция линейной интерполяции между двумя значениями обычно используется в компьютерная графика. На жаргоне той области это иногда называют лерп. Термин может использоваться как глагол или имя существительное для операции. например "Алгоритм Брезенхема lerps постепенно между двумя конечными точками линии ".

Операции Lerp встроены в аппаратное обеспечение всех современных процессоров компьютерной графики. Их часто используют в качестве строительных блоков для более сложных операций: например, билинейная интерполяция может быть выполнено за три лерпа. Поскольку эта операция дёшево, это также хороший способ реализовать точный таблицы поиска с быстрым поиском гладкие функции без слишком большого количества записей в таблице.

Расширения

Сравнение линейной и билинейной интерполяции некоторых 1- и 2-мерных интерполяций. Черные и красные / желтые / зеленые / синие точки соответствуют интерполированной точке и соседним отсчетам соответственно. Их высота над землей соответствует их значениям.

Точность

Если C0 функция недостаточна, например, если известно, что процесс, создавший точки данных, более плавный, чем C0, обычно заменяют линейную интерполяцию на сплайн-интерполяция или, в некоторых случаях, полиномиальная интерполяция.

Многомерный

Описанная здесь линейная интерполяция предназначена для точек данных в одном пространственном измерении. Для двух пространственных измерений расширение линейной интерполяции называется билинейная интерполяция, и в трех измерениях, трилинейная интерполяция. Однако обратите внимание, что эти интерполянты больше не линейные функции пространственных координат, а не произведений линейных функций; это иллюстрируется явно нелинейным примером билинейная интерполяция на рисунке ниже. Другие расширения линейной интерполяции могут применяться к другим видам сетка такие как треугольные и тетраэдрические сетки, в том числе Поверхности Безье. Их можно определить как действительно многомерные кусочно-линейная функция (см. второй рисунок ниже).

Пример билинейная интерполяция на единичном квадрате с z значения 0, 1, 1 и 0,5, как указано. Интерполированные значения между ними представлены цветом.
Кусочно-линейная функция в двух измерениях (вверху) и выпуклые многогранники, на которых она линейна (внизу)

Поддержка языков программирования

Многие библиотеки и языки затенения иметь вспомогательную функцию "lerp" (в GLSL вместо этого известен как смешивание), возвращая интерполяцию между двумя входами (v0, v1) для параметра (t) в закрытом единичном интервале [0, 1]. Сигнатуры между функциями lerp по-разному реализуются в обеих формах (v0, v1, t) и (t, v0, v1).

// Неточный метод, который не гарантирует v = v1 при t = 1 из-за арифметической ошибки с плавающей запятой. Этот метод монотонный// Эта форма может использоваться, когда оборудование имеет встроенную команду умножения-сложения.плавать лерп(плавать v0, плавать v1, плавать т) {  вернуть v0 + т * (v1 - v0);}// Точный метод, который гарантирует v = v1 при t = 1. Этот метод является монотонным только тогда, когда v0 * v1 <0. Перемещение между одинаковыми значениями может не дать одно и то же значение.плавать лерп(плавать v0, плавать v1, плавать т) {  вернуть (1 - т) * v0 + т * v1;}

Эта функция lerp обычно используется для альфа-смешение (параметр «t» - это «альфа-значение»), и формула может быть расширена для смешивания нескольких компонентов вектора (например, пространственных Икс, у, z топоры или р, г, б компоненты цвета) параллельно.

Смотрите также

использованная литература

  1. ^ Джозеф Нидхэм (1 января 1959 г.). Наука и цивилизация в Китае: Том 3, Математика и науки о небе и Земле. Издательство Кембриджского университета. С. 147–. ISBN  978-0-521-05801-8.

внешние ссылки