The present invention relates to associative computation generally and to data mining algorithms using associative computation in particular.
Applications often need to pick or retrieve several elected items, one by one, from a large dataset of items. A set of elected items may be created by one of the following ways: manually selected by a user; created by an algorithm; or a result of a search or any other procedure that produces a set of items needed by the application.
In the dataset, items belonging to the set are explicitly identified as being part of the set. The items in the set may be retrieved one after the other, such that, in each retrieve step, a single item from the set is retrieved. After its retrieval, the retrieved item may be removed from the set, so as not to be retrieved again. A method for choosing which item to retrieve in each specific step is referred herein as “item select”. It may be appreciated that the application may repeat the retrieve step until all items in the set have been retrieved and the set is emptied.
It is assumed that the order of retrieving items from the set has no implicit importance, as long as all the items in the set are eventually retrieved. The naive “item select” method may be used to select an item by its location in the dataset. In each retrieve operation, the entire dataset may be scanned, starting from the first item until an item belonging to the set is found. Once read, a “read” indication may be assigned to the read item, and the application may perform the next retrieve operation.
It may be appreciated that the complexity of a single retrieve operation that scans the entire dataset is O(N), where N is the size of the dataset, and the complexity of reading an entire set having P items is O(P*N).
There is provided, in accordance with a preferred embodiment of the present invention, an associative memory array. The associative memory array includes a plurality of associative memory cells arranged in rows and columns where each first cell in a first row and in a first column has access to a content of a second cell in a second row in an adjacent column.
Moreover, in accordance with a preferred embodiment of the present invention, the first row and the second row are the same row.
Additionally, in accordance with a preferred embodiment of the present invention, the associative memory array further includes for each column, a multiplexer unit to select either the adjacent column from the left of the first column or the adjacent column to the right of the first column.
Moreover, in accordance with a preferred embodiment of the present invention, the associative memory array further includes for each column, a logic unit to perform a Boolean operation between content read from a first column and content read from a second column.
Furthermore, in accordance with a preferred embodiment of the present invention, the associative memory array further includes circuitry to store a result of the Boolean operation in a cell in the first column.
The subject matter regarded as the invention is particularly pointed out and distinctly claimed in the concluding portion of the specification. The invention, however, both as to organization and method of operation, together with objects, features, and advantages thereof, may best be understood by reference to the following detailed description when read with the accompanying drawings in which:
It will be appreciated that for simplicity and clarity of illustration, elements shown in the figures have not necessarily been drawn to scale. For example, the dimensions of some of the elements may be exaggerated relative to other elements for clarity. Further, where considered appropriate, reference numerals may be repeated among the figures to indicate corresponding or analogous elements.
In the following detailed description, numerous specific details are set forth in order to provide a thorough understanding of the invention. However, it will be understood by those skilled in the art that the present invention may be practiced without these specific details. In other instances, well-known methods, procedures, and components have not been described in detail so as not to obscure the present invention.
Applicant has realized that selecting an item by scanning the entire dataset, starting from the first item all over again for each item in the set, is not efficient as the complexity is proportional to the dataset size. As the dataset grows, the average time to fetch or pick or select an item will increase, and the response time may worsen.
Applicant has further realized that associative memory devices may be used to store large datasets and may provide an efficient in-memory system that may perform the “item select” method in a constant computation complexity, O(1), regardless of the size of the dataset.
Memory devices that may provide such constant complexity are described in U.S. Pat. No. 8,238,173 (entitled “USING STORAGE CELLS TO PERFORM COMPUTATION”), issued on Aug. 7, 2012; U.S. Pat. No. 10,832,746, (entitled “NON-VOLATILE IN-MEMORY COMPUTING DEVICE”), issued on Nov. 10, 2020; U.S. Pat. No. 9,859,005 (entitled “MEMORY DEVICE”), issued on Jan. 2, 2018; U.S. Pat. No. 9,418,719 issued on Aug. 16, 2016 (entitled “IN-MEMORY COMPUTATIONAL DEVICE”) and U.S. Pat. No. 9,558,812 issued on Jan. 31, 2017 (entitled “SRAM MULTI-CELL OPERATIONS”), all assigned to the common assignee of the present invention and incorporated herein by reference.
Item selector 110 may select an item from the set according to one of the selection methods described hereinbelow. Item selector 110 further comprises a found and selected (FS) vector 112, an “extreme item selector” (EIS) 114 that selects an item having the highest/lowest index in the set, and a “next index selector” (NIS) 116 that selects a next item in a linked list of items, described in detail hereinbelow.
Item selector 110 may add an indication of the selected item to FS 112 that may be used to fetch or pick the selected item. Item selector 110 may remove the indication from FS 112 after the item is fetched. It may be appreciated that in each fetch operation, a single indication is present in FS vector 112. Item selector 110 may further remove the item from the set after it has been fetched.
Associative memory array 120 may be a memory device comprising numerous sections 122, constructed and operative in accordance with a preferred embodiment of the present invention and as shown in more detail in
Circuitry 200 comprises two elements: a multiplexer (mux) 260 and a logic unit 280 and wires. Wires of circuitry 200 provide connectivity between memory units 230 of column J and elements of circuitry 200. A wire 250-J may provide connectivity between memory units 230 of column J and logic 280. A wire 250-LJ may provide connectivity between memory units 230 of column-LJ and mux 260. A wire 250-RJ may provide connectivity between memory units 230 of column RJ and mux 260. It may be appreciated that a wire (250-LJ, 250-J, 250-RJ) between a column (LJ, J, RJ) and an element in circuitry 200 may read data 232 stored in any memory unit 230 in that column. Additionally or alternatively, wires 250-LJ, 250-J, and 250-RJ may provide the result of a Boolean operation performed between data 232 stored in several memory units 230 cells in column LJ, J, RJ respectively.
A wire 270 may provide connectivity between mux 260 and logic 280 and a wire 290 may provide connectivity between logic 280 and MU-J. Mux 260 may select to read data 232 from MU-LJ or from MU-RJ. Logic 280 may read data 232 from MU-J and may receive data from mux 260. Logic 280 may perform Boolean operations between data 232 read from MU-J and data received from mux 260. Logic 280 may write the outcome to a memory unit 230 of column J such as MU-J.
It may be appreciated that using circuitry 200, memory unit MU-J may replace its own stored data with data of an adjacent memory unit. Memory unit MU-J may alternatively perform a Boolean operation between its own stored data 232 and data from an adjacent memory unit and may replace its own data with the result of the executed Boolean operation.
It may be appreciated that similar circuitry may be associated with each column of each section 122 (of
As illustrated in
Item selector 110 may use any appropriate “item select” method. As described hereinabove, EIS 114 may select the item having the highest/lowest index in the set. and NIS 116 may select the next item in a linked list of items, starting with the first item in the list, provided that a linked list of the items in the set is built and is accessible in advance. Both EIS 114 and NIS 116 are described in detail hereinbelow.
In one embodiment, item selector 110 may choose to use a method according to the density of the Marker vector 330. As illustrated in
It may be appreciated that the density of the marker may be evaluated in any other way. When Marker vector 330 is sparse, as indicated in step 420, item selector 110 may use EIS 114, while when Marker vector 330 is dense, as indicated in step 430, item selector 110 may use NIS 116.
It may further be appreciated that item selector 110 may select EIS 114 or NIS 116 according to considerations, other than the density of Marker vector 330. Item selector 110 may use only EIS 114, only NIS 116 and any mixture of EIS 114 NIS 116.
EIS 114 may consider the index associated with a data item stored in the dataset, and the marker associated with the data item (both stored in the same column) as one composed value (CV) associated with the data item, where the marker bit is the most significant bit (MSB) of the composed value and the index provides the rest of the bits. Considering the CV this way, it is guaranteed that the elected items, marked with “1” in Marker vector 330, will have larger values than non-elected items, marked with “0”, as binary numbers having a 1 in their MSB are larger than binary numbers having a 0 in their MSB, and that a single item will eventually be picked since each item has a unique index therefore, the CV is unique, and there will be a single extreme CV.
It may be appreciated that EIS 114 may also consider the index and the inverse of the marker bit (NOT-marker) as the MSB of the CV, and find the lowest index in the set. Considering the CV this way, it is guaranteed that the elected items, marked with “1” in Marker vector 330 will have a 0 (NOT 1) as the MSB of their CV ensuring that they have smaller values than non-elected items, which have a 1 (NOT 0) in their MSB.
EIS 114 may utilize any search method to find a maximum or a minimum value between the CVs. It may be appreciated that U.S. patent application Ser. No. 14/594,434, incorporated by reference, may describe a method for finding a maximum value in a dataset, with constant computation complexity regardless of its size, and may be used by EIS 114.
In the example of
Using the method described in U.S. patent application Ser. No. 14/594,434, item selector 110 may find the largest number in CV 540. It may be appreciated that data item Data-14 is associated with 30 which is the largest value in CV 540. Item selector 110 may set the value of FS [14] as 1 in FS 112, as shown, and may then read the item associated with FS[14].
After reading/fetching the item, item selector 110 may zero Marker[14], the bit associated with the relevant read data item, essentially removing the read item from the set. After zeroing the marker bit, CV[14] may be recalculated and FS[14] may be zeroed. The original values are indicated by column 220A and the modified values are indicated by column 220B. Item selector 110 may now be ready for another operation of EIS 114.
It may be appreciated that these steps, of finding the largest value and nulling the entry in Marker vector 530, are repeated until there are no more marked objects in Marker vector 530, i.e. the set is empty.
As already mentioned hereinabove, when the number of items in the set is large, NIS 116 may be more efficient, as a linked list is built once, and once built, all relevant items may be directly accessed (instead of a maximum or a minimum search operation).
NIS 116 may create a linked list of indices of marked items by computing the “deltas” between the markers. A delta is the number of cells in the marker vector having a value of “0” between each two consecutive cells having a value of “1”. Each computed delta may be added to the index of the current elected item, to get the index of the next elected item.
In the example of
NIS 116 may first concurrently compute the deltas between markers in Marker vector 630 where the delta is the number of zeros between each two consecutive ones in Marker vector 630. The first item in the linked list may be the value of the first delta. In the example, the first marker bit is associated with the item whose index is 3, so the first value in List 650 (i.e. the value located in index 0) is 3 (List[0]=3). The next items in the List 650 may be computed by adding the delta (to the next marker) to the index of the current marked item, plus one which is the space occupied by the current marked item. The formula for computing the values of the items in List 650 is defined be Equation 1.
List[x]=Index[x]+Delta[x+1]+1 Equation 1
In the example, the next item in List 650 is List[3]. The value to store in List[3] is computed by adding the relevant value from Delta 640, Delta[3+1], which in this example is 1 and adding another 1, i.e. List[3]=3+1+1=5. Arrow 651 visually points to the column pointed by the first item in List 650. The next item in List 650 is stored in the location pointed by the previous item, i.e. in List[3]. Arrow 652 visually points to the item pointed by the List[3], and arrow 653 visually points to the next item in the list. It may be appreciated that the value of the last item in List 650 may be invalid as it may point outside the linked list. In the example, and as illustrated by arrow 654, the last bit set in Marker 630 is Marker[27], and it “points” to 29 which is outside the list. The detailed mechanism for building the linked list and for using it is described hereinbelow.
Step 730 describes how the delta is concurrently computed in the entire vector. The value Delta[i], in each location i of Delta 640, (i=0 . . . N, N is the size of the dataset) is incremented as long as there is a “0” in the same location in the temporary vector, i.e. in Temp[i]. In each iteration, the value in each cell i of Temp vector 635 may be calculated as the result of a Boolean OR of the value of cell i and the value of cell i+1, which is the next cell in the vector as defined in equation 2.
Temp[i]=Temp[i] OR Temp[i+1] Equation 2
It may be appreciated that the effect of the Boolean OR operation on the entries of Temp 635 is essentially to copy entries having the value “1” to the left at most K times. It may be appreciated that only the value 1 is copied to the left, while a value of 0 is not copied. As long as the value of an entry in Temp 635 is “0”, the value of Delta 640 is incremented. i.e. in each iteration, the value of each cell Delta[i] in Delta vector 640 may be calculated as Delta[i] plus the inverse of the value stored in the respective cell, Temp[i], in Temp 635, as defined by equation 3.
Delta[i]=Delta[i]+NOT(Temp[i]) Equation 3
The result is that, over the iterations, each Delta[i] will be incremented by 1 until Temp[i] becomes 1.
Delta1 illustrates the values of Delta 640 after the first iteration, Delta2 illustrates the value of Delta 640 after the next iteration and Deltak illustrates the value of Delta 640 after the last (Kth) iteration where value of each cell in Delta 640 is computed using equation 3. Note that, the value of a cell is increased and represents the number of zeroes encountered in Temp 635 in the past iterations for each i, and eventually the number of zeros between an item and the next marked item.
Returning to
It should be noted that K, the number of iterations, is selected without any connection to the actual deltas between markers in an actual marker vector. Thus, it is possible that there may be a delta which is larger than K. In this case, the large delta cannot be computed in only K iterations and thus, it will not be listed in List 650. Instead, List 650 may contain entries List[x] that are intermediate pointers that point to an unmarked item, i.e. the value of Marker[x] may be 0. Nevertheless, List[x] may point to another entry in List 650 that may eventually be associated with a marked entry.
Once List 650 is ready, it can be used for reading the items. The item fetching flow, implemented by NIS 116, is described in
It may be appreciated by the person skilled in the art that the steps shown in flow 700 and flow 1100 are not intended to be limiting and that both flows may be practiced with more or less steps, or with a different sequence of steps, or any combination thereof.
It may be appreciated that item select system 100 may reduce the computation time for fetching elected items from a database. The computation steps may be performed concurrently on all cells of the vectors Temp 635 and Delta 640. The abilities of the associative memory device, that is, concurrent Boolean operation on all columns and concurrent access to data stored in adjacent cells in the same row, may provide a computation complexity that does not depend on the vector size for both methods of item select. For a set of size P, the computation complexity of EIS 114 is O(P) and the computation complexity of NIS 116 is O(K).
While certain features of the invention have been illustrated and described herein, many modifications, substitutions, changes, and equivalents will now occur to those of ordinary skill in the art. It is, therefore, to be understood that the appended claims are intended to cover all such modifications and changes as fall within the true spirit of the invention.
This application is a divisional application of U.S. patent application Ser. No. 15/690,305, filed Aug. 30, 2017, which is incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
3851313 | Chang | Nov 1974 | A |
5295101 | Stephens, Jr. | Mar 1994 | A |
5452244 | Mohan Rao | Sep 1995 | A |
5506810 | Runas | Apr 1996 | A |
6278992 | Curtis | Aug 2001 | B1 |
6505225 | Takayanagi | Jan 2003 | B1 |
7822944 | Schuessler | Oct 2010 | B2 |
8238173 | Akerib | Aug 2012 | B2 |
8321485 | Yasuda | Nov 2012 | B2 |
9418719 | Akerib | Aug 2016 | B2 |
9558812 | Akerib | Jan 2017 | B2 |
9859005 | Akerib | Jan 2018 | B2 |
20020004862 | Horikomi | Jan 2002 | A1 |
20020122597 | Kikuchi | Sep 2002 | A1 |
20030135495 | Vagnozzi | Jul 2003 | A1 |
20050281562 | Pappalardo | Dec 2005 | A1 |
20070052736 | Inazumi | Mar 2007 | A1 |
20070174369 | Detlefs | Jul 2007 | A1 |
20080133565 | Yasuda | Jun 2008 | A1 |
20110153980 | Sasao | Jun 2011 | A1 |
20120096213 | Kato | Apr 2012 | A1 |
20120198174 | Nellans | Aug 2012 | A1 |
20130007419 | Bajenaru | Jan 2013 | A1 |
20130018856 | Pedersen | Jan 2013 | A1 |
20140129530 | Raufman | May 2014 | A1 |
20150131383 | Akerib | May 2015 | A1 |
20150146491 | Akerib | May 2015 | A1 |
20150200009 | Akerib | Jul 2015 | A1 |
20150370794 | Yochai | Dec 2015 | A1 |
20160378828 | Hopcroft | Dec 2016 | A1 |
20210056085 | Akerib | Feb 2021 | A1 |
20220138173 | Gaumnitz | May 2022 | A1 |
Number | Date | Country | |
---|---|---|---|
20210182289 A1 | Jun 2021 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 15690305 | Aug 2017 | US |
Child | 17189316 | US |