Основы Maxima
2.7.4 Математические функции
В Maxima имеется достаточно большой набор встроенных математических функций. Перечень основных классов встроенных функций приведён ниже:
- тригонометрические функции: (синус), (косинус), (тангенс), (котангенс);
- обратные тригонометрические функции: (арксинус), (арккосинус), (арктангенс), (арккотангенс);
- (секанс, , (косеканс, );
- (гиперболический синус), (гиперболический косинус), (гиперболический тангенс), (гиперболический котангенс), (гиперболический секанс), (гиперболический косеканс);
- (натуральный логарифм);
- (квадратный корень);
- (остаток от деления);
- (модуль);
- и — нахождение минимального и максимального значения в списке аргументов;
- (определяет знак аргумента: — положительный, — отрицательный, — не определён, — значение равно нулю);
- Специальные функции — функции Бесселя, гамма-функция, гипергеометрическая функция и др.;
- Эллиптические функции различных типов.
2.7.5 Вычисление и преобразование аналитических выражений
Функция ev является основной функцией, обрабатывающей выражения. Синтаксис вызова:
Функция вычисляет выражение expr в окружении, определяемом аргументами . Аргументы могут быть ключами (булевскими флагами, присваиваниями, уравнениями и функциями. Функция ev возвращает результат (другое выражение).
Во многих случаях можно опускать имя функции (т.е. применять значения переменных к некоторому выражению)
На выражение expr по умолчанию действует функция упрощения. Необходимость выполнения упрощения регулируется флагом (если установить , упрощение будет отключено). Кроме того, используют флаги и , определяющие формат представления рациональных чисел (в виде дробей или с плавающей точкой) и результатов вычисления математических функций. Флаг определяет необходимость вычисления применительно к логическим выражениям.
Аргументами могут быть и встроенные функции, выполняющие упрощение или преобразование выражений () или функция .
Если указаны подстановки (в виде или ), то они выполняются.
При этом повторный вызов функции вполне способен ещё раз изменить выражение, т.е. обработка выражения не идёт до конца при однократном вызове функции .
Пример:
(%i1) ev((a+b)^2,expand);
(%i2) ev((a+b)^2,a=x);
(%i3) ev((a+b)^2,a=x,expand,b=7)
Другой пример показывает применение к отложенному вычислению производной:
(%i1) sin(x) + cos(y) + (w+1)^2 + 'diff (sin(w), w);
(%i2) ev (%, sin, expand, diff, x=2, y=1);
Флаг разрешает либо запрещает упрощение выражений. Изначально он равен , если установить его равным , то упрощения производиться не будут:
(%i1) f:a+2*a+3*a+4*a;
(%i2) simp:false;
(%i3) f:a+2*a+3*a+4*a;
Функцию ev не обязательно указывать явно, например:
(%i3) x+y, x: a+y, y: 2;
Оператор, принудительного вычисления, обозначенный двумя апострофами, является синонимом к функции (выражение). Сама функция предоставляет гораздо более широкие возможности, нежели простое принудительное вычисление заданного выражения: она может принимать произвольное число аргументов, первый из которых — вычисляемое выражение, а остальные — специальные опции, которые как раз и влияют на то, как именно будет производиться вычисление.
В терминологии Maxima невычисленная форма выражения называется "noun form", вычисленная — "verb form". Сохраняя лингвистические параллели, на русский это можно перевести как "несовершенная форма" и "совершённая форма". Значение вводимого выражения в Maxima закономерно сохраняется до его вычисления (т. е. в несовершенной форме), а значение выводимого выражения — после (т. е. в совершённой); другими словами, тут имеется естественный порядок "ввод — вычисление — вывод".
Функция факторизует (т.е. представляет в виде произведения некоторых сомножителей) заданное выражение (функция — аналогично, но на множестве комплексных чисел и выражений).
Пример:
(%i1) x^3-1,factor;
(%i2) factor(x^3-1);
Ещё примеры факторизации различных выражений:
(%i3) factor (-8*y - 4*x + z^2*(2*y + x));
(%i4) factor (2^63 - 1);
(%i5) factor (1 + %e^(3*x));
Пример использования функции :
(%i6) gfactor(x^2+a^2);
(%i7) gfactor(x^2+2*%i*x*a-a^2);
Функция факторизует отдельные слагаемые в выражении.
(%i8) expand ((x + 1)*((u + v)^2 + a*(w + z)^2));
(%i9) factorsum(%);
Функция отличается от тем же, чем отличается от :
(%i10) gfactorsum( a^3+3*a^2*b+3*a*b^2+b^3+x^2+2*%i*x*y-y^2 );
Функция раскрывает скобки, выполняет умножение, возведение в степень, например:
(%i1) expand((x-a)^3);
(%i2) expand((x-a)*(y-b)*(z-c));
(%i3) expand((x-a)*(y-b)^2);
Функция объединяет слагаемые с идентичным знаменателем
(%i5) combine(x/(1+x^2)+y/(1+x^2));
Функция приводит выражение к общему знаменателю, не раскрывая скобок и не пытаясь факторизовать слагаемые
(%i6) xthru( 1/(x+y)^10+1/(x+y)^12 );
(%i1) ((x+2)^20 - 2*y)/(x+y)^20 + (x+y)^(-19) - x/(x+y)^20;
(%i2) xthru (%);
Функция умножает каждое слагаемое в сумме на множитель, причём при умножении скобки в выражении не раскрываются. Она допускает два варианта синтаксиса:
В последнем случае выражение expr включает и множитель и сумму (см. (%i4) в примере ниже).
Пример:
(%i1) x/(x-y)^2 - 1/(x-y) - f(x)/(x-y)^3;
(%i2) multthru ((x-y)^3, %);
(%i3) ((a+b)^10*s^2 + 2*a*b*s + (a*b)^2)/(a*b*s^2);
(%i4) multthru (%);
Функции assume (ввод ограничений) и (снятие ограничений) позволяют управлять условиями выполнения (контекстом) прочих функций и операторов.
Пример:
(%i20) sqrt(х^2); (%o20) |x| (%i21) assume (x<0); (%o21) [ x< 0 ] (%i22) sqrt(х^2); (%o22) -x (%i23) forget(x<0); (%o23) [ x< 0 ] (%i24) sqrt (х^2) ; (%o24) |x|
Функция позволяет вычислить частное и остаток от деления одного многочлена на другой:
(%i1) divide(x^3-2,x-1);
Первый элемент полученного списка — частное, второй — остаток от деления.
Функция позволяет найти наибольший общий делитель многочленов.
Подстановки осуществляются функцией . Вызов этой функции: (подставляем вместо в выражении ).
Пример:
(%i1) subst (a, x+y, x + (x+y)^2 + y);