![]() |
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Главная Рефераты по сексологии Рефераты по информатике программированию Рефераты по биологии Рефераты по экономике Рефераты по москвоведению Рефераты по экологии Краткое содержание произведений Рефераты по физкультуре и спорту Топики по английскому языку Рефераты по математике Рефераты по музыке Остальные рефераты Рефераты по авиации и космонавтике Рефераты по административному праву Рефераты по безопасности жизнедеятельности Рефераты по арбитражному процессу Рефераты по архитектуре Рефераты по астрономии Рефераты по банковскому делу Рефераты по биржевому делу Рефераты по ботанике и сельскому хозяйству Рефераты по бухгалтерскому учету и аудиту Рефераты по валютным отношениям Рефераты по ветеринарии Рефераты для военной кафедры Рефераты по географии Рефераты по геодезии Рефераты по геологии Рефераты по геополитике Рефераты по государству и праву Рефераты по гражданскому праву и процессу Рефераты по делопроизводству Рефераты по кредитованию Рефераты по естествознанию Рефераты по истории техники Рефераты по журналистике Рефераты по зоологии Рефераты по инвестициям Рефераты по информатике Исторические личности Рефераты по кибернетике Рефераты по коммуникации и связи |
Дипломная работа: Математические основы системы остаточных классовДипломная работа: Математические основы системы остаточных классовМИНИСТЕРСТВО ОБРАЗОВАНИЯ И НАУКИ РОССИЙСКОЙ ФЕДЕРАЦИИ СТАВРОПОЛЬСКИЙ ГОСУДАРСТВЕННЫЙ УНИВЕРСИТЕТ ФАКУЛЬТЕТ ФИЗИКО-МАТЕМАТИЧЕСКИЙ КАФЕДРА АЛГЕБРЫ Утверждена приказом по университету Допущена к защите от ____________________№_________ «____» ______________200__г. Зав.кафедрой алгебры, к. ф.-м. наук, доц. Копыткова Людмила Борисовна М. П. ДИПЛОМНАЯ РАБОТА «МАТЕМАТИЧЕСКИЕ ОСНОВЫ СИСТЕМЫ ОСТАТОЧНЫХ КЛАССОВ» Рецензенты: Выполнила: ___________________________ Пивоварова Елена Николаевна ___________________________ студентка 5 курса, гр. «Б» специальности математика очной формы обучения Дата защиты: Научный руководитель: «______» __________________ Копыткова Людмила Борисовна к. ф.-м. н., доцент Ставрополь, 2004 г. Оглавление Введение Глава 1. Теоретико-числовая база построения СОК § 1. Сравнения и их основные свойства § 2. Теорема о делении с остатком. Алгоритм Евклида § 3. Китайская теорема об остатках и её роль в представлении чисел в СОК § 4. Теоремы Эйлера и Ферма, их роль в вычислении мультипликативных обратных элементов по данному модулю § 5. Числа Мерсенна, Ферма и операции над ними Глава 2. Математические модели модулярного представления и параллельной обработки информации § 1. Представление числа в СОК. Модульные операции § 2. Основные методы и алгоритмы перехода от позиционного представления к остаткам § 3. Восстановление позиционного представления числа по его остаткам § 4. Расширение диапазона представления чисел Глава 3. Программная эммуляция алгоритмов перевода чисел из СОК в ПСС и обратно и алгоритма RSA Цитированная литература Введение Инженеры и программисты, а также математики знакомы с таким понятием как цифровая обработка сигналов. Напомним некоторые факты. Сигнал называется цифровым, если область значений последовательности ограничена конечным множеством действительных или комплексных чисел. Обработка сигналов универсальными цифровыми вычислительными машинами или специализированными цифровыми процессорами осуществляется путём выполнения ряда вычислительных операций над последовательностями чисел. В настоящее время существует несколько алгоритмов, предназначенных для использования в области цифровой обработки сигналов. Здесь же немалую роль играет система остаточных классов, основанная на элементарной теории чисел. Вообще, идею теории чисел для получения алгоритмов вычислений используют в 2-х наиболее важных направлениях обработки сигналов: - в вычислении свёртки; - в вычислении дискретного преобразования Фурье. Цель же дипломной работы: - установить взаимосвязь СОК и теории чисел; - изучить СОК и методы перевода чисел из ПСС в СОК и обратно; - разработать и выполнить программы на языке Paskal, содержащие различные методы перевода чисел из ПСС в СОК и обратно. Дипломная работа состоит из введения, трёх глав и списка литературы. Во введении даётся краткое обоснование поставленных задач. Первая глава содержит известные факты теории чисел в той мере, в какой они будут применяться в дальнейшем. Здесь излагаются самые элементарные понятия теории чисел, в частности, сравнения и их свойства, различные теоремы. А также главная теорема в СОК – китайская теорема об остатках. Вторая глава посвящена представлению чисел в СОК и различным методам перевода чисел из СОК в ПСС и от ПСС в СОК. Третья глава содержит программные разработки методов перевода чисел из ПСС в СОК и обратно. Глава 1. Теоретико-числовая база построения СОК § 1. Сравнения и их основные свойстваВозьмём произвольное фиксированное натуральное число p и будем рассматривать остатки при делении на р различных целых чисел. При рассмотрении свойств этих остатков и проведении операций над ними удобно ввести понятие сравнения по модулю. Определение. Целые числа а и b называются сравнимыми по модулю р,
если разность чисел а – b делится
на р, то есть, если
запись mod p будет означать, что Если разность а – b не делится на р, то запишем:
Согласно определению Примеры:
Теорема. а сравнимо с b тогда и только тогда, когда а и b имеют одинаковые остатки при делении на р, поэтому в качестве определения сравнения можно взять следующее: Определение: Целые числа а и b называются сравнимыми по модулю р, если остатки от деления этих чисел на р равны. Дадим основные свойства сравнений: 1. Рефлексивность отношения сравнимости: 2. Симметричность отношения сравнимости: если, 3. Транзитивность отношения сравнимости: если 4.
Если 5.
Если 6.
Если 7.
Если 8.
Если 9.
Если 10. Если 11. Если 12. Любое слагаемое левой или правой части сравнения можно перенести с противоположным знаком в другую часть. 13. Если 14. Если 15. Если При делении целого числа на модуль р в остатке получается 0, 1, 2, 3,…, р – 1 чисел. Отнесём все целые числа, дающие при делении на р один и тот же остаток в один класс, поэтому получится р – различных классов по модулю р. В один класс попадут равноостаточные числа, они называются вычетами друг друга. Обозначим через А0 класс вычетов, которые при делении на р дают остаток 0. Например, числа вида Через А1 числа, дающие при делении остаток 1. Например, числа вида Через А2 числа, дающие при делении остаток 2. Например, числа вида Через Ар-1 числа, дающие при делении остаток р – 1. Например, числа вида Полной системой вычетов по модулю р называется совокупность р-целых чисел, содержащая точно по одному представителю из каждого класса вычетов по модулю р. Каждый класс вычетов по модулю р содержит в точности одно из чисел совокупности всех возможных остатков от деления на р: 0, 1, …, р 1. Множество {0, 1, …, р – 1} называется полной системой наименьших неотрицательных вычетов по модулю р. Можно легко доказать, что любая совокупность р чисел (р >1), попарно несравнимых по модулю р, есть полная система вычетов по модулю р. Часто рассматривают полную систему наименьших положительных вычетов: 1, 2, …, р; полную систему наименьших по абсолютной величине вычетов:
Можно ввести в рассмотрение приведённую систему вычетов по модулю р, т. е. систему чисел, взятых по одному и только по одному из каждого класса, взаимно простого с модулем. Число классов, взаимно простых с модулем р, равно значению функции Эйлера φ(р). § 2. Теорема о делении с остатком. Алгоритм ЕвклидаРассмотрим пример. Пусть р = 6. Тогда имеем шесть классов разбиения множества целых чисел по модулю 6:
где через r обозначен остаток от деления целого числа на 6. Напомним теорему о делении с остатком: Теорема: Разделить число Легко доказывается, что
для любых целых чисел а и Один из методов
выполнения арифметических операций над данными целыми числами основан на
простых положениях теории чисел. Идея этого метода состоит в том, что целые
числа представляются в одной из непозиционных систем – в системе остаточных
классов. А именно: вместо операций над целыми числами оперируют с остатками от
деления этих чисел на заранее выбранные простые числа – модули Пусть Так как в кольце целых
чисел имеет место теорема о делении с остатком, т. е. Рассмотрим гомоморфное отображение:
Тогда каждому целому
числу А можно поставить в соответствие кортеж Важно отметить, что при
том нет никакой потери информации при условии, что Для дальнейшего нам
требуется расширенный алгоритм Евклида или его аналог – алгоритм нахождения
линейного представления наибольшего общего делителя целых чисел: если числа а
и b одновременно не равны нулю, то
существуют целые числа х и у, такие, что Действительно, пусть d – наименьшее целое положительное
число вида
что противоречит минимальности d. Выполнение свойства б) проверяется непосредственно: Рассмотрим теперь
расширенный алгоритм Евклида для нахождения линейного представления наибольшего
общего делителя
В левом столбце алгоритма записана последовательность делений, которая получается в результате работы алгоритма Евклида и которая разрешена относительно остатков. Согласно теореме Ламе (1844 г.) число делений, которое необходимо выполнить для нахождения (а, b), не превосходит числа цифр в меньшем из чисел а и b, умноженного на 5 (оценка наихудшего случая для алгоритма Евклида). Теорема Ламе доказывается на основе последовательности Фибоначчи. Там же доказывается, что
время выполнения алгоритма Евклида оценивается равенством откуда получается
следующая индуктивная процедура вычисления
Пример. Применим расширенный алгоритм Евклида к числам а = 342, b = 612. Весь алгоритм представим в виде следующей таблицы. Расширенный алгоритм Евклида
Заметим, что равенство § 3. Китайская теорема об остатках и её роль в представлении чисел в СОКФундаментальным положением, лежащим в основе модулярного представления чисел, является китайская теорема об остатках. Эта теорема формулируется следующим образом. Теорема. Пусть
Другими словами,
отображение, которое каждому целому числу х,
Существует много различных доказательств этой теоремы. Приведём конструктивное доказательство китайской теоремы об остатках. Доказательство. Найдём
число х,
для некоторого целого
числа
Теперь первые два сравнения могут быть заменены на одно
Применим теперь описанную процедуру к сравнению (3.2) и к одному из оставшихся сравнений системы (3.1). Повторяя этот процесс k 1 раз, мы в конечном итоге найдём число х, удовлетворяющее всем сравнениям системы (3.1). Докажем единственность
решения системы (3.1). Воспользуемся методом от противного. Предположим, что
существует другое решение для всех Пример. Решим систему сравнений Решение. Так как модули 13, 15, 19 попарно
взаимно простые числа, то данная система имеет единственное решение по модулю
Исходя из конструктивного доказательства китайской теоремы об остатках, можно записать алгоритм решения системы линейных сравнений рассматриваемого вида следующим образом (греко-китайский алгоритм). Вход: Пары Выход: х – единственное наименьшее
неотрицательное решение системы по модулю 1. Инициализация. Р:=1; х:=МОД( 2. Цикл для i от 1 до n – 1: q:=МОД( 3. х:= х + pq, где MOДINV – подпрограмма вычисления мультипликативного обратного элемента. 4. q:=МОД( 5. Вернуть х. Несложный анализ времени работы данного алгоритма показывает, что где § 4. Теоремы Эйлера и Ферма, их роль в вычислении мультипликативных обратных элементов по данному модулюВернёмся теперь к вопросу о мультипликативных обратных элементах в фактор-кольце Zp. Теорема. Пусть Теорема. Характеристика λ конечного поля – простое число. Рассмотрим два способа вычисления обратных мультипликативных элементов. Первый способ основан на рассмотренном выше алгоритме Евклида, второй – на теореме Эйлера. Первый способ. Из условия (а, р) = 1
получаем ах + ру = 1 или Второй способ. Предварительно напомним теорему Эйлера: (а, р) = 1 Малая теорема Ферма. Если р – простое число и а
произвольное целое число, не делящееся на р, то Следствие. В кольце Zp классов вычетов по модулю р
из Таким образом, для
вычисления мультипликативного обратного к классу Ясно, что при таком
методе вычисления мультипликативного обратного элемента задача сводится к
цепочке умножений и делений с остатком на модуль р. Эта задача решается
без особых трудностей, если наименьший положительный вычет Из китайской теореме об остатках следует следующее Утверждение. Пусть Таким образом,
т. е. кольцо классов
вычетов по модулю р раскладывается в прямое произведение колец классов
вычетов по модулям
Можно сделать вывод о
том, что произвольное целое положительное число А, 0 < A < P, где Как следует из китайской
теоремы об остатках, можно использовать любой соответствующий интервал § 5. Числа Мерсенна, Ферма и операции над ними При рассмотрении
отдельных классов простых чисел значительный интерес представляет вопрос о простых
числах вида Например, при р =
2, 3, 5, 7, 13, 17, 19 мы получаем простые числа Мерсенна: 3, 7, 31, 127, 8191,
131071, а при р = 11, 23, 29 числа Числа вида Необходимо отметить, что значения чисел Мерсенна и Ферма быстро растут. Это не позволяет использовать лишь их в качестве модуле СОК. При работе же на двоичных
компьютерах, иногда желательно выбирать модули
Другими словами, значение
каждого модуля на единицу меньше очередной степени 2. Такой выбор значения
модуля
Таким образом, значение
Здесь
Эти операции могут быть
эффективно выполнены, даже если
Формула (5.3) утверждает, в частности, что
Уравнение (5.3) следует из алгоритма Евклида и тождества
где mod означает операцию нахождения остатка от деления. Поэтому на компьютере с длиной слова 232 можно выбрать
что обеспечивает
эффективность сложения, вычитания и умножения целых чисел в интервале вплоть до
Как мы уже заметили,
операции преобразования чисел в СОК и обратно очень важны. Модулярное
представление
Если основание b = 2 и модули
где Тогда Поскольку Обратный переход от СОК к
позиционной системе счисления выполняется немного сложнее. Как мы видели при
доказательстве китайской теоремы об остатках, при вычислении обратных мультипликативных
элементов требуется уметь вычислять значение функции Эйлера, которое в общем
случае требует факторизации, т. е. разложения чисел Константы
и Тогда Вернёмся к общему случаю.
Так как
Тогда число будет удовлетворять
условиям Формулы (5.5) можно переписать следующим
Если это сделать, то
вместо Оценим с точки зрения вычислений на компьютере достоинства и недостатки последнего варианта формул (5.5) по сравнению с исходным вариантом этих формул. Пусть с Поэтому
Формула (5.6) – это
представление числа А по так называемому смешанному основанию, которое
можно перевести в двоичный, либо десятичный формат. Если интервал [0; P) не является необходимым (напомним,
что Важно отметить, что
представление (5.6) по смешанному основанию пригодно для сравнения величин двух
чисел, заданных в СОК. Так, если известно, что Операции сравнения двух
чисел или определения знака числа при представлении в СОК интуитивно понятны и
очень просты, поэтому можно было бы ожидать, что удастся найти значительно
более лёгкий способ выполнения такого сравнения, чем переход к представлению со
смешанным основанием. Однако следующая теорема утверждает, что вопрос этот не
простой, поскольку величина числа в СОК существенным образом зависит от всех
битов всех остатков Теорема. Примитивные корни по модулю р существуют тогда и только тогда, когда: 1) 2) 3) где р – любое
нечётное простое число, Таким образом, при всех других р примитивных корней нет. Доказательство теоремы можно найти, например, в книге [ ]. Эта теорема позволяет фактически дать полное описание группы U(Zp) для произвольного модуля р. Теорема. Пусть Как следствие отметим,
что для Пример. Пусть b обратно к а по модулю р. Проверить. Что b(2 – ab) обратно к а по модулю р2 и что b2(3 – 2ab) обратно к а2 по модулю р2. Решение. По условию Пример. Определим последовательность Проверить, что Решение. Первая часть задачи фактически повторяет рассуждения примера 1.5. Для второй части задачи полагаем p = 2, а = 11335, b0 = 1, k = 4. Тогда числом, обратным к а = 11335 по модулю 216 будет число b4, которое вычисляем последовательно:
Пример. Сколько элементов порядка 10 в следующей группе и каковы они? Z25; Решение. В группе Z25 элементов порядка 10 нет, так как |Z25| = 25, а 25 не делится на 10. Глава 2. Математические модели модулярного представления и параллельной обработки информации § 1. Представление числа в СОК. Модульные операцииВсякая вычислительная
структура тесно связана с системой счисления, в которой она работает. Под
системой счисления понимают совокупность приёмов обозначения (записи) чисел,
или точнее, способ кодирования (представления) элементов некоторой конечной
модели действительных чисел словами одного или более алфавитов. Кодирование
представляет собой инъективное отображение диапазона системы счисления на
декартово произведение его алфавитов, т. е. К любой кодовой системе применимы следующие требования: - возможность представления в данной системе любой величины в рассматриваемом, заранее назначенном диапазоне; - единственность представления – любая кодовая комбинация соответствует одному и только одному числу в заданном диапазоне; - простота оперирования с числами в данной системе счисления. Таким образом, коды чисел являются именами числовых объектов, составляющих числовой диапазон. Диапазоны как модели вещественных чисел должны с максимально доступной полнотой и простотой отражать свойства числового множества. Всякое представление чисел рабочего диапазона является лишь составным элементом соответствующей машинной арифметики и не может рассматриваться отдельно от неё. Арифметические свойства той или иной системы счисления прежде всего определяются характером межразрядных связей, появляющихся в ходе выполнения операций над кодовыми словами. Исследования показали, что в рамках обычной позиционной системы счисления (ПСС) значительного ускорения выполнения операций добиться невозможно. Это объясняется тем, что в ПСС значение разряда любого числа, кроме младшего, являющегося результатом двухместной арифметической операции, зависит не только от значения одноимённых операндов, но и от всех младших разрядов, т. е. ПСС обладает строго последовательной структурой. Сегодня, предпочтение отдаётся вычислительным структурам, обладающими способностями к параллельной обработке информации. Этими особенностями обладают непозиционные коды с параллельной структурой, которые позволяют реализовать идею распараллеливания операций на уровне выполнения элементарных арифметических действий. Эта мысль зародилась в середине 50-х годов прошлого века, когда чешские учёные М. Валах и Л. Свобода в своих исследованиях в области непозиционных систем счисления рассматривают представление чисел в виде набора остатков от деления на выбранные натуральные модули – основания системы. Подобную систему счисления стали называть системой остаточных классов (СОК) или модулярной системой счисления (МСС). Вслед за чешскими учёными возможность применения этой системы в ЭВМ рассмотрена в исследованиях американских учёных Айкена, Семона и Гарнера. Пусть заданы
положительные числа Возможность такого представления числа определяется теоремой о делении с остатком в кольце целых чисел. Теорема. Если
Несложно заметить, что
каждый остаток Установить взаимно-однозначное соответствие между целыми числами из диапазона [0, P) и их остатками позволяет китайская теорема об остатках. Возможность применения СОК в вычислительных алгоритмах обуславливается наличием определённого изоморфизма между математическими операциями над целыми числами и соответствующими операциями над системой целых неотрицательных остатков по отдельным модулям. Причём сложение, умножение, возведение в целую положительную степень любых целых положительных чисел совершенно идентичны соответствующим операциям, выполняемым над системой остатков. Пусть операнды А и
В, а также результаты операций сложения и умножения А + В и А·В
представлены соответственно остатками
и Выражения (1.3) можно переписать в виде Справедливость этих правил выполнения арифметических действий в СОК непосредственно вытекает из свойств сравнения. Действительно, на основании (1.1´) можно переписать в виде Из представления А и В по теореме о делении с остатком (1. 2´) следует, что
Тогда Откуда, В случае умножения Тогда
Следовательно, Примеры. Даны: р1 = 2, р2 = 3, р3 = 5, р4 = 7. А = (0, 0, 3, 4), В = (1, 1, 2, 0). Найти: А+В, А В, АВ. Решение. А+В = (0, 0, 3, 4) + (1, 1, 2, 0) = (1, 1, 0, 4). АВ = (0, 0, 3, 4)· (1, 1, 2, 0) = (0, 0, 1, 0). А – В = (0, 0, 3, 4) – (1, 1, 2, 0) = (1, 2, 1, 4). В отличие от позиционной системы счисления (ПСС), в которой число А представляется в виде где N – основание ПСС , значение числа в модулярном коде не зависит от местоположения каждого разряда в его представлении, а зависит от значения основания соответствующего разряда. Поэтому модулярный код является непозиционным. Таким образом, выполнение арифметических операций в модулярном коде производится независимо по каждому из модулей, что и указывает на параллелизм данной системы. Это обстоятельство определяет поразрядное выполнение операций. Это свойство избавит от необходимости «занимать» или «переносить» единицу старшего разряда, что приводит к появлению кодов с параллельной структурой. Это позволяет распараллелить алгоритмы при выполнении арифметических операций. Перевод чисел из ПСС в СОК при помощи выражения (1.1´) связан с реализацией операции деления, поэтому использование данного метода неэффективно. Итак, операции сложения и умножения над числами, представленными в СОК, сводятся к соответствующим операциям над цифрами этого представления. Это относится и к возведению в степень, к вычислению значений многочлена и т. п. Операция вычитания в СОК заменяется сложением с аддитивной инверсией отрицательного числа. Все эти операции модульные, т. е. не требуют позиционных характеристик обрабатываемых чисел. Исследования СОК выявили целый ряд её преимуществ. 1) Максимальный параллелизм. Для оценки уровня параллелизма системы счисления вводится специальный показатель где k – длина кода системы, n(v) – количество поразрядных показателей параллелизма 2) Малоразрядность остатков. Поэтому, ввиду малого количества возможных кодовых комбинаций появляется возможность построения табличной арифметики. При этом большинство операций превращаются в однотактовые, осуществляемые простой выборкой из таблиц. По мере совершенствования технологии производства запоминающих устройств с высокой плотностью записи информации, составляющих техническую систему табличного метода вычислений, интерес к СОК неуклонно возрастает. 3) Реализация принципа конвейерной обработки информации. Это означает, что при выполнении вычислений модульные и следующие за ним операции удаётся совместить по времени только тогда, когда очередные операции зависят от результатов текущих, ещё не закончившихся операций. Таким образом, алгоритмы модулярной арифметики обладают конвейерной структурой. 4) Высокая точность, надёжность, способность к самокоррекции. Причём в СОК можно построить непозиционные коды, обнаруживающие и исправляющие ошибки, которые являются полностью арифметическими, то есть в этих кодах информативная и контрольная части равноправны относительно любой операции. Эта особенность предоставляет возможность варьировать корректирующей способностью кода за счёт изменения точности вычислений. Конечно, и эта система не лишена недостатков. К ним относится невозможность визуального сравнения чисел, отсутствие признаков выхода результатов за пределы диапазона, ограниченность действия системы сферой целых положительных чисел, получение во всех случаях точного результата операции, что исключает возможность непосредственного округления результата, а также трудность выполнения немодульных операций. Но они не являются непреодолимыми. § 2. Основные методы и алгоритмы перехода от позиционного представления к остаткамОбработка информации в цифровых устройствах, функционирующих в СОК, осуществляется с помощью модульных и немодульных операций. К модульным операциям относятся операции сложения, вычитания и умножения. Анализ применения арифметики СОК показывает, что их звенья имеют одинаковую структуру, типовым элементом которой является последовательность вида где К немодульным операциям относятся операции, при которых значение того или иного результата разряда зависит от всех или нескольких разрядов исходного числа. Устройства, реализующие немодульные операции, довольно чётко разделяются на 2 типа. Примером устройства первого типа является устройство свёртки, обеспечивающее вычисление где Аi – значение i-го разряда исходного числа, представленного в позиционной системе счисления (ПСС); Qi – весовой коэффициент. Устройства свёртки широко используются в цифровых системах, функционирующих в СОК, представляющих существенную, а порой и основную часть оборудования, предназначенную для реализации ряда способов выполнения операций – перевода чисел из ПСС в СОК, деления произвольных чисел и некоторых других. Кроме того, такие устройства находят применение и в цифровых системах, функционирующих в ПСС. Примером устройств второго типа является устройство позиционного преобразования, обеспечивающие получение характеристик, указывающих на принадлежность числа, представленного в СОК, тому или иному интервалу диапазона представимых чисел. Математической основой устройств первого типа является определение наименьших неотрицательных вычетов, которые определяются свёртками исходного числа по каждому модулю. Для определения свёрток по каждому модулю необходимо перевести число из позиционной системы счисления в систему остаточных классов. Перевод числа в систему остаточных классов можно осуществить методом деления. Однако из-за операции деления техническая реализация такого метода не эффективна для машинного использования, кроме того, данный метод требует применения арифметического устройства в позиционной системе счисления. Рассмотрим метод перевода числа из позиционной системы счисления в СОК, не содержащий операции деления, называемый методом непосредственного суммирования модульных значений разрядов позиционного числа. Пусть число X записано в позиционной системе счисления с основанием N, т. е. где Представим степени
основания Ni и коэффициенты Ai в системе остаточных классов с
основаниями Подставим (2.4´) в (2.3´), получим
Таким образом, для
образования числа Х в СОК требуется k констант, являющихся степенями Имея в памяти процессора
массив из Рассмотренный метод является основой широкого выбора возможных аппаратурных реализаций цифровых преобразователей ПСС – СОК, которые различаются между собой как по составу и количеству используемых элементов, так и по скорости преобразования информации. Известные в литературе цифровые преобразователи ПСС – СОК, основанные на данном методе, анализ которых позволил сделать важные выводы о том, что одним из существенных недостатков подобных преобразователей являются большие аппаратурные затраты при переводе чисел большой разрядности и низкое быстродействие. Повышенные требования, связанные с уменьшением аппаратурных средств и увеличением скорости обработки информации, привели к необходимости глубокого изучения вопросов разработки эффективных алгоритмов. Для решения этой задачи предлагаются два метода. Рассмотрим первый метод. Для этого докажем следующую теорему, которая является основой нового метода преобразования чисел из ПСС в СОК как аппаратурными, так и программными способами. Теорема. Пусть число Х записано в позиционной системе счисления с основанием N и если а Доказательство. Рассмотрим второй метод, который нашёл широкое применение в литературе. Назовём его методом последовательного умножения и суммирования. Суть метода состоит в следующем. Пусть число записано в виде (2.3´). Иначе это выражение можно записать
Т. е. значение числа Х
в СОК по модулю Следует отметить, что рассмотренный метод позволяет реализовать весьма экономичные, в смысле аппаратурных затрат, цифровые устройства преобразования информации. § 3. Восстановление позиционного представления числа по его остаткам Система остаточных классов обладает одной особенностью, которую можно отнести к недостаткам этой системы: нельзя визуально определить величину числа, представленного в СОК, а следовательно затруднительно и выполнение таких операций, как сравнение чисел, определение знака числа. Один из путей решения этой проблемы состоит в преобразовании чисел из СОК в позиционную систему счисления. Оценим существующие способы перевода, как традиционные: метод ортогональных базисов; перевод числа в обобщенную позиционную систему (ОПС), так и недавно появившиеся интервальные методы перевода. 1). Метод восстановления числа по его остаткам был найден еще в Китае две тыс. лет назад. Основой этого метода является теорема, названная, поэтому Китайской теоремой об остатках (КТО). Теорема. Пусть Эта теорема лежит в основе метода ортогональных базисов при переводе из системы остаточных классов в позиционную систему счисления. Пусть основания системы
остаточных классов
которые называются ортогональными. Тогда в случае
ортогональных базисов
где
Тогда, по Китайской теореме, число
Таким образом, если
найдены ортогональные базисы для системы оснований, то для перевода числа
где Пример. Пусть дана система оснований Вычислим ортогональные базисы. Для этого найдем величины
Ищем веса базисов: 1155 770 462 330 210 Тогда получаем сами базисы:
Вычислим величину числа
Так как ортогональные
базисы Недостаток рассмотренного
метода заключается в том, что приходится иметь дело с большими числами 2). Другой метод
определения величины числа связан с переводом числа из системы остаточных
классов в ОПС. Для того чтобы рассмотреть этот метод, выявим связь между
представлением некоторого числа
+ где 0 £ Очевидно, что диапазоны чисел, представимых в СОК и ОПС совпадают, т.е. можно говорить о наличии взаимооднозначного соответствия между множеством представлений чисел в СОК и ОПС. Равенство (3.5´) можно переписать в виде
откуда следует, что цифры ОПС могут быть получены из соотношений:
…
Причем при определении
цифр Действительно, из
(3.6´) следует, что
Перевод, осуществляемый
согласно алгоритму (3.6´),содержит всего 2(
Эти константы можно, например получить из расширенного алгоритма Евклида
Здесь следует заметить
тот факт, что константы Если константы
Константы Рассмотрим алгоритм (3.9´) на примере. Пример. Пусть дана система оснований Найдем сначала константы
Для удобства константы Выполнение алгоритма (3.9´) представлено в таблице Перевод числа из СОК в ОПС
Таким образом,
= 7 · 2 · 3 ·5 · 7 + 0 · 2 · 3 · 5 + 1 · 2 · 3 + 2 · 2 + 1 = 1481. Преимущество
рассмотренного метода перед методом ортогональных базисов состоит в том, что
все вычисления выполняются в модулярной арифметике, причем в отдельных каналах,
соответствующих модулям Один из вариантов уменьшения числа операций в рассмотренном алгоритме может быть достигнут путём особого выбора системы оснований. Выберем систему оснований СОК следующим образом: Очевидно, что основания
такой системы взаимно простые числа. Эта система обладает той особенностью, что
где Пример. Выберем систему оснований по указанному принципу:
Введем новые обозначения
Пусть в системе оснований
Метод перевода чисел из СОК в ОПС на основе выбора системы оснований
Таким образом, Как видно, при указанном
выборе системы оснований число операций уменьшается вдвое, т.к. необходимо для
осуществления перевода совершить
для которых все константы
Другая модификация алгоритма (3.9´) основывается на факте, что если в процессе перевода появляется определенная комбинация цифр, то оставшиеся цифры числа в ОПС можно сразу определить и процесс перевода может быть завершен. К условиям, которые могут завершить процесс перевода до выполнения последнего шага алгоритма (3.9´) можно отнести следующие: 1.
Если при
определении цифры 2.
Если при
определении цифры Рассмотрим примеры, иллюстрирующие эти случаи. Пример. Пусть основания системы Переведем числа Для числа Метод перевода числа
Тогда согласно пункту 1, Для числа Метод перевода числа
Тогда согласно пункту 2, Таким образом , При использовании
предложенного метода число операций в процессе перевода чисел в ОПС
уменьшается. Причем наибольшая выгода наблюдается при небольших по абсолютной
величине основаниях системы. Было подсчитано, что при использовании
рассмотренных приемов число операций в процессе перевода числа из СОК в ОПС,
например, для системы модулей Еще можно отметить, что
специальный выбор оснований СОК может позволить вычисление констант
Тогда для определения
констант
где целые числа
3). Достаточно эффективными методами перевода чисел из СОК в ПСС являются интервальные методы, основанные на интервальных характеристиках чисел. Одна из таких характеристик номер интервала. Рассмотрим СОК, заданную
системой оснований в котором находится число
Так как ( где Для определения номера
интервала Учитывая, что Так как где
постоянные коэффициенты, определённые системой оснований. Таким образом, Подставляя (3.20´)
в (3.15´), получим позиционное представление числа В качестве дробирующего модуля
целесообразнее выбирать наибольший из модулей системы. В этом случае модульные
операции выполняются при меньшей величине модуля, что ведёт к меньшим временным
и аппаратурным затратам. Целесообразно также для упрощения вычислений и
минимизации времени выполнения операций выбирать в качестве дробирующего модуля
Проиллюстрируем рассмотренный метод на примере. Пример. Пусть дана система оснований
Тогда Таким образом, На основе этой же
характеристики числа – номера интервала, с применением теоремы Эйлера
предлагается алгоритм перевода числа в ПСС. Разность между модулями можно
представить в виде
но с другой стороны
Из (3.22´) и
(3.23´) следует, что Так как Решение сравнения (3.24´) можно записать в виде
где Перепишем (3.15´) с учётом (3.25´)
где
где
Где
Тогда искомая величина
числа Пример. Пусть основания СОК § 4. Расширение диапазона представления чиселРасширение системы оснований является одной из основных немодульных операций в СОК. Выполнение этой операции бывает необходимо при выполнении операции деления чисел, при вычислении позиционных характеристик, при обнаружении переполнения при выполнении сложения или умножения чисел. Задачу расширения системы оснований можно сформулировать следующим образом: найти остаточное представление числа по новому основанию (новым основаниям), если известно представление числа по другим основаниям остатки от деления на другие числа. Один из путей расширения системы оснований состоит в переводе числа в позиционную систему счисления и вычисления остатка от деления на новый модуль. Этот путь не является рациональным с точки зрения числа операций. Другой метод расширения
системы оснований позволяет определить цифру числа по новому основанию,
базируясь на таких позиционных характеристиках числа, как ранг числа, след
числа. Пусть вновь задана система оснований Чтобы получить формулы
для цифры
где Приравнивая правые части
этих выражений, определяем , или обозначая через
Формула (4.1´) и есть формула расширения диапазона чисел. Для практической реализации этой формулы поступают следующим образом: 1. Вычисляют параметры основной и расширенной систем (ортогональные базисы, их веса, минимальные псевдоортогональные числа с их рангами и кратности). 2.
Конструируют
число
где 3.
Расширяют число 4.
Если 5.
Если 6.
Если кратность 7.
Если Еще один путь решения поставленной задачи представляет собой перевод числа из СОК в ОПС с дополнительным финальным шагом. Рассмотрим этот метод. Пусть СОК состоит из
оснований Пусть число Для определения этой
цифры рассматриваем алгоритм перевода числа из СОК в ОПС, включая неизвестную
цифру Пример. Пусть задана система модулей Процесс решения задачи покажем Расширение оснований модулярного кода
Таким образом, а5
=
Этот алгоритм может быть несколько видоизменен за счет следующего свойства:
Фактически величина Пусть по этому алгоритму
будет получено что
Рассмотрим на том же примере эту модификацию алгоритма. Модифицированный метод расширения оснований модулярного кода
Тогда Тогда финальный шаг для
определения цифры по новому основанию может быть записан как
Так как результат
образования цифры в СОК по новому основанию Пример. Пусть задана система оснований
объем диапазона Найдем расширенное представление
этого числа, добавляя модули Для этого запишем нули в качестве неизвестных цифр и примем вышерассмотренный алгоритм расширения системы оснований. Константы Тогда получаем Расширение модулярного кода по нескольким основаниям
Цифры по основаниям
откуда получаем Таким образом, число
Преимущества метода расширения системы основания с помощью перевода в ОПС состоит в том, что: во-первых, все вычисления идут в параллельных каналах по определенным модулям; во-вторых, не требуется
вычисление большого количества дополнительных величин (необходимо наличие в
памяти только констант в-третьих, возможно получение расширенного представления числа сразу по нескольким дополнительным основаниям, что не влияет на быстродействие всей операции. Глава 3. Программная эмуляция алгоритмов перевода чисел из СОК в ПСС и обратно и алгоритма RSA Программа №1 {SN+,E+}{Создание программного кода одинаково пригодного при работе на ПЭВМ с математическим сопроцессором или без него} program Eyler; uses crt; type mas=array[1..20] of longint; var i,n,b,c,d,v,x,f,f1:longint; w:real; a,p:mas; r:string; {Оформление экрана} procedure visitka; begin writeln(‘ Министерство образования Российской Федерации ‘); writeln(‘ Ставропольский государственный университет ‘); writeln(‘ Кафедра алгебры ‘); writeln(‘ ‘); writeln(‘Дипломная работа ‘); writeln(‘ ‘); writeln(‘ Методы перевода чисел из системы остаточных классов‘); writeln(‘ в позиционную систему счисления ‘); writeln(‘ ‘); writeln(‘ Выполнила: Пивоварова Елена Николаевна, ‘); writeln(‘ФМФ, 5 курс, гр. Б ‘); writeln(‘Научный руководитель:‘); writeln(‘заведующая кафедрой алгебры‘); writeln(‘Копыткова Людмила Борисовна ‘); writeln(‘‘); writeln(‘ Нажмите клавишу <Enter> ‘); writeln(‘ ‘); writeln(‘Теоретические сведения‘); writeln(‘ Программа позволяет производить перевод числа‘); writeln(‘ А=(а1, а2, ,аn), представленного в СОК с основаниями ‘); writeln(‘ р1, p2 ,…,pn такими, что р1< p2 <…<pn и p(i) – простые ‘); writeln(‘числа, в позиционную систему счисления методом, ‘); writeln(‘основанным на применении функции Эйлера. Данный метод‘); writeln(‘заключается в следующем: для нахождения числа A в‘); writeln(‘позиционной системе счисления берутся 2 модуля:p(i) и p(i+1),‘); writeln(‘причем p(i) > p(i+1), и соответствующие им остатки а(i) и а(i+1). ‘); writeln(‘Находится наименьший неотрицательный вычет по модулю ‘); writeln(‘p(i) * p(i+1). Применяя эту операцию многократно и переходя ‘); writeln(‘к составным модулям, осуществляют перевод чисел. ‘) writeln;writeln;writeln; writeln ('Нажмите клавишу <Enter>...'); readln; clrscr; end; {visitka} {Вычисление наименьшего неотрицательного вычета} procedure vich (var v:longint; a,m:longint); begin if a<0 then v:=a+m else v:=a mod m end;{vich} {Тест простого числа} function test (ch:longint):boolean; var i:longint; begin i:=2; while (i<=ch) and ((ch mod i)<>0) do i:=i+1+(i mod 2); if i=ch then test:=true else test:=false; end;{test} {Ввод данных} procedure DataEnter; var i:longint; begin write('Введите число модулей:'); readln(n); writeln('Ввод значения модулей (p(i)<=30, p(i)-простые,'); writeln('p(i)<p(i+1)):'); for i:=1 to n do begin while true do begin write('Модуль p',i ,'= '); readln(p[i]); if (p[i]<=30) and Test(p[i]) then begin if i<>1 then begin if p[i]>p[i-1] then break; end else break; end; end;{while} end;{for} writeln('Ввод числа в СОК (a(i)>=0 и a(i)<p(i)):'); for i:=1 to n do begin while true do begin write('a[',i,']='); readln(a[i]); if (a[i]>=0) and (a[i]<p[i]) then break; end;{while} end;{for} end;{DataEnter} {Перевод числа в ПСС} procedure Calcx(var x:longint;p,a:mas); var i,b,c,f1:longint; begin f1:=p[2]; for i:=2 to n do begin {Вычисление функции Эйлера} if p[1]<p[i] then f:=p[i]-1;{f-значение функции Эйлера, если} {p[i]-простое число} f1:=f1*(p[i]-1); if p[1]>p[i] then begin b:=p[1];p[1]:=p[i];p[i]:=b; c:=a[1];a[1]:=a[i];a[i]:=c; f:=f1 {f - значение функции Эйлера, если} {f - составное число} end; {Перевод числа } w:=exp((f-1)*ln(p[i]-p[1])); vich(d,round(w),p[i]); vich(v,a[1]-a[i],p[i]); vich(v,d*v,p[i]); x:=v*p[1]+a[1]; p[1]:=p[1]*p[i]; a[1]:=x; end end;{Calcx} begin repeat clrscr; visitka; dataenter; calcx(x,p,a); writeln('A= ',x); writeln('Повторить? (y/n): '); readln(r); until (r= 'n') end. Министерство образования Российской Федерации Ставропольский государственный университет Кафедра алгебры Дипломная работа Методы перевода чисел из системы остаточных классов в позиционную систему счисления Выполнила:Пивоварова Елена Николаевна, ФМФ, 5 курс, гр. Б Научный руководитель: заведующая кафедрой алгебры Копыткова Людмила Борисовна Нажмите клавишу <Enter> Теоретические сведения Программа позволяет производить перевод числа А=(а1, а2, ,аn), представленного в СОК с основаниями р1, p2 ,…,pn такими, что р1< p2 <…<pn и p(i) – простые числа, в позиционную систему счисления методом, основанным на применении функции Эйлера. Данный метод заключается в следующем: для нахождения числа A в позиционной системе счисления берутся 2 модуля: p(i) и p(i+1), причем p(i) > p(i+1), и соответствующие им остатки а(i) и а(i+1). Находится наименьший неотрицательный вычет по модулю p(i) * p(i+1). Применяя эту операцию многократно и переходя к составным модулям, осуществляют перевод чисел. Результаты работы программы Нажмите клавишу <Enter>… Введите число модулей:2 Ввод значения модулей (p(i)< =30, p(i)-простые, p(i)< p(i+1)): Модуль р1=17 Модуль р2=19 Ввод числа в СОК (а(i)>=0 и (а(i)<p(i)): a[1]=2 a[2]=3 A=155 Повторить? (у/n): y Введите число модулей:3 Ввод значения модулей (p(i)< =30, p(i)-простые, p(i)< p(i+1)): Модуль р1=2 Модуль р2=3 Модуль р3=5 Ввод числа в СОК (а(i)>=0 и (а(i)<p(i)): a[1]=1 a[2]=2 a[3]=4 A=29 Повторить? (у/n): n Программа №2 program COK_Poliandr; type mas1=array [1..10] of integer; mas2= array [1..10,1..10] of integer; var p, a, o: mas1; t: mas2; Aonc, PP, i, j, y, k, n, f : integer; begin writeln ('Перевод чисел из СОК в обобщенную систему счисления '); write ('Введите размер системы оснований = '); readln (n); writeln ('Введите каждое основание '); PP:=1;{Присвоение начального значения объему диапазона} for i:=1 to n do begin {Ввод системы оснований и вычисление объёма диапазона} write ('p[',i,']= '); readln (p[i]); PP:=PP*p[i]; end; writeln ('Объем диапазона Р =',PP); writeln ('Введите число в СОК по цифрам: '); for i:=1 to n do begin{Ввод исходного числа в СОК} write (i,' цифра = '); readln (a[i]); end; write('Переведём число А = ( '); {Вывод на экран исходного числа} for i:=1 to n do write (a[i],','); writeln(') в ОПС.'); writeln ('На первом этапе получим матрицу констант '); for k:=1 to n do for J:=k to n do{Вычисление матрицы обратных элементов по умножению для чисел pk по модулю pj} begini:=0; f:=0; repeat if (1+i*p[j]) mod p[k] =0 then begin t[k,j]:=(1+i*p[j]) div p[k];f:=1;{Флаг поднят, если произошло вычисление константы} end; i:=i+1; until (i>n) or (f=1);{Выход из цикла, если поднят флаг или превышено значение параметра} end; for k:=1 to n do begin{Вывод полученной матрицы} for J:=1 to n do write(t[k,j],' '); writeln; end; write ('Затем получим цифры ОПС: '); for j:=1 to n do begin o[j]:=a[j];{Получение очередной цифры} for i:=j to n do begin if a[i]>=o[j] then a[i]:=a[i]-o[j] {Первое действие} else a[i]:=a[i]+p[i]-o[j]; a[i]:=a[i]*t[j,i]; {Второе действие} if a[i]>p[i] then a[i]:=a[i] mod p[i]; end; write(o[j],' ');{Вывод очередной цифры ОПС} end; writeln; write ('В итоге, получим число: '); Aonc:=0; y:=1;{Обнуление результата} for i:=1 to n do begin{Получение числа в позиционной системе счисления по его цифрам } Aonc:= Aonc+y*o[i]; y:=y*p[i]; end; writeln (Aonc);{Вывод полученного результата} readln;{Задержка результата на экране до нажатия клавиши ENTER} end. Результаты работы программы Перевод чисел из СОК в обобщенную систему счисленияВведите размер системы оснований = 5 Введите каждое основание p[1]=2 p[2]=3 p[3]=5 p[4]=7 p[5]=11 Объем диапазона Р =2310 Введите число в СОК по цифрам: 1 цифра = 1 2 цифра = 2 3 цифра = 1 4 цифра = 4 5 цифра = 7Переведём число А = ( 1, 2, 1, 4, 7,) в ОПС. На первом этапе получим матрицу констант 0 0 2 3 4 5 0 0 0 2 5 4 0 0 0 0 3 9 0 0 0 0 0 8 0 0 0 0 0 0 Затем получим цифры ОПС: 1 2 1 0 7 В итоге, получим число: 1481 Применение СОК не ограничивается только переводом чисел из СОК в ПСС и обратно. Например, ещё СОК можно использовать для шифровки сообщений. Программа №3 В данной программе реализуется шифрование и расшифрование сообщения методом RSA. Блок-схема алгоритма нахождения А-1 mod N
Блок-схема алгоритма нахождения простых чисел не превышающих N
#include <vcl.h> #pragma hdrstop #include "Unit1.h" #include <math.h> #pragma package(smart_init) #pragma resource "*.dfm" using namespace std; TForm1 *Form1; __fastcall TForm1::TForm1(TComponent* Owner) : TForm(Owner) { } void __fastcall TForm1::Button2Click(TObject *Sender) { Close(); } void __fastcall TForm1::Button1Click(TObject *Sender) { Log->Lines->Clear(); srand( GetTickCount() ); // Ввод P и Q
int p = StrToInt( Edit1->Text ); int q = StrToInt( Edit2->Text ); Log->Lines->Add( "p = " + IntToStr( p ) ); Log->Lines->Add( "q = " + IntToStr( q ) ); // Вычисление N int N = p * q; Log->Lines->Add( "N = p*q = " + IntToStr( N ) ); // Вычисление f(N) int f = (p-1)*(q-1); Log->Lines->Add( "f(n)=(p-1)(q-1) = " + IntToStr( f ) ); // Ввод открытого ключа K1 int k1 = StrToInt( edtOK->Text ); Log->Lines->Add( "k1 = " + IntToStr( k1 ) ); // Проверка условий существования открытого ключа if( NOD( k1, f ) != 1 ) { Log->Lines->Add( "открытый ключ и f(n) не взаимно простые. введите новые параметры" ); return; } // Нахождение секретного ключа int k = ObrElem( k1, f ); Log->Lines->Add( "k = k1^(-1) mod f(n) = " + IntToStr( k ) ); AnsiString clear = Edit3->Text; AnsiString coded; // Шифрование и расшифрование сообщения coded = ""; int *clear_c = new int[clear.Length()]; int *coded_c = new int[clear.Length()]; int *clr_c = new int[clear.Length()]; for( int i = 1; i <= clear.Length(); i++ ) { clear_c[i-1] = (int)clear[i]; coded_c[i-1] = ModStep( clear_c[i-1], k1, N ); clr_c[i-1] = ModStep( coded_c[i-1], k, N ); char temp[256]; wsprintf( temp, "%c = %c = %c", clear[i], (char)coded_c[i-1], (char)clr_c[i-1] ); Log->Lines->Add( temp ); wsprintf( temp, "%c", (char)coded_c[i-1] ); coded += temp; } delete[] clr_c; delete[] coded_c; delete[] clear_c; // Вывод полученных результатов Log->Lines->Add( "clear text = " + clear ); Log->Lines->Add( "coded text = " + coded ); Log->Lines->Add( "" ); } // Модуль нохождения НОД (a, b) int __fastcall TForm1::NOD(int a, int b) { if( ( a == 0 )||( b == 0 ) ) { return abs( a + b ); } while( a != b ) { if( a > b ) { a -= b; } else { b -= a; } } return b; } //Модуль нахождения обратного элемента по модулю N int __fastcall TForm1::ObrElem(int a, int N) { int u1 = 0, u2 = 1, u3 = N; int v1 = 1, v2 = 0, v3 = a; int t1, t2, t3, q; while(u3 != 1) { q = u3 / v3; t1 = u1 - v1*q; t2 = u2 - v2*q; t3 = u3 - v3*q; u1 = v1; u2 = v2; u3 = v3; v1 = t1; v2 = t2; v3 = t3; } return u1 < 0 ? u1 + N : u1; } // Модуль возведения числа в степень по модулю N int __fastcall TForm1::ModStep(int a, int d, int n) { int aBmodN = a; int dtemp = d; AnsiString binary = ""; while( dtemp > 1 ) { binary += IntToStr( dtemp % 2 ); dtemp = floor( dtemp / 2 ); } binary += dtemp; for( int i = 1; i < binary.Length(); i++ ) { aBmodN = aBmodN*aBmodN * ( binary[binary.Length() - i] == '0' ? 1 : a ) % n; } return aBmodN; } void __fastcall TForm1::Button3Click(TObject *Sender) { int q = 0; int p = 0; int *a = new int[256]; prost( a, 64 ); srand( GetTickCount() ); while( ( p == 0 )||( p > 64 ) ) { p = a[ rand() % 64-1 ]; } while( ( q == 0 )||( q > 64 ) ) { q = a[ rand() % 64-1 ]; } Edit1->Text = FloatToStr( p ); Edit2->Text = FloatToStr( q ); delete[] a; } // Модуль нахождения простых чисел на превышающих N методом решета Эратосфера void __fastcall TForm1::prost( int *a, int n ) { int b, c; for( b = 1; b <= n; b++ ) { a[b] = b; } for( b = 2; b <= floor( sqrt( n ) ); b++ ) { c = 0; c += ( b << 1 ); while( c <= n ) { a[c] = 0; c += b; } } } Цитированная литература 1. Бухштаб А. А. Теория чисел – М: Наука, 1975 г. 2. Айерленд К. Классическое введение в современную теорию чисел. М: Мир, 1987. 3. Акушинский И. Л., Юдицкий Д. И. Машинная арифметика в остаточных классах. – М. Советское радио, 1968. 4. Амербаев В. М. Теоретические основы мащинной арифметики, - Алма –Ата: Наука, 1976. 5. Червяков Н. И. Применение нейронных сетей для прямого и обратного преобразования кодов в СОК. Вестник СГУ, Физ.-мат. науки, 1999. 6. Червяков Н. И. Применение системы остаточных классов в цифровых системах обработки и передачи информации. Ставрополь: СВВиУС, 1984. 7. Червяков Н. И. Преобразование цифровых позиционных и непозиционных кодов в системах управления и связи. Ставрополь: СВВиУС, 1985. 8. Коляда А. А., Пак И. Т. Модулярные структуры конвейерной обработки цифровой информации, - Минск: Университетское, 1992. 9. Онищенко С. М. Применение гиперкомплексных чисел в теории инерциальной навигации. Автономные системы, - Киев: Наукова думка, 1983. |
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||