Научная статья на тему 'Программный модуль получения явных выражений коэффициентов производящих функций, основанных на использовании композиции'

Программный модуль получения явных выражений коэффициентов производящих функций, основанных на использовании композиции Текст научной статьи по специальности «Математика»

CC BY
211
18
i Надоели баннеры? Вы всегда можете отключить рекламу.
Ключевые слова
ПРОГРАММНЫЙ МОДУЛЬ / СИСТЕМА КОМПЬЮТЕРНОЙ АЛГЕБРЫ / MAXIMA / ПРОИЗВОДЯЩИЕ ФУНКЦИИ / КОЭФФИЦИЕНТЫ КОМПОЗИЦИИ ПРОИЗВОДЯЩИХ ФУНКЦИЙ / SOFTWARE MODULE / COMPUTER ALGEBRA SYSTEM / GENERATING FUNCTIONS / COEFFICIENTS OF THE GENERATING FUNCTIONS COMPOSITION

Аннотация научной статьи по математике, автор научной работы — Перминова Мария Юрьевна

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

i Надоели баннеры? Вы всегда можете отключить рекламу.

Похожие темы научных работ по математике , автор научной работы — Перминова Мария Юрьевна

iНе можете найти то, что вам нужно? Попробуйте сервис подбора литературы.
i Надоели баннеры? Вы всегда можете отключить рекламу.

Software module to obtain explicit expressions for generating functions coefficients based on use of composition

The article investigates the software implementation of a new method to find the coefficients of generating functions, describes the developed software module used to obtain explicit expressions for composition of generating functions coefficients in the computer algebra system Maxima and its structure, and gives examples of solving specific problems.

Текст научной работы на тему «Программный модуль получения явных выражений коэффициентов производящих функций, основанных на использовании композиции»

УДК 519.16:004.021 М.Ю. Перминова

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

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

Ключевые слова: программный модуль, система компьютерной алгебры, Maxima, производящие функции, коэффициенты композиции производящих функций. doi: 10.21293/1818-0442-2017-20-1-65-69

Системы компьютерной алгебры (СКА), относящиеся к классу систем символьных вычислений, широко используются не только в инженерных и теоретических расчетах, математическом моделировании, но и в таких областях, как анализ звука и изображений [1-3]. Как правило, СКА востребованы математиками, исследователями и инженерами, активно применяющими математические методы. Одной из тенденций развития систем компьютерной алгебры является развитие преобразующих процедур и процедур управления преобразованиями [3], в том числе операций над производящими функциями. Производящие функции [4] являются эффективным инструментом решения математических задач комбинаторики, теории вероятности, математической физики и т.д. [5, 6]. В настоящее время появился новый метод нахождения явных выражений коэффициентов композиции производящих функций [7]. Коротко опишем данный метод. Для нахождения явных выражений коэффициентов производящих функций необходимо знать композиты производящих функций и операции над композитами. Компо-

зитой ЛА (п,к) называется функция, являющаяся

коэффициентом производящей функции

А(х)к]=£ЛА(п,к)хп . Существует множество

п>к

операций над композитами: сумма, произведение, сдвиг, обращение и др. Одной из таких операций является композиция.

Пусть даны две производящие функции А(х) и В(х). Тогда для вычисления композиции Р (х) = В (А(х)) будет верно выражение

/ (п) = ]ТЛА (п, к) • Ъ(к), / (0) = Ъ(0), (1)

к=1

где /(п) - явное выражение коэффициентов композиции производящих функций; Ъ(к) - коэффициенты

производящей функции В(х); ЛА (п,к) - композита

А(х).

Обзор СКА показал, что получение явных выражений коэффициентов производящих функций

реализовано для простейших случаев [8]. В общем случае эта задача не решена. В данной статье предлагается вариант реализации программного модуля, основанного на автоматизации описанного выше метода.

Постановка задачи

