This application relates to neural network technologies, and in particular, to a method and an apparatus for quantizing a neural network model in a device.
An artificial neural network (ANN), also briefly referred to as a neural network (NN), is a network structure that imitates behavioral characteristics of animal neural networks for information processing. This structure is formed by interconnecting a large quantity of nodes (or referred to as neurons), and achieves the purpose of processing information by learning and training input information based on a specific operation model. A neural network includes an input layer, a hidden layer and an output layer. The input layer is responsible for receiving input signals, the output layer is responsible for outputting calculation results of the neural network, and the hidden layer is responsible for calculation processes such as learning and training. The hidden layer is a memory unit of the network and a memory function of the hidden layer is represented by a weight matrix. Each neuron generally corresponds to one piece of weight data.
A neural network model is a description of the neural network based on a mathematical model. Quantization of the neural network model refers to conversion of parameters in the neural network model from high-precision data to low-precision data so that a size of the neural network model becomes smaller, a running speed becomes higher, and accuracy is similar to that before quantization. The quantization of the neural network model includes two stages: quantization of weight data and quantization of input data commonly used quantization techniques include INT8 quantization. The INT8 quantization means that the weight data (such as double-precision (64-bit), single-precision (32-bit), or half-precision (16-bit)) and the input data (double-precision, single-precision, or half-precision) stored in the neural network model are mapped to 8-bit quantized data through linear or nonlinear methods. The process of quantizing the weight data is performed layer by layer. Before quantization, a weight quantization parameter of each layer in the neural network needs to be obtained, and the weight data is quantized based on the weight quantization parameter to obtain quantized weight data of each layer. After that, quantization of the input data can be further performed, and the process is performed using an input quantization parameter. To obtain the weight quantization parameter and the input quantization parameter, a device manufacturer or a model provider can input a set of preset calibration data into a weight-quantized neural network model, so as to derive the weight quantization parameter and the input quantization parameter.
However, the foregoing input quantization parameters are all generated and provided offline by the device manufacturer or the model provider based on the preset calibration data, that is, the device manufacturer or the model provider loads the quantized neural network model including the input quantization parameter onto various types of devices, such as terminal devices. Because common preset calibration data is used in the process of obtaining the input quantization parameter offline, it is clearly that the common calibration data does not match data generated by a user, increasing a quantization error of the neural network model and reducing accuracy of the neural network model.
This application provides a method and an apparatus for quantizing a neural network model in a device, so as to obtain a quantization parameter on the device online, thereby improving quantization accuracy.
A first aspect of this application provides a method for quantizing a neural network model in a device, including: obtaining user calibration data, where the user calibration data is generated based on data generated by the device used by a user, inputting the user calibration data into the neural network model to calculate a quantization parameter of each of a plurality of layers of the neural network model; and inputting to-be-quantized data into the neural network model to quantize input data of each layer by using the quantization parameter of each layer.
In the method, the user calibration data is used to calculate the quantization parameter of each layer. Because the user calibration data is generated based on the data generated by the device used by the user, the quantization parameter can be obtained online, and the quantization parameter matches the user data in the device, thereby improving quantization accuracy.
Optionally, obtaining user calibration data may include generating the user calibration data. For example, the user calibration data may be generated based on the data generated by the device used by the user.
In an example manner, obtaining the user calibration data and calculating the quantization parameter are performed at a quantization parameter calculation stage, and quantizing input data of each layer is performed at a quantization stage. Optionally, the quantization parameter calculation stage may be triggered periodically or when there is no quantization task.
In an example manner, the user calibration data includes at least one of first audio data or first image data; and the to-be-quantized data includes at least one of second audio data or second image data.
In an example manner, the user calibration data is obtained by screening or tailoring the data generated by the device used by the user. For example, the generating the user calibration data includes generating the user calibration data by screening or tailoring the data generated by the device used by the user.
In an example manner, the quantization parameter includes a quantization scale value scaledata.
In another example manner, the quantization parameter further includes a quantization offset value offset.
In an example manner, calculating a quantization parameter of any layer includes: determining a maximum value in input data of the layer; and calculating a quantization scale value of the layer by using the following formula:
where datamax represents the maximum value in the input data of the layer, and X represents a quantity of quantized bits.
In another example manner, calculating a quantization parameter of any layer includes: determining a maximum value and a minimum value in input data of the layer; and calculating a quantization scale value and a quantization offset value of the layer by using the following formulas:
where datamax represents the maximum value in the input data of the layer, datamin represents the minimum value in the input data of the layer, and x represents a quantity of quantized bits.
In another example manner, before determining the maximum value in input data of the layer, the method further includes: replacing a value greater than a quantization threshold in the input data of the layer with the quantization threshold.
A second aspect of this application provides an apparatus for quantizing a neural network model in a device, including: an obtaining module, configured to obtain user calibration data, where the user calibration data is generated based on data generated by the device used by a user; a calculation module, configured to input the user calibration data into the neural network model to calculate a quantization parameter of each of a plurality of layers of the neural network model; and a quantization module, configured to input to-be-quantized data into the neural network model to quantize input data of each layer by using the quantization parameter of each layer. Optionally, obtaining user calibration data may include generating the user calibration data. For example, the user calibration data may be generated based on the data generated by the device used by the user.
In an example manner, obtaining the user calibration data and calculating the quantization parameter are performed at a quantization parameter calculation stage, and quantizing input data of each layer is performed at a quantization stage. Optionally, the quantization parameter calculation stage may be triggered periodically or when there is no quantization task.
In an example manner, the data generated by the device used by the user includes at least one of first audio data or first image data; and the to-be-quantized data includes at least one of second audio data or second image data.
In an example manner, the user calibration data is obtained by screening or tailoring the data generated by the device used by the user. For example, the generating the user calibration data includes generating the user calibration data by screening or tailoring the data generated by the device used by the user.
In an example manner, the quantization parameter includes a quantization scale value scaled.
In another example manner, the quantization parameter further includes a quantization offset value offset.
In an example manner, when calculating a quantization parameter of any layer, the calculation module is configured to: determine a maximum value in input data of the layer, and calculate a quantization scale value of the layer by using the following formula:
where datamax represents the maximum value in the input data of the layer, and x represents a quantity of quantized bits.
In another example manner, when calculating a quantization parameter of any layer, the calculation module is configured to: determine a maximum value and a minimum value in input data of the layer; and calculate a quantization scale value and a quantization offset value of the layer by using the following formulas:
and
where datamax represents the maximum value in the input data of the layer, datamin represents the minimum value in the input data of the layer, and x represents a quantity of quantized bits.
In another example manner, the calculation module is further configured to: before determining the maximum value in input data of the layer, replace a value greater than a quantization threshold in the input data of the layer with the quantization threshold.
Optionally, each of the foregoing modules may be a hardware dedicated circuit, a software program module, or a combination of the two.
A third aspect of this application provides a device, including a processor and a memory, where the memory is configured to store an instruction, and the processor is configured to execute the instruction stored in the memory, so that the device performs the method according to the first aspect of this application.
A fourth aspect of this application provides a computer-readable storage medium, where the computer-readable storage medium stores an instruction, and when the instruction is executed by a computer or a processor, the computer or the processor is enabled to perform the method according to the first aspect of this application.
A fifth aspect of this application provides a computer program product, where when the computer program product is executed by a computer or a processor, the computer or the processor is enabled to perform the method according to the first aspect of this application.
A sixth aspect of this application provides a device, including a processor, and at least one of an image component and an audio component, where the image component and the audio component are configured to generate the data when a user uses the device, so that the processor is configured to perform the method according to the first aspect of this application.
According to the method and apparatus for quantizing a neural network model in a device provided in this application, the user calibration data is obtained and input into the neural network model to calculate the quantization parameter of each of the plurality of layers of the neural network model, and the to-be-quantized data is input into the neural network model to quantize the input data of each layer by using the quantization parameter of each layer. Because the user calibration data is generated based on the data generated by the device used by the user, the quantization parameter can be obtained online, and the quantization parameter matches the user data in the device, thereby improving quantization accuracy.
In the embodiments, a neural network is a network structure that imitates behavioral characteristics of an animal neural network for information processing, and can be implemented by software, hardware, or a combination thereof. The structure of the neural network can be represented by a neural network model, and therefore the neural network model is also briefly referred to as a neural network. A neural network model refers to programs and data that are obtained through training based on a large amount of data and that are used to perform neural network calculation, such as cognitive calculation.
For ease of understanding, the following describes a processing principle of the neural network in the embodiments of this application. For example, the processing of the neural network is a non-linear function ƒ(xi), for example, ƒ(xi)=max(0, xi). In some feasible embodiments, the processing function may be an activation function (ReLU), a hyperbolic tangent function (tanh), a sigmoid function (sigmoid), or the like. It is assumed that (x1, x2, x3) represents a one-dimensional input signal matrix, each x represents one piece of input data of the layer, (h1, h2, h3) represents an output signal matrix, Wij represents weight data between input xj and output hi, and a matrix formed by the weight data is a weight matrix. Then, a weight matrix W corresponding to the one-dimensional input signal matrix and the output signal matrix is shown in equation (1):
A relationship between the input signal and the output signal is shown in equation (2), where bi represents a bias value of the processing function of the neural network. The bias value is used to adjust input of the neural network to obtain an ideal output result.
The hidden layer is a memory unit of the neural network model and a memory function of the hidden layer is represented by a weight matrix. Each neuron generally corresponds to one piece of weight data. The weight matrix is usually large. Therefore, the weight matrix needs to be quantized, that is, a plurality of pieces of weight data are quantized. The quantization can be performed by using a weight quantization parameter. In addition to the quantization of the weight matrix of each layer, the quantization of the neural network model further includes quantization of the input data of each layer. The input data of each layer is quantized by using an input quantization parameter.
The weight quantization parameter and the input quantization parameter are floating point numbers. The weight quantization parameter of each layer is used to quantize the weight matrix of the layer to obtain quantized weight data. The weight quantization parameter of each layer is calculated independently. Therefore, the weight quantization parameters of various layers may be the same or different. The input quantization parameter of each layer is used to quantize the input data of the layer. The input quantization parameter of each layer is calculated independently. Therefore, the input quantization parameters of various layers may be the same or different. The weight matrix and the input data of each layer of the neural network model are quantized, so that a size of the neural network model becomes smaller, a running speed becomes higher, and accuracy is similar to that before quantization.
A neural network model includes quantized weight data, a weight quantization parameter, and an input quantization parameter. After the device manufacturer or the model provider generates weight data and a weight quantization parameter, the weight data and the weight quantization parameter are set in a device. The input quantization parameter can also be set in the device by the device manufacturer or the model provider, and can be updated in subsequent launching or use of the device.
Because an existing process of obtaining an input quantization parameter is completed by the device manufacturer or the model provider offline, a quantization error is relatively large. To resolve the foregoing problem, this application provides a method for quantizing a neural network model. In this quantization method, an input quantization parameter is obtained online, thereby improving accuracy of quantizing the neural network model. It should be understood that in this application, the input quantization parameter used to quantize each layer is also briefly referred to as a quantization parameter. In subsequent embodiments, a quantization parameter is used to represent an input quantization parameter for quantizing input data of any layer. The quantization parameter may be different from the weight quantization parameter, and is obtained online. Compared with the offline obtaining of the quantization parameter, the device manufacturer or the model provider does not need to set the quantization parameter, and the device does not need to be returned to a factory, so that a device that has been used by a user can independently obtain the quantization parameter. The quantization parameter can match the user's usage habits and common data, helping improve quantization accuracy.
In some feasible embodiments, the input data of the neural network model may be various forms of data such as audio data (or referred to as voice data), text data, image data, and temperature data. For example, the audio data may be voice data recorded by a recording device, voice data received by a mobile phone or a fixed phone during a call, or voice data sent by a radio station and received by a radio. The text data may be TXT text data, Word text data, PDF text data, or the like. The image data may be a landscape image shot by a camera, image data of a community environment captured by a monitoring device, facial data of a human face obtained by an access control system, or the like. The input signals of the neural network include other engineering signals that can be processed by various computers, which are not listed herein one by one. The processing performed by the hidden layer 102 of the neural network may be processing such as removing a noise signal mixed in the audio data to enhance the audio data, understanding specific content in the text data, and recognizing facial image data of a human face. The input data of the neural network model can be sequentially processed by a plurality of layers, and input data of each layer is processed output data of a previous layer. Therefore, each layer has its own input data, and only the input data of the first layer (the input layer) is the input data of the neural network model. The input data of the remaining layers is the output data of the neural network model processed by at least one previous layer, that is, the processing result of the at least one layer.
An embodiment of this application provides a specific implementation scenario of the neural network model 100. As shown in
An embodiment of this application provides another specific implementation scenario of the neural network model 100. As shown in
The method provided in the embodiments of this application can be performed by a quantization device. The quantization device may be the foregoing terminal device, or may be a server or a network device. The terminal device is also referred to as a terminal, user equipment (UE), a mobile station (MS), a mobile terminal (MT), or the like. The terminal device may be a mobile phone, a tablet computer (Pad), a computer with a wireless sending/receiving function, a virtual reality (VR) terminal device, an augmented reality (AR) terminal device, a wireless terminal in industrial control, a wireless terminal in a self-driving car, a wireless terminal in remote medical surgery, a wireless terminal in a smart grid, a wireless terminal in transportation safety, a wireless terminal in a smart city, a wireless terminal in a smart home, or the like.
The memory 402 is configured to store various types of data. For example, the data includes any application program or method instruction operating on the device 400, contact data, address book data, a message, a picture, a video, and the like. The memory 402 further includes a neural network model and input data to be input into the neural network model. For example, the memory 402 includes a weight quantization parameter in the neural network model, a quantized weight matrix (that is, quantized weight data), and an input quantization parameter. The memory 402 may be implemented by any type of volatile storage device, any type of non-volatile storage device, or a combination thereof, such as a static random access memory (SRAM), an electrically erasable programmable read-only memory (EEPROM), an erasable programmable read-only memory (EPROM), a programmable read-only memory (PROM), a read-only memory (ROM), a magnetic memory, a flash memory, a magnetic disk, or an optical disc.
The processor 401 is configured to execute data stored in the memory 402 to implement the function of the neural network 100 shown in
Therefore, the neural network 100 described in this embodiment can be implemented by the processor 401 in
The bus 405 may be an industry standard architecture (ISA) bus, a peripheral component interconnect (PCI) bus, an extended industry standard architecture (EISA) bus, or the like. The bus 405 may be classified into an address bus, a data bus, a control bus, and the like. For ease of representation, the bus 405 in the accompanying drawings of this application is not limited to only one bus or only one type of bus.
The audio component 403 may include an audio codec device or an audio enhancement device and is configured to form audio data: the audio component 403 may further include an audio data input/output device, such as a sensor. For example, the audio component 403 further includes a microphone in addition to the audio codec device or the audio enhancement device.
The image component 404 may include an image sensor and an image signal processor (ISP). The image sensor is configured to collect an image signal, and the image signal processor is configured to form image data based on the image signal collected by the image sensor; the image component 404 may alternatively be a video component for collecting a video, where the video includes a series of image data.
The structure of the quantization device shown in
For ease of understanding, the following describes a specific quantization method in an embodiment of this application.
Step S501: Obtain user calibration data, where the user calibration data is generated based on data generated by a terminal device use by a user. The data generated by the quantization device used by the user may include different types of data. For example, the data generated by the quantization device used by the user includes at least one of audio data or image data, for example, the data is generated by an audio component 403 or an image component 404. The data generated by the quantization device used by the user may include some useless data. The quantization device can screen or tailor the data generated by the quantization device used by the user, to obtain the user calibration data. For example, the image data generated by the quantization device used by the user is tailored to a preset size to obtain first image data, and the audio data generated by the quantization device used by the user is tailored to preset duration to obtain first audio data. Alternatively, redundant data in the data generated by the quantization device is removed to obtain the user calibration data.
Alternatively, the user calibration data may be a part of the data generated by the quantization device, or a variant of the data generated by the quantization device. For example, the data generated by the terminal device may be generated by the processor by running a user-specified service or another service, or may be generated by a component other than the processor, such as the audio component or the image component described above. The audio component may be an audio codec device or an audio enhancement device and is configured to form audio data. The image component may be an image signal processor (ISP), which is configured to form image data based on an image signal collected by an image sensor: the image component may alternatively be a video component for collecting a video, where the video includes a series of image data. The image data and the audio data can be used as user data to obtain the user calibration data after further screening.
Optionally, the user calibration data not only can be obtained based on the data generated by the device used by the user, but also may include a part of common preset calibration data. The common preset calibration data is data used by a device manufacturer or a model provider when calculating a quantization parameter of each layer of the neural network model.
In this embodiment of the present invention, obtaining user calibration data includes generating the user calibration data. For example, an audio component, a video component, another component, or the processor 401 itself can generate the user calibration data, so that the processor 401 uses the user calibration data to generate a quantization parameter. For example, an audio component, a video component, another component, or the processor 401 can generate data when the device is used by the user, where the data is referred to as data generated by the device used by the user. The audio component, the video component, the another component, or the processor 401 can further process the data generated by the device used by the user, such as screening or tailoring, to obtain the user calibration data.
Alternatively, the data generated by the device used by the user can be stored in a memory, such as a memory 402, and be invoked by the audio component, the video component, the another component, or the processor 401 when a quantization parameter needs to be calculated, to generate the user calibration data. Alternatively, the user calibration data may be stored in the memory, so that the processor 401 invokes the user calibration data in a subsequent process of calculating the quantization parameter.
Step S502: Input the user calibration data into the neural network model, and calculate a quantization parameter (also referred to as an input quantization parameter) of each of a plurality of layers of the neural network model. The neural network model can be obtained through training by the device manufacturer or the model provider. The neural network model is preset in the quantization device when the quantization device is delivered. Alternatively, during use of the quantization device, the quantization device remotely downloads the neural network model from the device manufacturer or the model provider, and saves the neural network model. When quantization is needed, the quantization device reads the neural network model from the memory. Each layer of the neural network model obtained through training by the device manufacturer or the model provider may further have initial quantization parameters, and the initial quantization parameters include a weight quantization parameter and an initial input quantization parameter. The quantization parameter generated in the method of this embodiment can be used to replace the initial input quantization parameter. Therefore, the user calibration data is equivalent to an updated quantization parameter that is obtained by calibrating the initial input quantization parameter, and the quantization parameter better matches actual use requirements of the user.
In this embodiment, the quantization parameter includes a quantization scale value scaledata, or includes a quantization scale value scaledata and a quantization offset value offset. Correspondingly, the quantization method can be divided into a quantization method without an offset and a quantization method with an offset. Optionally, the quantization method without an offset is subdivided into a quantization method with saturation and without an offset, and a quantization method without saturation and without an offset. Similarly, the quantization method with an offset is subdivided into a quantization method with saturation and with an offset, and a quantization method without saturation and with an offset.
For example, when the quantization method without saturation and without an offset is used, calculating a quantization parameter of any layer includes: first determining a maximum value in input data of the layer; and then calculating a quantization scale value of the layer by using the following formula 1:
where, datamax represents the maximum value in the input data of the layer, and x represents a quantity of quantized bits, indicating a quantity of bits of the quantized input data, for example, a value of x in INT8 quantization is 8, indicating that the quantity of bits of the quantized input data is 8, and the value of x in INT4 quantization is 4; and scaledata represents a floating point number, which may be a 32-bit, 64-bit, or 16-bit floating point number. For the quantization without an offset, a representation domain of INTx needs to be symmetric (that is, a quantity of negative numbers is equal to a quantity of positive numbers). Therefore, the representation domain of INTx is changed from [−(2x-1), (2x-1−1)] to [−(2x-1−1), (2x-1−1)]. Correspondingly, for the INT8 quantization, a floating point number needs to be quantized into an 8-bit integer, and a data range of the INT8 quantization is [−127, 127]. For the INT4 quantization, a floating point number needs to be quantized into a 4-bit integer, and a data range of the INT4 quantization is [−15, 15]. The following uses the INT8 quantization as an example for description.
The input data of the layer may be a matrix, each piece of data in the matrix is an 8-bit, 32-bit, or 64-bit floating point number, and the input data of the layer is the output data of the previous layer. Optionally, when the output data of each layer is calculated, a quantization parameter of the layer calculated by the quantization device can be used to quantize the input data of the layer to obtain first quantized input data, and calculate the output data of the layer; or an initial quantization parameter of the neural network model can be used to quantize the input data of the layer to obtain second quantized input data, and calculate the output data of the layer. The initial quantization parameter is obtained through training by the device manufacturer or the model provider.
It is assumed that the input data of the layer is a 3×3 matrix data_cali_01:
data_cali_01=[[[[0.72639324 0.71439985 0.24460189][0.51045154 0.22901999 0.43988897][0.40455139 0.75840769 0.91973927]]]]
Then, datamax=0.91973927. If the INT8 quantization is performed, then
When the quantization method with saturation and without an offset is used, a quantization threshold is introduced. Correspondingly, before the maximum value in the input data of the layer is determined, data greater than the quantization threshold in the input data of the layer is replaced with the quantization threshold. Subsequent steps are the same as those of the quantization method without saturation and without an offset, and details are not described herein again. In the quantization method without saturation, all floating point numbers in the input data can be covered by the value range of INT8. This solution ensures the data range but compromises a specific degree of accuracy. In the quantization method with saturation, a reasonable quantization threshold is selected to correspond to a largest INT8 representation range, while the accuracy and the range are considered, and a value exceeding the quantization threshold is processed in a saturation manner, that is, replaced with the quantization threshold.
When the quantization method without saturation and with an offset is used, calculating a quantization parameter of any layer includes: first determining a maximum value and a minimum value in input data of the layer; and then calculating a quantization scale value and a quantization offset value of the layer by using the following formula 2 and formula 3:
where, datamax represents the maximum value in the input data of the layer, datamin represents the minimum value in the input data of the layer, x represents a quantity of quantized bits, and the round function is used to round the data to a nearest integer.
It is assumed that the input data of the layer is data_cali_01, then datamax=0.91973927, and datamin=0.22901999. If the INT8 quantization is performed, then
When the quantization method with saturation and with an offset is used, before the maximum value in the input data of the layer is determined, data greater than the quantization threshold in the input data of the layer is replaced with the quantization threshold.
In this embodiment, a quantization parameter of each layer of the neural network model is calculated independently. Therefore, different quantization methods may be used for different layers, or the same quantization method may be used for different layers.
Step S503: Input to-be-quantized data into the neural network model to quantize input data of each layer by using the quantization parameter of each layer. The to-be-quantized data may be generated based on the data generated by the quantization device used by the user. However, the to-be-quantized data is different from the user calibration data. The to-be-quantized data needs to be processed by the neural network to obtain a processing result, and the user calibration data is used to generate a quantization parameter. The quantization parameter can be used to replace a default initial input quantization parameter that is set by the device manufacturer or the model provider.
In the quantization method without an offset, input data of any layer can be quantized by using formula 4:
where, dataInt8 represents quantized input data of the layer, datafloat represents the input data of the layer, and scaledata represents a quantization scale value of the layer.
In the quantization method with an offset, input data of any layer can be quantized by using formula 5:
It should be noted that steps 501 and 502 are performed at a quantization parameter calculation stage, and step 503 of quantizing the input data of each layer is performed at a quantization stage. The quantization parameter calculation stage and the quantization stage are two independent stages. The quantization parameter calculation stage is carried out before the quantization stage. After quantization parameter calculation is completed, a quantization process may be executed immediately, or after a period of time. The quantization parameter can be used in a plurality of quantization processes. In a life cycle of the quantization device, the quantization parameter calculation process may be executed only once, or the quantization parameter calculation may be executed a plurality of times. For example, the quantization parameter calculation process may be executed periodically (monthly, semiannually, or annually) to calibrate or update the quantization parameter. In an embodiment, the user calibration data includes at least one of first audio data or first image data obtained at the quantization parameter calculation stage, and the data is used to obtain the quantization parameter. The to-be-quantized data includes at least one of second audio data or second image data obtained at the quantization stage.
For example, the data generated by the device used by the user can be pre-stored in a memory, and when quantization parameter update time is reached or in a case of being triggered by a specific condition, the quantization parameter calculation stage can be entered to perform steps 501 and 502. Alternatively, the quantization parameter calculation stage can last for a long time, that is, whenever the user uses the device, step 501 can be performed to enter the quantization parameter calculation stage. To be specific, the user calibration data is generated based on the data generated by the device used by the user, and then is stored in the memory. When preset time is reached or in a case of being triggered by a specific condition, step 502 can be performed to further calculate the quantization parameter, and after the calculation is completed, the quantization parameter calculation stage exits, so as to wait for a subsequent quantization process.
Optionally, at the quantization stage, the quantization device can quantize the input data of each layer in real time. To-be-quantized data used for each quantization is different. When the user has related usage requirements, such as game, photographing or voice requirements, the quantization device can initiate the quantization process and perform step 503. For example, the user can trigger execution of a neural network task by performing an operation on the quantization device, to perform a quantization operation. The quantization parameter calculation stage can be periodically initiated by the quantization device or the processor 401 in the quantization device or its equivalent dedicated hardware. To avoid impact of the quantization parameter calculation process on the user's usage, the quantization device can also determine, based on a quantization period and a status of the quantization device, whether to initiate the quantization parameter calculation. Therefore, the quantization parameter calculation stage can be entered when a specific condition is met. For example, when the quantization period expires, it is determined whether the quantization device is in an unused state or in a charging state. When the quantization device is in an unused state or in a charging state, steps 501 and 502 are initiated to update or calculate the quantization parameter, so that the quantization calculation step 503 is performed subsequently when the user has a requirement. Therefore, the quantization parameter calculation stage may be triggered by the neural network, the processor 401, or the quantization device periodically or when there is no quantization task, to avoid interfering with the quantization process. That there is no quantization task may include but is not limited to that the quantization device is in an unused state or in a charging state, for example, may also include that the neural network or the processor 401 is in an idle or low power consumption state.
Further, the quantization parameter calculation stage and the quantization stage may overlap, and do not have to be two completely isolated stages. Therefore, the quantization device can execute the quantization process synchronously when updating or calculating the quantization parameter. This is not limited in this embodiment. For example, the quantization device or the processor 401 can generate a quantization parameter based on data generated by the device used by the user, and further use the quantization parameter to quantize the data. Therefore, the to-be-quantized data and the data generated by the device used by the user may be at least partly identical, or the to-be-quantized data and the user calibration data may be at least partly identical. The terms “first” and “second” mentioned in this embodiment are used to distinguish different names or features, and are not used to limit the order and specific meanings of nouns.
In this embodiment, the user calibration data is input into the neural network model. Because the user calibration data is generated based on the data generated by the device used by the user, the quantization parameter can be calculated based on the user's personalized data, so that the quantization parameter can match the user data, improving quantization accuracy. In the conventional technology, a set of common calibration data is usually used to calculate a quantization parameter of each layer. The following uses specific examples to compare quantization errors of the two.
The foregoing data_cali_01 is common calibration data used by the device manufacturer or the model provider, and the user calibration data used in this embodiment of this application is data_cali_02:
data_cali_02=[[[[0.12639324 0.11439985−0.35539811][−0.08954846−0.37098001−0.16011103][−0.19544861 0.15840769 0.31973927]]]]
When the quantization method without saturation and without an offset is used, in the data_cali_02, datamax=0.37098001, and
scaledata=0.0029211 is used to quantize the data_cali_02 to obtain the following quantized input data:
data_val_quant2=[[[[43. 39. −122.][−31. −127. −55.][−67. 54. 109.]]]]
When scaledata=0.007242 is used to quantize the data_cali_01, quantized input data obtained is as follows:
data_val_quant1=[[[[17. 16. −49.][−13. −51. −22.][−27. 22. 44.]]]]
After the quantized input data is obtained, when the quantization method without an offset is used, restored data of the input data can be obtained according to the following formula 6; when the quantization method with an offset is used, the restored data of the input data can be obtained according to the following formula 7:
datafloat=scaledata*dataInt8 (Formula 6)
datafloat=scaledata*(dataInt8+offset) (Formula 7)
The symbol * in formula 6 and formula 7 represents a multiplication operation and is used to replace the symbol “×”.
When the quantization method without an offset is used, the restored data of the data_cali_01 is as follows:
data_val_quant_dequant1=[[[[0.12311471 0.11587266−0.35486003][−0.09414654−0.36934412−0.15932491][−0.19553512 0.15932491 0.31864983]]]]
When the quantization method without an offset is used, the restored data of the data_cali_02 is as follows:
data_val_quant_dequant2=[[[[0.1256074 0.113923−0.3563745][−0.09055418−0.37098001−0.16066063][−0.19571386 0.15773953 0.31840017]]]]
The data_cali_01 and the data_cali_02 are verified by using the following verification data data_val:
data_val=[[[[0.12539324 0.11339985−0.35639811][−0.09054846−0.37198001−0.16111103][−0.19644861 015740769 0.31873927]]]]
The data_val is user data that is generated by the quantization device being used by the user next time and that is obtained through simulation. For example, the processor or another component can use user data generated by the quantization device being used by the user recently, to obtain the data_val through simulation. The data_val can be used to obtain a quantization error matrix corresponding to the data_cali_01 as follows:
data_val_quant_loss1=[[[[2.27853457e−03−2.47281394e−03−1.53807669e−03][3.59807945e−03−2.63589370e−03−1.78611709e−03][−9.13489606e−04−1.91722291e−03 8.94441732e−05]]]]
A quantization error matrix corresponding to the data_cali_02 is as follows:
data_val_quant_loss2=[[[[−2.14164961e−04−5.23145197e−04−2.36122047e−05][5.71566929e−06−1.00000000e−03−4.50395748e−4][−7.34746457e−04−3.31841811e−04 3.39103937e−04]]]]
In the foregoing quantization error matrices, e-03 represents 10{circumflex over ( )}−3 (that is, 10 to the power of minus three), and xe-03 represents x×10{circumflex over ( )}−3: similarly, e-04 represents 10 to the power of minus four, e-05 represents 10 to the power of minus five, and e-06 represents 10 to the power of minus six.
The foregoing quantization error matrices are obtained by using a difference between the verification data and the restored data. Alternatively, when the quantization error matrices are calculated, the error function loss may also be the square root of the difference between the verification data and the restored data. This is not limited in this embodiment. According to the quantization error matrices, error ratios of the two pieces of calibration data can be obtained:
Σ|lossdata-cali-01|=0.0172
Σ|lossdata-cali-02|=0.0036
In this embodiment, the error ratio is obtained by summing up absolute values of all pieces of data in the quantization error matrix. Based on comparison between the error ratios of the two pieces of calibration data, it can be learned that the error of using the user calibration data is reduced by 4.75 times compared with using the common calibration data.
In this embodiment, the user calibration data is obtained and input into the neural network model to calculate the quantization parameter of each of the plurality of layers of the neural network model, and the to-be-quantized data is input into the neural network model to quantize the input data of each layer by using the quantization parameter of each layer. Because the user calibration data is generated based on the data generated by the terminal device used by the user, the neural network model can be updated in the device, that is, the quantization parameter is updated online, and the quantization parameter matches the user data in the device, thereby improving quantization accuracy.
It should be noted that the foregoing solution is applicable to a process of quantizing all of the plurality of layers of the neural network model. Certainly, if only some layers in the neural network model need to be quantized, and other layers do not need to be quantized, the foregoing solution is still applicable. For each of the plurality of layers that need to be quantized in the neural network model, the foregoing solution is used for quantization. For a layer that does not need to be quantized, the foregoing solution may not be executed. Therefore, in the foregoing embodiments, the plurality of layers that perform quantization parameter calculation and quantization processing may be at least some of all the layers in the neural network.
In an example manner, the user calibration data includes at least one of first audio data or first image data; and the to-be-quantized data includes at least one of second audio data or second image data.
In an example manner, the user calibration data is obtained by screening or tailoring the data generated by the device used by the user.
In an example manner, the quantization parameter includes a quantization scale value scaledata, or includes a quantization scale value scaledata and a quantization offset value offset.
In an example manner, when calculating a quantization parameter of any layer, the calculation module 602 is configured to: determine a maximum value in input data of the layer; and calculate a quantization scale value of the layer by using the following formula:
where, datamax represents the maximum value in the input data of the layer, and X represents a quantity of quantized bits.
In another example manner, when calculating a quantization parameter of any layer, the calculation module 602 is configured to: determine a maximum value and a minimum value in input data of the layer; and calculate a quantization scale value and a quantization offset value of the layer by using the following formulas:
where, datamax represents the maximum value in the input data of the layer, datamin represents the minimum value in the input data of the layer, and x represents a quantity of quantized bits.
In another example manner, the calculation module 602 is further configured to: before determining the maximum value in input data of the layer, replace data greater than a quantization threshold in the input data of the layer with the quantization threshold.
The apparatus provided in this embodiment can be configured to perform the method in the first embodiment. A specific implementation and a technical effect are similar to those of the method in the first embodiment, and details are not described herein again.
It should be noted that the quantization apparatus corresponding to
If the modules or method steps in this embodiment are implemented in a form of a software function unit and sold or used as an independent product, the functions may be stored in a computer-readable storage medium. Based on such an understanding, at least a part of the technical solutions of this application may be implemented in a form of a software product. The computer software product is stored in a storage medium, for example, the memory 402 mentioned in the foregoing embodiments. The storage medium includes several instructions for instructing a computer device (which may be a personal computer, a server, a device, or the like) to perform all or some of the steps of the methods described in the embodiments of this application. The foregoing storage medium includes: any medium that can store program code, such as a USB flash drive, a removable hard disk, a read-only memory (ROM), a random access memory (RAM), a magnetic disk, or an optical disc.
The foregoing descriptions are merely specific implementations of this application, but are not intended to limit the protection scope of this application. Any variation or replacement readily figured out by a person skilled in the art within the technical scope disclosed in this application shall fall within the protection scope of this application. Therefore, the protection scope of this application shall be subject to the protection scope of the claims.
This application is a continuation of International Application No. PCT/CN2018/106919, filed on Sep. 21, 2018, the disclosure of which is hereby incorporated by reference in its entirety.
Number | Date | Country | |
---|---|---|---|
Parent | PCT/CN2018/106919 | Sep 2018 | US |
Child | 17197677 | US |