WikiDer > Квадратура Кленшоу – Кертиса

Clenshaw–Curtis quadrature

Квадратура Кленшоу – Кертиса и Квадратура Фейера методы для численное интегрирование, или "квадратура", основанная на расширении интегрировать с точки зрения Полиномы Чебышева. В равной степени они используют замена переменных и использовать дискретное косинусное преобразование (DCT) приближение для косинусный ряд. Помимо того, что точность быстрого схождения сопоставима с Квадратура Гаусса правил, квадратура Кленшоу – Кертиса естественным образом приводит к вложенные квадратурные правила (где разные порядки точности разделяют баллы), что важно для обоих адаптивная квадратура и многомерная квадратура (кубатура).

Вкратце, функция подлежащих интеграции оценивается на экстремумов или корней полинома Чебышева, и эти значения используются для построения полиномиального приближения для функции. Затем этот многочлен точно интегрируется. На практике веса интегрирования для значения функции в каждом узле предварительно вычисляются, и это вычисление может быть выполнено в время с помощью быстрое преобразование Фурье-связанные алгоритмы для DCT.[1][2]

Общий метод

Простой способ понять алгоритм - понять, что квадратура Кленшоу – Кертиса (предложенная этими авторами в 1960 г.)[3] сводится к интеграции через изменение переменной Икс = cos (θ). Алгоритм обычно выражается для интегрирования функции ж(Икс) на интервале [-1,1] (любой другой интервал может быть получен соответствующим изменением масштаба). Для этого интеграла можно написать:

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

в этом случае интеграл становится:

Конечно, для вычисления коэффициентов косинусного ряда

нужно снова выполнить числовое интегрирование, поэтому сначала может показаться, что это не упростило задачу. Однако, в отличие от вычисления произвольных интегралов, интегрирование ряда Фурье для периодические функции (подобно , по построению), до Частота Найквиста , точно вычисляются точки на равном расстоянии друг от друга и с одинаковым весом за (за исключением того, что конечные точки имеют вес 1/2, чтобы избежать двойного счета, что эквивалентно трапеция или Формула Эйлера – Маклорена).[4][5] То есть мы аппроксимируем интеграл косинус-ряда величиной типа I дискретное косинусное преобразование (DCT):

за а затем используйте приведенную выше формулу для интеграла через эти . Потому что только необходимо, формула далее упрощается до DCT типа I порядка N/ 2, полагая N является четное число:

Из этой формулы ясно, что квадратурное правило Кленшоу – Кертиса является симметричным в том смысле, что оно весит ж(Икс) и ж(−Икс) на равных.

Потому что сглаживание, вычисляются только коэффициенты вплоть до k=N/ 2, поскольку дискретная выборка функции делает частоту 2k неотличимый от N–2k. Эквивалентно - амплитуды уникальных ограниченный диапазон тригонометрический интерполяционный полином проходя через N+1 балл, где ж(потому что θ) вычисляется, и мы приближаем интеграл интегралом от этого интерполяционного полинома. Есть некоторая тонкость в том, как обращаться с коэффициент в интеграле, однако - чтобы избежать двойного счета с его псевдонимом, он включен с весом 1/2 в окончательный приближенный интеграл (что также можно увидеть, исследуя интерполирующий полином):

Связь с многочленами Чебышева

Причина, по которой это связано с полиномами Чебышева по определению , поэтому приведенный выше ряд косинусов на самом деле является приближением по полиномам Чебышева:

и таким образом мы "действительно" интегрируем интегрируя его приближенное разложение по многочленам Чебышева. Очки оценки соответствуют экстремумы полинома Чебышева .

То, что такое Чебышевское приближение просто косинусный ряд при замене переменных отвечает за быструю сходимость приближения по мере увеличения числа членов включены. Ряд косинусов сходится очень быстро для функций, которые четное, периодический и достаточно гладкий. Это верно здесь, поскольку четный и периодический в по конструкции, и является k-кратно дифференцируемые везде, если является k-раз дифференцируемые на . (Напротив, прямое применение разложения в ряд косинусов к вместо обычно будет нет сходятся быстро, потому что наклон четно-периодического расширения, как правило, будет разрывным.)

Квадратура Фейера

