Generation of High Order Primitive Matrix Elements for Post-Quantum Key Exchange Protocol
Total Page:16
File Type:pdf, Size:1020Kb
Generation of high order primitive matrix elements for post-quantum key exchange protocol Richard Megrelishvili Melkisadeg Avtandil Gagnidze Maksim Iavich Giorgi Iashvili Math dept. Tbilisi State Jinjikhadze Faculty of management. School of technology. School of technology. University Math dept. Akaki Bank of Georgia Caucasus University Caucasus University Tbilisi, Georgia Tsereteli State University Tbilisi, Georgia Tbilisi, Georgia [email protected] University Tbilisi, Georgia [email protected] [email protected] Kutaisi, Georgia [email protected] [email protected] Abstract— Active work is performed to create quantum Public-key cryptography is used in different products, on computers. Quantum computers can break existing public key different platforms and in various fields. Many commercial cryptography. So they can break Diffie-Hellman key exchange products use public-key cryptography, the number of which is protocol. Matrix algorithms of key exchange can be considered as the actively growing. Public-key cryptography is also widely used alternative to Diffie-Hellman key exchange protocol. in operating systems from Microsoft, Apple, Sun, and Novell. The improved method of key-exchange protocol is offered in the It is used in secure phones, Ethernet, network cards, smart article. The method deals with the original matrix one-way function cards, and it is widely used in cryptographic hardware. Public- and the generalized method of processing the corresponding high order key technology is used in protected Internet communications, matrix multiplicative finite commutative group. such as S / MIME, SSL and S / WAN. It is used in government, banks, most corporations, different laboratories and educational The general method of the insertion-enlarging method of building organizations. Breaking existing public-key crypto-systems the primitive elements of the field is derived from elements of the will cause complete chaos [1,2]. matrix groups with different power. Public-key crypto systems, resistant to quantum attacks, are The article describes the results that give us the prospect of developed. But nowadays successful attacks are recorded on generating the high order multiplicative Abelian matrix groups and of these systems [3,4]. creating key-exchange protocol, resistant to quantum computers attacks by means of this groups. II. ONE-WAY MATRIX FUNCTION One of the modifications of Diffie-Hellman's well-known Keywords— Matrix One-way Function, Abelian Finite Field, method of cryptographic key exchange is the matrix algorithms Asymmetric Cryptography, High order finite matrix Field, Primitive Matrix Element, quantum computers, post-quantum cryptography. of the exchange, the basis for which is the high order cyclic multiplicative matrix groups in the GF (2) field. Suppose that the P matrix is a primitive element of a cyclic I. INTRODUCTION matrix group. While (P) is a multiplicative group formed by this Scientists and experts are actively working on the creation of matrix, with the power 2푛 − 1, where n is the size of the square quantum computers. GOOGLE Corporation, NASA the matrix. association USRA (Universities Space Research Association The matrix algorithm for general key development is the and D-Wave teamed-up to develop quantum processors. following: Quantum computers can break existing public-key crypto systems. Quantum computer solves the discrete logarithm The sender sends to the receiving party via the open problem both for finite fields and elliptic curves. Being able to channel 푢1 = 푣푃1 vector, where 푃1 ∈ 〈푃〉 is the secret matrix, calculate efficiently discrete logarithms, it can break Diffie- Hellman key exchange protocol. selected by the sender, and 푣 ∈ 푉푛 is commonly known (푉푛 – is Quantum computer also solves the factorization problem, so it vector space on 퐺퐹(2) field); can easily break RSA cryptosystem. The receiving party chooses 푃2 ∈ 〈푃〉 to send a secret matrix and sends to the sender 푢2 = 푣푃2 vector; © 2019 for this paper by its authors. Use permitted under Creative Commons License Attribution 4.0 International (CC BY 4.0) 48 Sender calculates 푘1 = 푢2푃1 vector; The polynomial coefficients generated by the above structure, Receiver calculates 푘2 = 푢1푃2 푣, where 푘1 and 푘2 – are known as the Serpinsky triangle. Serpinsky's structure are secret keys. contains a number of sub-structures, that can be used as a generator (generating matrix) for multiplication groups, i.e. It is evident, thar 푘1 = 푘2 = 푘, because 푘 = 푣푃1푃2 = 푣푃2푃1, primitive elements. For example, while 〈푃〉 is a commutative group. Let 푣 = 1 1 1 1 1 1 1 1 1 0 0 0 0 (푣 , 푣 , 푣 , ⋯ , 푣 ) ∈ 푉 and 푢 = (푢 , 푢 , 푢 , ⋯ , 푢 ) ∈ 푉 are 1 2 3 푛 푛 1 2 3 푛 푛 푃3 = (1 0 0), 푃5 = 1 1 0 0 0 , non-secret vectors from the above mentioned algorithm and 1 1 0 1 0 1 0 0 (1 1 1 1 0) 푎11 ⋯ 푎1푛 1 1 1 1 1 1 1 푃1 = ( ⋮ ⋱ ⋮ ) ∈ 〈푃〉 푎푛1 … 푎푛푛 1 0 0 0 0 0 0 1 1 0 0 0 0 0 is the secret matrix. Then, according to the algorithm: 푃7 = 1 0 1 0 0 0 0 (2) 1 1 1 1 0 0 0 푢 푣1푎11 + 푣2푎21 + ⋯ + 푣푛푎푛1 1 1 0 1 0 1 0 0 푣 푎 + 푣 푎 + ⋯ + 푣 푎 푢 1 12 2 22 푛 푛2 2 (1) (1 1 1 1 1 1 0) 푣푃1 = ( ⋮ ) = ( ⋮ ) 푣1푎푛1 + 푣2푎푛2 + ⋯ + 푣3푎푛3 푢푛 Many others examples can be provided. Their natural powers The number of variables in the system of linear equations is the form the Abelian multiplicative cyclic group. square of the number of equations. Generally, solutions in such cases are not uniquely defined, and the system has infinitely many solutions. However, because we deal with a special types It’s easy to see that natural powers of matrices 푃3 , 푃5 , 푃7 푘 푘 푘 푘 of matrices, the solution is defined uniquely. In addition, it is 푃3 , 푃5 , 푃7 , 푘 = 1,2, … , 2 − 1 (3) obvious that the solution of the system is very time consuming and is practically impossible in real time if the size of the matrix Form the Abelian multiplicative cyclic group: is large enough. 1 1 1 1 0 1 0 0 1 1 1 0 1 2 3 4 푃3 = (1 0 0) , 푃3 = (1 1 1), 푃3 = (1 0 1) , 푃3 = (0 0 1), 1 1 0 0 1 1 0 1 0 1 0 0 All this makes it necessary to generate high order Abelian 0 1 1 0 1 0 1 0 0 5 6 7 0 multiplication matrix group, whose primitive element will be a 푃3 = (1 1 0) , 푃3 = (0 1 1), 푃3 = 푃3 = (0 1 0) high order quadratic matrix. 1 1 1 1 0 1 0 0 1 (4) Therefore we derived the insertion-enlargement method of second order enlargement of the basic structure of P3 [5]. III. FINITE MATRIX GROUPS 푗 Let's consider (1 + 훼) , where 푗 = 0, 1, 2, ⋯, and α represents Let’s keep the structure of the matrix 푃3 and enlarge it by the root of primitive polynomial in the 퐺퐹(2푛) field with the elements of the set (4) as following [5]: module 푝(푥). 푖 푗 푗 푃3 푃3 푃3 푗 푃32(푖, 푗) = (푃 0 0 ), where i,j=0..6. (5) 0 3 (1 + 훼) = 1 1 푗 푗 푃3 푃3 0 (1 + 훼)1 = 1 + 훼 11 푃 matrix is called a basic structure and let’s call 푃푖 and 푃푗 2 2 3 3 3 (1 + 훼) = 1 + 훼 101 matrices the first and the second enlarged matrice and 푃 2(푖, 푗) (1 + 훼)3 = 1 + 훼 + 훼2 + 훼3 1111 3 matrix let’s call the second order (풊, 풋) enlargement of 푃3. (1 + 훼)4 = 1 + 훼4 10001 (1 + 훼)5 = 1 + 훼 + 훼4 + 훼5 110011 49 푘 3 The set 푃3 , 푘 = 1,2, … , 2 − 1 is called the primary group for It is easy to check that 푃5 is a primitive element. It means 푘 5 퐹(푃32(푖, 푖 + 1)) group. that 푃5 , 푘 = 1,2, … , 2 − 1 is a finite Abelian multiplicative We have proved the following statement: group. 0 1 Any second order (푖, 푖 + 1) enlargement of 푃3 푃32(푖, 푖 + 1) , Consider basic structure 푃3 and enlarge it by 푃5 and 푃5 푖 = 0. .5, is a primitive element and forms a finite Abelian matrices. 32 There exist such enlargements of 푃 matrix by 푃0 and 푃1 multiplicative group 퐹(푃32(푖, 푖 + 1)) with power 2 – 1. 3 5 5 matrices, that are primitive elements. For example: For example, the matrix 푃32(0,1) is primitive, and the matrix 1 1 22∙3 +23 +1 [푃32(0,1)] is diagonal matrix: 푃1 푃1 푃1 푃1 푃1 푃1 푃3 0 0 5 5 5 5 5 5 1 1 3 1 1 22∙3 +23 +1 3 (푃5 0 0 ) , (푃5 0 0 ) (9) [푃32(0,1)] =( 0 푃3 0 ) (6) 0 1 1 0 3 푃5 푃5 0 푃5 푃5 0 0 0 푃3 1 1 푖 22∙3 +23 +1 All powers ([푃32(0,1)] ) , 푖 = 1,2, … of the matrices are primitive elemenents. Therefore the set 0 1 diagonal matrix are also diagonal and because of the set 퐹(푃3×51(푃5 , 푃5 )) is a finite Abelian multiplicative group. 31 퐹(푃32(0,1)) are a finite group, when 푖 = 2 − 1, so we see: It is easy to check that 푃2 0 0 1 1 5 0 1 22∙5 +25 +1 2 (푃3)푖 0 0 [푃3×51(푃5 , 푃5 )] = ( 0 푃5 0 ) (10) 2 2 푖 3 22∙3 +23 +1 3 푖 2 ([푃32 (0,1)] ) = ( 0 (푃3 ) 0 ) = 0 0 푃5 0 0 (푃3)푖 3 is a diagonal matrix.