 
              Binary Edwards Curves Daniel J. Bernstein Tanja Lange University of Illinois at Chicago and Technische Universiteit Eindhoven djb@cr.yp.to tanja@hyperelliptic.org 12.08.2008 joint work with Reza Rezaeian Farashahi, Eindhoven D. J. Bernstein & T. Lange & R. Rezaeian Farashahi cr.yp.to/papers.html#edwards2 – p. 1
Harold M. Edwards Edwards generalized single example x 2 + y 2 = 1 − x 2 y 2 by Euler/Gauss to whole class of curves. Shows that – after some field extensions – every elliptic curve over field k of odd characteristic is birationally equivalent to a curve of the form x 2 + y 2 = a 2 (1 + x 2 y 2 ) , a 5 � = a Edwards gives addition law for this generalized form, shows equivalence with Weierstrass form, proves addition law, gives theta parameterization . . . in his paper Bulletin of the AMS, 44 , 393–422, 2007 D. J. Bernstein & T. Lange & R. Rezaeian Farashahi cr.yp.to/papers.html#edwards2 – p. 2
� � How to add on an Edwards curve y Let k be a field with 2 � = 0 . Let d ∈ k with d � = 0 , 1 . Edwards curve: { ( x, y ) ∈ k × k | x 2 + y 2 = 1 + dx 2 y 2 } Generalization covers more curves over k . Associative operation on points x ( x 1 , y 1 ) + ( x 2 , y 2 ) = ( x 3 , y 3 ) defined by Edwards addition law x 1 y 2 + y 1 x 2 y 1 y 2 − x 1 x 2 x 3 = and y 3 = . 1 + dx 1 x 2 y 1 y 2 1 − dx 1 x 2 y 1 y 2 Neutral element is (0 , 1) ; this is an affine point. − ( x 1 , y 1 ) = ( − x 1 , y 1 ) . (0 , − 1) has order 2 ; (1 , 0) and ( − 1 , 0) have order 4 . D. J. Bernstein & T. Lange & R. Rezaeian Farashahi cr.yp.to/papers.html#edwards2 – p. 3
Relationship to Weierstrass form Every elliptic curve with point of order 4 is birationally equivalent to an Edwards curve. Let P 4 = ( u 4 , v 4 ) have order 4 and shift u s.t. 2 P 4 = (0 , 0) . Then Weierstrass form: v 2 = u 3 + ( v 2 4 − 2 u 4 ) u 2 + u 2 4 /u 2 4 u. Define d = 1 − (4 u 3 4 /v 2 4 ) . The coordinates x = v 4 u/ ( u 4 v ) , y = ( u − u 4 ) / ( u + u 4 ) satisfy x 2 + y 2 = 1 + dx 2 y 2 . Inverse map u = u 4 (1 + y ) / (1 − y ) , v = v 4 u/ ( u 4 x ) . Finitely many exceptional points. Exceptional points have v ( u + u 4 ) = 0 . Addition on Edwards and Weierstrass corresponds. D. J. Bernstein & T. Lange & R. Rezaeian Farashahi cr.yp.to/papers.html#edwards2 – p. 4
Nice features of the addition law Neutral element of addition law is affine point, this avoids special routines (for (0 , 1) one of the inputs or the result). Addition law is symmetric in both inputs. � x 1 y 2 + y 1 x 2 , y 1 y 2 − x 1 x 2 � P + Q = . 1 + dx 1 x 2 y 1 y 2 1 − dx 1 x 2 y 1 y 2 D. J. Bernstein & T. Lange & R. Rezaeian Farashahi cr.yp.to/papers.html#edwards2 – p. 5
Nice features of the addition law Neutral element of addition law is affine point, this avoids special routines (for (0 , 1) one of the inputs or the result). Addition law is symmetric in both inputs. � x 1 y 2 + y 1 x 2 , y 1 y 2 − x 1 x 2 � P + Q = . 1 + dx 1 x 2 y 1 y 2 1 − dx 1 x 2 y 1 y 2 � x 1 y 1 + y 1 x 1 , y 1 y 1 − x 1 x 1 � [2] P = . 1 + dx 1 x 1 y 1 y 1 1 − dx 1 x 1 y 1 y 1 D. J. Bernstein & T. Lange & R. Rezaeian Farashahi cr.yp.to/papers.html#edwards2 – p. 5
Nice features of the addition law Neutral element of addition law is affine point, this avoids special routines (for (0 , 1) one of the inputs or the result). Addition law is symmetric in both inputs. � x 1 y 2 + y 1 x 2 , y 1 y 2 − x 1 x 2 � P + Q = . 1 + dx 1 x 2 y 1 y 2 1 − dx 1 x 2 y 1 y 2 � x 1 y 1 + y 1 x 1 , y 1 y 1 − x 1 x 1 � [2] P = . 1 + dx 1 x 1 y 1 y 1 1 − dx 1 x 1 y 1 y 1 No reason that the denominators should be 0 . Addition law produces correct result also for doubling. D. J. Bernstein & T. Lange & R. Rezaeian Farashahi cr.yp.to/papers.html#edwards2 – p. 5
Nice features of the addition law Neutral element of addition law is affine point, this avoids special routines (for (0 , 1) one of the inputs or the result). Addition law is symmetric in both inputs. � x 1 y 2 + y 1 x 2 , y 1 y 2 − x 1 x 2 � P + Q = . 1 + dx 1 x 2 y 1 y 2 1 − dx 1 x 2 y 1 y 2 � x 1 y 1 + y 1 x 1 , y 1 y 1 − x 1 x 1 � [2] P = . 1 + dx 1 x 1 y 1 y 1 1 − dx 1 x 1 y 1 y 1 No reason that the denominators should be 0 . Addition law produces correct result also for doubling. Unified group operations! D. J. Bernstein & T. Lange & R. Rezaeian Farashahi cr.yp.to/papers.html#edwards2 – p. 5
Complete addition law If d is not a square the denominators 1 + dx 1 x 2 y 1 y 2 and 1 − dx 1 x 2 y 1 y 2 are never 0 ; addition law is complete. Edwards addition law allows omitting all checks Neutral element is affine point on curve. Addition works to add P and P . Addition works to add P and − P . Addition just works to add P and any Q . Only complete addition law in the literature. No exceptional points, completely uniform group operations. Having addition law work for doubling removes some checks from the code and gives SCA protection (might leak Hamming weight, though). D. J. Bernstein & T. Lange & R. Rezaeian Farashahi cr.yp.to/papers.html#edwards2 – p. 6
Fast addition law Very fast point addition 10M + 1S + 1D. (Even faster with Inverted Edwards coordinates.) Dedicated doubling formulas need only 3M + 4S. Fastest scalar multiplication in the literature. For comparison: IEEE standard P1363 provides “the fastest arithmetic on elliptic curves” by using Jacobian coordinates on Weierstrass curves. Point addition 12M + 4S. Doubling formulas need only 4M + 4S. For more curve shapes, better algorithms (even for Weierstrass curves) and many more operations (mixed addition, re-addition, tripling, scaling,. . . ) see www.hyperelliptic.org/EFD for the Explicit-Formulas Database. D. J. Bernstein & T. Lange & R. Rezaeian Farashahi cr.yp.to/papers.html#edwards2 – p. 7
Edwards Curves – a new star(fish) is born lecture circuit: Hoboken Turku Warsaw Fort Meade, Maryland Melbourne Ottawa (SAC) Dublin (ECC) Bordeaux Bristol Magdeburg Seoul Malaysia (Asiacrypt) Madras Bangalore (AAECC) . . . D. J. Bernstein & T. Lange & R. Rezaeian Farashahi cr.yp.to/papers.html#edwards2 – p. 8 Washington (CHES)
One year passes . . . . . . I feel so odd . . . D. J. Bernstein & T. Lange & R. Rezaeian Farashahi cr.yp.to/papers.html#edwards2 – p. 9
Exceptions, 2 � = 0 . . . Even characteristic much more interesting for hardware . . . D. J. Bernstein & T. Lange & R. Rezaeian Farashahi cr.yp.to/papers.html#edwards2 – p. 10
Exceptions, 2 � = 0 . . . Even characteristic much more interesting for hardware . . . and soon also in software, cf. Intel’s and Sun’s current announcements to include binary instructions. D. J. Bernstein & T. Lange & R. Rezaeian Farashahi cr.yp.to/papers.html#edwards2 – p. 10
How to design a worthy binary partner? Our wish-list (early February 2008) after studying and experimenting with mostly small modifications of odd Edwards: A binary Edwards curve should be elliptic. look like an Edwards curve. have a complete addition law. cover most (all?) ordinary binary elliptic curves. have an easy to compute negation. have efficient doublings. have efficient additions. D. J. Bernstein & T. Lange & R. Rezaeian Farashahi cr.yp.to/papers.html#edwards2 – p. 11
How to design a worthy binary partner? Our wish-list (early February 2008) after studying and experimenting with mostly small modifications of odd Edwards: A binary Edwards curve should be elliptic. look like an Edwards curve. have a complete addition law. cover most (all?) ordinary binary elliptic curves. have an easy to compute negation. have efficient doublings. have efficient additions. be found before the CHES deadline, February 29th. D. J. Bernstein & T. Lange & R. Rezaeian Farashahi cr.yp.to/papers.html#edwards2 – p. 11
Binary Edwards curves Let d 1 � = 0 and d 2 � = d 2 1 + d 1 then E B ,d 1 ,d 2 : d 1 ( x + y ) + d 2 ( x 2 + y 2 ) = xy + xy ( x + y ) + x 2 y 2 , is a binary Edwards curve with parameters d 1 , d 2 . Map ( x, y ) �→ ( u, v ) defined by u = d 1 ( d 2 1 + d 1 + d 2 )( x + y ) / ( xy + d 1 ( x + y )) , v = d 1 ( d 2 1 + d 1 + d 2 )( x/ ( xy + d 1 ( x + y )) + d 1 + 1) is a birational equivalence from E B ,d 1 ,d 2 to the elliptic curve v 2 + uv = u 3 + ( d 2 1 + d 2 ) u 2 + d 4 1 ( d 4 1 + d 2 1 + d 2 2 ) , an ordinary elliptic curve in Weierstrass form. D. J. Bernstein & T. Lange & R. Rezaeian Farashahi cr.yp.to/papers.html#edwards2 – p. 12
Properties of binary Edwards curves ( x 3 , y 3 ) = ( x 1 , y 1 ) + ( x 2 , y 2 ) with x 3 = d 1 ( x 1 + x 2 ) + d 2 ( x 1 + y 1 )( x 2 + y 2 ) + ( x 1 + x 2 1 )( x 2 ( y 1 + y 2 + 1) + y 1 y 2 ) , d 1 + ( x 1 + x 2 1 )( x 2 + y 2 ) y 3 = d 1 ( y 1 + y 2 ) + d 2 ( x 1 + y 1 )( x 2 + y 2 ) + ( y 1 + y 2 1 )( y 2 ( x 1 + x 2 + 1) + x 1 x 2 ) . d 1 + ( y 1 + y 2 1 )( x 2 + y 2 ) if denominators are nonzero. Neutral element is (0 , 0) ; again, this is an affine point. (1 , 1) has order 2 . − ( x, y ) = ( y, x ) . ( x 1 , y 1 ) + (1 , 1) = ( x 1 + 1 , y 1 + 1) . D. J. Bernstein & T. Lange & R. Rezaeian Farashahi cr.yp.to/papers.html#edwards2 – p. 13
Recommend
More recommend