Фейер предложил два квадратурных правила, очень похожих на квадратуру Кленшоу – Кертиса, но намного раньше (в 1933 г.).[6]

Из этих двух "второе" квадратурное правило Фейера почти идентично правилу Кленшоу-Кертиса. Единственная разница в том, что конечные точки и установлены на ноль. То есть Фейер использовал только интерьер экстремумов полиномов Чебышева, т.е. истинных стационарных точек.

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

что и есть DCT типа II. Однако первое квадратурное правило Фейера не вложено: баллы оценки для 2N не совпадают ни с одним из пунктов оценки для Nв отличие от квадратуры Кленшоу – Кертиса или второго правила Фейера.

Несмотря на то, что Фейер открыл эти техники до Кленшоу и Кертиса, название «квадратура Кленшоу – Кертиса» стало общепринятым.

Сравнение с квадратурой Гаусса

Классический метод Квадратура Гаусса оценивает подынтегральное выражение в точек и построен на точно интегрировать многочлены с точностью до степень . Напротив, квадратура Кленшоу – Кертиса, приведенная выше, оценивает подынтегральное выражение при точек и точно интегрирует многочлены только до степени . Таким образом, может показаться, что Кленшоу – Кертис по своей природе хуже, чем гауссова квадратура, но на самом деле это не так.

На практике несколько авторов заметили, что точность Кленшоу – Кертиса может быть сопоставима с точностью квадратуры Гаусса для того же числа точек. Это возможно, потому что большинство числовых интегрантов не являются полиномами (особенно потому, что полиномы можно интегрировать аналитически), а приближение многих функций в терминах полиномов Чебышева быстро сходится (см. Чебышевское приближение). Фактически, недавние теоретические результаты[7] утверждают, что и квадратуры Гаусса, и Кленшоу – Кертиса имеют ошибку, ограниченную для k-кратно дифференцируемое подынтегральное выражение.

Одним из часто упоминаемых преимуществ квадратур Кленшоу – Кертиса является то, что квадратурные веса могут быть вычислены в время по быстрое преобразование Фурье алгоритмы (или их аналоги для DCT), тогда как большинство алгоритмов для квадратурных весов Гаусса требовали время вычислить. Однако недавние алгоритмы достигли сложность для квадратур Гаусса – Лежандра.[8] На практике численное интегрирование высокого порядка редко выполняется путем простого вычисления квадратурной формулы для очень больших . Вместо этого обычно используют адаптивная квадратура Схема, которая сначала оценивает интеграл до низкого порядка, а затем последовательно улучшает точность, увеличивая количество точек выборки, возможно, только в областях, где интеграл неточен. Чтобы оценить точность квадратуры, нужно сравнить ответ с ответом квадратурного правила еще более низкого порядка. В идеале это квадратурное правило низшего порядка оценивает подынтегральное выражение при подмножество оригинала N точек, чтобы свести к минимуму оценки подынтегральной функции. Это называется вложенное квадратурное правило, и здесь Кленшоу – Кертис имеет то преимущество, что правило порядка N использует подмножество точек из порядка 2N. Напротив, квадратурные правила Гаусса не являются естественными вложенными, поэтому необходимо использовать Квадратурные формулы Гаусса – Кронрода. или аналогичные методы. Вложенные правила также важны для разреженные сетки в многомерной квадратуре, и квадратура Кленшоу – Кертиса является популярным методом в этом контексте.[9]

Интеграция с весовыми функциями

В более общем плане можно поставить задачу интегрирования произвольного против фиксированного весовая функция что известно заранее:

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

Квадратуру Кленшоу – Кертиса можно обобщить на этот случай следующим образом. Как и прежде, он работает, находя разложение в ряд косинусов через DCT, а затем интегрировать каждый член в ряд косинусов. Однако теперь эти интегралы имеют вид

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

Например, были разработаны специальные методы применения квадратуры Кленшоу – Кертиса к подынтегральным выражениям вида с весовой функцией это сильно колеблется, например а синусоида или же Функция Бесселя (см., например, Evans & Webster, 1999[10]). Это полезно для высокой точности Ряд Фурье и Ряд Фурье – Бесселя вычисление, где просто квадратурные методы проблематичны из-за высокой точности, необходимой для определения вклада быстрых колебаний. Здесь быстроосциллирующая часть подынтегрального выражения учтена специальными методами для , а неизвестная функция обычно ведет себя лучше.

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

