Суббота, 08 Фев 2025, 06:37
Uchi.ucoz.ru
Меню сайта
Форма входа

Категории раздела
Авиация и космонавтика [0]
Административное право [0]
Арбитражный процесс [0]
Архитектура [0]
Астрология [0]
Астрономия [0]
Банковское дело [0]
Безопасность жизнедеятельности [1930]
Биографии [0]
Биология [2350]
Биология и химия [0]
Биржевое дело [78]
Ботаника и сельское хоз-во [0]
Бухгалтерский учет и аудит [4894]
Валютные отношения [0]
Ветеринария [0]
Военная кафедра [0]
География [2269]
Геодезия [0]
Геология [0]
Геополитика [46]
Государство и право [13375]
Гражданское право и процесс [0]
Делопроизводство [0]
Деньги и кредит [0]
Естествознание [0]
Журналистика [660]
Зоология [0]
Издательское дело и полиграфия [0]
Инвестиции [0]
Иностранный язык [0]
Информатика [0]
Информатика, программирование [0]
Исторические личности [0]
История [6878]
История техники [0]
Кибернетика [0]
Коммуникации и связь [0]
Компьютерные науки [0]
Косметология [0]
Краеведение и этнография [540]
Краткое содержание произведений [0]
Криминалистика [0]
Криминология [0]
Криптология [0]
Кулинария [923]
Культура и искусство [0]
Культурология [0]
Литература : зарубежная [2115]
Литература и русский язык [0]
Логика [0]
Логистика [0]
Маркетинг [0]
Математика [2893]
Медицина, здоровье [9194]
Медицинские науки [100]
Международное публичное право [0]
Международное частное право [0]
Международные отношения [0]
Менеджмент [0]
Металлургия [0]
Москвоведение [0]
Музыка [1196]
Муниципальное право [0]
Налоги, налогообложение [0]
Наука и техника [0]
Начертательная геометрия [0]
Оккультизм и уфология [0]
Остальные рефераты [0]
Педагогика [6116]
Политология [2684]
Право [0]
Право, юриспруденция [0]
Предпринимательство [0]
Промышленность, производство [0]
Психология [6212]
психология, педагогика [3888]
Радиоэлектроника [0]
Реклама [910]
Религия и мифология [0]
Риторика [27]
Сексология [0]
Социология [0]
Статистика [0]
Страхование [117]
Строительные науки [0]
Строительство [0]
Схемотехника [0]
Таможенная система [0]
Теория государства и права [0]
Теория организации [0]
Теплотехника [0]
Технология [0]
Товароведение [21]
Транспорт [0]
Трудовое право [0]
Туризм [0]
Уголовное право и процесс [0]
Управление [0]
Управленческие науки [0]
Физика [2737]
Физкультура и спорт [3226]
Философия [0]
Финансовые науки [0]
Финансы [0]
Фотография [0]
Химия [1714]
Хозяйственное право [0]
Цифровые устройства [34]
Экологическое право [0]
Экология [1778]
Экономика [0]
Экономико-математическое моделирование [0]
Экономическая география [0]
Экономическая теория [0]
Этика [0]
Юриспруденция [0]
Языковедение [0]
Языкознание, филология [1017]
Новости
Чего не хватает сайту?
500
Статистика
Зарегистрировано на сайте:
Всего: 51657


Онлайн всего: 11
Гостей: 11
Пользователей: 0
Яндекс.Метрика
Рейтинг@Mail.ru

База рефератов


Главная » Файлы » База рефератов » Математика

Арифметика сверхбольших натуральных чисел в параллельных вычислительных системах


Гость, для того чтобы скачать БЕСПЛАТНО ПОЛНУЮ ВЕРСИЮ РЕФЕРАТА, Вам нужно кликнуть по любой ссылке после слова оплачиваемая реклама.
14 Апр 2013, 10:07

АРИФМЕТИКА СВЕРХБОЛЬШИХ НАТУРАЛЬНЫХ ЧИСЕЛ В ПАРАЛЛЕЛЬНЫХ ВЫЧИСЛИТЕЛЬНЫХ СИСТЕМАХ

Макоха А.Н., Зуй Б. Ю.

В настоящее время существует необходимость проводить вычисления с очень большими целыми числами (то есть с числами, не помещающимися в разрядную сетку регистров АЛУ процессора) в таких областях как кодирование информации, криптография, физика, астрономия и т. д.

