Computing the Modular Inverse of a Polynomial Function Over GF(2P) Using Bit Wise Operation

Total Page:16

File Type:pdf, Size:1020Kb

Computing the Modular Inverse of a Polynomial Function Over GF(2P) Using Bit Wise Operation International Journal of Network Security, Vol.10, No.2, PP.107{113, Mar. 2010 107 Computing the Modular Inverse of a Polynomial Function over GF (2P ) Using Bit Wise Operation Rajaram Ramasamy and Amutha Prabakar Muniyandi (Corresponding author: Rajaram Ramasamy) Department of Computer Science and Engineering, Thiayagarajar College of Engineering Thiruparankundram, Madurai, Tamil Nadu, India, 625 015, India (Email: rrajaram@tce.edu) (Received May 26, 2008; revised Dec. 4, 2008; and accepted Feb. 10, 2009) Abstract The integer is ¯rst expressed as a polynomial in x, say, 7 4 2 95H = 10010101 ¡! x + x + x + 1. Then its multiplica- Most public key crypto systems use ¯nite ¯eld modulo tive inverse in GF (28) is determined. The polynomial arithmetic. This modulo arithmetic is applied on real to represent GF (28) is a carefully selected prime num- numbers, binary values and polynomial functions. The ber in the range of 28 to 29. Say, 283=100011101 ¡! computation cost is based on how it works with minimum x8 + x4 + x3 + x + 1. This is called an irreducible poly- use of scarce resources like processor and memory We have nomial [8, 14]. It is so chosen such that it has a unique implemented the determination of the multiplicative in- multiplicative inverse. Then we apply the Extended Eu- verse of a polynomial over GF (2p) with minimum com- clidean Algorithm (EEA) to these polynomials to evaluate putational cost. The \Extended Euclidean Algorithm" the multiplicative inverse. This means, we have to deter- (EEA) has been demonstrated to work very well manually mine the multiplicative inverse of x7 + x4 + x2 + 1 with for integers and polynomials. However polynomial manip- respect to x8 + x4 + x3 + x + 1. Manual operation on the ulation cannot be computerized directly. We have imple- EEA is quite easy and straightforward. But how do we mented the same by using simple bit wise shift and XOR implement the process by using computers? This is what operations. In small applications like smart cards, mo- this paper does. It proposes an algorithm, which imple- bile devices and other small memory devices, this method ments it e±ciently and cost e®ectively. It implements the works very well. To the best of our knowledge, the pro- algorithm in C/C++ for two di®erent cases. This is the posed algorithm seems to be the ¯rst, e±cient and cost ¯rst attempt at proposing an algorithm to determine the e®ective implementation of determining the multiplicative multiplicative inverse of a polynomial over the GF (28) ¯- inverse of polynomials over GF (2p) using computers. As nite plane. Therefore the results got through this method this is a pioneering work, the results could not be com- could not be compared with past works. pared with that of any previous work. We organize this paper as follow: In Section 2 papers Keywords: Advance encryption standard, extended Eu- that have appeared on this topic are surveyed. In Section clidean algorithm, multiplicative inverse 3, the proposed algorithm is explained. Section 4 de¯nes the problem. Section 5 de¯nes the proposed algorithm. Section 6 implements the proposed method. Section 7 1 Introduction gives the concluding remarks and discusses future scope of this problem. Euclid proposed an algorithm to determine the multi- plicative inverse of polynomials over GF (Zp) [1, 5, 14]. In modern cryptography, ¯nite ¯elds and number the- 2 Related Work ory play a major role. Some basic operations in ¯nite ¯eld are essential to develop encryption algorithm like Ad- Stallings [14] has used the Extended Euclidean Algorithm vance Encryption Standard [6] and ECC [11]. Advanced to solve linear Diophantine equations, GCDs, and module Encryption Standard largely relies on S-Box values to in- inverses. Ever since Di±e and Hellman [3] developed the troduce non-linearity in the encryption process. Using a prototype of modern cryptography; most public key cryp- row and a column value, expressed in Hexadecimal nota- tosystems are based on ¯nite ¯elds with modular arith- tion, accesses an element of the S-Box. The hexadecimal metic constituting basic operations. Modular multipli- integer is representative of a character in a message to cations, modular exponentiations, and modular inverses be encrypted. Evaluation of the corresponding elemental are performed in RSA cryptosystems [13], the US Gov- value of the S-Box is quite a circumlocutory process. ernment Digital Signature Algorithm [10], the Di±e Hell- International Journal of Network Security, Vol.10, No.2, PP.107{113, Mar. 2010 108 man Key Exchange Scheme [10]. Among the basic opera- For example, GF (23) = x2 + x + 1. tions [4, 7], computing modular inverses involving polyno- The above-mentioned GF (23) is ¯nite ¯eld with re- mials is the most complex. This has engaged the attention spect to 3. In AES, the S-box generation is designed by of many researchers [1, 2, 9, 15]. using irreducible polynomial in GF (28). The strength of In 1997, Calvez et al. [1] proposed a variation on the the AES is dependent on the non-linearity introduced in Euclidean Algorithm, which determines the greatest com- evaluating the S-Box values. mon divisors (GCDs) and inverses of polynomials. In Suppose we want to generate S-box value for 2A with 2004, Goupil and Palicot [5] introduced another variation respect to GF (28) = x8 + x4 + x3 + x + 1. First, we have on this algorithm to reduce the number of operations to to determine the multiplicative inverse of 2A in GF (28). a large extent. Inspired by their work, Liu [9] proposes 2A in binary form is 0010 1010, which in polynomial rep- a variation on the EA, which uses only simple modulo resentation in x is (x5 + x3 + x). In manual procedure operators (subtraction operations), to compute the mod- the Extended Euclidean Algorithm or its shortened ver- ular inverses. This variant only modi¯es the initial values sion can be directly applied to polynomials to evaluate and the termination condition of the EA. Therefore it is the multiplicative inverse. as simple as the EA. However one drawback is that the The multiplicative inverse of 2A(00101010), expressed input of this variant is twice the size of bit length as the as a polynomial (x5 + x3 + x), over GF (28) is calculated input of the EA. manually using the abridged Euclidean Algorithm [1]. Liu's algorithm only deals with number system [9]. It The manual operation shows that the multiplicative is not applicable for polynomial functions. Polynomials inverse of (x5 + x3 + x) over (x8 + x4 + x3 + x + 1) is with coe±cients other than 1 are di±cult to implement (x7 + x4 + x3). in computers [9]. The reason for this is due to occurrence In general terms this algorithm determines multiplica- of some negative or fractional value coe±cients. The pro- tive inverse of B(x) modulo M(x), if the degree of B(x) posed algorithm is based on polynomials with 1 or 0 as is less than the degree of M(x); or alternatively we say coe±cients such as x7 + x5 + x3 + x + 1. that gcd[M(x);B(x)] = 1. If M(x) is an irreducible poly- In 1997, the American Government [1] decided to re- nomial, then it has no factor other than itself or 1, so that place DES with an e±cient encryption algorithm. The gcd[M(x);B(x)] = 1. National Institute of Standards and Technology (NIST) However the computer cannot be coded to deal with announced a common note to cryptographers for devel- these polynomial functions straightaway. They need to opment of a new algorithm. Earlier the DES was de- be handled in an indirect way. This paper proposes the veloped using Federal encryption standard. In January technique to manipulate polynomials by the Extended 1997 NIST solicited a new symmetric algorithm based Euclidean Algorithm. on 128-bit block of message using 128¡, 192¡, 256¡bit keys. Cryptographers from di®erent parts of the world submitted their proposals. Fifteen of these proposals met 4 Proposed Algorithm the NIST speci¯cations. Based on this, NIST organized a conference to deliberate on all the proposed methods. In our proposed method, we have converted the poly- After nineteen months of evaluation, NIST recommended nomial function into decimal and its equivalent binary ¯ve algorithms like MARS, RC6, Rijndael, Serpent, and values. Both number systems ¯gure in the computations. Two¯sh. Then after one year of study, in October 2000, The proposed algorithm is given below. National Institute of Standard and Technology recom- mended the Rijndael algorithm as best suited for AES. Procedure Multiplicative Inverse ((A3[], B3[ ])) The Rijndael algorithm is combination of security, per- formance, e±cient, implement ability, and flexibility. Af- 1: Binary value A3[];B3[] ter one more year of evaluation, in November 2001, the 2: Begin Department of Commerce o±cially declared Rijndael al- 3: C1 = 0; A2 = 0; B2 = 0; gorithm as the de facto Advance Encryption Standard. 4: while (B3 > 1) //Step 1 do 5: Q= 0; 6: T emp = B3; 3 Problem Description 7: do 8: Q1 = 1; In the ¯eld of information security some of the security al- 9: do p gorithms are designed by using the ¯nite ¯eld GF (2 ) [2]. 10: B3 = B3 <<LinearLeftShift AES and ECC are the two important encryption tech- 11: Q1 = Q1 ¤ 2; niques that use algorithms based on ¯nite ¯eld arithmetic. 12: until(A3MSB ==B3MSB ) p The ¯nite ¯eld GF (2 ) is representative of a polynomial 13: Q = Q + Q1; function with respect to one variable x, as follows: 14: A3 = A3[] © B3[ ]; 15: B3 = T emp; p p¡1 p¡2 2 1 GF (2 ) = x + x + ¢ ¢ ¢ + x + x : 16: until(A3 > T empjjBitSize(C) >= BitSize(T emp)) International Journal of Network Security, Vol.10, No.2, PP.107{113, Mar.
Recommended publications
  • Frequency Domain Finite Field Arithmetic for Elliptic Curve Cryptography
    Frequency Domain Finite Field Arithmetic for Elliptic Curve Cryptography by Sel»cukBakt³r A Dissertation Submitted to the Faculty of the Worcester Polytechnic Institute in partial ful¯llment of the requirements for the Degree of Doctor of Philosophy in Electrical and Computer Engineering by April, 2008 Approved: Dr. Berk Sunar Dr. Stanley Selkow Dissertation Advisor Dissertation Committee ECE Department Computer Science Department Dr. Kaveh Pahlavan Dr. Fred J. Looft Dissertation Committee Department Head ECE Department ECE Department °c Copyright by Sel»cukBakt³r All rights reserved. April, 2008 i To my family; to my parents Ay»seand Mehmet Bakt³r, to my sisters Elif and Zeynep, and to my brothers Selim and O¸guz ii Abstract E±cient implementation of the number theoretic transform (NTT), also known as the discrete Fourier transform (DFT) over a ¯nite ¯eld, has been studied actively for decades and found many applications in digital signal processing. In 1971 SchÄonhageand Strassen proposed an NTT based asymptotically fast multiplication method with the asymptotic complexity O(m log m log log m) for multiplication of m-bit integers or (m ¡ 1)st degree polynomials. SchÄonhageand Strassen's algorithm was known to be the asymptotically fastest multipli- cation algorithm until FÄurerimproved upon it in 2007. However, unfortunately, both al- gorithms bear signi¯cant overhead due to the conversions between the time and frequency domains which makes them impractical for small operands, e.g. less than 1000 bits in length as used in many applications. With this work we investigate for the ¯rst time the practical application of the NTT, which found applications in digital signal processing, to ¯nite ¯eld multiplication with an emphasis on elliptic curve cryptography (ECC).
    [Show full text]
  • Acceleration of Finite Field Arithmetic with an Application to Reverse Engineering Genetic Networks
    ACCELERATION OF FINITE FIELD ARITHMETIC WITH AN APPLICATION TO REVERSE ENGINEERING GENETIC NETWORKS by Edgar Ferrer Moreno A thesis submitted in partial fulfillment of the requirements for the degree of DOCTOR OF PHILOSOPHY in COMPUTING AND INFORMATION SCIENCES AND ENGINEERING UNIVERSITY OF PUERTO RICO MAYAGÜEZ CAMPUS 2008 Approved by: ________________________________ __________________ Omar Colón, PhD Date Member, Graduate Committee ________________________________ __________________ Oscar Moreno, PhD Date Member, Graduate Committee ________________________________ __________________ Nayda Santiago, PhD Date Member, Graduate Committee ________________________________ __________________ Dorothy Bollman, PhD Date President, Graduate Committee ________________________________ __________________ Edusmildo Orozco, PhD Date Representative of Graduate Studies ________________________________ __________________ Néstor Rodríguez, PhD Date Chairperson of the Department Abstract Finite field arithmetic plays an important role in a wide range of applications. This research is originally motivated by an application of computational biology where genetic networks are modeled by means of finite fields. Nonetheless, this work has application in various research fields including digital signal processing, error correct- ing codes, Reed-Solomon encoders/decoders, elliptic curve cryptosystems, or compu- tational and algorithmic aspects of commutative algebra. We present a set of efficient algorithms for finite field arithmetic over GF (2m), which are implemented
    [Show full text]
  • Study of Extended Euclidean and Itoh-Tsujii Algorithms in GF(2 M)
    Study of Extended Euclidean and Itoh-Tsujii Algorithms in GF (2m) using polynomial bases by Fan Zhou B.Eng., Zhejiang University, 2013 A Report Submitted in Partial Fulfillment of the Requirements for the Degree of MASTER OF ENGINEERING in the Department of Electrical and Computer Engineering c Fan Zhou, 2018 University of Victoria All rights reserved. This report may not be reproduced in whole or in part, by photocopying or other means, without the permission of the author. ii Study of Extended Euclidean and Itoh-Tsujii Algorithms in GF (2m) using polynomial bases by Fan Zhou B.Eng., Zhejiang University, 2013 Supervisory Committee Dr. Fayez Gebali, Supervisor (Department of Electrical and Computer Engineering) Dr. Watheq El-Kharashi, Departmental Member (Department of Electrical and Computer Engineering) iii ABSTRACT Finite field arithmetic is important for the field of information security. The inversion operation consumes most of the time and resources among all finite field arithmetic operations. In this report, two main classes of algorithms for inversion are studied. The first class of inverters is Extended Euclidean based inverters. Extended Euclidean Algorithm is an extension of Euclidean algorithm that computes the greatest common divisor. The other class of inverters is based on Fermat's little theorem. This class of inverters is also called multiplicative based inverters, because, in these algorithms, the inversion is performed by a sequence of multiplication and squaring. This report represents a literature review of inversion algorithm and implements a multiplicative based inverter and an Extended Euclidean based inverter in MATLAB. The experi- mental results show that inverters based on Extended Euclidean Algorithm are more efficient than inverters based on Fermat's little theorem.
    [Show full text]
  • 3 Finite Field Arithmetic
    18.783 Elliptic Curves Spring 2021 Lecture #3 02/24/2021 3 Finite field arithmetic In order to perform explicit computations with elliptic curves over finite fields, we first need to understand how to compute in finite fields. In many of the applications we will consider, the finite fields involved will be quite large, so it is important to understand the computational complexity of finite field operations. This is a huge topic, one to which an entire course could be devoted, but we will spend just one or two lectures on this topic, with the goal of understanding the most commonly used algorithms and analyzing their asymptotic complexity. This will force us to omit many details, but references to the relevant literature will be provided for those who want to learn more. Our first step is to fix an explicit representation of finite field elements. This might seem like a technical detail, but it is actually quite crucial; questions of computational complexity are meaningless otherwise. Example 3.1. By Theorem 3.12 below, the multiplicative group of a finite field Fq is cyclic. One way to represent the nonzero elements of a finite field is as explicit powers of a fixed generator, in which case it is enough to know the exponent, an integer in [0; q − 1]. With this representation multiplication and division are easy, solving the discrete logarithm problem is trivial, but addition is costly (not even polynomial time). We will instead choose a representation that makes addition (and subtraction) very easy, multiplication slightly harder but still easy, division slightly harder than multiplication but still easy (all these operations take quasi-linear time).
    [Show full text]
  • Finite Field Arithmetic (Galois Field)
    ASS.PROF.DR Thamer Information Theory 4th Class in Communication Finite Field Arithmetic (Galois field) Introduction: A finite field is also often known as a Galois field, after the French mathematician Pierre Galois. A Galois field in which the elements can take q different values is referred to as GF(q). The formal properties of a finite field are: (a) There are two defined operations, namely addition and multiplication. (b) The result of adding or multiplying two elements from the field is always an element in the field. (c) One element of the field is the element zero, such that a + 0 = a for any element a in the field. (d) One element of the field is unity, such that a • 1 = a for any element a in the field. (e) For every element a in the field, there is an additive inverse element -a, such that a + ( - a) = 0. This allows the operation of subtraction to be defined as addition of the inverse. (f) For every non-zero element b in the field there is a multiplicative inverse element b-1 such that b b-1= 1. This allows the operation of division to be defined as multiplication by the inverse. (g) The associative [a + (b + c) = (a + b) + c, a • (b • c) = [(a • b) • c], commutative [a + b = b + a, a • b = b • a], and distributive [a • (b + c) = a • b + a • c] laws apply. 1 ASS.PROF.DR Thamer Information Theory 4th Class in Communication These properties cannot be satisfied for all possible field sizes. They can, however, be satisfied if the field size is any prime number or any integer power of a prime.
    [Show full text]
  • 3 Arithmetic in Finite Fields
    18.783 Elliptic Curves Spring 2015 Lecture #3 02/10/2015 3 Arithmetic in finite fields In order to perform explicit computations with elliptic curves over finite fields, we first need to understand how to do arithmetic in finite fields. In many of the applications we will consider, the finite fields involved will be quite large, so it is important to understand the computational complexity of finite field operations. This is a huge topic, one to which an entire course could be devoted, but we will spend just one week on finite field arithmetic (this lecture and the next), with the goal of understanding the most commonly used algorithms and analyzing their asymptotic complexity. This will force us to omit many details. The first step is to fix an explicit representation of finite field elements. This might seem like a technical detail, but it is actually crucial; questions of computational complexity are meaningless otherwise. Example 3.1. As we will prove shortly, the multiplicative group of a finite field is cyclic. So one way to represent nonzero elements of a finite field is as powers of a fixed generator. With this representation multiplication and division are easy, and solving the discrete logarithm problem is essentially trivial. But addition is hard. We will instead choose a representation that makes addition and subtraction very easy, multiplication slightly harder but still easy, and division slightly harder still, but still easy (all quasi-linear time). But solving the discrete logarithm problem will be very difficult (no polynomial-time algorithm known). For they sake of brevity, we will focus primarily on finite fields of large characteristic, and prime fields in particular, although the algorithms we describe will work in any finite field of odd characteristic.
    [Show full text]
  • Computation in Finite Fields
    Computation in finite fields John Kerl Arizona State University and Lockheed Martin Corporation April, 2004 Abstract Elementary techniques for computation in finite fields are presented, at a level appropriate for an engi- neering, computer science or mathematical audience. Second, elementary Galois theory for finite fields is presented at a level appropriate for undergraduate or beginning graduate students in mathematics. For the latter, illustrative properties of a novel logarithmic root chart are developed. Third, linear feedback shift registers are presented in a manner which connects mathematical theory and engineering practice. Fourth, some techniques for software implementation are outlined: using a computer algebra system for the general case, and in C for the p = 2 case. This paper is an elaboration on lecture notes for a talk given to the Arizona State University Math Department's Graduate Student Seminar Series in fall of 2003. Some software-related updates were made January 2013. Contents Contents i 1 Introduction 1 1.1 Purpose . 1 1.2 Context . 1 1.3 Scope . 1 1.4 Audience . 2 1.5 Rings and fields; notation . 3 I Arithmetic 4 2 The field Fp 5 2.1 Elements of Fp ............................................ 5 2.2 Arithmetic in Fp ........................................... 6 2.3 First reciprocation method in Fp .................................. 6 2.4 Second reciprocation method in Fp ................................. 6 2.5 Third reciprocation method in Fp .................................. 7 2.6 Repeated-squaring algorithm for exponentiation . 7 2.7 Fourth reciprocation method in Fp; logarithms . 8 3 The field Fpn 10 3.1 Field characteristic and prime subfield . 10 3.2 Existence of Fpn ........................................... 10 3.3 Computation in Fp[x] .......................................
    [Show full text]
  • Fast Multiplication in Finite Fields GF(2N )
    Fast Multiplication in Finite Fields GF(2N ) Joseph H. Silverman Mathematics Department, Brown University, Providence, RI 02912 USA NTRU Cryptosystems, Inc., 3 Leicester Way, Pawtucket, RI 02860 USA jhs@math.brown.edu, jhs@ntru.com, http://www.ntru.com Abstract. A method is described for performing computations in a fi- N nite field GF(2 ) by embedding it in a larger ring Rp where the multipli- cation operation is a convolution product and the squaring operation is a rearrangement of bits. Multiplication in Rp has complexity N + 1, which is approximately twice as efficient as optimal normal basis multiplica- tion (ONB) or Montgomery multiplication in GF(2N ), while squaring has approximately the same efficiency as ONB. Inversion and solution of quadratic equations can also be performed at least as fast as previous methods. Introduction The use of finite fields in public key cryptography has blossomed in recent years. Many methods of key exchange, encryption, signing and authentication use field operations in either prime fields GF(p) or in fields GF(2N ) whose order is a power of 2. The latter fields are especially pleasant for computer implementation because their internal structure mirrors the binary structure of a computer. For this reason there has been considerable research devoted to making the basic field operations in GF(2N ) (especially squaring, multiplication, and inver- sion) efficient. Innovations include: • use of optimal normal bases [15]; • use of standard bases with coefficients in a subfield GF(2r) [26]; • construction of special elements α ∈ GF(2N ) such that powers αe can be computed very rapidly [5,6,8]; • an analogue of Montgomery multiplication [14] for the fields GF(2N ) [13].
    [Show full text]
  • Implementation of Finite Field Arithmetic Operations for Large Prime and Binary Fields Using Java Biginteger C Lass
    Published by : International Journal of Engineering Research & Technology (IJERT) http://www.ijert.org ISSN: 2278-0181 Vol. 6 Issue 08, August - 2017 Implementation of Finite Field Arithmetic Operations for Large Prime and Binary Fields using java BigInteger C lass Ni Ni Hla Tun Myat Aung University of Computer Studies, Yangon University of Computer Studies, Yangon Myanmar Myanmar Abstract—Many cryptographic protocols are based on the II. INTRODUCTION TO FINITE FIELDS difficulty of factoring large composite integers or a related problem. Therefore, we implement the finite field arithmetic A finite field is a field containing a finite number of operations for large prime and binary fields by using java elements. Fields are abstractions of familiar number systems BigInteger class to study our research under large integers for (such as the rational numbers Q, the real numbers R, and the public key cryptosystems and elliptic curve. complex numbers C) and their essential properties. They consist of a set F together with two operations, addition Keywords — Finite Field Arithmetic; Prime Field; Binary Field, (denoted by +) and multiplication (denoted by ·), that satisfy Large Integer the usual arithmetic properties: I. INTRODUCTION (F,+) is an abelian group with (additive) identity denoted The origins and history of finite fields can be traced back by 0. to the 17th and 18th centuries, but there, these fields played (F\{0}, ·) is an abelian group with (multiplicative) identity only a minor role in the mathematics of the day. In more denoted by 1. recent times, however, finite fields have assumed a much more The distributive law holds: (a+b) · c = (a · c) + (b · c) for fundamental role and in fact are of rapidly increasing all a, b, c ∈ F.
    [Show full text]
  • On the Circuit Complexity of Composite Galois Field Transformations∗
    Electronic Colloquium on Computational Complexity, Report No. 93 (2012) On the Circuit Complexity of Composite Galois Field Transformations∗ Charanjit S. Jutla Vijay Kumar† Atri Rudra‡ IBM T.J. Watson Research Center Groupon Inc. University of Buffalo, SUNY Abstract We study the circuit complexity of linear transformations between Galois fields GF(2mn) and their isomorphic composite fields GF((2m)n). For such a transformation, we show a lower bound of Ω(mn) on the number of gates required in any circuit consisting of constant-fan-in XOR gates, except for a class of transformations between representations of such fields which are nicely characterized. The exceptions show that the polynomials representing the fields must be of a regular form, which may be of independent interest. We characterize a family of transformations which can be implemented as cross-wires (permutations), without using any gates, which is very useful in designing hardware implementations – and through bit-slicing, software implementations – of computations based on Galois Field arithmetic. We also show that our lower bound is tight, by demonstrating a class of transformations which only require a linear number of gates. 1 Introduction Galois Field Arithmetic finds wide use in engineering applications such as error-correcting codes [4, 14], cryptography [26], switching theory [2] and digital signal processing [3, 15]. However the bulk of the applications have been in cryptography and coding theory. Galois fields have been used extensively in public key cryptography, including elliptic curve cryptography [12][17], as well as in symmetric key cryptography The best example of the latter is perhaps the AES algorithm Rijndael [28].
    [Show full text]
  • Applications of Finite Fields
    CDM Applications of Finite Fields Klaus Sutner Carnegie Mellon University 42-ffield-apps 2017/12/15 23:16 Warning 2 This lecture contains a number of \dirty tricks," rather than the supremely elegant and deeply rooted mathematical ideas that you have become accustomed to in this class. Think of it as the engineering approach: it's an opportunistic hack, but, boy, does it ever work well. 1 Implementing Finite Fields Discrete Logarithms Advanced Encryption Standard What To Implement 4 In order to implement a finite field we need a data structure to represent field elements and operations on this data structure to perform addition multiplication reciprocals, division exponentiation Subtraction is essentially the same as addition and requires no special attention. But, anything to do with multiplication is by no means trivial. In fact, there is an annual international conference that is dedicated to the implementation of finite fields. WAIFI Conference 5 Theory of finite field arithmetic: • Bases (canonical, normal, dual, weakly dual, triangular ...) • Polynomial factorization, irreducible polynomials • Primitive elements • Prime fields, binary fields, extension fields, composite fields, tower fields ... • Elliptic and Hyperelliptic curves Hardware/Software implementation of finite field arithmetic: • Optimal arithmetic modules • Design and implementation of finite field arithmetic processors • Design and implementation of arithmetic algorithms • Pseudorandom number generators • Hardware/Software Co-design • IP (Intellectual Property) components • Field programmable and reconfigurable systems Applications: • Cryptography • Communication systems • Error correcting codes • Quantum computing Classes of Implementations 6 Our characterization of finite fields as quotients of polynomial rings provides a general method of implementation, and even a reasonably efficient one. Still, it is a good idea to organize things into several categories, with different algorithmic answers.
    [Show full text]
  • Computing Multiplicative Inverses in Finite Fields by Long Division
    sciendo Journal of ELECTRICAL ENGINEERING, VOL 69 (2018), NO5, 400–402 COMMUNICATIONS Computing multiplicative inverses in finite fields by long division ∗ Otokar Groˇsek, Tom´aˇsFabˇsiˇc We study a method of computing multiplicative inverses in finite fields using long division. In the case of fields of a prime order p, we construct one fixed integer d(p) with the property that for any nonzero field element a, we can compute its inverse by dividing d(p) by a and by reducing the result modulo p. We show how to construct the smallest d(p) with this property. We demonstrate that a similar approach works in finite fields of a non-prime order, as well. However, we demonstrate that the studied method (in both cases) has worse asymptotic complexity than the extended Euclidean algorithm. K e y w o r d s: finite fields, multiplicative inverses 1 Introduction Thus to find an inverse mod p requires one long division and one reduction mod p. Computing a multiplicative inverse in a finite field is a This approach, although very laborious, has an in- common operation used in cryptography. For instance, it teresting history [4–6]. J. Waring in Meditationes alge- is a key operation in the cryptographic standard AES [1]. braicae, Cambridge, 1770, p. 218, first published the the- After M. Repka studied the McEliece cryptosystem orem that p|1 + (p − 1)! ascribing it to Sir John Wilson in [2], he set the question (in personal communication, (1714–93). J. L. Lagrange was the first to publish a proof 2017) if would be possible to find multiplicative inverses also with the converse in Nouv.
    [Show full text]