Скачиваний:
178
Добавлен:
02.05.2014
Размер:
224.77 Кб
Скачать
    1. Пример доказательства правильности программы для алгоритма дискретного экспоненцирования

      1. Вводные замечания

Большинство известных алгоритмов электронной цифровой подписи, криптосистем с открытым ключом и схем вероятностного шифрования (см. приложение) в качестве основной алгоритмической операции используют дискретное возведение в степень. Стойкость соответствующих криптографических схем основывается (как правило, гипотетически) или на сложности извлечения корней в поле GF(n),n- произведение двух больших простых чисел, или на трудности вычисления дискретных логарифмов в полеGF(p),p- большое простое число. Чтобы противостоять известным на данный момент методам решения этих задач операнды должны иметь длину порядка 512 или 1024 битов. Понятно, что выполнение вычислений над операндами повышенной разрядности (еще будет употребляться термин «операнды многократной точности» по аналогии с операндами однократной и двукратной точности [Кн]) требует высокого быстродействия рабочих алгоритмов криптографических схем.

      1. Представление чисел

Пусть A,N,e- три целых положительных числа многократной точности, причемA<N. Тогда для любогоeпри вычисленииAe(modN)C, результат редукцииC{1,N-1}. Еслиeпредставитьn-разрядным двоичным вектором, то всю операцию возведения в степень можно свести к чередованию операций видаA*BmoduloNиB*BmoduloN, где 0<B<N-1 [Кн, стр.482-510]. Таким образом, во всех дальнейших рассужденияхeбудет представляться только как двоичная строка. Кроме того, числаA,B,N, а такжеP- частичное произведение иS- текущий результат будут представлятьсяn-битовыми двоичными векторами, например,N[1,n], гдеN[1] иN[n] - младший и старший битыNсоответственно.

Алгоритм Р(при разработке и доказательстве его правильности использованы результаты работы [Bk]), реализует вычислительную систему с фиксированной длиной слова, то естьA,B,N,PиSбудут также рассматриваться как векторыA[1,m],B[1,m],N[1,m],P[1,m'] иS[1,m'], где каждый элемент вектора (элемент одномерного массива) есть цифраr-ичной системы счисления,m'=m+h, величинаhбудет изменяться в зависимости от вида алгоритма. Основаниеrтакой системы будет ограничено длиной машинного словаи цифры такой системы имеют вид 0,1,...,r-1 (rвыбирается как целое положительное основание с неотрицательной базой). При этомnиmсвязаны соотношениемn=s*m, гдеs=log2r(в дальнейших рассуждениях log - логарифм по основанию 2). Наиболее целесообразно выбрать основаниеr=2как наиболее экономное представление чисел в машине, так как приr<2на представление чисел уходит больше памяти. Например, широко принятое на практике представление десятичных чисел в двоично-десятичном коде требует на 20 % большего объема памяти, чем двоичное представление тех же чисел.

Тем не менее, иногда полезно представлять ситуацию, когда r=10 [Кн, стр.283] илиr=10k, например, при отладке программ.

Следует также обратить внимание на тот факт, что при выполнении арифметических операций над числами многократной точности, например, по классическим алгоритмам Кнута [Кн, стр.282-302], основание rследует уменьшать, чтобы не возникло переполнение разрядной сетки. Так, для операции сложения уменьшение выполняется доr=2-1, для умножения - доr=2/2. Однако если архитектурой вычислительной системы предусмотрен флаг переноса или хранение промежуточного результата с двойной точностью, то можно возвращаться к основаниюr=2.

Соседние файлы в папке Казарин О.В. Теория и практика защиты программ