Главная страница
Навигация по странице:

  • 9.1. Фильтрующие генераторы.

  • 9.2. Комбинирующие генераторы

  • 9.4. Корреляционные атаки

  • 9.5. Генераторы гаммы с неравномерным движением

  • 9.5.1. Схемы с внешним управлением.

  • Генератор « шагов»

  • Генератор с перемежающимся шагом

  • Каскадные генераторы Гольмана.

  • 9.5.2. Схемы с самоуправлением

  • Генератор -самоусечения.

  • 9.5.3. Генераторы с дополнительной памятью.

  • Криптография. 09 генераторы. Лекция Криптографические генераторы


    Скачать 120.24 Kb.
    НазваниеЛекция Криптографические генераторы
    АнкорКриптография
    Дата26.09.2022
    Размер120.24 Kb.
    Формат файлаdocx
    Имя файла09 генераторы.docx
    ТипЛекция
    #698807

    Лекция 9. Криптографические генераторы

    Криптографические генераторы обычно реализуются программно и используются для выработки псевдослучайных последовательностей над конечным полем . Из этих последовательностей, называемых гаммой получаются ключи криптосистем, случайные инициальные векторы, управляющая гамма поточных шифров.

    Обозначим в гамме :

    — длина периода, — линейная сложность.

    Базовым элементом криптосхем многих генераторов является ЛРС с максимальной длиной периода, выходная гамма которого (ЛРП) имеет и хорошие статистические свойства. В то же время линейная сложность ЛРП равна ее порядку, что позволяет восстанавливать всю ЛРП по ее сравнительно небольшому отрезку. Эта слабость ЛРС позволяет ее использовать только в сочетании с различными функциональными узлами и элементами памяти. Назначение последних — привнести в функции криптосистемы нелинейные свойства и зависимость каждого знака выхода от возможно большего числа знаков входа, не теряя положительные свойства ЛРП. Гамма такого генератора есть определенное усложнение ЛРП.

    Рассмотрим классы генераторов, построенных на основе ЛРС.

    9.1. Фильтрующие генераторы. Фильтрующий генератор (ф.г.) над полем генерирует гамму по формуле

    , , (9.1)

    где - линейная подстановка пространства , выполняемая ЛРС длины , – тождественная подстановка; — функция, называемая фильтром или фильтрующей функцией; – ненулевое начальное состояние ЛРС. Ф.г. называется нелинейным, если фильтрнелинейный. Ключевые элементы ф.г. — начальное состояние ЛРС, ключами может быть также характеристический многочлен ЛРС и фильтр . Схема ф.г. дана на рис. 9.1.

    Пусть , . Отметим свойства ф.г.:

    1. , ;

    2. если ф.г. использует ЛРС и сбалансированный фильтр, то , и частоты «1» и «0» на периоде гаммы различаются на 1;

    3. нелинейные свойства гаммы обеспечены нелинейным фильтром:

    ,

    где —число различных конъюнкций от ранга от 0 до . В случае верна оценка

    .

    Получение оценки снизу для () требует учета более глубоких свойств фильтра. Гамма ф.г. имеет высокую линейную сложность при фильтре высокой степени нелинейности.

    При простом доля ф.г. на базе ЛРС , у которых линейная сложность достигает наибольшего значения , стремится к 1 [26].

    9.2. Комбинирующие генераторы (комб.г.) являются усложнением фильтрующих генераторов. Они построены на основе ЛРС-1 длины , …, ЛРС- длины над , , и комбинирующей функции , на вход которой поступают знаки ЛРП-1, …, ЛРП- . Комб.г. изображен на рис. 9.2.

    Обозначим +…+ , и положим, не теряя общности: . Уравнения гаммообразования комб.г. имеют вид:



    где есть -й знак, генерируемый ЛРП- при начальном состоянии , .

    Комбинирующий генератор называется нелинейным, если нелинейна комбинирующая функция. Ключевые элементы комб.г. — начальные состояния всех ЛРС, ключами могут быть также их характеристические многочлены и комбинирующая функция.

    Начальные состояния всех ЛРС образуют начальное состояние генератора. Начальное состояние комб.г. назовем неособенным, если начальное состояние каждого ЛРС ненулевое. Наилучшие криптографические свойства комб.г. имеет в том случае, когда комбинирующая функция зависит существенно от переменных и начальное состояние неособенное, иначе данный комб.г. вырождается в комб.г. с меньшим числом ЛРС. Далее считаем, что эти условия выполнены.

    Отметим, что , .

    Оценим линейную сложность гаммы генератора. Каждому каноническому полиному над соответствует полином над кольцом целых чисел, полученный из заменой всех ненулевых коэффициентов на 1и заменой сложения и умножения в поле Р сложением и умножением в Z.

    Теорема 9.1. При любом неособенном начальном состоянии комб.г.

    .

    Данная оценка в некоторых условиях вырождается в точное равенство, в частности, еслиполе простое, и характеристические многочлены всех ЛРС примитивные, имеющие попарно взаимно простые степени [1, 26].

    При определенных ЛРС и функции гамма комб.г. имеет хорошие статистические свойства и большую длину периода. В частности, если ЛРС-1, …, ЛРС- генерируют гаммы с попарно взаимно простыми длинами периодов и функция биективна по каждой переменной, то . Если каждая ЛРС имеет максимальную длину периода, то

    .

    Теорема 9.2. Если функция равновероятна, то

    ,

    где число единиц на периоде гаммы комб.г. при начальном состоянии .

    9.3. Аддитивные генераторы (АГ). АГ предназначены для генерации векторов или -битовых чисел (элементов кольца вычетов ). Они синтезируют идеи построения ЛРС и ЛКГ. Пусть суть числа, образующие начальное состояние генератора, тогда -й знак гаммы определен законом рекурсии, ,

    ,

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

    АГ нестойки, но используются как базовые блоки для построения более стойких генераторов (Fish — Fibonacci Shrinking Generator, Pike, Mush). Свойства АГ улучшаются при модификации обратной связи.

    9.4. Корреляционные атаки. Корреляционные атаки часто применяют для анализа генераторов гаммы в СПШ, построенных как композиция нескольких функциональных блоков и узлов типа ЛРС. Ключом генератора являются начальные состояния элементов памяти, ключами могут быть также параметры функциональных блоков.

    Идея корреляционных атак заключается в использовании ненулевой взаимной корреляции (если таковая имеется) между выходной гаммой генератора и промежуточной гаммой некоторого функционального блока или узла. Например, в ф.г. и комб.г. может быть взаимная корреляция между выходной гаммой и гаммой некоторых ЛРС [18, 19]. При наличии корреляции можно поэтапно определить по выходной гамме начальные состояния ряда ЛРС. Опробуя состояния регистра, отбраковываем как ложные (с помощью различения статистических гипотез) те из них, при которых гамма регистра не коррелирует с выходной гаммой.

    Проиллюстрируем технику на примере комб.г. Геффе, на основе генерирующих регистров ЛРС-1, ЛРС-2 и управляющего регистра ЛРС-3 длин , и соответственно. Комб. функция , она совпадает с функцией x1 (а также с функцией x2) с вероятностью 3/4 при случайном равновероятном выборе набора . Значит, гамма генератора совпадает с выходом ЛРС-1 примерно для 75% знаков. Опробуем начальные состояния ЛРС-1 и отбракуем «ложные» значения статистическим методом, генерируя знаки выхода ЛРС-1 и наблюдая частоту их совпадения с соответствующими знаками гаммы генератора. При истинном начальном состоянии частота совпадения знаков в последовательностях длины распределена по нормальному закону с математическим ожиданием и с дисперсией . При ложных значениях имеем нормальное распределение с математическим ожиданием и с дисперсией t. Для отбраковки ложного значения достаточно примерно 16 сравнений знаков. Значит, начальное состояние одного из генерирующих ЛРС определяется в среднем после сравнений, где .

    Трудоемкость вскрытия других элементов ключа менее значительна.

    Наилучшее противодействие корреляционным атакам достигается при комбинирующих функциях, имеющих высокий корреляционный иммунитет. Вместе с тем, известно [28], что корреляционный иммунитет комбинирующей функции связан с линейной сложностью гаммы генератора, ослабление одной характеристики влечет усиление другой.

    Пример 9.1. Генератор Геффе использует комбинацию генерирующих ЛРС-1, ЛРС-2 и управляющего ЛРС-3. Комбинирующая функция . В каждом такте знак гаммы при управляющем знаке 1 совпадает с выходным знаком ЛРС-1, а при управляющем знаке 0 — с выходным знаком ЛРС-2. Если все ЛРС имеют максимальные периоды и их длины попарно взаимно просты, то период гаммы равен произведению периодов ЛРС, а линейная сложность гаммы генератора равна .

    Пример 9.2 Пороговый генератор использует комбинацию нечетного числа регистров. Комбинирующая функция , называемая функцией мажорирования, равна 1 . При подходящих ЛРС линейная сложность длина периода гаммы порогового генератора равна произведению периодов ЛРС. При и линейная сложность гаммы равна .

    Наилучшие криптографические свойства фильтрующих и комбинирующих генераторов достигаются при использовании функций высокой степени нелинейности, техническая и программная реализация которых весьма сложна. Трудность достижения приемлемого компромисса стимулировала поиск новых конструкций генераторов гаммы.

    9.5. Генераторы гаммы с неравномерным движением. Информация в элементах памяти рассмотренных схем обновляется при любом состоянии памяти равномерно (в каждом такте функционирования). Вместе с тем, гамма усложняется, если продвижение информации в регистрах зависит от последовательности, вырабатываемой другим регистром, т.е. является неравномерным. Построенные по такому принципу генераторы гаммы называются генераторами гаммы с неравномерным движением. Зависимость закона движения информации проявляется, например, в усечении (удалении), реже — в дублировании некоторых битов исходной гаммы. Эффект неравномерного движения достигается с помощью внешнего управления регистрами генератора гаммы или с помощью самоуправления.

    Один из способов внешнего управления состоит в последовательном соединении функциональных узлов, где предыдущий узел управляет движением информации в следующем, последний узел называют генерирующим. Если , то такое соединение называют каскадным с числом каскадов . Конструкция каскада может быть простой, например, каскад — это ЛРС, и управление реализуется в каждый такт в виде зависимости от управляющего знака величины «продвижения» информации генерирующего автомата.

    Другой способ основан на нескольких взаимно управляемых автоматах, совместно генерирующих гамму (см. генератор шифра А5 [13]). При самоуправлении величина «продвижения» информации в регистрах автомата управляется гаммой, зависящей от состояния всех регистров памяти.

    9.5.1. Схемы с внешним управлением. Для двоичного ЛРС- , , обозначим: — характеристический многочлен; — длина периода выходной гаммы ( не зависит от начального состояния при ЛРС с максимальной длиной периода).

    Генератор « шагов» - двухкаскадная схема (рис. 9.3), где (при ( — генератор «стоп-вперед»), управляющий автомат есть ф.г. на базе ЛРС-1 длины с фильтрующей булевой функцией , генерирующий автомат есть ЛРС-2 длины (гамма есть последовательность состояний его -й ячейки). Далее считаем, что , , .

    Обозначим: и — линейные подстановки, реализуемые соответственно ЛРС-1 на и ЛРС-2 на ; — нелинейная подстановка множества состояний генератора; и — состояния ЛРС-1 и ЛРС-2 в -м такте, ; при — начальные состояния. При любом состоянии генератора подстановка имеет вид:

    ,

    где . Уравнения гаммообразования имеют вид

    ,

    где величина «продвижения» ЛРС-2 после первых тактов:

    .

    Лемма 9.1. Величина не зависит от делит i.

    Доказательство. Обозначим: .

    По условию и на периоде ЛРС-1 имеется нулей и единиц. Тогда при , величина не зависит от :

    .

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

    В соответствии с леммой 9.1 при , кратных . Обозначим .Тогда оба регистра вернутся в начальное состояние при «продвижении» ЛРС-2 на шагов, достигаемом после тактов, где . Следовательно, длина периода гаммы генератора достигает наибольшего значения при .

    Группа генератора « шагов» есть циклическая группа . При начальном состоянии генераторасостояние после тактов есть , , Отсюда подстановка линейная величина не зависит от . Тем самым доказана следующая теорема.

    Теорема 9.3 [13]. Если управляющий блок генератора « шагов» состоит из ф.г. на базе ЛРС , ограничение фильтра на отлично от константы, а генерирующий блок есть ЛРС , то порядок линейной подгруппы группы равен .

    Для линейной сложности гаммы генератора верна оценка .

    В генераторе «стоп-вперед» эта оценка достигается [17], если управляющий регистр есть ЛРС и . Но статистические свойства его гаммы слабы: в среднем каждый 2-й бит выхода ЛРС-2 дублируется; из неравенства следует , что упрощает нахождение состояний ЛРС-1 по гамме.

    Если , то в гамме генератора «1-2 шага» при частота всех -грамм та же, что и в гамме ЛРС-2 при равномерном движении.

    Генератор с перемежающимся шагом является усложнением генератора «стоп-вперед» с целью улучшения статистических свойств. Гамма образуется как сумма гамм двух генераторов «стоп-вперед» с генерирующими ЛРС-2 и ЛРС-3 длины и соответственно, имеющими общий управляющий блок — ф.г. с фильтром на базе ЛРС-1 длины . Если в -м такте управляющий знак равен 1, то ЛРС-2 продвигается на 1 шаг, а ЛРС-3 простаивает; при управляющем знаке 0 — наоборот. Ключом генератора являются начальные состояния всех ЛРС.

    Длина периода наибольшая и равна при попарно взаимно простых числах , и .


    При максимальной длине периодов ЛРС-2 и ЛРС-3 частота в гамме всех -грамм, где , близка к c отклонением порядка .

    Ключ генератора (как и генератора « шагов») определяется по гамме опробованием начального состояния ЛРС-1 (метод типа «разделяй и вскрывай»). Отсюда эффективная длина ключа генератора с перемежающимся шагом близка к длине управляющего регистра.

    Каскадные генераторы Гольмана. Такие генераторы построены на основе ЛРС-1, …, ЛРС- с максимальными длинами периодов, где первый ЛРС управляет вторым, второй — третьим и т.д. Если все ЛРС имеют длину и различные примитивные характеристические многочлены [20], то длина периода гаммы -каскадного генератора достигает величины , а линейная сложность имеет порядок . При корреляция между гаммой ЛРС-1 и гаммой -каскадного генератора позволяет построить эффективный метод последовательного вскрытия начальных состояний ЛРС, начиная с 1-го [25].

    Сжимающие генераторы. Построены на основе параллельно работающих ЛРС-1 и ЛРС-2 с максимальными длинами периодов. Знаки гаммы снимаются с ячейки ЛРС-2 только в те такты, когда управляющий знак ЛРС-1 равен 1; в остальные такты биты, генерируемые ЛРС-1 и ЛРС-2, игнорируются. При таком законе гаммообразования есть знак ЛРС-2 с номером такта, соответствующего -й единице в выходной последовательности ЛРС-1.

    Гамма сжимающего генератора имеет хорошую длину периода и линейную сложность. Слабости обнаружены, когда характеристические многочлены содержат мало ненулевых коэффициентов. Реализация сжимающего генератора имеет высокую скорость, но имеются определенные проблемы с нерегулярностью выдачи знаков гаммы. В связи с этим предлагается техника буферизации.

    9.5.2. Схемы с самоуправлением. Самопрореживающие генераторы могут строиться на базе одного ЛРС с помощью добавления одной обратной связи. Их гамма получена удалением части знаков из гаммы равномерно движущегося ЛРС.

    Генератор -самоусечения. Построен на основе ЛРС [27], где величина сдвига информации управляется состоянием некоторых ячеек регистра. В частности, информация в ЛРС продвигается на шагов, если знак управляющей гаммы (состояние -й ячейки регистра) равен 1, и в противном случае информация в ЛРС продвигается на шагов, где . В более сложных модификациях генератора знак, определяющий величину сдвига информации, есть функция от состояния нескольких ячеек ЛРС.

    Экспериментально установлено, что линейная сложность гаммы генератора (1,2)-самоусечения близка к , доказательства не найдены.

    Простейший генератор -самоусечения не рекомендуется использовать непосредственно, так как любой бит на выходе является битом состояния, и при известном законе движения следующий бит выхода позиционно привязывается к предыдущему. Для повышения стойкости генератора используют различные подмножества битов состояния для генерации гаммы и для управления движением.

    Самосжимающий генератор строится на основе ЛРС , где с двух ячеек снимаются 2 знака: если 1-й знак равен 1, то 2-й знак идет на выход; иначе 2-й знак игнорируется. Для гаммы самосжимающего генератора также достижимы хорошие характеристики. По сравнению со сжимающими генераторами их скорость в 2 раза меньше, но и регистров требуется в 2 раза меньше.

    9.5.3. Генераторы с дополнительной памятью. Для снижения корреляции между выходной и промежуточными гаммами используют дополнительные регистры памяти. В криптосхемах используют несколько способов дополнения памяти. К таким схемам относятся генераторы Макларена-Марсальи и регистры сдвига с обратной связью с переносом [19, 22].




    написать администратору сайта