Научная статья на тему 'Конструктивная математика и принцип близкодействия'

Конструктивная математика и принцип близкодействия Текст научной статьи по специальности «Математика»

CC BY
128
37
i Надоели баннеры? Вы всегда можете отключить рекламу.
Ключевые слова
КОНСТРУКТИВНАЯ МАТЕМАТИКА / ПРИНЦИП БЛИЗКОДЕЙСТВИЯ / ПАРАЛЛЕЛЬНЫЙ АЛГОРИТМ / КЛАСТЕРНЫЕ ВЫЧИСЛЕНИЯ / CONSTRUCTIVE MATHEMATICS / CONCEPTION OF SHORT-RANGE INTERACTION / PARALLEL ALGORITHMS / CLUSTER COMPUTATIONS

Аннотация научной статьи по математике, автор научной работы — Малашонок Геннадий Иванович

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

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

CONSTRUCTIVE MATHEMATICS AND CONCEPTION OF SHORT-RANGE INTERACTION

Modern directions of constructive mathematics development are discussed. This directions are connected with occurrence of multiprocessing computing systems. Requirements to algorithms and date structures which are destined for multiprocessing systems are discussed.

Текст научной работы на тему «Конструктивная математика и принцип близкодействия»

УДК 519.688

КОНСТРУКТИВНАЯ МАТЕМАТИКА И ПРИНЦИП БЛИЗКОДЕЙСТВИЯ

© Г. И. Малашонок

Ключевые слова: конструктивная математика, принцип близкодействия, параллельный алгоритм, кластерные вычисления.

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

1 Введение

Причины развития отдельных научных областей - это предмет философии науки. Когда говорят о причинах развития математики последних веков, считается общепризнанным, что внешние побудительные мотивы развития находились в области естествознания и, главным образом, в области решения физических задач, а во второй половине XX в. развитие вычислительной техники стало сильно сказываться на развитии конструктивной математики.

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

Следующие поколения компьютеров, позволяющие проводить сложную символьную обработку текстов, привели к появлению символьной компьютерной математики, которую обычно называют компьютерной алгеброй. Выкладки, которые приходится делать студенту, который изучает математику или применяет математический аппарат в прикладных задачах, могут быть осуществлены с помощью компьютера. При этом, с одной стороны, можно избежать механических ошибок, а с другой стороны, можно оперировать очень большими аналитическими выражениями, недоступными без компьютера.

Это привело к развитию многих конструктивных направлений в математике, которые не могли быть интересны в эпоху расцвета численных методов.

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

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

Такое оборудование потенциально способно решать гигантские аналитические и численноаналитические задачи. Однако отсутствует теория параллельных алгоритмов.

Параллельные алгоритмы принципиально отличаются от последовательных алгоритмов наличием, кроме собственно вычислительной, еще и коммуникативной составляющей: нужно не только вычислять промежуточные результаты, но и пересылать их от одного процессора к другому согласованным образом. Самые замечательные алгоритмы, которые имеют низкую вычислительную сложность, могут быть совершенно не пригодны для параллельных вычислений.

Рассмотрим два класса алгоритмов, которые играют роль «крайних случаев» для параллельных вычислительных алгоритмов.

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

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

Самый неудобный класс алгоритмов - итерационные алгоритмы. Это алгоритмы, у которых следующая итерация вычислений не может начаться, пока не завершится предыдущая. Например, алгоритм, который вычисляет 10000-й член последовательности, у которой задано 10 первых членов и каждый последующий член определяется предыдущими десятью членами.

2 Матричные алгоритмы и принцип близкодействия

Важный класс алгоритмов составляют конструктивные матричные алгоритмы. Это алгоритмы вычисления матричных функций, когда матрицы имеют большой размер, а элементами матриц являются символьные или численно-символьные выражения.

Классический подход в виде вычисления Ьи-разложения или применение метода Гаусса не позволяют получить эффективную параллельную программу. Во-первых, на каждом шаге требуется пересылать данные из текущей строки во все остальные строки. Во-вторых, всякий раз, когда необходимо выбирать ведущий элемент, а без этого, как известно, алгоритм Гаусса просто остановится, например, на нулевом ведущем элементе, нужно запускать очень «дорогой» коммуникативный процесс. Результатом такого процесса должен быть выбор нового ведущего элемента, перестроение вычислительного процесса и возобновление процесса вычислений.

Для такой организации требуется некоторое централизованное управление вычислительным процессом. Этапы вычислений сменяются этапами перестройки вычислительного процесса, и чем больше процессоров, тем «дороже» перестройка вычислительного процесса.

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

При такой организации вычислений нет лишних затрат на коммуникативные процессы, на централизованное управление и на перестройку вычислительного процесса.

