Aspects of the present disclosure generally relate to hardware and methods for improved implementation of multiplication and multiply-accumulate functions.
Current machine learning (ML), and especially neural network (NN) models, may include a combination of multiple layers with varying number of weights in each layer. Each layer may compute a number of multiply-accumulate (MAC) operations involving the stored weights as well as the input to each layer. While NNs have been very successful in classification tasks (inference), as the difficulty of tasks increase, larger networks with more layers and more weights per layer are needed. As the NN size increases the required memory for weights and the computational power needed to implement the network increases as well. In typical digital hardware implementations, the large number of weights cannot all be stored on the same application-specific integrated circuit (ASIC) that performs the MAC operations and significant data transfer with off-chip memory is required. Both the MAC operation, which consists of a number of multiplication and accumulate steps, and the data transfer can be costly in terms of time and energy.
In one or more illustrative examples, a multiply-accumulate successive approximation (MASAR) column is provided. The MASAR column includes a plurality of MASAR cells, each including a multiplier configured to perform digital multiplication between an input activation received to an input and an operand to compute a result, and a unit capacitor configured to store the result as analog charge. The MASAR column further digital logic configured to perform analog summation of the analog charge of the unit capacitors of the plurality of MASAR cells to determine a digital output of the multiplication by configuring the unit capacitors as a capacitive digital to analog converter (CDAC) in a successive approximation register (SAR) analog to digital converter (ADC).
In one or more illustrative examples, a MASAR column includes a plurality of MASAR cells, each including a multiplier configured to perform digital multiplication between an input activation received to an input and an operand to compute a result, a unit capacitor configured to store the result as analog charge, and a multiplexer (MUX) having at least first and second inputs and an output, wherein the MUX is configured to receive the result on the first input, to receive a bit-guess input from the digital logic on the second input, and to apply the output to the unit capacitor. The MASAR column further includes digital logic configured to utilize a successive approximation register (SAR) algorithm to perform analog summation of the analog charge of the unit capacitors of the plurality of MASAR cells to determine a digital output of the MAC, by controlling the individual MASAR cell unit capacitances via the bit-guess input to form a capacitive digital to analog converter (CDAC). The MASAR column further includes a comparator having a comparator input and a comparator output, wherein each of the unit capacitors is connected to the comparator input via a common bit line, and the digital logic is configured to receive the comparator output, wherein the common bit line is connected to a RESET switch controllable by a RESET line. The MUX is further configured to be controlled by an enable MAC control line to select between (i) storing the result to the unit capacitor and (ii) utilizing the unit capacitor to determine the analog summation of the charge. The RESET switch is further configured to be controlled to select between (i) connecting the common bit line to a reference voltage, and (ii) disconnecting the common bit line from the reference voltage.
In one or more illustrative examples, a method of performing multiplication and multiply-accumulate functions using a plurality of MASAR cells and digital logic includes performing digital multiplication, utilizing multipliers of each of the plurality of MASAR cells, between an input activation received to an input of the respective MASAR cell and an operand to compute a result; storing the result of the digital multiplication as analog charge in unit capacitors of the respective MASAR cells; and performing analog summation of the analog charge of the unit capacitors of the plurality of MASAR cells, under control of digital logic, to determine a digital output of the multiplication by configuring the unit capacitors as a capacitive digital to analog converter (CDAC) in a successive approximation register (SAR) analog to digital converter (ADC).
In one or more illustrative examples, a MASAR array for performing a plurality of parallel MAC calculations is provided. The MASAR array includes a plurality of MASAR columns, each MASAR column including a plurality of MASAR cells, each of the MASAR cells including a multiplier configured to perform digital multiplication between an input activation received to an input and an operand to compute a result, and a unit capacitor configured to store the result as analog charge. The MASAR array further includes global digital logic configured to control analog summation of the analog charge of the unit capacitors of the plurality of MASAR cells to determine a digital output of the multiplication.
In one or more illustrative examples, a parallel multi-bit MASAR architecture for performing multi-bit multiplication is provided. The parallel architecture includes a two-dimensional array of MASAR cells, configured to collectively multiply each digit of a multi-bit input activation by each digit of a multi-bit operand, the MASAR cells being arranged into MASAR columns by bit significance, such that summation is performed in analog via charge summation for each column to determine a multi-bit digital output of the multiplication for each MASAR column. The parallel architecture further includes a plurality of scalars, each configured to digitally scale the multi-bit digital outputs of each MASAR column by the bit significance to produce scaled digital outputs. The parallel architecture further includes an adder configured to add the scaled digital outputs to produce a multi-bit digital result of the multiplication.
In one or more illustrative examples, a serial multi-bit MASAR architecture for performing multi-bit multiplication is provided. The serial architecture includes a single row of MASAR cells, configured to multiply a single bit of a multi-bit input activation by each digit of a multi-bit operand, the MASAR cells being arranged into MASAR columns by bit significance, such that summation is performed in analog via charge summation for each column to determine intermediate results of the multiplication for each single bit of the multi-bit input activation. The serial architecture further includes a plurality of scalars, each configured to digitally scale the intermediate results of each MASAR column by the bit significance to produce scaled digital outputs. The serial architecture further includes registers and an adder configured to add the scaled digital outputs to the registers. The serial architecture further includes control logic configured to iterate the single row of MASAR cells through each bit of the multi-bit input activation and to utilize the adder to sum a multi-bit digital result of the multiplication using the registers.
Embodiments of the present disclosure are described herein. It is to be understood, however, that the disclosed embodiments are merely examples and other embodiments can take various and alternative forms. The figures are not necessarily to scale; some features could be exaggerated or minimized to show details of particular components. Therefore, specific structural and functional details disclosed herein are not to be interpreted as limiting, but merely as a representative basis for teaching one skilled in the art to variously employ the embodiments. As those of ordinary skill in the art will understand, various features illustrated and described with reference to any one of the figures can be combined with features illustrated in one or more other figures to produce embodiments that are not explicitly illustrated or described. The combinations of features illustrated provide representative embodiments for typical applications. Various combinations and modifications of the features consistent with the teachings of this disclosure, however, could be desired for particular applications.
The computational workload of convolutional neural networks (CNNs) may be dominated by multiply and accumulate or MAC operations (also known as dot products). These operations are essentially sums of products between input activations, Ai and weights, Wij, of the CNNs. Hence there is interest in hardware (HW) based building blocks that can accelerate MAC operations while improving performance such as energy/MAC, Area/MAC and Clock cycles/MAC.
Aspects of the disclosure relate to a new building block for implementing MAC functions in HW using both digital and analog circuit techniques. These approaches may enable possible architectures going from a single multiplier to large scale MAC arrays that enable parallel multiply and accumulation of data and weights for artificial intelligence (AI)/ML applications. Such architectures may be adapted from 1 bit to multi bit (4 bit, 8 bit) computational precision of the weights and activations.
An array may be made up of modular processing elements or cells. These processing elements may be configured such that a column of cells can perform a digital input to digital output MAC computation without the need of an additional analog to digital converter (ADC). A column of such cells may perform a mixed signal MAC calculation which results in an analog charge proportional to the MAC computation result. The analog result is then converted to digital using the same column of cells configured as a SAR ADC. These cells may be referred to as MAC+SAR, or MASAR cells. The MASAR cells are the processing elements that enable all functions for MAC calculation and analog to digital conversion. Thus, the proposed approach uses the same processing element array for digital multiplication and charge summation as well as for the ADC conversion.
The MASAR modular processing elements may be used to implement multibit precision multiplications and MAC computations, which is useful for ML/AI HW acceleration. Each MASAR cell uses a unit capacitance to store the results of the 1-bit multiplications in charge. A column of MASAR cells can be used sum the 1-bit products in charge using charge redistribution. The column of MASAR cells also provide the ability to convert the charge to a digital value by configuring the column of MASAR cells into a SAR ADC. The SAR is used to convert the sum of products back to a digital representation. These new building blocks (MASAR cells) enable both MAC and SAR functions when used in columns (MASAR columns). MASAR columns can be placed in parallel to form MASAR arrays which can perform multibit precision MAC computations.
In a weights programming mode, weights wij may be applied to the digital inputs 106 of the MASAR cells 104. These weights may be stored in the MASAR cells 104 and used in a two-mode runtime approach to perform digital-in to digital-out MAC computations. Weights may be stored in each MASAR cell or only in some or not at all. In some examples, the weights may be stored outside of the MASAR columns. The weight programming mode may be specific to when the weights are stored in the MASAR columns or cells. In this case it may be advantageous to use the same inputs (e.g., wires) to the cells for programming weights and applying input activations. It should be noted that more than one weight may be stored in each MASAR cell in some examples (e.g., each MASAR cell may contain multiple memory cells), which may be advantageous for computation of ML algorithms.
This two-mode approach includes a MAC mode (multiply+charge summation) followed by a SAR mode (charge to digital). It should be noted that memory can be in every MASAR cell 104 or only certain rows in the MASAR column 102 may have memory. For cases where not all MASAR cells 104 have memory, there are different options for how memory can be distributed in a MASAR column 102. Some examples are discussed herein. Also programming of the memory can be do done in multiple ways. One way would be programming the weights wij one column j at a time. In this case a vector of weight wij may be applied to the inputs of the MASAR column 102. Other options may include to program one row i at a time, program individual MASAR cell 104 memories one at a time or multiple MASAR cell 104 memories all at once through an entire MASAR array.
In the MAC mode, input activations di, or input biases bi, may be applied to each of the cells. These values may be applied to the digital inputs 106. In a first aspect (MAC step 1), multiple 1-bit digital multiplications are performed digitally. In a second aspect (MAC step 2), the multiplication results are stored in charge. In a third aspect (MAC step3), the results of the multiplications are summed using charge sharing/redistribution on the MASAR column 102. The total charge stored on the MASAR column 102 as unit capacitances represents the analog value of the result of the MAC computation.
In the SAR mode, conversion of the charge back to digital is accomplished by configuring the unit capacitors of the MASAR cells 104 in the column as a capacitive digital to analog converter (CDAC) 115. The column is used with a single comparator to perform a successive approximation analog to digital conversion of the stored charge in the column. In the SAR mode, ADC guess bits BGi[0: N−1] may be utilized to facilitate the conversion back to digital.
The MASAR column 102 may produce digital outputs 108 representative of multiplication of the input i with the stored weights wij. These digital outputs 108 may provide a single bit B[N] result, or, in other examples, may include a full output B[0: N−1]. The MASAR columns 102 may further include a bit line driver 110, a zero input cell 112, a comparator 114, and digital logic 116. These components are discussed in further detail below.
The MASAR cell 104 can be configured to calculate a 1-bit multiplication between an input, (Ii=ai in MAC mode) and store it as a charge on the unit capacitor 206 as unit capacitance Cu. The output of the MASAR cell 104 may be provided to the BLj, as the jth bit line, for charge summation. By setting the EM signal, the unit capacitance may be stored to the capacitor 206, and by resetting the EM signal the capacitor 206 may be reset. Additionally, the EM signal may be used to select between MAC mode in which the capacitance is determined by the multiple, and the collective capacitive across MASAR cells 104 is measured in the SAR mode.
It should be noted that single bit computation does not require sign bits, as 1-bit or single bit multiplication does not include a sign. For signed integer multiplication a sign bit may be utilized. Note that a sign bit is not required in cases that do not use signed integer computation, such as binary coded decimal.
Table 1 illustrates a description of the signaling shown in
Table 2 illustrates values of the signaling with respect to the different modes and operations that are performed by the MASAR column 102 and MASAR cells 104.
Table 3 illustrates further definitions of terms with respect to the MASAR column 102.
Here, the MASAR column 102 is shown in the first portion of the MAC. In this first portion, all products, ai·wij, are being applied to the MASAR column 102 for computation by the multiplier 204. At this point, the ADC guess bits are set to zero (BG0=BG1=0). Additionally, the signal EM is set such that EM=1, EM=0, thereby forcing the products on the “cell” side of the unit capacitors 206. The signal RESET is set such that RESET=1, forcing the bit line side of the unit capacitors 206 to the reference voltage, Vs. Further aspects of the signaling of the MASAR column 102 are illustrated in Table 4.
Referring more specifically to the MAC step 1 aspect, the 1-bit products, ai·wij, are stored as a charge, Qi, (Eq. 1) on the unit capacitors 206 of the MASAR cell 104. Here, EM=1, EM=0. The charge is thereby stored by applying the product, ai·wij, to the “cell” side of each unit capacitor 206 or node Vxi in the cell. At the same time, the common side of the unit capacitors 206 or bit line is forced to the reference voltage, VS by setting RESET=1. Eq. 2 is the total charge, Qtot stored in the MASAR column 102 after MAC step 1.
Note that for this MASAR column 102 with 2N cells there is a maximum of Ny inputs where Ny=2N−1. One MASAR cell 104 (the zero input cell 112) has zero input and Ny cells have inputs. This is to ensure full analog to digital conversion of the MAC result on the MASAR column 102. The total capacitance, CTOT, of the MASAR column 102 is given in Eq. 3. It should again be noted that a zero input cell 112 is not needed if the MASAR column 102 is not performing a full resolution conversion, i.e., where the output of the MASAR column has less than log 2 (Ny) bits.
For this example, the bit line voltage is defined by Eq. 4 and input to the comparator 114 by Eq. 5. Finally, the comparator 114 computes Eq. 6. For purposes of showing how the SAR algorithm operation, the expected result of the MAC is defined by Eq. 7. In this case, the output of the MASAR column 102, for this example, is 2 or B[1]=1, B[0]=0.
Referring more specifically to the SAR conversion, The SAR conversion (SAR step 1) starts with the SAR logic guessing the most significant bit BG[1]=1, while keeping the least significant bit, BG[0]=0. This results in a comparator 114 input of zero, as shown in Eq., and a comparator 114 output of zero as shown in Eq. Here, the SAR logic assigns B[1]=1.
This portion of the SAR conversion starts with the SAR logic guessing the least significant bit, BG[0]=1. As the most significant bit, BG[1], has been already determined to be 1, that value is not changed. Setting BG[0]=1 results in a comparator 114 input that is greater than zero as shown in Eq. 10. Therefore, the comparator 114 output is one as shown in Eq. 11. The SAR logic assigns B[0]=0. This is the last portion of the SAR computation for this example. The final output of the MASAR column 102 is therefore B[1]=1, B[0]=0, which matches the expected MAC result of 2.
Thus, a simplified 4-cell MASAR column 102 (NBG=2,Ny=3) may accomplish a MAC computation and a SAR analog to digital conversion using the same capacitor 206 array. Note this was done for 1-bit computations which do not require a sign for each MAC product. However, this approach may be extended to signed operations for multibit MACs.
While the aforementioned example utilizes four cells, the MAC mode may be extended to a MASAR column 102 comprised of Nr rows. In this case a Nr row MASAR column 102 may perform Ny=Nr−1 one-bit MAC calculations. Thus, the maximum digital value of the MAC output for a MASAR column 102 using Nr−1 rows as inputs is BMAX, as shown in Eq. 12.
The total charge stored on the capacitance of the MASAR column 102 is given earlier by Eq. The bit line voltage (extending the example to the general case) is given by Eq. 13. For the general case the output of the jth MASAR column 102 is a digital output as given by Eq. 14.
As a variation, the addition of an input bias and calibration in MASAR columns 102 may be performed. In some cases, it may be of interest to add input biases, bj, to the MAC calculation. In this case the desired output of the MASAR column 102 is given by Eq. 15:
To add these biases Nb rows in the MASAR column 102 can be dedicated to the bias input. Since the number of inputs is fixed at Ny this reduces the number of possible input activations to Na=Ny−Nb. For instance, if it is desired to calibrate the SAR ADC, additional Nc rows may be dedicated to the addition of calibration of the ADC output. If desired, this may further reduce the quantity of inputs for the MAC, as shown in Eq. 16. It should be noted that while adding bias in MASAR cells 104 may be performed in some approaches, in other approaches the biases may be added to the outputs after the MASAR column 102. This may occur in the digital summation stages, for example (as shown in the FIGS. herein).
Similarly, while the aforementioned example utilizes four cells, the SAR mode may be extended to a MASAR column 102 comprised of Nr rows. Here, the ADC guess bits can be distributed to form an N bit CDAC 115.
Accordingly, a MASAR column 102 may be configured as an SAR ADC with a maximum ADC resolution or max number of bits, NBG=k (for 2's complement) and, NBG=k+1 for signed integer computation. While optional, it is assumed one row in all MASAR columns 102 is the row of zero input cells 112. Doing so ensures the SAR ADC including the rows of MASAR cells 104 can perform a full resolution conversion of the MAC result.
One key aspect of the SAR computation and MASAR concept is the routing of the ADC guess bits, BG[n], to the MASAR cells 104. An example MASAR column 102 may be used to demonstrate different options for setting the SAR ADC conversion resolution by changing how we configure the MASAR column 102 ADC guess bits.
It should be noted that these SAR ADC conversion modes assume MASAR columns 102 configured as a binary CDAC 115. In other words, the capacitors are sized such that they are binarily weighted, as shown in Eq. 17. The choice of binary weighting may dictate how the ADC guess bits are distributed to control the individual MASAR cells 104 in the previous sections. However, there are alternatives to binary weighting. For example, a SAR ADC may be developed with non-binary split-capacitor arrays, which can be implemented as well in the MASAR columns 102. Use of a MASAR column 102 for such applications may provide even more compact architectures and/or lower energy implementations as compared to other designs of SAR ADC.
For some applications, however, it may be desirable to utilize a subset of possible values that may be available through use of the MASAR column 102. For instance, in some cases less precision may be desired. In such a case the LSB may not be used. Or, in other cases conversion may be desired for a subset of ranges of the values, with values below the range of interest being set to a minimum and values above the range of interest begin set to a maximum. As discussed above abstractly with respect to
Referring more specifically to
Accordingly, the resultant mapping is from a low value of 28 to a high value of 28+7 or 35, based on the values of the 3 LSBs.
Accordingly, the resultant mapping is from a low value of 4 to a high value of 4+7=11, based on the values of the 3 LSBs.
Accordingly, the resultant mapping is from a low value of 24 to a high value of 24+14=46, with a step size of 2, based on the values of the 3 utilized bits (the 8-, 4- and 2-bits).
Thus, by configuring the mapping of the unit capacitors 206 to the SAR DAC, configurable output mappings of the and offset range of values may be performed. It should also be noted that the number of inputs is not limited to being need to 2N−1. Indeed, any number of inputs N>2M may be possible with approximate conversion.
Serial and parallel SAR architectures for the MASAR columns 102 and MASAR arrays 150 may be utilized.
For a serial SAR MASAR array 150 the MAC calculation occurs in parallel, however, the SAR ADC conversion of the MAC results occur in a serial fashion. The ADC conversion occurs in each MASAR column 102 one at a time. The advantage of this architecture is that the SAR logic can be global and does not need to be in each MASAR column 102. This results in an area savings for the MASAR array 150. The disadvantage is that throughput or the speed of the MAC calculation is reduced. However, for some applications the tradeoff between area and speed is advantageous.
Additionally, the global digital logic 154 may provide control signals for the different modes of the MASAR array 150. These modes are described in Table 2. For instance, the digital logic 116 may apply input activations, ai, to the row driver 152 in the MAC mode and weight values, wij, for programming the SRAM 202 weight memories in the weight programming mode.
The global digital logic 154 may be used to orchestrate top level functions of the parallel array, for providing control signals for the different modes of the MASAR array 150, as discussed in Table 2. For example, the global digital logic 154 may apply input activations, ai, to the row drivers 152 in the MAC mode, and may provide provides weight memory values, wij, for programming the SRAM 202 in the weight programming mode. The digital logic 116 may also controls the timing of the array signals.
Unlike the serial MASAR array 150, however, the global digital logic 154 in the parallel MASAR array 150 may not apply the ADC guess signals, BGj[0: NBG−1], to the row driver 152 during the SAR modes. Instead, this may be done by local SAR logic 156 in each MASAR column 102, which is routed through the MASAR column 102 to each MASAR cell 104.
Thus, MASAR columns 102 and MASAR arrays 150 which perform 1-bit MAC computations may be utilized in serial or parallel configurations. These computations may include a summation of products of 1-bit weights and activations. Additionally, MASAR columns 102 and MASAR arrays 150 may be used to perform multi-bit MAC computations. In such examples, the weights and activations can be >1-bit in precision.
Multibit digital multiplications may be decomposed into individual units, which may be implemented using MASAR columns 102. A product of Np bit precision weights and activations may accordingly be accomplished. An example of 4-bit signed integer (Np=4-bit) activations and weights is defined as shown in Eq. 19 and Eq. 20. The multibit activations and weights may be represented by single bits having different significance, l. For instance, Ai can be represented by the 1-bit values, au, and Wu by the 1-bit values wij. The most significant bits are the sign bits, ai3, wi3. These may be used to calculate the sign bit for the overall product, as given by Eq. 21. Note, for simplicity of notation, that the column index j for the weights is omitted in these examples.
Each cell in
The architecture shown in
While previous examples have been with Np=4-bit signed integers, this architecture can be scaled to precisions that are larger or smaller than 4-bits. This involves scaling the number of rows, Npr, and columns, Npc, of the product cells, as shown in Eq. 23 and Eq. 24.
The relationship between the total number of rows, Nr, in the MASAR column 102 the number of MACs, NM, and number of zero input rows, NZ, can be determined with Eq. and Eq.
It is assumed here the number of rows, Nr, must be a power of 2 to enable using of a binary weighted capacitor DAC in each MASAR column 102. To give an example let Nr=2k=256 (k=8) and Np=4 bits. In this case, Npr=3, Npc=5, NZ=1, and NM=85 can be calculated from the equations above. For this example, a 256-row by 5-column MASAR array 150 can compute 85 parallel MACs with 4-bit precision. Note zero input rows are added to insure there are 2k MASAR cells 104 in each MASAR column 102. This is required since each MASAR column 102 is also an k=8-bit SAR ADC. In another example, a 256-row by 13-column, 8-bit precision MASAR array 150 can compute NM=36 MACs. For the 8-bit case: Npr=7, Npc=13, and NZ=4.
While parallel multibit architectures improve speed of computation, serial architectures are more compact. In this section we describe how to decompose multibit digital multiplications into serial computations which enable smaller multibit MASAR array 150 accelerators.
Referring back to
The architecture shown in
It should also be noted that serial MASAR accelerators can be extended to higher or lower bit precision. For instance a Np=16-bit precision accelerator that calculates NM 16 bit MACs can be implemented with a 16 column by (NM+1) row serial MASAR accelerator.
It should be noted that while many of the examples above are discussed in terms of signed integer values, the MASAR columns 102 and MASAR arrays 150 may also be used to perform two's-complement computations. Like unsigned numbers, N-bit two's complement numbers represent one of 2N possible values, although with a different range. Thus, for two's complement computations, 2N rows may be used for an N-bit output. However, for signed values, 2N+1 rows may be required for an N-bit output to account for the sign.
While exemplary embodiments are described above, it is not intended that these embodiments describe all possible forms encompassed by the claims. The words used in the specification are words of description rather than limitation, and it is understood that various changes can be made without departing from the spirit and scope of the disclosure. As previously described, the features of various embodiments can be combined to form further embodiments of the disclosure that may not be explicitly described or illustrated. While various embodiments could have been described as providing advantages or being preferred over other embodiments or prior art implementations with respect to one or more desired characteristics, those of ordinary skill in the art recognize that one or more features or characteristics can be compromised to achieve desired overall system attributes, which depend on the specific application and implementation. These attributes can include, but are not limited to cost, strength, durability, life cycle cost, marketability, appearance, packaging, size, serviceability, weight, manufacturability, ease of assembly, etc. As such, to the extent any embodiments are described as less desirable than other embodiments or prior art implementations with respect to one or more characteristics, these embodiments are not outside the scope of the disclosure and can be desirable for particular applications.