Задачи высшей математики с Maxima
3.6.2 Приближённое вычисление определённых интегралов
Степенные ряды эффективны и удобны при приближённом вычислении определённых интегралов, не выражающихся в конечном виде через элементарные функции. Для вычисления подинтегральная функция раскладывается в степенной ряд. Если
то при степенной ряд можно интегрировать почленно. Получаем метод вычисления интеграла с любой наперёд заданной точностьюПример: Приближённое вычисление интеграла вероятностей
Так как
тоПодставив этот ряд под знак интеграла и произведя почленное интегрирование получаем
Так как это знакопеременный ряд с последовательно убывающими слагаемыми, то погрешность вычисления интеграла последовательно убывает и не превышает последнего слагаемого.
Рассмотрим пример приближённого представления интеграла в виде полинома некоторой степени в том случае, когда он не вычисляется в замкнутой аналитической форме.
Пример: Вычислить , оценить достигнутую точность
Используем разложение подинтегральной функции в ряд. Подставляя в полученное выражение , вычисляем искомый интеграл. Так как исследуемый ряд знакопеременный, погрешность замены бесконечной суммы конечным выражением по абсолютной величине не превышает первого отброшенного члена.
(%i1) f(x):=exp(-x^2/2);
(%i2) taylor(f(x),x,0,8);
Интегрируя в пределах от 0 до 1, получаем числовой результат:
(%i3) integrate(%,x,0,1);
(%i4) float(%);
Точность расчёта оцениваем, интегрируя в пределах от 0 до :
(%i5) integrate(%o2,x,0,a);
При находим:
(%i6) expand(%);
(%i7) float(1/3456);
Таким образом, точность расчёта значения интеграла , не хуже 0,0003. Окончательно
3.7 Преобразование степенных рядов
Пакет Maxima позволяет не только строить разложение различных функций в степенные ряды, но и представления их в виде дробнорациональной функции (аппроксимация Паде) или цепной дроби.
Аппроксимацией Паде для функции , заданной степенным рядом, называется такая дробно-рациональная функция , чьё разложение в степенной ряд совпадает со степенным рядом с точностью до коэффициента при .
Паде-аппроксиммант задаётся значением функции в заданной точке и значениями её производных в этой же точке. Эта же информация может послужить основой для степенного ряда, так в чём же отличие? Главное отличие в том, что задав член степенного ряда, мы отбрасываем остальные члены ряда, приравнивая их к нулю. Паде-аппроксимант не является полиномом, поэтому задав членов разложения Паде-аппроксиманта в степенной ряд, мы в неявной форме задаём и остальные члены.
Чему эти дополнительные члены будут равны? Это вопрос, на который нет однозначного ответа. В одних случаях они позволят нам построить более точную аппроксимацию, в других — наоборот могут ухудшить положение. Нет способа, который позволил бы сказать, насколько точна окажется Паде-аппроксимация и в какой окрестности и с какой точностью можно получить результаты.
Ещё одним недостатком этого метода является то, что он требует информации не о значениях функции, а о её производных высших порядков, которые могут быть значительно большими по абсолютной величине, чем сами значения функции.
Паде-аппрокимация наиболее эффективна для функций, имеющих полюса на комплексной плоскости в окрестностях точки разложения. Например, функция непрерывна на действительной оси, но имеет полюса на комплексной плоскости. Поэтому она неэффективно аппроксимируется степенным рядом (до шестой степени включительно), но хорошо аппроксимируется по Паде со степенями числителя и знаменателя равными 4 и 2.
Функция , представленная в пакете Maxima, аппроксимирует отрезок ряда Тейлора, содержащий слагаемые до -го порядка включительно, дробно-рациональной функцией. Её аргументы — ряд Тейлора, порядок числителя n, порядок знаменателя . Разумеется, количество известных коэффициентов ряда Тейлора должно совпадать с общим количеством коэффициентов в дробно-рациональной функции минус один, поскольку числитель и знаменатель определены с точностью до общего множителя.
Синтаксис вызова функции :
pade (ряд Тейлора, степень числителя, степень знаменателя)
Вместо ряда Тейлора может использоваться ряд Лорана. В этом случае степени числителя и знаменателя могут быть и бесконечными (). В этом случае рассматриваются все рациональные функции, суммарная степень которых меньше или равна длине степенного ряда.
Пример:
(%i1) t:taylor(exp(x),x,0,3);
(%i2) pade(t,1,2);
(%i3) taylor(sin(x)/x,x,0,7);
(%i4) pade(%,2,4);
(%i5) taylor (1/(cos(x) - sec(x))^3, x, 0, 5);
(%i6) pade(%,3,inf);
Более специфичной является функция , которая рассчитывает коэффициенты цепной дроби, аппроксимирующей заданное выражение. Синтаксис вызова — . Выражение должно состоять из целых чисел, квадратных корней целых чисел и знаков арифметических операций. Функция возвращает список коэффициентов (непрерывная дробь представляется списком []). Флаг определяет количество периодов цепной дроби. Изначально установлено значение 1. Функция преобразует список (как правило выдачу функции ) в собственно цепную дробь вида ).
Примеры использования функций и :
(%i1) cf ([1, 2, -3] + [1, -2, 1]);
(%i2) cfdisrep (%);
(%i3) cflength: 3;
(%i4) cf (sqrt (3));
(%i5) cfdisrep(%);
(%i6) ev (%, numer);