Пусть дана производящая функция Р(х) на языке системы компьютерной алгебры.

Необходимо найти явное выражение коэффициентов /п) с использованием метода [7], алгоритма последовательной генерации ограниченных разбиений натурального числа [9], алгоритма декомпозиции полиномов, основанного на генерации разбиений [10, 11], и формулы композиции производящих функций (1).

Композиты производящих функций и операции над ними известны и находятся в базе знаний в виде некоторых обобщенных функций.

Для решения данной задачи в СКА разработан программный модуль, основанный на перечисленных выше методе и алгоритмах.

Структура программного модуля

Рассмотрим структуру разработанного программного модуля (рис. 1).

На вход блока синтаксического анализа поступает исходная производящая функция Р(х), соответствующая стандартному описанию функции на исходном языке. Если синтаксический анализ прошел успешно, то Р(х) поступает на вход блока семантического анализа. Иначе генерируется ошибка. Если семантический анализ Р(х) прошел успешно, то на вход блока анализа на наличие композиции полиномов поступает Р(х). Иначе генерируется ошибка.

Блок поиска композиции полиномов базируется на разработанных ранее алгоритме последовательной генерации ограниченных разбиений натурального числа [9] и алгоритме декомпозиции полиномов, основанном на генерации разбиений [10, 11]. Если композиция полиномов найдена, то список с полиномами [А(х),В(х)] передается на вход блока

получения явного вида выражений коэффициентов /(п). В случае неудачи Р(х) поступает на вход блока

поиска композиции других классов производящих функций.

Блок поиска композиции других классов производящих функций основан на представлении Е(х) синтаксическим деревом в виде списка, составлении списка подвыражений Е(х) и их анализе. Если подобная композиция найдена, то на вход блока полу-

Блок синтаксического анализа Fix)

Блок семантического анализа F(x)

чения fn) поступает список производящих функций [A( x), B( x)]. Иначе генерируется ошибка.

По схеме на рис. 1 видно, что два блока взаимодействуют с базой композит и операций, в которой находятся производящие функции с их композитами и операции над ними.

>

Рис. 1. Структура модуля получения явных выражений ко;

Рис. 1. Структура модуля получения явных выражений коэффициентов композиции производящих функций

Блок обработки и генерации ошибки

Программная реализация

Для программной реализации модуля выбрана СКА Maxima. Maxima - это система компьютерной алгебры, аналогичная Mathematica, Mathlab и другим подобным системам. Несмотря на сложность программных продуктов, предназначенных для символьных вычислений, Maxima выгодно отличается от аналогичных программ тем, что является бесплатной и распространяется с открытым исходным кодом. Кроме того, Maxima переносима почти на все основные операционные системы и платформы, даже на карманные компьютеры [12].

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

Lib представляет собой базу композит и операций, где находятся производящие функции с их композитами и операции над ними. Производящие функции в модуле разделены по классам: полиномы; рациональные производящие функции; производящие функции логарифма; радикалы; тригонометрические производящие функции; гиперболические производящие функции; производящие функции на основе ex.

Формат записей в базе:

/* Comment */

C0mp0sita_name(pi,p2,...,pn) := formula; где Comment - комментарий (производящая функция, композита которой будет записана), Composita_name(pbp2,.. .,pn) - название композиты (в названиях изменяется только часть «name») с указанием параметров pbp2,...,pn и далее формула компо -зиты.

Примеры записей в базе Lib:

/* Композита f(x)=x+2*xA2+xA3 */

Composita_x2x2x3(n,k):=binomial(2*k,n-k);

/* Композита f(x)=ln(1+x) */

Composita_ln(n,k):=stirling1(n,k)*k!/n!;

/* Композита f(x)=sinh(x) */

Composita_sinh(n,k): =

1/2Ak*sum((-1)Ai*binomial(k,i)* (k-2*i)An/n!,i,0,k);

