3. х:= х + pq, где MOДINV – подпрограмма вычисления мультипликативного обратного элемента.
4. q:=МОД(
5. Вернуть х.
Несложный анализ времени работы данного алгоритма показывает, что
где - количество цифр числа Р, т. е. длина числа Р, при этом функция L ведёт себя как логарифм.
§ 4. Теоремы Эйлера и Ферма, их роль в вычислении мультипликативных обратных элементов по данному модулюВернёмся теперь к вопросу о мультипликативных обратных элементах в фактор-кольце Zp.
Теорема. Пусть , тогда класс имеет мультипликативный обратный элемент по модулю р тогда и только тогда, когда (, р) = 1.
Теорема. Характеристика λ конечного поля – простое число.
Рассмотрим два способа вычисления обратных мультипликативных элементов. Первый способ основан на рассмотренном выше алгоритме Евклида, второй – на теореме Эйлера.
Первый способ. Из условия (а, р) = 1 получаем ах + ру = 1 или и, следовательно, х – мультипликативный обратный к а по модулю р.
Второй способ. Предварительно напомним теорему Эйлера:
(а, р) = 1, доказательство которой достаточно простое и мы его не приводим, так как его можно найти в любой книге по теории чисел. Частным случаем теоремы Эйлера является малая теорема Ферма.
Малая теорема Ферма. Если р – простое число и а – произвольное целое число, не делящееся на р, то .
Следствие. В кольце Zp классов вычетов по модулю р из следует, что
Таким образом, для вычисления мультипликативного обратного к классу по модулю р в случае, когда , достаточно возвести в степень k, где k = р – 2, если р – простое число, и в противном случае.
Ясно, что при таком методе вычисления мультипликативного обратного элемента задача сводится к цепочке умножений и делений с остатком на модуль р. Эта задача решается без особых трудностей, если наименьший положительный вычет , где , представлен в СОК. Однако возникает вопрос об эффективности этого метода. Другими словами, является ли наименьшим показателем степени, для которого ? Оказывается, что нет.
Из китайской теореме об остатках следует следующее
Утверждение. Пусть - каноническое представление числа р. Тогда функция, которая каждому классу ставит в соответствие кортеж , где для , является кольцевым изоморфизмом кольца класса вычетов по модулю р и кольца кортежей вида , где для . Более того, если обозначить через * любую из кольцевых операций + или · , то
Таким образом,
,
т. е. кольцо классов вычетов по модулю р раскладывается в прямое произведение колец классов вычетов по модулям . Это разложение колец индуцирует разложение групп их обратимых элементов:
.
Можно сделать вывод о том, что произвольное целое положительное число А, 0 < A < P, где и для , однозначно представимо своими наименьшими неотрицательными остатками по модулю , причём сложение (а, следовательно, и вычитание) и умножение выполняются покомпонентно.
Как следует из китайской теоремы об остатках, можно использовать любой соответствующий интервал целых чисел. Например, можно работать только с неотрицательными целыми числами, меньшими Р. С другой стороны, при выполнении операций сложения и вычитания, так же, как и умножения, обычно удобнее всего предположить, что все модули являются нечётными целыми числами, так что и тоже нечётное, и можно работать с целыми числами из интервала , симметричного относительно нуля.
§ 5. Числа Мерсенна, Ферма и операции над ними
При рассмотрении отдельных классов простых чисел значительный интерес представляет вопрос о простых числах вида , где m – нечётное, именуемые числами Мерсенна. При простых значениях m = p число может оказаться простым, но может быть составным.
Например, при р = 2, 3, 5, 7, 13, 17, 19 мы получаем простые числа Мерсенна: 3, 7, 31, 127, 8191, 131071, а при р = 11, 23, 29 числа - составные.
Числа вида , где k – положительное, обычно называют числами Ферма. При k = 0, 1, 2, 3, 4 числа Ферма простые: 3, 5, 17, 257, 65537. Все остальные числа Ферма – составные. Все числа Мерсенна и Ферма – взаимно простые.
Необходимо отметить, что значения чисел Мерсенна и Ферма быстро растут. Это не позволяет использовать лишь их в качестве модуле СОК.
При работе же на двоичных компьютерах, иногда желательно выбирать модули в виде чисел Мерсенна
. (5.1)
Другими словами, значение каждого модуля на единицу меньше очередной степени 2. Такой выбор значения модуля зачастую упрощает выполнение основных арифметических операций, так как выполнять вычисления с числами, представленными по модулю , несколько проще, чем с числами, представленными в обратном коде. После того как значения модулей таким образом выбраны, полезно несколько ослабить условие и потребовать чтобы только
, . (5.2)
Таким образом, значение принимается в качестве оптимального вместо , поскольку это, с одной стороны, не влияет на справедливость китайской теоремы об остатках, а с другой означает, что может быть любым - битовым двоичным числом. При таком допущении, операции сложения и вычитания по модулю выполняются следующим образом:
,
.
Здесь и указывают на действия, которые с учётом условия (5.2) должны быть выполнены с отдельными компонентами кортежей и при сложении или умножении соответственно. При вычитании можно пользоваться и соотношением:
.
Эти операции могут быть эффективно выполнены, даже если больше машинного слова компьютера, так как совсем просто вычислить остаток положительного числа по модулю степени 2 или разложить число по степеням 2. Для работы с модулями вида необходимо знать, при каких условиях число является взаимно простым с числом . Для этого существует простое правило:
. (5.3)
Формула (5.3) утверждает, в частности, что
.
Уравнение (5.3) следует из алгоритма Евклида и тождества
,
где mod означает операцию нахождения остатка от деления. Поэтому на компьютере с длиной слова 232 можно выбрать
, ,, , ,
что обеспечивает эффективность сложения, вычитания и умножения целых чисел в интервале вплоть до .
Как мы уже заметили, операции преобразования чисел в СОК и обратно очень важны. Модулярное представление для заданного числа А может быть получено посредством деления А на с запоминанием остатков. В случае, когда , возможно применение более подходящего способа, который состоит в том, чтобы, используя СОК, вычислить полином
.
Если основание b = 2 и модули имеют вид , оба подхода сводятся к совсем простому способу. Рассмотрим двоичные представления числа А с блоками по бит:
,
где и при .
Тогда ,
Поскольку . Поэтому вычисляются путём сложения битовых чисел .
Обратный переход от СОК к позиционной системе счисления выполняется немного сложнее. Как мы видели при доказательстве китайской теоремы об остатках, при вычислении обратных мультипликативных элементов требуется уметь вычислять значение функции Эйлера, которое в общем случае требует факторизации, т. е. разложения чисел на простые множители. Даже это обстоятельство показывает, что обратное преобразование чисел из СОК в позиционную систему счисления приводит к большому числу вычислительных операций с высокой точностью, а именно этого нам хотелось бы избежать прежде всего. Поэтому, чтобы найти действительно пригодный для практического применения метод перехода от к А, необходимо иметь другое доказательство китайской теоремы об остатках. Такое доказательство предложено в 1958 г. Х. Л. Гарнером. Оно основано на использовании констант , где . (5.4)
Константы можно вычислить с помощью расширенного алгоритма Евклида, который по заданным i и j позволяет определить числа a и b такие, что , и можно положить . В частности, для величины, обратной к по модулю , легко получить сравнительно простую формулу
, где
и . Действительно, если , то . Поэтому при имеем ; а так как эти последние величины расположены между нулём и , должно быть .
Тогда
Вернёмся к общему случаю. Так как , удовлетворяют условиям (5.4), то можно выполнить присваивания
,
,
, (5.5)
.
Тогда число
(5.6)
будет удовлетворять условиям ,
для . (5.5)
Формулы (5.5) можно переписать следующим
,
,
,
Если это сделать, то вместо констант как в (5.5), потребуется только k – 1 констант
Оценим с точки зрения вычислений на компьютере достоинства и недостатки последнего варианта формул (5.5) по сравнению с исходным вариантом этих формул.
Пусть . Тогда для некоторого постоянного числа
с .
Поэтому
. Таким образом,
. (5.6)
Формула (5.6) – это представление числа А по так называемому смешанному основанию, которое можно перевести в двоичный, либо десятичный формат. Если интервал [0; P) не является необходимым (напомним, что ), то после завершения процесса к нему можно добавить (или вычесть из него) соответствующее число, кратное Р. Преимущество метода, представленного формулами (5.5), состоит в том, что для вычисления используется только арифметика по модулю , которая уже встроена в алгоритмы этого класса. Более того, соотношения (5.5) позволяют выполнять вычислении параллельно. Можно начать с присваивания , затем, в момент j при сразу же получить для .
Важно отметить, что представление (5.6) по смешанному основанию пригодно для сравнения величин двух чисел, заданных в СОК. Так, если известно, что , то можно сказать, будет ли , если сначала выполнить переход к и к , затем в соответствии с лексикографическим правилом проверить выполнение неравенств или и и т. д. Более того, нет необходимости переходить к двоичной системе счисления, если нужно всего лишь выяснить, будет ли меньше, чем .
Операции сравнения двух чисел или определения знака числа при представлении в СОК интуитивно понятны и очень просты, поэтому можно было бы ожидать, что удастся найти значительно более лёгкий способ выполнения такого сравнения, чем переход к представлению со смешанным основанием. Однако следующая теорема утверждает, что вопрос этот не простой, поскольку величина числа в СОК существенным образом зависит от всех битов всех остатков .
Теорема. Примитивные корни по модулю р существуют тогда и только тогда, когда:
1) ,
2) ,
3) ,
где р – любое нечётное простое число, .
Таким образом, при всех других р примитивных корней нет. Доказательство теоремы можно найти, например, в книге [ ]. Эта теорема позволяет фактически дать полное описание группы U(Zp) для произвольного модуля р.
Теорема. Пусть - каноническое представление числа Р. Тогда . Группа - циклическая группа порядка , а - циклическая группа порядка 1 или 2 при l = 1 или l = 2 соответственно. Если , то она будет прямым произведением двух циклических групп, одной порядка 2, другой порядка 2l– 2. Кроме того, число р обладает примитивными корнями тогда и только тогда, когда р = 2, р = 4, р = рl или р = 2рl , где р – нечётное простое число.
Как следствие отметим, что для кольцо - поле тогда и только тогда, когда р – простое число, причём - область целостности. По изложенному материалу рассмотрим ряд примеров.
Пример. Пусть b обратно к а по модулю р. Проверить. Что b(2 – ab) обратно к а по модулю р2 и что b2(3 – 2ab) обратно к а2 по модулю р2.
Решение. По условию , следовательно , откуда , то есть . Вторую часть задачи можно решить непосредственным вычислением, учитывая, что (так как в кольце из х2 = 0 следует, что , и можно применить это к х = 1 – ab в .
Пример. Определим последовательность , следующим образом: и .
Проверить, что обратно к а по модулю . Какое число обратно к 11335 по модулю 216?
Решение. Первая часть задачи фактически повторяет рассуждения примера 1.5. Для второй части задачи полагаем p = 2, а = 11335, b0 = 1, k = 4. Тогда числом, обратным к а = 11335 по модулю 216 будет число b4, которое вычисляем последовательно:
Пример. Сколько элементов порядка 10 в следующей группе и каковы они? Z25;
Решение. В группе Z25 элементов порядка 10 нет, так как |Z25| = 25, а 25 не делится на 10.
Глава 2. Математические модели модулярного представления и параллельной обработки информации
§ 1. Представление числа в СОК. Модульные операцииВсякая вычислительная структура тесно связана с системой счисления, в которой она работает. Под системой счисления понимают совокупность приёмов обозначения (записи) чисел, или точнее, способ кодирования (представления) элементов некоторой конечной модели действительных чисел словами одного или более алфавитов. Кодирование представляет собой инъективное отображение диапазона системы счисления на декартово произведение его алфавитов, т. е. где , т. е. отображение F элементу элементов ставит в соответствие кодовое слово , где - i-я цифра, n – длина кода. С помощью обратного отображения F-1, которое называют декодированием, так же можно определить систему счисления.
К любой кодовой системе применимы следующие требования:
- возможность представления в данной системе любой величины в рассматриваемом, заранее назначенном диапазоне;
- единственность представления – любая кодовая комбинация соответствует одному и только одному числу в заданном диапазоне;
- простота оперирования с числами в данной системе счисления.
Таким образом, коды чисел являются именами числовых объектов, составляющих числовой диапазон. Диапазоны как модели вещественных чисел должны с максимально доступной полнотой и простотой отражать свойства числового множества.
Всякое представление чисел рабочего диапазона является лишь составным элементом соответствующей машинной арифметики и не может рассматриваться отдельно от неё. Арифметические свойства той или иной системы счисления прежде всего определяются характером межразрядных связей, появляющихся в ходе выполнения операций над кодовыми словами. Исследования показали, что в рамках обычной позиционной системы счисления (ПСС) значительного ускорения выполнения операций добиться невозможно. Это объясняется тем, что в ПСС значение разряда любого числа, кроме младшего, являющегося результатом двухместной арифметической операции, зависит не только от значения одноимённых операндов, но и от всех младших разрядов, т. е. ПСС обладает строго последовательной структурой. Сегодня, предпочтение отдаётся вычислительным структурам, обладающими способностями к параллельной обработке информации. Этими особенностями обладают непозиционные коды с параллельной структурой, которые позволяют реализовать идею распараллеливания операций на уровне выполнения элементарных арифметических действий. Эта мысль зародилась в середине 50-х годов прошлого века, когда чешские учёные М. Валах и Л. Свобода в своих исследованиях в области непозиционных систем счисления рассматривают представление чисел в виде набора остатков от деления на выбранные натуральные модули – основания системы. Подобную систему счисления стали называть системой остаточных классов (СОК) или модулярной системой счисления (МСС). Вслед за чешскими учёными возможность применения этой системы в ЭВМ рассмотрена в исследованиях американских учёных Айкена, Семона и Гарнера.
Пусть заданы положительные числа , которые называют основаниями или модулями системы. Обозначим . Эта величина характеризует объём диапазона системы. Под системой остаточных классов понимают такую непозиционную систему счисления, в которой целое неотрицательное число А можно представить в виде набора остатков от деления этого числа на выбранные основания системы, т. е.
, . (1.1´)
Возможность такого представления числа определяется теоремой о делении с остатком в кольце целых чисел.
Теорема. Если , то существуют единственные
, такие, что
(1.2´)
Несложно заметить, что каждый остаток получается независимо от других и содержит информацию обо всём числе.
Установить взаимно-однозначное соответствие между целыми числами из диапазона [0, P) и их остатками позволяет китайская теорема об остатках.
Возможность применения СОК в вычислительных алгоритмах обуславливается наличием определённого изоморфизма между математическими операциями над целыми числами и соответствующими операциями над системой целых неотрицательных остатков по отдельным модулям. Причём сложение, умножение, возведение в целую положительную степень любых целых положительных чисел совершенно идентичны соответствующим операциям, выполняемым над системой остатков.
Пусть операнды А и В, а также результаты операций сложения и умножения А + В и А·В представлены соответственно остатками , , по основаниям , причём оба числа и результаты находятся в диапазоне [0, P), то есть
,
,
, (1.3´)
,
и , , , .
Выражения (1.3) можно переписать в виде
(1.4´)
. (1.5´)
Справедливость этих правил выполнения арифметических действий в СОК непосредственно вытекает из свойств сравнения.
Действительно, на основании (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).
В отличие от позиционной системы счисления (ПСС), в которой число А представляется в виде
, (1.6´)
где N – основание ПСС , значение числа в модулярном коде не зависит от местоположения каждого разряда в его представлении, а зависит от значения основания соответствующего разряда. Поэтому модулярный код является непозиционным.
Таким образом, выполнение арифметических операций в модулярном коде производится независимо по каждому из модулей, что и указывает на параллелизм данной системы. Это обстоятельство определяет поразрядное выполнение операций. Это свойство избавит от необходимости «занимать» или «переносить» единицу старшего разряда, что приводит к появлению кодов с параллельной структурой. Это позволяет распараллелить алгоритмы при выполнении арифметических операций.
Перевод чисел из ПСС в СОК при помощи выражения (1.1´) связан с реализацией операции деления, поэтому использование данного метода неэффективно.
Итак, операции сложения и умножения над числами, представленными в СОК, сводятся к соответствующим операциям над цифрами этого представления. Это относится и к возведению в степень, к вычислению значений многочлена и т. п. Операция вычитания в СОК заменяется сложением с аддитивной инверсией отрицательного числа. Все эти операции модульные, т. е. не требуют позиционных характеристик обрабатываемых чисел.
Исследования СОК выявили целый ряд её преимуществ.
1) Максимальный параллелизм. Для оценки уровня параллелизма системы счисления вводится специальный показатель
, (1.7´)
где k – длина кода системы, n(v) – количество поразрядных показателей параллелизма , не меньших заданного порога , причём , где ni – максимально возможное число пар цифр оказывающих влияние на значение суммы в ходе её формирования на языке данного кода. Для СОК показатель параллелизма принимает максимально возможное значение . Это говорит об отсутствии межразрядных связей в числе, записанном в СОК.
2) Малоразрядность остатков. Поэтому, ввиду малого количества возможных кодовых комбинаций появляется возможность построения табличной арифметики. При этом большинство операций превращаются в однотактовые, осуществляемые простой выборкой из таблиц. По мере совершенствования технологии производства запоминающих устройств с высокой плотностью записи информации, составляющих техническую систему табличного метода вычислений, интерес к СОК неуклонно возрастает.
3) Реализация принципа конвейерной обработки информации. Это означает, что при выполнении вычислений модульные и следующие за ним операции удаётся совместить по времени только тогда, когда очередные операции зависят от результатов текущих, ещё не закончившихся операций. Таким образом, алгоритмы модулярной арифметики обладают конвейерной структурой.
4) Высокая точность, надёжность, способность к самокоррекции. Причём в СОК можно построить непозиционные коды, обнаруживающие и исправляющие ошибки, которые являются полностью арифметическими, то есть в этих кодах информативная и контрольная части равноправны относительно любой операции. Эта особенность предоставляет возможность варьировать корректирующей способностью кода за счёт изменения точности вычислений.
Конечно, и эта система не лишена недостатков. К ним относится невозможность визуального сравнения чисел, отсутствие признаков выхода результатов за пределы диапазона, ограниченность действия системы сферой целых положительных чисел, получение во всех случаях точного результата операции, что исключает возможность непосредственного округления результата, а также трудность выполнения немодульных операций. Но они не являются непреодолимыми.
§ 2. Основные методы и алгоритмы перехода от позиционного представления к остаткамОбработка информации в цифровых устройствах, функционирующих в СОК, осуществляется с помощью модульных и немодульных операций.
К модульным операциям относятся операции сложения, вычитания и умножения. Анализ применения арифметики СОК показывает, что их звенья имеют одинаковую структуру, типовым элементом которой является последовательность вида
, (2.1´)
где - целочисленная функция вычета по некоторому модулю, рi – основание СОК, - операция определения наименьшего вычета по модулю рi.
К немодульным операциям относятся операции, при которых значение того или иного результата разряда зависит от всех или нескольких разрядов исходного числа.
Устройства, реализующие немодульные операции, довольно чётко разделяются на 2 типа.
Примером устройства первого типа является устройство свёртки, обеспечивающее вычисление
, (2.2´)
где Аi – значение i-го разряда исходного числа, представленного в позиционной системе счисления (ПСС); Qi – весовой коэффициент.
Устройства свёртки широко используются в цифровых системах, функционирующих в СОК, представляющих существенную, а порой и основную часть оборудования, предназначенную для реализации ряда способов выполнения операций – перевода чисел из ПСС в СОК, деления произвольных чисел и некоторых других. Кроме того, такие устройства находят применение и в цифровых системах, функционирующих в ПСС.
Примером устройств второго типа является устройство позиционного преобразования, обеспечивающие получение характеристик, указывающих на принадлежность числа, представленного в СОК, тому или иному интервалу диапазона представимых чисел.
Математической основой устройств первого типа является определение наименьших неотрицательных вычетов, которые определяются свёртками исходного числа по каждому модулю. Для определения свёрток по каждому модулю необходимо перевести число из позиционной системы счисления в систему остаточных классов.
Перевод числа в систему остаточных классов можно осуществить методом деления. Однако из-за операции деления техническая реализация такого метода не эффективна для машинного использования, кроме того, данный метод требует применения арифметического устройства в позиционной системе счисления.
Рассмотрим метод перевода числа из позиционной системы счисления в СОК, не содержащий операции деления, называемый методом непосредственного суммирования модульных значений разрядов позиционного числа.
Пусть число X записано в позиционной системе счисления с основанием N, т. е.
или , (2.3´)
где .
Представим степени основания Ni и коэффициенты Ai в системе остаточных классов с основаниями , тогда
, (2.4´)
Подставим (2.4´) в (2.3´), получим
(2.5´)
Таким образом, для образования числа Х в СОК требуется k констант, являющихся степенями и констант, соответствующих значениям .
Имея в памяти процессора массив из констант, весь перевод может быть осуществлён процессором, работающим в СОК.
Рассмотренный метод является основой широкого выбора возможных аппаратурных реализаций цифровых преобразователей ПСС – СОК, которые различаются между собой как по составу и количеству используемых элементов, так и по скорости преобразования информации. Известные в литературе цифровые преобразователи ПСС – СОК, основанные на данном методе, анализ которых позволил сделать важные выводы о том, что одним из существенных недостатков подобных преобразователей являются большие аппаратурные затраты при переводе чисел большой разрядности и низкое быстродействие. Повышенные требования, связанные с уменьшением аппаратурных средств и увеличением скорости обработки информации, привели к необходимости глубокого изучения вопросов разработки эффективных алгоритмов. Для решения этой задачи предлагаются два метода. Рассмотрим первый метод. Для этого докажем следующую теорему, которая является основой нового метода преобразования чисел из ПСС в СОК как аппаратурными, так и программными способами.
Теорема. Пусть число Х записано в позиционной системе счисления с основанием N и если
, где . (2.6´)
а - простое число, r – число разрядов (при j = 1, 2,…, r), то
и . (2.7´)
Доказательство. , . Далее, подставляя значения выражений (2.6´) в выражение (2.7´), и учитывая свойства сравнений, получим
, (2.8´)
Рассмотрим второй метод, который нашёл широкое применение в литературе. Назовём его методом последовательного умножения и суммирования. Суть метода состоит в следующем. Пусть число записано в виде (2.3´). Иначе это выражение можно записать
,
, (2.9´)
,
.
Т. е. значение числа Х в СОК по модулю образуется путём умножения старшего разряда на основание системы счисления N, затем суммирования полученного результата со значением следующего разряда по модулю , затем умножения полученного результата на основание N по модулю , а так последовательные умножения и суммирования по модулю производятся до тех пор, пока при суммировании не будет добавлено значение младшего разряда.
Следует отметить, что рассмотренный метод позволяет реализовать весьма экономичные, в смысле аппаратурных затрат, цифровые устройства преобразования информации.
§ 3. Восстановление позиционного представления числа по его остаткам
Система остаточных классов обладает одной особенностью, которую можно отнести к недостаткам этой системы: нельзя визуально определить величину числа, представленного в СОК, а следовательно затруднительно и выполнение таких операций, как сравнение чисел, определение знака числа. Один из путей решения этой проблемы состоит в преобразовании чисел из СОК в позиционную систему счисления. Оценим существующие способы перевода, как традиционные: метод ортогональных базисов; перевод числа в обобщенную позиционную систему (ОПС), так и недавно появившиеся интервальные методы перевода.
1). Метод восстановления числа по его остаткам был найден еще в Китае две тыс. лет назад. Основой этого метода является теорема, названная, поэтому Китайской теоремой об остатках (КТО).
Теорема. Пусть – попарно взаимно простые числа, = , , , …, подобраны так, что 1, = , . Тогда решение системы , , будет иметь вид: .
Эта теорема лежит в основе метода ортогональных базисов при переводе из системы остаточных классов в позиционную систему счисления.
Пусть основания системы остаточных классов ; = = – объем диапазона системы. С выбором системы определяются ее основные константы – базисы , . Задача перевода числа = =() в ПСС заключается в определении таких чисел , , чтобы =. Для однозначного определения на базисы системы накладывается ряд ограничений и показывается, что таким свойством обладают базисы
= (1, 0, 0, …, 0, 0), =(0, 1, 0, …, 0, 0), = (0, 0, 0, …, 0, 1),
которые называются ортогональными.
Тогда в случае ортогональных базисов =, . Ортогональные базисы определяются по формуле
= , , (3.1´)
где
= (3.2´)
– целые положительные числа, которые называются весами базиса, их определяют из сравнений
º 1 (3.3´)
Тогда, по Китайской теореме, число
= ().
Таким образом, если найдены ортогональные базисы для системы оснований, то для перевода числа = () достаточно вычислить и ввести эту сумму в диапазон [0; ) вычитанием величины, кратной , т.е.
==–, (3.4´)
где – ранг числа , показывающий сколько раз надо вычесть величину диапазона из полученного числа, чтобы вернуть его в диапазон.
Пример. Пусть дана система оснований = 2, = 3, = 5, =7, =11, объем диапазона =2·3·5·7·11=2310. перевести число = (1, 2, 1, 4, 7) в позиционную систему.
Вычислим ортогональные базисы.
Для этого найдем величины :
=1155, =770, =462, =330,
=210.
Ищем веса базисов:
1155º 1(2), º 1( 2).
770 º 1(3), º 2(3).
462 º 1(5), º 3( 5).
330 º 1(7), º 1( 7).
210 º 1(11), º 1( 11).
Тогда получаем сами базисы:
= ·= 1·1155 =1155,
= ·= 2·770 =1540,
= ·= 3·462 =1386,
=·= 1·330 =330,
=·= 1·210 =210.
Вычислим величину числа :
===1481.
Так как ортогональные базисы полностью определяются выбором оснований системы, то они могут быть заранее вычислены, причем единственный раз.
Недостаток рассмотренного метода заключается в том, что приходится иметь дело с большими числами и, кроме того, действия сложения и умножения надо выполнять в позиционной системе счисления, а полученный результат необходимо вводить в диапазон вычитанием величины кратной .
2). Другой метод определения величины числа связан с переводом числа из системы остаточных классов в ОПС. Для того чтобы рассмотреть этот метод, выявим связь между представлением некоторого числа в этих двух системах. Пусть по-прежнему СОК задается основаниями и = () – число в этой системе. И пусть – также основания ОПС, тогда число можно представить в виде
= + +…+
+ + + , (3.5´)
где 0 £ < – коэффициенты (цифры) ОПС.
Очевидно, что диапазоны чисел, представимых в СОК и ОПС совпадают, т.е. можно говорить о наличии взаимооднозначного соответствия между множеством представлений чисел в СОК и ОПС.
Равенство (3.5´) можно переписать в виде
=+(+(+…+(+)…)),
откуда следует, что цифры ОПС могут быть получены из соотношений:
=–=–, где =,
=–=–, где =, (3.6´)
…
=– = –, где =.
Причем при определении цифр по формулам (3.6´) все вычисления можно вести в СОК.
Действительно, из (3.6´) следует, что =, т.е. – первая СОК цифра или =. Для получения , сперва – представим в остаточном коде. Очевидно – делится на . Более того, взаимно просто со всеми другими модулями. Следовательно, для нахождения цифры может быть использована процедура деления без остатка: =. Таким путем, с помощью вычитаний и делений в остаточной записи все цифры ОПС могут быть получены. При этом замечено, что =, =,
= и, вообще, для > 1 =.
Перевод, осуществляемый согласно алгоритму (3.6´),содержит всего 2(–1) остаточные арифметические операции вычитания и деления без остатка, где – число модулей системы. Можно предложить некоторую модификацию, т. е. операция деления заменить операцией умножения. Для этого предварительно вычисляется констант , которые удовлетворяют условию
1(), 1 ≤ < ≤ . (3.7´)
Эти константы можно, например получить из расширенного алгоритма Евклида
= 1 (3.8´)
Здесь следует заметить тот факт, что константы полностью определяются выбранной системой оснований, поэтому могут быть вычислены заранее и храниться в некоторой таблице. В приложении к [90] для модулей и не превосходящих 31 представлена таблица величин .
Если константы вычислены, то вычисление цифр ОПС по алгоритму (3.6´) может быть переписано в виде:
,
, (3.9´)
,
.
Константы принято также записывать в виде = и называть обратными элементами по умножению для чисел по модулю (multiplicative inverse).
Рассмотрим алгоритм (3.9´) на примере.
Пример. Пусть дана система оснований = 2, = 3, = 5, = 7, = 11. Объем диапазона = 2310. переведем число =(1, 1, 3, 5, 4) в ОПС.
Найдем сначала константы :
= =2, = =3, = =4, = =6,
= =2, = =5, = =4,
= =3, = =9,
= =8.
Для удобства константы запишем в виде матрицы :
Выполнение алгоритма (3.9´) представлено в таблице
Перевод числа из СОК в ОПС
Действия | Модули | Цифры ОПС | ||||
= 2 | = 3 | = 5 | = 7 | = 11 | ||
–
| 1 | 2 1 | 1 1 | 4 1 | 7 1 | ==1 |
–
| 0 | 1 2 | 0 3 | 3 4 | 6 6 | |
–
| – | 2 2 | 0 2 | 5 2 | 3 2 | = 2 = |
–
| 0 | 3 2 | 3 5 | 1 4 | ||
–
| – | 1 | 1 1 | 4 1 | = 1 = | |
–
| 0 | 0 3 | 3 9 | |||
–
| 0 | 5 0 | = 0 = | |||
–
| 0 | 5 8 | ||||
7 – | = 7 = |
Таким образом,
+ +++=
= 7 · 2 · 3 ·5 · 7 + 0 · 2 · 3 · 5 + 1 · 2 · 3 + 2 · 2 + 1 = 1481.
Преимущество рассмотренного метода перед методом ортогональных базисов состоит в том, что все вычисления выполняются в модулярной арифметике, причем в отдельных каналах, соответствующих модулям , правда, к сожалению, не параллельно. Рассмотрим некоторые модификации изложенного метода.
Один из вариантов уменьшения числа операций в рассмотренном алгоритме может быть достигнут путём особого выбора системы оснований. Выберем систему оснований СОК следующим образом:
Очевидно, что основания такой системы взаимно простые числа. Эта система обладает той особенностью, что , т.е. из сравнений получаем, что все константы = 1. При таком выборе системы оснований алгоритм можно видоизменить следующим образом: вычисления начинают со старших модулей, тогда, т.к. константы = 1, то в алгоритме отпадает необходимость умножать на , т.е.
(3.10´)
где
Пример. Выберем систему оснований по указанному принципу:
Объём диапазона
Введем новые обозначения
Пусть в системе оснований задано число (27, 0, 1, 1). Переведём его в ОПС с той же системой оснований.
Метод перевода чисел из СОК в ОПС на основе выбора системы оснований
Действия | Модули | Цифры ОПС |
| |||||||
|
|
|
| |||||||
– | 27 27 | 0 6 | 1 0 | 1 1 | ||||||
– | – | 1 1 | 0 1 | |||||||
– | – | 1 0 | ||||||||
– | 1 | |||||||||
Таким образом,
Как видно, при указанном выборе системы оснований число операций уменьшается вдвое, т.к. необходимо для осуществления перевода совершить операцию вычитания, против операций в общем случае. Кроме того отпадает необходимость вычислять и хранить константы . Похожим свойством обладают системы оснований
,
для которых все константы . Однако, главный недостаток указанных систем состоит в быстром росте оснований системы, так как . Один из способов достижения компромисса в создавшемся положении это выбор такой системы оснований, для которой лишь часть констант .
Другая модификация алгоритма (3.9´) основывается на факте, что если в процессе перевода появляется определенная комбинация цифр, то оставшиеся цифры числа в ОПС можно сразу определить и процесс перевода может быть завершен. К условиям, которые могут завершить процесс перевода до выполнения последнего шага алгоритма (3.9´) можно отнести следующие:
1. Если при определении цифры оказалось, что все другие остаточные цифры равны , где – другие основания СОК (< ), тогда остальные цифры ОПС будут нули.
2. Если при определении цифры оказалось, что все другие остаточные цифры равны , где – другие основания СОК (>), тогда =–1.
Рассмотрим примеры, иллюстрирующие эти случаи.
Пример. Пусть основания системы = 2, = 3, = 5, = 7, = 11 объем диапазона = 2310.
Переведем числа =(1, 2, 3, 2, 1) и =(1, 0, 2, 4, 8) в ОПС с той же системой оснований. Учтем, что константы для этой системы вычислены ранее, выпишем их в виде матрицы :
Для числа получаем
Метод перевода числа в ОПС по условию получения комбинации цифр
Действия | Модули | Цифры ОПС | ||||
= 2 | = 3 | = 5 | = 7 | = 11 | ||
–
| 1 | 2 1 | 3 1 | 2 1 | 1 1 | =1 |
–
| 0 | 1 2 | 2 3 | 1 4 | 0 6 | |
–
| 2 | 1 2 | 4 2 | 0 2 | = 2 | |
–
| 0 | 4 2 | 2 5 | 9 4 | ||
| 3 | 3 | 3 | = 3 |
Тогда согласно пункту 1, == 0. Таким образом,
=(1, 2, 3, 2, 1)= = 0 · 2 · 3 ·5 · 7 + 0 · 2 · 3 · 5 + 3 · 2 · 3 + 2 · 2 + 1 = 23.
Для числа получаем
Метод перевода числа в ОПС по условию получения комбинации цифр
Действия | Модули | Цифры ОПС | ||||
= 2 | = 3 | = 5 | = 7 | = 11 | ||
–
| 1 | 0 1 | 2 1 | 4 1 | 8 1 | =1 |
–
| 0 | 2 2 | 1 3 | 3 4 | 7 6 | |
–
| 1 | 3 1 | 5 1 | 9 1 | = 1 | |
–
| 0 | 2 2 | 4 5 | 8 4 | ||
| 4 | 6 | 10 | = 4 |
Тогда согласно пункту 2, = 4, = 6, = 10.
Таким образом
, = (1, 0, 2, 4, 8) = 10 · 2 · 3 ·5 · 7 + 6 · 2 · 3 · 5 + 4 · 2 · 3 + 1 · 2 + 1 = 2307.
При использовании предложенного метода число операций в процессе перевода чисел в ОПС уменьшается. Причем наибольшая выгода наблюдается при небольших по абсолютной величине основаниях системы. Было подсчитано, что при использовании рассмотренных приемов число операций в процессе перевода числа из СОК в ОПС, например, для системы модулей = 13, = 11, = 7, = 5, = 3, = 2, будет в среднем 6,4, против 10 остаточных операций при применении стандартного метода. Однако, для проверки условий, позволяющих завершить процесс перевода. Потребуется наличие дополнительных логических устройств.
Еще можно отметить, что специальный выбор оснований СОК может позволить вычисление констант . Так, при кодировании остатков в двоичной системе бывает удобно выбирать модули СОК в виде
=. (3.11´)
Тогда для определения констант существует достаточно простая формула
= 1++…+, (3.12´)
где целые числа и подбираются из условий
, . (3.13´)
3). Достаточно эффективными методами перевода чисел из СОК в ПСС являются интервальные методы, основанные на интервальных характеристиках чисел. Одна из таких характеристик – номер интервала.
Рассмотрим СОК, заданную системой оснований , с объёмом диапазона . Выберем дробящий модуль и проведём дробление заданного диапазона на интервалы путём деления на модуль . Тогда количество интервалов , а длина интервала определяется величиной модуля. В результате величину любого числа , заданного в СОК по выбранным основаниям можно определить по номеру интервала:
, (3.14´)
в котором находится число и по цифре числа в СОК по модулю , т.е.
. (3.15´)
Так как (,) = 1, то по теореме Эйлера:
, (3.16´)
где – функция Эйлера. Причём если – простое число, то =–1. Подставляя (3.15´) в (3.4´), учитывая (3.1´) и (3.4´) число можно записать в виде
. (3.17´)
Для определения номера интервала подставим (3.17´) в (3.14´):
. (3.18´)
Учитывая, что перепишем (3.18´) в виде
. (3.19´)
Так как является делителем чисел то
где
и –
постоянные коэффициенты, определённые системой оснований.
Таким образом,
. (3.20´)
Подставляя (3.20´) в (3.15´), получим позиционное представление числа
. (3.21´)
В качестве дробирующего модуля целесообразнее выбирать наибольший из модулей системы. В этом случае модульные операции выполняются при меньшей величине модуля, что ведёт к меньшим временным и аппаратурным затратам. Целесообразно также для упрощения вычислений и минимизации времени выполнения операций выбирать в качестве дробирующего модуля наибольшие модули системы, представляющие числа Мерсенна или Ферма . При этом предпочтение отдаётся числам Мерсенна, так как арифметика по этим модулям проще.
Проиллюстрируем рассмотренный метод на примере.
Пример. Пусть дана система оснований тогда = 210. Пусть надо перевести число =(0,1,4,3). В качестве дробирующего модуля выберем тогда , номер интервала , а само число . Определим Так как
то
Тогда
Таким образом, 13·7 + 3 = 94.
На основе этой же характеристики числа – номера интервала, с применением теоремы Эйлера предлагается алгоритм перевода числа в ПСС. Разность между модулями можно представить в виде = – и тогда
, (3.22´)
но с другой стороны
(). (3.23´)
Из (3.22´) и (3.23´) следует, что
Так как . (3.24´)
Решение сравнения (3.24´) можно записать в виде
(3.25´)
где – функция Эйлера. Если – простое число, то Поэтому в случае простого выражение (2.3.13) примет вид:
Перепишем (3.15´) с учётом (3.25´)
(3.26´)
где – константа, определяемая выбором оснований СОК. Нетрудно заметить, что – наименьший неотрицательный вычет по составному модулю ·. Исходя из этого можно записать:
(3.27´)
где показывает, сколько раз произведение · укладывается в числе . Для нахождения можно считать, что число представлено в системе оснований в виде и после этого можно воспользоваться формулой (3.27´). Проводя аналогичные рассуждения, после преобразований получим:
(3.28´)
Где
(3.29´)
Тогда искомая величина числа ( – наименьший неотрицательный вычет числа по составному модулю ) определяется за – 1 шагов, где – число оснований СОК.
Пример. Пусть основания СОК = 3, = 5, = 7, = 11, объём диапазона = 1155. Найдём величину числа = (1,2,0,8).
§ 4. Расширение диапазона представления чиселРасширение системы оснований является одной из основных немодульных операций в СОК. Выполнение этой операции бывает необходимо при выполнении операции деления чисел, при вычислении позиционных характеристик, при обнаружении переполнения при выполнении сложения или умножения чисел.
Задачу расширения системы оснований можно сформулировать следующим образом: найти остаточное представление числа по новому основанию (новым основаниям), если известно представление числа по другим основаниям остатки от деления на другие числа.
Один из путей расширения системы оснований состоит в переводе числа в позиционную систему счисления и вычисления остатка от деления на новый модуль. Этот путь не является рациональным с точки зрения числа операций.
Другой метод расширения системы оснований позволяет определить цифру числа по новому основанию, базируясь на таких позиционных характеристиках числа, как ранг числа, след числа. Пусть вновь задана система оснований с диапазоном Р, ортогональными базисами , веса которых . По определению, . Пусть в этой системе задано число . Расширим систему оснований, добавляя основание , тогда диапазон системы станет , ортогональные базисы системы , их веса , причём . Задача состоит в определении цифры числа по основанию называют цифру , при которой число находится в интервале , и что число , то определение цифры по основанию сводится к определению минимального следа числа А в расширенной системе оснований.
Чтобы получить формулы для цифры запишем выражение для числа А в основной и расширенной системах:
и ,
где и - ранги числа А в основной и расширенной системах.
Приравнивая правые части этих выражений, определяем :
, или обозначая через целое число , а через величину , получаем . Наконец, представляя в виде , где k, q – целые неотрицательные числа и , получаем
, или
. (4.1´)
Формула (4.1´) и есть формула расширения диапазона чисел.
Для практической реализации этой формулы поступают следующим образом:
... по соответствующему полю). В окне Конструктора таблиц созданные связи отображаются визуально, их легко изменить, установить новые, удалить (клавиша Del). 1 Многозвенные информационные системы. Модель распределённого приложения БД называется многозвенной и её наиболее простой вариант – трёхзвенное распределённое приложение. Тремя частями такого приложения являются: ...
... , может приводить к большим потерям рабочего тела и раскрутке космического аппарата до недопустимых угловых скоростей. Таким образом разработка алгоритмов контроля и диагностики системы управления ориентацией космического аппарата – является актуальной задачей. В настоящей работе решается задача построения алгоритмов контроля и идентификации отказов командных приборов и исполнительных органов. ...
... для реализации системы бюджетирования Консультационной группы "Воронов и Максимов". Статья о проблемах выбора системы бюджетирования - в проекте "УПРАВЛЕНИЕ 3000". Бюджетный автомат Если вы решитесь на автоматизацию системы бюджетирования компании, перед вами сразу встанут вопросы: что выбрать, сколько платить, как внедрять. Примеряйте! О ЧЕМ РЕЧЬ В “Капитале” на стр. 44, 45 мы рассказали ...
... управления и его характеристика; функциональные задачи управления; характеристика системы первичных экономических показателей; организация информационного обслуживания органа управления; методика реализации функции управления; перспективы совершенствования. Обоснование проектных решений по автоматизированному решению экономико-информационных задач включают обоснование выбора задач, входящих ...
0 комментариев