Обратите внимание, что Квадратура Гаусса также могут быть адаптированы для различных весовых функций, но техника несколько отличается. В квадратуре Кленшоу – Кертиса подынтегральное выражение всегда вычисляется в одном и том же наборе точек независимо от , соответствующие экстремумам или корням полинома Чебышева. В квадратуре Гаусса разные весовые функции приводят к разным ортогональные многочлены, и, следовательно, разные корни, в которых вычисляется подынтегральное выражение.

Интегрирование на бесконечных и полубесконечных интервалах

Также можно использовать квадратуру Кленшоу – Кертиса для вычисления интегралов вида и , используя технику переназначения координат.[11] Высокая точность, даже экспоненциальная сходимость для гладких подынтегральных выражений, может сохраняться до тех пор, пока распадается достаточно быстро, поскольку |Икс| приближается к бесконечности.

Одна из возможностей - использовать универсальное преобразование координат, такое как Икс=т/(1−т2)

для преобразования бесконечного или полубесконечного интервала в конечный, как описано в Численное интегрирование. Существуют также дополнительные методы, разработанные специально для квадратур Кленшоу – Кертиса.

Например, можно использовать переназначение координат , куда L - константа, заданная пользователем (можно просто использовать L= 1; оптимальный выбор L может ускорить сходимость, но зависит от проблемы[11]), чтобы преобразовать полубесконечный интеграл к виду:

Коэффициент, умножающий sin (θ), ж(...)/(...)2, затем можно разложить в косинусный ряд (приблизительно, используя дискретное косинусное преобразование) и интегрировать почленно, точно так же, как это было сделано для ж(cos θ) выше. Чтобы устранить сингулярность при θ = 0 в этом подынтегральном выражении, достаточно просто, чтобы ж(Икс) стремятся к нулю достаточно быстро при Икс приближается к бесконечности, и в частности ж(Икс) должен распадаться по крайней мере так быстро, как 1 /Икс3/2.[11]

Для вдвойне бесконечного интервала интегрирования можно использовать переотображение координат (куда L - указанная пользователем константа, как указано выше), чтобы преобразовать интеграл в:[11]

В этом случае мы использовали тот факт, что подынтегральное выражение ж(L cotθ) / грех2(θ) уже является периодическим, поэтому его можно напрямую интегрировать с высокой (даже экспоненциальной) точностью, используя правило трапеций (при условии, что ж достаточно гладкий и быстро затухающий); нет необходимости вычислять ряд косинусов в качестве промежуточного шага. Обратите внимание, что квадратурное правило не включает конечные точки, где мы предположили, что подынтегральная функция стремится к нулю. Формула выше требует, чтобы ж(Икс) распадаются быстрее, чем 1 /Икс2 в качестве Икс переходит в ± ∞. (Если ж распадается точно как 1 /Икс2, то подынтегральное выражение переходит к конечному значению в конечных точках, и эти пределы должны быть включены как члены конечной точки в правило трапеций.[11]). Однако если ж затухает только полиномиально быстро, тогда может потребоваться использовать следующий шаг квадратур Кленшоу-Кертиса, чтобы получить экспоненциальную точность переназначенного интеграла вместо правила трапеции, в зависимости от более подробной информации о предельных свойствах ж: проблема в том, что хотя ж(L cotθ) / грех2(θ) действительно периодичен с периодом π, он не обязательно будет гладким на концах, если все производные там не обращаются в нуль [например, функция ж(Икс) = tanh (Икс3)/Икс3 распадается как 1 /Икс3 но имеет скачкообразный скачок в наклоне переотображенной функции при θ = 0 и π].

Другой подход к переотображению координат был предложен для интегралов вида , в этом случае можно использовать преобразование преобразовать интеграл к виду куда , после чего можно аналогично перейти к квадратуре Кленшоу – Кертиса для ж как указано выше.[12] Однако из-за особенностей конечных точек в этом преобразовании координат используется первое квадратурное правило Фейера [которое не оценивает ж(−1)] если грамм(∞) конечно.

Предварительное вычисление квадратурных весов

