Sophie

Sophie

distrib > Fedora > 18 > i386 > by-pkgid > 971a3706a7676677c8b7bbdffc0c4b9b > files > 242

sagemath-doc-ru-5.9-9.fc18.noarch.rpm

.. _section-poly:

Полиномы
========

Данный раздел содержит информацию о том, как создавать и использовать 
полиномы в Sage.

.. _section-univariate:

Полиномы одной переменной
-------------------------

Есть три способа создания полиномиальных колец.

::

    sage: R = PolynomialRing(QQ, 't')
    sage: R
    Univariate Polynomial Ring in t over Rational Field

Данный способ создаст полиномиальное кольцо и укажет Sage использовать 
строку 't' в качестве неизвестного при выводе на экран. Однако, это не 
определяет символ ``t`` для использования в Sage, так что нельзя при помощи 
него ввести полином (как :math:`t^2+1`), принадлежащий ``R``.

Другой способ:

.. link

::

    sage: S = QQ['t']
    sage: S == R
    True

Этот способ имеет ту же проблему по отношению к ``t``.

Третий способ более удобный

::

    sage: R.<t> = PolynomialRing(QQ)

или

::

    sage: R.<t> = QQ['t']

или даже

::

    sage: R.<t> = QQ[]

Этот способ влечет за собой объявление переменной ``t`` как неизвестного 
в полиномиальном кольце так, что ее можно использовать при создании 
элементов ``R``, как описано ниже. (Заметьте, что третий способ похож на 
обозначение конструктора в Magma, и, как в Magma, он может быть 
использован для широкого набора объектов.)

.. link

::

    sage: poly = (t+1) * (t+2); poly
    t^2 + 3*t + 2
    sage: poly in R
    True

Какой бы способ ни использовался для задания полиномиального кольца, 
можно вычленить неизвестное в виде :math:`0^{th}` генератора:

::

    sage: R = PolynomialRing(QQ, 't')
    sage: t = R.0
    sage: t in R
    True

Похожая конструкция используется для комплексных чисел: комплексные 
числа могут быть рассмотрены как генерированные из вещественных чисел 
с использованием символа ``i``; из этого следует:

::

    sage: CC
    Complex Field with 53 bits of precision
    sage: CC.0  # 0-ой генератор CC
    1.00000000000000*I

Для полиномиальных колец можно получить и кольцо, и его генератор, 
или просто генератор во время создания кольца:

::

    sage: R, t = QQ['t'].objgen()
    sage: t    = QQ['t'].gen()
    sage: R, t = objgen(QQ['t'])
    sage: t    = gen(QQ['t'])

Наконец, можно совершить некоторые арифметические опрерации в :math:`\QQ[t]`.

::

    sage: R, t = QQ['t'].objgen()
    sage: f = 2*t^7 + 3*t^2 - 15/19
    sage: f^2
    4*t^14 + 12*t^9 - 60/19*t^7 + 9*t^4 - 90/19*t^2 + 225/361
    sage: cyclo = R.cyclotomic_polynomial(7); cyclo
    t^6 + t^5 + t^4 + t^3 + t^2 + t + 1
    sage: g = 7 * cyclo * t^5 * (t^5 + 10*t + 2)
    sage: g
    7*t^16 + 7*t^15 + 7*t^14 + 7*t^13 + 77*t^12 + 91*t^11 + 91*t^10 + 84*t^9 
           + 84*t^8 + 84*t^7 + 84*t^6 + 14*t^5
    sage: F = factor(g); F
    (7) * t^5 * (t^5 + 10*t + 2) * (t^6 + t^5 + t^4 + t^3 + t^2 + t + 1)
    sage: F.unit()
    7
    sage: list(F)
    [(t, 5), (t^5 + 10*t + 2, 1), (t^6 + t^5 + t^4 + t^3 + t^2 + t + 1, 1)]

Деление двух полиномов создаст элемент в дробном поле, что будет сделано 
Sage автоматически.

::

    sage: x = QQ['x'].0
    sage: f = x^3 + 1; g = x^2 - 17
    sage: h = f/g;  h
    (x^3 + 1)/(x^2 - 17)
    sage: h.parent()
    Fraction Field of Univariate Polynomial Ring in x over Rational Field

Используя ряды Лорана, можно посчитать разложение в ряд в дробном поле ``QQ[x]``:

::

    sage: R.<x> = LaurentSeriesRing(QQ); R
    Laurent Series Ring in x over Rational Field
    sage: 1/(1-x) + O(x^10)
    1 + x + x^2 + x^3 + x^4 + x^5 + x^6 + x^7 + x^8 + x^9 + O(x^10)

Если назвать переменную по-другому, можно получить другое одномерное 
полиномиальное кольцо.

::

    sage: R.<x> = PolynomialRing(QQ)
    sage: S.<y> = PolynomialRing(QQ)
    sage: x == y
    False
    sage: R == S
    False
    sage: R(y)
    x
    sage: R(y^2 - 17)
    x^2 - 17

