This application claims the benefit under 35 U.S.C. §119(a) of a Korean Patent Application No. 10-2006-0128663, filed on Dec. 15, 2006, in the Korean Intellectual Property Office, the entire disclosure of which is hereby incorporated by reference.
1. Field of the Invention
The present invention relates to a public key generation method in Elliptic Curve Cryptography (ECC), and a public key generation system performing the method. More particularly, the present invention relates to a public key generation method which can quickly compute a public key using an elliptic curve over finite fields of characteristic three.
2. Description of Related Art
Public key cryptography, introduced by W. Diffei and M. Hellman in 1976, is an asymmetrical method using different keys during encryption and decryption. The public key encryption uses two keys, a public key and a private key. The public key is used for encrypting a message, and the private key being used for decrypting a ciphertext into the original message.
The RSA algorithm and the Merkle-Hellman algorithm, are presently endorsed in terms of security as the public key encryption method.
Elliptic curve cryptography is an approach to public key cryptography based on the algebraic structure of elliptic curves over finite fields. The use of elliptic curves cryptography was proposed by Neal Koblitz and Victor Miller in 1985. The discrete logarithm problem on the elliptic curve is believed to be more difficult than the corresponding problem in the multiplicative group of nonzero elements of the underlying finite field. Thus, the keys chosen in elliptic curve cryptography can be much shorter for a comparable level of security.
For example, the RSA algorithm requires a 1024 bit key and an ECC algorithm requires a 160 bit key for a comparable level of security. Accordingly, the usage of elliptic curve cryptography can improve the performance of the existing solutions for the wireless Internet and IC cards.
Two user terminals 101 and 102 respectively include private keys 103 and 104, and include a common generator P (not illustrated). In this case, the first user terminal 101 may generate a public key aP 105 using the common generator P and the first user terminal's 101 own private key 103, and the second user terminal 102 may generate a public key bP 106 using the common generator P and the second user terminal's 102 own private key 104.
The user terminals 101 and 102 exchange the generated public keys aP 105 and bP 106 with each other to generate common encryption keys a(bP) 107 and b(aP) 108. In other words, the user terminals 101 and 102 have a common key abP to share.
However, the conventional art fails to take full advantage of the improved performance capabilities of keys in elliptic curve cryptography while maintaining a comparable level of security.
Accordingly, there is a need for an improved public key generation method wherein a public key may be quickly computed by reducing a sequence length of a private key represented in signed ternary τ-adic expansion and optimizing the public key by applying a splitting algorithm to a public key whose sequence is reduced.
Exemplary embodiments of the present invention address at least the above problems and/or disadvantages to provide at least the advantages described below. Accordingly, an aspect of exemplary embodiments of the present invention is to provide a public key generation method and a system for executing the method which can quickly compute a public key by a private key which is represented in the τ-adic expansion using an elliptic curve over fields of characteristic three.
An aspect of exemplary embodiments of the present invention is the signed ternary representation of the scalar ‘k’ in the fields of characteristic three.
An aspect of exemplary embodiments of the present invention also provides a public key generation method and a system for executing the method which can generate a public key by applying the splitting algorithm to a private key which is represented in the τ-adic expansion.
According to an aspect of exemplary embodiments of the present invention, there is provided a public key generation method in Elliptic Curve Cryptography (ECC) including representing a secret key ‘k’ in a signed ternary τ-adic representation; reducing a sequence length of the signed ternary τ-adic representation of the private key ‘k’ using the properties of the elliptic curve including Frobenius mapping and characteristic equation; and computing a public key kP by multiplying the τ-adic representation of the private key ‘k’ whose sequence length is reduced on a point P.
According to an aspect of exemplary embodiments of the present invention, the private key ‘k’, having been represented by the τ-adic representation,
k=k
0
+k
1
τ+. . . +k
l-1τl−1, [Equation 1]
where l indicates the sequence length, and ki(0≦i≦l−1) indicates an element of a set including 0, 1, and −1, and τ is a complex number solution of the characteristic equation [Equation 5].
According to another aspect of exemplary embodiments of the present invention, the reducing of the sequence length of the τ-adic representation of the private key ‘k’ performed by finding α which satisfies the Equation 2.
α=kmodτn−1 kP=α[τ]P. [Equation 2]
The private key ‘k’ is chosen around 3n, α8 τ] denotes α in the signed ternary τ-adic representation.
According to still another aspect of exemplary embodiments of the present invention, the elliptic curve is represented as,
y
2
=x
3+2x2+2, [Equation 3]
the Frobenius mapping is represented as,
τ(x,y)=(x3,y3) [Equation 4]
where the (x, y) indicates the point P on the elliptic curve, and
the characteristic equation is represented as,
τ2=2τ−3. [Equation 5]
According to another aspect of exemplary embodiments of the present invention, there is provided a public key generation system in Elliptic Curve Cryptography (ECC) including a private key representation module representing a private key ‘k’ in a signed ternary τ-adic representation; a sequence length reducing module reducing a sequence length of the signed ternary τ-adic representation of the private key ‘k’; and a public key computation module computing a public key kP by multiplying a point P on the elliptic curve by the signed ternary τ-adic representation of the private key ‘k’ whose sequence length is decreased.
Other objects, advantages, and salient features of the invention will become apparent to those skilled in the art from the following detailed description, which, taken in conjunction with the annexed drawings, discloses exemplary embodiments of the invention.
The above and other objects, features, and advantages of certain exemplary embodiments of the present invention will be more apparent from the following detailed description, taken in conjunction with the accompanying drawings in which:
Throughout the drawings, the same drawing reference numerals will be understood to refer to the same elements, features, and structures.
The matters defined in the description such as a detailed construction and elements are provided to assist in a comprehensive understanding of the embodiments of the invention. Accordingly, those of ordinary skill in the art will recognize that various changes and modifications of the embodiments described herein can be made without departing from the scope and spirit of the invention. Also, descriptions of well-known functions and constructions are omitted for clarity and conciseness.
In the fields of characteristic three, a cubing operation is much quicker than multiplication or exponentiation. An ordinary elliptic curve on F3 may be generated in accordance with the following Equation 6:
y
2
=x
3
+ax
2
+bx+c, [Equation 6]
where ‘a’ and ‘c’ are not ‘0’, affine addition, affine doubling, and affine tripling may be generated in accordance with the following Equations 7 through 9:
affine tripling: 3(x1,y1)=2(x1,y1)+(x1,x), [Equation 9]
where Table 1 denotes the cost of multiplication with respect to each of the affine addition, affine doubling, and affine tripling.
In Table 1, M denotes complexity for multiplication, and I denotes inversion complexity.
An elliptic curve E, generated as in Equation 6, is defined on F3
(x9, y9)−t(x3,y3)+3(x,y)=O. [Equation 10]
When a Frobenius mapping is defined as Equation 11, Equation 10 may be represented as,
τ(x,y)=(x2,y3), and [Equation 11]
τ(τ(P))−tτ(P)+3P=O, [Equation 12]
where all of the points are elements of E.
Equation 12 denotes that a solution of Equation 12 may be acquired by a solution of Equation 13.
τ2−tτ+3=O. [Equation 13]
A solution of Equation 13 is a complex number as in Equation 14,
accordingly a solution of Equation 12 is represented as in Equation 15,
By combining the Frobenius mapping with complex multiplication, multiplication for the points on the elliptic curve by any element of a ring Z[τ] may be performed. Accordingly the scalar ‘k’ can be represented as,
k=k
0
+k
1
τ+. . . +k
l-1τl−1, [Equation 16]
where ki(0≦i≦l−1) denotes an element of a set including 0, 1, and 2.
Namely, Equation 17 can be verified through Equation 16, and Equation 17 can be represented as,
In Equation 18, since multiplication by τ is implemented by cubing, it is essentially free when F3
The representation of the k base τ as in Equation 16 is called τ-adic representation. This representation could be found by using the following observation:
a+bτ is divided by τ if and only if a=0 and mod 3. Equations 19 and 20 show this.
This observation leads to algorithm 1 (200) of
If ‘k’ is chosen around 3n, the length of the τ-adic representation obtains 2n, and density of the non-zero positions obtains ⅔. Algorithm 1 (200) of
The algorithm 1 (200) of
where ‘A’ denotes a complexity of adding, and the τM denotes a complexity of τ-mapping.
In operation S401, the public key generation system reduces a sequence length of the signed ternary τ-adic representation of the private key ‘k’ using properties of the elliptic curve.
In this instance, properties of the Frobenius mapping may be represented as,
τn(x,y)=(x3
τnP=P, [Equation 24]
τn=1. [Equation 24]
After being based on the Frobenius mapping and Equation 26, when α[τ] denotes α in the τ-adic representation from Equation 27, the length of the signed ternary τ-adic representation of‘k’ may be reduced using Equation 27.
α=kmodτn−1, and [Equation 26]
kP=α[τ]P. [Equation 27]
Where the private key ‘k’ is chosen around 3n, the sequence length of the signed τ-adic representation may be reduced by half. To find α, when the representation of τn−1 in the form α+bτ is computed, an algorithm that will output α mod β over complex numbers is required.
In algorithm 4 (600) of
T
k
=tT
k-1−3Tk-2, [Equation 28]
where T0=0, T1=1, k≦2,
and the final result obtained from Equation 29,
τn=Tnτ−3Tn-1. [Equation 29]
To illustrate algorithm 4 (600) of
y
2
x
3+2x2+2. [Equation 30]
The characteristic equation is represented as Equation 31,
τ2=2τ−3. [Equation 31]
A solution of Equation 31 is represented as Equation 32, wherein
τ=1+√{square root over (2)}i. [Equation 32]
To find α mod β the conjugate to complex β=c+d τ should be found. The conjugate is C+2d−dτ. Namely, Equation 34 is represented as follows by multiplying a nominator by denominator of Equation 33,
In this instance, a residue with respect to a complex number can be obtained by the following algorithm 4 (600) of
In operation S402, the public key generation system, generating a public key, represents the reduced private key ‘k’ in a signed ternary τ-adic representation.
In this case, algorithm 2 of
k=k
0
+k
1
τ+. . . +k
l-1τl−1, [Equation 35]
where ki(0≦i≦l−1) is an element of a set including 0, 1, and −1.
This sequence can be obtained by an example of an algorithm which is illustrated on
In operation S403, the public key generation system computes a public key kP by multiplying a point P on the elliptic curve by the τ-adic representation of the reduced private key ‘k’ whose sequence length is reduced. The public key kP is represented as,
kP=k
l-1τl−1(P)+kl-2τl−2(P)+. . . k1τ1(P)+k0τ0(P). [Equation 36]
In operation S403, the public key generation system optimizes the public key kP using a splitting algorithm. Specifically, the public key generation system separates the computed public key kP into two parts, and generates an optimized public key using the splitting algorithm.
Algorithm 5 (700) of
In this instance, the public key kP, by using Q which is represented as Equation 38, may represent the public key kP as Equation 39, and an upper sequence and a lower sequence in Equation 39 may be combined with each other as in Equation 40:
A main property of an obtained sequence in Equation 40 is that a sequence length of the obtained sequence may be reduced by half. This is possible by formulating algorithm 5 (700) of
In this instance, an average complexity with respect to the algorithm 3 (400) of
Through complexity of Equation 41 and Equation 21, it is seen that the signed ternary τ-adic algorithm may compute the public key kP faster than a basic τ-adic algorithm. Namely, the private key is represented in the signed ternary τ-adic representation, the splitting method is applied, and consequently the public key kP can be quickly computed.
Also, in operation S401, the average complexity according to an embodiment of the present invention is represented as in Equation 42, an embodiment of the present invention including operation of the reducing of the sequence length of the signed ternary τ-adic representation of the private key ‘k’, using the elliptic curve, the Frobenius mapping, and the characteristic equation.
It is seen that the average complexity is reduced since a sequence length is reduced by half in comparison to Equation 41. Cost of multiplication in field operation, where M is the multiplication complexity and τM is the complexity of the τ-mapping, which is the sequence length, determines speed in generating the public key kP.
As described above, according to the public key generation method of an exemplary embodiment of the present invention, a public key may be quickly computed by reducing a sequence length of the signed ternary τ-adic representation of the private key ‘k’ using an elliptic curve, a Frobenius mapping which is represented as a ternary number, and a characteristic equation in ECC based on a signed ternary, and an optimized public key may be generated by applying a splitting algorithm to the computed public key using a private key whose sequence length is reduced.
The sequence length reducing module 801 reduces a sequence length of the signed ternary τ-adic representation of the private key ‘k’, using an elliptic curve, a Frobenius mapping, and a characteristic equation.
In this instance, the Frobenius mapping may be represented as,
τn(x,y)=(x3
τnP=P, [Equation 44]
τn=1, [Equation 45]
α=kmodτn−1, and [Equation 46]
kP=α[τ]P. [Equation 47]
When the private key ‘k’ is chosen around 3n, the sequence length of the signed τadic representation may be reduced in half. To find α, when the representation of τn−1 in the form of α+bτ is computed, an algorithm will output α mod β. The algorithm 4 (600) of
The private key representation module 802 represents a reduced secret key ‘k’ in a signed ternary τ-adic representation. In this instance, algorithm 2 (300) of FIG, 3 may be improved by eliminating the operation of precomputation 2P in algorithm (300) of
k=k
0
+k
1
τ+. . . +k
l-1τl−1, [Equation 43]
where ki(0≦i≦l−1) is an element of a set including 0, 1, and −1.
The reduced private key ‘k’ typed in Equation 43 may be obtained using algorithm 3 (400) of
The public key computation module 803 computes the public key kP by multiplying a point P on the elliptic curve by the τ-adic representation of the private key ‘k’ whose sequence length is reduced. The public key kP is represented as,
kP=k
l-1τl−1(P)+kl-2τl−2(P)+. . . k1τ1(P)+k0τ0(P). [Equation 49]
The public key separation module 804 separates the computed public key kP into two parts. Namely, the public key separation module 804 may separate the computed public key kP into two parts, that is, a sequence of the τ-adic representation as Equation 49, may be separated into two parts by Equation 50.
The public key optimizing module 805 generates an optimized public key using a splitting algorithm. In this instance, the public key optimizing module 805, by using Q which is represented as Equation 51, may represent the public key kP as Equation 52, and an upper sequence and a lower sequence in Equation 52 may be combined with each other as Equation 53.
A main property of an obtained sequence in Equation 53 is that a sequence length of the obtained sequence may be reduced by half. This is possible to formulate with algorithm 5 (700) of
As described above, according to the public key generation method of an exemplary embodiment of the present invention, a public key may be quickly computed by reducing a sequence length of the signed ternary τ-adic representation of the private key ‘k’ using an elliptic curve, a Frobenius mapping which is represented as a ternary number, and a characteristic equation in ECC based on a signed ternary, and an optimized public key may be generated by applying a splitting algorithm to the computed public key using a private key whose sequence length is reduced.
The public key generation method according to the above-described embodiment of the present invention may be recorded in computer-readable media including program instructions to implement various operations embodied by a computer. The media may also include, alone or in combination with the program instructions, data files, data structures, and the like. Examples of computer-readable media include magnetic media such as hard disks, floppy disks, and magnetic tape; optical media such as CD ROM disks and DVD; magneto-optical media such as optical disks; and hardware devices that are specially configured to store and perform program instructions, such as read-only memory (ROM), random access memory (RAM), flash memory, and the like. The media may also be a transmission medium such as optical or metallic lines, wave guides, and the like, including a carrier wave transmitting signals specifying the program instructions, data structures, and the like. Examples of program instructions include both machine code, such as produced by a compiler, and files containing higher level code that may be executed by the computer using an interpreter. The described hardware devices may be configured to act as one or more software modules in order to perform the operations of the above-described embodiments of the present invention.
According to an exemplary embodiment of the present invention, a public key may be quickly computed by reducing a sequence length of a private key represented in signed ternary a τ-adic expansion.
Also, according to an exemplary embodiment of the present invention, an optimized public key may be generated by applying a splitting algorithm to a public key whose sequence length is reduced.
While certain exemplary embodiments of the invention have been shown and described with reference to certain preferred embodiments thereof, it will be understood by those skilled in the art that various changes in form and details may be made therein without departing from the spirit and scope of the invention as defined by the appended claims and their equivalents.
Number | Date | Country | Kind |
---|---|---|---|
10-2006-0128663 | Dec 2006 | KR | national |