 
                 Patent Grant
 Patent Grant
                     11481636
 11481636
                    The present disclosure relates generally to training and use of machine learning systems and more specifically to systems and methods for out-of-distribution classification.
Neural networks have been widely used for data classification, e.g., identifying which class from a set of pre-defined classes that an input data sample may belong to. For example, when a digital image is fed to the neural network, the image pixels may be classified as belonging to a set of pre-defined classes, e.g., indicating a shape, a pattern, an object, etc. in the image. Specifically, the neural network generates probabilistic distributions indicating a respective likelihood that the input image may belong to each pre-defined class. However, when the image does not belong to any of the pre-defined classes, the output probabilistic distributions from neural network can be highly inaccurate. In this case, pixels of the input image may be referred to as “out-of-domain” or “out-of-distribution” (OOD), as opposed to “in-domain” or “in-distribution” (ID) when the input image belongs to one of the pre-defined classes.
When the neural network is only trained to classify an input sample into pre-defined classes, the classification output in response to an OOD input can be highly inaccurate and even completely erroneous. Thus, to more accurately classify the input data, an OOD classification scheme is needed to identify inputs that may go beyond the pre-defined classes. However, due to the vast randomness of OOD inputs and the large scale of unseen dataset and domains, OOD identification has proven to be difficult.
    
    
    
    
    
    
    
    
    
    
    
    
    
In the figures, elements having the same designations have the same or similar functions.
In view of the need for an OOD identification scheme with improved accuracy, embodiments described herein provide various training and implementation schemes for OOD detection.
Some existing systems preprocess the input data by adding small perturbations, thus for in-domain examples, a large change in output distribution may be expected even for a small change to the inputs, as against OOD examples. Thus, by measuring the scale of change in outputs, OOD examples may be identified. However, this model is not tractable to compute backpropagation during interference. An embodiment provided herein preprocesses the input samples to the classification neural network, e.g., by adding Gaussian noise to word/sentence representations to make the function of the neural network satisfy Lipschitz property such that a small change in the input does not cause much change to the output if the input sample is in-distribution. In this way, the accuracy of both in-domain and OOD identification can be improved.
Some existing systems uses hyperparameter search in a multidimensional space to classify input vector representations. For example, each pre-defined class is represented by a reference class vector in the multidimensional space, and an input vector representation is determined to belong to a pre-defined class based on the closest reference class vector. However, when only a small training dataset is available, such dataset may not be sufficient for the neural network to learn the hyperparameters for the neural network to separate the multidimensional space with respect to different pre-defined classes. An embodiment described herein provides that a small dataset may be used for the neural network to learn characteristics of the radius of the input vector to the origin. In this way, an OOD vector may be identified when the OOD vector is sufficiently close to the origin (identified through learning), or when the OOD vector is orthogonal to all reference class vectors.
Some existing systems process input samples with a high feature dimension to improve the accuracy of classification, While the in-domain output may be sensitive to the dimensions and higher dimensions of the features may yield better in-domain output accuracy, however, higher feature dimension sometimes may lead to poor performance of OOD detection. For example, certain feature basis which do not contribute to classification may cause long tail accumulation for the OOD output. An embodiment proposed herein uses sparsification techniques to train the neural network with a high feature dimension that may yield desirable in-domain detection accuracy, but may prune away dimensions in the output that are less important. Specifically, a sparsification vector is generated based on Gaussian distribution (or other probabilistic distribution) and is used to multiply with the higher dimension output to reduce the number of feature dimensions. The pruned output may be then used for the neural network to learn the sparsification vector. In this way, OOD detection accuracy can be improved.
In some embodiments, training a neural model for OOD identification may be difficult due to a lack of OOD training samples. An embodiment proposed herein generates OOD training samples by feeding samples that are similar to in-domain samples but are semantically OOD. Specifically, the system may find candidate words in an in-domain sample to be replaced by other words for the sentence to be OOD. For example, in-domain examples may be “what is Mark's keynote?” “When is Mark's keynote?” or “Where is Mark's keynote?” The system may identify that words such as “what” “when” and “where” are the critical words that carry more weight in classifying the sentence into a pre-defined class, and may seek to replace these words with other random words to generate an OOD input, e.g., “How is Mark's keynote” is an OOD sample.
As used herein, the term “in-distribution” or “in-domain” (the two terms may be used interchangeably herein) refers to a characteristic of a data sample when the data sample belongs to one of a set of pre-defined classes.
As used herein, the term “out-of-distribution” or “out-of-domain” (the two terms may be used interchangeably herein, or as “OOD”) refers to a characteristic of a data sample when the data sample does not belong to any of a set of pre-defined classes.
As used herein, the term “network” may include any hardware or software-based framework that includes any artificial intelligence network or system, neural network or system and/or any training or learning models implemented thereon or therewith.
As used herein, the term “module” or “model” may include any hardware or software-based framework that performs one or more functions. In some embodiments, the module may be implemented using one or more neural networks.
  
