Макоха А.Н., Зуй Б. Ю.
В настоящее время существует необходимость проводить вычисления с очень большими целыми числами (то есть с числами, не помещающимися в разрядную сетку регистров АЛУ процессора) в таких областях как кодирование информации, криптография, физика, астрономия и т. д.
Архитектура 32-х разрядных систем позволяет обрабатывать числа в максимальном диапазоне 0..4294967295. Но это слишком узкий диапазон натуральных чисел для решения многих прикладных задач. Для расширения диапазона разработчики программного обеспечения предлагают разнообразные методы решения данной задачи. Средства для работы с большими целыми числами имеются в таких программных пакетах как Java, Си, Perl. Эффективным способом выполнения операций над сверхбольшими целыми числами является их представление в системе остаточных классов, где нет переносов из младших разрядов в старшие [3]. Однако здесь возникает своя проблема нахождения остатков от деления сверхбольшого числа на основания системы остаточных классов.
Диапазон представления натуральных чисел можно значительно расширить, реализовав несложные алгоритмы операций над данными на языке Ассемблера [1], увеличив при этом длину слова в десятки раз. Разработаны алгоритмы представления и хранения в памяти ЭВМ больших целых чисел в виде связанных списков [2]. Пусть (
В настоящей работе предлагаются алгоритмы выполнения арифметических операций над сверхбольшими натуральными числами, представленными в виде списков (последовательности бит или последовательности десятичных знаков), с помощью относительного распараллеливания этих операций на многопроцессорных системах. Пусть
при этом коэффициенты
а) при сложении
б) при вычитании
в) при умножении
Приступим к непосредственному описанию алгоритмов перечисленных операций.
Пусть имеется параллельная вычислительная система: схема процессоров или локальная сеть. Назовем элемент системы (процессор, компьютер) устройством. Имеется общее пространство ячеек памяти. Из всех устройств системы выделяется управляющее (УУ), выполняющее функции инициализации системы, анализа данных.
Инициализация системы
УУ анализирует наличие устройств системы и каждому устройству присваивает порядковый номер, выделяет ячейки памяти для каждого устройства, а также необходимое количество бит для хранения двух слов (для хранения
А. Сложение
Система инициализирует
А1. Считывает данные из отведенных для него ячеек памяти.
А2. Выполняет сложение
А3. Записывает в младшие байты слова, соответствующего устройству
А4. Записывает в старшие байты своего же слова:
А5. Оповещает УУ о завершении работы.
Далее УУ анализирует первый бит старших байтов слов, например, с помощью логической операции дизъюнкции и, если результат этой операции равен 0, формирует результат из младших байтов слов. Если результат этой операции равен 1, то возвращаемся к шагу А1.
Таким образом, рассмотренный алгоритм, в зависимости от чисел
Б. Вычитание
Система инициализирует
Б1. Считывает данные из ячеек памяти.
Б2. Выполняет вычитание
Б3. Записывает в младшие байты слова соответствующее устройству
Б4. Записывает в старшие байты слова значение
Б5. Оповещает УУ о завершении работы.
Далее УУ анализирует первый бит старших байтов слов, например, логической операцией дизъюнкции и, если результат этой операции равен 0, то формирует результат из младших байтов слов. Если же результат этой операции равен 1, то возвращаемся к шагу Б1.
Аналогично сложению количество шагов варьируется от 1 до n + 1.
В. Умножение
Алгоритм умножения несколько сложнее в реализации, но напоминает собой умножение в столбик.
Система инициализирует
Таблица 1. - Распределение ячеек памяти при инициализации
| … | | 0 | … | | … | | 0 | 0 |
| … | | 0 | … | | … | | 0 | 0 |
| … | | |||||||
|
Сначала вычисляются одновременно числа