Misplaced Pages

Non-commutative cryptography

Article snapshot taken from Wikipedia with creative commons attribution-sharealike license. Give it a read and then ask your questions in the chat. We can research this topic together.

Non-commutative cryptography is the area of cryptology where the cryptographic primitives, methods and systems are based on algebraic structures like semigroups, groups and rings which are non-commutative. One of the earliest applications of a non-commutative algebraic structure for cryptographic purposes was the use of braid groups to develop cryptographic protocols. Later several other non-commutative structures like Thompson groups, polycyclic groups, Grigorchuk groups, and matrix groups have been identified as potential candidates for cryptographic applications. In contrast to non-commutative cryptography, the currently widely used public-key cryptosystems like RSA cryptosystem, Diffie–Hellman key exchange and elliptic curve cryptography are based on number theory and hence depend on commutative algebraic structures.

Non-commutative cryptographic protocols have been developed for solving various cryptographic problems like key exchange, encryption-decryption, and authentication. These protocols are very similar to the corresponding protocols in the commutative case.

Some non-commutative cryptographic protocols

In these protocols it would be assumed that G is a non-abelian group. If w and a are elements of G the notation w would indicate the element awa.

Protocols for key exchange

Protocol due to Ko, Lee, et al.

The following protocol due to Ko, Lee, et al., establishes a common secret key K for Alice and Bob.

  1. An element w of G is published.
  2. Two subgroups A and B of G such that ab = ba for all a in A and b in B are published.
  3. Alice chooses an element a from A and sends w to Bob. Alice keeps a private.
  4. Bob chooses an element b from B and sends w to Alice. Bob keeps b private.
  5. Alice computes K = (w) = w.
  6. Bob computes K' = (w)=w.
  7. Since ab = ba, K = K'. Alice and Bob share the common secret key K.

Anshel-Anshel-Goldfeld protocol

Main article: Anshel-Anshel-Goldfeld key exchange

This a key exchange protocol using a non-abelian group G. It is significant because it does not require two commuting subgroups A and B of G as in the case of the protocol due to Ko, Lee, et al.

  1. Elements a1, a2, . . . , ak, b1, b2, . . . , bm from G are selected and published.
  2. Alice picks a private x in G as a word in a1, a2, . . . , ak; that is, x = x( a1, a2, . . . , ak ).
  3. Alice sends b1, b2, . . . , bm to Bob.
  4. Bob picks a private y in G as a word in b1, b2, . . . , bm; that is y = y ( b1, b2, . . . , bm ).
  5. Bob sends a1, a2, . . . , ak to Alice.
  6. Alice and Bob share the common secret key K = xyxy.
  7. Alice computes x ( a1, a2, . . . , ak ) = y xy. Pre-multiplying it with x, Alice gets K.
  8. Bob computes y ( b1, b2, . . . , bm) = xyx. Pre-multiplying it with y and then taking the inverse, Bob gets K.

Stickel's key exchange protocol

In the original formulation of this protocol the group used was the group of invertible matrices over a finite field.

  1. Let G be a public non-abelian finite group.
  2. Let a, b be public elements of G such that abba. Let the orders of a and b be N and M respectively.
  3. Alice chooses two random numbers n < N and m < M and sends u = ab to Bob.
  4. Bob picks two random numbers r < N and s < M and sends v = ab to Alice.
  5. The common key shared by Alice and Bob is K = ab.
  6. Alice computes the key by K = avb.
  7. Bob computes the key by K = aub.

Protocols for encryption and decryption