For example, when the user 102 says “I need to report a fraud on my credit card” 111, which is transmitted to the char bot 104 via communication interface 104a, the chat bot 104 may instantiate a neural classification model to classify the user communication 111 as related to the label “fraud” 111c, e.g., at 104b. The chat bot 104 may then retrieve a response that has been pre-defined for fraud handling, such as “please state the last four digits of our social security number” 112.
For another example, when the user says “I need to speak to someone higher up” 115, the chat bot 104 may not be able to identify which pre-defined label 101a-n the statement 115 belongs to. In this case, when the chat bot 104 is trained with OOD identification 120, the chat bot 104 may identify the input 115 as OOD, and allow a customer or a provider to define a response to be associated with the OOD class 106, such as reporting an error, or directing the user 102 to a representative, etc.
Therefore, as any random comment made by the user 102 may be an OOD input, such vast randomness may render OOD identification and training of the OOD identification 120 difficult.
  
The upstream application 220 may operate an OOD classification training framework 225, which sends a data or model training request 202 to the data provider(s) 210. The data provider 210, which may store a dataset of training data 205, may in turn provide training samples 203 to the OOD classification training module 225.
  
Memory 320 may be used to store software executed by computing device 300 and/or one or more data structures used during operation of computing device 300. Memory 320 may include one or more types of machine readable media. Some common forms of machine readable media may include floppy disk, flexible disk, hard disk, magnetic tape, any other magnetic medium, CD-ROM, any other optical medium, punch cards, paper tape, any other physical medium with patterns of holes, RAM, PROM, EPROM, FLASH-EPROM, any other memory chip or cartridge, and/or any other medium from which a processor or computer is adapted to read.
Processor 310 and/or memory 320 may be arranged in any suitable physical arrangement. In some embodiments, processor 310 and/or memory 320 may be implemented on a same board, in a same package (e.g., system-in-package), on a same chip (e.g., system-on-chip), and/or the like. In some embodiments, processor 310 and/or memory 320 may include distributed, virtualized, and/or containerized computing resources. Consistent with such embodiments, processor 310 and/or memory 320 may be located in one or more data centers and/or cloud computing facilities.
Computing device 300 further includes a communication interface 305 that is operable to receive and transmit data to one or more other computing devices, such as the data providers 210. In some examples, data may be sent to or received from the data providers 210 via the communication interface 305.
Memory 320 includes an OOD identification module 330 that may be used to implement a machine learning system and model described further herein and/or to implement any of the methods described further herein. In some examples, the OOD identification module 330 may also handle the iterative training and/or evaluation of OOD identification module 330 as is described in further detail below. In some examples, OOD identification module 330 may include a machine learning structure, such as one or more neural networks, deep convolutional networks, and/or the like.
In some examples, memory 320 may include non-transitory, tangible, machine readable media that includes executable code that when run by one or more processors (e.g., processor 310) may cause the one or more processors to perform the methods described in further detail herein. In some examples, each of the OOD identification modules 330 and/or OOD training module 360 may be implemented using hardware, software, and/or a combination of hardware and software. As shown, computing device 300 receives an input batch of data samples 340 and generates a classification output which may include OOD identification 350.
The OOD identification module 330 includes a number of submodules such as the preprocessing module 331, the separation module 332, the sparsification module 333 and the OOD sample generation module 334. The preprocessing module 331 is configured to receive and preprocess the input data samples 340 by adding a Gaussian noise component to each input data sample at the word or sentence level to render the input-output transformation function with a Lipschitz property. Further details and implementations of the preprocessing module 331 are discussed in relation to 
The separation module 332 is configured to learn characteristics of the vector representations of in-distribution and OOD input samples from the penultimate layer, as compared against reference class vectors geometrically separating a multi-dimensional space. The separation module 332 is then configured to use the learned characteristics to distinguish in-distribution or OOD inputs. Further details and implementations of the separation module 332 are discussed in relation to 
The sparsification module 333 is configured to train the OOD identification module 330 with a higher feature dimension, but then prune away feature dimensions that are less important in the classification outputs, in order to enhance hardware resource efficiency. Further details and implementations of the sparsification module 333 are discussed in relation to 
The OOD sample generation module 334 is configured to generate OOD training samples from in-distribution training samples, e.g., by feeding sentences that are similar to in-distribution samples but are semantically OOD to train the OOD identification module 330. Further details and implementations of the sparsification module 333 are discussed in relation to 
As discussed above and further emphasized here, 
Lipschitz Preprocessing
For deep neural networks (DNNs) that are trained for classification, when the DNNs are robust to adversarial inputs, such DNNs perform better for OOD tasks as compared to DNNs that are not robust to adversarial inputs. A property of DNNs that are robust to adversarial inputs is that such DNNs learn functions that are Lipschitz tight, e.g., given different inputs x, y, the outputs ƒ(x) and ƒ(y) satisfies a property that ∥ƒ(x)−ƒ(y)∥<C∥x−y∥, where ƒ( )) represents the function corresponding to the DNN, and C is a constant. In one embodiment, Gaussian noise may be added to the inputs x, y to make the function ƒ( ) of the DNN Lipschitz tight.
  