Архитектура 32-х разрядных систем позволяет обрабатывать числа в максимальном диапазоне 0..4294967295. Но это слишком узкий диапазон натуральных чисел для решения многих прикладных задач. Для расширения диапазона разработчики программного обеспечения предлагают разнообразные методы решения данной задачи. Средства для работы с большими целыми числами имеются в таких программных пакетах как Java, Си, Perl. Эффективным способом выполнения операций над сверхбольшими целыми числами является их представление в системе остаточных классов, где нет переносов из младших разрядов в старшие [3]. Однако здесь возникает своя проблема нахождения остатков от деления сверхбольшого числа на основания системы остаточных классов.

Диапазон представления натуральных чисел можно значительно расширить, реализовав несложные алгоритмы операций над данными на языке Ассемблера [1], увеличив при этом длину слова в десятки раз. Разработаны алгоритмы представления и хранения в памяти ЭВМ больших целых чисел в виде связанных списков [2]. Пусть ( ) – список общего вида. Компьютерное представление списка состоит из n ячеек, связанных через их поля ссылок, вместе с предполагаемыми уже данными представлениями каждого из значений xi , являющихся в свою очередь списками.  

В настоящей работе предлагаются алгоритмы выполнения арифметических операций над сверхбольшими натуральными числами, представленными в виде списков (последовательности бит или последовательности десятичных знаков), с помощью относительного распараллеливания этих операций на многопроцессорных системах. Пусть , ,  – сверхбольшие натуральные числа. Разобьем эти числа на слова по основанию , где $IMAGE6$ - длина слова:

$IMAGE7$,

$IMAGE8$,

$IMAGE9$,

при этом коэффициенты $IMAGE10$. Так как будут рассматриваться числа без знака, то для всех рассуждений будем предполагать, что $IMAGE11$. Тогда

а) при сложении

$IMAGE12$, $IMAGE13$;

б) при вычитании

$IMAGE14$, $IMAGE15$;

в) при умножении

$IMAGE16$, $IMAGE17$.

Приступим к непосредственному описанию алгоритмов перечисленных операций.

Пусть имеется параллельная вычислительная система: схема процессоров или локальная сеть. Назовем элемент системы (процессор, компьютер) устройством. Имеется общее пространство ячеек памяти. Из всех устройств системы выделяется управляющее (УУ), выполняющее функции инициализации системы, анализа данных.

Инициализация системы

УУ анализирует наличие устройств системы и каждому устройству присваивает порядковый номер, выделяет ячейки памяти для каждого устройства, а также необходимое количество бит для хранения двух слов (для хранения $IMAGE18$). После инициализации все устройства работают с отведенными для них ячейками памяти.

А. Сложение

Система инициализирует $IMAGE19$ двойных слов; $IMAGE20$-е двойное слово соответствует $IMAGE20$-ому устройству ( $IMAGE22$), $IMAGE23$. В младшие байты слов УУ записывает $IMAGE24$, в старшие - $IMAGE25$, причём $IMAGE26$. Затем УУ дает команду на начало работы, после чего все устройства работают одновременно по следующему алгоритму: устройство $IMAGE27$

А1. Считывает данные из отведенных для него ячеек памяти.

А2. Выполняет сложение $IMAGE28$ (сложение данных из младших и старших байтов слов).

А3. Записывает в младшие байты слова, соответствующего устройству $IMAGE29$: $IMAGE30$.

А4. Записывает в старшие байты своего же слова:

$IMAGE31$.

А5. Оповещает УУ о завершении работы.

Далее УУ анализирует первый бит старших байтов слов, например, с помощью логической операции дизъюнкции и, если результат этой операции  равен 0, формирует результат из младших байтов слов. Если результат этой операции равен 1, то возвращаемся к шагу А1.

Таким образом, рассмотренный алгоритм, в зависимости от чисел  и $IMAGE33$,  может выдать результат $IMAGE34$ не более чем через n + 1 шагов, тогда как последовательные алгоритмы выдают результат строго через n + 1  шагов для таких же чисел.

Б. Вычитание

Система инициализирует $IMAGE35$ двойных слов, при этом $IMAGE20$-е двойное слово соответствует $IMAGE20$-ому устройству ( $IMAGE22$), $IMAGE39$. В младшие байты слов УУ записывает $IMAGE40$, в старшие - $IMAGE41$, причём для $IMAGE26$. Затем УУ дает команду на начало работы, после чего все устройства работают одновременно по следующему алгоритму: устройство $IMAGE43$

