Content addressable memory (CAM) is a special type of memory that determines memory storage locations to associate with input data based upon the input data. A typical memory, such as a random access memory (RAM), is accessed based upon memory addresses. In contrast a CAM is accessed based upon content stored at one or more memory addresses. During a read operation of a typical memory, the memory receives an address value as an input and, in response, outputs a data value stored at a memory location corresponding to the received address value. A CAM operates in a different manner. During a read operation of a CAM, the CAM receives as input, content data that may be stored at some location in the CAM, and outputs an indication of whether that data value is present at a CAM address location. The content data received as input to a CAM during a read operation is commonly referred to as a search expression or as a key. During a typical CAM read operation, a CAM searches for stored entries in the CAM that match the key. A typical CAM can compare in parallel each of a plurality of content data values stored within the CAM with a key to determine whether there exists a stored content data value that matches the key and if so, output an indication of the match. Thus, a CAM accesses content (i.e., stored data values) by comparing content stored within the CAM with a key.
Applications of CAM include routing Internet packets, cache memory for microprocessors, and artificial intelligence to name a few examples. Many network devices (e.g., bridges, switches, routers, gateways, network proxies), for example, use a ternary CAM for routing operations. A ternary CAM (TCAM) is referred to as ternary because it can store data in any of three different states: logic 0, logic 1 and X. Data having an “X” or “don't care” state is of no relevance to a content search being conducted. Algorithmic RAM-based TCAM typically uses two-bit values stored in RAM to represent individual ternary states. In other words, each of TCAM logic 0, logic 1, and X often is represented in RAM-based TCAM as a different combination of two binary bits. TCAMs have suffered from large use of resources. There is a need to reduce resources required for TCAM.
In one aspect, a ternary content addressable memory is provided that includes an interface to receive a ternary key, an integrated circuit memory device that includes a plurality of memory address locations, and hash logic. The hash logic is operative to determine a hash value based upon a ternary key received at the interface, and the determined hash value corresponds to a memory address location of the memory device. An encoder logic is operable to convert the ternary key that includes at least five ternary value bits, to a binary bit representation. The encoder logic determines binary mapping bits based upon number and positions of ternary non-X (don't care) value bits of the ternary key. The encoder logic also determines a different binary data bit to correspond to each different ternary non-X value bit of the ternary key, wherein each determined binary data bit has a logic value that matches a logic value of the ternary value bit to which the determined binary data bit corresponds. Memory controller logic causes the memory device to store the binary bit representation at the memory address location that corresponds to the determined hash value.
In another aspect, a ternary content addressable memory is provided that includes an interface to receive a ternary keys and a memory device that includes a plurality of memory address locations. The memory device stores, at a first memory address location, an encoded key that includes three or more binary value mapping bits that indicate position and number of ternary non-X (don't care) value bits within a previous ternary key and that includes zero or more binary value data bits that each corresponds to and matches a logical value of a different ternary non-X value bit of the previous ternary value. Hash logic is operative to determine hash values based upon the received ternary keys, wherein the hash values correspond to memory address locations of the memory device. Memory controller logic is operative to cause the memory device to output the encoded key from the memory address location in response to a hash value determined based upon a later ternary key, on a condition that the determined hash value corresponds to the first memory location. A decoder is operable to determine correspondences between the non-X ternary value bits in the later ternary key and the binary value data bits in the outputted binary encoded key, based upon the binary value mapping bits in the binary encoded key. A comparator is operable to compare the non-X ternary value bits in the later ternary key with binary value data bits determined to correspond to the non-X ternary value bits in the later ternary key and to provide one or more comparator results.
In another aspect, a method is provided to control a ternary content addressable memory that includes a memory device that includes a plurality of memory address locations. A ternary key is received. A hash value is determined based upon the received ternary key. The determined hash value corresponds to a memory address location of the memory device. The received ternary key, which includes at least five ternary value bits, is converted to a binary bit representation. Converting includes determining binary mapping bits based upon number and positions of ternary non-X (don't care) value bits of the ternary key. Converting also includes determining a different binary data bit to correspond to each different ternary non-X value bit of the ternary key, wherein each determined binary data bit has a logic value that matches a logic value of the ternary value bit to which the determined binary data bit corresponds. The memory device is caused to store the binary bit representation at the memory address location that corresponds to the determined hash value.
In another aspect, a method is provided to control a ternary content addressable memory that includes a memory device that includes a plurality of memory address locations. An encoded key is stored at a first memory location. The encoded key includes three or more binary value mapping bits that indicate position and number of ternary non-X (don't care) value bits within a previous ternary key and includes zero or more binary value data bits that each corresponds to and matches a logical value of a different ternary non-X value bit of the previous ternary value. A hash value is determined based upon a later ternary key. The encoded key is output from the first memory address location in response to the determined hash value on a condition that the hash value corresponds to the first memory location. Correspondences between the non-X ternary value bits in the later ternary key and the binary value data bits in the outputted binary encoded key are determined based upon the binary value mapping bits in the binary encoded key. A determination is made as to whether the non-X ternary value bits in the later ternary key match binary value data bits determined to correspond to the non-X ternary value bits in the later ternary key.
In the drawings, which are not necessarily drawn to scale, like numerals may describe similar components in different views. Like numerals having different letter suffixes may represent different instances of similar components. Some embodiments are illustrated by way of example, and not limitation, in the figures of the accompanying drawings in which:
Overview:
An algorithmic ternary (3-state) content addressable memory (TCAM) encodes ternary keys for storage to and retrieval from a binary (2-bit state) memory device using fewer than two binary bits per ternary value bit. A ternary key includes a sequence of ternary bits. The algorithmic TCAM uses mapping bits to indicate ternary bit positions having X values, thereby eliminating the need to represent X values in an encoded binary representation. This approach reduces the number of 2-state binary bits required to represent a sequence of 3-state ternary bits.
Network Device:
The network device 100 includes a network processor device 110, which receives the packets or portions of packets on an input port or interface 120. The network processor 110 parses incoming packet information to identify relevant data fields that provide information for handling network operations, such as routing and forwarding. The network processor 110 can be coupled with a TCAM-based network rules search engine 140, hereinafter referred to as the “TCAM system” 140, which assists in determining appropriate actions to take in response to receipt of packets over a network. The network processor 110 extracts information from the packets, referred to as key information 160. The key information is used to identify rules that determine appropriate actions to take in response to the received packets. The key information represents data bits within a packet that indicate packet information such as network addresses or portions thereof, port numbers, other header and trailer information, or combinations thereof, for example. The network processor 110 can generate key information, also referred as a “keys”, that uses ternary value bits, which can have any of three states, logic 0, logic 1, or X (“don't care”), to represent the binary bits extracted from a packet. In general, ternary value bits within a key that have a logic value 0 or a logic value 1 contribute to identifying a rule that determines an action to take based upon a packet represented by the key, and ternary value bits within a key that have an X state do not contribute to identifying a rule that determines an action take based upon the packet represented by the key.
The network processor 110 sends ternary key information 160 to the TCAM system 140, which stores rules associated with such key information that indicate corresponding action to take. In response to receipt of key information 160 corresponding to a packet, the TCAM system 140 returns one or more corresponding rules 170 identified using the key information 160. The network processor 110 determines actions to take based on the returned one or more rule 170. Such actions can include outputting a packet on a selected output port or interface 130 or dropping a packet, as appropriate, for example. The TCAM system 140 includes one or more memory devices to store keys in association with corresponding rules 170. Matches between previously stored keys and keys provided by the network processor 110, in response to received packets, are searched to identify rules to use to route or switch the received packets.
TCAM System:
The hash logic 220 uses a mathematical hash function to determine hash values based upon one or more ternary bits within key values received at the interface 210. The determined hash values correspond to memory addresses in the memory devices 2301-23015. The hash logic 220 receives a key as input at interface 210, which can include a buffer (not shown) to temporarily store a received ternary key, and based upon the received key, generates a value referred to as a hash value or hash that is used to determine a common memory address location present within each of the memory devices 2301-23015. Hash functions are well known to persons of ordinary skill in the art.
More particularly, during a data write operation, the hash logic 220 receives a ternary key provided by the network processor 110 and uses a hash function to determine a hash value corresponding to the received key. The TCAM 200 includes memory controller logic circuitry 224 to manage the flow of data going to and from the memory devices 2300-23015. The memory controller logic 224 determines control signals to provide on storage control lines 226, based upon the hash values, to cause storing of encoded keys at memory address locations within the memory devices 2301-23015. The memory control logic 224 also can cause a rule, indicated by the network processor 110 as corresponding to a key, to be stored in the memory device in association with the key, at a memory address determined for the key as illustrated in
The encoder 222 encodes the key information from a ternary key representation to an encoded key representation that uses binary data bits suitable for storing within the memory devices 230. Table 1 shows ternary value bits of a key and corresponding binary data bit values used to represent the ternary value bits in a memory device 230.
It is noted that a one-bit ternary logic 0 value is mapped to a corresponding one-bit binary logic 0 value and that a one-bit ternary logic 0 value is mapped to a corresponding one-bit binary logic 1 value and that a ternary X state value is not mapped and is removed. Thus, instead of using two binary bits to represent each ternary bit, which is conventional, only one binary bit is used to represent each ternary bit. The encoder 222 compresses the key information by excluding X values from the encoded version of the key. The encoder 162 generates mapping bits, described below, to indicate correspondence between binary data bits within the encoded representation and ternary value bits within the ternary key from which the encoded key is derived.
During a read operation, the TCAM 200 receives a ternary key at the key interface 210. As explained above, a ternary key can correspond to relevant fields of a packet received over a network by a network processor 110 and can include logic zero (0) values, logic one (1) values, and don't care (X) values. For example, the key can include ternary value bits sequences that represent one or more of an internet protocol (IP) address, a socket number, a protocol, a multiprotocol label switching (MPLS) label, or virtual routing and forwarding (VRF) data. The hash logic 220 produces a hash value that correspond to the received key. The memory control logic 224 determines signals to provide on storage control lines 226, based upon the hash value, to cause one or more of the memory devices to output to their one or more associated buffers 240 an encoded key and an associated rule stored at the determined memory address at the one or more memory devices. Associated decoders 242 at one or more memory devices decode the encoded keys outputted at one or more of the memory devices to identify binary data bit values to be compared with corresponding bits of the received ternary key. Associated comparators 250 at one or more memory devices compare binary data bit values outputted at one or more of the memory devices with corresponding ternary value bits of the received ternary key to identify a match.
As explained below, the binary data bits can occupy different bit locations in different encoded keys. The binary data bits within any given encoded key are indicated by mapping bits within the encoded key. A comparator 250 produces a match indication signal at a corresponding line 260 based upon a comparison identifying a match between a stored encoded key value and a received ternary key. These comparison operations can be performed in parallel at different memory device modules 270, and match indication signals on lines 260 can indicate whether a match was found for the search key in one or more respective memory devices 2301-23015. In response to determining a match, a comparator causes 250 causes a rule associated with the matching key to be returned to the network processor 110 for use in taking a corresponding action.
Memory Device Module:
Decoder:
Comparator:
An example comparator 250 includes a multiplex selector circuit 726, five (5) two-bit comparator circuits C0, C1, C2, C3, and C4, and a NOR logic circuit 728. The multiplex circuit is coupled to receive the selection signal on line 724 and to receive five (5) ternary key values T0-T4 of a later received ternary key value 508 as ternary data inputs. The multiplexor 726 is configured to selectably provide individual ones of the ternary value bits T0-T4 on lines 730 to selectable ones of comparator circuits C1-5, based upon the selection signal on line 724. In an example comparator 250, it is contemplated that different ternary bits may be compared at different comparator circuits, based upon the identified mapping bits. The comparator circuits C0-C4 are coupled to receive binary data bits provided on lines 722 by the decoder 742 and to receive ternary data bits provided on lines 730 by the multiplexer 726. The comparator circuits C0-C4 are configured to respectively compare received binary data bits with received ternary value bits and to produce respective comparison result signals on lines 732. In an example comparator 250, the comparison circuits output a comparison value having a logic 0 value in response to a match between a received binary data value bit and a received ternary value bit. The NOR logic circuit 728 produces a match indication signal on line 260 indicating whether each of comparator circuits C0-C4 that performs a comparison, produces a comparison value that indicates a match. In an example comparator 250, it is contemplated that different combinations of comparator circuits may used perform comparisons for different E-keys, based upon the identified mapping bits.
Encoder:
Each different row of the encoding table represents logic circuitry to encode 5T sequences having ternary X's in different positions. Stated differently, each row represents encoding logic circuitry to encode a 5T sequence having a unique combination of number and position(s) of ternary X's.
Mapping bits are represented in Table 2 as binary values, 0 or 1. Binary data bit values are represented in Table 2 as b0, b1, b2, b3, and b4. Each binary data bit corresponds to a different ternary value bit. Binary data bit b0 corresponds to ternary value bit T0. If T0 is logic 0, then b0 in encoded in Table 2 as logic 0. If T0 is logic 1, then b0 is encoded in the Table 2 as logic 1. Binary data bits b1-b4 are similarly encoded. Binary data bit b1 corresponds to ternary value bit T1. Binary data bit b2 corresponds to ternary value bit T2. Binary data bit b3 corresponds to ternary value bit T3. Binary data bit b4 corresponds to ternary value bit T4.
Row 1 represents a 5T sequence with no ternary X's. Rows 2-6 represent 5T sequences with one ternary X. Rows 7-16 represent 5T sequences with two ternary X's. Rows 17-26 represent 5T sequences with three ternary X's. Rows 27-31 represent 5T sequences with three ternary X's. Row 32 represents a 5T sequence of all ternary X's.
The memory control logic 224 produces control signals on storage control lines 226 that cause storage of an encoded version of the received ternary key, which includes the determined mapping bits and the corresponding binary data bits, in a memory device 230 at an address location determined, based on a hash value, which is determined by the hash circuitry 220, based upon the received ternary key.
The example encoding Table 2 includes eight columns, numbered 1-8, and thirty-two rows, numbered 1-32. The Table 2 includes an additional two columns numbered 9-10 that provide annotations indicating whether particular binary data bits correspond to ternary 5T X's. The annotations are not part of the encoding.
Row 1 represents encoder logic to encode a 5T value on the condition that there are no X values in the 5T value being encoded. In row 1, three (3) mapping bits occupy columns 1-3 and five (5) binary data bits occupy columns 4-8, in row 1. Columns 4-8 of row 1 shows positions of binary data bits b0-b4 on the condition that there are no X values in the 5T value being encoded. It will be appreciated that in the example encoder 222 positions binary bits b0-b4 in an ordering that matches ordering of ternary value bits T0-T4 to which they correspond.
Rows 2-6 represent encoder logic to encode on a 5T value on the condition that there is one X value in a 5T value being encoded. Each different one of rows 2-6 represents the one X value being located at a different position in the 5T value. A different combination of four (4) mapping bits occupies each of columns 1-4 and a different combination of four (4) binary data bits occupies columns 5-8, in each of rows 2-6. Columns 5-8 of each of rows 2-6 shows a different possible combination of binary data bits corresponding to the non-X-valued ternary bits of a 5T value that has one X value. Referring to row 5, for example, it will be appreciated that in the example encoder 222 positions binary bits b0, b1, b2, and b4 in an ordering that matches ordering of ternary value bits T0, T1, T2, and T4 to which they correspond.
Rows 7-16 represent encoder logic to encode on a 5T value on the condition that there are two X values in a 5T value being encoded. Each different one of rows 7-16 represents the two X values being located at different positions in the 5T value. A different combination of five (5) mapping bits occupies each of columns 1-5 and a different combination of binary data bits occupies each of columns 6-8, in each of rows 7-16. Columns 6-8 of each of rows 7-16 shows a different possible combination of binary data bits corresponding to the non-X-valued ternary bits of a 5T value that has two X values.
Rows 17-26 represent encoder logic to encode on a 5T value on the condition that there are three X values in a 5T value being encoded. Each different one of rows 17-26 represents the three X values being located at different positions in the 5T value. A different combination of six (6) mapping bits occupies each of columns 1-6 and a different combination of two (2) binary data bits occupies columns 7-8, in each of rows 17-26. Columns 6-8 of each of rows 17-26 shows a different possible combination of binary data bits corresponding to the non-X-valued ternary bits of a 5T value that has three X values.
Rows 27-31 represent encoder logic to encode on a 5T value on the condition that there are four X values in a 5T value being encoded. Each different one of rows 27-31 represents the four X values being located at different positions in the 5T value. A different combination of six (6) mapping bits occupies each of columns 1-6, and a different one (1) of binary data bit occupies column 7, in each of rows 27-31. Column 7 of each of rows 27-31 shows a different possible binary data bit corresponding to non-X-valued ternary bits of a 5T value that has four X values.
Example Encodings Based Upon the Example First Encoder:
If “No X” and 5T=10111, then the encoding is 00010111
If “One X” and 5T=10111 and T0 is X, then the encoding is 00100111
If “Two X's” and 5T=01001 and T1 and T3 are X, then the encoding is 10011001
If “Four X's” and 5T=10101 and T3 is not X, then the encoding is 111101X
Example 5T-to-Binary Encoder with 256 Binary States: Row 32 represent encoder logic to encode on a 5T value on the condition that all 5T values are X values in a 5T value being encoded. A combination of six (6) mapping bits occupies columns 1-6, and no binary data values occupy either of rows columns 7-8 in row 32.
Row 1 of the example encoder logic table represents thirty-two possible 5T value states since the five data bits represented in the first row can have 25=32 possible states.
Rows 2-6 of the example encoder logic table represent eighty possible states. Each of the rows 2-6 can have 24=16 states, and 16*5=80.
Rows 7-16 represent eighty possible states. Each of rows 7-16 can have 23=8 possible states, and 8*10=80.
Rows 17-26 represent forty possible states. Each of rows 17-26 can have 22=4 states, and 4*10=40.
Rows 27-31 represent twenty possible states. Each of the five rows 27-31 can have four states. The one binary data bit in each row can has two possible states and the one X value in each row can have any of two states, and 4*5=20.
Row 32 represents four possible states. Each of the two X values in row 32 has two possible states, which results in 4 possible states for row 32.
Thus, the encoder logic encodes 32+80+80+40+20+4=256 possible states.
Example 5T-to-Binary Encoder with 243 Binary States:
A second example encoder logic (not shown), which encodes only 243 states, can be used to encode a 5T value to eight encoding bits.
The second encoder logic is summarized as follows.
On a condition that a 5T value to be encoded has no X values, use three mapping bits and five binary data bits, which provides 32 possible states all together.
On a condition that a 5T value to be encoded has one X value, use four mapping bits and four binary data bits, which provides 5*16=80 possible states all together.
On a condition that a 5T value to be encoded has two X values, use five mapping bits and three binary data bits, which provides 10*8=80 possible states all together.
On a condition that a 5T value to be encoded has three X values, use six control bits and two binary data bits, which provides 10*4=40 possible states all together.
On a condition that a 5T value to be encoded has four X values, use seven control bits and one binary data bit, which provides 5*2=10 possible states all together.
On a condition that a 5T value to be encoded has five X values, use eight mapping bits, which provides one possible state.
Thus, the second encoder logic provides 32+80+80+40+10+1=243 states, which exactly matches the number of possible states of a 5T value.
The second encoder logic is more efficient than the first encoding logic in the sense that the second encoder logic encodes a smaller number of states that exactly matches the number of states required to represent all possible 35=243 combinations of 5T sequences. However, the second encoder logic is less efficient in terms of hardware and/or computing resources since the second example encoder logic requires a total of eight mapping bits whereas the first example encoder, illustrated with reference to Table 2, requires only six mapping bits.
The above description is presented to enable any person skilled in the art to make and use an algorithmic ternary content addressable memory with compressed key encoding. Various modifications to the examples will be readily apparent to those skilled in the art, and the generic principles defined herein may be applied to other embodiments and applications without departing from the spirit and scope of the invention. In the preceding description, numerous details are set forth for the purpose of explanation. However, one of ordinary skill in the art will realize that the invention might be practiced without the use of these specific details. In other instances, well-known processes are shown in block diagram form in order not to obscure the description of the invention with unnecessary detail. Identical reference numerals may be used to represent different views of the same or similar item in different drawings. Thus, the foregoing description and drawings of embodiments in accordance with the present invention are merely illustrative of the principles of the invention. Therefore, it will be understood that various modifications can be made to the embodiments by those skilled in the art without departing from the spirit and scope of the invention, which is defined in the appended claims.
This application claims priority to U.S. provisional application Ser. No. 63/168,921, filed Mar. 31, 2021, entitled, ALGORITHMIC TERNARY CONTENT ADDRESSABLE MEMORY, which is incorporated herein in its entirety by this reference.
Number | Name | Date | Kind |
---|---|---|---|
7643353 | Srinivasan et al. | Jan 2010 | B1 |
8195873 | Gazit | Jun 2012 | B2 |
9094307 | Edsall | Jul 2015 | B1 |
9262312 | Gazit | Feb 2016 | B1 |
9306851 | Gazit | Apr 2016 | B1 |
9639501 | Gazit | May 2017 | B1 |
10254968 | Gazit et al. | Apr 2019 | B1 |
10318587 | Bosshart et al. | Jun 2019 | B1 |
10778721 | Holbrook et al. | Sep 2020 | B1 |
10887233 | Labonte et al. | Jan 2021 | B2 |
20090190404 | Roohparvar | Jul 2009 | A1 |
20130242632 | Wada | Sep 2013 | A1 |
20150006808 | Miller et al. | Jan 2015 | A1 |
20150169467 | Chase et al. | Jun 2015 | A1 |
20170040059 | Arsovski | Feb 2017 | A1 |
20180039662 | Asai | Feb 2018 | A1 |
Number | Date | Country |
---|---|---|
WO-98007160 | Feb 1998 | WO |
WO-2007038805 | Apr 2007 | WO |
Entry |
---|
RETCAM: An Efficient TCAM Compression Model for Flow Table of OpenFlow by Zhang (Year: 2019). |
EE-TCAM: An Energy-Efficient SRAM-Based TCAM on FPGA by Ullah (Year: 2018). |
E-TCAM: An Efficient SRAM-Based Architecture for TCAM by Ullah (Year: 2014). |
A Novel Rule Mapping on TCAM for Power Efficient Packet Classification by Srinivasavarma (Year: 2019). |
Efficient Mapping of Range Classifier into Ternary-CAM by Liu (Year: 2002). |
Encoding Short Ranges in TCAM Without Expansion: Efficient Algorithm and Applications by Barr (Year: 2016). |
BitWeaving: A Non-Prefix Approach to Compressing Packet Classifiers in TCAMs by Meiners (Year: 2011). |
“U.S. Appl. No. 17/710,891, Ex Parte Quayle Action mailed Nov. 25, 2022”, 7 pgs. |
Demetriades, Socrates, et al., “An Efficient Hardware-basedMulti-hash Scheme for High Speed IP Lookup”, Department of Computer Science University of Pittsburg, (Jun. 2008), 8 pages. |
Meiners, Chad R., et al., “Algorithmic Approaches to Redesigning TCAM Based Systems”, Sigmetrics, '08IGMETRICS Jun. 2-6, 2008, Annapolis, Maryland, (Jun. 2008), 2 pgs. |
Pagiamtzis, Kostas, et al., “Content-Addressable Memcry (CAM) Circuits and Architectures: A Tutorial and Survey”, IEEE Journal of Solid-State Circuits, 41(3), (Mar. 2006), 16 pages. |
Ravikumar, V. C., et al., “TCAM Architecture for IP Lookup Using Prefix Properties”, Published by the IEEE Computer Society 0272-1732/04, (Mar.-Apr. 2004), 10 pages. |
Sheu, Jang-Ping, et al., “Efficient TCAM Rules Distribution Algorithms in Software-Defined Networking”, IEEE Transactions on Network and Service Management, 15(2), (Jun. 2018), 12 pages. |
Song, Yibo, et al., “A Low-power Content-Addressable Memory (CAM) Using Pipelined Search Scheme”, ICWET '10: Prcceedings of the International Conference and Workshop on Emerging Trends in Technology, (Dec. 2009), 6 pages. |
Trinh, Nguyen, et al., “Algorithmic TCAM on FPGA with data collision approach”, Indonesian Journal of Electrical Engineering and Computer Science, (Apr. 2021), 89-96. |
“U.S. Appl. No. 17/710,891, Response filed Jan. 18, 2023 to Ex Parte Quayle Action mailed Nov. 25, 2022”, 5 pgs. |
“U.S. Appl. No. 17/710,891, Notice of Allowance dated Feb. 8, 2023”, 8 pgs. |
“U.S. Appl. No. 17/710,629, Non Final Office Action dated May 24, 2023”, 10 pgs. |
“U.S. Appl. No. 17/710,891, Corrected Notice of Allowability dated May 17, 2023”, 2 pgs. |
Kyungbae, Park, “Resource-Efficient SRAM-Based Ternary Content Addressable Memory Ali Ahmed”, Sanghyeon Baeg IEEE Transactions on Very Large Scale Integration (VLSI) Systems Year: 2017 | vol. 25, Issue: 4 | Journal Article | Publisher: IEEE, (Jan. 1, 2017). |
Number | Date | Country | |
---|---|---|---|
63168921 | Mar 2021 | US |