At step 402, an input sample may be received, e.g., input samples 340 may be received via communication interface 305 shown in 
At step 404, a vector representation of the input sample may be optionally generated.
At step 406, the vector representation of the input sample may be preprocessed by adding a Gaussian noise component having a variance value to the vector representation such that the resulting input-output function of the neural network satisfies the Liptschitz property. For example, the Gaussian noise may be added at the word level or at the sentence level of the input sample. For each language, the variance of the Gaussian noise is estimated and learned via backpropagation to render the learned function of the neural network Liptschitz tights.
At step 408, a classification output is then generated from the neural network from the preprocessed input sample. For example, the output may take a form as classification probabilities indicating a likelihood that the input sample belongs to a pre-defined class or is OOD.
At step 410, the neural network determines whether the input sample is in-distribution or out-of-distribution based on the generated classification output. For example, a pre-defined threshold may be used to determine whether the input sample is in-distribution or OOD depending on whether a classification probability is greater or less than the pre-defined threshold.
In some embodiments, with input samples obtained from a training dataset (e.g., 205 in 
  
As shown by 500a-b, with added noise, for a much broader range of OOD probabilities on the x-axis, the OOD performance 504b and the in-distribution performance 502b achieve a better performance level than the OOD performance 504a and the in-distribution performance 502a. Therefore, the preprocessing with added Gaussian noise to the input samples may improve both the in-distribution and OOD performance of the neural network.
Separation of OOD Vectors
When OOD examples are passed through a DNN at the penultimate layer right before the final softmax layer, the representation from the penultimate layer tend to be closer to the origin when compared to those of in-domain counterparts. The OOD example may thus be forced to be closer to the origin by training the DNN with random OOD examples and penalizing the penultimate layer outputs if they are a pre-defined distance away from the origin. This technique requires a couple of hyper-parameters to be tuned to achieve optimal performance. To tune these hyper-parameters, some of the training data needs to be set aside. As training data can be scarce, hyper-parameter tuning may not always be feasible. Instead of hyper-parameter tuning, the characteristics of the OOD samples while passing through the penultimate layer can be utilized to identify the OOD samples, e.g., an OOD representation at the penultimate layer can be either closed to the origin or on a plane that is orthogonal to all the in-domain classes.
  
Specifically, at the output layer 606, the classification output may be computed as:
P(Y|ID,X)=softmax(WF(x)),P(ID|X)=tan h(max(∥WF(x)∥))
P(Y,ID|X)=P(Y|ID,X)P(ID|X)
P(Y|X)=[P(Y,ID|X),P(ID|X)]
where W is a kernel of weights that may be learned, F(x) is the output of the penultimate layer, ID stands for the condition that input x belongs to an in-domain class. In other words, the pre-defined classes may be viewed as sub-spaces separated by a set of reference class vectors in a multi-dimensional space. The vector representation F(x) from the penultimate layer is compared with the reference class vectors to determine whether F(x) belongs to a particular reference class, e.g., when F(x) is the closest to the particular reference class vector. In particular, max (∥WF(x)∥) computed at 608 computes the minimum angle made by the representation (F(x)) of an input x against an in-domain class representation that is the closest to the vector F(x). The tan h(.) transformation, as shown in diagram 610, transforms this distance max (∥WF(x)∥) to the origin to a probability distribution of value between 0 and 1, and this probability indicates whether the given input x is in-domain or OOD.
Specifically, the loss function may be computed as
loss=−Y log(P(Y|X)
which may be used to learn the kernel of weights W.
  
At step 702, an input sample may be received, e.g., input samples 340 may be received via communication interface 305 shown in 
At step 704, a vector representation of the input sample may be generated at a penultimate layer of the neural network, e.g., the vector F(x) generated at layer 604 of DNN 600 shown in 
At step 706, a number of reference class vectors corresponding to a number of pre-defined classes are retrieved. For example, the pre-defined classes may be viewed as sub-spaces separated by a set of reference class vectors in a multi-dimensional space.
At step 708, the vector representation of the input sample is compared against the number of reference class vectors. For example, the vector representation F(x) from the penultimate layer is compared with the reference class vectors to determine whether F(x) belongs to a particular reference class, e.g., when F(x) is the closest to a particular reference class vector.
At step 710, the minimum angle made by the vector representation (F(x)) of an input x against an in-domain class representation that is the closest to the vector F(x) is computed by maximizing a distance of the vector product WF(x), e.g., max (∥WF(x)∥).
At step 714, the maximized distance of the vector product WF(x) is converted to a probability value indicating a likelihood that the input sample is in-distribution or OOD. For example, a tan h(.) operation is applied to transform the distance max (∥WF(x)∥) to a probability distribution of value between 0 and 1, and this probability indicates whether the given input x is in-domain or OOD. Based on the probability, it can be determined whether the input sample is in-distribution or OOD. In particular, when the vector representation of the input sample F(x) is orthogonal to the number of reference class vectors or is close to the origin for less than a pre-defined threshold distance, the input sample x may be determined to be OOD.
Feature Dimension Sparsification
For a DNN, the representation learnt by the DNN for each pre-defined class doe s not usually require all the allocated hidden feature dimensions. Barring a few feature dimensions may not impair classification performance due to the existence of noise that may impede the ODD performance. Thus, after training a DNN with pre-defined classifiers, the weights for feature dimensions that do not contribute to identifying an in-domain class can be set to zero, which does not affect the classification performance significantly.
Specifically, while inputs with a higher dimension may result in better in-domain classification performance of the DNN, the higher dimension can also yield a poor performance for OOD detection accuracy. Basis (dimensions) that do not contribute to classification gets used by tan h(∥ƒ(X)W∥) (a case of long tail accumulation of bias), where X is the input, ƒ(X) is the penultimate layer of NN output vector and W is the weight of the OOD classifier. Thus, the DNN may be trained with a higher dimension but may prune away basis/dimensions that are less important.
  
At step 802, an input training sample having a first feature dimension may be received, e.g., input samples 340 may be received via communication interface 305 shown in 
At step 804, a classification output is generated, via the neural network, in response to an input of the training sample.
At step 806, the neural network is trained using the classification output to obtain a set of parameters for the neural network.
At step 808, the dimension of the representation of the input is pruned with a discrete sparsification vector generate by a gumble sigmoid. For example, a sparsification vector is defined
  
    
  
  
by an Here g is a gumble noise, 0 is a null vector, the parameter τ is the temperature a hyperparameter which is set to 1 at the start of the training and gradually reduced over the period of training. The ƒ(x)∈Rd and S∈Rd×c where d is the hidden dimension of the penultimate layer of the DNN classifier and c is the number of in-domain classifiers of the dataset. This temperature parameter forces the sigmoids to discretely select the linearly independent basis of the class representation for discriminating one class against another—in this way, the unused or noisy dimensions of the representation of each in-domain class may be set to zero.
At step 810, a classification output of the neural network is modified to incorporate the sparsification vector, which is represented as:
P(Y|X)=softmax f(X)(Wc)⊙S+bc)
Where WC and bC are the weights and bias of the in-domain classifier from the earlier training and are fixed. Here X represents the input, Y represents the classification output, W represents the vector of weight of the feature layer and W∈Rd×c, and the ⊙ operation represents the Hadamard product.
At step 812, the sparsification vector may be updated by backpropagation based on a computed loss based on the output while freezing parameters of the neural network that has been trained from step 806. For example, the loss may be computed by:
loss=−Y log(P(Y|X)+α|S|
where α is a hyper-parameter. This loss may be backpropagated to update the sparsification vector S.
  
  
OOD Sample Generation
Classification DNNs may be trained with a training dataset, e.g., see training dataset 205 in 
  
For example, an inter-class word importance probability is computed for each word based on term frequency-inverse document frequency (TF-IDF) of the respective word in the set of in-distribution training samples, e.g., the TF-IDF probabilities shown in 
For another example, an in-distribution word importance probability is computed for each word, which differentiates an in-distribution sample and an out-of-distribution sample for the respective element, e.g., the ID probabilities shown in 
A combined probability can thus be computed based on the TF-IDF based probability (a probability obtained by normalizing class-based TF-IDF word scores across the input sentence) and a word level in-domain probability (which is obtained by training a linear classifier with in-domain examples and random out-of-domain examples, e.g., random examples from Internet sources). The word-level in-domain probability may represent a probability that when the respective word candidature is replaced with a random word, e.g., from a corpus like Wikipedia, the resulting new sentence may become an OOD sample. In some embodiment, the combined probability may be computed based on a weighted sum of the TF-IDF probability and the in-domain probability. The combined probability is obtained by multiplying the TF-IDF based probability for each word in the sentence with corresponding word level in-domain probability.
For example, given the in-domain input sentence “when is the seminar for developers keynote,” the words “when,” “developers” and “seminar” are good candidate for replacement with random words. If one or more of these words are replaced with random words to form a new sentence, e.g., “how is the game for apple keynote,” the resulting generated sentence may take a similar sentence structure to the original in-domain sentence but semantically it is an OOD sentence, because it no longer makes sense in the category of class “Keynote Agenda.” Thus, for each in-domain training sentence, one or more OOD sentences can be generated, which can be used as OOD training samples to train the DNN for OOD detection.
  
At step 1201, an in-distribution input training sample may be received, e.g., input samples 340 may be received via communication interface 305 shown in 
At step 1202, one or more elements within an in-distribution training sample that are relevant to in-distribution classification based on word importance probabilities may be identified. For example, as discussed in relation to 
At step 1204, one or more OOD training samples may be generated by replacing the one or more elements from the in-distribution training sample with one or more random elements. For example, the words “when,” “developers” and “seminar” may be replaced with random words to form a new sentence, e.g., “how is the game for apple keynote,” semantically an OOD sentence.
At step 1206, the generated one or more OOD training samples may be used to train the neural network for OOD detection.
  
As shown by 1300a-b, with added noise, for a much broader range of OOD probabilities on the x-axis, the OOD performance 1304b and the in-distribution performance 1302b achieve a better performance level than the OOD performance 1304a and the in-distribution performance 1302a. Therefore, by using generated OOD samples from in-domain training data, the combined performance of in-distribution and OOD detection of the neural network is improved.
Some examples of computing devices, such as computing device 300 may include non-transitory, tangible, machine readable media that include executable code that when run by one or more processors (e.g., processor 320) may cause the one or more processors to perform the processes of methods 400, 700, 800 and 1200. Some common forms of machine readable media that may include the processes of methods 400, 700, 800 and 1200 are, for example, floppy disk, flexible disk, hard disk, magnetic tape, any other magnetic medium, CD-ROM, any other optical medium, punch cards, paper tape, any other physical medium with patterns of holes, RAM, PROM, EPROM, FLASH-EPROM, any other memory chip or cartridge, and/or any other medium from which a processor or computer is adapted to read.
This description and the accompanying drawings that illustrate inventive aspects, embodiments, implementations, or applications should not be taken as limiting. Various mechanical, compositional, structural, electrical, and operational changes may be made without departing from the spirit and scope of this description and the claims. In some instances, well-known circuits, structures, or techniques have not been shown or described in detail in order not to obscure the embodiments of this disclosure. Like numbers in two or more figures represent the same or similar elements.
In this description, specific details are set forth describing some embodiments consistent with the present disclosure. Numerous specific details are set forth in order to provide a thorough understanding of the embodiments. It will be apparent, however, to one skilled in the art that some embodiments may be practiced without some or all of these specific details. The specific embodiments disclosed herein are meant to be illustrative but not limiting. One skilled in the art may realize other elements that, although not specifically described here, are within the scope and the spirit of this disclosure. In addition, to avoid unnecessary repetition, one or more features shown and described in association with one embodiment may be incorporated into other embodiments unless specifically described otherwise or if the one or more features would make an embodiment non-functional.
Although illustrative embodiments have been shown and described, a wide range of modification, change and substitution is contemplated in the foregoing disclosure and in some instances, some features of the embodiments may be employed without a corresponding use of other features. One of ordinary skill in the art would recognize many variations, alternatives, and modifications. Thus, the scope of the invention should be limited only by the following claims, and it is appropriate that the claims be construed broadly and in a manner consistent with the scope of the embodiments disclosed herein.
The present disclosure is a non-provisional application of and claims priority under 35 U.S.C. 119 to U.S. Provisional Application No. 62/937,079, filed on Nov. 18, 2019 and U.S. Provisional Application No. 62/968,959, filed on Jan. 31, 2020 which are hereby expressly incorporated herein by reference in their entirety. The present disclosure is related to U.S. Nonprovisional application Ser. No. 16/877,333, filed on May 18, 2020, and U.S. Nonprovisional application Ser. No. 16/877,339, filed on May 18, 2020 which claims priority under 35 U.S.C. 119 to U.S. Provisional Application No. 62/937,085, filed on Nov. 18, 2019 and U.S. Provisional Application No. 62/968,973, filed on Jan. 31, 2020, all of which are hereby expressly incorporated herein by reference in their entirety.
| Number | Name | Date | Kind | 
|---|---|---|---|
| 6353815 | Vilim | Mar 2002 | B1 | 
| 6553357 | Mathias | Apr 2003 | B2 | 
| 6611823 | Selmic | Aug 2003 | B1 | 
| 8199999 | Hoyt | Jun 2012 | B2 | 
| 8880450 | Dobson | Nov 2014 | B2 | 
| 9129218 | Commons | Sep 2015 | B1 | 
| 10282663 | Socher et al. | May 2019 | B2 | 
| 10346721 | Albright et al. | Jul 2019 | B2 | 
| 10353905 | Ramachandran et al. | Jul 2019 | B2 | 
| 10354264 | Jagota et al. | Jul 2019 | B2 | 
| 10542270 | Zhou et al. | Jan 2020 | B2 | 
| 10546217 | Albright et al. | Jan 2020 | B2 | 
| 10558750 | Lu et al. | Feb 2020 | B2 | 
| 10565305 | Lu et al. | Feb 2020 | B2 | 
| 10565306 | Lu et al. | Feb 2020 | B2 | 
| 10565493 | Merity et al. | Feb 2020 | B2 | 
| 10573295 | Zhou et al. | Feb 2020 | B2 | 
| 10592767 | Trott et al. | Mar 2020 | B2 | 
| 10614393 | Jagota et al. | Apr 2020 | B2 | 
| 10699060 | Mccann et al. | Jun 2020 | B2 | 
| 10747761 | Zhong et al. | Aug 2020 | B2 | 
| 10776581 | Mccann et al. | Sep 2020 | B2 | 
| 10783875 | Hosseini-Asl et al. | Sep 2020 | B2 | 
| 20160140355 | Jagota et al. | May 2016 | A1 | 
| 20160350653 | Socher et al. | Dec 2016 | A1 | 
| 20170024645 | Socher et al. | Jan 2017 | A1 | 
| 20170060919 | Ramachandran et al. | Mar 2017 | A1 | 
| 20180121787 | Hashimoto et al. | May 2018 | A1 | 
| 20180121788 | Hashimoto et al. | May 2018 | A1 | 
| 20180121799 | Hashimoto et al. | May 2018 | A1 | 
| 20180129931 | Bradbury et al. | May 2018 | A1 | 
| 20180129937 | Bradbury et al. | May 2018 | A1 | 
| 20180129938 | Xiong et al. | May 2018 | A1 | 
| 20180336453 | Merity et al. | Nov 2018 | A1 | 
| 20180373682 | Mccann et al. | Dec 2018 | A1 | 
| 20180373987 | Zhang et al. | Dec 2018 | A1 | 
| 20190130248 | Zhong et al. | May 2019 | A1 | 
| 20190130312 | Xiong et al. | May 2019 | A1 | 
| 20190130896 | Zhou et al. | May 2019 | A1 | 
| 20190138653 | Roller et al. | May 2019 | A1 | 
| 20190140995 | Roller et al. | May 2019 | A1 | 
| 20190213482 | Socher et al. | Jul 2019 | A1 | 
| 20190251431 | Keskar et al. | Aug 2019 | A1 | 
| 20190258714 | Zhong et al. | Aug 2019 | A1 | 
| 20190258939 | Min et al. | Aug 2019 | A1 | 
| 20190272335 | Liu et al. | Sep 2019 | A1 | 
| 20190286073 | Hosseini-Asl et al. | Sep 2019 | A1 | 
| 20190286832 | Szeto et al. | Sep 2019 | A1 | 
| 20190355270 | Mccann et al. | Nov 2019 | A1 | 
| 20190362020 | Paulus et al. | Nov 2019 | A1 | 
| 20190362246 | Lin et al. | Nov 2019 | A1 | 
| 20200005765 | Zhou et al. | Jan 2020 | A1 | 
| 20200057805 | Lu et al. | Feb 2020 | A1 | 
| 20200065651 | Merity et al. | Feb 2020 | A1 | 
| 20200084465 | Zhou et al. | Mar 2020 | A1 | 
| 20200089757 | Machado et al. | Mar 2020 | A1 | 
| 20200090033 | Ramachandran et al. | Mar 2020 | A1 | 
| 20200090034 | Ramachandran et al. | Mar 2020 | A1 | 
| 20200103911 | Ma et al. | Apr 2020 | A1 | 
| 20200104643 | Hu et al. | Apr 2020 | A1 | 
| 20200104699 | Zhou et al. | Apr 2020 | A1 | 
| 20200105272 | Wu et al. | Apr 2020 | A1 | 
| 20200117854 | Lu et al. | Apr 2020 | A1 | 
| 20200153765 | Burbank et al. | May 2020 | A1 | 
| 20200153934 | Burbank et al. | May 2020 | A1 | 
| 20200175305 | Trott et al. | Jun 2020 | A1 | 
| 20200184020 | Hashimoto et al. | Jun 2020 | A1 | 
| 20200272940 | Sun et al. | Aug 2020 | A1 | 
| 20200285705 | Zheng et al. | Sep 2020 | A1 | 
| 20200285993 | Liu et al. | Sep 2020 | A1 | 
| 20200301925 | Zhong et al. | Sep 2020 | A1 | 
| 20200302178 | Gao et al. | Sep 2020 | A1 | 
| 20200302236 | Gao et al. | Sep 2020 | A1 | 
| Number | Date | Country | |
|---|---|---|---|
| 20210150365 A1 | May 2021 | US | 
| Number | Date | Country | |
|---|---|---|---|
| 62968959 | Jan 2020 | US | |
| 62937079 | Nov 2019 | US |