Б1. Считывает данные из ячеек памяти.

Б2. Выполняет вычитание $IMAGE44$.

Б3. Записывает в младшие байты слова соответствующее устройству $IMAGE29$  значение $IMAGE46$

$IMAGE47$

Б4. Записывает в старшие байты слова значение $IMAGE48$:

$IMAGE49$

Б5. Оповещает УУ о завершении работы.

Далее УУ анализирует первый бит старших байтов слов, например, логической операцией дизъюнкции и, если результат этой операции  равен 0, то формирует результат из младших байтов слов. Если же результат этой операции равен 1, то возвращаемся к шагу Б1.

Аналогично сложению количество шагов варьируется от 1 до n + 1.

В. Умножение

Алгоритм умножения несколько сложнее в реализации, но напоминает собой умножение в столбик.

Система инициализирует $IMAGE50$ двойных слов. При этом распределение ячеек памяти при инициализации можно представить в виде таблицы 1:

Таблица 1. - Распределение ячеек памяти при инициализации

$IMAGE51$

$IMAGE52$

0

$IMAGE51$

$IMAGE52$

0 0

$IMAGE55$

$IMAGE55$

0

$IMAGE57$

$IMAGE57$

0 0

$IMAGE19$ ячеек

$IMAGE19$ ячеек

$IMAGE61$ ячеек

Сначала вычисляются одновременно числа $IMAGE62$, представляющие собой умножение $IMAGE63$ на число $IMAGE64$, по следующему алгоритму: устройство $IMAGE22$

В1. Считывает данные из ячеек памяти.

В2. Выполняет умножение $IMAGE66$ ( $IMAGE39$,  j $IMAGE68$).

В3. Записывает в младшие байты слов: $IMAGE69$, $IMAGE70$.

В4. Записывает в старшие байты слов: $IMAGE71$.

В5. Для каждой $IMAGE72$-ки  происходит сложение по алгоритму А.

После шага В5 в старших байтах слов будут содержаться $IMAGE73$(таблица 2):

Таблица 2. - Распределение ячеек памяти после операции умножения

$IMAGE74$

$IMAGE75$

$IMAGE76$

$IMAGE77$

$IMAGE78$

$IMAGE79$

0

$IMAGE19$ ячеек

$IMAGE19$ ячеек

$IMAGE82$

$IMAGE83$

Результат умножения формируем из $IMAGE73$ сложением со сдвигом на $IMAGE85$ разрядов.

Количество шагов варьируется от 1 до $IMAGE86$, в то время как последовательное вычисление произведения займет $IMAGE87$ шагов.

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


Литература

1.Юров В. Assembler.  – СПб.: Издательство  «Питер», 2000.

2.Акритас А. Основы компьютерной алгебры с приложениями. – М: Мир, 1994.

3. Макоха А.Н., Ионисян А.С. Компьютерная эмуляция арифметических операций над целыми и рациональными числами в СОК.        // Вестник СГУ. – Ставрополь: Изд-во СГУ, вып. 20, 1999.

***** Скачайте бесплатно полную версию реферата !!! *****
Категория: Математика | Добавил: Lerka
Просмотров: 178 | Загрузок: 12 | Рейтинг: 0.0/0 | Жаловаться на материал
Всего комментариев: 0
html-cсылка на публикацию
BB-cсылка на публикацию
Прямая ссылка на публикацию
Добавлять комментарии могут только зарегистрированные пользователи.
[ Регистрация | Вход ]
Профиль
Суббота
08 Фев 2025
06:37


Вы из группы: Гости
Вы уже дней на сайте
У вас: непрочитанных сообщений
Добавить статью
Прочитать сообщения
Регистрация
Вход
Улучшенный поиск
Поиск по сайту Поиск по всему интернету
Наши партнеры
Интересное
Популярное статьи
Портфолио ученика начальной школы
УХОД ЗА ВОЛОСАМИ ОЧЕНЬ ПРОСТ — ХОЧУ Я ЭТИМ ПОДЕЛИТ...
Диктанты 2 класс
Детство Л.Н. Толстого
Библиографический обзор литературы о музыке
Авторская программа элективного курса "Практи...
Контрольная работа по теме «Углеводороды»
Поиск
Учительский портал
Используются технологии uCoz