The present invention relates to an address generator for producing a unique address corresponding to an input vector, and more particularly to an address generator capable of easily perform rewriting as well as being mounted in a small circuit area.
It is assumed that a set of k pieces (k is a natural number) of different binary vectors is called a set of registered vectors. Unique addresses from 1 to k are injected to inputs which coincide with the respective elements of the set of the registered vectors, and a function acting as 0 with respect to the inputs other than the above inputs is called an address generation function. Further, a network for calculating the address generation function is called an address generator. A vector that is applied to the address generator is called an input vector. An address generation function whose input vector is an n-dimensional vector is called an n-input address generation function. Further, a network for calculating the n-input address generation function is called an n-input address generator.
The address generator is also called an associative memory or a content addressable memory (CAM) and used in a wide field of such as pattern matching, a router of the Internet, a cache of a processor, TLB (Translation Lookaside Buffer), data compression, an accelerator of a database, a neural net, a memory path, and the like.
Although it is also possible to realize the function of the address generator using software, the speed of the address generator realized by software is very slow. Accordingly, the address generator is often realized using dedicated hardware (semiconductor memory). A conventional address generator composed of hardware will be explained below.
The comparison register 101 is a register for storing n-bit input vectors. The search bit-line driver 102 drives the respective bits of the comparison register 101 on a search bit line. Each of the words W1 to Wk has an n-bit CAM cell.
The coincidence comparison circuit 105 has three nMOS transistors (hereinafter, called “nMOSs”) 106, 107, 108. The nMOSs 106, 107 are connected in series between the search bit lines SLN and SL. The gates of the nMOSs 106, 107 are connected to the data D and the reverse data DN of the memory cell 104, respectively. The nMOS 108 is connected between the coincidence line ML and the ground. The gate of the nMOS 108 is connected to a node 109 between the nMOSs 106, 107.
First, before a search is performed, registered vectors as objects to be searched are stored in the respective words W1 to Wk of the address generator 100. The respective CAM cells 103 in the respective words write data to the memory cell 104 and read out data from the memory cell 104 likewise an ordinary SRAM.
When the search is performed, first, an input vector is stored in the comparison register 101. The respective bits of the input vector are driven on the search bit lines corresponding thereto by the search bit-line driver 102, respectively.
In the respective words W1 to Wk, the coincidence between the registered vectors previously stored in the respective CAM cells 103 and the input vector driven on the search bit line is simultaneously searched (in parallel), and the results are produced on the coincidence lines ML1 to MLk. The results of search of them are applied to the respective coincidence sensing circuits MSC1 to MSCk. The respective coincidence sensing circuits MSC1 to MSCk amplify the results of search and produce them to the coincidence sense output lines MT1 to MTk as coincidence sense produces. The respective coincidence sense outputs are stored in the coincidence flag registers MFR1, to MFRk and produced to coincidence flag output lines MF1 to MFk as coincidence flag produces. It is assumed that the coincidence flag set to ‘1’ shows “coincidence” and the coincidence flag set to ‘0’ shows “incoincidence”.
The respective coincidence flag outputs are applied to a priority encoder PE. The priority encoder PE selects the address of the word having the highest priority order from the words whose coincidence is detected according to a predetermined priority order (highest priority coincidence address: HMA) and produces the address. It is assumed that the priority order of the respective words is such that the word W1 has the highest priority order, and the priority order is sequentially lowered toward the word Wk.
Note that the coincidence search in the respective CAM cells 103 in the respective words W1 to Wk is performed as described below.
First, an initialization operation is performed. In the initialization operation, both the pair of the search bit lines SL, SLN are set to ‘L’(=‘0’). In contrast, one of the nMOSs 106, 107 of the coincidence comparison circuit 105 is placed in an ON state and the other of them is placed in an OFF state according to the data stored in the memory cell 104. Accordingly, the level of the node 109 between both the nMOSs 106, 107 is set to ‘L’ and the nMOS 108 is placed in the OFF state through one of the nMOSs 106, 107 which is placed in the ON state. In the state, the coincidence line ML is precharged to an ‘H’ (=‘1’) state. Note that the coincidence line ML that is set to ‘H’ is shows “coincidence”.
Next, the respective bits of the input vector stored in the comparison register 101 through the search bit line are applied to the respective CAM cells 103. With this operation, any one of the pair of the search bit lines SL, SLN is set to ‘H’ and the other of them is set to ‘L’ according to the input vector S.
When the data D stored in the memory cell 104 coincides with the input vector S, the level of the node 109 is set to ‘L’, and the nMOS 108 is kept in the OFF state.
In contrast, when the data D does not coincide with the input vector S, the level of the node 109 is set to ‘H’, and the nMOS 108 is placed in the ON state. With this operation, the coincidence line ML is discharged and placed in an ‘L’ state.
The coincidence line ML of a CAM word composed of the n-bit CAM cells 103 constitute a wired OR circuit to which the nMOSs 108 of the respective CAM cells 103 are connected in parallel. Accordingly, only when coincidence is detected in all the n-bit CAM cells 103 which constitute one word, the coincidence line ML is held in the ‘H’ (“coincidence”) state. In contrast, when incoincidence is detected in the CAM cells 103 even in one bit, the coincidence line ML is placed in an ‘L’ (“incoincidence”) state.
For example, it is assumed that ‘0’, ‘1’, ‘1’, ‘0’, . . . , ‘1’, and ‘0’ are stored in the coincidence flag registers MFR1 to MFRk as coincidence flags as a result of the search. In this case, the coincidence is detected in the words W2, W3, . . . , Wk−1. Accordingly, the priority encoder PE produces the address of the word W2 having the most priority order as HMA. Further, the address of the word W3 having the next highest priority order can be produced as HMA by clearing the coincidence flag stored in the coincidence flag register MFR2 to ‘0’, Hereinafter, the addresses of the words whose coincidence is detected can be sequentially produced likewise.
In the CAM cell 103′, when a search is performed, both a pair of bit lines SL, SLN are set to ‘H’ as an initialization operation. In contrast, one of the nMOSs 106, 107 of the coincidence comparison circuit 105 is placed in the ON state and the other of them is placed in the OFF state according to the data stored in the memory cell 104. Accordingly, the level of the node 109 between both the nMOSs 106, 107 is set to ‘H’ and the nMOS 108 is placed in the ON state through one of the nMOSs 106, 107 which is in the ON state. In this state, one end of the coincidence line ML is precharged to the ‘H’(=‘1’) state. Note that the coincidence line ML that is set to ‘H’ shows “incoincidence”.
The coincidence line ML of CAM words composed of the n-bit CAM cells 103 constitute an AND circuit to which the nMOSs 108 of the respective CAM cells 103′ are serially connected. Accordingly, the coincidence lines MLa, MLb of the respective CAM cells are precharged to ‘H’ through the nMOSs 108 of the respective CAM cells 103′.
Thereafter, the respective bits of the input vector stored in a comparison register 101 are applied to the respective CAM cells 103′ through a search bit line. With this operation, any one of the pair of the search bit lines SL, SLN is set to ‘H’ and the other of them is set to ‘L’ according to the input vector S.
When the data D stored in the memory cell 104 coincides with the input vector S, the level of the node 109 is ‘H’, and the nMOS 108 is held in the ON state.
Whereas, when the data D does not coincide with the input vector S, the level of the node 109 is set to ‘L’, and the nMOS 108 is placed in the OFF state.
After all the states of the n-bit CAM cells 103′ of the CAM words are fixed, a discharge is started from one end of the coincidence line ML, and a result of comparison of coincidence is determined by the other end thereof. At the time, when there is an incoincident CAM cell 103′ even in one bit, the result of coincidence of comparison is ‘H’, that is, the result is held in the state of incoincidence. In contrast, only when incoincidence is detected in all the CAM cells 103′, the result of comparison of coincidence is set to ‘L’, that is, it is placed in a coincidence state.
“Ultra high speed device series 2 Ultra high speed MOS device”, supervised by Tadao Kanno, edited by Susumu Koyama, first edition, Baihukan, February 1986, pp. 324-325.
“LSI hand book”, edited by The Institute of Electronics, Information and Communication Engineers, first edition, Ohm Sha, November 1994, pp 523-525.
Kostas Pagiamtzis and Ali Sheikholeslami, “A Low-Power Content-Addressable Memory (CAM) Using Pipelined Hierarchical Search Scheme”, IEEE Journal of Solid-State Circuits, Vol. 39. No. 9, September 2004, pp. 1512-1519.
T. Sasao, M. Matsuura, and Y. Iguchi, “A cascade realization of multi-output function for reconfigurable hardware”, International Workshop on Logic and Synthesis (IWLSO1), Lake Tahoe, Calif., Jun. 12-15, 2001, pp. 225-230.
T. Sasao and M. Matsuura, “BDD representation for incompletely specified multiple-output logic functions and its applications to functional decomposition”, Design Automation Conference, June 2005, (pp. 373-378).
An n-input address generation function is a so-called sparse logic function in which, ordinarily, the number k of input vectors whose output value is made to non-zero is sufficiently smaller than the number 2n which is a combination of all the n-dimensional vectors.
A set of registered vectors of, for example, n=128, k=40000 will be examined. In this case, the ratio of the number of the input vectors to the number to which the input vectors can be set is 40000/2128=1.17549×10−34. A most simple method of realizing an address generator to the set of the registered vectors is a truth table. However, it is not practical to directly store the truth table in a memory because the memory becomes excessively large.
Further, the address generator can be also realized even by the conventional address generator described above, a two-stage logic network, a PLA (Programmable Logic Array). However, when an LSI is employed in the set of the registered vectors, a problem arises in that a chip area and power consumption become excessively large. Further, in the conventional address generator described above, a cost per bit (bit cost) becomes more expensive than a RAM.
For example, although the speed of the conventional address generator is higher than that of the RAM because it can perform searches in parallel, it has a complex device configuration. Accordingly, the cost per bit (bit cost) of the address generator is more expensive than the RAM.
Further, a power consumption per bit is much larger than that of the RAM (refer to Non-Patent Document 3). This is because all the CAM cells are accessed at the same time as explained above. Accordingly, the power consumption per bit becomes about several tens as large as that of an ordinary RAM.
Accordingly, an object of the present invention is to provide an address generator which can suppress power consumption as well as simplify the structure of a device and can be mounted in a small circuit area while maintaining a high speed search property.
Before an constitution of the present invention is explained, first, the terms used in the description will be defined, and a basic principle of the present invention will be explained.
[1] Definition of Terms and Several Theorems
[Definition 1] (Address Generation Function)
In function f(X): Bn→(0, 1, . . . , k), (B=(0, 1), kεnatural number), when f(ai)=i (i=1, 2, . . . , k) is established to k pieces of different registered vectors aiεBn (i=1, 2, . . . , k) and f(ai)=0 is established to (2n−k) pieces of input vectors ai other than the above mentioned, f(X) is called an address generation function having a weight k. The address generation function generates unique addresses of from 1 to k to k pieces of different binary vectors.
In the description, it is assumed that the value of k is sufficiently smaller than the total number 2n of a combination of the input vectors (k<<2n).
[Definition 2] (Registered Vector, Registered Vector Table)
A set of k pieces of n-bit vectors will be examined. The set of the vectors is called a set of registered vectors, and the respective vectors that belong to the set of the registered vectors is called registered vectors. A table, in which each of integers of from 1 to k are caused to correspond to each of all the registered vectors that belong to the set of the registered vectors is called a registered vector table.
(Table 1) shows a registered vector table composed of seven pieces of 4-bit registered vectors. (Table 2) shows address generation functions corresponding to the registered vector table. Any of the address generation functions produces an address that corresponds to an input vector that coincides with the registered vectors as a 3-bit number (for example, ‘001’). When there is no registered vector which coincides with the input vector in the registered vector table, ‘000’ is produced.
[Definition 3] (Partition)
The input vector is shown by X=(x1, x2, . . . , xn). A set of variables of X is shown by {X}. When {X1}∪{X2}={X} as well as {X1}∩{X2}=φ, X=(X1, X2) is called a partition of X. Here, φ shows an empty set.
It is assumed that completely defined function f(X): Bn→Bq (B={0, 1}, X=(x1, x2, . . . , xn), n, qεnatural number) are given. It is assumed that (XL, XH) is a partition of X. The dimension of X (the number of pieces of variables) is denoted by d(X). A table, which satisfies the following conditions (1) to (3) to the function f(X) and the partition of X X=(XL, XH) is called a degradation table of f 2nL column 2nH row:
(1) a table of 2nL column 2nH row, wherein it is assumed that nL=d(XL), nH=d(XH);
(2) It is assumed that the respective rows and the respective columns have a label of a binary code, and the sets of the labels of the columns and the rows use all the patterns of nL, nH bits as elements, respectively; and
(3) The respective elements of the table are the truth values f(XL, XH) of f to a combination (XL, XH) of the columns and the rows corresponding to the labels.
XL is called a bound variable, and XH is called a free variable.
The number of pieces of different column patterns of the degradation table is called a degree of column complexity of the degradation table and shown by μ. A case of XL=X, XH=φ is also examined as a special case of the degradation table.
Further, in the degradation tables of the function f, a degradation table in which XL=(x1, x2, . . . , xnL) as well as XH=xnL+1, XnL+2, . . . , xn), is called a basic degradation table.
In the degradation table of (Table 3), nL=3, nH=2, μ=2.
[Definition 5] (C Scale)
When the order of the variables of a vector X is shown by X=(x1, x2, . . . , xn), a maximum value of the degree of column complexity of the basic degradation table of a logic function f(X) is called a C scale of f.
Although the C scale of f1=x1 x2 x4 x6 is 3, the C scale of f2=x1 x5 x6 x4 is 8.
The degree of column complexity of the degradation table is equal to the width of MTBDD (Multi-Terminal Binary Decision Diagram). Accordingly, the C scale of the logic function is equal to a maximum value of the MTBDD in the given order of input variables. The C scale can be easily calculated to a given logic function f(x1, x2, xn) and uniquely determined. As described later, a function having a small C scale can be efficiently realized by a LUT cascade. Accordingly, the C scale acts as a scale of complexity when the logic function is realized by the LUT cascade.
[Lemma 1]
The C scale of the logic function f having a weight k is k+1 at the highest.
It is assumed that XL shows the free variable of the degradation table, XH shows the bound variable of the degradation table, and μ shows the degree of column complexity of the degradation table with respect to a given function f(X). At the time, the function f can be realized by the circuit shown in
┌log2μ┐ [Expression 1]
It is called a functional decomposition to decompose one function f(X)=f(XL, XH) and to realize it as two functions G, H (however, f(X)=(G(H1 (XL)), XH)). The functions G, H, which can be obtained by the functional decomposition, is called a subfunction of the decomposition.
In
[Definition 7] (LUT Cascade)
Subfunctions, which can be obtained by repeatedly subjecting one function f(X) to the functional decomposition are shown by G1, G2, . . . , G5.
The respective subfunctions G1, G2, . . . , G5 are realized by a look up table (LUT), and when respective LUTs are cascade-connected by signal lines, they are called a LUT cascade. The respective LUTs which show the respective subfunctions G1, G2, . . . , G5 are called cells. Signal lines, which connect between adjacent cells, are called rails.
A logic function having the C scale of μ can be realized by a LUT cascade composed of a cell having the number of inputs of q+1 at the highest and the number of outputs of q. Here, Expression 3 is shown as follows.
q=┌log2μ┐ [Expression 3]
A LUT cascade for realizing the function f will be examined. It is assumed that n shows the number of external inputs, s shows the number of cells, q shows the maximum number of rails (the number of signal lines between the cells), p shows the maximum input number of the cells, and μ shows the C scale of the function f.
p≧┌log2μ┐+1 [Expression 4]
When Expression 4 is established, there exists a LUT cascade that realizes a function f satisfying the following relation.
An address generation function having the weight of k can be realized by a LUT cascade the number of rails of which is shown by Expression 6.
┌log2(k+1)┐ [Expression 6]
However, when k has a large value, it is difficult to realize the address generation function by a single cascade because a cell becomes excessively large. When, for example, k=40000, a cell having 17 inputs and 16 outputs is necessary. In this case, the amount of necessary memory can be reduced by decomposing a set of vectors to several sets of vectors and realizing the sets of the respective vectors by independent cascades. However, in this case, an encoder is necessary to integrate the outputs of a plurality of the cascades.
[2] Principle of the Present Invention
(1) Method Using One Hash Memory (Hybrid Method)
In the address generation function f(X1, X2) having the weight of k, an input variable (X1, X2) is subjected to primary conversion to (Y1, Y2), and an address space is hashed. A degradation table (
[Expression 7]
{circumflex over (f)}(Y1,X2) (1)
Note that, hereinafter, an expression suffixed with “^” as in Expression 8 is shows as “f ^” in the text.
{circumflex over (f)} [Expression 8]
The number of variables (bound variables) of Y1 is shown by p. When it is assumed that non-zero elements are uniformly distributed in the degradation table, the degradation table has one non-zero element in average at the highest when 2p>k. For the purpose of simplification, it is assumed that the degradation table has one non-zero element in each column at the highest. Next, h^ (Y1) is realized by a hash memory 3′ using Expression 9 (refer to
Although the input of a function f^ is (Y1, X2), since h^(Y1) can predict the value of f^ only by the value of Y1, there is a possibility that the value of h^(Y1) is different from the value of f^. Thus, whether or not the value of h^(Y1) is correct is checked by an auxiliary (AUX) memory 4′. The number of inputs of the auxiliary memory 4′ is shown by Expression 10, and the number of outputs thereof is n (actually, it can be reduced up to n−p)
[Expression 10]
q=┌log2(k+1)┐ (3)
Corresponding registered vectors are stored in the respective addresses of the auxiliary memory 4′. When the search patterns of the output and the input of the auxiliary memory 4′ are equal to each other, since the hash memory 3′ produces a correct value, the output value of the hash memory 3′ is produced as it is. When they are not equal each other, since the hash memory 3′ produces a value different from f^, 0 is produced.
When a column has two or more non-zero elements (when hash collision occurs), since the above method cannot be used, f^(Y1, X2) is subjected to functional decomposition using Expression 11 so that one non-zero element exists at the highest in the respective columns of the degradation table of the function f^1(Y1, X2).
{circumflex over (f)}(Y1,X2)={circumflex over (f)}1(Y1,X2){circumflex over (f)}2(Y1,X2), {circumflex over (f)}1(Y1,X2)·{circumflex over (f)}2(Y1,X2)=0 [Expression 11]
Further, the function f^2(Y1, X2)=f2(X1, X2) is realized by a reconfigurable logic network such as a LUT cascade, a reconfigurable PLA (refer to, for example, Patent Document 4) and the like. Here, f2(X1, X2) shows a function that can be obtained by converting the hashed bound variable Y1 of f^2 (Y1, X2) into a bound variable X1.
Note that the function f^1 (Y1, X2) is called a master address generation function. Further, the function f2 (X1, X2) is called a slave address generation function.
The address generator has the following features. Although the hash memory 3′ effectively realizes the address generation function, since hash collision occurs, a part of the registered vectors cannot be expressed. In contrast, although the reconfigurable logic network such as the LUT cascade, the reconfigurable PLA, and the like securely realizes the address generation function, it is ineffective when the value of k is large. Thus, the address generator of
(2) Method Using Two or More Hash Memories (Super Hybrid Method)
M pieces of different partitions (X1i, X2i) (i=1, . . . , M) will be examined to an input variable X. An address space is hashed to the respective partitions likewise (1), and an address generation function f^1i(Y1i, X2i) is realized using the hash memory 3′ and the auxiliary memory 4′ (refer to
{circumflex over (f)}(Y1,X2)−{circumflex over (f)}1l(Y1l,X2l) . . . {circumflex over (f)}1k(Y1k,X2k){circumflex over (f)}2(Y1,X2), {circumflex over (f)}1i(Y1i,X2i)·{circumflex over (f)}2(Y1,X2)=0 (i=1, . . . , M) [Expression 12]
Further, the slave address generation function f^2(Y1, X2)=f2(X1, X2) is realized by the reconfigurable logic network such as the LUT cascade, the reconfigurable PLA, and the like. Here, f2(X1, X2) shows the function that can be obtained by converting the hashed bound variable Y1 of f^2 (Y1, X2) into the bound variable X1.
When a case that k=2 (refer to
An address generation function f(X) having variables and the weight of k will be examined.
[Hybrid Method]
In the hybrid method, the number of inputs of the hash memory 3′ is p=q+2, and the number of outputs thereof is q. Here, q is shown by a formula (3). Further, the number of inputs of the auxiliary memory is q, and the number of outputs thereof is (n−q−2). Accordingly, the total amount of the memory is shown by Expression 13.
q·2q+2+(n−q−2)·2q=(4n+12q−8)·2q−2 [Expression 13]
[Super Hybrid Method]
In the super hybrid method, the number of inputs of a first hash memory is (q+1), the number of outputs thereof is q, the number of inputs of a first auxiliary memory is q, the number of outputs thereof is (n−q−1), the number of inputs of a second hash memory is (q−1), the number of outputs thereof is (q−2), the number of inputs of a second auxiliary memory is (q−2), and the number of outputs thereof is (n−q+2). Accordingly, the total amount of the memory is shown by Expression 14.
q·2q|1+(n−q−1)·2q+(q−2)·2q−1+(n−q+2)·2q−2=(5n+5q−6)·2q−2 [Expression 14]
When Expression 15 is established from the above two formulas, the amount of the necessary memory of the super hybrid method is smaller than that of the hybrid method.
n≦7 log2(k|1)−2 [Expression 15]
With the first constitution of the address generator according to the present invention, an address generator to perform operation of the address generation function f(X) which produces a unique address A corresponding to a binary input vector (hereinafter referred to simply as “input vector”) X if said input vector is a registered vector, otherwise produces “invalid value”, comprises:
A. one or more master address generators to produce the unique address A corresponding to said input vector X if said input vector X belongs to a subset of a registered vector set, otherwise produce “invalid value”;
B. a slave address generator that produces the unique address A corresponding to said input vector X if all the outputs of the master address generators are “invalid value” and said input vector X which belongs to said registered vector set, otherwise performs operation of a slave address generation function f2(X) to produce “invalid value” or an unique address A corresponding to said input vector X; and
C. an output combiner that produces the output value of the master address generator or the output value of the slave address generator as the unique address $A$ if the output value of the master address generator or the slave address generator are not “invalid value”, otherwise produces “invalid value”; wherein
said master address generator comprising:
a. a hash network to hash the bound variables Xn to produce the hashed bound variables Yn for the partition (X1i,X2i) of the input vector X, where i denotes an index identifying master address generator;
b. a tentative address generator that produces a unique address A as a tentative address A′ if the unique address A corresponds one-to-one to said bound variables Y1i (i.e., when no hash collision occurs), otherwise (i.e., when hash collision occurs), produces an arbitrary value or one of the corresponding unique address A as a tentative address A′;
c. a data re-generator that performs operation of data regeneration function f−1(A), which is an inverse function of the address generation function f(X), wherein regenerated vector X″=f−1(A′) is produced when said tentative address A′ produced by said tentative address generator is applied, and
d. a unique address detector that compares said regenerated vector X″ with said input vector X, and produces said tentative address A′ if they are identical, otherwise produces “invalid value”.
According to the constitution, when the input vector X is applied to the address generator from the outside, the hash network hashes the bound variable X1i to an input vector X=(X1i, X2i) and produces it as the hashed bound variable Y1i. Here, it is assumed that X=(X1i, X2i) is a partition of X. Further, the bound variable Xn is converted into Y1i by the hashing, and the input vector X becomes a hashed input vector x1i=(Y1i, X2i).
Next, when no hash collision occur as to Y1i, the tentative address generator produces a unique address A corresponding to Y1i as the tentative address A′. When hash collision occurs, any one of an arbitrary value or a corresponding unique addresses A is produced as the tentative address A′. The data regenerator produces the regenerated vector X″=f−1(A′) from the obtained tentative address A′ in correspondence to the address thereof. When the unique address generator compares X″ with X and they coincide with each other, it produces the tentative address A′. Otherwise, the unique address generator produces “invalid value”. With this operation, a correct unique address A or the “invalid value” is produced from unique address generator to the input vector X.
In contrast, the slave address generator produces a correct unique address A=f(X) corresponding to X (“invalid value” when no unique address exists) to the input vector X in which the output of the unique address generator becomes the “invalid value”. Whereas, when the output of the unique address generator becomes a value other than the “invalid value”, the slave address generator produces the “invalid value” or the correct unique address A=f(X) corresponding to X.
Finally, when the output value of the unique address generator and the output value of the slave address generator include values which are not the “invalid values”, the output combiner produces them as the unique address A. When both of them are the “invalid values”, the output combiner produces the “invalid values”. With this operation, when a registered vector that coincides with the input vector X exists, the correct unique address A corresponding to X is produced from the output combiner.
When the input vector X is hashed once, the address generation function A=f(X)=f(X1i, X2i) is converted into A=f^(Y1i X2i). When the number k of the unique address A is sufficiently smaller than the number 2n of a combination of n-dimensional input vectors X, the number of A corresponding to Y1i is one piece in average at the highest. That is, when a hash function is selected well, the allocation of Y1i and A are in a relation of about 1 to 1. Thus, the hash function used in hashing is selected using the value of Y1i so that the probability capable of uniquely determining A can be increased as much as possible. As a result, A can be almost entirely shown as the function A=G(Y1i) of the bound variable Y1i. Since the number of elements of the input vector Y1i of G is smaller than the number of elements of the input vector X, the tentative address generator can be realized by a small network.
Then, the remaining input vectors X, in which hash collision occurs, are calculated in the slave address generator using A as the function of all the elements of X. At the time, X is limited to those in which hash collision occurs, the number of a combination of As which must be calculated by the slave address generator is small. Accordingly, the slave address generator can be realized by a small network.
Thus, it is possible to reduce the overall network scale of the address generator in its entirety and to suppress power consumption. Further, the structure of a device can be simplified and the device can be mounted in a small area.
Further, when two or more master address generators are provided, since a different partition (X1i, X2i) can be performed by the respective master address generator, the ratio of the registered vectors, at which the address generation function is realized by the master address generators, is increased as compared with the case that the one master address generator is employed. Accordingly, since the number of the registered vectors whose address creation function must be realized by the slave address generator can be reduced, it is possible to constitute the address generator by a smaller network scale.
Here, “binary vector” means a vector in which each component of the vector is a binary digit.
“Hashing” means to replace the order of a part or all of the vector components of the input vector X so that non-zero elements are dispersed in many columns in the degradation table of the address generation function. “Hash collision occurs” means that a plurality of unique addresses A correspond to the allocation of bound variables Y1 in which not-hashed vector components are removed from the vector components of a hashed input vector X′.
“Data-regeneration function” means a reverse function of the address generation function f(X), that is, a function for mapping a unique address A to an input vector X corresponding to it.
“Invalid value” means a value showing that an address is invalid (does not exist). A value in which all the components of an address are shown by 0 and all the components are shown by 1, an address value which does not exist actually, and the like are used as the “invalid value”.
“Slave address generation function” means a function which produces, when the unique address generator produces “invalid value”, the value calculated by the address generation function f(X) to the input vector X and otherwise produces “invalid value” or the value calculate by the address generation function f(X). That is, the slave address generation function maps the input vector X to the unique address A corresponding to it in the former case and maps it to the “invalid value” or to the unique address A corresponding to the input vector X in the latter case.
A LUT cascade and other logic network can be used as the slave address generator.
With the second constitution of the address generator according to the present invention, in the first constitution, said slave address generator produces the unique address A corresponding to the input vector X if the input vector X produces the hash collision for the hashed bound variables Y1i, otherwise produces “invalid value” in all of said master address generators.
According to the constitution, when hash collision occurs, the slave address generator produces a correct unique address and, when no hash collision occurs, it produces “invalid value” at all times. Accordingly, it is sufficient to arrange the slave address generator so that it examines X when hash collision occurs and calculates the unique address A to several Xs which are obtained as a result of the examination. Thus, a logic calculation network in the slave address generator can be easily arranged.
With the third constitution of the address generator according to the present invention, in the first constitution, said tentative address generator is a hash memory storing the tentative address generate function as an LUT and the tentative address generate function produces the unique address A corresponding to the bound variables Y1 as a tentative address A′, if no hash collision occurs for the hashed bound variables Y1.
Reconfiguration can be also simply performed by rewriting a memory while keeping a high calculation speed by composing the tentative address generator of the hash memory as described above.
With the fourth constitution of the address generator according to the present invention, in the first constitution, said data re-generator is an auxiliary memory storing the data regeneration function f−1(A) as an LUT.
Since the data regenerator is composed of the auxiliary memory as described above, reconfiguration can be also simply performed by rewriting a memory while keeping a high calculation speed.
With the fifth constitution of the address generator according to the present invention, in the first constitution, said slave address generator is configured by an LUT cascade logic network, consisting of plural subfunction memories connected in a cascade, and
said each subfunction memory stores subfunction, which is obtained by a functional decomposition of the slave address generation function f2(X), as an LUT.
Since the slave address generator comprises the LUT cascade logic network, a network scale can be also reduced as compared with a case that it comprises PLA (Programmable Logic Array) while keeping a high calculating speed. Further, reconfiguration can be also simply performed by rewriting the memories while keeping a high calculation speed.
As described above, according to the present invention, the hash network, which hashes an input vector, and the tentative address generator, which produces a unique address from a hashed input vector, are provided as well as the slave address generator, which calculates a unique address that cannot be calculated by the tentative address generator is provided so that the unique address is created by complementarily combining the tentative address generator and the slave address generator. With this constitution, the network scale of the overall address generator can be reduced and power consumption is suppressed as well as the structure of the device is simplified so that it can be mounted in a small area.
Further, since the tentative address generator and the data regenerator are composed of the memory in which the LUT is stored and the slave address generator is composed of the LUT cascade, reconfiguration can be also simply performed by rewriting the memory while keeping a high calculation speed.
A best mode for carrying out the invention will be explained below referring to the drawings.
[Embodiment 1]
In the embodiment, a case of one master address generator will be explained (hybrid method).
[1] Configuration of Address Generator
The address generator 1 according to the embodiment has a hash network 2, a tentative address generator 3, a data regenerator 4, a unique address detector 5, a slave address generator 6, and an output combiner 7.
The address generator 1 is a calculator for calculating an address generation function f(X) having a weight k. That is, when an input vector X is applied from the outside and a registered vector corresponding to the input vector X exists, the address generator 1 produces a unique address A of the registered vector. Otherwise, the address generator 1 produces “invalid value” 0.
Here, the input vector X is an n-dimensional vector. Further, the unique address A takes a value of from 1 to k and is expressed by a q-bit binary digit. Here, q is shown by the formula (3) described above.
The hash network 2 hashes a part or all of the input vectors X according to a predetermined hash function. Here, a partition of X is shown by X=(X1, X2). Xi is a bound variable, and X2 is a free variable. A case of X1=X is also examined. The hash network 2 hashes the bound variable X1 of X and generates a hashed input vector X′=(Y1, X2).
The tentative address generator 3 generates a tentative address A′. In this case, the tentative address A′ is determined as follows:
(1) When one allocation to a hashed bound variable Y1 does not cause hash collision to occur, a unique address A corresponding to the allocation is shown by a tentative address A′; and
(2) When one allocation to a hashed bound variable Y1 causes hash collision, a smallest unique address A in a set {A1} of unique addresses A corresponding to the allocation is shown by the tentative address A′.
Hereinafter, a function, which maps one allocation to the bound variable Y1 (2p pieces of allocations exist in total) to the tentative address A′, is called a tentative address generation function and shown by h^(Y1).
The data regenerator 4 is a calculator for calculating the reverse function X=f−1(A) of an address generation function A=f(X). The data regenerator 4 produces a regenerated vector X″=f−1(A′) to the tentative address A′ applied from the tentative address generator 3.
The input vector X, the regenerated vector X″, and the tentative address A′ are applied to the unique address detector 5. The unique address detector 5 compares the regenerated vector X″ with the input vector X. Then, when they coincide with each other, the tentative address A′ is produced, otherwise, “invalid value” 0 is produced.
The slave address generator 6 is a calculator for performing a calculation of the slave address generation function f2^(X), which is in a complementary relation to a calculation of the tentative address A′ performed by the tentative address generator 3, the data regenerator 4, and the unique address detector 5, to the address generation function f(X) and producing a slave address A″. The slave address generation function f2^(X) is a function as shown below:
(1) When the unique address detector 5 produces the “invalid value” 0, the input vectors X is mapped to the unique address A corresponding thereto; and
(2) Otherwise, the input vector X is mapped to the “invalid value” 0 or to a corresponding unique address A.
The slave address generator 6 may be arranged by combining logic gates or using a LUT cascade logic network.
An output value of the unique address detector 5 and an output value of the slave address generator 6 are applied to the output combiner 7. When one or both of these output values are values other than the “invalid value” 0, the output combiner 7 produces the values as the unique address A. When both of them are the “invalid values” 0, the output combiner 7 produces the “invalid values” 0.
Note that, in
The hash memory 3′ is composed of a rewritable memory. The tentative address generation function h^(Y1) shown in a formula (2a) or a formula (2b) is stored in the hash memory 3′ as a LUT.
The auxiliary memory 4′ is composed of a rewritable memory. A data regeneration function f−1, which is the reverse function of the address generation function f, is stored in the auxiliary memory 4′ as a LUT.
The LUT cascade 6′ is composed of a plurality of rewritable memories (cells) which are cascade-connected by a plurality of signal lines (rails) as shown in
[2] Operation of Address Generator
First, an input vector X of an n-dimensional vector is applied to the address generator 1. The hash network 2 primarily converts the input vector X=(X1, X2) into (Y1, X2) according to a predetermined hash function and hashes an address space. Here, (X1, X2) is a partition of X, and X1 is a bound variable and X2 is a free variable. The number of pieces of the variables of the vector X is shown by d(X). It is assumed that d(X)=n, d(X1)=d(Yi)=p, d(X2)=r=n−p. Further, q is shown by the formula (3).
The bound variable Y1, which is generated in the hash network 2 and hashed, is applied to the hash memory 3′.
Here, a hash function is previously set to the hash network 2 by adapting to the address generation function f. A generation method of the hash function will be described later.
The address generation function after it is hashed is shown as f^(Y1, X2). The degradation table of the function f^(Y1, X2) is as shown in
The hash memory 3′ generates the tentative address A′ by the tentative address generation function h^(Y1) defined by the formula (2a) or the formula (2b) based on the bound variable Y1. Here, d(A′)=q. Note that since the value of A is predicted only by the value of the Y1, A′=h^(Y1) may take a value different from a correct value A=f^(Y1, X2).
The tentative address A′ is applied to the auxiliary memory 4′ and the AND circuit 11.
The auxiliary memory 4′ generates a regenerated vector X″=f−1(A′) that corresponds to the tentative address A′. The regenerated vector X″ and the original input vector X are applied to the comparison circuit 10.
The comparison circuit 10 compares both of them with each other, and when both of them coincide with each other, 1 is produced to the AND circuit 11, and otherwise 0 is produced thereto. The AND circuit 11 performs an AND operation of an output value of the comparison circuit 10 and the respective bits of the tentative address A′. A result of calculation is produced to the OR circuit 7′.
With this operation, when the tentative address A′ is equal to the correct unique address A to X, the tentative address A′ is produced from the AND circuit 11 to the OR circuit 7′, and otherwise the “invalid value” 0 is produced. That is, the output value of the AND circuit 11 is made to a function in which the elements other than a minimum non-zero element is replaced with 0 as to the columns in which two or more non-zero elements exist in the degradation table of the address generation function f1^(Y1, X2) after hashing. Hereinafter, the function is called a master address generation function and shown by f1^(Y1, X2).
In contrast, the input vector X is applied also to the LUT cascade 6′. In the LUT cascade 6, a slave address generation function f2(X1, X2) is calculated by a LUT cascade, and a result of the calculation is produced to the OR circuit 7′ as a slave address A″.
Note that the slave address generation function f2(X1, X2) can be obtained by subjecting the address generation function f^(Y1, X2) to the functional decomposition after it is hashed as shown in the formula (5) and converting the variable Y1 of f2^(Y1, X2) into X1 by the reverse function of the hash function as described above.
[Expression 17]
{circumflex over (f)}(Y1,X2)={circumflex over (f)}(Y1,X2){circumflex over (f)}2(Y1,X2) (5)
Accordingly, when the master address generation function f1^(Y1, X2) is determined, the hashed slave address generation function f2^(Y1, X2) is uniquely determined by the following formula (6).
Note that a specific method of arranging the slave address generation function f2(X1, X2) will be described later.
The master address generation function f1^(Y1, X2) and the slave address generation function f2(X1, X2) are complementary to the address generation function f(X1, X2). That is, a formula (7) is established from the formula (5).
[Expression 19]
f (X1,X2)={circumflex over (f)}(Y1,X2)f 2(X1,X2) (7)
Thus, the OR circuit 7′ calculates the value of the address generation function f(X1, X2) by performing an OR operation of the output value f1^(Y1, X2) of the AND circuit 11 and the output value f2(X1, X2) of the LUT cascade 6′.
[3] Method of Arranging Hash Function
In the hash network 2, any function can be used as a hash function for hashing the bound variable X1 as long as it uniformly distributes the non-zero elements in the degradation table of the address generation function f. Here, the following hash function is used as an example in consideration of easiness of realization.
[Expression 20]
Y1−(y1, y2, . . . , yp), yi−xi⊕xj (xiε{Xi},yiε{Y1}, xjε{X2}) (8)
[3-1] Generation Algorithm of Hash Function
In the address generation function f(X1, X2), a bound variable is shown by X1=(x1, x2, . . . , xp), and a free variable is shown by X2=(xp+1, xp+2, . . . , xn). A function, which is obtained by replacing the bound variable X1 to Y1=(y1, y2 . . . , yp), is shown by f^(Y1, X2). In the columns of a degradation table of the function f^(Y1, X2), the number of pieces of the columns including a non-zero element is shown by w. To store many addresses in the hash memory 3′, it is sufficient to select Y1 by which w is maximized. Y1 may be selected using various known algorithms (non-linear program method and heuristic algorithm).
[Algorithm 1]
When Expression 21 is established to the respective elements xi (i=1, 2, . . . p) of X1, Xj1′ε{X2} by which w is maximized is selected.
yi=xi⊕x′j
The operation is repeated until w does not increase.
The hash function is arranged by Xj=(xj1, xj2, . . . , xjp) determined as described above.
[3-2] Realization Method of Hash Function
In the address generation function f(X1, X2) having the weight k, the function, which is obtained by replacing the bound variable X1=(x1, x2 . . . , xp) with Expression 22, is shown by a function f^(Y1, X2).
[Expression 22]
(y1⊕xj1,y2⊕xj2, . . . , yp⊕xj
Here, it is assumed that the number of pieces p of the bound variable satisfies the condition of the following formula (10).
[Expression 23]
p≧┌log2(k+1)┐ (10)
When f^(a, X2) has two or more non-zero output values to a p-dimensional binary vector a (εY1), the function, which is obtained by replacing the values of f^(a, X2) other than a minimum non-zero output value with 0, is shown by the master address generation function f1^(Y1, X2). The master address generation function f1^(Y1, X2) is shown by the following formula (11).
Next, a function f2(Y1, X2) is determined by the formula (6). At the time, the relation of the formula (7) is established.
In the respective columns of the degradation table of the master address generation function f1^(Y1, X2), only one non-zero output value exists at the highest. Next, the function h^(Y1) defined by the following formula (12) is realized by the hash memory 3′.
However, since there is a possibility that the value of the function h^(Y1) is different from the value of the master address generation function f1^(Y1, X2), whether or not an output value is correct is confirmed using the auxiliary memory 4′. Further, the slave address generation function f2(Y1, X2) is generated by performing replacement of the following formula (13) from the function f2^(Y1, X2). The slave address generation function f2(Y1, X2) is realized by the LUT cascade 6′.
[Expression 26]
xi=yi⊕xj
(Table 4) shows the degradation table of the address generation function f(X1, X2) of six variables having the weight k=7. The degradation table of the function f^(Y1, X2), which is obtained by replacing the bound variable X1=(x1, x2, x3) to Y1 by the function as shown in the next formula (14) and hashed, is shown in (Table 5).
[Expression 27]
Y1=(y1,y2,y3)=(x1⊕x6,x2⊕x5,x3⊕x4) (14)
In the hashed function, the columns of the original function are replaced. Further, each row employs a different replacement method. In the original function, two non-zero elements exist in the columns of (x1, X2, x3)=(0, 0, 0), (0, 1, 0), (0, 0, 1). In contrast, in the function f^ (X1, X2) shown in (Table 5) after it is hashed, two non-zero elements exist only in the columns of (y1, y2, y3)=(0, 1, 0). The degradation table of the function f1^(Y1, X2), in which the non-zero element 4 that is larger one of the two non-zero elements is replaced with 0, is shown in (Table 6). Further, (Table 7) shows the degradation table of the function f2^(Y1, X2) which is to be realized by the LUT cascade 6′. In the example, only one non-zero element exists. The remaining functions are realized by the hash memory 3′ shown in (Table 8) and the auxiliary memory 4′ of (Table 9). Since the output h^(Y1) of the hash memory 3′ predicts the value of the function f1^ using only the value of (y1, y2, y3), there is a possibility that the value is different from f1^. Accordingly, whether or not the output is correct is checked using the auxiliary memory 4′ shown in (Table 9). The function to be realized by the LUT cascade 6′ takes a non-zero output value 4. A combination in the input thereof is (x1, x2, x3, x4, x5, x6)=(0, 0, 1, 0, 1, 1).
Note that when a formula (8) is used as the hash function, the comparison potion of the output of the portion of X1 of the auxiliary memory 4′ and X1 in the comparison circuit 10 can be omitted. A reason is as shown below.
A function to be realized in the hash memory 3′ is h^(Y1). Although the value of the auxiliary memory 4′ is referred to by the output value, the elements of rows of the original address generation function f are replaced in the degradation table of the hashed address generation function f^. Accordingly, it is sufficient to examine the value of X2 to confirm that the output value of the hash memory 3′ is correct. That is, when the output value of the auxiliary memory 4′ coincides with the value of X2, it is guaranteed that the value of X1 is also in coincidence therewith from the relation of the formula (8). Accordingly, it can be found that the output of the hash memory 3′ is correct. Further, when they do not coincide with each other, the output value of the comparison circuit 10 is 0.
In, for example, the circuit of
[4] Ratio of Registered Vectors that can be Realized by Hash Memory
Next, to evaluate to what degree a circuit scale can be reduced in the address generator according to the present invention, the ratio of the registered vectors, which can be realized by the tentative address generator 3 (the hash memory 3′), is evaluated.
First, the following theorem is established as to the ratio of the registered vectors that can be realized by the tentative address generator 3.
[Theorem 4]
It is assumed that f is an n-input address generation function having the weight k and that non-zero elements are uniformly distributed in a degradation table. At the time, the ratio δ of the addresses that can be realized by the tentative address generator 3 in
k shows the total number of the non-zero elements in the degradation table. α=k/2n shows the ratio of the non-zero elements in the degradation table. β=1−α shows the ratio of the zero elements in the degradation table. r=n−p=|X2| shows the number of pieces of the free variables of the degradation table of f^(Y1, X2). At the time, a probability P0 that all the elements in a certain column become 0 and a probability P1 that at least one non-zero element is included in the elements of a certain column are shown by the following formulas (16) and (17).
[Expression 29]
P0=β2
P1=1−β2
2p pieces of columns exist as a whole, and the number of non-zero elements is k. As to a column in which two or more non-zero elements exist, when it is assumed that only one non-zero element is realized by the tentative address generator 3, the ratio δ of the addresses that can be expressed by the tentative address generator 3 is shown by a formula (18).
Further, s=n−q results in r−s=q−p from a relation r=n−p. Since s>r, the absolute values of the respective terms of the above formulas degrease as i increases. Next, when δ is approximated using up to a third term of the final formula on the right-hand side of the formula (18), it is shown by a formula (19).
When it is assumed, for example, k/2p=¼, δ≈0.8854. Further, in the region of ¼≦k/2p≦½, δ becomes a monotone decreasing function of k/2p.
A case of n=40, k=1730 will be examined. At the time, since Expression 32 is established, the number of pieces of the variables of the bound variable is set to p=13.
q=┌log2(k|1)┐=┌log2(1730|1)┐=11 [Expression 32]
(1) When Realized Only by LUT Cascade
When the number of inputs of cells is set to p=13, the number of stages of a cascade is as shown in Expression 33 from (Theorem 2).
The amount of a memory per cell is 2p×q=213×11 bits. Accordingly, the total amount of the memory is 213×11×15=1,351,680 bits.
(2) When Realized by Address Generator 1 of Present Invention
Since s=n−q=40−11=29, r=n−p=40−13=27, the assumption of the approximation of (Theorem 4) is established. Expression 34 is established from (Theorem 4).
The hash memory 3′ has p=13 input q=11 output, and the auxiliary memory 4′ has q=11 input n=40 output. The LUT cascade 6′ realizes an address generation function having a weight of 1730×(1−0.901)=170. At the time, the number of outputs of the cells of a LUT cascade is as shown in Expression 35.
┌log2(170+1)┐=8 [Expression 35]
When the number of inputs of the cells is 10, the number of stages of the LUT cascade to be realized is as shown in Expression 36.
The amount of the memory per cell in the stages other than a final stage is 210×8 bits at the highest. The amount of the memory of the cell of the final stage is 210×11 bits at the highest. The total amount of the memory of the cascade is 210×8×15+210°×11=134,144 bits. The capacity of the hash memory 3′ is 213×11=901112 bits. The capacity of the auxiliary memory 4′ is 211×40=81920 bits. Accordingly, the total amount of the memory is 306,176 bits.
Thus, in the example, when the address generator 1 of the present invention is used, the total amount of the memory is preferably more reduced than when the address generation function is arranged only by the LUT cascade.
As an example of application of the address generation circuit 1, a table of frequently-used English words will be examined. Here, three types of word tables (word table 1, word table 2, word table 3) were used as benchmarks. Although the number of characters of a word in the word notebook is 13 characters at the maximum, only initial eight characters are treated. Further, a word shorter than eight characters was made to eight characters by adding spaces to the end thereof. When each English character is expressed by five bits, each English word can be expressed by 40 bits. Further, the number of words in the word table 1, the word table 2, and the word table 3 is 1730 words, 3366 words, and 4705 words, respectively. In the respective tables, a unique index (natural number) is added to each word. At the time, the indexes of the words are 11 bits, 12 bits, and 13 bits, respectively.
Next, a hash function is generated. The number of inputs of the hash function is set to (the number of bits of the indexes of the word notebook)+2. In the word table 1, the number of the words is k=1730, the number of bits of the indexes is as shown in Expression 37, and the number of pieces of a bound variable is p=q+2=13.
[Expression 37]
q=┌log2(1+k)┐=┌log2(1+1730)┐=11 (21)
The number of pieces of the columns of a degradation table is 29=213=8192. The number of the columns including one non-zero element is 1389. The number of the columns including two or more non-zero elements is 165. The number of registered vectors that can not be realized by the hash memory 3′ is 176. That is, 90% of all the words can be realized by the hash memory 3′ and it is necessary to realize the remaining 10% by the LUT cascade. A result of the experiment is shown in (Table 10).
Next, a result of experiment when a similar address generation function is realized using a pseudo-random number (average of 100 pieces) is shown in (Table 11). In this case, the number of the columns including one non-zero element was 1398.4, the number of the columns including two or more non-zero element was 160.0, and the number of registered vectors that could be realized by the hash memory 3′ was 171.6. A similar experiment was performed also as to the word notebooks 2, 3.
A result of actual word tables, and a result as to the address generation function generated by the pseudo-random number were not greatly different from those theoretically determined by (Theorem 4). Accordingly, it can be found that the hash function generated using the (Algorithm 1) is effective as a function for distributing non-zero elements at random.
Further, a result of comparison of the necessary amount of a memory is shown in (Table 12). As apparent from (Table 12), the necessary total amount of the memory is greatly smaller than the case that the address generation function is realized by one LUT cascade.
[Embodiment 2]
In the embodiment, a case that two master address generators are used (super hybrid method) will be explained.
In comparison with
The master address generator 8 calculates a master address generation function f^1(Y1, X2) as to a partition (X1, X2) to an input vector X. Here, Y1 is a vector obtained by hashing X1 and calculated likewise the formula (8). Further, the master address generator 8′ calculates a master address generation function f^1′(Y1′, X2′) as to a partition (X1′, X2′) to an input vector X. Here, Y1′ is a vector obtained by hashing X1′ and calculated likewise the formula (8).
Here, the partition (X1, X2) is different from the partition (X1′, X2′). Specifically, it is sufficient to determine the optimum partition (X1′, X2′) by the following procedure.
(1) To an address generation function f:
(1-1) Variables are sequentially partitioned so that the number of inputs of a first hash memory is (q+1), the number of outputs thereof is q, the number of inputs of a first auxiliary memory is q, and the number of outputs thereof is (n−q−1); and
(1-2) A hash function is determined so that the non-zero elements of a degradation table are dispersed as much as possible. The function, which is expressed by a unique address realized by the configuration, is shown by f^11 (in a random function, about 80% of original unique addresses can be expressed).
(2) To the function, which is expressed by a unique address that is not realized by the above operation, that is, to f−f^11:
(2-1) Variables are sequentially partitioned so that the number of inputs of a second hash memory is (q−1), the number of outputs thereof is (q−2), the number of inputs of a second auxiliary memory is (q−2), and the number of outputs thereof is (n−q+2);
(2-2) A hash function is determined so that the non-zero elements in the degradation table are dispersed as much as possible, which the function that is expressed by a unique address realized by the configuration is shown by f^12 (in a random function, about 16% of the original unique addresses can be expressed); and
(3) The function, which is expressed by a unique address that is not realized by any of the operations, is realized by a method of a LUT cascade or a reconfigurable PLA, and the like.
As described above, since the two master address generators 8, 8′ are provided, the ratio of registered vectors whose unique addresses are determined by the master address generators 8, 8′ is more increased than the case of the embodiment 1. Accordingly, since the number of the registered vectors whose unique addresses are determined by a slave address generation function f^2(X1, X2) is reduced, the scale of the network of a slave address generator 6 (reconfigurable PLA 6″) can be reduced.
A case that an address generation function f(X) having the weight k=1730 and the number of variables of n=40 is realized using the address generator 1′ of
In this case, Expression 38 is established.
[Expression 38]
q−┌log2(k+1)┐−┌log2(1+1730)┐−11 (22)
[Reconfigurable PLA]
There are various methods as a method of realizing the reconfigurable PLA 6″. However, a register and gates approach, which uses a register for storing the values of the respective bits of an input vector and an AND gate, is employed here.
In the approach, words having any width can be arranged and they can be rearranged at a high speed. When the number of inputs is shown by n, the number of outputs is shown by q, and the weight of an address generation function to be realized is shown by k, the number of LE (Log Elements) which is necessary when the reconfigurable PLA 6″ of
In the example, the number of registered vectors to be realized in the reconfigurable PLA 6″ is 1730. Accordingly, the number of the LE, which is necessary to mount the reconfigurable PLA 6″, is 84, 478 from a formula (23).
[Hybrid Method]
The ratio δ of the addresses which can be expressed by the tentative address generator 3 is as shown in Expression 40 from a formula (19).
The number of inputs of the hash memory 3′ of
[Super Hybrid Method]
The ratio δ of the addresses, which can be expressed by the tentative address generator 3, is as shown by Expression 41 from the formula (19).
The number of inputs of the first hash memory 3′ of
The size of the first hash memory 3′ is 212×11=45,056 (bits), the size of the first auxiliary memory 4′ is 211×28=57,344 (bits), the size of the second hash memory 3′ is 210×9=9,216 (bits), and the size of the second auxiliary memory 4′ is 29×30=15,360 (bits). Accordingly, the total amount of the memory size is 126,976 (bits). The number of the registered vectors realized by the reconfigurable PLA 6″ is 43. Accordingly, in the example, the super hybrid method can more reduce the amount of hardware.
Number | Date | Country | Kind |
---|---|---|---|
2006-101104 | Mar 2006 | JP | national |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/JP2007/056497 | 3/27/2007 | WO | 00 | 5/20/2010 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2007/119539 | 10/25/2007 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
5063573 | Langewellpott | Nov 1991 | A |
6493793 | Pereira et al. | Dec 2002 | B1 |
20030093616 | Slavin | May 2003 | A1 |
Number | Date | Country |
---|---|---|
64-76320 | Mar 1989 | JP |
2003-389264 | Nov 2003 | JP |
2004-229163 | Aug 2004 | JP |
2004-258799 | Sep 2004 | JP |
2004-295967 | Oct 2004 | JP |
Number | Date | Country | |
---|---|---|---|
20100228947 A1 | Sep 2010 | US |