Вы находитесь на странице: 1из 9

IMPLEMENTATION OF ELLIPTIC CURVE CRYPTOGRAPHY

LAB PROJECT CS704


Gopal Benakanawari 10IS12F Under Instruction of Mr. K.C.Shet

Department of Computer Science National Institute of Technology Karnataka, Surathkal

IMPLEMENTATION OF ELLIPTIC CURVE CRYPTOGRAPHY

ABATRACT:
This project aims at how elliptic curves are used in cryptography, Implementation of elliptic curve cryptography over finite field, Encryption and decryption process in elliptic curve cryptography. Elliptic curve cryptography uses discrete logarithm problem which is very difficult to solve in a short time. The security of elliptic curve cryptography depends on difficult of discrete logarithm problem.

INTRODUCTION: Elliptic Curve Cryptography (ECC) is a public key cryptography. In public key cryptography each user or the device taking part in the communication generally have a pair of keys, a public key and a private key, and a set of operations associated with the keys to do the cryptographic operations. Only the particular user knows the private key whereas the public key is distributed to all users taking part in the communication. Some public key algorithm may require a set of predefined constants to be known by all the devices taking part in the communication. Domain parameters in ECC is an example of such constants. Public key cryptography, unlike private key cryptography, does not require any shared secret between the communicating parties but it is much slower than the private key cryptography. The mathematical operations of ECC is defined over the elliptic curve y2 = x3 + ax + b, where 4a3 + 27b2 0. Each value of the a and b gives a different elliptic curve. All points (x, y) which satisfies the above equation plus a point at infinity lies on the elliptic curve. The public key is a point in the curve and the private key is a random number. The public key is obtained by multiplying the private key with the generator point G in the curve. The generator point G, the curve parameters a and b, together with few more constants constitutes the domain parameter of ECC. One main advantage of ECC is its small key size. A 160-bit key in ECC is considered to be as secured as 1024-bit key in RSA.

IMPLEMENTATION: 1. Discrete logarithm problem: The security of ECC depends on the difficulty of Elliptic Curve Discrete Logarithm Problem. Let P and Q be two points on an elliptic curve such that kP = Q, where k is a scalar. Given P and Q, it is computationally infeasible to obtain k, if k is sufficiently large. K is the discrete logarithm of Q to the base P. Hence the main operation involved in ECC is point multiplication. i.e. multiplication of a scalar k with any point P on the curve to obtain another point Q on the curve.
2. Point multiplication:

In point multiplication a point P on the elliptic curve is multiplied with a scalar k using elliptic curve equation to obtain another point Q on the same elliptic curve. i.e. kP =Q Point multiplication is achieved by two basic elliptic curve operations Point addition, adding two points J and K to obtain another point L i.e., L = J + K. Point doubling, adding a point J to itself to obtain another point L i.e. L = 2J. Let P be a point on an elliptic curve. Let k be a scalar that is multiplied with the point P to obtain another point Q on the curve. i.e. to find Q = kP. If k = 23 then kP = 23.P = 2(2(2(2P) + P) + P) + P. 3. Point addition: Consider two distinct points J and K such that J = (xJ, yJ) and K = (xK, yK) Let L = J + K where L = (xL, yL), then xL = s2 - xJ xK yL = -yJ + s (xJ xL) s = (yJ yK)/(xJ xK), s is the slope of the line through J and K.
4. Point doubling:

Point doubling is the addition of a point J on the elliptic curve to itself to obtain another point L on the same elliptic curve. Consider a point J such that J = (xJ, yJ), where yJ 0 Let L = 2J where L = (xL, yL), Then xL = s2 2xJ yL = -yJ + s(xJ - xL)

5. Elliptic Curve Domain parameters Apart from the curve parameters a and b, there are other parameters that must be agreed by both parties involved in secured and trusted communication using ECC. These are domain parameters. The domain parameters for Elliptic curve over Fp are p, a, b, G, n and h. p is the prime number defined for finite field Fp . a and b are the parameters defining the curve y2 mod p= x3 + ax + b mod p. G is the generator point (xG, yG), a point on the elliptic curve chosen for cryptographic operations. n is the order of the elliptic curve. The scalar for point multiplication is chosen as a number between 0 and n 1.

6. Elliptic curve key pair generation

INPUT: Elliptic curve domain parameters (p, E, P, n). OUTPUT: Public key Q and private key d. 1. Select d R [1, n1]. 2. Compute Q = dP. 3. Return (Q, d).

7. Elliptic curve encryption:

INPUT: Elliptic curve domain parameters (p, E, P,n), public key Q, plaintext m. OUTPUT: Ciphertext (C1, C2). 1. Represent the message m as a point M in E (Fp). 2. Select k R [1,n1]. 3. Compute C1 = kP. 4. Compute C2 = M +kQ. 5. Return (C1, C2).

8. Elliptic curve decryption: INPUT: Domain parameters (p, E, P, n), private key d, ciphertext (C1, C2). OUTPUT: Plaintext m. 1. Compute M = C2dC1, and extract m from M. 2. Return (m).

Conclusion:

Вам также может понравиться