Записи в базе упорядочены в соответствии с монографией [7]. Всего в базе насчитывается более 100 композит производящих функций различных классов.

В Lib есть обобщенные и частные формулы композит производящих функций. Например,

2 3 2 3

ax+bx + cx - обобщенная формула, x+2x + x -

частная формула.

На основе базы композит и операций Lib построены два списка: LIST_GF - список производящих функций, LIST_CO - список композит произво-

дящих функций. Порядок элементов LIST_GF строго соответствует порядку элементов LIST_COi. Поиск производящих функций осуществляется по списку LIST_GF. Производящие функции в этом списке упорядочены по количеству параметров pn, необходимых для получения композиты производящей функции.

Decomposition содержит в себе функции всех оставшихся блоков структуры (см. рис. 1). Эти функции вызываются главной функцией части Decomposition - AllFunc(/), где f - исходная производящая функция в синтаксисе Maxima. Остановимся подробнее на программной реализации оставшихся блоков.

Синтаксический анализ F(x) осуществляется стандартными функциями Maxima. Существуют следующие ограничения для F(x):

• функция F должна зависеть только от одной переменной х;

• если F(x) - экспоненциальная производящая функция, то ее необходимо записывать как eA(expression). Если expression - это переменная, то скобки можно опустить;

• F(x) должна представлять собой композицию двух производящих функций A(x) и B(x), и их композиты должны быть записаны в Lib;

• все коэффициенты F(x) должны быть записаны в числовом виде.

Семантический анализ F(x) представляет собой разложение F(x) в ряд Тейлора и проверку нулевого коэффициента. Это осуществляется стандартной функцией Maxima - taylor(F(x),x,0,0).

В блоке поиска композиции полиномов главной функцией является GetDecompositionPoly(F(x)), она вызывает следующие функции:

1) SearchDegrees(F(x)) - формирует список, содержащий все возможные сочетания степеней m и s полиномов А(х) и В(х) соответственно, при которых возможно представление F(x) в виде композиции B(A(x)). Для каждого сочетания степеней вызывается функция GetT(m,s);

2) GetT(m,s) - формирует список номеров уравнений T, которые необходимо решить для получения коэффициентов полиномов композиции. Для каждого уравнения Tj вызываются функции:

• First(m,s,7j) - находит путь от корня (m,s,Tj) к самому левому листу дерева разбиений;

• Nexi(m,s,T) - находит следующий путь в поддереве дерева разбиений;

• GetPartition(L) - формирует разбиение P, где L - путь в дереве разбиений;

• GetMonom(P) - формирует моном по разбиению Р;

• GetEquation(Poly) - формирует уравнение, решение которого представляет собой коэффициенты полиномов A(x) и B(x).

Более подробно ознакомиться с алгоритмом работы функции GetDecompositionPoly(F(x)) можно в статьях [9-11].

Блок поиска композиции других классов производящих функций включает в себя следующие функции:

1) И818иЪЕхр(Р(х)) - формирует список подвыражений Б для Р(х) на основе синтаксического дерева, представленного списком;

2) СотроБУауп(Б) - по списку Б проверяет, является ли В(х) в композиции Р (х) = В (А(х)) тригонометрической, гиперболической, логарифмической функцией или функцией квадратного корня;

3) ве1Ы818иЪехр8(Р(х)) - возвращает список с производящей функцией, полученной после замены повторяющихся в ней подвыражений, и самим подвыражением. Вызывает функции:

• Яереа18иЪЕхр(Б) - возвращает список Я повторяющихся подвыражений Р(х);

• Яер1асе(Р(х),Я) - заменяет повторяющиеся подвыражения в производящей функции Р(х).

Для связи с базой предназначена функция ОеШитЬз1пВа5е(Р(х)). Она формирует список с номерами позиций производящих функций из базы, с которыми сходна Р(х). Как видно из схемы (см. рис. 1), данная функция содержится в блоках поиска композиции различных классов производящих функций.

