Работа с выражениями
Одним из важнейших понятий системы Mathematica является математическое выражение, или просто выражение — ехрг (от английского слова expression). Работа с математическими выражениями в символьном виде — основа основ символьной математики.
Выражение может быть представлено в общепринятом виде (как математическая формула или ее часть) с помощью операторов, например, а* (х + у + z) или х ^ у, оно может задавать и некоторую функцию f [х, у,...] или их комбинацию. Наряду с такой формой существует так называемая полная форма представления выражений, при которой основные арифметические операции задаются не операторами, а только соответствующими функциями. Ее примеры даны ниже.
Выражение ехрг |
Полная форма ехрг |
Комментарий |
х + у + z |
Plus [х, у, z] |
Сложение |
х у z |
Times [x, у, z] |
Умножение |
х^n |
Power [x,n] |
Возведение в степень |
{a,b,c} |
List [a,b, c] |
Создание списка |
a->b |
Rule [a,b] |
Подстановка |
a=b |
Set [a,b] |
Присваивание |
1+х^2+(у+г)^2+2 3 + х2 + (y+z)2 FullForm[%] Plus[3, Power[x, 2], Power[Plus[у, z] , 2]] Integrate[a*Sin[b*x]*Exp[-c*x],x] a [(be-cxCos[bx])/{-ib + c) (ib + c)-( ce+cxSin[bx]) \(-ib + c) (ib + c) ] FullForm[%] Times[a, Plus[Times[-1, b, Power[Plus[Times[Complex[0, -1], b], c] , -1], Power[Plus[Times[Complex[0, 1], b], c] , -1], Power[E, Times[-l, c, x] ] , Cos[Times[b, x] ] ] , Times[-1, c, Power[Plus[Times[Complex[0, -1], b] , c], -1] , Power[Plus[Times[Complex[0, 1] , b], c] , -1] , Power[E, Times[-1, c, x] ] , Sin[Times[b, x]]]]]Для определения типа выражения служит функция Head [ехрr ]. Применительно к числовым выражениям она возвращает тип результата, как показано в приводимых ниже примерах.
Ввод (In) |
Вывод (Out) |
1+2+3 | 6 |
Head[%] | Integer |
Head[123/12345] | Rational |
Head[2*0.25] | Real |
{Head[l + 2], Head[аЬ] , Head[ 5/7], Headfl + 3i], Head[e2]} {Integer, Times, Rational, Complex, Power} Head/@{l, 1/3, 2.1, 2 + 3i, x, f [x] , {1, 2, 3}, a+b, a/b} {Integer, Rational, Real, Complex, Symbol, f, List, Plus, Times}Обратите внимание на второй пример — в нем функция Head применяется к каждому выражению списка, что дает более компактную запись.
Основные формы записи выражений
Возможны четыре основные формы записи выражений: f [х, у] — стандартная форма для f [х, у]; f @ х — префиксная форма для f [ х ]; х / / f — постфиксная форма для f [ х ]; х ~ f ~ у — инфиксная форма для f [ х, у ]. Далее приведены примеры применения этих форм.
Ввод (In) |
Вывод (Out) |
F[x_] = 2*х^2 |
2X 2 |
F[a] |
2a 2 |
a//F |
2 a 2 |
f [x_, y_] = х^ 2 + у^2 |
y 2 +x 2 |
f[a,b] |
a 2 +b 2 |
a-f-b |
a 2 + b 2 |
Части выражений и работа с ними
Сложные выражения состоят из частей, которые могут интерпретироваться различным образом.
Тип части |
Зависимость |
Пример |
Function |
От аргументов или параметров |
Ехр[х], f [х,у] |
Command |
От аргументов или параметров |
Expand [ (х-1) ^2] |
Operator |
От операндов |
x + y+z, a = b |
Head |
От элементов |
{a,b,c} |
Object type |
От контекста |
RGBColor [r,g,b] |
Ввод (In) |
Вывод (Out) |
f :=а + b*х^2 + с*х^3 | |
Part[f, 3] |
ex 3 |
Part[f, 2] | bx 2 |
f[[1]] |
a |
f[[3]] |
ex 3 |
f[[-1]] |
ex 3 |
f[x_] := % + 2 хВывода здесь нет. Продолжим наш эксперимент: 1 + у^2
1 + y2 g[х_] = % + 2 х 1 + 2 х + у2Теперь вывод есть, так как % (ссылка на предыдущий результат) определена в виде выражения 1 + у^2 и при задании [х_] использован оператор немедленного присваивания. Далее:
2 + z 2 + z {f[a],g[a]> {2 + 2a+z, 1 + 2 а + у2}Следующие функции возвращают особые части выражения: Denominator [expr] — возвращает знаменатель выражения ехрг; First[expr] — возвращает первый элемент из ехрг; Last[expr] — возвращает последний элемент из ехрг; Rest [expr] — возвращает ехрг с удаленным первым элементом. Ниже приводятся примеры применения этих функций.
Ввод (In) |
Вывод (Out) |
Denominator [ (х + 1) / (х ^ 2 + 2*х + 3) ] |
3+ 2х+ х^2 |
ехрг = а * b + с - d |
ab+ с- d |
First [expr] |
ab |
Last [expr] |
-d |
Rest [expr] |
c-d |
Ввод (In) |
Вывод (Out) |
ехрr = а * b + с - d |
ab + с - d |
Delete [expr, 1] |
c-d |
Delete [expr, 3] |
ab+ с |
Delete [expr, {{!}, {3}}] |
с |
DeleteCases [expr, а*b] |
c-d |
DeleteCases [expr, с, 1] |
ab-d |
Другие манипуляции с выражениями
В процессе преобразования выражений с ними возможны и иные манипуляции. Наиболее важные из них выполняются следующими функциями: Append [expr, elem] — возвращает ехрг с дополнением elem; AppendTo [s, elem] — добавляет elem к значению s и присваивает s новое значение; Apply [f, expr, levelspec] — возвращает ехрг, замещая заголовки в тех частях ехрг, которые указаны спецификацией уровня levelspec; Cancel [expr] — возвращает ехрг с сокращением общих множителей числителя и знаменателя; Cases [expr, pattern, levelspec] — возвращает список всех частей выражения expr на уровнях, указанных спецификацией levelspec, которые соответствуют шаблону pattern; Chop [expr] — присваивает значение 0 тем приближенным вещественным числам в выражении expr, абсолютные величины которых меньше 10 -10 ; Chop [expr, tol ] — присваивает значение 0 тем приближенным вещественным числам в выражении expr, абсолютные величины которых меньше tol; Replace [expr, rules] — возвращает expr с подстановкой, заданной правилом или списком правил rules; ReplaceAll — используется в виде expr /. rules и возвращает expr с подстановками, заданными правилом или списком правил rules; ReplacePart [expr, new, n] — возвращает выражение, в котором п-я часть expr заменена на new; ReplacePart [expr, new, {i, j,...}] — заменяет на new часть в позиции {i, j,...}; ReplacePart [expr, new, {{il, jl,...}, {i2, j 2 ,...},...}] — заменяет на new части в нескольких позициях выражения; ReplaceRepeated — применяется в виде expr //. rules и неоднократно выполняет замещения до тех пор, пока expr не перестанет изменяться. Действие этих функций достаточно очевидно и поясняется следующими примерами.
Ввод (In) |
Вывод (Out) |
Append [a + с, b] |
a+ b+ с |
х = {а, b, с} |
{a, b, c} |
AppendTo [ х , 15 ] |
{a, b, c, 15} |
x |
{a, b, c, 15} |
Apply[f, а А 2 + b ^ 2, 2] |
f[a, 2] +f[b, 2] |
Cancel [(z-1) ^ 2/ (z - 1) ] |
-1 + Z |
Cases[{a, 3.5, 2, 5, "HELLO"}, _Integer] |
{2, 5} |
Exp[N[-лI]] |
-1. - 1. 22461 x 10 -16 I |
Chop[%] |
-1. |
Ехр[N[-лI]] |
-1. - 1. 22461 x10 16 I |
Chop[%, 1*10^-10] |
-1. |
Replace[s ^ 2, s ^ 2 -> a] |
a |
s^2 /. s -> a |
a 2 |
Ввод (In) |
Вывод (Out) |
AtomQ [{a |
False |
AtomQ[2+3/4] |
True |
AtomQ [Sin] |
True |
FreeQ[a*x^b,a] |
False |
FreeQ [ a*x ^ b+c , 1 ] |
True |
FreeQ [a*x^b+c, 1,1] |
True |
FreeQ[a*x^b+c,b,2]}] |
True |
Приложение имени функции к выражению или его части
Функции в системе Mathematica характеризуются именем (обобщенно — f) и выражением ехрг, задающим функциональную зависимость. Обычно функция в ответ на обращение к ней возвращает значение выражения — численное или символьное. Однако в системе Mathematica понятие функции значительно расширено, и она может возвращать любой объект, в том числе графический или звуковой. Можно сказать, что входной язык общения с системой Mathematica основан на принципах функционального программирования с применением полных форм представления выражений. Следующие функции позволяют прикладывать имя функции к выражению или к частям выражения: Apply [f, expr] — замещает заголовок выражения ехрг на f; Nest [f, expr, n] — возвращает выражение, полученное и-кратным применением f к ехрг; Map [f, expr] — применяет f к каждому элементу на первом уровне в ехрr; Map[f, expr, levelspec] — применяет f к частям ехрг, указанным с помощью levelspec; MapAll [f, expr] — применяет f ко всем частям выражения ехрг. Приведем примеры действия этих функций.
Ввод (In) |
Вывод (Out) |
Apply [f, {a, b, x}] |
f [a, b, x] |
Nest[f , x, 3] |
f[f[f[x]]] |
s[x_, y_, z_] := x + y + b |
|
N[Apply[s, {1, 2, a}]] |
3. + b |
Map[f, {а, Ь, с}] |
{f[a], f[b], f[c]} |
MapAll [f, a*x + b] |
f[f[b] + f[f[a] f[x]]] |
MapAll [f, {а, Ь, с}] |
f[{f[a], f[b] , f[c]}] |
Из описания указанных функций вытекает, что они наряду с полной формой могут задаваться укороченной формой.
Укороченная форма | Полная форма |
f @ ехрг | f [expr] |
f @@ ехрг | Apply [f, expr] |
f /@ ехрг | Map[f, expr] |
f //@ ехрг | MapAll [f, expr] |
Ввод (In) |
Вывод (Out) |
f@{a, b, с} | f[{a, b, c}] |
f@@{a, b, c} | f [a, b, c] |
f /@{a, b, c} | {f[a], f[b], f[c]} |
f//@{a, b, x} | f[{f[a], f[b], f[x]}] |
Выделения и подстановки в функциях
Функция Slot[n], или, в укороченной форме, #n, представляет n-й аргумент функции. Это иллюстрируют следующие примеры.
Ввод (In) |
Вывод (Out) |
(5* Slot [1] + Slot [2] *Slot[3] A 2) &[a, b, с] |
5a+bc 2 |
#1 A #2 S[a, b] | a b |
Ввод (In) |
Вывод (Out) |
(Times[5, ##2] +Times[##2, ##3 A 2]) &[а, b, с] |
Sbobc 3 |
Ввод (In) |
Вывод (Out) |
f[x] =u |
u |
f[x] +f[y] |
u+f ty] |
f [x_] = х^2 |
x 2 |
f[x] +f[y] |
u+y 2 |
Clear [f] |
|
f[x]+f[y] |
f [x] + f [y] |
Операция |
Комментарий |
fact[n_] :=n*fact[n-l] |
Задана рекурсивная функция факториала |
fact[l]=l |
Выполнена инициализация функции |
1 |
|
fact[3] |
Вычислено значение 3! |
6 |
|
fact[10] |
Вычислено значение 10! |
3628800 |
|
?fact[l] |
Выполнена проверка определения функции |
Global ' fact |
|
fact[l] = 1 |
|
fact[n_] :=nfact[n-l] |
Дополнительные примеры работы с функциями
Приведем еще ряд примеров действия функций Apply, Map и Nest.
Ввод (In) |
Вывод (Out) |
Nest[f ,x,3] |
f [f[f [X]]] |
Apply[f,{a,b,c}] |
f[a, b, c] |
s [x_,y_, z_] : =х+у+b |
|
N[Apply[s,{l,2,a}]] |
3. + b |
Map[f,{a,b,c}] |
{f [a], f [b], f [c] } |
N[Map[Exp, {1,2,3}]] |
{2.71828, 7.38906, 20.0855} |
Map[f ,1+2+c] |
f[3] + f[c] |
m={{a,b},{c,d}} |
{{a, b}, {c, d}} |
Map[f,m] |
{f [{a, b}], f [{c, d}] } |
take2[list_] :=Take[list,2] |
|
Map[take2,{{a,b,c},{c,a,b),{c,c,a}}] |
{{a, b}, {c, a}, {c, c}} |
Большинство описанных операций для работы с функциями могут использоваться и при работе со списками. Порой это резко упрощает запись алгоритмов вы-числений для данных, представленных списками, поскольку дает общее определение функций для произвольного числа их параметров. Примерами могут служить определения следующих статистических функций.
Вычисление среднего для элементов списка:Mean[list_] := Apply[Plus, list] / Length[list] /; VectorQ[list] && Length[list] > 0 General: :spell! : Possible spelling error: new symbol name "list" is similar to existing symbol "List".Вычисление среднего геометрического для списка:
GeometricMean[list_] : = Apply [Times, list"4 (I/Length [list])] /; VectorQ[list] && Length[list] > 0Вычисление гармонического среднего для списка:
HarmonicMean[list_] := Length[list] / Apply[Plus, I/list] /; VectorQ[list] && Length[list] > 0Обратите внимание на то, что при задании первой функции Mathematica предупреждает о том, что введенный идентификатор list подозрительно напоминает зарезервированный идентификатор List. Все приведенные выше функции не имеют смысла, если список пустой. Поэтому в них введен контроль за такой ситуацией. Теперь можно выполнить расчеты по этим формулам.
Ввод (In) |
Вывод (Out) |
data={l,2,3,4} |
{1, 2, 3, 4} |
Mean [data] |
5/2 |
GeometricMean [data] |
2 3/4 3 l/4 |
N[%] |
2.21336 |
HarmonicMean [data] |
48/25 |
Ввод (In) | Вывод (Out) |
InverseFunction [Sin] | ArcSin |
%[х] | ArcSin[x] |
Composition [ f , g , h] | Ccrrposition[f , g, h] |
InverseFunction [Composition [% , q] ] | Corpositiont [q- 1 , h- 1 , g- 1 ,f- 1] |
Задание математических отношений
Символьные преобразования- при всей их кажущейся таинственности осуществляются по определенным, хотя и весьма многочисленным, а потому для нас запутанным, правилам. Основные из них давно известны из математики и описаны в многочисленных справочниках и монографиях. Они записаны в ядре системы и вызываются из него при создании условий, необходимых для выполнения того или иного преобразования. Если этих условий нет, исходное выражение просто повторяется. А если обнаружена явная ошибка в преобразованиях, то о ее сути выводится соответствующее сообщение. При ситуациях, лишь близких к ошибочным, выводится предупреждающее сообщение, и вычисления продолжаются. Однако математика и использующие ее науки непрерывно развиваются. Появляются все новые и новые правила преобразований. Пользователь-математик может пожелать изменить встроенные правила преобразований — например, для создания новых разделов математики, базирующихся на каких-либо новых представлениях. Блестящий пример этого — теория относительности Эйнштейна. Таким образом, возникает необходимость расширения математических символьных систем и обучения их новым правилам математических преобразований. Система Mathematica имеет и такие возможности. Поясним на простых примерах, как это делается. В математике можно найти множество примеров математических отношений. Например, хорошо известно такое отношение для логарифма и экспоненциальной функции:log(exp(x)) = х.Не обременяя себя поиском действительно новых закономерностей (порой на это может не хватить жизни, да и везет не каждому ученому), зададим приведенную закономерность для введенных по-новому функций log и ехр. Центральным моментом тут является введение новых имен функций, которые начинаются с малых букв, а не с больших, как у встроенных функций Log и Ехр. Поэтому система воспринимает log и ехр как новые функции. Итак, вводим «новую» закономерность следующим образом:
log[exp[x_]] :=x General::spelll : Possible spelling error: new symbol name "log" is similar to existing symbol "Log". General::spelll : Possible spelling error: new symbol name "exp" is similar to existing symbol "Exp".Система на всякий случай сообщает о рискованности эксперимента — символы log и ехр похожи на зарезервированные имена функций Log и Ехр. Проигнорировав это предупреждение, проверим введенную закономерность в работе.
Ввод (In) |
Вывод (Out) |
log [exp [15]] |
15 |
1оg[ехр[у^2+1]] | 1+y 2 |
log[x_^n_] :=n*log[x]Проверим, какие отношения заданы нами для функции log:
?log Global' log log[exp[x_] ] : = x log[x_n-] := n log[x]Проверим введенные правила, например, так:
5lоg[[1+х]^5] 5lоg[1+х]Рассмотрим еще пару примеров задания «новых» математических правил. В первом примере задано правило — логарифм произведения равен сумме логарифмов сомножителей:
log[x_*y_] := log[x] +log[y]Любопытно, что эта закономерность действует при любом числе сомножителей:
log[a*b*c*d*e] log [a] + log[b] + log[c] + log[d] + log[e]Второй пример иллюстрирует задание объекта, ассоциированного со списком:
а /: а[х_] +а[у_] :=а[х + у] а[х] + а[у] +a[z] а[х+ у+ z]Введенные здесь обозначения х_, у_ и n_ представляют собой образцы, на место которых могут подставляться произвольные выражения. Позже мы обсудим применение образцов более детально.
Функции компьютерной алгебры
Системы компьютерной алгебры имеют несколько характерных для них функций, выполняющих достаточно сложные преобразования выражений. Эти функции имеют вполне установившиеся названия (Simplify, Expand, Collect, Factor и т. д.) и встречаются практически во всех системах символьной математики. Настало время детально познакомиться с ними, что и делается в данном разделе.
Упрощение выражений — функция Simplify
Упрощение математических выражений — одна из самых важных задач символьной математики. Частенько невероятно сложное математическое выражение, пугающее новичков своим грозным видом, является просто нулем или единицей либо сводится к простому выражению после ряда вполне заурядных (хотя, порою, и довольно сложных) преобразований. Качество выполнения операции упрощения во многом определяется мощью ядра математической системы, поскольку зависит от числа заложенных в него функций и правил преобразования выражений. С точки зрения простоты выражений они делятся на недостаточно простые и достаточно простые выражения. Недостаточно простые выражения таят в себе всевозможные «излишества»: сокращаемые общие члены, лишние переменные и функции, полиномы со степенями, допускающими понижение, и т. д. Это затрудняет качественный анализ выражений и может даже приводить к неоднозначным и даже неверным результатам. Mathematica всегда старается упростить то или иное выражение, если для этого не требуется каких-либо особых средств. Например, сложные выражения, содержащие элементарные или специальные функции, превращаются в более простые выражения — в том лишь смысле, что они состоят из более простых функций. Следующие примеры иллюстрируют это.
Ввод (In) |
Вывод (Out) |
(Csc[x] Tan[w]) / (Cot[x] Sec[w]) |
Sec[x] Sin[w] |
BesselY[5/2, Е] | SQRT(2/л)(Cos[E]-[3Cos[E]+3Sin[E]]/SQRT(E)) |
Ввод (In) |
Вывод (Out) |
Комбинирование числовых подвыражений Simplify [6 х 2] |
12 х |
Приведение подобных множителей у произведений Simplify[x ^ 3 у х ^ 5] |
х 8 у |
Приведение подобных членов суммы Simplify[x + 12 + 4 х] |
5 х + 12 |
Упрощение тождеств, содержащих 0 или 1 Simplify [2+0] Simplify[l*x] |
2 х |
Распределение целочисленных показателей степени в произведениях Simplify[(5 х ^ 2 у ^ 3) ^ 2] |
5 х 4 у 5 |
Приведение общих знаменателей к выражениям с пониженной степенью или с исключением сокращаемых переменных Simplify [2 х / (х ^ 2- 1) - 1/(х + 1) ] | 1/(х + 1) |
Разложение полиномов и понижение степени выражений Simplify[(x + 1) ^ 2-х ^ 2] | 2 х + 1 |
Сокращение на наибольший полиномиальный делитель ; Simplify [ (х ^ 2 - 2 х у + у ^ 2 ) / (х ^ 2 - у ^ 2 ) ] |
(х -у)/(х + у) |
Ввод (In) |
Вывод (Out) |
Simplify[a*a - 2*а*b + b^2] |
(a-b) 2 |
Simplify [Exp [х] ^2/х] |
E 2x /X |
Sirnplif у [Sin [x-y] H-Sin [х+у] ] |
2Cos[y] Sin[x] |
Simplif у [Ехр [х] *Ехр [у] /Exp [z] ] |
E x+y-z |
Simplify [Exp [z*Log [b] ] ] |
b z |
Simplify [Log [x/y] ] |
Log[x/y] |
А := (Cos[4*x] - 4*Cos[2*x] +3)/ (4*Cos[2*x] + Cos[4*x] + 3) |
|
Simplify [A] |
Tan[x] 4 |
Simplify[6*Log[10] ] |
6Log[10] |
Simplify[6 Log[10], Complexity Function -> LeafCount] |
Log[ 1000000] |
Функция полного упрощения FullSimplify
Функция FullSimplify, область применения которой в Mathematica 4 заметно расширена, обладает заметно большими возможностями, чем функция Simplify. В частности, она обеспечивает упрощение выражений, содержащих специальные математические функции:Simplify [Gamma [х] *х* (х+1) * (х+2) * (х+n) ] х(1+х) (2 + х) (n+x) Garrma[x] FullSimplify [Gamma [х] *х* (х+1) * (х+2) * (х+n) ] (п+ х) Garrma[3 + х] Simplify[Tan[x] , ComplexityFunction-> (Count[{#l}, _Tan, \ [Infinity]]*;)] Tan[x] FullSimplify [Tan [x] , ComplexityFunction -> (Count[{#l}, _Tan, \ [Infinity]] &)]Как видно из этих примеров, функция FullSimplify обеспечивает упрощение даже в том случае, когда функция Simplify пасует. Неплохо упрощаются тригонометрические функции, особенно при использовании опции Complexity-Function, подсказывающей путь упрощения. В то же время нельзя не отметить, что теоретический фундамент упрощения выражений находится лишь в начале своего возведения, так что не стоит удивляться, если отдельные выражения не будут упрощаться — даже в том случае, когда это в принципе возможно. Более того, с позиций истинного математика функции Simplify и FullSimplify делают не совсем понятно что. Тем не менее, часто эти функции позволяют получить вполне приемлемую, хотя вовсе не единственную и не самую простую форму упрощаемого выражения.
Раскрытие и расширение выражений — функции класса Expand
Расширение, или раскрытие, выражений — еще одна типовая операция компьютерной алгебры. По смыслу она противоположна упрощению выражений. Часто компактная форма представления выражений обусловлена определенными операциями по их упрощению. Существует множество выражений, для которых эти правила известны. Например, мы знаем, что выражение(а -b)2 = (а - b) (а - b)можно представить как
a2-2ab + b2Разумеется, такое соответствие существует далеко не всегда. К примеру, выражение в виде числа 1 вовсе не является представлением только выражения sin(X) 2 + cos(x) 2 . Ниже представлены основные функции, производящие раскрытие и расширение выражений: ComplexExpand[expr] — раскрывает ехрг, полагая все переменные вещественными; ComplexExpand [expr, {x1, х2,...}] — раскрывает ехрг, считая переменные xi комплексными; FunctionExpand [expr] — раскрывает выражения ехрг, содержащие специальные функции; Expand [ехрг ] — раскрывает произведения и положительные целые степени в ехрг; Expand [expr, patt] — выполняет расширение только для тех элементов ехрг, которые содержат соответствующие шаблону patt члены; Exp_andAll [expr] — раскрывает все произведения и целочисленные степени в любой части ехрг; ExpandAll [expr, patt] — исключает из операции расширения те части ехрг, которые не содержат соответствующие шаблону patt члены; ExpandDenominator [expr] — раскрывает произведение и степени, которые присутствуют в выражении ехрг в роли знаменателей; ExpandNumerator [expr] — раскрывает произведения и степени в числителе выражения ехрг; PowerExpand[expr] — раскрывает вложенные степени, степени произведений, логарифмы от степеней и логарифмы от произведений. Осторожно используйте PowerExpand, так как эта функция не реагирует на разрывный характер выражения ехрг. Приведем примеры операций расширения выражений с помощью функции Expand:
Expand[(х - а)*(х - b)*(х - с)] -abc+ abx + acx+bcx-ax2- bx2-cx2 + x3 Simplify[%] -(а-х) (-b+х) (-с + х) Expand!(Sin[x]+Cos[x])/(Cos[x]*Sin[x])] Csc[x] + Secfx] Simplify[%] Sirrplfy[Csc[x] + Sec[x] ] Expand[2*Cos[x]^2,Trig-> True] 2Cos[x]2 Simplify[%] l+Cos[2x] Expand[Sin[x]^2+Cos[x]^2] Cos[y]2+Sin[x]2 Expand[Sin[x]^2+Cos[x]^2,Trig-> True] 1- Cos[x]2/2 +Cos [у]2/2 +Sin[x]2/2 -Sin[y]2/2 Simplify[%] 1/2 (2-Cos[2x] + Cos[2y])В этих примерах полезно обратить внимание на то, что далеко не всегда последовательное применение функций Expand и Simplify дает исходное выражение. Гораздо чаще получается новое выражение, порой представляющее ценность. При операциях с тригонометрическими выражениями нередко нужно использовать опцию Trig->True, намечая тригонометрический путь решения. В противном случае может быть просто выдан отказ от выполнения операции Expand с заданным выражением, которое будет просто повторено в ячейке вывода. Приведем примеры использования других функций расширения выражений:
ExpandAll[Sin[2*Cos[x]], Trig -> True] Cos [Cos [x] + ISin[x] ] Sin[Cos[x] - ISin[x] ] + Cos [Costx] - ISintx] ] Sin[Cos[x] + ISin[x] ] Simplify[%] Sin [ 2 Cos [x]] ExpandNumerator[(1 + x)^2/х] 1 + 2 x + x2/x ExpandDenominator[(1 - x)^2/(l + x)^2] (1-х)2/1 + 2 x + x2 ComplexExpand[Sin[a + I*b]] Cosh[b] Sin [a] + I Cos [a] Sirihfb] ComplexExpand[ (a. + b I) / (x + d I) ] -lad/Abs[Id+x]2+bd/Abs[Id+x]2 + ax/Abs[Id + x]2 +Ibx/Abs[Id+x]2 Simplify[%] (-Ia + b) (d + Ix)/^bstld+x]2 PowerExpand[Sqrt[a^2*b*c]] aSQRT(b)SQRT(c) FunctionExpand[Gamma[4, x]] E-xx3+ 3 (Fxx2+ 2 (E-x+ E-xx)) FunctionExpand[Beta[4, 2 + x]] 6/(2 + x) (3+x) (4 + x) (5 + x) FunctionExpand[Zeta[3, 2 + x] ]Разумеется, этими примерами далеко не исчерпываются возможности данной группы функций. Рекомендуется опробовать примеры из справочной системы данных Mathemaca и свои собственные примеры. К операциям, расширяющим выражения, относится также функция Collect: Collect[expr, x]— выполняет приведение общих членов выражения по степеням переменной х; Collect [expr, {x1, x2, ...}]— выполняет приведение общих членов выражения по степеням переменных xl, х2, ... Эта операция особенно полезна, если результат можно представить в виде степенных многочленов. Проиллюстрируем это следующими примерами.
Ввод (In) |
Вывод (Out) |
Collect [%, x] |
-5x+5x 2 -x 3 + x 4 |
expr = (5 + x ^ 2) * (x- 1) *x | (-1 + x) x(5 + x 2 ) |
Collect [a *x ^ 2 +b*x*y+c*y+d*y ^ 2, y] | ax + (c+ bx) y+ dy 2 |
Collect [a *x ^ 2+b*x*y + c*y+d*y ^ 2, x] | ax + cy+ bxy+ dy 2 |
Collect[ (x - 1) * (x - 2) * (х^2 - 9) , x] | -18-27х-7х 2 -Зх 3 + х 4 |
Collect[(х-1)*(у-3)*(х-2)*(у-2)*(х-1),у,х] -12.+ 30х-24х2+ 6х3 + (10-25х + 20Х2- Sx3) y+ (-2+ 5х-4х2 + х3) у2Разумеется, как и в случае упрощения выражений, их расширение не является однозначной операцией и предполагает наличие определенных условностей. Опытный пользователь, используя опции функций, обычно без труда может получить результат в нужной форме.
Функции преобразования тригонометрических выражений
Хотя представленные выше функции иногда применимы для тригонометрических выражений, для последних есть ряд специальных функций, дающих более надежные результаты в ходе преобразований тригонометрических функций. В названии этой группы функций имеется слово Trig. Начнем с функции Trig-Expand [expr ], которая обеспечивает расширение выражения ехрг, содержащего тригонометрические и гиперболические функции. Представленные ниже примеры иллюстрируют работу этой функции:TrigExpandfSin[а+b]] Cos[b] Sin[a] +Cos[a] Sin[b] TrigExpand[Cos[3*x]] TrigExpand[Cos[3*x]] Cos[x]3-3Cos[x] Sin[x]2 TrigExpand[Sinh[2^x]] 2Cosh[x] Sinh[x] TrigExpand[Sin[Cos[Tan[x]^2]]] Cos[1/2Cos[Tan[x]2] + 1/2ISin[Tan[x]2] Sin[1/2Cos[Tan[x]2] - 1/2ISin[Tan[x]2] Cos[1/2Cos[Tan[x]2] - 1/2ISin[Tan[x]2] Sin[1/2Cos[Tan[x]2] + 1/2ISin[Tan[x]2] TrigExpand[Sin[2*x]-Cos[3*x]^2] 1/2 Cos[x]6/2+2Cos[x] Sin[x] + 15/2Cos[x]4Sin[x]2 15/2Cos[x]2/Sin[x]4+Sin[x]6 /2 TrigExpand[Sin[2 ArcCoth[t]]] 2 Cos [ArcCoth[ t] ] Sin[ArcCoth[ t] ]Следующие две функции обеспечивают взаимные преобразования экспоненциальных и тригонометрических выражений: TrigToExp [expr] — преобразует тригонометрические выражения к экспоненциальному виду; ExpToTrig [expr] — преобразует экспоненциальные выражения в тригонометрические.
Примеры применения этих функций:
TrigToExp[Cos[z]] 1/2( EIz+EIz) ExpToTrig [ % ] Cos [ z] f := Sinh[z] + Cosh[z] TrigToExp[f] Ez ExpToTrig[%] Cosh[z] + Sinh[z] TrigToExp[Sin[x]/Cos[y]] I (E-IX- EIX)/(E-IX+ EIX) ExpToTrig[%] Sec[y] Sin[x]Приведем еще две функции: TrigFactor [expr] — раскладывает на простые множители тригонометрическое выражение ехрr; TrigFactorList [expr] — раскладывает тригонометрическое выражение ехрг на списки с термами выражения. Следующие примеры показывают применение этих функций:
expr = TrigExpand[Sin[a + b]^3] 3/4Cos[b] Sinfa] - 3/4 Cos [a]2 Cos [b]3 Sin [a] + 1/4 Cos[b]3Sin[a]3 + 3/4 Cos[a] Sin[b]- 3/4Cos[a]3Cos[b]2Sin[b] +9/4 Cos[a] Cos[b]2Sin[a]2 Sin[b] + 9/4 Cos[apCos[b] Sin [a] Sin[a]2-3/4 Cos[b] Sin[a]-3 Sin[b]2 + 1/4Cos[a]3Sin[b]3-3/4 Cos[a] Sin[a]2Sin[b]3 TrigFactor[expr] Sin[a+b]3 TrigFactorList[expr] {{1, 1}, {Sin[a+b] , 3}} TrigExpand[Cosh[Sin[x*y]]] Cos[1/2 Cos[xy] - 1/2 ISin[xy]] Cos[1/2 Cos[xy] + 1/2 ISin[xy]] Sin[1/2Cos[xy] -1/2 ISin[xy]] Sin[1/2 Cos[xy] + 1/2 ISin[xy]] TrigFactorList[%] {{1, 1}, {Cosh[Sin[xy]], 1}}Наконец, функция TrigReduce [expr] упрощает выражения с произведениями тригонометрических функций.
Примеры применения этой функции:
TrigReduce[2*Sin[x]*Cos[у]] Sin[x- у] + Sin[x + y] TrigReduce[Cosh[x]*Tanh[x]] Sinh[x] TrigReduce[Sin[x]^2 + Cos[x]^2] 1 TrigReduce[Sin[x]*Cos[x]] 1/2 Sin[2x] TrigReduce[Sinh[x/y]^3] 1/4 (-3Sinh[x/y] + Sinh[3x/y])Применение рассмотренных функций расширяет круг задач, решаемых с применением символьных преобразований.
Основные операции над полиномами
Полиномом называют выражение, состоящее из нескольких частей одного вида. В западной математической литературе к ним часто относят степенной многочлен видаР(х) = а0 + а1х + а2 х2 + а3 х3 + ... + аnхn.Хотя термин «полином» не очень прижился в отечественной математической литературе, мы оставляем его ввиду краткости и ради лучшего понимания синтаксиса функций системы, поскольку слова poly и Polynomial входят в параметры и имена многих функций. При этом полиномы мы будем кратко обозначать как poly или pi (здесь i — индекс или порядковый номер полинома). Над полиномами можно выполнять обычные арифметические операции: сложение, вычитание, умножение и деление. Это иллюстрируют следующие примеры (здесь р! и р2 — полиномы от одной переменной х):
р1 := х^3 + 2*х^2 + 3*х + 4 р2 := х^2 - 1 р1 + р2 3+3х+3х2+х3 р1 - p2 5+3х+х2+х3 Expand[pl*p2] -4- 3х + 2х2 + 2х3 + 2х4 + х5 pl/p2 [4 + Зх+2х2 + х3]/[-1 + х2] Simplify[(х^5 + 2*х^4 + 2*х^3 + 2*х^2 - 3*х - 4)/(х^2 - 1)] 4+3х+2х2+х3Если ситуация со сложением и вычитанием полиномов достаточно очевидна, то с умножением и делением результат часто повторяет задание. Для получения результата умножения полиномов в обычной форме следует использовать функцию расширения символьных выражений Expand. Если один полином делится на другой (это бывает далеко не всегда), то для получения результата надо использовать функцию Simplify. В общем случае при делении полиномов может оставаться остаток. Функция, обеспечивающая деление полиномов и вычисляющая остаток, описана ниже.
Разложение полиномов — функции класса Factor
Разложение чисел, математических выражений и особенно полиномов на простые , множители является столь же распространенной операцией, что и функции Simplify, Collect и Expand. Имеется целый ряд функций, в названии которых есть слово Factor и которые решают указанные задачи: Factor [poly] — выполняет разложение полинома над целыми числами; Factor [poly, Modulus->p] — выполняет разложение полинома по модулю простого числа р; Factorlnteger [n] — возвращает список простых множителей целого числа п вместе с их показателями степеней. Опция FactorComplete позволяет указать, следует ли выполнять полное разложение; FactorList [poly] — возвращает список множителей полинома с их показателями степени. Опция Modulus->p позволяет представить множители полинома по модулю простого числа р; FactorSquareFree [poly] — записывает полином в виде произведения множителей, свободных от квадратов. Опция Modulus->p позволяет представить разложение полинома по модулю простого числа р; FactorSquareFreeList [poly] — возвращает список множителей полинома, свободных от квадратов, вместе с показателями степени. Может использоваться опция Modulus->р; FactorTerms [poly] — извлекает полный (общий) числовой множитель в poly; FactorTermsList [poly] — возвращает лист всех общих числовых множителей полинома poly. Далее представлен ряд примеров применения этих функций.
Ввод (In) |
Вывод (Out) |
Factor [x ^ 3 - 6*x ^ 2 + 11*х - 6] Factor[x ^ 3 - 6*х ^ 2 + 21*х - 52] |
(-3 + x) (-2+x) (-1 + x) (-4 + x) (13-2X+X 2 ) |
Factor [х А 5 + 8*х ^ 4 + 31*х ^ 3 + 80*х ^ 2 + 94*х + 20, Modulus -> 3] |
(1+x) 2 (2+x) 3 |
FactorList[x A 4 - 1, Modulus -> 2] FactorSquareFree [ (x ^ 2 + 1)*(х ^ 4 - 1) ] |
{{1, 1}, {1 + x, 4}} (-1+x 2 ) (1 + x 2 ) 2 |
FactorSguareFree [ (x ^ 2 + l)*(x ^ 4 - 1) , Modulus -> 2] |
(1+x) 6 |
FactorSquareFreeListt (x ^ 2 +1)* |
|
(x A 4 - 1) , Modulus -> 2] FactorTerms[2*x ^ 2 + 4*x + 6] FactorTermsList[2*x ^ 2 + 4*x + 6] |
{{1, 1), {1 + x, 6}} 2 (3+ 2x+ x 2 ) {2, 3 + 2X+X 2 } |
Factorlnteger [123456789] |
{{3, 2), {3607, 1}, {3803, 1}} |
FactorList[x ^ 4 - 1] |
{{!,.!}, {-1 + x, 1}, {1+x, 1}, {1+x 2 , 1}} |
FactorSquareFreeListt (x ^ 2 +1)* (x ^ 4 - 1) ] |
{{1, 1}, {-1+x 2 , 1}, {1 + x 2 , 2}} |
Ввод (In) |
Вывод (Out) |
Factor [Csc[x] + Sec[x], Trig -> True] |
Csc[x] Sec[x] (Cos[x]+ Sin[x] ) |
Factor [ Sin [3*x] , Trig -> True] | (1+ 2Cos[2x]) Sin[x] |
Функции для работы с полиномами
Для работы с полиномами имеется множество функций, по большей части достаточно очевидных для знакомого с математикой пользователя: Decompose [poly, x] — выполняет разложение полинома, если это возможно, на более простые полиномиальные множители; GroebnerBasis [ {polyl, poly2,...}, {xl, х2,...}]—возвращает список полиномов, которые образуют базис Гробнера для идеала, порожденного полиномами polyi; Polynomial-Division [p, q, x] — возвращает список частного и остатка, полученных делением полиномов р и q от х; PolynomialGCD [polyl, poly2,...] — возвращает наибольший общий делитель ряда полиномов polyl, poly2, ... С опцией Modulus->p функция возвращает наибольший общий делитель по модулю простого числа р; PolynomialLCM[polyl, poly2,...] — возвращает наименьшее общее кратное полиномов polyl, poly2, ... С опцией Modulus->p функция возвращает наименьшее общее кратное по модулю простого числа р; PolynomialMod [poly, m] — возвращает полином poly, приведенный по модулю m; PolynomialMod [poly, {ml, m2,...}] — выполняет приведение по модулю всех mi; PolynomialQ [expr, var] — возвращает значение True, если expr является полиномом от var, иначе возвращает False; PolynomialQ [expr, {varl,...}] — проверяет, является ли expr полиномом от vari; PolynomialQuotient [р, q, х] — возвращает частное от деления р и q как полиномов от х, игнорируя какой-либо остаток; PolynomialRemainder [р, q, х] — возвращает остаток от деления р на q как полиномов от х; Resultant [polyl, poly2, var] — вычисляет результант полиномов polyl и poly2 по переменной var. С опцией Modulus->p функция вычисляет результант по модулю простого числа р. Итак, работа с этими функциями, по существу, сводит операции с таким сложным видом символьных данных, как многочлены, к типовым алгебраическим операциям над обычными символьными переменными. Следующие примеры поясняют работу с полиномами:Р[х] := а*х^3 + b*х^2 + с*х + d Q[x] := е*х^2 - f*x - 1 Null2 Collect[P[x] + Q[x], x] -1 + d+ (c- f) x+ (b+e) x^ax3 Collect[P[x]*Q[x], x] -d+ (-c-df) x+ (-b+de- cf) x2* (-a+ ce-bf) x3 + (be-af) x4+aex5 {PolynomialQ[P[x]], PolynomialQ[Q[x]]} {True, True} PolynomialQ[Sin[x], x] False PolynomialQ[P[x] + Q[x]] True Decompose[P[x], х] {d+ cx+ bх2 + ах3} PolynomialQuotient[P[x], Q[x], x] b/e+af/e2+ax/e PolynomialRemainder[Q[x], Р[х], х] -1-fx+ex2 CoefficientList[P[x], x] {d, с, b, a} Decompose[х^6 + х + 1 - х^3 + 2*х^5, х] {1+х-х3+2х5 + х6} PolynomialGCD[Р[х], Q[х]] 1 PolynomialLCM[P[x], Q[x]] Р[х] Q[x] PolynomialQuotient[3*x^3 - 2*х^2 + х, х^2 - х + 1, х] 1+Зх PolynomialRemainder[3*х^3 - 2*х^2 + х, х^2 - х + 1, х] -1-х Reduce[а*х^2 + b*х + с == 0, х]Полиномы широко используются в математических расчетах. Поэтому обилие функций по работе с ними облегчает проведение сложных вычислений и позволяет представлять результаты в достаточно простой и удобной форме. Если бы системы компьютерной алгебры работали только с одними полиномами, то и в этом случае они вполне оправдали бы себя в глазах многих математиков.
Функции для расширенных операций с выражениями
Выше была описана сравнительно немногочисленная группа функций для работы с выражениями — их упрощения, расширения, выделения множителей и т. д. Эти функции способны решать большинство повседневных задач, связанных с аналитическими преобразованиями выражений. Однако система Mathematica имеет гораздо более полный набор функций для работы с выражениями. Они приведены в приложении. К сожалению, объем книги не позволяет привести примеры использования всех этих функций, да и вряд ли они будут интересны всем читателям. Поэтому приведем лишь отдельные примеры работы с некоторыми из этих функций: Apart [expr] — переписывает рациональное выражение expr в виде суммы членов с минимальными знаменателями; Apart [expr, var] — аналогична Apart [expr], но все переменные, кроме var, интерпретируются как константы. Примеры использования функции Apart:Apart[(x^4 + 1)/(х^2 - 1)] 1+-1/(1+X)+X2-1/(1 + х ) Apart[(х^3 - у^3 - 1)/(х^2 - у), у]Две уже знакомые нам функции выделяют знаменатель и числитель выражения в виде дроби:
Denominator[(х^2 - х - 1)/(х - 1)] -1 + х Numerator[(х^2 - х - 1)/(х - 1)] -1-х + х2Следующие функции позволяют судить о размерности выражений: Depth [expr ] — возвращает значение, на единицу превышающее максимальное число индексов, требуемых для указания любой части выражения expr; Dimensions [expr] — возвращает список размерностей выражения expr; Dimensions [expr, n] — возвращает список размерностей expr до уровня n. Примеры применения этих функций:
Depth[х^3 + х^2 + х + 1] 3 Dimensions[х^3 - 2*х^2 + 1] {3}.Функция Evaluate [expr] вычисляет выражение expr безусловно, то есть даже если оно оказывается аргументом функции, чьи атрибуты определяют его невычисляемым:
Evaluate[1 + 1 + Sin[l]] 2+Sin[l]
Что нового мы узнали
В этом уроке мы научились:
Записывать выражения в разной форме. Работать с частями выражений. Осуществлять выделения и подстановки в функциях. Работать с рекурсивными функциями. Задавать инверсные функции. Задавать математические отношения. Упрощать, раскрывать и расширять выражения. Преобразовывать тригонометрические выражения. Работать с полиномами.