Принцип близкодействия благотворно сказывается даже на последовательном вычислительном процессе, протекающем в одном процессоре. Как известно, сегодня повсеместно используется многоуровневая память. Около процессора располагается самый скоростной кэш первого уровня, за ним располагается кэш второго уровня, более медленный, затем отдельный чип с оперативной памятью. В процессе вычислений данные из ОЗУ перегружаются блоками в кэш второго уровня, а из него в кэш первого уровня, с которым обменивается данными процессор с самой высокой скоростью.

Поэтому алгоритмы, учитывающие принцип «близкодействия», будут всегда в выигрышной ситуации по сравнению с алгоритмами, которые вынуждены часто обращаться в далекие друг от друга области ОЗУ. Хорошим примером тут может послужить алгоритм умножения матриц. Если матрицы хранятся как вектор из строк, то известный алгоритм умножения матриц «строка-на-столбец» будет проигрывать по сравнению с любым другим алгоритмом, у которого не требуется передвигаться по столбцу, перемещаясь по далеким друг от друга элементам с одной строки на другую.

Альтернативным является блочный матричный алгоритм. Кроме того, можно предложить алгоритм, в котором элемент а{г^) первого сомножителя после умножения на строку j второго сомножителя подсуммируется к строке г произведения.

Отметим, что рекурсивный локально-блочный подход оказался плодотворным при создании эффективных матричных алгоритмов в коммутативных кольцах ([1-5]). Он позволил построить алгоритмы, имеющие сложность матричного умножения.

Программа пересмотра матричных алгоритмов и создания алгоритмов, удовлетворяющих принципу близкодействия, была запущена с момента выхода работы [1] в 2002г. Алгоритмы, известные к тому времени, не могли преодолеть проблему возможного появления нулевых ведущих элементов.

В 2005 г. появился первый алгоритм обращения матрицы, удовлетворяющий принципу близкодействия [6]. В 2008 г. был создан алгоритм вычисления ядра линейного оператора и присоединенной матрицы для матриц над коммутативными областями [7]. Для матрицы над полем произвольной характеристики алгоритм вычисления обобщенного разложения Брюа был опубликован в 2010 г. [8, 9].