Случается, что для производящей функции по разным формулам в базе можно найти несколько

2 3

композит. Например, для полинома 2х + 4х + 3х будет две композиты:

п _к _^2к_] 4_п+к+2]3п-к_] - по формуле

k , j=0

3 2

для производящей функции вида cx + bx + ax ;

J--

k

I

3k-n

J |3k - J [k]2-n+3k - J 4n-3k+2 J -

n - 3k + 2 J J [ J)

по

формуле для производящей функции вида

ax+bx2 + pxm .

Поэтому для выбора одной формулы коэффициентов вызывается функция ChooseForm(K), где V -список из формул коэффициентов. Она возвращает самую простую формулу с наименьшим количеством переменных.

Блок получения явного выражения коэффициентов композиции производящих функций f(n) содержит функцию Superposition(A(x),B(x)). В основе работы данной функции лежит формула композиции производящих функций, о которой говорилось ранее. Формулу коэффициентов b(k) получаем из композиты производящей функции B(x) (степень k = 1).

iНе можете найти то, что вам нужно? Попробуйте сервис подбора литературы.

На данный момент преобразования f(n) выполняются стандартными функциями Maxima.

Пример работы модуля

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

Сначала объявляется переменная функцией load загружаются обе части программно-file_search_maxima. Она указывает списки каталогов го модуля: Lib и Decomposition. Затем вызывается Для поиска файлов функциями load, demo и некото- главная функция AllFunc(F(x)), где F(x) - производи другими функциями Maxima. В нашем случае дящая функция в синтаксисе Maxima. Результатом

к катали™, которые заданы в Maxima по умолча- работы AllFunc(F(x)) является закрытый вид выра-нию, добавляется один пользовательский каталог, , , „ .

г ^ жений коэффициентов f(n). путь которого указан в квадратных скобках. Далее

<%il) f ile_search._maxinia: append (filesearchmaxima, [ "C : /work/mary/maxima/### . mac" ] } S

(%i2) load(Lib),-

(%o2) C:/work/mary/maxima/Lib.mac

(%i3) load(Decomposition);

<%оЗ) С:/work/та гу/maxima/Decomposition.mac

(%i4) AllFunc (sin. (x) +sin (x) "2) ,

■0)

Л ( i-i)

[2i-

(-1)

*=1

(%o45

n :

Рис. 2. Получение закрытого вида выражений коэффициентов композиции производящих функций в Maxima

Для тестирования программного модуля был разработан набор тестовых примеров. Они основаны на следующих производящих функциях: тригонометрические - sin(x), tan(x); гиперболическая -sinh(x); полиномы степеней от 2 до 6; экспоненциальные - ex -1 и x ■ ex; рациональные -xjsqrt (l-x2 ) и -x/(x-1). Примеры производящих

функций из тестового набора: sin(x) + sin(x) , -4x6 - 24x5 - 47x4 - 28x3 + 5x2 + 2x , tan (sinh(x)) ,

x + 3x2 + x3)))l-(x+3x2 + x3) . Результаты численных экспериментов на наборе тестовых примеров показали работоспособность программного модуля.

Заключение

Разработанный программный модуль позволяет в автоматизированном режиме решать задачи комбинаторики, алгебры, теории чисел, статистики, математической физики и пр. Это обеспечивает ускорение и уменьшение числа ошибок. Программный модуль расширяет возможности Maxima по нахождению явных выражений коэффициентов производящих функций. Полученное с использованием программного модуля явное выражение коэффициентов производящей функции позволяет расширить базу энциклопедии целочисленных последовательностей OEIS [13]. Данными этой энциклопедии пользуются как любители, так и специалисты в математике, комбинаторике, теории чисел, теории игр, физике, хи-

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

Литература

