emdl
Embedded and mobile deep learning research resources
view repo
Researches on deep neural networks with discrete parameters and their deployment in embedded systems have been active and promising topics. Although previous works have successfully reduced precision in inference, transferring both training and inference processes to low-bitwidth integers has not been demonstrated simultaneously. In this work, we develop a new method termed as "WAGE" to discretize both training and inference, where weights (W), activations (A), gradients (G) and errors (E) among layers are shifted and linearly constrained to low-bitwidth integers. To perform pure discrete dataflow for fixed-point devices, we further replace batch normalization by a constant scaling layer and simplify other components that are arduous for integer implementation. Improved accuracies can be obtained on multiple datasets, which indicates that WAGE somehow acts as a type of regularization. Empirically, we demonstrate the potential to deploy training in hardware systems such as integer-based deep learning accelerators and neuromorphic chips with comparable accuracy and higher energy efficiency, which is crucial to future AI applications in variable scenarios with transfer and continual learning demands.
READ FULL TEXT VIEW PDF
Performing the inference step of deep learning in resource constrained
e...
read it
The high computational and parameter complexity of neural networks makes...
read it
Artificial neural networks can be trained with relatively low-precision
...
read it
Deep Neural Networks (DNNs) have gained immense success in cognitive
app...
read it
Batch Normalization (BN) has been proven to be quite effective at
accele...
read it
Neuromorphic Multiply-And-Accumulate (MAC) circuits utilizing synaptic w...
read it
Binarized Neural Networks (BNNs) can significantly reduce the inference
...
read it
Embedded and mobile deep learning research resources
Code example for the ICLR 2018 oral paper
Recently deep neural networks (DNNs) are being widely used for numerous AI applications (Krizhevsky et al., 2012; Hinton et al., 2012; Silver et al., 2016)
. Depending on the massive tunable parameters, DNNs are considered to have powerful multi-level feature extraction and representation abilities. However, training DNNs needs energy-intensive devices such as GPU and CPU with high precision (float32) processing units and abundant memory, which has greatly challenged their extensive applications for portable devices. In addition, a state-of-art network often has far more weights and effective capacity to shatter all training samples
(Zhang et al., 2016), leading to overfitting easily.As a result, there is much interest in reducing the size of network during inference (Hubara et al., 2016; Rastegari et al., 2016; Li et al., 2016), as well as dedicated hardware for commercial solutions (Jouppi et al., 2017; Chen et al., 2017; Shi et al., 2015)
. Due to the accumulation in stochastic gradient descent (SGD) optimization, the precision demand for training is usually higher than inference
(Hubara et al., 2016; Li et al., 2017). Therefore, most of the existing techniques only focus on the deployment of a well-trained compressed network, while still keeping high precision and computational complexity during training. In this work, we address this problem as how to process both training and inference with low-bitwidth integers, which is essential for implementing DNNs in dedicated hardware. To this end, two fundamental issues are addressed for discretely training DNNs: i) how to quantize all the operands and operations, and ii) how many bits or states are needed for SGD computation and accumulation.With respect to the issues, we propose a framework termed as “WAGE” that constrains weights (W), activations (A), gradients (G) and errors (E) among all layers to low-bitwidth integers in both training and inference. Firstly, for operands, linear mapping and orientation-preserved shifting are applied to achieve ternary weights, 8-bit integers for activations and gradients accumulation. Secondly, for operations, batch normalization (Ioffe & Szegedy, 2015) is replaced by a constant scaling factor. Other techniques for fine-tuning such as SGD optimizer with momentum and L2 regularization are simplified or abandoned with little performance degradation. Considering the overall bidirectional propagation, we completely streamline inference into accumulate-compare cycles and training into low-bitwidth multiply-accumulate (MAC) cycles with alignment operations, respectively.
We heuristically explore the bitwidth requirements of integers for error computation and gradient accumulation, which have rarely been discussed in previous works. Experiments indicate that it is the relative values (orientations) rather than absolute values (orders of magnitude) in error that guides previous layers to converge. Moreover, small values have negligible effects on previous orientations though propagated layer by layer, which can be partially discarded in quantization. We leverage these phenomena and use an orientation-preserved shifting operation to constrain errors. As for the gradient accumulation, though weights are quantized to ternary values in inference, a relatively higher bitwidth is indispensable to store and accumulate gradient updates.
The proposed framework is evaluated on MNIST, CIFAR10, SVHN, ImageNet datasets. Comparing to those who only discretize weights and activations at inference time, it has comparable accuracy and can further alleviate overfitting, indicating some type of regularization. WAGE produces pure bidirectional low-precision integer dataflow for DNNs, which can be applied for training and inference in dedicated hardware neatly. We publish the code on GitHub
^{1}^{1}1https://github.com/boluoweifenda/WAGE.We mainly focus on reducing precision of operands and operations in both training and inference. Orthogonal and complementary techniques for reducing complexity like network compression, pruning (Han et al., 2015; Zhou et al., 2017) and compact architectures (Howard et al., 2017) are impressively efficient but outside the scope this paper.
Weight and activation Courbariaux et al. (2015); Hubara et al. (2016)
propose methods to train DNNs with binary weights (BC) and activations (BNN) successively. They add noises to weights and activations as a form of regularization but real-valued gradients are accumulated in real-valued variables, suggesting that high precision accumulation is likely required for SGD optimization. XNOR-Net
(Rastegari et al., 2016) has a filter-wise scaling factor for weights to improve the performance. Convolutions in XNOR-Net can be implemented efficiently using XNOR logical units and bit-count operations. However, these floating-point factors are calculated simultaneously during training, which generally aggravates the training effort. In TWN (Li et al., 2016) and TTQ (Zhu et al., 2016) two symmetric thresholds are introduced to constrain the weights to be ternary-valued: . They claimed a tradeoff between model complexity and expressive ability.Gradient computation and accumulation DoReFa-Net (Zhou et al., 2016) quantizes gradients to low-bitwidth floating-point numbers with discrete states in the backward pass. TernGrad (Wen et al., 2017) quantizes gradient updates to ternary values to reduce the overhead of gradient synchronization in distributed training. Nevertheless, weights in DoReFa-Net and TernGrad are stored and updated with float32 during training like previous works. Besides, the quantization of batch normalization and its derivative is ignored. Thus, the overall computation graph for the training process is still presented with float32 and more complex with external quantization. Generally, it is difficult to apply DoReFa-Net training in an integer-based hardware directly, but it shows potential for exploring high-dimensional discrete spaces with discrete gradient descent directions.
The main idea of WAGE quantization is to constrain four operands to low-bitwidth integers: weight and activation in inference, error and gradient
in backpropagation training, see Figure
1. We extend the original definition of errors to multi-layer: error is the gradient of activation for the perspective of each convolution or fully-connected layer, while gradient particularly refers to the gradient accumulation of weight . Considering the -th layer of a feed-forward network, we have:(1) |
where
is the loss function. We separate these two terms that are mixed up in most existing schemes. The gradient of weight
and the gradient of activation flow to different paths in each layer, which is a fork both in inference and in backward training and generally acts as node of MAC operations.For the forward propagation in the -th layer, assuming that weights are stored and accumulated with -bit integers, then numerous works strive for a better quantization function that maps higher precision weights to their -bit reflections, for example, to . Although weights are accumulated with high precision like float32, the deployment of the reflections in dedicated hardware are much more memory efficient after training. Activations are quantized with function to bits to align the increased bitwidth caused by MACs. Weights and activations are discretized to even binary values in previous works, then MACs degrade into logical and bit-count operations that are extremely efficient (Rastegari et al., 2016).
For the backward propagation in the -th layer, the gradients of activations and weights are calculated by the derivatives of MACs that are generally considered to be in 16-bit floating-point precision at least. As illustrated in Figure 1, the MACs between -bit inputs and -bit weights will increase the bitwidth of outputs to in signed integer representation, and the similar broadening happens to errors as well. In consideration of training with only low-bitwidth integers, we propose additional functions and to constrain bitwidth of and to bits and bits, respectively. In general, where there is a MAC operation, there are quantization operators named , , and in inference and backpropagation.
In WAGE quantization, we adopt a linear mapping with -bit integers for simplicity, where continuous and unbounded values are discretized with uniform distance :
(2) |
Then the basic quantization function that converts a floating-point number to its -bitwidth signed integer representation can be formulated as:
(3) |
where approximates continuous values to their nearest discrete states. is the saturation function that clips unbounded values to , where the negative maximum value is removed to maintain symmetry. For example, quantizes to . Equation 3 is merely used for simulation in floating-point hardware like GPU, whereas in a fixed-point device, quantization and saturation is satisfied automatically.
Before applying linear mapping in some operands (e.g., error), we introduce an additional monolithic scaling factor for shifting values distribution to an appropriate order of magnitude, otherwise values will be all saturated or cleared by Equation 3. The scaling factor is calculated by function and then divided in later steps:
(4) |
Finally, we propose stochastic rounding to substitute small and real-valued updates for gradient accumulation in training. Section 3.3.4 will detail the implementation of operator , where high bitwidth gradients are constrained to -bit integers stochastically by a 16-bit random number generator. Figure 2 summarizes quantization methods used in WAGE.
In previous works, weights are binarized directly by
function or ternarized by threshold parameters calculated during training. However, BNN fails to converge without batch normalization because weight values are rather big for a typical DNN. Batch normalization not only efficiently avoids the problem of exploding and vanishing gradients, but also alleviates the demand for proper initialization. However, normalizing outputs for each layer and computing their gradients are quite complex without floating point unit (FPU). Besides, the moving averages of batch outputs occupy external memory. BNN shows a shift-based variation of batch normalization but it is hard to transform all of the elements to the fixed-point representations. As a result, weights should be cautiously initialized in this work where batch normalization is simplified to a constant scaling layer. A modified initialization method based on MSRA (He et al., 2015) can be formulated as:(5) |
where is the layer fan-in number, and the original limit
in MSRA is calculated to keep same variance between inputs and outputs of the same layer theoretically. The additional limit
is a minimum value that the uniform distribution
should reach, and is a constant greater than to create overlaps between minimum step size and maximum value . In case of -bit linear mapping, if weightsare quantized directly with original limits, we will get all-zero tensors when bitwidth
is small enough, e.g., , or fan-in is wide enough, where initialized weights may never reach the minimum step presented by fixed-point integers. So ensures that weights can go beyond and quantized to non-zero values after when initialized randomly.The modified initialization in Equation 5 will amplify weights holistically and guarantee their proper distribution, then is quantized directly with Equation 3:
(6) |
It should be noted that the variance of weights is scaled compared to the original limit, which will cause exploding of network’s outputs. To alleviate the amplification effect, XNOR-Net proposed a filter-wise scaling factor calculated continuously with full precision. In consideration of integer implementation, we introduce a layer-wise shift-based scaling factor to attenuate the amplification effect:
(7) |
where is a pre-defined constant for each layer determined by the network structure. The modified initialization and attenuation factor together approximates floating-point weights to their integer representations, except that takes effect after activations to maintain precision of weights presented by -bit integers.
As stated above, the bitwidth of operands increases after MACs. Then a typical CNN is usually followed with pooling, normalization and activation. Average pooling is avoided because mean operations will increase precision demand. Besides, we hypothesize that batch outputs of each hidden layer approximately have zero-mean, then batch normalization degenerates into to a scaling layer where trainable and batch-calculated scaling parameters are replaced by mentioned in Equation 7. If activations are presented in bits, the overall quantization of activations can be formulated as:
(8) |
Errors
are calculated layer by layer using the chain rule during training. Although the computation graph of backpropagation is similar to the inference, the inputs are the gradients of
, which are relatively small compared to actual inputs for networks. More importantly, the errors are unbounded and might have significantly larger ranges than that of activations, e.g., . DoReFa-Net first applies an affine transform on to map them into , and then inverts the transform after quantization. Thus, the quantized are still presented as float32 numbers with discrete states and mostly small values.However, experiments uncover that it is the orientations rather than orders of magnitude in errors that guides previous layers to converge, then the inverse transformation after quantization in DoReFa-Net is no longer needed. The orientation-only preservation prompts us to propagate errors with integer thoroughly, where error distribution is firstly scaled into by dividing a shift factor as shown in Figure 2 and then quantized by :
(9) |
where extracts the layer-wise maximum absolute value among all elements in error , multi-channel for convolution and multi-sample for batch training. The quantization of error discards large proportion of values smaller than , we will discuss the influence on accuracy later.
Since we only preserve relative values of error after shifting, the gradient updates derived from MACs between backward errors and forward activations are shifted consequently. We first rescale gradients with another scaling factor and then bring in shift-based learning rate :
(10) |
where is an integer power of 2. The shifted gradients represent for minimum step numbers and directions for updating weights. If weights are stored with -bit numbers, the minimum step of modification will be for integers and for floating-point values, respectively. The implement of learning rate here is quite different from that in a vanilla DNN based on float32. In WAGE, there only remain directions for weights to change and the step sizes are integer multiples of minimum step . Shifted gradients may get greater than if is or bigger to accelerate training at the beginning, or smaller than during latter half of training when learning rate decay is usually applied. As illustrated in Figure 2, to substitute accumulation of small gradients in latter case, we separate into integer parts and decimal parts, then use a 16-bit random number generator to constrain high bitwidth to -bit integers stochastically:
(11) |
where (Zhou et al., 2016) stochastically samples decimal parts to either or . With proper setting of , quantization of gradients will restrict the minimum step size, which may avoid local minimum and overfitting. Furthermore, the gradients will be ternary values when is not greater than , which reduces communication costs for distributed training (Wen et al., 2017). At last, weights might exceed the range presented by -bit integers after updating with discrete increments . So function is indispensable to saturate and make sure there are only states for weights accumulation. In case of the -th iteration, we have:
(12) |
From the above, we have illustrated our quantization methods for weights, activations, gradients and errors. See Algorithm 1 for the detailed computation graph. There remain some issues to specify in an overall training process with only integers.
Gradient descent optimizer like Momentum, RMSProp and Adam contains at least one copy of gradient updates
or their moving average, doubling memory consumption for weights during training, which is partially equivalent to use bigger . Since the weight updates are quantized to integer multiple of and scaled by , we adopt pure mini-batch SGD without any form of momentum or adaptive learning rate to show the potential of reducing storage demands.Although L2 regularization works quite well for many large-scale DNNs where overfitting occurs commonly, WAGE removes small values in Equation 3 and introduces randomness in Equation 11, acting as certain types of regularization and can get comparable accuracy in later experiments. Thus, we remain L2 weight decay and dropout as supplementary regularization methods.
The Softmax layer and cross-entropy criterion are widely adopted in classification tasks but the calculation of can hardly be applied in low-bitwidth linear mapping occasions. For tasks with small number of categories, we avoid Softmax layer and apply mean-square-error criterion but omit mean operation to form a sum-square-error (SSE) criterion since shifted errors will get the same values in Equation 9.
In this section, we set W-A-G-E bits to 2-8-8-8 as default for all layers in a CNN or MLP. The bitwidth is for ternary weights, which implies that there are no multiplications during inference. Constant parameter is to make equal probabilities for ternary weights when initialized randomly. Activations and errors should be of the same bitwidth since computation graph of backpropagation is similar to inference and might be applied in the same partition of hardware or memristor array (Sheridan et al., 2017). Although XNOR-Net achieves 1-bit activations, reducing errors to 4 or less bits dramatically degenerates accuracies in our tests, so the bitwidth and
are increased to 8 simultaneously. Weights are stored with 8-bit integers during training and ternarized by two constant symmetrical thresholds during inference. We first build the computation graph for a vanilla network, then insert quantization nodes in forward propagation and override gradients in backward propagation for each layer on Tensorflow
(Abadi et al., 2016). Our method is evaluated on MNIST, SVHN, CIFAR10 and ILSVRC12 (Russakovsky et al., 2015) and Table 1 shows the comparison results.MNIST: A variation of LeNet-5 (LeCun et al., 1998) with 32C5-MP2-64C5-MP2-512FC-10SSE is adopted. The input grayscale images are regarded as activations and quantized by Equation 8 where equals to 1. The learning rate in WAGE remains as
for the whole 100 epochs. We report average accuracy of 10 runs on the test set.
SVHN & CIFAR10: We use a VGG-like network (Simonyan & Zisserman, 2014) with 2(128C3)-MP2-2(256C3)-MP2-2(512C3)-MP2-1024FC-10SSE. For CIFAR10 dataset, we follow the data augmentation in Lee et al. (2015)
for training: 4 pixels are padded on each side, and a 32
32 patch is randomly cropped from the padded image or its horizontal flip. For testing, only single view of the original 3232 image is evaluated. The model is trained with mini-batch size of 128 and totally 300 epochs. Learning rate is set to 8 and divided by 8 at epoch 200 and epoch 250. The original images are scaled and biased to the range of for 8-bit integer activation representation. As for SVHN dataset, we leave out randomly flip augmentation and reduce training epochs to 40 since it is a rather big dataset. The error rate is evaluated in the same way as MNIST.ImageNet: WAGE framework is evaluated on ILSVRC12 dataset with AlexNet (Krizhevsky et al., 2012) model but removes dropout and local response normalization layers. Images are firstly resized to 256256 then randomly cropped to 224224 and horizontally flipped, followed by bias subtraction as CIFAR10. For testing, the single center crop in validation set is evaluated. Since ImageNet task is much difficult than CIFAR10 and has 1000 categories, it is hard to converge when applying SSE or hinge loss criterion in WAGE, so we add Softmax and remove quantizations in the last layer for fear of severe accuracy drop (Tang et al., 2017). The model is trained with mini-batch size of 256 and totally 70 epochs. Learning rate is set to 4 and divided by 8 at epoch 60 and epoch 65.
Method | Opt | BN | MNIST | SVHN | CIFAR10 | ImageNet | ||||
---|---|---|---|---|---|---|---|---|---|---|
BC | 1 | 32 | 32 | 32 | Adam | 1.29 | 2.30 | 9.90 | - | |
BNN | 1 | 1 | 32 | 32 | Adam | 0.96 | 2.53 | 10.15 | - | |
BWN^{1}^{1}1BWN is the counterpart of XNOR that only quantizes weights | 1 | 32 | 32 | 32 | withM | - | - | - | 43.2/20.6 | |
XNOR | 1 | 1 | 32 | 32 | Adam | - | - | - | 55.8/30.8 | |
TWN | 2 | 32 | 32 | 32 | withM | 0.65 | - | 7.44 | 34.7/13.8 | |
TTQ | 2 | 32 | 32 | 32 | Adam | - | - | 6.44 | 42.5/20.3 | |
DoReFa^{2}^{2}2They use floating-point presentation for errors | 8 | 8 | 32 | 8 | Adam | - | 2.30 | - | 47.0/ - | |
TernGrad^{3}^{3}3Only for worker-to-server communication in distributed training, weights are accumulated with float32 | 32 | 32 | 2 | 32 | Adam | - | - | 14.36 | 42.4/19.5 | |
WAGE | 2 | 8 | 8 | 8 | SGD | 0.40 | 1.92 | 6.78 | 51.6/27.8 |
We further compare WAGE variations and a vanilla CNN on CIFAR10. The vanilla CNN has the same VGG-like architecture described above except that none quantization of any operand or operation is applied. We add batch normalization in each layer and Softmax for the last layer, replace SSE with cross-entropy criterion, and then use a L2 weight decay of 1e-4 and momentum of for training. The learning rate is set to 0.1 and divided by 10 at epoch 200 and epoch 250. For variations of WAGE, pattern 28ff has no quantization nodes in backpropagation. Although the 28ff pattern has the same optimizer and learning rate annealing method as the vanilla pattern, we find that weight updates are decreased by the rescale factor in Equation 7. Therefore, the learning rate for 28ff is amplified and tuned, which reduces the error rate by 3%. Figure 3 shows the training curves of three counterparts. It can be seen that the 2888 pattern has comparable convergence rate to the vanilla CNN, better accuracy than those who only discretize weights and activations in inference time, though slightly more volatile. The discretization of backpropagation somehow acts as another type of regularization and have significant error rate drop when decreasing learning rate .
The bitwidth is set to 8 as default in previous experiments. To further explore a proper bitwidth and its truncated boundary, we firstly export errors from vanilla CNN for CIFAR10 after 100 training epochs. The histogram of errors in the last convolution layer among 128 mini-batch data is shown in Figure 4
. It is obvious that errors approximately obey logarithmic normal distribution where values are relatively small and have significantly large range. When quantized with
-bit integers, a proper window function should be chosen to truncate the distribution while retaining the approximate orientations for backpropagation. For more details about the layerwise histograms of all W, A, G, E operands, see Figure 5.Firstly, the upper (right) boundary is immobilized to the maximum absolute value among all elements in errors as described in Equation 9. Then the left boundary will be based on the bitwidth . We conduct a series of experiments for ranging from 4 to 15. The boxplot in Figure 4 indicates that 4-8 bits of errors represented by integers are enough for CIFAR10 classification task. Bitwidth 8 is chosen as default to match the 8-bit image color levels and most operands in the micro control unit (MCU). The histogram of errors in the same layer of WAGE-2888 shows that after being shifted and quantized layer by layer, the distribution of errors reshapes and mostly aggregates into truncated window. Thus, most information for orientations is retained. Besides, the smaller values in errors have negligible effects on previous orientations though accumulated layer by layer, which are partially discarded in quantization.
Since the width of the window has been optimized, we left-shift the window with factor to explore its horizontal position. The right boundary can be formulated as . Table 2 shows the effect of shifting errors: although large values are in the minority, they play critical roles for backpropagation training while the majority with small values actually act as noises.
1 | 2 | 4 | 8 | |
---|---|---|---|---|
error | 6.78 | 7.31 | 8.08 | 16.92 |
The bitwidth is set to 8 as default in previous experiments. Although weights are propagated with ternary values in inference and achieve compression rate than float32 weights, they are saved and accumulated in a relatively higher bitwidth (8 bits) for backpropagation training. Therefore, the overall compression rate is only . The inconsistent bitwidth between weight updates and their effects in inference provides indispensable buffer space. Otherwise, there might be too many weights changing their ternary values in each iteration, making training very slow and unstable. To further explore a proper bitwidth for gradients, we use WAGE 2-8-8-8 in CIFAR10 as baseline and range from 2 to 12, the learning rate is divided by 2 every time the decreases 1 bit to keep approximately equal weights accumulation in large number of iterations. Results from Table 3 show the effect of and indicate the similar bitwidth requirement as previous experiments for .
2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | |
---|---|---|---|---|---|---|---|---|---|---|---|
error | 54.22 | 51.57 | 28.22 | 18.01 | 11.48 | 7.61 | 6.78 | 6.63 | 6.43 | 6.55 | 6.57 |
For ImageNet implementation, we conduct six patterns to show bitwidth requirements: 2888 from Table 1, 288C for more accurate errors (12 bits), 28C8 for larger buffer space, 28f8 for none quantization of gradients, 28ff for errors and gradients in float32 as unlimited case and its BN counterpart. The accuracy of original AlexNet reproduction is reported as baseline. Learning rate is set to 64 and divided by 8 in 28C8 pattern, 0.01 and divided by 10 in 28f8, 28ff counterparts and vanilla AlexNet. We observe overfitting when increasing thus add L2 weight decay of 1e-4, 1e-4 and 5e-4 for 28f8, 28ff and 28ff-BN patterns, respectively. In table 4, the comparison between pattern 28C8 and 288C reveals that it might be more important to make more buffer space for gradient accumulation than to keep high-resolution orientation . Besides, when it comes to ImageNet dataset, the gradient accumulation, i.e., the bit width of gradients () and batch normalization become more important (Li et al., 2017) since samples in training set are so variant.
To avoid external memory consumption of full-precision weights during training, Deng et al. (2018) achieved 1-bit weights representation in both training and inference. They use a much larger mini-batch size of 1000 and float32 backpropagation dataflow to accumulate more precise weight updates, equally compensating the buffer space in WAGE provided by external bits of . However, large batch size will dramatically increase total training time, counteracting the speed benefits brought by integer arithmetic units. Besides, intermediate variables like feature maps often consume much more memory than weights and linearly correlated with mini-batch size. Therefore, we apply bigger for better convergence rate, accuracy and lower memory usage.
Pattern | Vanilla | 28ff-BN | 28ff | 28f8 | 28C8 | 288C | 2888 |
---|---|---|---|---|---|---|---|
error | 19.29 | 20.67 | 24.14 | 23.92 | 26.88 | 28.06 | 27.82 |
The goal of this work is to demonstrate potentials of applying training and inference with low-bitwidth integers in DNNs. Compared with FP16, 8-bit integer operations will not only reduce the energy and area costs for IC design (about , see Table 5), but also halve the memory accesses costs and memory size requirements during training, which will greatly benefit mobile devices with on-site learning capability. There are some points not involved in this work but yet to be improved or solved in future algorithm developments and hardware deployment.
MAC Operation: WAGE framework is mainly tested with 2-8-8-8 bitwidth configuration, which means that though there are no multiplications during inference with ternary weights, MACs are still needed to calculate in training. Possible solution is 2-2-8-8 pattern if we do not consider the matching of bitwidths between and . However, ternary will dramatically slow down convergence and hurt accuracy since has two relatively high thresholds and clear most outputs of each layer at the beginning of training, this phenomenon is also observed in our BNN replication.
Non-linear quantization: The linear mapping with uniform distance is adopted in WAGE for its simplicity. However, non-linear quantization method like logarithmic representation (Miyashita et al., 2016; Zhou et al., 2017) might be more efficient because the weights and activations in a trained network naturally have logarithmic normal distributions as shown in Figure 4. Besides, values in logarithmic representation have much larger range with fewer bits than fixed-point representation and are naturally encoded in digital hardware. It is promising to training DNNs with integers encoded with logarithmic representation.
Normalization: Normalization layers like Softmax and batch normalization are avoided or removed in some WAGE demonstrations. We think normalizations are essential for end-to-end multi-channel perception where sensors with different modalities have different input distributions, as well as cross-model features encoding and cognition where information from different branches gather to form higher-level representations. Therefore, a better way to quantize normalization is of great interest in further studies.
Operation | Energy(pJ) | Area(µ) | ||
---|---|---|---|---|
MUL | ADD | MUL | ADD | |
8-bit INT | 0.2 pJ | 0.03 pJ | 282 | 36 |
16-bit FP | 1.1 pJ | 0.40 pJ | 1640 | 1360 |
32-bit FP | 3.7 pJ | 0.90 pJ | 7700 | 4184 |
WAGE empowers pure low-bitwidth integer dataflow in DNNs for both training and inference. We introduce a new initialization method and a layer-wise constant scaling factor to replace batch normalization, which is a pain spot for network quantization. Many other components for training are also considered or simplified by alternative solutions. In addition, the bitwidth requirements for error computation and gradient accumulation are explored. Experiments reveal that we can quantize relative values of gradients, as well as discard the majority of small values and their orders of magnitude in backpropagation. Although the accumulation for weights updates are indispensable for stable convergence and final accuracy, there still remain works for compression and memory consumption can be further reduced in training. WAGE achieves state-of-art accuracies on multiple datasets with 2-8-8-8 bitwidth configuration. It is promising for incremental works via fine-tuning, more efficient mapping, quantization of batch normalization, etc. Overall, we introduce a framework without floating-point representation and demonstrate the potential to implement both discrete training and inference on integer-based lightweight ASIC or FPGA with on-site learning capability.
This work is partially supported by the Project of NSFC (61327902), the SuZhou-Tsinghua innovation leading program (2016SZ0102), the National Natural Science Foundation of China (61603209) and the Independent Research Plan of Tsinghua University (20151080467). We discuss a lot with Peng Jiao and Lei Deng, gratefully acknowledge for their thoughtful comments.
Tensorflow: A system for large-scale machine learning.
In OSDI, volume 16, pp. 265–283, 2016.Eyeriss: An energy-efficient reconfigurable accelerator for deep convolutional neural networks.
IEEE Journal of Solid-State Circuits, 52(1):127–138, 2017.Proceedings of the IEEE international conference on computer vision
, pp. 1026–1034, 2015.We assume that network structures are defined and initialized with Equation 5. The annotations after pseudo code are potential corresponding operations for implementation in a fixed-point dataflow.
Comments
There are no comments yet.