ECC Writeup
ECC Writeup
ECC Writeup
OBJECTIVE : To understand the ECC encryption and decryption algorithm and implement
it in python.
OUTCOMES: Students will be able to encrypt and decrypt messages using ECC algorithm.
THEORY :
INTRODUCTION:
Elliptic-curve cryptography (ECC) is an approach to public-key cryptography based on the
algebraic structure of elliptic curves over finite fields. ECC requires smaller keys compared to
non-EC cryptography (based on plain Galois fields) to provide equivalent security.[1]
Elliptic curves are applicable for key agreement, digital signatures, pseudo-random generators
and other tasks. Indirectly, they can be used for encryption by combining the key agreement
with a symmetric encryption scheme.
ALGORITHM :
The equation of an elliptic curve is given as,
Key Generation
Key generation is an important part where we have to generate both public key and private key.
The sender will be encrypting the message with receiver’s public key and the receiver will
decrypt its private key.
Now, we have to select a number ‘d’ within the range of ‘n’.
Using the following equation we can generate the public key
Q=d*P
d = The random number that we have selected within the range of ( 1 to n-1 ). P is the point on
the curve.
‘Q’ is the public key and ‘d’ is the private key.
Encryption
Let ‘m’ be the message that we are sending. We have to represent this message on the curve.
This have in-depth implementation details. All the advance research on ECC is done by a
company called certicom.
Conside ‘m’ has the point ‘M’ on the curve ‘E’. Randomly select ‘k’ from [1 – (n-1)].
Two cipher texts will be generated let it be C1 and C2.
C1 = k*P
C2 = M + k*Q
C1 and C2 will be sent.
Decryption
We have to get back the message ‘m’ that was send to us,
M = C2 – d * C1
M is the original message that we have send.
Proof
How do we get back the message,
M = C2 – d * C1
‘M’ can be represented as ‘C2 – d * C1’
C2 – d * C1 = (M + k * Q) – d * ( k * P ) ( C2 = M + k * Q and C1 = k * P )
= M + k * d * P – d * k *P ( canceling out k * d * P )
= M ( Original Message )
ADVANTAGES :
ECC employs a relatively short encryption key -- a value that must be fed into the encryption
algorithm to decode an encrypted message. This short key is faster and requires less computing
power than other first-generation encryption public key algorithms. For example, a 160-bit ECC
encryption key provides the same security as a 1024-bit RSA encryption key and can be up to
15 times faster, depending on the platform on which it is implemented.Both RSA and ECC are in
widespread use. The advantages of ECC over RSA are particularly important in wireless
devices, where computing power, memory and battery life are limited.
DISADVANTAGES:
One of the main disadvantages of ECC is that it increases the size of the encrypted message
significantly more than RSA encryption. Furthermore, the ECC algorithm is more complex and
more difficult to implement than RSA, which increases the likelihood of implementation errors,
thereby reducing the security of the algorithm.
APPLICATIONS :
CONCLUSION: Elliptic Curve Cryptography provides greater security and more efficient
performance than the first generation public key techniques like RSA now in use. As vendors
look to upgrade their systems they should seriously consider the elliptic curve alternative for the
computational and bandwidth advantages they offer at comparable security. Hence we have
successfully implemented ECC algorithm.