Aes

評估 S-box 的代數複雜度

  • November 5, 2019

在研究 AES S-box 的設計和理想屬性時,我了解到代數複雜性也是 S-box 的一個重要屬性,通常在評估 S-box 的屬性時會考慮它。

在閱讀了幾篇論文(例如APA)之後,我了解到代數複雜性基本上是代表該 S-box 的“代數方程”中出現的項數。

在做了一些研究(來源)之後,我知道有三種主要方法可以找到表示 S-box 的多項式方程,它們是:

  1. 拉格朗日插值
  2. 多項式線性化
  3. Q 元多項式推導

但老實說,我無法理解上述任何一種方法來找到給定 S-box 的代數方程。所以最終我可以評估它的代數複雜性。

因此,如果有人可以詳細解釋它(或相同的算法),那麼為它編寫程式碼對我來說真的很有幫助。或者,如果有其他方法(或程式碼)可以找到 AES S-box 的代數複雜性或代數方程,請分享。

**TL;DR:**給定一個 S-box ( $ n \times n $ ) ,我們如何評估它的代數方程或代數複雜性?

Sbox 的插值基於拉格朗日算法。以下三個步驟用於計算 S-box 的插值:

  1. 將 S-box 值表示為多項式系統,其中 P 和 C 是 S-box 輸入和輸出的多項式表示。
  2. M (N x N ) 是由 P 次冪多項式組成的矩陣。N 是 sbox 大小(8 位 sbox 為 256)
  3. 從以下等式求解 B:MB=C
# the Equation is M.B=C.
#     1  p0  p0^2  p0^3  p0^4  p0^5 .......  p0^d   
#     1  p1  p1^2  p1^3  p1^4  p1^5 .......  p1^d
#  M= 1  p2  p2^2  p2^3  p2^4  p2^5 .......  p2^d
#     1  p3  p3^2  p3^3  p3^4  p3^5 .......  p3^d   
#       .
#       .
#       .
#     1  pn  pn^2  pn^3  pn^4  pn^5 .......  pn^d 
#  size of M is dXn , d and n are equal for sbox, they are GF (2^8) (8-bit sbox)
# Calculation steps. 
#   1. convert Sbox table to polynomial of input and output, vectors (P is input  and C is output)
#   2. calculate M table  
#   3. B=M.solve_right(C)
#

以下程式碼是 Rijndael S-box 的插值表示的實現

f=x^8+x^4+x^3+x^1+1  # irreducible polynomial
L.<z>= GF(2^8,modulus=f)
R=PolynomialRing(L,'x')
N=256
M=matrix(L,N,N)
S=[0x63, 0x7C, 0x77, 0x7B, 0xF2, 0x6B, 0x6F, 0xC5, 0x30, 0x01, 0x67, 0x2B, 0xFE, 0xD7, 0xAB, 0x76, 
                            0xCA, 0x82, 0xC9, 0x7D, 0xFA, 0x59, 0x47, 0xF0, 0xAD, 0xD4, 0xA2, 0xAF, 0x9C, 0xA4, 0x72, 0xC0,
                            0xB7, 0xFD, 0x93, 0x26, 0x36, 0x3F, 0xF7, 0xCC, 0x34, 0xA5, 0xE5, 0xF1, 0x71, 0xD8, 0x31, 0x15,
                            0x04, 0xC7, 0x23, 0xC3, 0x18, 0x96, 0x05, 0x9A, 0x07, 0x12, 0x80, 0xE2, 0xEB, 0x27, 0xB2, 0x75,
                            0x09, 0x83, 0x2C, 0x1A, 0x1B, 0x6E, 0x5A, 0xA0, 0x52, 0x3B, 0xD6, 0xB3, 0x29, 0xE3, 0x2F, 0x84,
                            0x53, 0xD1, 0x00, 0xED, 0x20, 0xFC, 0xB1, 0x5B, 0x6A, 0xCB, 0xBE, 0x39, 0x4A, 0x4C, 0x58, 0xCF,
                            0xD0, 0xEF, 0xAA, 0xFB, 0x43, 0x4D, 0x33, 0x85, 0x45, 0xF9, 0x02, 0x7F, 0x50, 0x3C, 0x9F, 0xA8,
                            0x51, 0xA3, 0x40, 0x8F, 0x92, 0x9D, 0x38, 0xF5, 0xBC, 0xB6, 0xDA, 0x21, 0x10, 0xFF, 0xF3, 0xD2,
                            0xCD, 0x0C, 0x13, 0xEC, 0x5F, 0x97, 0x44, 0x17, 0xC4, 0xA7, 0x7E, 0x3D, 0x64, 0x5D, 0x19, 0x73,
                            0x60, 0x81, 0x4F, 0xDC, 0x22, 0x2A, 0x90, 0x88, 0x46, 0xEE, 0xB8, 0x14, 0xDE, 0x5E, 0x0B, 0xDB,
                            0xE0, 0x32, 0x3A, 0x0A, 0x49, 0x06, 0x24, 0x5C, 0xC2, 0xD3, 0xAC, 0x62, 0x91, 0x95, 0xE4, 0x79,
                            0xE7, 0xC8, 0x37, 0x6D, 0x8D, 0xD5, 0x4E, 0xA9, 0x6C, 0x56, 0xF4, 0xEA, 0x65, 0x7A, 0xAE, 0x08,
                            0xBA, 0x78, 0x25, 0x2E, 0x1C, 0xA6, 0xB4, 0xC6, 0xE8, 0xDD, 0x74, 0x1F, 0x4B, 0xBD, 0x8B, 0x8A,
                            0x70, 0x3E, 0xB5, 0x66, 0x48, 0x03, 0xF6, 0x0E, 0x61, 0x35, 0x57, 0xB9, 0x86, 0xC1, 0x1D, 0x9E,
                            0xE1, 0xF8, 0x98, 0x11, 0x69, 0xD9, 0x8E, 0x94, 0x9B, 0x1E, 0x87, 0xE9, 0xCE, 0x55, 0x28, 0xDF,
                            0x8C, 0xA1, 0x89, 0x0D, 0xBF, 0xE6, 0x42, 0x68, 0x41, 0x99, 0x2D, 0x0F, 0xB0, 0x54, 0xBB, 0x16] # rajS-box 

C=vector(L,N)
P=vector(L,N)

# step 1
for i in range(0,N):

   P[i]= (i) + z^1*(i>>1) + z^2*(i>>2) + z^3*(i>>3) + z^4*(i>>4) + z^5*(i>>5) + z^6*(i>>6) + z^7*(i>>7)
   C[i]= S[(i)] + z^1*(S[i]>>1) + z^2*(S[i]>>2) + z^3*(S[i]>>3) + z^4*(S[i]>>4) + z^5*(S[i]>>5) + z^6*(S[i]>>6) + z^7*(S[i]>>7)


#print P
#print C
# step 2
for j in range(0,N):
   for i in range(0,N):
       M[j,i]= P[j]^i





#step 3
B=M.solve_right(C)



print B

我很高興偶然發現這個老問題。S盒由線性循環運算組成 $ \text{L} $ 由表示的非線性操作組成 $ \text{Inv}() $ 並在 8 位上以相反的順序添加十六進制數字 63 $ x $ . 自從 $ x $ 可以認為是一個元素 $ \text{F}_{2^8} $ , 的代數方程 $ \text{Inv}() $ 操作可以與操作一起編寫 $ \text{L} $ 並添加常數。所以專注於編寫代數 MQ 方程 $ x, \space y $ 其中 y=Inv(x)。這 $ \text{Inv}() $ 定義為 $ \text{Inv}(x)=x^{-1} $ 在場的時候 $ x\neq 0 $ 和 $ \text{Inv}(x)=0 $ 什麼時候 $ x=0 $ . 中的代數方程 $ x, \space y $ 是 $ xy^2-y=0, \space yx^2-x=0 $ . 這些滿足 $ \text{Inv}() $ 確切地。

引用自:https://crypto.stackexchange.com/questions/22944