Задача создания алгоритма разложения Гаусса в коммутативной области, удовлетворяющего такому принципу близкодействия, пока ожидает своего решения. Известный блочный рекурсивный алгоритм вычисления разложения Гаусса предполагает, что у исходной матрицы ранга г все г ведущих угловых миноров отличны от нуля [1|. Это ограничение не позволяет создавать универсальный блочный алгоритм разложения Гаусса. Отметим, решение этой задачи приведет к обобщению разложения Брюа на область целостности, а также должно привести к ускорению вычисления базиса Гребнера полиномиального идеала по методу Фужера.

ISSN 1810-0198 Вестник ТГУ, т. 16, вып. 1,2011

3 Разложение Гаусса

Пусть Я - коммутативное кольцо, А = (а- матрица с элементами а^, размера п х тп ранга г над Л, 1п - единичная матрица порядка п, - минор порядка к, полученный окаймлением верхнего левого углового минора порядка к — 1 строкой г и столбцом 1 в матрице А, к ^ тт(п, га), г ^ п, ^ ^ га, аг = - угловой минор

порядка г. Пусть все ведущие угловые миноры г*г, (1 < г < г) отличны от нуля.

Разложение матрицы А в произведение нижней треугольной, обратной диагональной и верхней треугольной, которое называют разложением Гаусса, имеет вид

А = Ь\уд-1!#,,

где нижняя треугольная и верхняя треугольная матрицы Ь\и С/^ имеют размер п х г и г х т соответственно:

г1,г

7-1.« _ Ь1,г -

(

ап

«2,1

«г—1,1 «г,1

о

7 2 г2,2

аг-1,2

а?,2

и}:

1,г __ т

V &п і Ц? о • Сг-1 <г /

/ а\\ «1,2 «1,3 • а\)Г &1,тп \

0 а2,2 а2,3 * . а\г ... 2,т

0 0 аз,з • . а|г ... 4т

\ 0 0 0 . • К,г ••• «г,т /

аг-1,г-1

<7-1

О \ о

о

«.Г

а диагональная матрица имеет порядок г:

£> = diag (а1, а1а2, • • • , аг-2аг-1, аг_1аг).

Будем полагать, что п = га, и дополним это тождество единичными и нулевыми блоками следующим образом:

А =

г1,Г

Ь1,г

Г7"

Л-1 о о о

/71,г г/1,г

1,1" иг+ 1,п

о /

ГІ.Т-

В таком разложениии обе треугольные матрицы имеют полный ранг п, а диагональная матрица имеет ранг г.

Разложение Гаусса в таком виде может быть обобщено на случай произвольной матрицы ранга г ^ 0. Алгоритм для общего случая неизвестен. Отметим несколько частных случаев.

Для ненулевой матрицы первого порядка имеется единственное разложение а = аа~1а.

„ /а И

Для ненулевых матриц второго порядка А = I ^ I в зависимости от расположения нулевых элементов возможны следующие с;

Если а^0и^ = ^ 0, то ^ а ^

,-і

0

0 (аб)

а Ь 0 6

Если а ф 0 и det^ = 0, то Если Ъ ф 0 и с ф 0, то Если Ь ф О, то Если с ф 0, то Если d ф 0, то

а b с d

а О

,-i

О

О Ь

с d

О 6 О d

О О

с d

О О О d

-6 О

0 с

Ь О d 1

1 О

0 с

1 О

О d

О

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

с-1

О 6“1 О О

О О с-1 О

О О О d~l

-(«Г1

О

а b О 1

с

О

1 О О ь

с d

0 1

1 О

О d

Если матрица имеет полный ранг, п = т = гапк(Л) и все ведущие угловые миноры отличны от нуля, ак ф 0, 1 ^ к ^ п, то разложение Гаусса имеет вид

( an 0 0 0 \

«2,1 a2,2 0 0

A = • • X

«n—1,1 an-l,2 • •• П—1,71— 1 0

^ «n,l <2 an_1 7l,Tl— 1 1 J

a1 0 0 ... 0 \ — 1 ( «11 «1,2 «1,3 • • «1,71 \

0 otla2 0 ... 0 0 a2,2 a2,3 ' • • 4»

0 0 a2 „3 or ... 0 X 0 0 a3,3 • • • a3,n

0 0 0 ... a"-1 ) I 0 0 0 .. • °n,n /

Такое разложение матрицы Д.П.Желобенко (см. [10]) предложил называть разложением Гаусса. Разложение, приведенное в [б], отличается только в том, что обе треугольные матрицы имеют единичные элементы на диагонали, дробные внедиагональные элементы, а диагональная матрица имеет вид

D = diag(a1,a 1а2,

а

—г+2лг—1 п+1 „п

ас

а

Если же матрица нулевая и имеет произвольный размер, то у нее существует разложение вида 0 = /0/. Задача состоит в том, чтобы получить разложения Гаусса для произвольной матрицы.

ЛИТЕРАТУРА

1. Малагионок Г.И. Матричные методы вычислений в коммутативных кольцах /монография/. Тамбов, ТГУ, 2002.

2. Malaschonok G.I. ParCA2: Arcitecture and Experiments // Mathematical Modeling and Computation Physics (MMCP’2009): Book of Abstracts of the International Conference (Dubna, July 7-11, 2009). - Dubna: JINR, 2009. P. 175.

3. Malaschonok G.I. On the project of parallel computer algebra // Tambov University Reports.Natural and Technical Sciences. V. 14, part. 4, 2009. p. 744-748.

4. Malaschonok G.I. Architecture of РагСАЗ project // International conference Polynomial Computer Algebra. St.Petersburg, PDMI RAS, 2010. P. 44-47.

5. Алгоритмы компьютерной алгебры. Ч. 1: Учебное пособие / Г.И. Малашонок, О.Н. Переславцева, О.А. Сажнева, М.В. Старов; Федеральное агенство по образованию, Тамб. гос. ун-т им. Г.Р. Державина. Тамбов: Издательский дом ТГУ им. Г.Р. Державина, 2008. 89 с.

6. Малашонок Г.И. Параллельные алгоритмы компьютерной алгебры // Тезисы публичных лекций на юбилейной конференции, посвященной 75-летию Института математики, физики и информатики ТГУ им. Г.Р. Державина (23-24 ноября 2005 года). Тамбов: ИМФИ ТГУ им. Г.Р. Державина, 2005.

7. Malaschonok G.I. On computation of kernel of operator acting in a module // Tambov University Reports. Natural and Technical Sciences. Tambov, 2008. V. 13. Issue. 1. P. 129-131.

8. Malaschonok G.I. Fast matrix decomposition in parallel computer algebra // Tambov University Reports. Series: Naturaland Technical Sciences. Tambov, 2010. V. 15. Issue. 4. P. 1372-1385.

9. Malaschonok G.I. Fast Generalized Bruhat Decomposition // Computer Algebra in Scientific Computing, LNCS 6244, Springer, Berlin 2010. P. 194-202.

10. Желобенко Д.П. Компактные группы Ли и их представления.М.: Наука, 1970. С. S50-51

БЛАГОДАРНОСТИ: Работа выполнена при поддержке программы «Развитие потенциала высшей школы» (проект 2.1.1/10437).

Поступила в редакцию 12 ноября 2010 г.

UDK 519.688

CONSTRUCTIVE MATHEMATICS AND CONCEPTION OF SHORT-RANGE

INTERACTION

(c) G.I. Malaschonok

Key words: constructive mathematics, conception of short-range interaction, parallel algorithms, cluster computations.

Modern directions of constructive mathematics development are discussed. This directions Eire connected with occurrence of multiprocessing computing systems. Requirements to algorithms and date structures which are destined for multiprocessing systems axe discussed.

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