The present disclosure describes embodiments generally related to neural network model compression/decompression.
The background description provided herein is for the purpose of generally presenting the context of the disclosure. Work of the presently named inventors, to the extent the work is described in this background section, as well as aspects of the description that may not otherwise qualify as prior art at the time of filing, are neither expressly nor impliedly admitted as prior art against the present disclosure.
Various applications in the fields of computer vision, image recognition, and speech recognition rely on neural networks to achieve performance improvements. A neural network is based on a collection of connected nodes (also referred to as neurons), which loosely model the neurons in a biological brain. The neurons can be organized into multiple layers. Neurons of one layer can connect to neurons of the immediately preceding and immediately following layers.
A connection between two neurons, like the synapses in a biological brain, can transmit a signal from one neuron to the other neuron. A neuron that receives a signal then processes the signal and can signal other connected neurons. In some examples, to find the output of a neuron, inputs to the neuron are weighted by the weights of the connections from the inputs to the neuron, and the weighted inputs are summed to generate a weighted sum. A bias may be added to the weighted sum. Further, the weighted sum is then passed through an activation function to produce the output.
Aspects of the disclosure provide methods and apparatuses of neural network model compression/decompression. In some examples, an apparatus of neural network model decompression includes receiving circuitry and processing circuitry. The processing circuitry can be configured to receive a dependent quantization enabling flag from a bitstream of a compressed representation of a neural network. The dependent quantization enabling flag can indicate whether a dependent quantization method is applied to model parameters of the neural network. The model parameters of the neural network can be reconstructed based on the dependent quantization method in response to the dependent quantization enabling flag indicating the dependent quantization method is used for encoding the model parameters of the neural network.
In an embodiment, the dependent quantization enabling flag is signaled at a model level, a layer level, a sublayer level, a 3-dimensional coding unit (CU3D) level, or a 3-dimensional coding tree unit (CTU3D) level. In an embodiment, the model parameters of the neural network can be constructed based on a uniform quantization method in response to the dependent quantization enabling flag indicates the uniform quantization method is used for encoding the model parameters of the neural network.
In some examples, an apparatus can include processing circuitry configured to receive one or more first sublayers of coefficients in a bitstream of a compressed representation of a neural network before receiving a second sublayer of weight coefficients in the bitstream. The first and second sublayers belongs to a layer of the neural network. In an embodiment, the one or more first sublayers of coefficients can be reconstructed before reconstructing the second sublayer of weight coefficients.
In an embodiment, the one or more first sublayers of coefficients include a sublayer of scaling factor coefficients, a sublayer of bias coefficients, or one or more sublayers of batch-normalization coefficients. In an embodiment, the layer of the neural network is a convolutional layer or a fully connected layer. In an embodiment, the coefficients of the one or more first sublayers are represented using quantized or unquantized values.
In an embodiment, a decoding sequence of the first and second sublayers can be determined based on structure information of the neural network transmitted separately from the bitstream of the compressed representation of the neural network. In an embodiment, one or more flags can be received indicating whether the one or more first sublayers are available in the layer of the neural network. In an embodiment, a 1-dimensional tensor can be inferred as a bias or local scaling tensor corresponding to one of the first sublayers of coefficients based on structure information of the neural network. In an embodiment, the first sublayers of coefficients that have been reconstructed can be merged to generate a combined tensor of coefficients during an inference process. The reconstructed weight coefficients belonging to a portion of the second sublayer of weight coefficients can be received as an input to the inference process while the remaining of the second sublayer of weight coefficients are still being reconstructed. Matrix multiplication of the combined tensor of coefficients and the received reconstructed weight coefficients can be performed during the inference process.
In some examples, an apparatus can include circuitry configured to receive a first unification enabling flag in a bitstream of a compressed representation of a neural network. The first unification enabling flag can indicate whether a unification parameter reduction method is applied to model parameters of the neural network. The model parameters of the neural network can be reconstructed based on the first unification enabling flag. In an embodiment, the first unification enabling flag is included a model parameter set or a layer parameter set.
In an embodiment, a unification performance map can be received in response to a determination that the unification method is applied to the model parameters of the neural network. The unification performance map can indicate a mapping between one or more unification thresholds and respective one or more sets of inference accuracies of neural networks compressed using the respective unification thresholds.
In an embodiment, the unification performance map includes one or more of the following syntax elements: a syntax element indicating a number of the one or more unification thresholds, a syntax element indicating the respective unification threshold corresponding to each of the one or more unification thresholds, or one or more syntax elements indicating the respective set of the inference accuracies corresponding to each of the one of the one or more unification thresholds.
In an embodiment, the unification performance map further includes one or more syntax elements indicating one or more dimensions of a model parameter tensor, a super block partitioned from the model parameter tensor, or a block partitioned from the super block.
In an embodiment, it is determined to apply values of syntax elements in a unification performance map in a layer parameter set to compressed data referencing the layer parameter set in the bitstream of the compressed representation of the neural network, responsive to that the first unification enabling flag being included in a model parameter set, a second unification enabling flag being included in the layer parameter set, and the first and second unification enabling flag each having a value indicating the unification parameter reduction method is enabled.
Aspects of the disclosure also provide a non-transitory computer-readable medium storing instructions which when executed by a computer for neural network model decompression cause the computer to perform the method of neural network model decompression.
Further features, the nature, and various advantages of the disclosed subject matter will be more apparent from the following detailed description and the accompanying drawings in which:
Aspects of the disclosure provide various techniques for neural network model compression/decompression. The techniques can include parameter quantization method control techniques, sublayer processing order techniques, and weight unification based parameter reduction techniques.
Artificial neural networks can be adopted for a broad range of tasks in multimedia analysis and processing, media coding, data analytics, and many other fields. Success of using artificial neural networks is based on the feasibility of processing much larger and complex neural networks (deep neural networks, DNNs) than in the past, and the availability of large-scale training data sets. As a consequence, trained neural networks can contain a large number of model parameters, resulting in a quite large size (e.g., several hundred MBs). The model parameters can include coefficients of the trained neural networks such as weights, biases, scaling factors, batch-normalization (batchnorm) parameters, or the like. Those model parameters can be organized into model parameter tensors. A model parameter tensor is used to refer to a multidimensional structure (e.g., array or matrix) that groups related model parameters of a neural network together. For example, the coefficients of a layer in a neural network, when available, can be grouped into a weight tensor, a bias tensor, a scaling factor tensor, a batchnorm tensor, or the like.
Many applications require the deployment of a particular trained network instance, potentially to a larger number of devices, which may have limitations in terms of processing power and memory (e.g., mobile devices or smart cameras) and also in terms of communication bandwidth. Those applications can benefit from neural network compression/decompression techniques disclosed herein.
I. Neural Network Based Devices and Applications
In the
It is noted that the electronic device (130) can be any suitable device, such as a smartphone, a camera, a tablet computer, a laptop computer, a desktop computer, a gaming headset, and the like.
In the
The processing circuitry (140) includes any suitable processing hardware, such as central processing units (CPUs), graphics processing units (GPUs), and the like. The processing circuitry (140) includes suitable components to execute applications based on neural networks, and includes suitable components configured as a neural network model codec (141). The neural network model codec (141) includes a decoder that can decode, for example, the compressed neural network model received from the application server (110). In an example, the processing circuitry (140) includes a single chip (e.g., integrated circuit) with one or more processors disposed on the single chip. In another example, the processing circuitry (140) includes multiple chips, and each chip can include one or more processors.
In some embodiments, the main memory (160) has a relatively large storage space and can store various information, such as software codes, media data (e.g., video, audio, image, etc.), compressed neural network models, and the like. The cache memory (150) has relatively small storage space, but a much faster access speed compared to the main memory (160). In some examples, the main memory (160) can include hard disc drives, solid state drives, and the like, and the cache memory (150) can include static random access memory (SRAM), and the like. In an example, the cache memory (150) can be on-chip memory that is disposed on, for example, a processor chip. In another example, the cache memory (150) can be off-chip memory that is disposed on one or more memory chips that are separate from the processor chips. Generally, on-chip memory has faster access speed than off-chip memory.
In some embodiments, when the processing circuitry (140) executes an application that uses a neural network model, the neural network model codec (141) can decompress the compressed neural network model to restore the neural network model. In some examples, the cache memory (150) is large enough, thus the restored neural network model can be buffered in the cache memory (150). Then, the processing circuitry (140) can access the cache memory (150) to use the restored neural network model in the application. In another example, the cache memory (150) has limited memory space (e.g., on-chip memory), the compressed neural network model can be decompressed layer by layer, or block by block, and the cache memory (150) can buffer the restored neural network model layer by layer or block by block.
It is noted that the neural network model codec (121) and the neural network model codec (141) can be implemented by any suitable techniques. In some embodiments, encoder and/or decoder can be implemented by integrated circuits. In some embodiments, encoder and decoder can be implemented as one or more processors executing a program that is stored in a non-transitory computer-readable medium. The neural network model codec (121) and the neural network model codec (141) can be implemented according to the encoding and decoding features described below.
The present disclosure provides techniques for neural network representation (NNR) that can be used to encode and decode neural network models, such as deep neural network (DNN) models, to save both storage and computation. Deep Neural Network (DNN) can be used in a large range of video applications, such as semantic classification, target detection/recognition, target tracking, video quality enhancement, and the like.
A neural network (or an artificial neural network) generally includes multiple layers between the input layer and the output layer. In some examples, a layer in the neural network corresponds to the mathematical manipulation to turn the inputs of the layer into the outputs of the layer. The mathematical manipulation can be a linear relationship or a non-linear relationship. The neural network can move through the layers to calculate the probability of each output. Each mathematical manipulation as such is considered a layer, and complex DNN can have many layers. In some examples, mathematical manipulation of a layer can be represented by one or more tensors (e.g., weight tensor, bias tensor, scaling factor tensor batchnorm tensor, or the like).
II. Dependent Quantization Enablement
1. Scan Order
Various techniques, such as scan order techniques, quantization techniques, entropy coding techniques, and the like can be used in the encoding/decoding of neural network models.
In some examples of the scan order techniques, the dimensions of a weight tensor are more than two (such as four in a convolution layer) and the weight tensor can be reshaped to a two-dimension tensor. No reshape is performed if the dimensions of a weight tensor are no more than two (such as a fully connected layer or bias layer) in an example.
To encode the weight tensor, weight coefficients in the weight tensor are scanned according to a certain order. In some examples, the weight coefficients in the weight tensor can be scanned in a row-first manner from the left to the right for each row and from the top row to the bottom row, for example.
2. Quantization
In some examples, nearest neighbour quantization is applied in a uniform way to each weight coefficient in the weight matrices. Such a quantization method is referred to as a uniform quantization method. For example, a step size is suitably determined and is included in the bitstream. In an example, the step size is defined as a 32-bit floating number and coded in the bitstream. Thus, when the decoder decodes from the bitstream the step size and an integer number corresponding to a weight coefficient, the decoder can reconstruct the weight coefficient as a multiplication of the integer number and the step size.
3. Entropy Coding
To encode the quantized weight coefficients, entropy coding techniques can be used. In some embodiments, an absolute value of the quantized weight coefficient is coded in a sequence that includes a unary sequence that may be followed by a fixed length sequence.
In some examples, the distribution of the weight coefficients in a layer generally follows Gaussian distribution, and the percentage of weight coefficients with a large value is very small, but the maximum value of the weight coefficients can be very large. In some embodiments, very smaller values can be coded using unary coding, and the larger values can be coded based on Golomb coding. For example, an integer parameter that is referred to as maxNumNoRem is used to indicate the maximum number when Golomb coding is not used. When a quantized weight coefficient is not greater than (e.g., is equal or smaller than) maxNumNoRem, the quantized weight coefficient can be coded by the unary coding. When the quantized weight coefficient is greater than maxNumNoRem, a portion of the quantized weigh coefficient equal to maxNumNoRem is coded by unary coding, and the remainder of the quantized weight coefficient is coded by Golomb coding. Thus, the unary sequence includes a first portion of the unary coding and a second portion of bits for coding the exponential Golomb remainder bits.
In some embodiments, a quantized weight coefficient can be coded by the following two steps.
In a first step, a binary syntax element sig_flag is encoded for the quantized weight coefficient. The binary syntax element sig_flag specifies whether the quantized weight coefficient is equal to zero. If the sig_flag is equal to one (indicates that the quantized weight coefficient is not equal to zero), a binary syntax element sign_flag is further encoded. The binary syntax element sign_flag indicates whether the quantized weight coefficient is positive or negative.
In the second step, the absolute value of the quantized weight coefficient can be coded into a sequence that includes a unary sequence that may be followed by a fixed length sequence. When the absolute value of the quantized weight coefficient is equal to or smaller than maxNumNoRem, the sequence includes unary coding of the absolute value of the quantized weight coefficient. When the absolute value of the quantized weight coefficient is greater than maxNumNoRem, the unary sequence can include a first part for coding maxNumNoRem using unary coding, and a second part for coding the exponential Golomb remainder bits, and the fixed length sequence is for coding a fixed length remainder.
In some examples, a unary coding is applied first. For example, a variable, such as j, is initialized with 0, and another variable X is set to j+1. A syntax element abs_level_greater_X is encoded. In an example, when the absolute value of the quantized weight level is greater than the variable X, abs_level_greater_X is set to 1, the unary encoding continues; otherwise, abs_level_greater_X is set to 0, and unary encoding is done. When abs_level_greater_X is equal to 1, and the variable j is smaller than maxNumNoRem, the variable j is increased by 1 and the variable X is also increased by 1. Then, a further syntax element abs_level_greater_X is encoded. The process continues until abs_level_greater_X is equal to 0 or the variable j is equal to maxNumNoRem. When the variable j is equal to maxNumNoRem, the encoded bits are the first part of the unary sequence.
When abs_level_greater_X is equal to 1 and j is equal to maxNumNoRem, the coding continues with Golomb coding. Specifically, the variable j is reset to 0, and X is set to 1<<j. A unary coding remainder can be calculated as the absolute value of the quantized weight coefficient subtracting maxNumNoRem. A syntax element abs_level_greater_than X is encoded. In an example, when the unary coding remainder is greater than the variable X, abs_level_greater_X is set to 1; otherwise, abs_level_greater_X is set to 0. If the abs_level_greater_X is equal to 1, the variable j is increased by 1, and 1<<j is added to X and a further abs_level_greater_X is encoded. The procedure is continued until an abs_level_greater_X is equal to 0, thus the second part of the unary sequence is encoded. When an abs_level_greater_X is equal to 0, the unary coding remainder can be one of the values (X, X−1, . . . X−(1<<j)+1). A code of length j can be used to code an index that points to one value in (X, X−1, . . . X−(1<<j)+1), the code can be referred to as a fixed length remainder.
According to an aspect of the disclosure, a context modeling approach can be used in the coding of the three flags sig_flag, sign_flag, and abs_level_greater_X. Thus, flags with similar statistical behavior can be associated with the same context model, so that the probability estimator (inside of the context model) can adapt to the underlying statistics.
In an example, the context modeling approach uses three context models for the sig_flag, depending on whether the neighboring quantized weight coefficient to the left is zero, smaller, or larger than zero.
In another example, the context model approach uses three other context models for the sign flag, depending on whether the neighboring quantized weight coefficient to the left is zero, smaller, or larger than zero.
In another example, for each of the abs_level_greater_X flags, the context modeling approach uses either one or two separate context models. In an example, when X<=maxNumNoRem, two context models are used depending on the sign_flag. When X>maxNumNoRem, only one context model is used in an example.
4. Dependent Quantization
In some embodiments, a dependent scalar quantization method is used for neural network parameter approximation. A related entropy coding method can be used to cooperate with the quantization method. The method introduces dependencies between the quantized parameter values, which reduces the distortion in parameter approximation. Additionally, the dependencies can be exploited in the entropy coding stage.
In dependent quantization, the admissible reconstruction values for a neural network parameter (e.g., weight parameter) depend on the selected quantization indexes for the preceding neural network parameters in reconstruction order. The main effect of the approach is that, in comparison to conventional scalar quantization, the admissible reconstruction vectors (given by all reconstructed neural network parameters of a layer) are packed denser in the N-dimensional vector space (N represents the number of parameters in a layer). That means, for a given average number of admissible reconstruction vectors per N-dimensional unit volume, the average distance (e.g. Mean Squared Error (MSE) or Mean Absolute Error (MAE) distortion) between an input vector and the closest reconstruction vector is reduced (for typical distributions of input vectors).
In the dependent quantization process, parameters can be reconstructed in a scanning order (in the same order in which they are entropy decoded), due to the dependencies between the reconstructed values. Then, the method of dependent scalar quantization can be realized by defining two scalar quantizers with different reconstruction levels and defining a process for switching between the two scalar quantizers. Accordingly, for each parameter, there can be two available scalar quantizers as shown in
For both the quantizers Q0 and Q1, the location of the available reconstruction levels is uniquely specified by the quantization step size Δ. The two scalar quantizers Q0 and Q1 are characterized as follows:
Q0: The reconstruction levels of the first quantizer Q0 are given by the even integer multiples of the quantization step size Δ. When this quantizer is used, a reconstructed neural network parameter t′ is calculated according to
t′=2·k·Δ, (Eq. 1)
where k denotes the associated parameter level (transmitted quantization index).
Q1: The reconstruction levels of the second quantizer Q1 are given by the odd integer multiples of the quantization step size Δ and the reconstruction level equal to zero. The mapping of neural network parameter levels k to reconstructed parameters t′ is specified by
t′=(2·k−sgn(k))·Δ, (Eq. 2)
where sgn(⋅) denotes the signum function
Instead of signaling the used quantizer (Q0 or Q1) for a current weight parameter explicitly in the bitstream, it is determined by the parities of the weight parameter levels that precede the current weight parameter in coding/reconstruction order. The switching between the quantizers is realized via a state machine, which is represented by Table 1. The state has eight possible values (0, 1, 2, 3, 4, 5, 6, 7) and is uniquely determined by the parities of the weight parameter levels preceding the current weight parameter in coding/reconstruction order. For each layer, the state variable is initially set to 0. When a weight parameter is reconstructed, the state is updated afterwards according to Table 1 where k denotes the value of the transform coefficient level. The next state depends on the current state and the parity (k & 1) of the current weight parameter level k. Hence, the state update can be obtained by:
state=sttab[state][k&1] (Eq. 4)
where sttab represents Table 1.
Table 1 shows a state transition table for determining the scalar quantizer used for the neural network parameters, where k denotes the value of the neural network parameter:
The state uniquely specifies the scalar quantizer used. If the state value for a current weight parameter is even (0, 2, 4, 6), the scalar quantizer Q0 is used. Otherwise, if the state value is odd (1, 3, 5, 7), scalar quantizer Q1 is used.
5. Dependent Quantization Enabling Flags
In dependent quantization, for a given parameter level (transmitted quantization index) k, if quantizer Q0 is used, the reconstructed neural network parameter t′ is calculated according to t′=2·k·Δ; if quantizer Q1 is used, the reconstructed parameters t′ is specified by t′=(2·k−sgn(k))·Δ.
It is known that many current modern high-performance inference engineer use low-bitdepth integers (such as INT8 or INT4) to perform matrix multiplication. However, in some cases, the integer parameter level (transmitted quantization index) k obtained by the dependent quantization procedure is not used by an inference engine directly. The integer parameter level may be dequantized to a floating-number reconstructed parameter value and later used by the inference engine. The floating-number value may not match with the inference engine operating with low-bitdepth integers.
To solve the above problem, in some embodiments, a control mechanism can be employed to turn on or turn off a dependent quantization tool at the encoder side for compression of a neural network. For example, a dependent quantization enabling flag, denoted dq_flag, can be signaled in a bitstream of a compressed neural network model. The flag can indicate whether a dependent quantization method is used for the compression of model parameters of the compressed neural network model.
When the bitstream is received at a decoder, the decoder can determine how to decode the bitstream based on the dependent quantization enabling flag. For example, in response to the dependent quantization enabling flag indicating the dependent quantization method is used for encoding the neural network, the decoder can reconstruct the model parameters of the neural network based on the dependent quantization method. When the dependent quantization enabling flag indicates the dependent quantization method is not used for encoding the neural network, the decoder can proceed to process the bitstream in a different way.
In an example, the dependent quantization enabling flag dq_flag specifies whether the quantization method applied is a dependent scalar quantization method or a uniform quantization method. A dq_flag equal to 0 indicates that the uniform quantization method is used. A dq_flag equal to 1 indicates that the dependent quantization method is used. In an example, when dq_flag is not present in the bitstream, the dq_flag is inferred to be 0. In other examples, a dq_flag equal to 0 may indicate another parameter quantization method other than the uniform quantization method.
In various embodiments, the dq_flag can be signaled in various levels in a bitstream. For example, one or more dependent quantization enabling flags can be signaled at a model level, a layer level, a sublayer level, a 3-dimensional coding unit (CU3D) level, a 3-dimensional coding tree unit (CTU3D) level, or the like. In an example, a dq_flag transmitted in a lower level may override a dq_flag transmitted in a higher level. In this case, different quantization methods may be employed for compression of model parameters at different positions within a structure of a model parameter tensor or in different model parameter tensors.
For example, a neural network may include multiple layers (e.g., convolutional layers or fully-connected layers). A layer may include multiple tensors (e.g., a weight tensor, a bias tensor, a scaling factor tensor, or batchnorm parameter tensors) each corresponding to a sublayer. Accordingly, in one embodiment, a dq_flag is defined at a model header level, so that a dependent quantization procedure can be turned on or off for all layers in the model. In another embodiment, a dq_flag is defined for each layer, so that a dependent quantization procedure can be turned on or off at per layer level. In another embodiment, a dq_flag is defined at sublayer level.
In some examples, a tensor (e.g., weight tensor) may be partitioned into blocks based on a predefined hierarchical structure. In an example, the dimension of a weight tensor is usually 4 for a convolution layer with a layout of [R][S][C][K], 2 for a fully-connected layer with a layout of [C][K], and 1 for a bias and batch normalization layer. Where R/S is a convolution kernel size, C is an input feature size and K is an output feature size. For a convolution layer, the 2D [R][S] dimension can be reshaped to 1D [RS] dimension so that the 4D tensor [R][S][C][K] is reshaped to 3D tensor [RS][C][K]. A fully-connected layer is treated as a special case of 3D tensor with R=S=1.
The 3D tensor [RS][C][K] can be partitioned along [C][K] plane with non-overlapping smaller blocks referred to as 3D coding tree unit (CTU3D). The CTU3D blocks can be further partitioned into 3D coding unit (CU3D) based on a quadtree structure. Whether to split a node in the quadtree structure can be based on a rate-distortion (RD) based decision. In some embodiments, slice, tile, or other block partition mechanisms may be used in combination with the CTU3D/CU3D partition method for partitioning along a [C][K] plane in a way similar to partitioning in the Versatile Video Coding (VVC) standard.
In an embodiment, when the above CTU3D/CU3D partitioning method is employed, one or more dq_flags can be defined and signaled at different block partition levels (e.g., levels of a CU3D, a CTU3D, a slice, a tile, or the like).
III. Sublayer Transmission Order in Bitstream
1. Scaling Factor Layer, Bias Layer, and Batchnorm Layer
In some embodiments, a local parameter scaling tool can be used to add a local scaling factor to model parameters after quantization has been performed on a layer or sublayer of a neural network. The scaling factor can be adapted or optimized to reduce a loss in prediction performance caused by respective quantization errors.
In an embodiment, a local scaling adaptation (LSA) method is performed using an already quantized neural network as input. For example, the linear components (a.k.a. weights) of the convolutional (conv) and fully-connected (fc) layers of the neural network are expected (but not necessarily) to be quantized. The method then introduces a factor (a.k.a a scaling factor) to the output of the weights of the conv and fc layers. For example, in the case of fc-layers, the factor corresponds to a vector with a same dimension as the number of rows of the weight matrix, which is respectively element-wise multiplied. As for conv layers, a scaling factor per output feature map can be applied to conserve the convolution property.
In some embodiments, a coding method is used to fold a scaling factor with a batchnorm layer (batchnorm folding). This method can be applied if a conv or fc layer is followed by a batch-normalization layer. In this case, the batch-normalization layer can be folded with the conv/fc layer (or a weight tensor in the conv/fc layer) in the following manner:
where s denotes a scaling factor in LSA, W denotes a weight tensor, X represent source data, b denotes a bias, γ, σ, μ, and β are batchnorm parameters, α=s·γ/√{square root over (σ2+ϵ)} represents a resulting scaling factor, and δ=(b−μ)·γ/√{square root over (σ2+ϵ)}+β represents resulting bias. Hence, α and δ can be signaled in this case instead of signaling s with γ, σ, μ, and β.
In some embodiments, another form of batchnorm folding can be applied if parameters of a model cannot be changed (e.g. when the decoder doesn't support changing the type of parameters) using the following batch norm folding operation (ordered steps) resulting in a set of new batchnorm parameters:
β:=β−μ·γ·/√{square root over (σ2+ϵ)} (Eq. 6)
γ:=γ·√{square root over (1+ϵ)}/√{square root over (σ2+ϵ)} (Eq. 7)
σ2:=1 (Eq. 8)
μ:=0 (Eq. 9)
In this case, σ2 and μ contain trivial values. In some examples, the trivial parameters are set to trivial values and not signaled in the bitstream.
In the above described LSA or batchnorm folding examples, the scaling factors, biases, and batchnorm parameters s, b, γ, σ, μ, β, α, δ in Eqs. 5-9, when available in a layer of a neural network model, can each form a sublayer belonging to the respective layer. Parameters of each sublayer can be grouped into a parameter tensor. It is noted that not all of those sublayers/tensors are necessarily present in a bitstream of a compressed neural network. Which sublayers/parameters are present in the bitstream depends on a structure of the neural network and which coding tools (e.g., an LSA method or a particular batchnorm folding method) are used for compression of the neural network.
2. Sublayer Ordering in a Bitstream
In some embodiments, during an inference process over a neural network model, an inference engine can merge (combine or fuse) multiple tensors, sublayers, or layers whenever possible to decrease computation cost and/or memory bandwidth consumption. For example, a layer in the neural network model may include multiple sublayers. If the tensors of those sublayers are used sequentially to process data resulting from a previous layer or sublayer one by one, intermediate data would be stored to and retrieved from memories for multiple rounds. This would result in extensive memory access as well as matrix computation. Merging the sublayers followed by a one-time processing over source data from a prior layer/sublayer can avoid that cost.
For example, when a conv or fc layer is followed by a bias layer, the inference engine will merge the bias layer with the conv or fc layer. When a conv or fc layer is followed by a batch-normalization layer, the inference engine can merge the batch-normalization layer into the conv or fc layer. When the scaling factor is introduced in the conv or fc layer, the inference engine can merge the scaling factor into the batch-normalization layer which can subsequently be merged with the conv or fc layer.
In some embodiments, an inference procedure can be executed in parallel with a decoding procedure in a pipelined manner. For example, a weight tensor in a compressed form in a bitstream can be decoded block by block (e.g., row by row, or CU3D CU3D). The blocks can be output from the decoding procedure sequentially. When a block of the weight tensor is available from the decoding procedure, an inference engine may perform data processing with the weight tensor block on the fly over source data from a previous layer/sublayer. In other words, the inference operation can start without waiting for the whole weigh tensor is decoded and becomes available.
The aforementioned sublayer/layer merge technique cannot be used in combination with the on-the-fly operation based on a partially available weight tensor if the scaling factor, bias and/or batch-normalization sublayer coefficients are placed after the conv or fc (weight tensor) coefficients in the bit-stream.
In some embodiments, to facilitate the combination of the on-the-fly operation and the sublayer/tensor merge technique, the sublayers of non-weight coefficients (coefficients other than the conv or fc coefficients (weight coefficients)) in a layer of a neural network are arranged in advance of the sublayer of the conv or fc coefficients (weight coefficients) in a bitstream carrying the compressed representation of the neural network. In this way, the sublayers of non-weight coefficients can have been reconstructed and available while the conv or fc coefficients are being reconstructed. When a part (a block) of the weight tensor becomes available, a merge operation can first be performed over this part using the coefficients of the available non-weight sublayers. The result of the merge operation can be input to an inference engine to process source data on the fly.
In various embodiments, the sublayers of coefficients reconstructed before the conv or fc coefficients can include scaling factor coefficients sublayers, bias coefficients sublayers, batch-normalization coefficients layers, or other types of sublayers that can merge with the sublayers of the conv or fc coefficients.
In an embodiment, scaling factor, bias and/or batch-normalization coefficients are arranged in front of conv or fc coefficients in a bit-stream. In one embodiment, if a conv or fc layer is followed by a bias in a neural network model, the bias coefficients can be arranged in front of the conv or fc coefficients in a bitstream. In another embodiment, if a conv or fc layer is followed by a batch-normalization layer, the batch-normalization coefficients can be arranged in front of the conv or fc coefficients in a bitstream. In another embodiment, if a scaling factor is used for a conv or fc layer, the scaling factor can be arranged in front of the conv or fc coefficients in a bitstream. In another embodiment, if a scaling factor is used for a conv or fc layer and the conv or fc layer is followed by a bias and/or a batch-normalization layer, the scaling factor, bias and/or batch-normalization layer can be arranged in front of conv or fc coefficients in the bitstream.
In one embodiment, the aforementioned scaling factor, bias and/or batch-normalization coefficients can be represented using their original values (e.g., without quantization or unquantized) and optionally encoded using any suitable encoding method. In another embodiment, the aforementioned scaling factor, bias and/or batch-normalization coefficients can be represented using their quantized values and optionally encoded using any encoding method.
In one embodiment, if transmission of a model structure of a neural network is separate from a bitstream body carrying a compressed representation of the neural network, a decoder receiving the bitstream body can be configured to analyze the model structure and accordingly adjust or determine a layer or sublayer decoding sequence. For example, when a layer includes a sublayer of weight tensor followed by a batchnorm sublayer, the decoder can determine coefficients of a batchnorm layer are arranged in front of the sublayer of weight tensor in the bitstream body. When a layer includes a sublayer of weight tensor with a scaling factor and a bias, the decoder can determine coefficients of the scaling factor and the bias are arranged in front of the sublayer of weight tensor in the bitstream body.
In another embodiment, if a model structure of a neural network is embedded in a bitstream body carrying a compressed representation of the neural network, a flag can be added, for example, in a conv/fc layer header, to indicate whether the conv/fc layer (the sublayer of a weight tensor) is followed by a batch normalization layer in the neural network. A decoder receiving the bitstream body can accordingly determine or adjust a sublayer/layer decoding sequence.
In another embodiment, if a model structure of a neural network is embedded in a bitstream body of the neural network, a flag can be added, for example, in a conv/fc layer header, to indicate whether a bias or local scaling tensor exists in this conv/fc layer in the neural network. In another embodiment, if structure information of a neural network is embedded in a bitstream body of the neural network, the following 1D tensor of a weight tensor (a conv/fc sublayer) can be inferred as a bias/local scaling tensor in the neural network model based on the structure information.
IV. Unification Based Model Parameter Reduction
In some embodiments, one or more parameter reduction methods are used to process a neural network model to obtain a compact representation of the neural network. Examples of such methods can include parameter sparsification, parameter pruning, parameter (e.g., weight) unification, and decomposition methods. For example, in a unification process, model parameters can be processed to produce groups of similar parameters. As a result, the entropy of the model parameters can be lowered. In some cases, unification does not eliminate or constrain the weights to be zero.
In some embodiments, learning based approaches are employed to obtain a compact DNN model. The target is to remove unimportant weight coefficients based on the assumption that the smaller the weight coefficients are in value, the less their importance is. In some examples, network pruning methods can be employed to explicitly pursue this goal, and sparsity-promoting regularization terms can be added to the network training target. In some embodiments, after learning a compact network model, the weight coefficients of the network model can be further compressed by quantization followed by entropy coding. Such further compression processes can significantly reduce the storage size of the DNN model, which are essential for model deployment over mobile devices, chips, etc., in some scenarios.
The present disclosure provides a method and related syntax elements for compressing a DNN model using a structured weight unification method as well as for using the compressed DNN model for an inference process. As a result, inference computation performance and compression efficiency can be improved.
1. Unification Regularization
An iterative network retraining/refining framework can be used to jointly optimize an original training target and a weight unification loss. The weight unification loss can include a compression rate loss, a unification distortion loss, and a computation speed loss. The learned network weight coefficients can preserve the original target performance, be suitable for further compression, and speed up computation using the learned weight coefficients. The method can be applied to compress an original pretrained DNN model. The method can also be used as an additional processing module to further compress a pruned DNN model.
Examples of unification regularization techniques are described below. Let ={(x,y)} denote a data set where a target y is assigned to an input x. Let Θ={w} denote a set of weight coefficients of a DNN. The target of network training is to learn an optimal set of weight coefficients Θ* so that a target loss £(|Θ) can be minimized. For example, in some network pruning approaches, the target loss £(|Θ) has two parts, an empirical data loss £(|Θ) and a sparsity-promoting regularization loss £R(Θ):
£T(|Θ)=£(|Θ)+λR£R(Θ), (Eq. 10)
where λR≥0 is a hyperparameter balancing the contributions of the data loss and the regularization loss.
The sparsity-promoting regularization loss places regularization over the entire weight coefficients, and the resulting sparse weights have a weak relationship with the inference efficiency or computation acceleration. From another perspective, after pruning, the sparse weights can further go through another network training process where an optimal set of weight coefficients can be learned that can improve the efficiency of further model compression.
In some embodiments, a weight unification loss £U(|Θ) given below can be optimized together with the original target loss:
£(|Θ)=£T(|Θ)+λU£U(Θ), (Eq. 11)
where λU≥0 is a hyperparameter to balance the contributions of the original training target and the weight unification. By jointly optimizing £(|Θ) of Eq. 11, the optimal set of weight coefficients can be obtained that can largely help the effectiveness of further compression. Also, the weight unification loss of Eq. 11 takes into consideration the underlying process of how the convolution operation is performed as a general matrix multiplication (GEMM) process, resulting in optimized weight coefficients that can largely accelerate computation. It is worth noting that the weight unification loss can be viewed as an additional regularization term to a general target loss, with (when λR>0) or without (when λR=0) general regularizations. Also, this method can be flexibly applied to any regularization loss £R(Θ).
In an embodiment, the weight unification loss £U(Θ) Further Comprises the compression rate loss £C(Θ), the unification distortion loss £l(Θ), and the computation speed loss £S(Θ):
£U(Θ)=£I(Θ)+λC£C(Θ)+λS£S(Θ), (Eq. 12)
Detailed descriptions of these loss terms are described in later. For both the learning effectiveness and the learning efficiency, an iterative optimization process is further described. In the first step, parts of the weight coefficients satisfying the desired structure are fixed, and then in the second step, the non-fixed parts of the weight coefficients are updated by back-propagating the training loss. By iteratively conducting these two steps, more and more weights can be fixed gradually, and the joint loss can be gradually optimized effectively.
Moreover, in an embodiment, each layer is compressed individually, £(|Θ) can be further written as:
£U(Θ)=Σj=1NLU(Wj), (Eq. 13)
where LU(Wj) is a unification loss defined over the j-th layer; N is the total number of layers where the quantization loss is measured; and Wj denotes the weight coefficients of the j-th layer. Again, since LU(Wj) is computed for each layer independently, in the rest of the disclosure the script j is omitted without loss of generality.
In an embodiment, for each network layer, its weight coefficients W form a general 5-Dimension (5D) tensor with size (ci, k1, k2, k3, co). The input of the layer is a 4-Dimension (4D) tensor A of size (hi, wi, di, ci), and the output of the layer is a 4D tensor B of size (ho, wo, do, co). The sizes ci, k1, k2, k3, co, hi, wi, di, ho, wo, do are integer numbers greater or equal to 1. When any of the sizes ci, k1, k2, k3, co, hi, wi, di, ho, wo, do takes number 1, the corresponding tensor reduces to a lower dimension. Each item in each tensor is a floating number. Let M denote a 5D binary mask of the same size as W, where each item in M is a binary number 0/1 indicating whether the corresponding weight coefficient is pruned/kept. M is introduced to be associated with W to cope with the case where W is from a pruned DNN model where some connections between neurons in the network are removed from computation. When W is from the original unpruned pretrained model, all items in M take value 1. The output B is computed through the convolution operation ⊙ based on A, M, and W:
The parameters hi, wi and di(h0, wo and do) are the height, weight, and depth of the input tensor A (output tensor B). The parameter ci (co) is the number of input (output) channel. The parameters k1, k2, and k3 are the size of the convolution kernel corresponding to the height, weight, and depth axes, respectively. That is, for each output channel v=1, . . . , c0, the operation described in Eq. 14 can be seen as a 4D weight tensor Wv of size (ci, k1, k2, k3) convolving with the input A.
In an embodiment, the order of the summation operation in Eq. 14 can be changed. In the embodiment, the operation of Eq. 14 can be performed as follows. The 5D weight tensor is reshaped into a 3D tensor of size (ci, co, k) where k=k1·k2·k3. The order of reshaped index along the k axis is determined by a reshaping algorithm in a reshaping process, which will be described in detail later.
In an embodiment, the desired structure of the weight coefficients is designed by taking into consideration two aspects. First, the structure of the weight coefficients is aligned with the underlying GEMM matrix multiplication process of how the convolution operation is implemented so that the inference computation of using the learned weight coefficients is accelerated. Second, the structure of the weight coefficients can help to improve the quantization and entropy coding efficiency for further compression.
In one embodiment, a block-wise structure is used for the weight coefficients in each layer in the 3D reshaped weight tensor. Specifically, the 3D tensor is partitioned into blocks of size (gi, go, gk), and all coefficients within the block are unified in an embodiment. Unified weights in a block are set to follow a pre-defined unification rule, e.g., all values are set to be the same so that one value can be used to represent the whole block in the quantization process which yields high efficiency.
There can be multiple rules of unifying weights, each associated with a unification distortion loss measuring the error introduced by taking this rule. For example, instead of setting the weights to be the same, the weights can be set to have the same absolute value while keeping their original signs.
Given this designed structure, during an iteration, the part of the weight coefficients to be fixed is first determined by taking into consideration the unification distortion loss, the estimated compression rate loss, and the estimated speed loss. Then, in the second step, the normal neural network training process is performed and the remaining un-fixed weight coefficients are updated through the back-propagation mechanism.
2. Workflow
Specifically, in an embodiment, the process can first partition the reshaped 3D tensor of weights W into super-blocks of size (gi, go, gk). Let S denote a super-block. I(W) is determined for each super-block S individually, based on the weight unification loss of the weight coefficients within the super-block S, i.e., based on the weight unification loss £T(Θ) of Eq. 12. The selection of the size of the super-blocks usually depends on the later compression methods. For example, in the embodiment, the process can choose super-blocks of size (64, 64, k) to be consistent with the 3-Dimension Coding Tree Unit (CTU3D) used by a later compression process.
In an embodiment, each super-block S is further partitioned into blocks of size (di, do, dk). Weight unification happens inside the blocks. For each super-block S, a weight unifier is used to unify the weight coefficients within the blocks of S. Let b denote a block in S, there can be different ways to unify weight coefficients in b. For example, the weight unifier can set all weights in b to be the same, e.g., the mean of all weights in b. In such a case, the LN norm of the weight coefficients in b (e.g., L2 norm as a variance of weights in b) reflects the unification distortion loss £l(b) of using the mean to represent the entire block.
Also, the weight unifier can set all weights to have the same absolute value, while keeping the original signs. In such a case, the LN norm of the absolute of weights in b can be used to measure LT(b). In other words, given a weight unifying method u, the weight unifier can unify weights in b using the method u with an associated unification distortion loss Ll(u,b). Then the process can compute the unification distortion loss £I(u,S) of the entire super-block S by averaging LI(u,b) across all blocks in S, i.e., LI(u,S)=averageb(LI(u,b)).
Similarly, the compression rate loss £C(u,S) of Eq. 12 reflects the compression efficiency of unifying weights in the super-block S using method u. For example, when all weights are set to be the same, only one number is used to represent the whole block, and the compression rate is rcompression=gi·go·gk. £C(u,S) can be defined as l/rcompression.
The speed loss £S(u,S) in Eq. 12 reflects the estimated computation speed of using the unified weight coefficients in S with method u, which is a function of the number of multiplication operations in computation using the unified weight coefficients.
By now, for each possible way of reordering the indexes to generate the 3D tensor of weights W, and for each possible method u of unifying weights by the weight unifier, the process can compute the weight unification loss £U(u,S) of Eq. 12 based on £I(u,S), £C(u,S), £S(u,S). The optimal weight unifying method u* and the optimal reordering indexes I*(W) can be selected whose combination has the smallest weight unification loss £U*(u,S). When k is small, the process can exhaustively search for the best I*(W) and u*. For large k, other methods can be used to find suboptimal 1*(W) and u*. This disclosure does not put any restrictions on the specific ways of determining l*(W) and u*.
Once the order of indexes I*(W) and the weight unifying method u* are determined for every super-block S, the target turns to finding a set of updated optimal weight coefficients W* and the corresponding weight mask M* by iteratively minimizing the joint loss described in Eq. 11.
Specifically, for the t-th iteration, the process can have the current weight coefficients W(t−1) and mask M(t−1). Also, the process can maintain a weight unifying mask Q(t−1) throughout the training process. The weight unifying mask Q(t−1) has the same shape as W(t−1), which records whether a corresponding weight coefficient is unified or not. Then, a unified weight coefficients WU(t−1) and a new unifying mask Q(t−1) are computed through a Weight Unification process.
In the Weight Unification process, the process can reorder the weight coefficients in S according to the determined order of index I*(W), and then rank the super-blocks based on their unification loss £U(u*,S) in accenting order. Given a hyperparameter q, the top q super-blocks are selected to be unified. And the weight unifier unifies the blocks in the selected super-blocks S using the corresponding determined method u*, resulting in a unified weight WU(t−1) and weight mask MU(t−1).
The corresponding entry in the unifying mask Q(t−1) is marked as being unified. In the embodiment, MU(t−1) is different from M(t−1), where for a block having both pruned and unpruned weight coefficients, the originally pruned weight coefficients will be set to have a non-zero value again by the weight unifier, and the corresponding item in MU(t−1) will be changed. For other types of blocks, MU(t−1) will naturally remain unchanged.
Then in the second step, the process can fix the weight coefficients which are marked in Q(t−1) as being unified, and then update the remaining unfixed weight coefficients of W(t−1) through a neural network training process, resulting in updated W(t) and M(t).
Let ={(x,y)} denote a training dataset, where can be the same as the original dataset 0={(x0,y0)} based on which the pre-trained weight coefficients W are obtained. can also be a different dataset from 0, but with the same data distribution as the original dataset . In the second step, each input x is passed through the current network via a Network Forward Computation process using the current weight coefficients WU(t−1) and mask MU(t−1), which generates an estimated output {tilde over (y)}. Based on the ground-truth annotation y and the estimated output
Then the gradient of the target loss G(WU(t−1)) can be computed. The automatic gradient computing method used by deep learning frameworks such as Tensorflow or Pytorch can be used to compute G(WU(t−1)). Based on the gradient G(WU(t−1)) and the unifying mask Q(t−1), the non-fixed weight coefficients of WU(t−1) and the corresponding mask MU(t−1) can be updated through back-propagation using a Back Propagation and Weight Update process.
The retraining process is also an iterative process itself, which is marked by the dotted box in
It is noted that the order of indexes I(W)=[i0, . . . , ik] to reorder the reshaped weight coefficients can take the trivial original order and therefore be optional and neglectable. In that case, the process can skip the process of reordering the reshaped weight coefficients.
The unification based parameter reduction methods disclosed herein provide the following technical advantages. The unification regularization targets at improving the efficiency of further compression of the learned weight coefficients, speeding up computation for using the optimized weight coefficients. This can significantly reduce the DNN model size and speed up the inference computation.
In addition, through the iterative retraining process, the methods can effectively maintain the performance of the original training target and pursue compression and computation efficiency. The iterative retraining process also gives the flexibility of introducing different losses at different times, making the system focus on different targets during the optimization process. Further, the methods can be generally applied to datasets with different data forms. The input/output data are general 4D tensors, which can be real video segments, images, or extracted feature maps.
3. Syntax Elements for Unification Based Parameter Reduction
In some embodiments, one or more syntax elements are employed for compressing a neural network model (e.g., a DNN model) using a weight unification based model parameter reduction method as well as for using the corresponding compressed neural network model.
When the mps_unification_flag is decoded and, for example, has a value (e.g., 1) indicating unification is applied, a syntax structure of a model level unification performance map, denoted unification_performance_map( ), can be received in the model parameter set payload syntax section in the bitstream. In an embodiment, the unification_performance_map( ) in the model parameter set can specify a number of thresholds, reshaped tensor dimensions, super block, and block dimensions, unification thresholds, or the like, in a model level. In an embodiment, the unification_performance_map( ) can specify a mapping between different unification thresholds (applied in unification processes) and resulting neural inference accuracies.
In an example, the resulting accuracies are provided separately for different aspects or characteristics of the output of the neural network. For example, for a classifier neural network, each unification threshold is mapped to separate accuracies for each class, in addition to an overall accuracy that considers all classes. Classes can be ordered based on the neural network output order, i.e, the order specified during the training of the neural network.
The syntax element reshaped_tensor_dimensions specifies an array or list of dimension values. For example, for a convolutional layer reshaped to 3-dimensional tensor, dim is an array or list of length 3. The syntax element count_super_block_dimensions specifies a counter of how many dimensions are specified. For example, for a 3-dimensional super block, count_dims is 3. The syntax element super_block_dimensions specifies an array or list of dimension values. For example, for a 3-dimensional super block, dim is an array or list of length 3, i.e., [64, 64, kernel_size]. The syntax element count_block_dimensions specifies a counter of how many dimensions are specified. For example, for a 3-dimensional block, count_dims is 3.
The syntax element block_dimensions specifies an array or list of dimension values. For example, for a 3-dimensional block, dim is an array or list of length 3, i.e., [2, 2, 2]. The syntax element unification_threshold specifies the threshold which is applied to tensor block to unify the absolute value of weights in this tensor block. The syntax element nn_accuracy specifies the overall accuracy of the neural network (e.g., classification accuracy by considering all classes).
The syntax element count_classes specifies a number of classes for which separate accuracies are provided for each unification threshold. The syntax element nn_class_accuracy specifies the accuracy for a certain class when a certain unification threshold is applied.
When the lps_unification_flag is decoded and, for example, has a value (e.g., 1) indicating unification is applied, a syntax structure of a layer level unification performance map, denoted unification_performance_map, can be received in the layer parameter set payload syntax section in the bitstream. In an embodiment, the unification_performance_map( ) in the layer parameter set can specify a number of thresholds, reshaped tensor dimensions, super block and block dimensions, unification thresholds, or the like, in a layer level.
In an embodiment, the unification_performance_map( ) in the layer parameter set can specify a mapping between different unification thresholds (applied in a layer level) and resulting neural inference accuracies. In an embodiment, the unification_performance_map( ) in the layer parameter set can have a similar structure as that in the model level as shown in
In an example, both the mps_unification_flag in a model parameter set and the lps_unification_flag in a layer parameter set are signaled in a bitstream. For example, the value of the mps_unification_flag & lps_unification_flag is equal to 1. In such a scenario, the values of syntax elements in the unification_performance_map( ) in the layer parameter set are used in the compressed data units that reference this layer parameter set. In other words, the values of syntax elements in the unification_performance_map( ) in the layer parameter set override the values of syntax elements in the unification_performance_map( ) in model parameter set for a layer referencing the unification_performance_map( ) in the layer parameter set.
At (S1110), a dependent quantization enabling flag can be received in the bitstream. For example, the dependent quantization enabling flag can be signaled at a model level, a layer level, a sublayer level, a 3-dimensional coding unit (CU3D) level, or a 3-dimensional coding tree unit (CTU3D) level. Accordingly, the dependent quantization flag can be applied to compressed data at different levels in the structure of the neural network.
At (S1120), whether a dependent quantization method is applied to respective model parameters of the neural network can be determined based on the dependent quantization enabling flag. For example, a value of 1 of the dependent quantization enabling flag can indicate the dependent quantization method is applied, while a value of 0 can indicate a uniform quantization method can be applied.
At (S1130), when the dependent quantization method is applied, the respective model parameters of the neural network can be reconstructed based on the dependent quantization method. For example, entropy decoding and inverse quantization operations can accordingly be performed using the dependent quantization method. The process (1100) can proceed to (S1199).
At (S1140), when the uniform quantization method is applied, the respective model parameters of the neural network can be reconstructed based on the uniform quantization method. For example, entropy decoding and inverse quantization operations can accordingly be performed using the uniform quantization method. The process (1100) can proceed to (S1199).
At (S1199), after the step of (S1130) or (S1140) is completed, the process (1100) can terminate.
The techniques described above, can be implemented as computer software using computer-readable instructions and physically stored in one or more computer-readable media. For example,
The computer software can be coded using any suitable machine code or computer language, that may be subject to assembly, compilation, linking, or like mechanisms to create code comprising instructions that can be executed directly, or through interpretation, micro-code execution, and the like, by one or more computer central processing units (CPUs), Graphics Processing Units (GPUs), and the like.
The instructions can be executed on various types of computers or components thereof, including, for example, personal computers, tablet computers, servers, smartphones, gaming devices, internet of things devices, and the like.
The components shown in
Computer system (1200) may include certain human interface input devices. Such a human interface input device may be responsive to input by one or more human users through, for example, tactile input (such as keystrokes, swipes, data glove movements), audio input (such as voice, clapping), visual input (such as gestures), olfactory input (not depicted). The human interface devices can also be used to capture certain media not necessarily directly related to conscious input by a human, such as audio (such as speech, music, ambient sound), images (such as scanned images, photographic images obtain from a still image camera), video (such as two-dimensional video, three-dimensional video including stereoscopic video).
Input human interface devices may include one or more of (only one of each depicted): keyboard (1201), mouse (1202), trackpad (1203), touch screen (1210), data-glove (not shown), joystick (1205), microphone (1206), scanner (1207), camera (1208).
Computer system (1200) may also include certain human interface output devices. Such human interface output devices may be stimulating the senses of one or more human users through, for example, tactile output, sound, light, and smell/taste. Such human interface output devices may include tactile output devices (for example tactile feedback by the touch-screen (1210), data-glove (not shown), or joystick (1205), but there can also be tactile feedback devices that do not serve as input devices), audio output devices (such as speakers (1209), headphones (not depicted)), visual output devices (such as screens (1210) to include CRT screens, LCD screens, plasma screens, OLED screens, each with or without touch-screen input capability, each with or without tactile feedback capability—some of which may be capable to output two dimensional visual output or more than three dimensional output through means such as stereographic output; virtual-reality glasses (not depicted), holographic displays and smoke tanks (not depicted)), and printers (not depicted).
Computer system (1200) can also include human accessible storage devices and their associated media such as optical media including CD/DVD ROM/RW (1220) with CD/DVD or the like media (1221), thumb-drive (1222), removable hard drive or solid state drive (1223), legacy magnetic media such as tape and floppy disc (not depicted), specialized ROM/ASIC/PLD based devices such as security dongles (not depicted), and the like.
Those skilled in the art should also understand that term “computer readable media” as used in connection with the presently disclosed subject matter does not encompass transmission media, carrier waves, or other transitory signals.
Computer system (1200) can also include an interface to one or more communication networks. Networks can for example be wireless, wireline, optical. Networks can further be local, wide-area, metropolitan, vehicular and industrial, real-time, delay-tolerant, and so on. Examples of networks include local area networks such as Ethernet, wireless LANs, cellular networks to include GSM, 3G, 4G, 5G, LTE and the like, TV wireline or wireless wide area digital networks to include cable TV, satellite TV, and terrestrial broadcast TV, vehicular and industrial to include CANBus, and so forth. Certain networks commonly require external network interface adapters that attached to certain general purpose data ports or peripheral buses (1249) (such as, for example USB ports of the computer system (1200)); others are commonly integrated into the core of the computer system (1200) by attachment to a system bus as described below (for example Ethernet interface into a PC computer system or cellular network interface into a smartphone computer system). Using any of these networks, computer system (1200) can communicate with other entities. Such communication can be uni-directional, receive only (for example, broadcast TV), uni-directional send-only (for example CANbus to certain CANbus devices), or bi-directional, for example to other computer systems using local or wide area digital networks. Certain protocols and protocol stacks can be used on each of those networks and network interfaces as described above.
Aforementioned human interface devices, human-accessible storage devices, and network interfaces can be attached to a core (1240) of the computer system (1200).
The core (1240) can include one or more Central Processing Units (CPU) (1241), Graphics Processing Units (GPU) (1242), specialized programmable processing units in the form of Field Programmable Gate Areas (FPGA) (1243), hardware accelerators for certain tasks (1244), and so forth. These devices, along with Read-only memory (ROM) (1245), Random-access memory (1246), internal mass storage such as internal non-user accessible hard drives, SSDs, and the like (1247), may be connected through a system bus (1248). In some computer systems, the system bus (1248) can be accessible in the form of one or more physical plugs to enable extensions by additional CPUs, GPU, and the like. The peripheral devices can be attached either directly to the core's system bus (1248), or through a peripheral bus (1249). Architectures for a peripheral bus include PCI, USB, and the like.
CPUs (1241), GPUs (1242), FPGAs (1243), and accelerators (1244) can execute certain instructions that, in combination, can make up the aforementioned computer code. That computer code can be stored in ROM (1245) or RAM (1246). Transitional data can be also be stored in RAM (1246), whereas permanent data can be stored for example, in the internal mass storage (1247). Fast storage and retrieve to any of the memory devices can be enabled through the use of cache memory, that can be closely associated with one or more CPU (1241), GPU (1242), mass storage (1247), ROM (1245), RAM (1246), and the like.
The computer readable media can have computer code thereon for performing various computer-implemented operations. The media and computer code can be those specially designed and constructed for the purposes of the present disclosure, or they can be of the kind well known and available to those having skill in the computer software arts.
As an example and not by way of limitation, the computer system having architecture (1200), and specifically the core (1240) can provide functionality as a result of processor(s) (including CPUs, GPUs, FPGA, accelerators, and the like) executing software embodied in one or more tangible, computer-readable media. Such computer-readable media can be media associated with user-accessible mass storage as introduced above, as well as certain storage of the core (1240) that are of non-transitory nature, such as core-internal mass storage (1247) or ROM (1245). The software implementing various embodiments of the present disclosure can be stored in such devices and executed by core (1240). A computer-readable medium can include one or more memory devices or chips, according to particular needs. The software can cause the core (1240) and specifically the processors therein (including CPU, GPU, FPGA, and the like) to execute particular processes or particular parts of particular processes described herein, including defining data structures stored in RAM (1246) and modifying such data structures according to the processes defined by the software. In addition or as an alternative, the computer system can provide functionality as a result of logic hardwired or otherwise embodied in a circuit (for example: accelerator (1244)), which can operate in place of or together with software to execute particular processes or particular parts of particular processes described herein. Reference to software can encompass logic, and vice versa, where appropriate. Reference to a computer-readable media can encompass a circuit (such as an integrated circuit (IC)) storing software for execution, a circuit embodying logic for execution, or both, where appropriate. The present disclosure encompasses any suitable combination of hardware and software.
While this disclosure has described several exemplary embodiments, there are alterations, permutations, and various substitute equivalents, which fall within the scope of the disclosure. It will thus be appreciated that those skilled in the art will be able to devise numerous systems and methods which, although not explicitly shown or described herein, embody the principles of the disclosure and are thus within the spirit and scope thereof.
This present disclosure claims the priority to U.S. Provisional Application No. 63/011,122, “Dependent Quantization Enabling Flag for Neural Network Model Compression” filed on Apr. 16, 2020, No. 63/011,908, “Sublayer Ordering in Bitstream for Neural Network Model Compression” filed on Apr. 17, 2020, No. 63/042,968, “Sublayer ordering flag for Neural Network Model Compression” filed on Jun. 23, 2020, and No. 63/052,368, “Syntax Elements for Neural Network Model Compression with Structured Weight Unification” filed on Jul. 15, 2020. The disclosures of the prior applications are hereby incorporated by reference in their entirety.
Number | Date | Country | |
---|---|---|---|
63011122 | Apr 2020 | US | |
63011908 | Apr 2020 | US | |
63042968 | Jun 2020 | US | |
63052368 | Jul 2020 | US |