Кольцо определяется переменной. Обратите внимание, что создание ещё 
одного кольца с переменной ``x`` не вернет другого кольца.

::

    sage: R = PolynomialRing(QQ, "x")
    sage: T = PolynomialRing(QQ, "x")
    sage: R == T
    True      
    sage: R is T
    True
    sage: R.0 == T.0
    True

Sage поддерживает кольца степенных рядов и рядов Лорана для любого 
базисного кольца. В следующем примере создадим элемент из :math:`\GF{7}[[T]]` 
и поделим, чтобы создать элемент из :math:`\GF{7}((T))`.

::

    sage: R.<T> = PowerSeriesRing(GF(7)); R
    Power Series Ring in T over Finite Field of size 7
    sage: f = T  + 3*T^2 + T^3 + O(T^4)
    sage: f^3
    T^3 + 2*T^4 + 2*T^5 + O(T^6)
    sage: 1/f
    T^-1 + 4 + T + O(T^2)
    sage: parent(1/f)
    Laurent Series Ring in T over Finite Field of size 7

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

::

    sage: GF(7)[['T']]
    Power Series Ring in T over Finite Field of size 7

Полиномы нескольких переменных
------------------------------

Для работы с полиномами с несколькими переменными, сначала надо объявить 
полиномиальное кольцо и переменные.

::

    sage: R = PolynomialRing(GF(5),3,"z") # здесь 3 - это число переменных
    sage: R
    Multivariate Polynomial Ring in z0, z1, z2 over Finite Field of size 5

Так же, как и для одномерных полиномов, существует несколько путей:

::

    sage: GF(5)['z0, z1, z2']
    Multivariate Polynomial Ring in z0, z1, z2 over Finite Field of size 5
    sage: R.<z0,z1,z2> = GF(5)[]; R
    Multivariate Polynomial Ring in z0, z1, z2 over Finite Field of size 5

Чтобы имена переменных состояли из букв, надо использовать следующее:

::

    sage: PolynomialRing(GF(5), 'x, y, z')
    Multivariate Polynomial Ring in x, y, z over Finite Field of size 5

Немного арифметики:

::

    sage: z = GF(5)['z0, z1, z2'].gens()
    sage: z
    (z0, z1, z2)
    sage: (z[0]+z[1]+z[2])^2
    z0^2 + 2*z0*z1 + z1^2 + 2*z0*z2 + 2*z1*z2 + z2^2

Можно использовать более математическое обозначение, чтобы построить 
полиномиальное кольцо.

::

    sage: R = GF(5)['x,y,z']
    sage: x,y,z = R.gens()
    sage: QQ['x']
    Univariate Polynomial Ring in x over Rational Field
    sage: QQ['x,y'].gens()
    (x, y)
    sage: QQ['x'].objgens()
    (Univariate Polynomial Ring in x over Rational Field, (x,))

Многомерные полиномы внедрены в Sage с использованием словарей Python. 
Sage использует Singular [Si]_ для вычислений НОД и базиса Грёбнера идеалов.

::

    sage: R, (x, y) = PolynomialRing(RationalField(), 'x, y').objgens()
    sage: f = (x^3 + 2*y^2*x)^2
    sage: g = x^2*y^2
    sage: f.gcd(g)
    x^2

Создадим идеал :math:`(f,g)`, генерированный из :math:`f` и :math:`f` 
умножением ``(f,g)`` на ``R``.

.. link

::

    sage: I = (f, g)*R; I
    Ideal (x^6 + 4*x^4*y^2 + 4*x^2*y^4, x^2*y^2) of Multivariate Polynomial 
    Ring in x, y over Rational Field
    sage: B = I.groebner_basis(); B
    [x^6, x^2*y^2]
    sage: x^2 in I
    False

Кстати, базис Грёбнера является не списком, а неизменяемой последовательностью. 
Это означает, что у него есть универсум, родитель и что он не может 
быть изменен (что хорошо, поскольку изменение базиса нарушило бы другие 
операции, использующие базис Грёбнера).

.. link

::

    sage: B.parent()
    Category of sequences in Multivariate Polynomial Ring in x, y over Rational 
    Field
    sage: B.universe()
    Multivariate Polynomial Ring in x, y over Rational Field
    sage: B[1] = x
    Traceback (most recent call last):
    ...
    ValueError: object is immutable; please change a copy instead.

Некоторая коммутативная алгебра доступна в Sage и внедрена с помощью 
Singular. К примеру, можно посчитать примарное разложение и простые 
соответствующие для :math:`I`:

.. link

::

    sage: I.primary_decomposition()
    [Ideal (x^2) of Multivariate Polynomial Ring in x, y over Rational Field,
     Ideal (y^2, x^6) of Multivariate Polynomial Ring in x, y over Rational Field]
    sage: I.associated_primes()
    [Ideal (x) of Multivariate Polynomial Ring in x, y over Rational Field,
     Ideal (y, x) of Multivariate Polynomial Ring in x, y over Rational Field]