На практике выполнять DCT значений выборочной функции неудобно. ж(cosθ) для каждого нового подынтегрального выражения. Вместо этого обычно предварительно вычисляют квадратурные веса (за п от 0 до N/ 2, полагая N четное) так что

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

куда D - матричная форма функции (N/ 2 + 1) -точка DCT типа I сверху, с записями (для с нуля индексы):

и является

Как обсуждалось выше, из-за сглаживание, нет смысла вычислять коэффициенты за пределами , так D является матрица. По этим коэффициентам c, интеграл приблизительно равен:

сверху, где c - вектор коэффициентов выше и d - вектор интегралов для каждого коэффициента Фурье:

(Обратите внимание, однако, что эти весовые коэффициенты изменяются при изменении матрицы DCT D использовать другое соглашение о нормализации. Например, DCT типа I обычно определяют с дополнительными коэффициентами 2 или 2 факторов в первой и последней строках или столбцах, что приводит к соответствующим изменениям в d записи.) суммирование может быть преобразовано в:

куда ш вектор желаемых весов выше, с:

Поскольку транспонированный матрица также является DCT (например, транспонирование DCT типа I является DCT типа I, возможно, с немного другой нормализацией в зависимости от используемых соглашений), квадратурные веса ш можно предварительно вычислить в О(N бревноN) время для данного N с использованием быстрых алгоритмов DCT.

Веса положительны и их сумма равна единице.[13]

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

Рекомендации

  1. ^ У. Морвен Джентльмен, «Реализация квадратуры Кленшоу-Кертиса I: методология и опыт», Коммуникации ACM 15(5), стр. 337-342 (1972).
  2. ^ Йорг Вальдфогель "Быстрое построение квадратурных правил Фейера и Кленшоу-Кертиса," BIT вычислительная математика 46 (1), стр. 195-202 (2006).
  3. ^ К. В. Кленшоу и А. Р. Кертис "Метод численного интегрирования на автомате. Numerische Mathematik 2, 197 (1960).
  4. ^ Дж. П. Бойд, Чебычев и спектральные методы Фурье., 2-е изд. (Довер, Нью-Йорк, 2001).
  5. ^ См., Например, S. G. Johnson, "Замечания о сходимости квадратуры по правилу трапеций, "заметки к онлайн-курсу MIT (2008 г.).
  6. ^ Леопольд Фейер "О бесконечных последовательностях, возникающих в теориях гармонического анализа, интерполяции и механических квадратур", Бюллетень Американского математического общества 39 (1933), стр. 521–534. Леопольд Фейер "Mechanische Quadraturen mit Positiven Cotesschen Zahlen, Mathematische Zeitschrift 37 , 287 (1933).
  7. ^ Трефетен, Ллойд Н. (2008). «Квадратура Гаусса лучше, чем Кленшоу-Кертис?». SIAM Обзор. 50 (1): 67–87. CiteSeerX 10.1.1.157.4174. Дои:10.1137/060659831.
  8. ^ Игнас Богерт, Без итерационное вычисление узлов и весов квадратур Гаусса - Лежандра, SIAM Journal on Scientific Computing vol. 36, стр. A1008 – A1026 (2014)
  9. ^ Эрих Новак и Клаус Риттер, «Интегрирование гладких функций над кубами высокой размерности», Numerische Mathematik т. 75С. 79–97 (1996).
  10. ^ Дж. А. Эванс и Дж. Р. Вебстер, "Сравнение некоторых методов оценки сильно колеблющихся интегралов", Журнал вычислительной и прикладной математики, т. 112, п. 55-69 (1999).
  11. ^ а б c d е Джон П. Бойд, "Экспоненциально сходящийся Фурье – Чебшев [sic] квадратурные схемы на ограниченных и бесконечных интервалах », J. Научные вычисления 2 (2), стр. 99-109 (1987).
  12. ^ Нирмал Кумар Басу и Мадхав Чандра Кунду, «Некоторые методы численного интегрирования на полубесконечном интервале», Приложения математики 22 (4), стр. 237-243 (1977).
  13. ^ Дж. П. Имхоф, "О методе численного интегрирования Кленшоу и Кертиса", Numerische Mathematik 5, п. 138-141 (1963).