в математический поле числовой анализ, Алгоритм де Кастельжау это рекурсивный метод оценки многочленов в Форма Бернштейна или же Кривые Безье, названный в честь своего изобретателя Поль де Кастельжау. Алгоритм де Кастельжау также может использоваться для разделения одной кривой Безье на две кривые Безье при произвольном значении параметра.
Хотя алгоритм для большинства архитектур медленнее по сравнению с прямым подходом, он более эффективен. численно стабильный.
Определение
Кривая Безье B (степени п, с контрольными точками ) можно записать в форме Бернштейна следующим образом
- ,
куда б это Базисный многочлен Бернштейна
- .
Кривая в точке т0 можно оценить с помощью отношение повторения
Затем оценка в точке можно оценить в операции. Результат дан кем-то:
Кроме того, кривая Безье может быть разделен на точку на две кривые с соответствующими контрольными точками:
Пример реализации
Вот пример реализации алгоритма Де Кастельжау в Haskell:
DeCasteljau :: Двойной -> [(Двойной, Двойной)] -> (Двойной, Двойной)DeCasteljau т [б] = бDeCasteljau т Coefs = DeCasteljau т уменьшенный куда уменьшенный = zipWith (lerpP т) Coefs (хвост Coefs) lerpP т (x0, y0) (x1, y1) = (лерп т x0 x1, лерп т y0 y1) лерп т а б = т * б + (1 - т) * а
Примечания
При расчете вручную полезно записывать коэффициенты в схеме треугольника как
При выборе точки т0 чтобы вычислить полином Бернштейна, мы можем использовать две диагонали схемы треугольника, чтобы построить деление полинома
в
и
Пример
Мы хотим вычислить многочлен Бернштейна степени 2 с коэффициентами Бернштейна
в момент т0.
Начнем рекурсию с
и на второй итерации рекурсия останавливается на
который является ожидаемым многочленом Бернштейна степени2.
Кривая Безье
При оценке кривой Безье степени п в трехмерном пространстве с п+1 контрольная точка пя
с
- .
мы разбиваем кривую Безье на три отдельных уравнения
которые мы оцениваем индивидуально, используя алгоритм Де Кастельжау.
Геометрическая интерпретация
Геометрическая интерпретация алгоритма Де Кастельжау проста.
- Рассмотрим кривую Безье с контрольными точками . Соединяя последовательные точки, мы создаем контрольный многоугольник кривой.
- Теперь разделите каждый линейный сегмент этого многоугольника с соотношением и соедините полученные баллы. Таким образом, вы придете к новому многоугольнику, имеющему на один сегмент меньше.
- Повторяйте процесс, пока не дойдете до единственной точки - это точка кривой, соответствующая параметру. .
На следующем рисунке показан этот процесс для кубической кривой Безье:
Обратите внимание, что построенные промежуточные точки фактически являются контрольными точками для двух новых кривых Безье, обе точно совпадают со старой. Этот алгоритм не только оценивает кривую при , но разбивает кривую на две части при , и предоставляет уравнения двух кривых в форме Безье.
Приведенная выше интерпретация верна для нерациональной кривой Безье. Чтобы оценить рациональную кривую Безье в , мы можем спроецировать точку в ; например, кривая в трех измерениях может иметь свои контрольные точки и веса проецируется на взвешенные контрольные точки . Затем алгоритм действует как обычно, интерполируя в . Полученные четырехмерные точки можно спроецировать обратно в трехмерное пространство с помощью разделение перспективы.
В общем случае операции на рациональной кривой (или поверхности) эквивалентны операциям на нерациональной кривой в проективное пространство. Такое представление в виде «взвешенных контрольных точек» и весов часто удобно при оценке рациональных кривых.
Смотрите также
Рекомендации
- Фарин, Джеральд и Хансфорд, Дайанна (2000). Основы CAGD. Натик, Массачусетс: A K Peters, Ltd. ISBN 1-56881-123-3
внешняя ссылка