This protocol describes how to encrypt a secret message and then decrypt using a non-commutative group. Let Alice want to send a secret message m to Bob.

  1. Let G be a non-commutative group. Let A and B be public subgroups of G such that ab = ba for all a in A and b in B.
  2. An element x from G is chosen and published.
  3. Bob chooses a secret key b from A and publishes z = x as his public key.
  4. Alice chooses a random r from B and computes t = z.
  5. The encrypted message is C = (x, H(t) {\displaystyle \oplus } m), where H is some hash function and {\displaystyle \oplus } denotes the XOR operation. Alice sends C to Bob.
  6. To decrypt C, Bob recovers t as follows: (x) = x = x = (x) = z = t. The plain text message send by Alice is P = ( H(t) {\displaystyle \oplus } m ) {\displaystyle \oplus } H(t) = m.

Protocols for authentication

Let Bob want to check whether the sender of a message is really Alice.

  1. Let G be a non-commutative group and let A and B be subgroups of G such that ab = ba for all a in A and b in B.
  2. An element w from G is selected and published.
  3. Alice chooses a private s from A and publishes the pair ( w, t ) where t = w .
  4. Bob chooses an r from B and sends a challenge w ' = w to Alice.
  5. Alice sends the response w ' ' = (w ') to Bob.
  6. Bob checks if w ' ' = t. If this true, then the identity of Alice is established.

Security basis of the protocols

The basis for the security and strength of the various protocols presented above is the difficulty of the following two problems:

  • The conjugacy decision problem (also called the conjugacy problem): Given two elements u and v in a group G determine whether there exists an element x in G such that v = u, that is, such that v = x ux.
  • The conjugacy search problem: Given two elements u and v in a group G find an element x in G such that v = u, that is, such that v = x ux.

If no algorithm is known to solve the conjugacy search problem, then the function xu can be considered as a one-way function.

Platform groups

A non-commutative group that is used in a particular cryptographic protocol is called the platform group of that protocol. Only groups having certain properties can be used as the platform groups for the implementation of non-commutative cryptographic protocols. Let G be a group suggested as a platform group for a certain non-commutative cryptographic system. The following is a list of the properties expected of G.

  1. The group G must be well-known and well-studied.
  2. The word problem in G should have a fast solution by a deterministic algorithm. There should be an efficiently computable "normal form" for elements of G.
  3. It should be impossible to recover the factors x and y from the product xy in G.
  4. The number of elements of length n in G should grow faster than any polynomial in n. (Here "length n" is the length of a word representing a group element.)

Examples of platform groups

Braid groups

Main article: Braid group

Let n be a positive integer. The braid group Bn is a group generated by x1, x2, . . . , xn-1 having the following presentation:

B n = x 1 , x 2 , , x n 1 | x i x j = x j x i  if  | i j | > 1  and  x i x j x i = x j x i x j  if  | i j | = 1 {\displaystyle B_{n}=\left\langle x_{1},x_{2},\ldots ,x_{n-1}{\big |}x_{i}x_{j}=x_{j}x_{i}{\text{ if }}|i-j|>1{\text{ and }}x_{i}x_{j}x_{i}=x_{j}x_{i}x_{j}{\text{ if }}|i-j|=1\right\rangle }

Thompson's group

Main article: Thompson groups

Thompson's group is an infinite group F having the following infinite presentation:

F = x 0 , x 1 , x 2 , | x k 1 x n x k = x n + 1  for  k < n {\displaystyle F=\left\langle x_{0},x_{1},x_{2},\ldots {\big |}x_{k}^{-1}x_{n}x_{k}=x_{n+1}{\text{ for }}k<n\right\rangle }

Grigorchuk's group

Main article: Grigorchuk's group

Let T denote the infinite rooted binary tree. The set V of vertices is the set of all finite binary sequences. Let A(T) denote the set of all automorphisms of T. (An automorphism of T permutes vertices preserving connectedness.) The Grigorchuk's group Γ is the subgroup of A(T) generated by the automorphisms a, b, c, d defined as follows:

  • a ( b 1 , b 2 , , b n ) = ( 1 b 1 , b 2 , , b n ) {\displaystyle a(b_{1},b_{2},\ldots ,b_{n})=(1-b_{1},b_{2},\ldots ,b_{n})}
  • b ( b 1 , b 2 , , b n ) = { ( b 1 , 1 b 2 , , b n )  if  b 1 = 0 ( b 1 , c ( b 2 , , b n ) )  if  b 1 = 1 {\displaystyle b(b_{1},b_{2},\ldots ,b_{n})={\begin{cases}(b_{1},1-b_{2},\ldots ,b_{n})&{\text{ if }}b_{1}=0\\(b_{1},c(b_{2},\ldots ,b_{n}))&{\text{ if }}b_{1}=1\end{cases}}}
  • c ( b 1 , b 2 , , b n ) = { ( b 1 , 1 b 2 , , b n )  if  b 1 = 0 ( b 1 , d ( b 2 , , b n ) )  if  b 1 = 1 {\displaystyle c(b_{1},b_{2},\ldots ,b_{n})={\begin{cases}(b_{1},1-b_{2},\ldots ,b_{n})&{\text{ if }}b_{1}=0\\(b_{1},d(b_{2},\ldots ,b_{n}))&{\text{ if }}b_{1}=1\end{cases}}}
  • d ( b 1 , b 2 , , b n ) = { ( b 1 , b 2 , , b n )  if  b 1 = 0 ( b 1 , b ( b 2 , , b n ) )  if  b 1 = 1 {\displaystyle d(b_{1},b_{2},\ldots ,b_{n})={\begin{cases}(b_{1},b_{2},\ldots ,b_{n})&{\text{ if }}b_{1}=0\\(b_{1},b(b_{2},\ldots ,b_{n}))&{\text{ if }}b_{1}=1\end{cases}}}

Artin group

Main article: Artin group

An Artin group A(Γ) is a group with the following presentation:

A ( Γ ) = a 1 , a 2 , , a n | μ i j = μ j i  for  1 i < j n {\displaystyle A(\Gamma )=\left\langle a_{1},a_{2},\ldots ,a_{n}|\mu _{ij}=\mu _{ji}{\text{ for }}1\leq i<j\leq n\right\rangle }

where μ i j = a i a j a i {\displaystyle \mu _{ij}=a_{i}a_{j}a_{i}\ldots } ( m i j {\displaystyle m_{ij}} factors) and m i j = m j i {\displaystyle m_{ij}=m_{ji}} .

Matrix groups

Main article: Matrix group

Let F be a finite field. Groups of matrices over F have been used as the platform groups of certain non-commutative cryptographic protocols.

Semidirect products

Main article: Semidirect product

See also

References

  1. Habeeb, M.; Kahrobaei, D.; Koupparis, C.; Shpilrain, V. (2013). "Public Key Exchange Using Semidirect Product of (Semi)Groups". Applied Cryptography and Network Security. ACNS 2013. Lecture Notes in Computer Science. Vol. 7954. Springer. pp. 475–486. arXiv:1304.6572. CiteSeerX 10.1.1.769.1289. doi:10.1007/978-3-642-38980-1_30. ISBN 978-3-642-38980-1.

Further reading

  1. Myasnikov, Alexei; Shpilrain, Vladimir; Ushakov, Alexander (2008). Group-based Cryptography. Birkhäuser Verlag. ISBN 9783764388270.
  2. Cao, Zhenfu (2012). New Directions of Modern Cryptography. CRC Press. ISBN 978-1-4665-0140-9.
  3. Benjamin Fine; et al. (2011). "Aspects of Nonabelian Group Based Cryptography: A Survey and Open Problems". arXiv:1103.4093 .
  4. Myasnikov, Alexei G.; Shpilrain, Vladimir; Ushakov, Alexander (2011). Non-commutative Cryptography and Complexity of Group-theoretic Problems. American Mathematical Society. ISBN 9780821853603.
Public-key cryptography
Algorithms
Integer factorization
Discrete logarithm
Lattice/SVP/CVP/LWE/SIS
Others
Theory
Standardization
Topics
Cryptography
General
Mathematics
Category: