/rsa

Primary LanguageC++


██████╗ ███████╗ █████╗ 
██╔══██╗██╔════╝██╔══██╗
██████╔╝███████╗███████║
██╔══██╗╚════██║██╔══██║
██║  ██║███████║██║  ██║
╚═╝  ╚═╝╚══════╝╚═╝  ╚═╝
                        

About RSA

refer

RSA (Rivest–Shamir–Adleman) is one of the commonly used asymmetric cryptography algorithm .

Operation

The RSA algorithm involves four steps: key generation, key distribution, encryption, and decryption.

RSA Proof of correctness

Before establishing the proof of correctness, there are two theorems that are essential in undertstanding RSA:

  1. Fermat's little theorem
  2. Chinese remainder theorem

Fermat's little theorem

Fermat's little theorem states that if p is a prime number, then for any integer a, the number a^p − a is an integer multiple of p.

fermats

Chinese remainder theorem

In number theory, the Chinese remainder theorem states that if one knows the remainders of the Euclidean division of an integer n by several integers, then one can determine uniquely the remainder of the division of n by the product of these integers, under the condition that the divisors are pairwise coprime.

If the remainders are same then:

Theorem: If, x = y (mod p) & x = y (mod q) with p and q coprime. Then x = y (mod pq).

Proof:


x = y (mod p)

x = y + kp
x - y = kp

p divides (x - y)

Similarly,

x = y (mod q)
x = y + kq
x - y = kq

q divides (x - y)

=> kp = kq = x - y

kq = x - y

Muliply with p on both sides,

kpq = (x - y)p

Take mod pq,

0 = (x - y)p mod pq

=> 0 = (x - y) mod pq

=> x = y mod pq

The same can be arrived from kp = x - y .

RSA Proof

We need to prove that,

rsa --------------- (1)

where m can be any integer, p and q are distinct prime numbers and e and d are positive integers satisfying,

rsa --------------- (2).

According to the Chinese remainder theorem (CRT) equation (1) is valid if,

rsa --------------- (3) and

rsa --------------- (4) are valid.

From equation (2)

rsa --------------- (5)

where u and v are some integers, because ed - 1 is a multiple of the lcm of (p-1, q-1), and lcm of (p-1, q-1) will be u(p - 1) = v(q - 1).

Equation (3) can be written as,

rsa --------------- (6),

which in turn can be written as

rsa --------------- (7),

which can be further reduced using the Fermats Little theorem to,

rsa --------------- (8),

which is valid.

Similarly equation (4) can be written as,

rsa --------------- (9),

which in turn can be written as

rsa --------------- (10),

which can be further reduced using the Fermats Little theorem to,

rsa --------------- (11),

which is also valid.

Hence as both equation (3) and (4) are valid, according to CRT equation 1 is valid. Hence correctness of RSA is proved.

RSA optimizing the decryption algorithm

The textbook RSA decryption algorithm is as follows:

rsa --------------- (12),

where c is the cipher text, d is the private/decryption key, m is the original message. But as c, d, and pq will be very large the decryption process will take long time to execute.

To optimize the calculation of equation 12, by using the CRT we can reduce it to,

rsa --------------- (13)

which can be further reduced to

rsa --------------- (14)

by using the Fermats Little theorem.

About the project

The project make use of the big-int repository for the mathematical calculation involving big numbers used in the RSA algorithm. For the decryption stage both the textbook algorithm and the optimized algorithm are implemented.

Building the project

mkdir build && cd build
cmake ..
make