1. Field
The embodiments relate to processing operands, and in particular to a method, apparatus and system for processing large operands.
2. Description of the Related Art
The Karatsuba algorithm (A. Karatsuba and Y. Ofman, Multiplication of Multidigit Numbers on Automata, Soviet Physics-Doklady, 7 (1963), pages 595-596) was proposed in 1962 as an attempt to reduce the number of scalar multiplications required for computing the product of two large numbers. The classic algorithm accepts as input two polynomials of degree equal to 1, i.e., a(x)=a1x+a0 and b(x)=b1x+b0 and computes their product a(x)b(x)=a1b1x2+(a1b0+a0b1)x+a0b0 using three scalar multiplications. This technique is different from the naïve (also called the ‘schoolbook’) way of multiplying polynomials a(x) and b(x) which is to perform 4 scalar multiplications, i.e., find the products a0b0, a0b1, a1b0 and a1b1.
Karatsuba showed that you only need to do three scalar multiplications, i.e., you only need to find the products a1b1, (a1+a0)(b1+b0) and a0b0. The missing coefficient (a1b0+a0b1) can be computed as the difference (a1+a0)(b1+b0)−a0b0−a1b1 once scalar multiplications are performed. For operands of a larger size, the Karatsuba algorithm is applied recursively.
Karatsuba is not only applicable to polynomials but, also large numbers. Large numbers can be converted to polynomials by substituting any power of 2 with the variable x. One of the most important open problems associated with using Karatsuba is how to apply the algorithm to large numbers without having to lose processing time due to recursion. There are three reasons why recursion is not desirable. First, recursive Karatsuba processes interleave dependent additions with multiplications. As a result, recursive Karatsuba processes cannot take full advantage of any hardware-level parallelism supported by a processor architecture or chipset. Second, because of recursion, intermediate scalar terms produced by recursive Karatsuba need more than one processor word to be represented. Hence, a single scalar multiplication or addition requires more than one processor operation to be realized. Such overhead is significant. Third, recursive Karatsuba incurs the function call overhead.
Cetin Koc et. al. from Oregon Sate University (S. S. Erdem and C. K. Koc. “A less recursive variant of Karatsuba-Ofman algorithm for multiplying operands of size a power of two”, Proceedings, 16th IEEE Symposium on Computer Arithmetic, J.-C. Bajard and M. Schulte, editors, pages 28-35, IEEE Computer Society Press, Santiago de Compostela, Spain, Jun. 15-18, 2003) describes a less recursive variant of Karatsuba where the size of the input operands needs to be a power of 2. This variant, however, still requires recursive invocations and only applies to operands of a particular size.
The embodiments are illustrated by way of example, and not by way of limitation, in the figures of the accompanying drawings and in which like reference numerals refer to similar elements and in which:
The embodiments discussed herein generally relate to an apparatus, system and method for processing large numbers/operands. Referring to the figures, exemplary embodiments will now be described. The exemplary embodiments are provided to illustrate the embodiments and should not be construed as limiting the scope of the embodiments.
A complete sub-graph connecting vertices i0, i2, . . . , im−1 is mapped to the scalar product (ai
As an example, the edges 0-1 and 2-3 (with their adjacent vertices), and 0-2 and 1-3 (without their adjacent vertices) are subtracted from the complete square 0-1-2-3. What remains is the diagonals 0-3 and 1-2. These diagonals correspond to the term a1b2+a2b1+a3b0+a0b3, which is the coefficient of x3 of the result. In one embodiment the differences produced by the subtractions of sets of formulae represent diagonals of complete graphs where the number of vertices in these graphs is a power of 2 (i.e., squares, cubes, hyper-cubes, etc.). The terms that result from the subtractions, if added to one another, create the coefficients of the final product.
To explain in more detail, the following definitions are first noted. N represents the size of the input (i.e., the number of terms in each input polynomial). N is the product of L integers n0, n1, . . . , nL-1. The number L represents the number of levels of multiplication.
N=n0·n1· . . . ·nL-1 Eq. 1
For L levels, where a ‘level’ defines a set of complete graphs, the set of graphs of level l is represented as G(l). The cardinality of the set G(l) is represented as |G(l)|. The i-th element of the set G(l) is represented as Gi(l). Each set of graphs G(l) has a finite number of elements. The cardinality of the set G(l) is defined as:
Each element of the set G(l) is isomorphic to a complete graph Kn
G(l)={Gi(l): iε[0,|G(l)|−1], Gi(l)≅Kn
A complete graph Ka is a graph consisting of a vertices indexed 0, 1, 2, . . . , a-1, where each vertex is connected with each other vertex of the graph with an edge.
In one embodiment an element of the set G(l) can be indexed in two ways. One way is by using a unique index i which can take all possible values between 0 and |G(l)|−1, where the cardinality |G(l)| is given by Eq. 2. Such an element is represented as Gi(l). This way of representing graphs is denoted as a ‘global index’. That is, the index used for representing a graph at a particular level is called global index.
Another way to index the element Gi(l) is by using a set of l indexes i0, i1, . . . il−1, with l>0. This type of index sequence is denoted as a ‘local index’ sequence. In the trivial case where l=0, the local index sequence consists of one index only, which is equal to zero. The local indexes i0, i1, . . . , il−1 are related with the global index i of a particular element Gi(l) in a manner illustrated in Eq. 4.
i=(((i0·n1)+i1)·n2+i2)·n3+ . . . +il−1 Eq. 4
Eq. 4 can also be written in closed form as:
The local indexes i0, i1, . . . , il−1 satisfy the following inequalities:
0≦i0≦n0−1
0≦i1≦n1−1
. . . 0≦il−1≦nl−1 Eq. 6
In one embodiment the value of a global index i related to a local index sequence i0, i1, . . . , il−1 is between 0 and |G(l)| if inequalities (6) hold and the cardinality |G(l)| is given by (2). This is proved by the following: from Eq. 4 it can be seen that i is a non-decreasing function of i0, i1, . . . , il−1. Therefore, the smallest value of i is produced by setting each local index equal to zero. Therefore, the smallest i is zero. The highest value of i is obtained by setting each local index i0, i1, . . . , il−1 to be equal to its maximum value. Substituting each local index ij with nj−1 for 0≦j≦l−1 results in:
In one embodiment for each global index i between 0 and |G(l)|−1 there exists a unique sequence of local indexes i0, i1, . . . , il−1 satisfying Eq. 5 and the inequalities in Eq. 6. This is proved by the following: to prove that for a global index i such that 0≦i≦|G(l)|−1 there exists at least one sequence of local indexes i0, i1, . . . , il−1 satisfying Eq. 5 and Eq. 6, in one embodiment, the following pseudo code represents the construction of such a sequence of local indexes:
It can be seen that the local index sequence i0, i1, . . . , il−1 produced by the LOCAL_INDEXES satisfies both Eq. 5 and the inequalities in Eq. 6. Therefore, the existence of a local index sequence associated with a global index is proven.
To prove the uniqueness of the local index sequence, it is noted that if two sequences i0, i1, . . . , il−1 and i0′, i1′, . . . il−1′, satisfy Eq. 5 and Eq. 6, then it is not possible for some index q, 0≦q≦l−1, to have iq′≠iq. Assume the opposite, i.e., that there are m indexes q0, q1, . . . , qm−1 such that iq
(iq
Without loss of generality, assume that q0<q1< . . . <qm−1. The number (iq
The following notation is used to represent a graph associated with global index i and local index sequence i0, i1, . . . , il−1
Gi(l)=Gi
Consider the graph Gi(l) (or Gi
V(i
A second way to represent the vertices of a graph is using a ‘semi-local’ index sequence notation. In one embodiment a semi-local index sequence consists of a global index of a graph and a local index associated with a vertex. Using the semi-local index sequence notation, the il-th vertex of a graph Gi(l) is represented as vi,i
Vi(l)={vi,i
In one embodiment, for each vertex vi,i
Substituting i with
according to Eq. 5, the global index ig of a vertex is associated with a local index sequence i0, i1, . . . , il−1, il. The indexes i0, i1, . . . . , il−1 characterize the graph that contains the vertex whereas the index il characterizes the vertex itself. The relationship between ig and i0, i1, . . . , il−1, il is given in Eq. 12:
In one embodiment a global index ig associated with some vertex of a graph at level l has an one-to-one correspondence to a unique sequence of local indexes i0, i1, . . . , il−1, il satisfying identity (12), the inequalities (6) and 0≦il≦nl−1.
Using the global index notation, the set of all vertices of a graph Gi(l) (or G(i
The edge which connects two vertices vj(l) and vk(l) of a graph at level l is represented as ej-k(l). If two vertices vi,i
E(i
or
Ei(l)={ei,i
or
Ei(l)={ei
In one embodiment, the notation used for edges between vertices of different graphs of the same level is the same as the notation used for edges between vertices of the same graph. For example, an edge connecting two vertices v(i
In one embodiment alternative notations for the sets of vertices and edges of a graph G are V(G) and E(G) respectively. In addition, the term ‘simple’ from graph theory is used to refer to graphs, vertices and edges associated with the last level L−1. The graphs, vertices and edges of all other levels l, l<L−1 are referred to as ‘generalized’. The level associated with a particular graph G, vertex v or edge e is denoted as l(G), l(v) or l(e) respectively.
A vertex to graph mapping function ƒv→G is defined as a function that accepts as input a vertex of a graph at a particular level l, l<L−1 and returns a graph at a next level l+1 that is associated with the same global index or local index sequence as the input vertex.
ƒv→g(vi,i
Alternative definitions of the function ƒv→g are:
ƒv→g(vi(l))=Gi(l+1) Eq. 19
and
ƒv→g(v(i
Similarly, a graph to vertex mapping function ƒg→v is defined as a function that accepts as input a graph at a particular level l, l>0 and returns a vertex at a previous level l−1 that is associated with the same global index or local index sequence as the input graph.
ƒg→v(Gi(l)=v└i/n
Alternative definitions of the function ƒg→v are:
ƒg→v(Gi(l)=vi(l−1) Eq. 22
and
ƒg→v(G(i
The significance of the vertex to graph and graph to vertex mapping functions lies on the fact that they allow us to represent pictorially all graphs of all levels defined for a particular operand input size. First, each vertex of a graph is represented as a circle. Second, inside each circle, a graph is drawn at the next level, which maps to the vertex represented by the circle. As an example,
In the example illustrated in
In one embodiment the term ‘spanning’ is overloaded from graph theory. The term spanning is used to refer to edges or collections of edges that connect vertices of different graphs at a particular level.
A spanning plane is defined as a graph resulting from the join ‘+’ operation between two sub-graphs of two different graphs of the same level. Each of the two sub-graphs consists of a single edge connecting two vertices. Such two sub-graphs are described below:
{{v(i
{{v(i
In addition, the local index sequences characterizing the two edges which are joined for producing a spanning plane need to satisfy the following conditions:
i0=i0′, i1=i1′, . . . , iq≠q′, . . . , il=il′, îl=îl′ Eq. 25
Eq. 25 can be also written in closed form as follows:
(∃q, qε[0, l−1]: iq≠iq′)^(∀jε[0, l], j≠q: ij=ij′)^(îl=îl′) Eq. 26
Eq. 25 or Eq. 26 indicate that all corresponding local indexes of the joined edges in a spanning plane are identical apart from the indexes in a position q, where 0≦q≦l−1. Since iq≠iq′, this means that the two edges that are joined to form a spanning plane are associated with different graphs. In the special case where q=l−1, the two graphs containing the joined edges of a spanning plane map to vertices of the same graph at level l−1, since i0=i0′, i1=il′, . . . , il−2=il−2′.
The join operation ‘+’ between two graphs is defined as a new graph consisting of the two operands of ‘+’ plus new edges connecting every vertex of the first operand to every vertex of the second operand. A spanning plane produced by joining the two sub-graphs of Eq. 24 with Eq. 26 holding and q=l−1 is illustrated in
Using the local index sequence notation, a spanning plane can be formally defined as:
s(i
Since the local index sequence notation is lengthy, the shorter ‘semi-local’ index sequence notation is used for representing a spanning plane:
si,i
In the definition of Eq. 28 above, the value of the index i is given by identity Eq. 5 and:
i′=i0·n1·n2· . . . ·nl−1+i1·n2· . . . ·nl−1+ . . . +iq′·nq+1· . . . +il−2·nl−1+il−1 Eq. 29
In one embodiment global index notation is used for representing a spanning plane. Using the global index notation, a spanning plane is defined as:
si
In the Eq. 30 notation above:
ig=i·nl+il, îg=i·nl+îl, ig′=i′·nl+il, îg′=i′·nl+îl Eq. 31
The index i in identity (31) is given by identity (5) whereas the index i′ in (31) is given by identity (29). A pictorial representation of spanning planes using the semi-local index sequence and global index notations is given in
In another embodiment, an alternative pictorial representation of a spanning plane used as illustrated in
An example of a spanning plane is illustrated in
A spanning edge is an edge that connects two vertices v(i
i0=i0′, i1=i1′, . . . , iq≠iq′, . . . , il=il′ Eq. 32
or (in closed form):
(∃q, qε[0, l−1]: iq≠iq′)^(∀jε[0, l], j≠q: ij=ij′) Eq. 33
From the conditions in Eq. 33 it is evident that a spanning edge connects vertices with the same last local index (i, =il′). Second, the vertices which are endpoints of a spanning edge are associated with different graphs of G(l) since iq≠iq′. Third, in the special case where q=l−1, the two graphs containing the endpoints of a spanning edge map to vertices of the same graph at level l−1, since
i0=i0′, il=i1′, . . . , il−2=il−2′.
A spanning edge can be represented formally using the local index sequence notation as follows:
s(i
A spanning edge can be also represented formally using the semi-local index sequence notation:
si
In the definition in Eq. 35, the value of the index i is given by identity shown in Eq. 5 and:
i′=i0·n1·n2· . . . ·nl−1+il·n2· . . . ·nl−1+ . . . +iq′·nq+1· . . . ·nl−1+ . . . +il−2·nl−1+il−1 Eq. 36
In another embodiment a third way to represent a spanning edge is by using the global index notation:
si
To further aid in understanding, a set of mappings defined between edges, spanning edges and spanning planes are introduced. In what follows the term ‘corresponding’ is used to refer to vertices of different graphs of the same level that are associated with the same last local index. Two edges of different graphs of the same level are called ‘corresponding’ if they are connecting corresponding endpoints.
A generalized edge (i.e., an edge of a graph Gi(l), 0≦l≦L−1) or a spanning edge can map to a set of spanning edges and spanning planes through a mapping function ƒe→s. The function ƒe→s accepts as input an edge (if it is a spanning edge, the endpoints are excluded) and returns the set of all possible spanning edges and spanning planes that can be considered between the corresponding vertices and edges of the graphs that map to the endpoints of the input edge through the function ƒv→g.
Before the ƒe→s mapping is described formally an example is introduced. In the example illustrated in
Using the local index sequence location the function ƒe→s can be formally defined as:
ƒe→s(e(i
In the definition in Eq. 38 the index position q takes all possible values from the set [0, l].
The mapping ƒe→s
ƒe→s
and
ƒe→s
The definitions in Eq. 39 and Eq. 40 the index position q takes all possible values from the set [0, l].
In one embodiment mappings between sets of vertices and products are defined. The inputs to a multiplication process of an embodiment are the polynomials a(x) b(x) of degree N−1:
a(x)=aN−1·xN−1+aN−2·xN−2+ . . . +a1·x+a0,
b(x)=bN−1·xN−1+bN−2·xN−2+ . . . +b1·x+b0 Eq. 41
In one embodiment the coefficients of the polynomials a(x) and b(x) are real or complex numbers. In other embodiments the coefficients of the polynomials a(x) and b(x) are elements of a finite field.
The set V of m vertices are defined as:
V={vi
The elements of V are described using the global index notation and their level is omitted for the sake of simplicity. Three mappings P(V), P1(V) and P2(V) are defined between the set V and products as follows:
P(V)=(ai
P1(V)={ai
P2(V)={(ai+aj)·(bi+bj): i,jε{i0, i1, . . . , im−1}, i≠j} Eq. 45
The product generation process accepts as input two polynomials of degree N−1 as shown in Eq. 41. The degree N of the polynomials can be factorized as shown in Eq. 1. The product generation process of an embodiment is the first stage of a two step process which generates a Karatsuba-like multiplication routine that computes c(x)=a(x) b(x). Since the polynomials a(x) and b(x) are of degree N−1, the polynomial c(x) must be of degree 2N−2. The polynomial c(x) is represented as:
c(x)=c2N−2·x2N−2+c2N−3·x2N−3+ . . . +c1·x+c0 Eq. 46
Where
The expression in Eq. 47 can be also written as:
c0=a0·b0
c1=a0·b1+a1·b0
. . .
cN−1=aN−1·b0+aN−2·b1+ . . . +a0·bN−1
cN=aN−1·b1+aN−2·b2+ . . . +a1·bN−1
. . .
c2N−2=aN−1·bN−1 Eq. 48
Our framework produces a multiplication process that computes all coefficients c0, c1, . . . , c2N−2. At the preprocessing stage, the product generation process generates all graphs Gi(l) for every level l, 0≦l≦L−1. The generation of products is realized by executing a product creation process of an embodiment, shown in pseudo code as CREATE_PRODUCTS:
The process GENERALIZED_EDGE_PROCESS of an embodiment is described below in pseudo code.
A shown above, the process GENERALIZED_EDGE_PROCESS( ) processes each generalized edge from the set G(l) one-by-one. If the level of a generalized edge is less than L−2, then the procedure GENERALIZED_EDGE_PROCESS( ) invokes two other processes for processing the spanning edges and spanning planes associated with the generalized edge. The first of the two, SPANNING_EDGE_PROCESS( ), is shown below in pseudo code:
The second process, SPANNING_PLANE_PROCESS( ), is shown below in pseudo code:
In one embodiment the process EXPAND_VERTEX_SETS( ) is shown below in pseudo code. The notation g(v) is used to refer to the global index of a vertex v.
In one embodiment for all simple graphs, the products associated with simple vertices and simple edges are determined and these products are added to the set Pa. This occurs in lines 3 and 4 of the process CREATE_PRODUCTS( ). Second, for all generalized edges at each level, one embodiment does the following: first, each generalized edge is decomposed into its associated spanning edges and spanning planes. This occurs in lines 9 and 10 of the process GENERALIZED_EDGE_PROCESS( ).
To find products associated with each spanning edge, it is determined if a spanning edge connects simple vertices. If it does, the process computes the product associated with the spanning edge from the global indexes of the endpoints of the edge. This occurs in line 14 of the process GENERALIZED_EDGE_PROCESS( ). If a spanning edge does not connect simple vertices, this spanning edge is further decomposed into its associated spanning edges and spanning planes. This occurs in lines 2 and 3 of the process SPANNING_EDGE_PROCESS( ). For each resulting spanning edge that is not at the last level the process SPANNING_EDGE_PROCESS( )is performed recursively. This occurs in line 10 of the process SPANNING_EDGE_PROCESS( ).
To find products associated with each spanning plane, it is determined if the vertices of a spanning plane are simple or not. If they are simple, the product associated with the global indexes of the plane's vertices is formed and it is added to the set Pa (line 14 of the process GENERALIZED_EDGE_PROCESS( )). If the vertices of a plane are not simple, then the process expands these generalized vertices into graphs and creates sets of corresponding vertices and edge endpoints. This occurs in lines 14 and 21 of the process EXPAND_SINGLE_VERTEX_SET( ). For each such set the expansion is performed down to the last level. This occurs in lines 7-9 of the process SPANNING_PLANE_PROCESS( ).
There are four types of products created. The first type includes all products created from simple vertices. The set of such products P1a is:
P1a=P({v(i
A second type of products includes those products formed by the endpoints of simple edges. The set of such products P2a is:
P2a=P({v(i
A third type of products includes all products formed by endpoints of spanning edges. These spanning edges result from recursive spanning edge decomposition down to the last level L−1. The set of such products P3a has the following form:
P3a={P({v(i
A fourth type of products includes those products formed from spanning planes after successive vertex set expansions have taken place. One can show by induction that this set of products P4a has the following form:
Pa={P({v(i
The set P4a consists of all products formed from sets of vertices characterized by identical local indexes apart from those indexes at some index positions q0, q1, . . . , qm−1. For these index positions vertices take all possible different values from among the pairs of local indexes: (iq0, iq0′), (iq1, iq1′) , . . . , (iq
The set Pa of all products generated by executing the process CREATE_PRODUCTS is given by the expression in Eq. 53 below.
The expression in Eq. 53 is identical to Eq. 52 with one exception: The number of index positions m for which vertices differ may also take the values 0 and 1. The set Pa results from the union of P1a, P2a, P3a and P4a. It can be seen that by adding the elements of P1a into P4a one covers the case for which m=0. By further adding the elements of P2a and P3a into P4a also covers the case for which m=1.
Pa={P({v(i
The expression in Eq. 53 is in a closed form that can be used for generating the products without performing spanning plane and spanning edge decomposition. In one embodiment all local index sequences defined in Eq. 53 are generated and form the products associated with these local index sequences. Spanning edges and spanning planes offer a graphical interpretation of the product generation process and can help with visualizing product generation for small operand sizes (e.g., N=9 or N=18).
The number of elements in the set Pa generated by executing the process CREATE_PRODUCTS is equal to the number of scalar multiplications performed by generalized recursive Karatsuba for the same operand size N, and factors n0, n1, . . . , nL−1 such that N=n0·n1· . . . ·nl−1.
This is true because the number of scalar multiplications performed by generalized recursive Karatsuba as defined by Paar and Weimerskirch is:
In Eq. 49-52 the sets P1a, P2a, P3a and P4a do not contain any common elements. Therefore, the cardinality |Pa| of the set Pa is given by:
The set P1a contains all products formed by sets which contain a single vertex only. Each single vertex is characterized by some arbitrary local index sequence. Hence the cardinality |P1a| of the set P1a is given by:
The set P2a contains products formed by sets which contain two vertices. These vertices are characterized by identical local indexes for all index positions apart from the last one L−1. Since the number of all possible pairs of distinct values that can be considered from 0 to nL−1 is nL−1·(nL−1−1)/2, the cardinality of the set P2a is equal to:
The set P3a contains products formed by sets which contain two vertices as well. The products of the set P3a are formed differently from P2a, however. The vertices that form the products of P3a are characterized by identical local indexes for all index positions apart from one position between 0 and L−2. Since the number of all possible pairs of local index values the can be considered for an index position j is nj·(nj−1)/2, the cardinality of the set P3a is equal to:
Finally, the set P4a is characterized by the expression in Eq. 52. The cardinality of the set P4a is equal to:
Summing up the cardinalities of the sets P1a, P2a, P3a and P4a:
To prove that |Pr|=Pa| the identity that follows is used:
(a0+k)·(a1+k) · . . . ·(am−1+k)=km+km−1·(a0+a1+ . . . +am−1)+km−2·(a0·a1+a0·a2+ . . . +am−2·am−1)+ . . . +a0·a1· . . . ·am−1 Eq. 61
By substituting ai with (ni−1), m with L, and k with 2 in Eq. 60 and by combining Eq. 60 and Eq. 61 results in Eq. 62:
Therefore, it is proven that the number of products generated by an embodiment process is equal to the number of multiplication performed by using a generalized recursive Karatsuba process. It should be noted that the number of products generated by an embodiment process is substantially smaller than the number of scalar multiplication performed by the one-iteration Karatsuba solution of Paar and Weimerskirch (A. Weimerskirch and C. Paar, “Generalizations of the Karatsuba Algorithm for Efficient Implementations”, Technical Report, University of Ruhr, Bochum, Germany, 2003), which is N·(N+1)/2.
A typical product p from the set Pa is
p=P({v(i
For the product p, a ‘surface’ in the m-k dimensions (0≦k≦m) associated with ‘free’ index positions qf
The sets of the free and occupied index positions satisfy the following conditions:
{qf
{qp
{qf
{qf
In addition the indexes for the occupied positions
satisfy:
îq
Such surface is denoted as
The formal definition of a surface
is given in Eq. 66 below.
From the definition of Eq. 66 is it evident that a surface
associated with a product p is also an element of the set Pa and is generated by the procedure CREATE_PRODUCTS. From the definition in Eq. 66 is it is also evident that whereas p is formed by a set of 2m vertices, the surface
is formed by a set of 2m−k vertices. Finally, from the definition of the mapping in Eq. 43 and Eq. 66 it is evident that
The set of all surfaces in the m−k dimensions associated with a product p, free index positions qf
Next, the set of all surfaces in the m−k dimensions associated with a product p are defined as the union:
A ‘parent’ surface (u) of a particular surface
is defined as the surface associated with the product p, occupied index positions qp
The set of ‘children’ of a surface uεUp; m−k is defined as the set:
l(u)={v: vεUp; m−k−1, u=(v)} Eq. 70
In one embodiment, a process that generates subtraction formulae uses a matrix M which size is equal to the cardinality of Pa, i.e., the number of all products generated by the procedure CREATE_PRODUCTS( ). The cardinality of Pa is also equal to the number of unique surfaces that can be defined in all possible dimensions for all products of Pa. This is because each surface of a product is also a product by itself. For each possible product p, or surface u, the matrix M is initialized as M[p]←p, or equivalently M[u]←u. Initialization takes place every time a set of subtractions is generated for a product p of Pa.
Subtractions are generated by a generate subtractions process GENERATE_SUBTRACTIONS( ), which pseudo code is listed below. The subtraction formulae which are generated by generate subtractions process GENERATE_SUBTRACTIONS( ) are returned in the set Sa.
The procedure INIT_M( ) is listed below:
A process GENERATE_SUBTRACTIONS_FOR_PRODUCT( ), that is also invoked by GENERATE_SUBTRACTIONS( ), is listed below in pseudo code:
For each product p of Pa the subtractions generated by a process GENERATE_SUBTRACTIONS( ) reduce its value. Let μ(p) the final value of the table entry M[p] after the procedure GENERATE_SUBTRACTIONS_FOR_PRODUCT( ) is executed for the product p. It can be seen that μ(p) is in fact the product p minus all surfaces of p defined in the m−1 dimensions, plus all surfaces of p defined in the m−2 dimensions, . . . , minus (plus) all surfaces of p defined in 0 dimensions (i.e., products of single vertices). By m it is meant that the number of free index positions of p.
Next, it is determined how the subtractions generated by the process GENERATE_SUBTRACTIONS( ) can be interpreted graphically. Consider an example of an 18 by 18 multiplication. One of the products generated by the procedure CREATE_PRODUCTS( ) is formed from the set of vertices with global indexes 0, 1, 6, 7, 9, 10, 15, 16. This is the product (a0+a1+a6+a7+a9+a10+a15+a16)□(b0+b1+b6+b7+b9+b10+b15+b16).
Consider the complete graph which is formed from the vertices of this product. This graph has the shape of a cube but it also contains the diagonals that connect every other vertex, as shown in
The surfaces defined in a single dimension are the products (a0+a1)·(b0+b1), (a0+a6)·(b0+b6), (a1+a7)·(b1+b7), (a6+a7)·(b6+b7), (a9+a10)·(b9+b10), (a9+a15)·(b9+b15), (a10+a16)·(b10+b16), (a15+a16)·(b15+b16), (a1+a10) (b1+b10), (a0+a9)·(b0+b9), (a7+a16)·(b7+b16), and (a6+a15) (b6+b15). These products are formed from sets of 2 vertices. The complete graphs of these sets form the edges of the cube associated with the product (a0+a1+a6+a7+a9+a10+a15+a16)·(b0+b1+b6+b7+b9+b10+b15+b16). Finally, the surfaces defined in 0 dimensions are products formed from single vertices. These are the products a0·b0, a1·b1, a6·b6, a7·b7, a9·b9, a10·b10, a15·b15, and a16·b16.
Next, it is determined what remains if from the product (a0+a1+a6+a7+a9+a10+a15+a16)·(b0+b1+b6+b7+b9+b10+b15+b16) are subtracted all the surfaces defined in 2 dimensions, added all surfaces defined in 1 dimension and subtracted all surfaces defined in 0 dimensions. It can be seen that what remains is the term a0·b16+a16·b0+a1·b15+a15·b1+a6·b10+a10·b6+a9·b7+a7·b9. This term is part of the coefficient c16 of the output. The derivation of this term can be interpreted graphically as the subtraction of all covering squares from a cube, the addition of its edges and the subtraction of its vertices. What remains from these subtractions are the diagonals of the cube, excluding their end-points.
To prove the correctness of the embodiments, it is shown that every term μ(p) produced by the subtractions of the process GENERATE_SUBTRACTIONS( ) is part of one coefficient of a Karatsuba output c(x). It is also shown that for two different products p, {tilde over (p)}εPa, the terms μ(p) and μ({tilde over (p)}) do not include common terms of the form ai
Consider a product pεPa defined by Eq. 63. If m>0, then μ(p) is the sum of all possible terms of the form aI
I1=i0·n1· . . . ·nL−1+ . . . +îq
I2=i0·n1· . . . ·nL−1+ . . . +{hacek over (i)}q
îq
This means that μ(p) is the sum of all terms of the form aI
From Eq. 63 it is evident that the product p is the sum of terms which are either of the form aI
Next, it is shown that μ(p) does not contain terms of the form aI
surfaces of m dimensions,
surfaces of m−1 dimensions,
surfaces of m−2 dimensions, . . . , and
surfaces of m-l dimensions. From the manner in which the mapping P(V) is defined, it evident that the term aI
Using Newton's binomial formula:
Substituting x with 1, a with −1 and n with l we get that NL=0. Hence μ(p) does not contain any terms of the form aI
surfaces of m dimensions,
surfaces of m−1 dimensions,
surfaces of m−2 dimensions, . . . , and
surfaces of 0 dimensions. Therefore, the total number of times a term aI
The term μ(p) contains all possible terms of the form aI
Consider a product pεPa defined by Eq. 63. The sum of terms μ(p) is part of the coefficient ci
First consider the case where m>0. In this case, μ(p) is a sum of terms of the form aI
Next we show that the terms μ(p) and μ({tilde over (p)}) that derive from two different products p, {tilde over (p)}εPa do not include any common terms.
Consider the products p, {tilde over (p)}εPa. The terms μ(p) and μ({tilde over (p)}) that derive from these products have no terms of the form aI
In the trivial case where the number of free index positions of both p and {tilde over (p)} is zero, p=μ(p), {tilde over (p)}=μ({tilde over (p)}) and p≠{tilde over (p)}. In the case where one of the two products is characterized by zero free index positions and the other is not, then it is not possible for μ(p), μ({tilde over (p)}) to contain common terms since one of the two is equal to aI
Now, assume that both p and {tilde over (p)} are characterized by at least one free index position and that there exist two terms aI
Every term of the form aI
In what follows we refer to the example of
Multiplications create the nodes of the triangles 0-1-2, 3-4-5, and 6-7-8. Multiplications create the edges of the triangle 6-7-8. Multiplications create the edges of the triangle 3-4-5. Multiplications create the edges of the triangle 0-1-2. Multiplications create the edges that connect the nodes of the triangles 6-7-8 and 3-4-5. Multiplications create the edges that connect the nodes of the triangles 6-7-8 and 0-1-2. Multiplications create the edges that connect the nodes of the triangles 3-4-5 and 0-1-2. Multiplications create the spanning planes that connect the edges of the triangles 6-7-8 and 3-4-5. Multiplications create the spanning planes that connect the edges of the triangles 6-7-8 and 0-1-2. Multiplications create the spanning planes that connect the edges of the triangles 3-4-5 and 0-1-2.
Subtractions are performed, associated with the edges of the triangle 6-7-8. Subtractions are performed, associated with the edges of the triangle 3-4-5. Subtractions are performed, associated with the edges of the triangle 0-1-2. Subtractions are performed, associated with the edges that connect the nodes of the triangles 6-7-8 and 3-4-5. Subtractions are performed, associated with the edges that connect the nodes of the triangles 6-7-8 and 0-1-2. Subtractions are performed, associated with the edges that connect the nodes of the triangles 3-4-5 and 0-1-2. Subtractions are performed, associated with the spanning planes that connect the edges of the triangles 6-7-8 and 3-4-5. Subtractions are performed, associated with the spanning planes that connect the edges of the triangles 6-7-8 and 0-1-2. Finally, subtractions are performed, associated with the spanning planes that connect the edges of the triangles 3-4-5 and 0-1-2.
Additions create the coefficients of the resulting polynomial. Next the polynomial is converted to a big number.
In block 1115, each simple vertex is associated with a global index and a last level local index. In block 1120, generalized edges are defined consisting of a number of spanning edges and spanning planes. In block 1125, a spanning edge is an edge between two corresponding generalized (or simple) vertices. Corresponding vertices are associated with the same last level local index but different global indexes. A spanning plane is a fully connected graph interconnecting four generalized (or simple) vertices.
In block 1130, for all graphs interconnecting simple vertices, the products associated with simple vertices and simple edges are determined. Block 1135 starts a loop between blocks 1140, 1145, 1150 and 1160, where each block is performed for all generalized edges at each level.
In block 1140, a generalized edge is decomposed into its constituent spanning edges and spanning planes. In block 1145, the products associated with spanning edges are determined. If a spanning edge connects simple vertices, the product associated with the edge from the global indexes of the edge's adjacent vertices is formed. Otherwise the products associated with spanning edges are determined by treating each spanning edge as a generalized edge and applying a generalized edge process (blocks 1140 and 1145) recursively.
In block 1150, to determine products associated with spanning planes, process 1100 examines if the vertices of the plane are simple or not. If they are simple, the product associated with the global indexes of the planes vertices is formed and returned. If the vertices are not simple, the generalized vertices are expanded into graphs and sets of corresponding vertices and edges are created. Corresponding edges are edges interconnecting vertices with the same last level local index but different global index. For each set, the vertices which are elements of the set are used for running the spanning plane process (block 1150) recursively.
In block 1160, it is determined whether the last generalized edge has been processed by blocks 1140, 1145 and 1150. If the last edge has not been processed, process 1100 returns to block 1140. If the last edge has been processed, process 1100 continues with block 1165. In block 1165, for all the graphs associated with products created, (i.e., edges, squares, cubes, hyper-cubes, etc.) the periphery is subtracted and the diagonals are used to create coefficients of a final product. Process 1100 then proceeds with returning the final product at 1170.
Next a comparison of four one-iteration multiplication techniques: the Montgomery approach to Karatsuba (P. Montgomery, “Five, Six and Seven-Term Karatsuba-like Formulae”, IEEE Transactions on Computers, March 2005), the Paar and Weimerskirch approach, an embodiment and the schoolbook way. These techniques are compared in terms of the number of scalar multiplications each technique requires for representative operand sizes. From the numbers shown in
Big number multiplication is used by popular cryptographic algorithms like Rivest, Shamir, & Adleman (RSA). The embodiment processes avoid the cost of recursion. The embodiments correlate between graph properties (i.e. vertices, edges and sub-graphs) and the Karatsuba-like terms of big number multiplication routines and these embodiments generate and use one iteration Karatsuba-like multiplication processes for any given operand size which require the same scalar operations as recursive Karatsuba, without recursion. Embodiments are associated with the least possible number of ‘scalar’ multiplications. By scalar multiplications it is meant multiplications between ‘slices’ of big numbers or coefficients of polynomials. The embodiments can generate optimal, ‘one-iteration’, Karatsuba-like formulae using graphs.
Embodiments of the present invention may be implemented using hardware, software, or a combination thereof and may be implemented in one or more computer systems or other processing systems. In one embodiment, the invention is directed toward one or more computer systems capable of carrying out the functionality described herein. In another embodiment, the invention is directed to a computing device. An example of a computing device 1300 is illustrated in
Each device may include or execute an encryption program 1305. The encryption program 1305 may be a software application, firmware, an embedded program, hardware or similarly implemented program. The program may be stored in a non-volatile memory or storage device or may be hardwired. For example, a software encryption program 1305 may be stored in system memory 1319 during use and on a hard drive or similar non-volatile storage.
System memory may be local random access memory (RAM), static RAM (SRAM), dynamic RAM (DRAM), fast page mode DRAM (FPM DRAM), Extended Data Out DRAM (EDO DRAM), Burst EDO DRAM (BEDO DRAM), erasable programmable ROM (EPROM) also known as Flash memory, RDRAM® (Rambus® dynamic random access memory), SDRAM (synchronous dynamic random access memory), DDR (double data rate) SDRAM, DDRn (i.e., n=2, 3, 4, etc.), etc., and may also include a secondary memory (not shown).
The secondary memory may include, for example, a hard disk drive and/or a removable storage drive, representing a floppy disk drive, a magnetic tape drive, an optical disk drive, etc. The removable storage drive reads from and/or writes to a removable storage unit. The removable storage unit represents a floppy disk, magnetic tape, optical disk, etc., which is read by and written to by the removable storage drive. As will be appreciated, the removable storage unit may include a machine readable storage medium having stored therein computer software and/or data.
The encryption program 1305 may utilize any encryption protocol including SSL (secure sockets layer), IPsec, Station-to-Station and similar protocols. In one example embodiment, the encryption program may include a Diffie-Hellman key-exchange protocol or an RSA encryption/decryption algorithm.
The encryption program 1305 may include a secret key generator 1309 component that generates a secret key for a key-exchange protocol. The encryption program 1309 may also include an agreed key generator 1307 component. The agreed key generator 1307 may utilize the secret key from the encryption component 1313 of the device 1303 in communication with the computer 1301 running the encryption program 1305. Both the secret key generator 1309 and the agreed key generator 1307 may also utilize a public prime number and a public base or generator. The public prime and base or generator are shared between the two communicating devices (i.e., computer 1301 and smartcard 1303).
The encryption program may be used for communication with devices over a network 1311. The network 1311 may be a local area network (LAN), wide area network (WAN) or similar network. The network 1311 may utilize any communication medium or protocol. In one example embodiment, the network 1311 may be the Internet. In another embodiment, the devices may communicate over a direct link including wireless direct communications.
Device 1301 may also include a communications interface (not shown). The communications interface allows software and data to be transferred between computer 1301 and external devices (such as smartcard 1303). Examples of communications interfaces may include a modem, a network interface (such as an Ethernet card), a communications port, a PCMCIA (personal computer memory card international association) slot and card, a wireless LAN interface, etc. Software and data transferred via the communications interface are in the form of signals which may be electronic, electromagnetic, optical or other signals capable of being received by the communications interface. These signals are provided to the communications interface via a communications path (i.e., channel). The channel carries the signals and may be implemented using wire or cable, fiber optics, a phone line, a cellular phone link, a wireless link, and other communications channels.
In one example embodiment, an encryption component 1313 may be part of a smartcard 1303 or similar device. The encryption component 1313 may be software stored or embedded on a SRAM 1315, implemented in hardware or similarly implemented. The encryption component may include a secret key generator 1309 and agreed key generator 1307.
In alternative embodiments, the secondary memory may include other ways to allow computer programs or other instructions to be loaded into device 1301, for example, a removable storage unit and an interface. Examples may include a program cartridge and cartridge interface (such as that found in video game devices), a removable memory chip or card (such as an EPROM (erasable programmable read-only memory), PROM (programmable read-only memory), or flash memory) and associated socket, and other removable storage units and interfaces which allow software and data to be transferred from the removable storage unit to device 1301.
In this document, the term “computer program product” may refer to the emovable storage units. These computer program products allow software to be provided to device 1301. Embodiments of the invention may be directed to such computer program products. Computer programs (also called computer control logic) are stored in memory 1319, and/or the secondary memory and/or in computer program products. Computer programs may also be received via the communications interface. Such computer programs, when executed, enable device 1301 to perform features of embodiments of the present invention as discussed herein. In particular, the computer programs, when executed, enable computer 1301 to perform the features of embodiments of the present invention. Such features may represents parts or the entire blocks 1105, 1110, 1115, 1120, 1125, 1130, 1135, 1140, 1145, 1150, 1160, 1165 and 1170 of
In an embodiment where the invention is implemented using software, the software may be stored in a computer program product and loaded into device 1301 using the removable storage drive, a hard drive or a communications interface. The control logic (software), when executed by computer 1301, causes computer 1301 to perform functions described herein.
Computer 1301 and smartcard 1303 may include a display (not shown) for displaying various graphical user interfaces (GUIs) and user displays. The display can be an analog electronic display, a digital electronic display a vacuum fluorescent (VF) display, a light emitting diode (LED) display, a plasma display (PDP), a liquid crystal display (LCD), a high performance addressing (HPA) display, a thin-film transistor (TFT) display, an organic LED (OLED) display, a heads-up display (HUD), etc.
In another embodiment, the invention is implemented primarily in hardware using, for example, hardware components such as application specific integrated circuits (ASICs) using hardware state machine(s) to perform the functions described herein. In yet another embodiment, the invention is implemented using a combination of both hardware and software.
In the description above, numerous specific details are set forth. However, it is understood that embodiments of the invention may be practiced without these specific details. For example, well-known equivalent components and elements may be substituted in place of those described herein, and similarly, well-known equivalent techniques may be substituted in place of the particular techniques disclosed. In other instances, well-known circuits, structures and techniques have not been shown in detail to avoid obscuring the understanding of this description.
Embodiments of the present disclosure described herein may be implemented in circuitry, which includes hardwired circuitry, digital circuitry, analog circuitry, programmable circuitry, and so forth. These embodiments may also be implemented in computer programs. Such computer programs may be coded in a high level procedural or object oriented programming language. The program(s), however, can be implemented in assembly or machine language if desired. The language may be compiled or interpreted. Additionally, these techniques may be used in a wide variety of networking environments. Such computer programs may be stored on a storage media or device (e.g., hard disk drive, floppy disk drive, read only memory (ROM), CD-ROM device, flash memory device, digital versatile disk (DVD), or other storage device) readable by a general or special purpose programmable processing system, for configuring and operating the processing system when the storage media or device is read by the processing system to perform the procedures described herein. Embodiments of the disclosure may also be considered to be implemented as a machine-readable or machine recordable storage medium, configured for use with a processing system, where the storage medium so configured causes the processing system to operate in a specific and predefined manner to perform the functions described herein.
While certain exemplary embodiments have been described and shown in the accompanying drawings, it is to be understood that such embodiments are merely illustrative of and not restrictive on the broad invention, and that this invention not be limited to the specific constructions and arrangements shown and described, since various other modifications may occur to those ordinarily skilled in the art.
Reference in the specification to “an embodiment,” “one embodiment,” “some embodiments,” or “other embodiments” means that a particular feature, structure, or characteristic described in connection with the embodiments is included in at least some embodiments, but not necessarily all embodiments. The various appearances “an embodiment,” “one embodiment,” or “some embodiments” are not necessarily all referring to the same embodiments. If the specification states a component, feature, structure, or characteristic “may”, “might”, or “could” be included, that particular component, feature, structure, or characteristic is not required to be included. If the specification or claim refers to “a” or “an” element, that does not mean there is only one of the element. If the specification or claims refer to “an additional” element, that does not preclude there being more than one of the additional element.
Number | Name | Date | Kind |
---|---|---|---|
5317755 | Hartley et al. | May 1994 | A |
20030142818 | Raghunathan et al. | Jul 2003 | A1 |
20060176306 | Nagaraj et al. | Aug 2006 | A1 |
20060206554 | Lauter et al. | Sep 2006 | A1 |
Number | Date | Country | |
---|---|---|---|
20080005218 A1 | Jan 2008 | US |