This application relates generally to techniques for adapting a neural network being trained on one system for use on a target device. The techniques reduce degradation in performance of the neural network resulting from quantization error when employed by the target device. The techniques involve training the neural network by injecting noise into layer outputs of the neural network during training.
A neural network may include a sequence of layers. A layer may consist of a multiplication operation performed between weights of the layer and inputs to the layer. A layer may further include a non-linear function (e.g., sigmoid) applied element-wise to a result of the multiplication operation. A layer between an input and output layer of a neural network may be referred to as an interior layer. A neural network may have one or more interior layers. A computing device may determine an output of the neural network for an input by using the sequence of layers of the neural network to determine the output.
A system used to train a neural network (“training system”) may have a different configuration and/or hardware components than a target device that employs the trained neural network. For example, the training system may use a higher precision format to represent neural network parameters (e.g., weights) than the target device. In another example, the target device may use analog and digital processing hardware to compute an output of the neural network whereas the training system may have used only digital processing hardware to train the neural network. The difference in configuration and/or hardware components of the target device may introduce quantization error into parameters of the neural network, and thus affect performance of the neural network on the target device. Described herein is a training system that trains a neural network for use on a target device that reduces loss in performance resulting from quantization error.
According to some embodiments, a method of training a neural network for use on a device is provided. The neural network comprises a plurality of layers and a plurality of parameters. The method comprises: using a processor to perform: obtaining training data comprising a plurality of sample inputs; training the neural network using the training data, the training comprising, for each of at least some of the plurality of sample inputs: determining, using the sample input, a layer output of at least one layer of the plurality of layers of the neural network; obtaining a noise sample from a quantization noise model for the device; injecting the noise sample into the layer output; determining an output of the neural network for the sample input using the layer output injected with the noise sample; and updating the plurality of parameters of the neural network using the output.
According to some embodiments, a system for training a neural network for use on a device separate from the system is provided. The neural network comprises a plurality of layers and a plurality of parameters. The system comprises: a processor; and a non-transitory computer-readable storage medium storing instructions that, when executed by the processor, cause the processor to: obtain training data comprising a plurality of sample inputs; train the neural network using the training data, the training comprising, for each of at least some of the plurality of sample inputs: determining, using the sample input, a layer output of at least one layer of the plurality of layers of the neural network; obtaining a noise sample from a quantization noise model for the device; injecting the noise sample into the layer output; determining an output of the neural network for the sample input using the layer output injected with the noise sample; and updating the plurality of parameters of the neural network using the output.
According to some embodiments, a non-transitory computer-readable medium storing instructions is provided. The instructions, when executed by a processor, cause the processor to perform: obtaining training data comprising a plurality of sample inputs; training a neural network using training data, the neural network comprising a plurality of layers and a plurality of parameters, the training comprising, for each of at least some of the plurality of sample inputs: determining, using the sample input, a layer output of at least one layer of the plurality of layers of the neural network; obtaining a noise sample from a quantization noise model for the device; injecting the noise sample into the layer output; determining an output of the neural network for the sample input using the layer output injected with the noise sample; and updating the plurality of parameters of the neural network using the output.
Various aspects and embodiments will be described herein with reference to the following figures. It should be appreciated that the figures are not necessarily drawn to scale. Items appearing in multiple figures are indicated by the same or a similar reference number in all the figures in which they appear.
Described herein are techniques of adapting a neural network to a device. The techniques mitigate loss in performance of a trained neural network on the device due to quantization error. A neural network may be trained using one computing device (“training system”) and subsequently deployed for use on another computing device (“target device”). The target device may have a different configuration and/or different hardware components than the training system. For example, the target device may use a lower precision format (e.g., a lower bit-width) to represent neural network parameters. As another example, the target device may include both analog and digital components, and an analog-to-digital converter (ADC). The different configuration and/or hardware components in the target device may result in quantization of neural network parameters and/or values computed using the neural network parameters. The neural network may perform worse on the target device than on the training system as a result of error caused by the quantization. For example, the target device's use of a lower precision (e.g., bit-width) to represent neural network parameter values than a precision used by the training system may introduce quantization error into computations involving the neural network. As another example, noise from an ADC of the target device may introduce quantization error into computations involving the neural network. The quantization error may cause layer outputs of a neural network determined by the target device to deviate from those determined by the training system, and thus reduce performance of the neural network on the target device.
Some conventional techniques mitigate loss in performance due to quantization error by increasing the precision used by the target device. For example, the bit-width used by the target device may be increased and/or a floating point format may be used to represent parameter values instead of a fixed point format. These conventional techniques, however, increase power consumption and/or area of digital circuitry in the target device and may reduce computational efficiency in using the neural network. Other conventional techniques may limit performance loss due to quantization by limiting the target device to digital components in order to eliminate quantization error resulting from ADC noise. However, these conventional techniques prevent the target device from taking advantage of efficiency improvements achieved by performing certain computations (e.g., multiplication) in analog.
The inventors have recognized the above-described shortcomings of conventional techniques in mitigating performance loss due to quantization error. Accordingly, the inventors have developed techniques of training a neural network that mitigate performance loss due to quantization error. The techniques incorporate noise that simulates quantization error of the target device into training of the neural network. The parameters of a neural network learned through the techniques are thus more robust to quantization error on the target device. Unlike conventional techniques, the techniques described herein mitigate performance loss without requiring an increase in precision of the target device (e.g., an increased bit-width). The techniques do not increase power consumption and/or area of digital circuitry in the target device nor do they decrease computational efficiency in using the neural network. Moreover, the techniques do not limit the target device to digital components, and thus allow the target device to take advantage of efficiency improvements provided by analog components.
In some embodiments, a training system trains a neural network using a quantization noise model for a device. During training, the training system obtains noise samples from the quantization noise model and injects the noise samples into outputs of one or more layers of the neural network (“layer outputs”). The training system may perform an iterative training technique to train the neural network using training data consisting of sample inputs. For each sample input, the training system determines, using the sample input, one or more layer outputs of the neural network. The system obtains noise sample(s) from the quantization noise model for the device and injects the noise sample(s) into the layer output(s). The system determines a final output of the neural network (e.g., an output of the last layer of the neural network) for the sample input using the layer output(s) injected with the noise sample(s). The system then updates parameters of the neural network using the final output (e.g., based on a difference between the final output and a label associated with the sample input).
Some embodiments described herein address all the above-described issues that the inventors have recognized with conventional techniques of mitigating performance loss due to quantization error. However, it should be appreciated that not every embodiment described herein addresses every one of these issues. It should also be appreciated that embodiments of the technology described herein may be used for purposes other than addressing the above-discussed issues of conventional techniques.
Example embodiments are described herein using a neural network as an example machine learning model. However, some embodiments may adapt other machine learning models to a target device. For example, some embodiments may adapt a support vector machine (SVM), a logistic regression model, a linear regression model, or other suitable machine learning model to a target device. The system may be configured to obtain training data comprising a plurality of sample inputs. The system may be configured to train a machine learning model using the training data. The system may be configured to, for each of at least some of the plurality of sample inputs, determine, using the sample input, an intermediate output or final output of the machine learning model. The system may be configured to obtain a noise sample from a quantization noise model for the device and inject the noise sample into the intermediate output or the final output. The system may be configured to update the parameter(s) of the machine learning model using the final output injected with the noise sample or a final output determined using the intermediate output injected with the noise sample.
The training system 102 may be any suitable computing device. In some embodiments, the training system 102 may be a computing device as described herein with reference to
As shown in
The training system 102 includes storage 102B. In some embodiments, the storage 102B may be memory of the training system 102. For example, the storage 102B may be a hard drive (e.g., solid state hard drive and/or hard disk drive) of the training system 102. In some embodiments, the storage 102B may be external to the training system 102. For example, the storage 102B may be a remote database server from which the training system 102 may obtain data. The training system 102 may be configured to access the remote database server via a network (e.g., the Internet, local area connection (LAN), or another suitable network). In some embodiments, the storage 102B may be cloud-based storage.
As shown in
The storage 102B may store noise model parameters. The noise model parameters may define one or more quantization noise models for a device (e.g., target device 104) used by the training system 102 for training the neural network 106. A quantization noise model may model quantization error of a target device (e.g., target device 104). For example, the quantization noise model may model quantization error resulting from use of a lower precision (e.g., lower bit-width) by the target device than that of the processor 102A, use of a different format for representing numbers, and/or noise from an analog-to-digital converter (ADC) of the target device. In some embodiments, a quantization noise model may be defined by one or more parameters. For example, the quantization noise model may be a Gaussian distribution defined by mean and variance parameters, a uniform distribution defined by minimum and maximum values, an Irwin-Hall distribution defined by a mean and variance, or other distribution. In some embodiments, a quantization noise model may be an unspecified distribution with parameters determined from empirical observations. For example, the quantization noise model may be a distribution of differences (e.g., in a histogram) between layer outputs of a target device (e.g., target device 104) and those of the training system 102 for one or more neural networks.
The training system 102 may be configured to use the processor 102A to train the neural network 106 using training data stored in the storage 102B. In some embodiments, the training system 102 may be configured to train the neural network 106 using a supervised learning technique. For example, the training system 102 may perform gradient descent (e.g., stochastic gradient descent, batch gradient descent, mini-batch gradient descent, etc.) to learn parameters (e.g., weights and/or biases) of the neural network 106. In some embodiments, the training system 102 may be configured to train the neural network 106 using an unsupervised learning technique. For example, the training system 102 may use a clustering algorithm to train the neural network 106. In some embodiments, the training system 102 may be configured to train the neural network 106 using a semi-supervised learning technique. For example, the training system 102 may determine a set of classes using clustering, label sample inputs with the determined set of classes, and then use a supervised learning technique to train the neural network 106 using the labeled sampled input.
The neural network 106 may be any suitable neural network. For example, the neural network 106 may be a convolutional neural network (CNN), a recurrent neural network (RNN), a transformer neural network, or any other suitable type of neural network. The neural network 106 includes parameters 106A that are to be learned during training. The parameters 106A may be weights or coefficients of the neural network 106 that are learned during training. For example, the parameters 106A may be iteratively updated during training (e.g., during performance of gradient descent). In some embodiments, the parameters 106A may be randomized values. In some embodiments, the parameters 106A may be parameters 106A learned from previously performed training. For example, the neural network 106 with parameters 106A may have been obtained by training another neural network.
The neural network 106 may include multiple layers.
A layer of neural network 106 may be a different type of layer than those illustrated in
In some embodiments, the training system 102 may be configured to incorporate noise injection into training of the neural network 106. The training system 102 may be configured to inject noise into layer outputs of the neural network 106 during training. For example, the training system 102 may perform iterative training (e.g., gradient descent) using sample inputs in which the training system 102 injects noise during at least some training iterations. In some embodiments, the training system 102 may be configured to inject noise in a training iteration by: (1) determining a layer output of at least one layer of the neural network 106; (2) obtaining a noise sample from a quantization noise model for a target device; and (3) injecting the noise sample into the layer output. The training system 102 may be configured to inject the noise sample into the layer output by combining the layer output with the noise sample. In some embodiments, the training system 102 may be configured to additively inject the noise sample into the layer output. For example, the layer output may include multiple output values and the noise sample may include multiple noise values corresponding to respective output values. The training system 102 may sum the layer output values with the corresponding noise values of the noise sample. In some embodiments, the training system 102 may be configured to multiplicatively inject the noise sample into the layer output. The training system 102 may multiply layer output values with corresponding noise values of the noise sample (e.g., using matrix element-wise multiplication).
In some embodiments, the training system 102 may be configured to determine an output of the neural network 106 for a sample input using one or more layer outputs injected with noise sample(s). The training system 102 may be configured to use a layer output injected with a noise sample as input to a subsequent layer of the neural network. An output of the neural network 106 may thus simulate an effect of quantization error modeled by a quantization noise model on the neural network 106. The training system 102 may be configured to update the parameters 106A (e.g., weights) of the neural network 106 using the determined output. For example, the training system 102 may determine a gradient of a loss function and update the parameters 106A by adjusting (e.g., increasing or decreasing) the parameters 106A by a proportion of the determined gradient. The training system 102 may then select another sample input and repeat steps of noise injection, determination of an output, and updating of the parameters 106A. In this manner the training system 102 may be configured to iteratively train neural network 106 to obtain trained neural network 108 with parameters 108A.
The training system 102 may be configured to provide the trained neural network 108 to the target device 104 for use by the target device 104. The training system 102 may be configured to provide the trained neural network 108 to the target device 104 by providing the parameters 108A to the target device 104. In some embodiments, the training system 102 may be configured to be communicatively coupled to the target device 104. For example, the training system 102 may communicate with the target device 104 through a communication network (e.g., the Internet). The training system 102 may provide the trained neural network 108 to the target device 104 through the communication network. In another example, the training system 102 may be connected to the target device 104 with a wired connection through which it may transmit the trained neural network 108 to the target device 104.
The target device 104 may be any suitable computing device. In some embodiments, the target device 104 may be a computing device as described herein with reference to
As shown in
In some embodiments, the processor(s) 104A may be configured to use a format to represent numbers. For example, the processor(s) 104A may use floating point format to represent numbers. In another example, the processor(s) 104A may use a fixed point format to represent numbers. In some embodiments, the format used by the processor(s) 104A may be different than the one used by the processor(s) 102A of the training system 102. For example, the processor(s) 102A may use a floating point format while the processor(s) 104A may use a fixed point format. The difference in format may introduce quantization error into computations involving the trained neural network 108.
As shown in
As shown in
The target device 104 may be configured to use the trained neural network 108 to generate an inference output 114 for a set of input data 112. The target device 104 may be configured to generate input to the neural network 108 using the data 112. The input may be an image, matrix, vector, tensor, or any other suitable data structure. For example, the target device 104 may determine a set of one or more features and provide the set of feature(s) as input to the neural network 108 to obtain the inference output 114. As an illustrative example, the neural network 108 may be trained to enhance images input to the target device 104. In this example, the data 112 may be pixel values of an image. The target device 104 may use the pixel values of the image to generate input (e.g., an input image, input matrix, or input vector) to the neural network 108. The target device 104 may use the parameters 108A of the neural network 108 to generate an enhancement of the image. As another example, the neural network 108 may be trained to diagnose a disease. In this example, the data 112 may be diagnostic scans of a patient. The target device 104 may use the diagnostic scans of the patient to generate input to the neural network 108, and use the parameters 108A to determine a classification of whether the patient is diagnosed as having the disease or not.
In some embodiments, the training server 202 may be a computer system for training a neural network. For example, the training system 102 described herein with reference to
In some embodiments, the device 204 may be target device 104 described herein with reference to
In some embodiments, the network 206 may be any network through which the training server 202 and the device 204 can communicate. In some embodiments, the network 206 may be the Internet, a local area network (LAN), a wide area network (WAN), a cellular network, an ad hoc network, and/or any other suitable type of network. In some embodiments, the network 206 may include a wired connection, a wireless connection, or any combination thereof.
Prior to beginning process 300, the system performing process 300 may obtain a neural network. The neural network may have parameters (e.g., weights). In some embodiments, the neural network may be a previously trained neural network. The parameters may have been learned from a previously performed training. For example, the neural network may have been previously trained by the system by performing process 300. In another example, the neural network may have been previously trained using another training technique. The system may perform process 300 to further train the previously trained neural network. For example, the system may perform process 300 to further train the neural network to be robust to quantization error that would be present on a target device (e.g., target device 104). In some embodiments, the neural network may be an untrained neural network. For example, the parameters of the neural network may be initialized to random values that need to be learned by performing process 300.
Process 300 begins at block 302, where the system performing process 300 obtains training data comprising multiple sample inputs. In some embodiments, the system may be configured to obtain the sample inputs by: (1) obtaining sets of input data; and (2) generating the sample inputs using the sets of input data. In some embodiments, a sample input may be a set of input features generated by the system. The system may be configured to preprocess input data to generate the set of input features. As an illustrative example, the input data may be an image. The system may be configured to generate a sample input for the image by: (1) obtaining pixel values of the image; and (2) storing the pixel values in a data structure to obtain the sample input. For example, the data structure may be a matrix, vector, tensor, or other type of data structure. In some embodiments, the system may be configured to preprocess input data by normalizing the input data. For example, the system may normalize pixel values based on a minimum and maximum pixel value in the image. In some embodiments, the system may be configured to preprocess input data by encoding categorical parameters (e.g., one-hot encoding the categorical parameters).
In some embodiments, the system may be configured to obtain labels for the sample inputs. The labels may be target outputs corresponding to the sample inputs to use during training (e.g., to perform a supervised learning technique). Continuing with the example of input data consisting of an input image, the system may obtain an output image corresponding to the input image. The output image may represent a target enhancement of the input image that is to be generated by the neural network. In some embodiments, the system may be configured to obtain labels comprising target classifications for respective sets of input data. For example, the input data may be diagnostic scans of patients and the labels may be disease diagnoses for the patients (e.g., determined from diagnosis by clinicians using other techniques).
In some embodiments, the system may be configured to obtain the training data by: (1) obtaining a set of sample inputs; and (2) duplicating the set of sample inputs to obtain training data including the set of sample inputs and the duplicate sample inputs. The system may be configured to train the neural network using the set of sample inputs and the duplicate sample inputs. For example, the system may divide the training data into mini-batches, and duplicate the mini-batches. The system may use the original mini-batches and the duplicates to train the neural network.
After obtaining the training data at block 302, process 300 proceeds to block 304, where the system uses a sample input of the training data to determine layer output(s) of one or more layers of the neural network. In some embodiments, the system may be configured to determine a layer output of a layer of the neural network using an input to the layer and parameters (e.g., weights) associated with the layer. For example, referring again to
In some embodiments, the system may be configured to determine a layer output for a layer by performing computations using matrices. An input to the layer (e.g., a layer output of a previous layer or a sample input) may be organized into a matrix. The parameters (e.g., weights) of the layer may be organized into a matrix. The system may be configured to determine the layer output by performing matrix multiplication between the input matrix and the parameters matrix to generate an output matrix. For example, the output matrix may store the output of each node of the layer in a row or column of the output matrix.
In some embodiments, the system may be configured to determine a layer output matrix using an input matrix and a parameter matrix using tiling. Tiling may divide a matrix operation into multiple operations between smaller matrices. The system may be configured to use tiling to perform the multiplication operation in multiple passes. In each pass, the system may perform an operation over a tile of a matrix. In some embodiments, the system may perform tiling to simulate computation that would be performed on a target device. For example, a target device may use tiling due to resource constraints. As an example, the processor of the target device may not be sufficiently large to perform a multiplication between large matrices (e.g., with thousands of rows and/or columns) in one pass. Tiling may allow the target device to perform matrix operations using a smaller processor.
C1=A1×B1+A2×B2 (1)
C2=A3×B1+A4×B2 (2)
In equation 1 above, the system may perform the multiplication of A1×B1 separately from the multiplication of A2×B2. The system may subsequently accumulate the results to obtain C1. Similarly, in equation 2, the system may perform the multiplication of A3×B1 separately from the multiplication of A4×B2. The system may subsequently accumulate the results to obtain C2.
Although the example of
Next, process 300 proceeds to block 306, where the system obtains one or more noise samples from a quantization noise model for a target device. In some embodiments, the system may be configured to obtain a noise sample from a quantization noise model by randomly sampling the quantization noise model. For example, the quantization noise model may be a Gaussian distribution and the system may randomly sample the Gaussian distribution to obtain the noise sample. In another example, the quantization noise model may be an unspecified distribution of error values (e.g., empirically determined error values) and the system may randomly sample error values according to the distribution (e.g., based on probabilities of different error values). In some embodiments, the quantization noise model for the target device may include noise models for respective layers of the neural network. The system may be configured to obtain a noise sample for a layer by: (1) accessing a noise model for the layer; and (2) obtaining a noise sample from the noise model for the layer. In some embodiments, the quantization noise model for the target device may be a single noise model for all the layers of the neural network.
A noise sample for a layer output may include multiple values. For example, the noise sample may include a noise sample for each output value. Referring again to
After obtaining the noise sample(s) at block 306, process 300 proceeds to block 308, where the system injects the noise sample(s) into one or more layer outputs. The system may be configured to inject a noise sample for a layer (e.g., obtained from a quantization noise model for the layer) into the corresponding layer output of the layer. In some embodiments, the system may be configured to additively inject a noise sample into a layer output. For example, a layer output matrix may be summed with a noise sample matrix to obtain a layer output injected with the noise sample. In some embodiments, the system may be configured to multiplicatively inject a noise sample into a layer output. The system may be configured to perform element-wise multiplication between a layer output matrix and a noise sample matrix to obtain a layer output injected with the noise sample.
In some embodiments, the system may be configured to inject a noise sample into a layer output per matrix. For example, the system may add a noise matrix to matrix C of
After injecting the noise sample(s) into layer output(s) at block 308, process 300 proceeds to block 310, where the system determines an output of the neural network for the sample input using the layer output(s) injected with the noise sample(s). In some embodiments, the system may be configured to determine the output of the neural network by using the layer output(s) injected with the noise sample(s) to compute outputs of subsequent layers. For example, referring again to
Next, process 300 proceeds to block 312, where the system updates parameters of the neural network using the output obtained at block 310. In some embodiments, the system may be configured to determine an update to the parameters of the neural network by determining a difference between the output and an expected output (e.g., a label from the training data). For example, the system may determine a gradient of a loss function with respect to the parameters using the difference. The loss function may be a mean square error function, quadratic loss function, L2 loss function, mean absolute error function, L1 loss function, cross entropy loss function, or any other suitable loss function. The system may be configured to update the parameters using the determined gradient. For example, the system may update the parameters by increasing or decreasing the parameters by a proportion of the gradient.
Next, process 300 proceeds to block 314, where the system determines whether the training has converged. In some embodiments, the system may be configured to determine whether the training has converged based on a loss function or gradient thereof. For example, the system may determine that the training has converged when the gradient of the loss function is less than a threshold value. In another example, the system may determine that the training has converged when the loss function is less than a threshold value. In some embodiments, the system may be configured to determine whether the training has converged by determining whether the system has performed a threshold number of iterations. For example, the system may determine that the training has converged when the system has performed a maximum number of iterations of blocks 304 to 312.
If at block 314, the system determines that the training has not converged, then process 300 proceeds to block 318, where the system adjusts the quantization noise model. In some embodiments, the system may be configured to adjust the quantization noise model such that noise is gradually introduced over multiple iterations of training. The system may be configured to update scalars applied to parameters of the quantization noise model to gradually introduce noise over iterations of training. The system may gradually increase the scalars to increase the level of noise injected during training. As an illustrative example, the quantitative noise model may be a Gaussian distribution Q-U(0,kB) which indicates a Gaussian distribution with mean 0 and standard deviation kB. In this example, the system may adjust the value of the scalar B to adjust the noise injected during training (e.g., by increasing B after each iteration to increase the noise variance). As another example, the quantitative noise model may be a uniform distribution
which indicates a minimum value −kB/2 and maximum value kB/2 of the uniform distribution. The system may adjust the value of B to adjust the noise injected during training (e.g., by increasing B to increase the range of error values). In some embodiments, the system may be configured to determine the value of B using a function calculated after each iteration of training. Equations 3, 4 and 5 below illustrate example functions for determining the value of B.
In equations 3, 4 and 5 above, B0 is an initial value of B, x is the current training iteration, center is the training iteration at which the function T(x) is at its midpoint, and scale controls the slope of the function. The variables center and scale may be set to control how the quantization noise model is adjusted after each training iteration. As the function T(x) is a sigmoidal function, it is in the range [0, 1]. The function T(x) is initialized at a low value and then increases with each iteration. This makes a variance of the quantization noise model start low and then gradually increase to a maximum value. The gradual increase in variance may allow the training to converge more efficiently.
As indicated by the dashed lines around block 318, in some embodiments, the system may proceed without adjusting the quantization noise model. For example, the system may use the quantization noise model used in one training iteration in a subsequent training iteration without modification to any parameters of the quantization noise model. As an illustrative example, the quantization noise model may be used in all training iterations with full scaling (e.g., B=1 in equation 3) for all iterations. Process 300 would proceed to block 320 without performing the act at block 318.
Next, process 300 proceeds to block 320, where the system selects another sample input from the training data. In some embodiments, the system may be configured to select the sample input randomly. After selecting the next sample input, process 300 proceeds to block 304 where the system determines layer output(s) of layer(s) of the neural network.
In some embodiments, the system may be configured to inject noise for some sample inputs of the training data and not inject noise for some sample inputs of the training data. For example, each sample input may be a mini-batch and the system may perform noise injection for some mini-batches and not perform noise injection for other mini-batches. In this example, the system may mask some of the mini-batches from noise injection. In some embodiments, the training data may include a first plurality of sample inputs and a second plurality of inputs that is a duplicate of the first plurality of sample inputs. The system may be configured to perform noise injection (e.g., as performed at block 308) for the first plurality of sample inputs and not the second plurality of inputs.
If at block 314, the system determines that the training has converged, then process 300 proceeds to block 316, where the system obtains a trained neural network (e.g., trained neural network 108 of
Process 500 begins at block 502, where the system obtains layer outputs of one or more layers of a neural network determined by a training system. The layer outputs determined by the training system may also be referred to as “training system layer outputs”. In some embodiments, the neural network may be obtained by performing training using training data. The neural network may be obtained by performing training without injection of noise. In some embodiments, the system performing process 500 may be the training system, and the system may be configured to determine outputs of the neural network by: (1) obtaining sample inputs; and (2) using parameters of the neural network to determine layer outputs of the layer(s) of the trained neural network. For example, the system may use parameters (e.g., weights, kernel, etc.) of each of the layer(s) to determine a layer output. The system may be configured to store the layer outputs of the layer(s) of the neural network. In some embodiments, the system performing process 500 may be separate from the training system. The system may be configured to receive layer outputs determined by the training system or another device that obtained the layer outputs from the training system. For example, the system may receive the layer outputs in a data transmission through a communication network (e.g., the Internet).
Next, process 500 proceeds to block 504, where the system obtains layer outputs of the layer(s) of the neural network determined by a target device. The layer outputs determined by the target device may also be referred to as “target device layer outputs”. For example, the system may provide the neural network to the target device. The target device may be configured to determine layer outputs of the layer(s) of the neural network using hardware components (e.g., processor(s), ADC(s), etc.) of the target device. The target device may be configured to determine layer outputs of the layer(s) by: (1) obtaining the sample inputs used by the training system; and (2) using parameters of the neural network to determine layer outputs of the layer(s). In some embodiments, the sample inputs may include inputs of hidden layers captured by introspection on the neural network. The hardware components of the target device may introduce quantization error into the computations of the layer outputs (e.g., due to a lower precision used to represent parameters of the neural network and/or noise from an ADC of the target device). The system performing process 500 may be configured to obtain the layer outputs determined by the target device by receiving them from the target device or another device that obtained the layer outputs from the target device. For example, the system may receive the layer outputs in a data transmission through a communication network (e.g., the Internet).
Next, process 500 proceeds to block 506, where the system determines a measure of difference between the training system layer outputs and the target device layer outputs. In some embodiments, the system may be configured to determine the measure of difference to be a difference calculated between the layer outputs and the target layer outputs. In some embodiments, the system may be configured to determine the measure of difference to be a measure of distance (e.g., Euclidean distance, Hamming distance, Manhattan distance, or other suitable distance measure) between the layer outputs. In some embodiments, the system may be configured to provide the training system layer outputs and target device layer outputs as input to a function. For example, the function may be a histogram function to generate, for each of the layer(s), a histogram of differences between the training system layer outputs and the target device layer outputs. As another example, the function may be a Gaussian distribution parameterized by a mean and standard deviation for each of the layer(s). In another example, the function may be a mixture of Gaussian distributions, to generate multimodal distributions, parameterized by multiple means and standard deviations for each of the layer(s). In another example, the function may be a generative adversarial network (GAN) trained to generate noise samples, or a conditional GAN trained to generate noise samples conditioned on the weights, inputs, and/or outputs of the neural network on the system and/or the target device.
Next, process 500 proceeds to block 508, where the system generates a quantization noise model for the target device using the determined difference between the training system layer outputs and the target device layer outputs. In some embodiments, the quantization noise model may be a single quantization noise model used for the layers of the neural network. In some embodiments, the quantization noise model may include a respective noise model for each of the layer(s) of the neural network.
The system may be configured to generate a noise model in various different ways. In some embodiments, the system may be configured to generate the noise model by determining parameters of a distribution that is used to model noise resulting from quantization error. For example, the system may determine parameters of a Gaussian distribution (e.g., mean or variance) that is to be used as the noise model. In another example, the system may determine parameters of a uniform distribution (e.g., minimum, and maximum value) that is to be used as the noise model. In some embodiments, the system may be configured to determine a histogram of difference values as the noise model. In some embodiments, the system may be configured to determine parameter(s) of a Gaussian mixture model, a GAN, or a conditional GAN as the noise model.
After generating the quantization noise model at block 508, the quantization noise model may be used to train a neural network (e.g., to be robust to quantization error on a target device). For example, the generated quantization noise model may be used by a training system to perform process 300 described herein with reference to
The processor 70 may be configured to generate or receive (e.g., from an external device) an input vector of a set of input bit strings and output an output vector of a set of output bit strings. For example, if the input vector is an N-dimensional vector, the input vector may be represented by N bit strings, each bit string representing a respective component of the vector. An input bit string may be an electrical signal and an output bit string may be transmitted as an electrical signal (e.g., to an external device). In some embodiments, the digital process 702 does not necessarily output an output bit string after every process iteration. Instead, the digital processor 702 may use one or more output bit strings to determine a new input bit string to feed through the components of the processor 70. In some embodiments, the output bit string itself may be used as the input bit string for a subsequent process iteration. In some embodiments, multiple output bit streams are combined in various ways to determine a subsequent input bit string. For example, one or more output bit strings may be summed together as part of the determination of the subsequent input bit string.
DAC module 706 may be configured to convert the input bit strings into analog signals. The optical encoder module 752 may be configured to convert the analog signals into optically encoded information to be processed by the optical computation module 754. The information may be encoded in the amplitude, phase, and/or frequency of an optical pulse. Accordingly, optical encoder module 752 may include optical amplitude modulators, optical phase modulators and/or optical frequency modulators. In some embodiments, the optical signal represents the value and sign of the associated bit string as an amplitude and a phase of an optical pulse. In some embodiments, the phase may be limited to a binary choice of either a zero phase shift or a 71 phase shift, representing a positive and negative value, respectively. Some embodiments are not limited to real input vector values. Complex vector components may be represented by, for example, using more than two phase values when encoding the optical signal.
The optical encoder module 752 may be configured to output N separate optical pulses that are transmitted to the optical computation module 754. Each output of the optical encoder module 752 may be coupled one-to-one to an input of the optical computation module 754. In some embodiments, the optical encoder module 752 may be disposed on the same substrate as the optical computation module 754 (e.g., the optical encoder 752 and the optical computation module 754 are on the same chip). The optical signals may be transmitted from the optical encoder module 752 to the optical computation module 754 in waveguides, such as silicon photonic waveguides. In some embodiments, the optical encoder module 752 may be on a separate substrate from the optical computation module 754. The optical signals may be transmitted from the optical encoder module 752 to optical computation module 754 with optical fibers.
The optical computation module 754 may be configured to perform multiplication of an input vector ‘X’ by a matrix ‘A’. In some embodiments, the optical computation module 754 includes multiple optical multipliers each configured to perform a scalar multiplication between an entry of the input vector and an entry of matrix ‘A’ in the optical domain. Optionally, optical computation module 754 may further include optical adders for adding the results of the scalar multiplications to one another in the optical domain. In some embodiments, the additions may be performed electrically. For example, optical receiver module 756 may produce a voltage resulting from the integration (over time) of a photocurrent received from a photodetector.
The optical computation module 754 may be configured to output N optical pulses that are transmitted to the optical receiver module 756. Each output of the optical computation module 754 is coupled one-to-one to an input of the optical receiver module 756. In some embodiments, the optical computation module 754 may be on the same substrate as the optical receiver module 756 (e.g., the optical computation module 754 and the optical receiver module 756 are on the same chip). The optical signals may be transmitted from the optical computation module 754 to the optical receiver module 756 in silicon photonic waveguides. In some embodiments, the optical computation module 754 may be disposed on a separate substrate from the optical receiver module 756. The optical signals may be transmitted from the optical computation module 754 to the optical receiver module 756 using optical fibers.
The optical receiver module 756 may be configured to receive the N optical pulses from the optical computation module 754. Each of the optical pulses may be converted to an electrical analog signal. In some embodiments, the intensity and phase of each of the optical pulses may be detected by optical detectors within the optical receiver module. The electrical signals representing those measured values may then be converted into the digital domain using ADC module 710, and provided back to the digital process 702.
The digital processor 702 may be configured to control the optical encoder module 752, the optical computation module 754 and the optical receiver module 756. The memory 704 may be configured to store input and output bit strings and measurement results from the optical receiver module 756. The memory 704 also stores executable instructions that, when executed by the digital processor 702, control the optical encoder module 752, optical computation module 754, and optical receiver module 756. The memory 704 may also include executable instructions that cause the digital processor 702 to determine a new input vector to send to the optical encoder based on a collection of one or more output vectors determined by the measurement performed by the optical receiver module 756. In this way, the digital processor 702 may be configured to control an iterative process by which an input vector is multiplied by multiple matrices by adjusting the settings of the optical computation module 754 and feeding detection information from the optical receive module 756 back to the optical encoder 752. Thus, the output vector transmitted by the processor 70 to an external device may be the result of multiple matrix multiplications, not simply a single matrix multiplication.
Process 800 begins at block 802, where the device obtains a neural network trained with noise injection using a quantization noise model for the device. For example, the device may obtain a neural network trained using process 300 described herein with reference to
Next, process 800 proceeds to block 804, where the device obtains input data. The device may be configured to receive input data from another system. For example, the device may receive input data from a computing device through a communication network (e.g., the Internet). In another example, the device may be a component of a system with multiple components, and receive the input data from another component of the system. In another example, the device may generate the input data. As an illustrative example, the input data may be an image captured by a camera of the device that is to be processed (e.g., enhanced) using the neural network.
Next, process 800 proceeds to block 806, where the system generates a set of input features. The device may be configured to process the input data to generate a set of input features that can be used as input to the neural network. For example, the device may encode parameters of the input data, normalize parameters of the input data, or perform other processing. In some embodiments, the device may be configured to organize parameters into a data structure (e.g., vector, array, matrix, tensor, or other type of data structure) to use as input to the neural network. For example, the device may generate a vector of input features. In another example, the device may generate a matrix of input features.
Next, process 800 proceeds to block 808, where the device determines an output of the neural network using the input features and the parameters of the neural network. The device may be configured to compute the output using the input features and the parameters of the neural network. The device may be configured to determine a sequence of layer outputs and an output of the neural network using the layer outputs. For example, the device may determine layer outputs of convolutional layers using convolution kernels and/or outputs of fully connected layers using weights associated with nodes. The device may be configured to use the layer outputs to determine an output of the neural network. For example, the output of the neural network may be a classification, a predicted likelihood, or pixel values of an enhanced image.
In some embodiments, the device may be configured to determine a layer output for a layer by performing computations using matrices. An input to the layer (e.g., a layer output of a previous layer or a sample input) may be organized into a matrix. The parameters (e.g., weights and/or biases) of the layer may be organized into a matrix. The device may be configured to determine the layer output by performing matrix multiplication between the input matrix and the parameters matrix to generate an output matrix. For example, the output matrix may store the output of each node of the layer in a row or column of the output matrix.
In some embodiments, the device may be configured to determine a layer output matrix using an input matrix and a parameter matrix using tiling. Tiling may divide a matrix operation into multiple operations between smaller matrices. The device may be configured to use tiling to perform the multiplication operation in multiple passes. In each pass, the device may perform an operation over a tile of a matrix. Tiling may allow the target device to perform matrix operations using a smaller processor. An example of tiling is described herein with reference to
The terms “program” or “software” are used herein in a generic sense to refer to any type of computer code or set of processor-executable instructions that can be employed to program a computer or other processor (physical or virtual) to implement various aspects of embodiments as discussed above. Additionally, according to one aspect, one or more computer programs that when executed perform methods of the disclosure provided herein need not reside on a single computer or processor, but may be distributed in a modular fashion among different computers or processors to implement various aspects of the disclosure provided herein.
Processor-executable instructions may be in many forms, such as program modules, executed by one or more computers or other devices. Generally, program modules include routines, programs, objects, components, data structures, etc. that perform tasks or implement abstract data types. Typically, the functionality of the program modules may be combined or distributed.
Various inventive concepts may be embodied as one or more processes, of which examples have been provided. The acts performed as part of each process may be ordered in any suitable way. Thus, embodiments may be constructed in which acts are performed in an order different than illustrated, which may include performing some acts simultaneously, even though shown as sequential acts in illustrative embodiments.
As used herein in the specification and in the claims, the phrase “at least one,” in reference to a list of one or more elements, should be understood to mean at least one element selected from any one or more of the elements in the list of elements, but not necessarily including at least one of each and every element specifically listed within the list of elements and not excluding any combinations of elements in the list of elements. This definition also allows that elements may optionally be present other than the elements specifically identified within the list of elements to which the phrase “at least one” refers, whether related or unrelated to those elements specifically identified. Thus, for example, “at least one of A and B” (or, equivalently, “at least one of A or B,” or, equivalently “at least one of A and/or B”) can refer, in one embodiment, to at least one, optionally including more than one, A, with no B present (and optionally including elements other than B); in another embodiment, to at least one, optionally including more than one, B, with no A present (and optionally including elements other than A); in yet another embodiment, to at least one, optionally including more than one, A, and at least one, optionally including more than one, B (and optionally including other elements); etc.
The phrase “and/or,” as used herein in the specification and in the claims, should be understood to mean “either or both” of the elements so conjoined, i.e., elements that are conjunctively present in some cases and disjunctively present in other cases. Multiple elements listed with “and/or” should be construed in the same fashion, i.e., “one or more” of the elements so conjoined. Other elements may optionally be present other than the elements specifically identified by the “and/or” clause, whether related or unrelated to those elements specifically identified. Thus, as a non-limiting example, a reference to “A and/or B”, when used in conjunction with open-ended language such as “comprising” can refer, in one embodiment, to A only (optionally including elements other than B); in another embodiment, to B only (optionally including elements other than A); in yet another embodiment, to both A and B (optionally including other elements); etc.
Use of ordinal terms such as “first,” “second,” “third,” etc., in the claims to modify a claim element does not by itself connote any priority, precedence, or order of one claim element over another or the temporal order in which acts of a method are performed. Such terms are used merely as labels to distinguish one claim element having a certain name from another element having a same name (but for use of the ordinal term). The phraseology and terminology used herein is for the purpose of description and should not be regarded as limiting. The use of “including,” “comprising,” “having,” “containing”, “involving”, and variations thereof, is meant to encompass the items listed thereafter and additional items.
Having described several embodiments of the techniques described herein in detail, various modifications, and improvements will readily occur to those skilled in the art. Such modifications and improvements are intended to be within the spirit and scope of the disclosure. Accordingly, the foregoing description is by way of example only, and is not intended as limiting. The techniques are limited only as defined by the following claims and the equivalents thereto.
This application claims the benefit under 35 U.S.C. 119(e) of U.S. Provisional Pat. App. Ser. No. 63/059,934, filed under Attorney Docket No. L0858.70031US00 and entitled “ADAPTING NEURAL NETWORKS TO ANALOG PROCESSORS BY TRAINING WITH NOISE”, which is hereby incorporated herein by reference in its entirety.
Number | Date | Country | |
---|---|---|---|
63059934 | Jul 2020 | US |