1. Joel S. Cohen. Computer algebra and symbolic computation. Mathematical Methods [Электронный ресурс]. -Режим доступа: http://www.ukma.edu.ua/~yubod/teach/ compalgebra/%5BJoel_S._Cohen%5D_Computer_algebra_an d_symbolic_comp(BookFi.org).pdf, свободный (дата обращения: 16.03.2017).

2. Афонский А.А., Дьяконов В.П. Электронные измерения в нанотехнологиях и микроэлектронике [Электронный ресурс]. - Режим доступа: https://www.litres.ru/ vladimir-dyakonov-2/elekronnye-izmereniya-v-nanotehnolo-giyah-i-mikroelektronike-6599233/, свободный (дата обращения: 19.03.2017).

3. Клименко В.П., Ляхов А.Л., Гвоздик Д.Н. Современные особенности развития систем компьютерной алгебры [Электронный ресурс]. - Режим доступа: http://cyberleninka.ru/article/ri/sovremennye-osobennosti-raz-vitiya-sistem-kompyuternoy-algebry, свободный (дата обращения: 19.03.2017).

4. Ландо С.К. Лекции о производящих функциях / С.К. Ландо. - 3-е изд., испр. - М.: МЦНМО, 2007. - 144 с.

5. Stanley R.P. Enumerative Combinatorics. -Cambridge University Press, 2001. - Vol. 2. - 600 p.

6. Wilf H.S. Generatingfunctionology / H.S. Wilf. - Academic Press, 1994. - 231 p.

7. Кручинин В.В. Степени производящих функций и их применение / В.В. Кручинин, Д.В. Кручинин. - Томск: ТУСУР, 2013. - 236 с.

8. Перминова М.Ю. Обзор систем компьютерной алгебры для работы с производящими функциями: матер. Всерос. науч.-техн. конф. студентов, аспирантов и молодых ученых «Научная сессия ТУСУР-2013». - Томск: В-Спектр, 2013. - Ч. 2. - С. 323-325.

9. Перминова М.Ю. Алгоритмы рекурсивной генерации ограниченных разбиений натурального числа / М.Ю. Перминова, В.В. Кручинин // Доклады ТУСУРа. -

2014. - № 4(34). - С. 89-94.

10. Перминова М.Ю. Алгоритм декомпозиции полиномов, основанный на разбиениях / М.Ю. Перминова, В.В. Кручинин, Д.В. Кручинин // Доклады ТУСУРа. -

2015. - № 4(38). - С. 102-107.

11. Перминова М.Ю. Анализ алгоритма декомпозиции полиномов, основанного на разбиениях [Электронный ресурс] / М. Ю. Перминова // Кибернетика и программирование. - 2015. - № 6. - С. 21-34. - Режим доступа: http://e-notabene.ru/kp/article_17169.html, свободный (дата обращения: 03.02.2017).

12. Решение прикладных задач с помощью Maxima [Электронный ресурс]. - Режим доступа: http://lug.mephistru/wiki/Решение_прикладных_задач_с_по мощью_Maxima, свободный (дата обращения: 19.01.2017).

69

13. Sloane J.A. The On-Line Encyclopedia of Integer Sequences [Электронный ресурс]. - Режим доступа: https://oeis.org/, свободный (дата обращения: 16.03.2017).

Перминова Мария Юрьевна

Аспирант каф. промышленной электроники (ПрЭ) ТУСУРа Тел.: +7 (382-2) 70-15-53 Эл. почта: [email protected]

Perminova M.Yu.

Software module to obtain explicit expressions for generating functions coefficients based on use of composition

The article investigates the software implementation of a new method to find the coefficients of generating functions, describes the developed software module used to obtain explicit expressions for composition of generating functions coefficients in the computer algebra system Maxima and its structure, and gives examples of solving specific problems. Keywords: software module, computer algebra system, Maxima, generating functions, coefficients of the generating functions composition.

i Надоели баннеры? Вы всегда можете отключить рекламу.