This application claims the benefit, under 35 U.S.C. §119 of European Patent Application No. 14305303.1, filed Mar. 3, 2014.
The invention relates to cryptography, and more precisely to elliptic curve cryptography. The disclosure has numerous applications, and is suitable to be used in embedded devices. More generally, it can be applied to all cryptographic protocols and algorithms based on the use of elliptic curves.
This section is intended to introduce the reader to various aspects of art, which may be related to various aspects of the present invention that are described and/or claimed below. This discussion is believed to be helpful in providing the reader with background information to facilitate a better understanding of the various aspects of the present invention. Accordingly, it should be understood that these statements are to be read in this light, and not as admissions of prior art.
Elliptic curve cryptography provides high level of security (exponential security) with smaller key size in comparison to the conventional RSA cryptosystem (subexponential security). The applications of ECC are increasing in our everyday lives as more and more people are relying on small electronic devices. The smaller key size makes ECC attractive for constrained devices such as PDAs or smart cards. The efficiency of ECC is dominated by an operation called scalar multiplication (or point multiplication). The problem is, given a point P on an elliptic curve (defined over a finite field or a finite ring) and a scalar k, to generate the point kP, that is, P+ . . . +P(k−1 times) as cost efficiently as possible. This problem is an obvious analogue of the evaluation of powers. Hence, methods of fast evaluation of powers can be used here to get efficient implementations.
The elliptic curve group operations can be expressed in terms of a number of operations in the definition ring. The crucial problem becomes to find the right model to represent an elliptic curve in a way to minimize the number of ring operations. Indeed, as an elliptic curve is defined up to birational transformations, there are plenty of possible choices for its representation. However, in order not to explode the number of coordinates and operations, only models of elliptic curves lying in low-dimensional spaces are considered in practice.
Furthermore, the basic operations involved in point addition formulæ (namely, ring addition/subtraction, ring multiplication, and ring inversion) are not equivalent with each other. In particular, ring inversion requires a special attention as it may significantly impact the overall performance. For cryptographic applications using elliptic curves, typical ratios for inversion over multiplication in the underlying finite ring range from 3 to 30. For that reason, inversion-free point addition formulæ are of particular interest. This is classically achieved by resorting on projective representations (including the widely-used homogeneous and Jacobian coordinates).
Numerous useful forms of elliptic curves using various coordinate systems and their respective costs are compiled in the Explicit-Formulas Database provided by D. Bernstein et al., on the website http://www.hyperelliptic.org/EFD.
When affine coordinates system is used to represent the points of an elliptic curve, there is currently no technique that prevents to use an inversion operation in a finite ring. It is an aim of the present technique to get rid of the ring inversion operation in the evaluation of a scalar multiplication. The proposed technique can of course be applied to another context where only basic operations (addition) are performed between points (as in the verification of the ECDSA algorithm).
References in the specification to “one embodiment”, “an embodiment”, “an example embodiment”, indicate that the embodiment described may include a particular feature, structure, or characteristic, but every embodiment may not necessarily include the particular feature, structure, or characteristic. Moreover, such phrases are not necessarily referring to the same embodiment. Further, when a particular feature, structure, or characteristic is described in connection with an embodiment, it is submitted that it is within the knowledge of one skilled in the art to affect such feature, structure, or characteristic in connection with other embodiments whether or not explicitly described.
The present invention is directed to a method of cryptographic processing of data, the method being executed by an electronic device, and comprising obtaining at least two points belonging to a same elliptic curve defined on an algebraic structure being a finite ring, each point being represented by at least two coordinates. The method is remarkable in that it comprises:
Hence, in function of the choice of the configuration parameters of a parameterization of an isomorphism, it is possible to avoid the execution of an inversion operation in an addition of points, the choice being performed in function of the values of the coordinates of the points. It should be noted that selection of configuration parameters was not obvious due to the fact that one skilled in the art would have used random values for the configuration parameters.
In a preferred embodiment, the method is remarkable in that when said at least two points are identical, said addition is a doubling operation.
In a preferred embodiment, the method is remarkable in that each point is represented in an affine coordinate system.
In a preferred embodiment, the method is remarkable in that it is used in a scalar multiplication operation with a first point belonging to a first elliptic curve.
In a preferred embodiment, the method is remarkable in that it comprises converting an output point of said scalar multiplication operation, said output point belonging to a last elliptic curve, to a converted output point belonging to said first elliptic curve.
Hence, the proposed technique does not use inversion operation as in the state of the art. It enables efficient implementation of a scalar multiplication over elliptic curves. The proposed technique relies on the use of curve isomorphisms as a way to avoid the computation of inverses in point addition formulæ. Interestingly, the proposed technique applies whatever the model used to represent an elliptic curve and whatever the coordinate system used to represent the points. Hence the proposed technique can be applied to affine representation, Jacobian representation, etc.
In a preferred embodiment, the method is remarkable in that said algebraic structure is a finite field having a characteristic equal to 2.
In a preferred embodiment, the method is remarkable in that said algebraic structure is a finite field having a characteristic equal to 3.
In a preferred embodiment, the method is remarkable in that said algebraic structure is a finite field having a characteristic equal to a prime number p>3.
According to an exemplary implementation, the different steps of the method are implemented by a computer software program or programs, this software program comprising software instructions designed to be executed by a data processor of a relay module according to the disclosure and being designed to control the execution of the different steps of this method.
Consequently, an aspect of the disclosure also concerns a program liable to be executed by a computer or by a data processor, this program comprising instructions to command the execution of the steps of a method as mentioned here above.
This program can use any programming language whatsoever and be in the form of a source code, object code or code that is intermediate between source code and object code, such as in a partially compiled form or in any other desirable form.
The disclosure also concerns an information medium readable by a data processor and comprising instructions of a program as mentioned here above.
The information medium can be any entity or device capable of storing the program. For example, the medium can comprise a storage means such as a ROM (which stands for “Read Only Memory”), for example a CD-ROM (which stands for “Compact Disc-Read Only Memory”), or a microelectronic circuit ROM or again a magnetic recording means, for example a floppy disk or a hard disk drive.
Furthermore, the information medium may be a transmissible carrier such as an electrical or optical signal that can be conveyed through an electrical or optical cable, by radio or by other means. The program can be especially downloaded into an Internet-type network.
Alternatively, the information medium can be an integrated circuit into which the program is incorporated, the circuit being adapted to executing or being used in the execution of the method in question.
According to one embodiment, an embodiment of the disclosure is implemented by means of software and/or hardware components. From this viewpoint, the term “module” can correspond in this document both to a software component and to a hardware component or to a set of hardware and software components.
A software component corresponds to one or more computer programs, one or more sub-programs of a program, or more generally to any element of a program or a software program capable of implementing a function or a set of functions according to what is described here below for the module concerned. One such software component is executed by a data processor of a physical entity (terminal, server, etc.) and is capable of accessing the hardware resources of this physical entity (memories, recording media, communications buses, input/output electronic boards, user interfaces, etc.).
Similarly, a hardware component corresponds to any element of a hardware unit capable of implementing a function or a set of functions according to what is described here below for the module concerned. It may be a programmable hardware component or a component with an integrated circuit for the execution of software, for example an integrated circuit, a smart card, a memory card, an electronic board for executing firmware etc. In a variant, the hardware component comprises a processor that is an integrated circuit such as a central processing unit, and/or a microprocessor, and/or an Application-specific integrated circuit (ASIC), and/or an Application-specific instruction-set processor (ASIP), and/or a graphics processing unit (GPU), and/or a physics processing unit (PPU), and/or a digital signal processor (DSP), and/or an image processor, and/or a coprocessor, and/or a floating-point unit, and/or a network processor, and/or an audio processor, and/or a multi-core processor. Moreover, the hardware component can also comprise a baseband processor (comprising for example memory units, and a firmware) and/or radio electronic circuits (that can comprise antennas) which receive or transmit radio signals. In one embodiment, the hardware component is compliant one or more standards such as ISO/IEC 18092/ECMA-340, ISO/IEC 21481/ECMA-352, GSMA, StoLPaN, ETSI/SCP (Smart Card Platform), GlobalPlatform (i.e. a secure element). In a variant, the hardware component is a Radio-frequency identification (RFID) tag. In one embodiment, a hardware component comprises circuits that enable Bluetooth communications, and/or Wi-fi communications, and/or Zigbee communications, and/or USB communications and/or Firewire communications.
It should also be noted that a step of obtaining an element/value in the present document can be viewed either as a step of reading such element/value in a memory unit of an electronic device or a step of receiving such element/value from another electronic device via communication means.
In another embodiment, it is proposed an electronic device configured to perform a cryptographic processing of data, said electronic device comprising means for obtaining at least two points belonging to a same elliptic curve defined on an algebraic structure being a finite ring, each point being represented by at least two coordinates. The electronic device is remarkable in that it comprises:
In a variant, the electronic device is remarkable in that when said at least two points are identical, said addition is a doubling operation.
In a variant, the electronic device is remarkable in that each point is represented in an affine-coordinate system.
In a variant, the electronic device is remarkable in that said means are used to perform a scalar multiplication operation with a first point belonging to a first elliptic curve.
In a variant, the electronic device is remarkable in that it comprises means for converting an output point of said scalar multiplication operation, said output point belonging to a last elliptic curve, to a converted output point belonging to said first elliptic curve.
In another embodiment, the electronic device is remarkable in that said algebraic structure is a finite field having a characteristic equal to a prime number p>3.
The above and other aspects of the invention will become more apparent by the following detailed description of exemplary embodiments thereof with reference to the attached drawings in which:
Before describing the proposed method in its full generality, we first make a couple of observations on the Weierstraβ model. To simplify the exposition, we focus on elliptic curves defined over a ring of characteristic different of 2, or 3. As is customary, we let * denote the multiplicative group of and Char() the characteristic of .
Consider the elliptic curve E1 over a ring , Char()≠2,3, given by
E1:y2=x3+a·x+b
For any uε*, elliptic curve E1 is -isomorphic to elliptic curve.
Eu:y2=x3+a·u4·x+b·u6
via the inverse mappings
Given two finite point points P1=(x1,y1) and P2=(x2,y2) on E1 such that P1≠±P2 (i.e. such that x1≠x2), provided that (x1−x2)ε*, their sum is given by P3=P1+P2=(x3,y3) where
The double of P1=(x1,y1), provided that y1ε*, is given by P4=2P1=P1+P1=(x4,y4) where
In one embodiment of the invention, the present technique uses the following property: By defining φ:=x1−x2, we get from the above addition equation formula (referenced eq. 1)
φ2x3=(y1−y2)2−φ2x1−φ2x2 and φ3y3=(φ2x1−φ2x3)(y1−y2)−φ3y1.
In other words, given points P1 and P2 on the elliptic curve E1, one can easily obtain on the isomorphic elliptic curve Eφ the point {tilde over (P)}3=ψφ(P1+P2)=(φ2x3,φ3y3). It is worth remarking that no inversion is required in the evaluation of {tilde over (P)}3. We let iADD denote the operation of getting {tilde over (P)}3εEφ.
It should be noticed that a similar treatment applies to the point doubling operation (the doubling operation can be viewed as a particular addition between two points which are identical. However, the formulæ used to perform an addition if the points are equal or not are not necessarily the same). Defining now φ:=2y1, we get from the doubling formula (referenced eq. 2)
φ2x4=(3x12+a)2−2φ2x1 and φ3y4=(φ2x1−φ2x4)(3x12+a)−φ3y1.
Namely, given point P1 on E1, one can easily obtain the point {tilde over (P)}4=ψφ(2P1)=(φ2x4,φ3y4), which belongs to the elliptic curve Eφ. As for the point addition, it is worth remarking that no inversion is required in the evaluation of {tilde over (P)}4. We let iDBL denote the operation of getting {tilde over (P)}4εEφ.
Let be an elliptic curve over a ring . Consider a family {E{right arrow over (φ)}} of isomorphic elliptic curves, indexed by some parameter {right arrow over (φ)}, under isomorphism
ψ{right arrow over (φ)}:{right arrow over (→)}E{right arrow over (φ)}
Parameter {right arrow over (φ)} is the description of the isomorphism (i.e. it is a parameterization that defines the isomorphism). We use the notation {right arrow over (φ)}=Desc(ψ{right arrow over (φ)}) (Desc being an acronyme of description). The set of all possible parameters {right arrow over (φ)} is noted .
The following three addition operations, noted iADD, iADDU and iADDC, are defined by the following equations:
For efficiency purposes, parameter {right arrow over (φ)} is chosen so that given two different points P1 and P2 on , the output of the addition operation does not require ring inversions.
We also give two doubling operations, iDBL and iDBLU, defined by the following equations:
Likewise, the parameter {right arrow over (φ)} is chosen so that, given a point P1 belonging to , the output of the doubling operation does not require ring inversions.
More generally, given two elliptic curves E{right arrow over (φ)} and E{right arrow over (φ)}′, that are isomorphic to , if
ψ{right arrow over (φ)}:E{right arrow over (φ)}{tilde over (→)}E{right arrow over (φ′)},
denotes the isomorphism between the elliptic curves E{right arrow over (φ)} and E{right arrow over (φ′)};
we similarly define the operations
Subscript {right arrow over (φ)} in the operator definition indicates that input points belong to the elliptic curve E{right arrow over (φ)}.
The following example illustrates the principle. For a general Weierstraβ model defined over a ring (whatever is characteristic is), we have
:y2+a1xy+a3y=x3+a2x2+a4x+a6, where parameters a1, a2, a3, a4 and a6 belong to , and ψ{right arrow over (φ)}:E{right arrow over (φ)}{tilde over (→)}E{right arrow over (φ′)} with (x,y)(u2x+r,u3y+u2sx+t), where the description {right arrow over (φ)} of isomorphism is given by the four parameters u, r, s and t. Hence, {right arrow over (φ)}=(u, r, s, t) and =(1, 0, 0, 0). We also have ={(U, R, S, T)ε4|Uε*}, where is the definition ring of . Hence, the isomorphism ψ{right arrow over (φ)} enables the mapping of a point P of :y2+a1xy+a3y=x3+a2x2+a4x+a6 to a point belonging to the elliptic curve :y2+a′1xy+a′3y=x3+a′2x2+a′4x+a′6, where parameters a′1, a′2, a′3, a′4 and a′6 belong to . The corresponding curve parameters are related by the following equations:
ua1=a′1+2s
u2a2=a′2−sa′1+3r−s2
u3a3=a′3+ra′1+2t
u4a4=a′4−sa′3+2ra′2−(t+rs)a′1+3r2−2st
u6a6=a′6+ra′4+r2a′2+r3−ta′3−rta′1
When the characteristic of is not 2 or 3, one can without loss of generality select a1=a2=a3=0. Likewise, when the characteristic of is 2, provided that the elliptic curve is non-supersingular, one can select a1=1 and a3=a4=0.
In the following section, explicit computations to be performed for obtaining the output of the operators iADD, iADDU, iADDC, iDBL and iDBLU are given, with an elliptic curve defined according to the short Weierstraβ model, and over a ring with a characteristic not equal to 2 or 3.
More precisely, the evaluation of {tilde over (P)}3=(,)=ψφ(P1+P2)=(φ2x3,φ3y3) from the points P1 and P2 (which belong to an elliptic curve :y2=x3+a·x+b (according to the short Weierstraβ model) defined over a ring with a characteristic not equal to 2 or 3 can be done as follows:
As mentioned previously, the operation of getting {tilde over (P)}3 together with {tilde over (P)}1 is noted iADDU.
The evaluation of =(,)=ψφ(P1−P2)=(φ2x3,φ3y3) from the points P1 and P2 (which belong to an elliptic curve :y2=x3+a·x+b defined over a finite ring with a characteristic not equal to 2 or 3) can be done as follows:
Then 3=(y1+y2)2−W1−W2 in and =(W1−3)(y1+y2)−A1 in .
Indeed, since −P2=(x2,−y2), it follows that P1−P2=(x′3,y′3) satisfies φ2x′3=(y1+y2)2−φ2x1−φ2x2 and φ3y′3=(φ2x1−φ2x′3)(y1+y2)−φ3y1. Hence, the operation of obtaining ψφ(P1−P2), noted iADDC, only needs 5M+3S.
The evaluation of {tilde over (P)}4=(,)=ψφ(2P1) from the points P1 (which belongs to an elliptic curve :y2=x3+a·x+b defined over a finite ring with a characteristic not equal to 2 or 3) can be done as follows:
The evaluation of {tilde over (P)}4=(,) is noted iDBL, and such operation needs only 1M+5S. Moreover, the obtaining of {tilde over (P)}1=(,)=ψφ(P1) come for free during the evaluation of {tilde over (P)}4. Indeed, we have S, and =8L. The operation consisting of obtaining {tilde over (P)}4 as well as {tilde over (P)}1 is noted, as previously mentioned, iDBLU.
One of the most used operation in cryptographic scheme using elliptic curves is the scalar multiplication.
More precisely, the scalar multiplication comprises the use of the doubling and adding operations via the use of a chain or series of isomorphisms that are determined during the scalar multiplication process.
Let E(0)= denote the original elliptic curve, and E(i)=E{right arrow over (φ)}
The isomorphism between the current curve at Step i and the original curve is given by ψ{right arrow over (φ)}
The following example illustrates such principle. For a general Weierstraβ model, we have
ψ{right arrow over (φ)}
and
ψ{right arrow over (φ)}
where {right arrow over (φ)}i-1=(Ui-1, Ri-1, Si-1, Ti-1), {right arrow over (φ)}i=(ui, ri, si, ti), and =(1, 0, 0, 0). Hence, the equation {right arrow over (φ)}i={right arrow over (φ)}i◯{right arrow over (φ)}i-1 translates into (Ui, Ri, Si, Ti)=(ui, ri, si, ti)◯(Ui-1, Ri-1, Si-1, Ti-1) with
for i≧1, and (U0, R0, S0, T0)=(1, 0, 0, 0).
A classical method for evaluating Q=kP (i.e. the scalar multiplication on elliptic curves) considers the binary representation of scalar k, k=(kn-1, . . . , k0)2, with kiε{0, 1}, 0≦i≦n−1. Advantageously it requires a minimal number of registers and is hence well suited to memory-constrained devices like smart cards. The method relies on the obvious relation that kP=2(└k/2┘P), if k is even and kP=2(└k/2┘P)+P if k is odd. Iterating the process yields a left-to-right scalar multiplication algorithm, known as double-and-add method. Such method requires two (point) registers R0 and R1. Register R0 acts as an accumulator and register R1 is used to store the value of input point P.
There exists a right-to-left variant. The resulting algorithm, known as add-and-double method, is depicted in Algorithm 2 of
More precisely, the algorithms or methods presented in
Such embodiment is a variant of the left-to-right method that is more efficient than the one depicted in
These classical methods use three registers (register R0, register R1 and register T) in order to store some results of operations.
For several elliptic curve models, the point addition formulæ of two distinct points are independent of the curve parameters. In this case, it is interesting to rely on scalar multiplication algorithms that can be written as a series of iADDU and iADDC operations.
The main loop for Algorithm 6 reads as R1-b←Rb+R1-b and Rb←2 Rb (where b is equal to 0 or 1), and for Algorithm 7 as R1-b←Rb+2R1-b. Therefore, Algorithm 6 and Algorithm 7 can be easily adapted with the new operations proposed in this document. The value kn-1=1 leads to (R0, T)=(P,P), and then to R1=P+P in the first iteration of Algorithm 6. This last operation is a point doubling. In order not to have to handle potential special cases, we assume that kn-1=1 and hence start the for-loop at i=n−2, and initialize (R0, R1) with (P, 2P). For better performance, this is achieved thanks to the iDBLU operation. For the same reason, we assume that k0=1 in the right-to-left algorithm. We start the for-loop at i=2 and initialize (Rk
The original Montgomery ladder keeps invariant the difference R1−R0, which is equal to P. Equivalently, variable T (←Rb−R1-b) in Algorithm 6 is equal to (−1)1-bP. Therefore, at iteration i=0, variable Rb in our version of the Montgomery ladder (Algorithm 8) contains at Line 4 the value of ψ{right arrow over (φ)}
Such device referenced 800 comprises a computing unit (for example a CPU, for “Central Processing Unit”), referenced 801, and one or more memory units (for example a RAM (for “Random Access Memory”) block in which intermediate results can be stored temporarily during the execution of instructions a computer program, or a ROM block in which, among other things, computer programs are stored, or an EEPROM (“Electrically-Erasable Programmable Read-Only Memory”) block, or a flash block) referenced 802. Computer programs are made of instructions that can be executed by the computing unit. Such device 800 can also comprise a dedicated unit, referenced 803, constituting an input-output interface to allow the device 800 to communicate with other devices. In particular, this dedicated unit 803 can be connected with an antenna (in order to perform communication without contacts), or with serial ports (to carry communications “contact”). It should be noted that the arrows in
In an alternative embodiment, some or all of the steps of the method previously described, can be implemented in hardware in a programmable FPGA (“Field Programmable Gate Array”) component or ASIC (“Application-Specific Integrated Circuit”) component.
In an alternative embodiment, some or all of the steps of the method previously described, can be executed on an electronic device comprising memory units and processing units as the one disclosed in the
For certain models (including the popular Weierstraβ model), the neutral element (i.e., point at infinity O) needs a special treatment. This can be circumvented by adequately adapting the initialization step. For the classical left-to-right ladders, assuming that kn-1=1, we can start the for-loop at i=n−2, and set R0←P, and R1←P in Algorithms 3 and 5 at the initialization step.
Similarly, for the right-to-left ladder, assuming that k0=1, we can start the for-loop at i=1, and set R0←P, and R1←2·P in Algorithm 4. When k0=0, we do the same but substrate P at the end of the computation to get the correct result.
It should be noted that for combined operations, such as the evaluation of R=2·P+Q can be done according to the present technique. This can be done in two steps, by first determining T←P+Q, and then the determination of R←P+T. If the point R is needed together with updated point P, this can be carried out with two consecutive applications of the iADDU operation: (T,P,{right arrow over (φ)}1)←iADDU{right arrow over (φ)}(P,Q); (R,P,{right arrow over (φ)}2)←iADDU{right arrow over (φ)}
Things are slightly more complex if we want to obtain point R together with updated point Q (rather than point P) at the end of the computation. This can be carried out by an evaluation of iADDU followed by an evaluation of iADDC: (T,P,{right arrow over (φ)}1)←iADDU{right arrow over (φ)}(P,Q); (R,Q,{right arrow over (φ)}2)←iADDC{right arrow over (φ)}
At last, it should be noted that the proposed technique based on isomorphic elliptic curves is compliant with technique that prevents side channel attacks such as a curve randomization at each execution of the technique.
Number | Date | Country | Kind |
---|---|---|---|
14305303 | Mar 2014 | EP | regional |
Number | Name | Date | Kind |
---|---|---|---|
5737424 | Elteto et al. | Apr 1998 | A |
7764785 | Al-Khoraidly et al. | Jul 2010 | B2 |
20040228478 | Joye | Nov 2004 | A1 |
20130202104 | Ghouti | Aug 2013 | A1 |
20140177824 | Al-Somani | Jun 2014 | A1 |
Number | Date | Country |
---|---|---|
2001290420 | Oct 2001 | JP |
Entry |
---|
Brier et al: “Fast Point Multiplication on Elliptic Curves through Isogenies”; Applied Algebra, Algebraic Algorithms and Error-Correcting Codes. International Symposium AAECC, XX, XXvol.2643, Jan. 1, 2003; pp. 43-50. |
“Projective Coordinates”; Elliptic Curve Public Key Cryptosystems 6.3; Jan. 1993 (Jan. 1, 1993); pp. 90-91. |
Qin et al: “A Fast ECC Digital Signature Based on DSP”; 2010 International Conference on Computer Application and System Modeling; IEEE, pp. V7-83-V7-86. |
Yasuda et al: “Application of Scalar Multiplication of Edwards Curves to Pairing-Based Cryptography”; Advances in Information and Computer Security. 7th International Workshop on Security, IWSEC 2012; pp. 19-36. |
Devigne et al:“Binary Huff curves”; Topics in Cryptology—CT-RSA 2011, vol. 6558 of Lecture Notes in Computer Science, pp. 340-355. Springer, 2011. |
Goundar et al:“Co-Z addition formula andbinary ladders on elliptic curves”; Cryptographic Hardware and Embedded Systems ? CHES 2010, vol. 6225 of Lecture Notesin Computer Science, pp. 65-79. Springer, 2010. |
Goundar et al: “Scalar multiplication on Weierstrass elliptic curves from co-z arithmetic”; Journal of Cryptographic Engineering, 1(2):161-176, 2011. |
Hutter et al: “Memory constrained implementations of elliptic curve cryptography in co-Z coordinate representation”; Progress in Cryptology AFRICACRYPT 2011, vol. 6737 of Lecture Notes in Computer Science, pp. 170-187. Springer, 2011. |
Izu et al:“A fast parallel elliptic curve multiplication resistantagainst side channel attacks”; Public Key Cryptography (PKC 2002), vol. 2274 of Lecture Notes in Computer Science, pp. 280-296. Springer, 2002. |
Joye et al: “Huff's model for elliptic curves.”; Cryptographic . . . , vol. 6225 of Lecture Notes in Computer Science, pp. 1-17; Springer. |
Montgomery: “Speeding up the Pollard and elliptic curve methods of factorization”; Mathematics of Computation, vol. 48; Issue 177: pp. 243-264, 1987. |
Farashahi et al:“Efficient Arithmetic on Hessian Curves”; Cryptographic . . . , vol. 6225 of Lecture Notes in Computer Science, pp. 1-18; Springer. |
IEEE Std P1363-2000. “IEEE Standard specifications for public key cryptography”; IEEE Computer Society, Jan. 30, 2000; Microprocessor & Microcomputer Standards Committee; pp. 1-236. |
“Digital signature standard (DSS).”; Federal Information Processing Standards Publication, Jun. 2009; pp. 1-131. |
Longa et al:“Novel precomputation schemes for ellipticcurve cryptosystems”; Applied Cryptography and Network Security (ACNS 2009), vol. 5536 of Lecture Notes in Computer Science, pp. 71-88.Springer, 2009. |
Bernstein et al:“Binary Edward Curves”; Cryptographic Hardware and Embedded Systems CHES 2008, vol. 5154 of Lecture Notes in Computer Science, pp. 244-265. Springer, 2008. |
Longa et al:“New composite operations and precomputation forelliptic curve cryptosystems over prime fields.”; PKC 2008, vol. 4939 of Lecture Notes in Computer Science, pp. 229-247. Springer, 2008. |
Bernstein et al:“Faster addition and doubling on elliptic curves”; ASIACRYPT 2007, vol. 4833 of Lecture Notes in Computer Science, pp. 29-50. Springer, 2007. |
Joye: “Highly regular right-to-left algorithms for scalar multiplication”; Cryptographic Hardware and Embedded Systems CHES 2007, vol. 4727 of Lecture Notes in Computer Science, pp. 135-147.Springer, 2007. |
Meloni: “New point addition formula for ECC applications.”; Arithmetic of Finite Fields (WAIFI 2007), vol. 4547 of Lecture Notes in Computer Science, pp. 189-201. Springer, 2007. |
Blake et al: “Advances in Elliptic Curve” Cryptography, vol. 317 of London Mathematical Society Lecture Note Series. 317; 2005; pp. 1-299. |
Brier et al:“Weierstraβ elliptic curves and side-channel attacks”; Public Key Cryptography (PKC 2002), vol. 2274 of Lecture Notes in Computer Science, pp. 335-345. Springer, 2002. |
Fischer et al: “Parallel scalar multiplication on general elliptic curves over Fp hedged against nondifferential side-channel attacks”; Cryptology ePrint Archive, Report 2002/007, 2002.http://eprint.iacr.org/.; pp. 1-12. |
Okeya et al:“Elliptic curves with the Montgomer-form and their cryptography applications.”; Public Key Cryptography (PKC 2000), vol. 1751 of Lecture Notes in Computer Science, pp. 238-257. Springer, 2000. |
Lopez et al:“Fast multiplication on elliptic curves over GF(2m)without precomputation”; , Cryptographic Hardware and Embedded Systems (CHES '99), vol. 1717 of Lecture Notes in Computer Science,pp. 316-327. Springer, 1999. |
De Win et al: “On the performance of signature schemes based on elliptic curves”; Algorithmic Number Theory (ANTS-III), vol. 1423 of Lecture Notes in Computer Science, pp. 252-266.Springer, 1998. |
Koblitz: “Elliptic curve cryptosystems”; Mathematics of Computation, vol. 48 No. 177: 203-209, Jan. 1987. |
Chudnovski et al: “Sequences of numbers generated by addition in formal groups and new primality and factorization test”; Advances in Applied Mathematics, 7(4); pp. 385-434, 1986. |
Miller: “Use of elliptic curves in cryptography”; Advances in Cryptology; CRYPTO'85, vol. 218 of Lecture Notes in Computer Science, pp. 417-426. Springer, 1985. |
Knuth et al: “The Art of Computer Programming :Seminumerical Algorithms”; vol. 2. Evaluation of Powers, 4.6.3rd edition, 1997, pp. 441-466. |
Longa et al: “Efficient Techniques for High-Speed Elliptic Curve Cryptography” ; ECC Point Arithmetic Formulae (EPAF): Jacobian coordinates; In Proc. Workshop on Cryptographic Hardware and Embedded Systems (CHES 2010), 2010. |
Bernstein et al: “Explicit Formulas Database”. |
Search Report Dated Aug. 8, 2014. |
Number | Date | Country | |
---|---|---|---|
20150256340 A1 | Sep 2015 | US |