RU2519004C2 - Способ трехмерного нелинейного преобразования замены - Google Patents

Способ трехмерного нелинейного преобразования замены Download PDF

Info

Publication number
RU2519004C2
RU2519004C2 RU2012130652/08A RU2012130652A RU2519004C2 RU 2519004 C2 RU2519004 C2 RU 2519004C2 RU 2012130652/08 A RU2012130652/08 A RU 2012130652/08A RU 2012130652 A RU2012130652 A RU 2012130652A RU 2519004 C2 RU2519004 C2 RU 2519004C2
Authority
RU
Russia
Prior art keywords
layer
round
layers
replacement
bit
Prior art date
Application number
RU2012130652/08A
Other languages
English (en)
Other versions
RU2012130652A (ru
Inventor
Михаил Александрович Иванов
Николай Петрович Васильев
Илья Владимирович Чугунков
Original Assignee
федеральное государственное автономное образовательное учреждение высшего профессионального образования "Национальный исследовательский ядерный университет МИФИ" (НИЯУ МИФИ)
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by федеральное государственное автономное образовательное учреждение высшего профессионального образования "Национальный исследовательский ядерный университет МИФИ" (НИЯУ МИФИ) filed Critical федеральное государственное автономное образовательное учреждение высшего профессионального образования "Национальный исследовательский ядерный университет МИФИ" (НИЯУ МИФИ)
Priority to RU2012130652/08A priority Critical patent/RU2519004C2/ru
Publication of RU2012130652A publication Critical patent/RU2012130652A/ru
Application granted granted Critical
Publication of RU2519004C2 publication Critical patent/RU2519004C2/ru

Links

Landscapes

  • Complex Calculations (AREA)
  • Image Processing (AREA)
  • Compression Or Coding Systems Of Tv Signals (AREA)

Abstract

Изобретение относится к вычислительной технике и электросвязи,
предназначено для решения задач защиты компьютерной информации.
Техническим результатом изобретения является повышение быстродействия за счет увеличения степени параллелизма. Способ выполнения трех раундов преобразования осуществляется вдоль осей х, у, z. В первом раунде выполняют N двухмерных преобразований замены слоев L x0, L x1, ..., L x(N-1) ; во втором раунде выполняют N двухмерных преобразований замены слоев L y0 , L y1 , ..., Ly (N-1); в третьем раунде выполняют N двухмерных преобразований замены слоев L z0, L z1, ..., L z(N-1) . 5 ил., 1 табл.

Description

Изобретение относится к вычислительной технике и электросвязи, предназначено для решения задач защиты компьютерной информации. Наиболее предпочтительной областью использования изобретения является построение генераторов псевдослучайных чисел (ГПСЧ), а также криптографических примитивов хеширования, блочного и поточного шифрования.
В совокупности признаков заявленного изобретения используются следующие термины:
Стохастическое преобразование - непредсказуемое преобразование данных; примером стохастического преобразования может являться криптографическое преобразование;
Раунд - последовательность шагов, образующих одну итерацию итеративного (многораундового) преобразования;
Двоичный вектор - некоторая последовательность нулевых и единичных бит, например (01101010), двоичный вектор разрядности n может быть интерпретирован как элемент конечного поля GF(2n);
Замена (Substitution) - операция, выполняемая над двоичным вектором i∈GF(2n), при этом результат операции равен содержимому ячейки с индексом i таблицы замен размерности n×2n.
Известен способ преобразования замены, описанный в Российском стандарте криптографической защиты информации [Стандарт СССР ГОСТ 28147-89. Системы обработки информации. Защита криптографическая. Алгоритм криптографического преобразования]. Способ-аналог включает в себя формирование 32-разрядного вектора, после чего над двоичным вектором F выполняют операцию замены F:=S(F), при этом операция замены выполняется следующим образом. Двоичный вектор F разбивается на 8 двоичных векторов длиной по 4 бит каждый. Каждый 4-разрядный двоичный вектор заменяется двоичным вектором из соответствующей таблицы замен размерности 4×16. Выбранные из таблиц замен восемь 4-разрядных векторов объединяются в преобразованный двоичный вектор F.
Недостатком данного способа является низкие криптостойкость и быстродействие, невозможность реализации с использованием гибридных суперкомпьютерных технологий.
Наиболее близким по своей технической сущности к заявленному способу является принятый за прототип способ трехмерного преобразования [Иванов М.А., Ковалев А.В., Чугунков И.В. и др. Стохастические методы защиты информации в компьютерных системах и сетях. М.: Кудиц-Пресс, 2009, с.243-246], включающий представление входного блока M и всех промежуточных результатов преобразования разрядностью 512 бит в виде кубического массива; введение понятие слоя (Layer) - квадратного массива разрядностью 128 бит; выполнение трех раундов преобразования соответственно вдоль осей x, y, z; деление блока данных M перед выполнением преобразований первого раунда на 4 слоя Lx0, Lx1, Lx2, Lx3 вдоль оси x; деление результата работы первого раунда перед выполнением преобразований второго раунда на 4 слоя Ly, Ly1, Ly2, Ly3 вдоль оси y; деление результата работы второго раунда перед выполнением преобразований третьего раунда на 4 слоя Lz0, Lz1, Lz2, Lz3 вдоль оси z.
Недостатками известного решения является низкое быстродействие и ограниченные функциональные возможности.
К причинам, препятствующим достижению указанного ниже технического результата, относится недостаточная эффективность при реализации на основе гибридных суперкомпьютерных технологий из-за малой степени параллелизма на уровне инструкций и зависимость разрядности используемых блоков замены от разрядности обрабатываемых блоков данных.
Указанный технический результат при осуществлении изобретения достигается тем, что в многораундовом трехмерном преобразовании замены, включающем
представление входного блока M и всех промежуточных результатов преобразования разрядностью N3 (N>1) бит в виде кубического массива битов N×N×N;
введение понятие слоя (Layer) - квадратного массива битов N×N;
выполнение трех раундов преобразования соответственно вдоль осей x, y, z;
деление блока данных М перед выполнением преобразований первого раунда на N слоев Lx0, Lx1, …, Lx(N-1) вдоль оси х;
деление результата работы первого раунда перед выполнением преобразований второго раунда на N слоев Ly0, Ly1, …, Ly(N-1) вдоль оси y;
деление результата работы второго раунда перед выполнением преобразований третьего раунда на N слоев Lz0, Lz1, …, Lz(N-1) вдоль оси z;
дополнительно
формируют k таблиц замен Si размерностью N×2N каждая, i=0, 1, …, (k-1), k≥1;
в первом раунде выполняют N двухмерных преобразований замены слоев Lx0, Lx1, …, Lx(N-1);
во втором раунде выполняют N двухмерных преобразований замены слоев Ly0, Ly1, …, Ly(N-1);
в третьем раунде выполняют N двухмерных преобразований замены слоев Lz0, Lz1, …, Lz(N-1).
Новым также является то, что двумерное преобразование замены слоя L может выполняться за два раунда, при этом формируют две различные таблицы замен S0 и S1 размерностью N×2N каждая;
в первом раунде слой L делят на NN-разрядных векторов-строк R0, R1, …, R(N-1), каждый i-й N-разрядный вектор Ri, i=0, 1, …, (N-1), заменяют N-разрядным вектором из таблицы замен S0 в соответствии с выражением Ri=S0(Ri), выбранные из таблицы замен N N-разрядных векторов Ri объединяют в преобразованный слой L;
во втором раунде слой L делят на NN-разрядных векторов-столбцов С0, С1, …, C(N-1), каждый i-й N-разрядный вектор Ci, i=0, 1, …, (N-1), заменяют N-разрядным вектором из таблицы замен S1 в соответствии с выражением С,=Si (С,), выбранные из таблицы замен N N-разрядных векторов Ci объединяют в преобразованный слой L, который выдают в качестве результата двумерного преобразования замены слоя L.
Новым также является то, что двумерное преобразование замены слоя L может выполняться за два раунда, при этом формируют таблицу замен S размерностью N×2N;
в первом раунде слой L делят на N N-разрядных векторов-строк R0, R1, …, R(N-1), каждый i-й N-разрядный вектор Ri, i=0, 1, …, (N-1), заменяют N-разрядным вектором из таблицы замен S в соответствии с выражением Ri=S(Ri), выбранные из таблицы замен N N-разрядных векторов Ri объединяют в преобразованный слой L;
во втором раунде слой L делят на NN-разрядных векторов-столбцов C0, С1, …, C(N-1), каждый i-й N-разрядный вектор Ci, i=0, 1, (N-1), заменяют N-разрядным вектором из таблицы замен S в соответствии с выражением Сi=S(Ci), выбранные из таблицы замен N N-разрядных векторов Ci объединяют в преобразованный слой L, который выдают в качестве результата двумерного преобразования замены слоя L.
Новым также является то, что при выполнении трехмерного нелинейного преобразования замены могут использоваться две различные таблицы замен S0 и S1 размерностью N×2 каждая, при этом строки всех слоев заменяют с использованием таблицы замен S0, а столбцы всех слоев заменяют с использованием таблицы замен S1.
Новым также является то, что при выполнении трехмерного нелинейного преобразования замены
могут использоваться три различные таблицы замен S0, S1 и S2 размерностью N×2n каждая, при этом слои Lxi, расположенные вдоль оси х, заменяют с использованием таблицы замен S0; слои Lyi, расположенные вдоль оси y, заменяют с использованием таблицы замен S1, а слои Lzi, расположенные вдоль оси z, заменяют с использованием таблицы замен S2.
Новым также является то, что при выполнении трехмерного нелинейного преобразования замены
могут использоваться шесть различных таблиц замен S0, S1, …, S5 размерностью N×2n каждая, при этом строки слоев Lxi, расположенных вдоль оси x, заменяют с использованием таблицы замен S0; столбцы слоев Lxi, расположенных вдоль оси x, заменяют с использованием таблицы замен S1; строки слоев Lyi, расположенных вдоль оси y, заменяют с использованием таблицы замен S2; столбцы слоев Lyi, расположенных вдоль оси y, заменяют с использованием таблицы замен S3, строки слоев Lzi, расположенных вдоль оси z, заменяют с использованием таблицы замен S4; столбцы слоев Lzi, расположенных вдоль оси z, заменяют с использованием таблицы замен S5.
Таким образом, техническим результатом заявленного изобретения является увеличение быстродействия и расширение функциональных возможностей за счет увеличения разрядности блока данных, обрабатываемого одним блоком замены.
Суть предлагаемого способа иллюстрируют фиг.1-5. На фиг.1, 2 показан принцип двухмерного преобразования слоя, иначе говоря, принцип работы 2D S-блока при N=4. На фиг.1 показан блок 1 данных (слой) 4×4; строки 20, 21, 22, 23 слоя; столбцы 30, 31, 32, 33 слоя. На фиг.2 показаны преобразования замены 40, 41, 42, 43 строк, которые могут выполняться параллельно, и преобразования замены 50, 51, 52, 53 столбцов, которые также могут выполняться параллельно, входной 6 (исходный) и выходной 7 (преобразованный) блок данных (слой). На фиг.3-5 показан принцип трехмерного преобразования слоя, иначе говоря, принцип работы 3D S-блока при N=4. На фиг.3 показан блок 8 данных 4×4×4 и отдельный бит 9 блока 8 данных. На фиг.4 показано разделение на слои 10xk, 10yk, 10zk, k=0, 1, 2, 3, вдоль осей x, y, z и отдельные слои 10xk, 10yk, 10zk (Lxk, Lyk, Lzk). Ha фиг.5 показаны операции преобразования 11x0, 11x1, 11x2, 11x3 слоев 10x0, 10x2, 10x3 вдоль оси x, которые могут выполняться параллельно; операции преобразования 11y0, 11y1, 11y2, 11y3 слоев 10y0, 10y1, 10y2, 10y3 вдоль оси y, которые могут выполняться параллельно и операции преобразования 11z0, 11z1, 11z2, 11z3 слоев 10z0, 10z1, 10z2, 10z3 вдоль оси z, которые могут выполняться параллельно.
Рассмотрим последовательность выполнения двухмерного преобразования замены слоя, т.е. алгоритм функционирования 2D S-блока.
Представим входные 6 и выходные 7 блоки данных, а также все промежуточные результаты преобразований в виде квадратного массива битов 1 размерностью N×N, где N - разрядность используемых узлов замены. Таким образом, объем ключевой информации, однозначно определяющей логику работы каждого узла замены, равен N×2N. На фиг.1 показан пример массива размерностью 4×4.
Последовательность выполнения операции А=SubSquare[A] 11 (или кратко, А=Ssq[A]), замены квадратного массива 10 битов A размерностью N×N, имеет следующий вид:
- Разбиение входного 6 массива A на N строк 2iRi длины N, i=0, 1, …, (N-1), (фиг.1);
- Преобразование 4 SubRows. Преобразование 4, каждого i-го N-разрядного двоичного набора 2iRi с использованием соответствующего узла замены Si:Ri=Si[Ri], i=0, 1, …, (N-1);
- Разбиение получившегося массива А=SnbRows[A] на N столбцов 3iCi длины N,i=0, 1, …, (N-1), (фиг.1);
- Преобразование 5 SubColumns. Преобразование 5, каждого i-го N-разрядного двоичного набора 3iCi с использованием соответствующего узла замены Si+N:Ci=Si+N[Ci], i=0, 1, …, (N-1);
- Результатом замены является 7 А=SnbColunms[A].
В частном случае, когда используется только одна таблица замен, т.е.=S, получаем следующий алгоритм:
- Разбиение входного 6 массива A на N строк 2iRi, длины N;
- Преобразование 4 SubRows. Преобразование каждого i-го N-разрядного двоичного набора 2iRi:Ri=S[Ri], i=0, 1, …, (N-1);
- Разбиение получившегося массива А=SubRows[A] на N столбцов 3iCi, длины N;
- Преобразование 5 SubColumns. Преобразование каждого /-го N-разрядного двоичного набора 3iCii=S[Ci], i=0, 1, …, (N-1);
- Результатом замены является блок 7 А=SubCoIumns[A]. Рассмотрим последовательность выполнения трехмерного преобразования замены, т.е. алгоритм функционирования 3D S-блока.
Представим входные 12 и выходные 13 блоки данных, а также все промежуточные результаты преобразований в виде кубического массива битов 8 размерностью N×N×N, где N - разрядность используемых узлов замены. Таким образом, объем ключевой информации, однозначно определяющей логику работы каждого узла замены, равен N×2n. На фиг.3 показан пример массива 8 размерностью 4×4×4.
Последовательность выполнения операции замены кубического массива битов 12 А=SubCube[A] (или кратко, А=Scu[A]) размерностью N×N×N имеет следующий вид:
- Разбиение входного массива 12 A на N слоев 10xi, Lxi размерностью N×N вдоль оси x, i=0, 1, …, (N-1), (фиг.4);
- Преобразование SubLayersX. Выполнение преобразования 11xi, Lxi=SubSquare[Lxi] каждого i-го слоя 10xi Lxi с использованием соответствующих узлов замены, j=0, 1, …, (N-1); все преобразования 1 при этом могут выполняться параллельно;
- Разбиение получившегося массива А=SubLayersX[A] на N слоев 10yi Lyi размерностью N×N вдоль оси у, i=0, 1, …, (N-1), (фиг.4);
- Преобразование SubLayersY. Выполнение преобразования 11yi Lyi=SubSquare[Lyi] каждого i-го слоя 10yi Lyi с использованием соответствующих узлов замены, i=0, 1, …, (N-1); все преобразования 11yi при этом могут выполняться параллельно;
- Разбиение получившегося массива A=SubLayersY[A] на N слоев 10zi Lzi - размерностью N×N вдоль оси z, i=0, 1, …, (N-1), (фиг.4);
- Преобразование SubLayersZ. Выполнение преобразования 11Zi Lzi=SiibSqnare[LZi] каждого i-го слоя 10zi Lzi с использованием соответствующих узлов замены, i=0, 1, …, (N-1); все преобразования 11zi при этом могут выполняться параллельно;
- Результатом замены является 13 А=SubLayersZ[A].
На фиг.5 показана последовательность преобразования массива 8 размером 4×4×4.
Предложены способы выполнения операции замены в двух и трех измерениях с использованием соответственно 2D и 3D 3-блоков. Описаны операции преобразования строк, столбцов и слоев блоков данных. Наиболее очевидное назначение предлагаемых алгоритмов - преобразование N2- и N3-разрядных блоков данных с использованием таблицы замен размерности N×2 при построении нелинейных функций выхода или обратной связи ГПСЧ, примитивов хеширования, блочного и поточного шифрования.
В последние годы все большую популярность завоевывают гибридные вычислительные системы, сочетающие удобство классических вычислений на центральных процессорах (CPU) с массово-параллельными вычислениями на графических процессорах (GPU) [Боресков А.В., Харламов А.А. Основы работы с технологией CUDA. М.: ДМК Пресс, 2011], [CUDA Zone. URL http://developer.nvidia.com/category/zone/cuda-zone]. Особенностью GPU является наличие большого числа (десятки и сотни) вычислительных ядер, работающих параллельно. В задачах, допускающих распараллеливание обработки потока исходных данных, выигрыш в производительности для системы CPU/GPU составляет до нескольких десятков раз по сравнению с классической CPU-системой. Многие из наиболее производительных современных суперкомпьютеров также имеют гибридную архитектуру CPU/GPU.
В гибридных системах CPU решает задачи управления выполнением программы в целом и проведения не очень "тяжелых" вычислений; наиболее критичные по производительности участки программы оформляются в виде специальных функций-ядер (kernel), которые запускаются на GPU. Современные производители графических процессоров, в частности компания NVIDIA, предоставляют разработчикам программ для систем CPU/GPU мощные инструментальные средства. Полезной и приятной особенностью таких средств является то, что они являются бесплатными. В качестве примеров можно указать CUDA Toolkit [CUDA Toolkit. URL ] и Parallel NSight [NVIDIA Parallel Nsight. URL nvidia-parallel-nsight], которые интегрируются с современными популярными системами разработки ПО, такими как Microsoft Visual Studio и NetBeans.
Для программной реализации предложенного алгоритма замены наиболее целесообразной представляется технология CUDA (Compute Unified Device Architecture - вычислительная унифицированная архитектура устройств) от компании NVIDIA [Боресков А.В., Харламов А.А. Основы работы с технологией CUDA. М.: ДМК Пресс, 2011], [CUDA Zone. URL ]. Минимальной вычислительной единицей в CUDA является нить (thread). По сути, нить есть набор конкретных действий над элементом данных, нити группируются в пучки (warp); все нити одного пучка физически параллельно выполняются на потоковом мультипроцессоре; из потоковых мультипроцессоров состоит графический процессор. Очень важной особенностью CUDA является то, что при программировании нити образуют трехмерные структуры, именуемые блоками (block). Блоки, в свою очередь, группируются в еще более крупную многомерную структуру, именуемую сеткой (grid). Другими словами, сетка есть совокупность всех нитей, выполняющих параллельную обработку данных, и вместе с тем представляющая собой гибкую многомерную иерархическую структуру. Таким образом, CUDA-программист может оперировать с одно-, двух- или трехмерными структурами для параллельной обработки исходных данных, в том числе комбинируя размерности этих структур.
Очевидно, что при предлагаемом способе выполнения преобразования замены все слои блоков данных могут быть обработаны параллельно, а применение CUDA позволит существенно упростить процесс разработки ПО на основе алгоритма 3D замены.
Данные анализа степени параллелизма в предлагаемом преобразовании представлены в таблице 1. Таким образом, можно сделать вывод, что достоинством изобретения помимо расширения функциональных возможностей за счет увеличение разрядности блока данных, обрабатываемого одним блоком замены, является более высокая степень параллелизма, что обеспечивает получение заявляемого технического результата - увеличение быстродействия при реализации с использованием гибридных суперкомпьютерных технологий.

Claims (1)

  1. Способ трехмерного нелинейного преобразования замены, включающий представление входного блока М и всех промежуточных результатов преобразования разрядностью N 3 (N > 1) бит в виде кубического массива битов NхNхN; введение понятие слоя (Layer) - квадратного массива битов NхN; выполнение трех раундов преобразования соответственно вдоль осей х, у, z; деление блока данных М перед выполнением преобразований первого раунда на N слоев L x0, L x1, ..., L x(N-1) вдоль оси х; деление результата работы первого раунда перед выполнением преобразований второго раунда на N слоев L y0 , L y1 , ..., L y(N-1) вдоль оси у; деление результата работы второго раунда перед выполнением преобразований третьего раунда на N слоев L z0, L z1, ..., L z(N-1) вдоль оси z; отличающийся тем, что формируют k таблиц замен S i размерностью Nх2 N каждая, i = 0, 1, ..., (k - 1), 1≤k; в первом раунде выполняют N двухмерных преобразований замены слоев L x0, L x1, ..., L x(N-1) ; во втором раунде выполняют N двухмерных преобразований замены слоев L y0 , L y1 , ..., L y(N-1); в третьем раунде выполняют N двухмерных преобразований замены слоев L z0, L z1, ..., L z(N-1), при этом двумерное преобразование замены слоя L выполняется за два шага, на первом шаге слой L делят на NN -разрядных векторов-строк R 0 , R 1 ..., R (N-1), каждый j-й N-разрядный вектор R j , j= 0, 1, ..., (N - 1), заменяют N-разрядным вектором из соответствующей таблицы замен S i согласно выражению R j = S j (R j ), выбранные из таблицы замен NN- разрядных векторов R j объединяют в преобразованный слой L; на втором шаге слой L делят на N N -разрядных векторов-столбцов С0, С1 ..., С (N-1), каждый jN-разрядный вектор Cj, j = 0, 1, (N - 1), заменяют N-разрядным вектором из соответствующей таблицы замен Sj согласно выражению Cj = Sj (Cj), выбранные из таблицы замен N N -разрядных векторов Cj объединяют в преобразованный слой L, который выдают в качестве результата двумерного преобразования замены слоя L.
RU2012130652/08A 2012-07-17 2012-07-17 Способ трехмерного нелинейного преобразования замены RU2519004C2 (ru)

Priority Applications (1)

Application Number Priority Date Filing Date Title
RU2012130652/08A RU2519004C2 (ru) 2012-07-17 2012-07-17 Способ трехмерного нелинейного преобразования замены

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
RU2012130652/08A RU2519004C2 (ru) 2012-07-17 2012-07-17 Способ трехмерного нелинейного преобразования замены

Publications (2)

Publication Number Publication Date
RU2012130652A RU2012130652A (ru) 2014-02-27
RU2519004C2 true RU2519004C2 (ru) 2014-06-10

Family

ID=50151427

Family Applications (1)

Application Number Title Priority Date Filing Date
RU2012130652/08A RU2519004C2 (ru) 2012-07-17 2012-07-17 Способ трехмерного нелинейного преобразования замены

Country Status (1)

Country Link
RU (1) RU2519004C2 (ru)

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
RU2591015C1 (ru) * 2015-12-28 2016-07-10 федеральное государственное автономное образовательное учреждение высшего профессионального образования "Национальный исследовательский ядерный университет МИФИ" (НИЯУ МИФИ) Способ нелинейного трехмерного многораундового преобразования данных rdozen
RU2683689C1 (ru) * 2017-12-05 2019-04-01 федеральное государственное автономное образовательное учреждение высшего образования "Национальный исследовательский ядерный университет МИФИ" (НИЯУ МИФИ) Способ нелинейного трехмерного многораундового преобразования данных
RU2747517C1 (ru) * 2020-03-05 2021-05-06 федеральное государственное автономное образовательное учреждение высшего образования "Национальный исследовательский ядерный университет МИФИ" (НИЯУ МИФИ) Способ хеширования информации

Families Citing this family (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
RU2633132C1 (ru) * 2016-06-02 2017-10-11 Андрей Валерьевич Менячихин Способ построения узлов замены, использующий значения линейного и разностных спектров, и устройство его реализующее

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6064738A (en) * 1996-12-10 2000-05-16 The Research Foundation Of State University Of New York Method for encrypting and decrypting data using chaotic maps
RU2239290C2 (ru) * 2001-12-24 2004-10-27 Воронежский государственный университет Способ поточного шифрования данных
CN101739695A (zh) * 2009-11-26 2010-06-16 西北工业大学 一种基于三维Arnold映射的图像分组加密方法

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6064738A (en) * 1996-12-10 2000-05-16 The Research Foundation Of State University Of New York Method for encrypting and decrypting data using chaotic maps
RU2239290C2 (ru) * 2001-12-24 2004-10-27 Воронежский государственный университет Способ поточного шифрования данных
CN101739695A (zh) * 2009-11-26 2010-06-16 西北工业大学 一种基于三维Arnold映射的图像分组加密方法

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
RU2591015C1 (ru) * 2015-12-28 2016-07-10 федеральное государственное автономное образовательное учреждение высшего профессионального образования "Национальный исследовательский ядерный университет МИФИ" (НИЯУ МИФИ) Способ нелинейного трехмерного многораундового преобразования данных rdozen
RU2683689C1 (ru) * 2017-12-05 2019-04-01 федеральное государственное автономное образовательное учреждение высшего образования "Национальный исследовательский ядерный университет МИФИ" (НИЯУ МИФИ) Способ нелинейного трехмерного многораундового преобразования данных
RU2747517C1 (ru) * 2020-03-05 2021-05-06 федеральное государственное автономное образовательное учреждение высшего образования "Национальный исследовательский ядерный университет МИФИ" (НИЯУ МИФИ) Способ хеширования информации

Also Published As

Publication number Publication date
RU2012130652A (ru) 2014-02-27

Similar Documents

Publication Publication Date Title
RU2519004C2 (ru) Способ трехмерного нелинейного преобразования замены
Zheng Variant construction from theoretical foundation to applications
Wang et al. An FPGA implementation of the Hestenes-Jacobi algorithm for singular value decomposition
RU2504911C1 (ru) Способ итеративного криптографического преобразования данных
CN102799416B (zh) 面向gpu的细粒度并行应用映射方法
Fucci et al. Conical Casimir pistons with hybrid boundary conditions
CN103345580A (zh) 基于格子Boltzmann方法的并行CFD方法
CN101937425A (zh) 基于gpu众核平台的矩阵并行转置方法
Hylton et al. Tuning the performance of a computational persistent homology package
Potebnia et al. Innovative GPU accelerated algorithm for fast minimum convex hulls computation
Peng et al. Realization of a tri-valued programmable cellular automata with ternary optical computer
CN112003688A (zh) 一种基于cuda的数据加解密处理方法及系统
RU2503994C1 (ru) Способ нелинейного трехмерного многораундового преобразования данных dozen
Mahmud et al. Towards higher scalability of quantum hardware emulation using efficient resource scheduling
Moreland et al. Visualization for exascale: Portable performance is critical
Wong et al. Efficient magnetohydrodynamic simulations on distributed multi-GPU systems using a novel GPU Direct–MPI hybrid approach
Skitev et al. Methods for implementation of Pseudo-Random Number Generator based on GOST R 34.12-2015 in hybrid CPU/GPU/FPGA high-performance systems
Miki et al. Highly scalable implementation of an N-body code on a GPU cluster
Atanassov et al. Tuning the generation of Sobol sequence with Owen scrambling
Udupa et al. Accelerating depthwise convolution and pooling operations on Z-first storage CNN architectures
Cai et al. GPU-accelerated restricted boltzmann machine for collaborative filtering
Dieguez et al. Solving multiple tridiagonal systems on a multi-GPU platform
Du et al. Providing GPU capability to LU and QR within the ScaLAPACK framework
Wang et al. An efficient architecture for floating-point eigenvalue decomposition
Barrett et al. Noncommutative geometry and the standard model vacuum

Legal Events

Date Code Title Description
MM4A The patent is invalid due to non-payment of fees

Effective date: 20190718