The present disclosure relates generally to machine learning in hyperbolic space. More particularly, the present disclosure relates to systems and methods that perform normalization techniques and/or identify adversarial examples to facilitate machine learning in hyperbolic space.
More particularly, hyperbolic spaces have received sustained interest in recent years, owing to their ability to compactly represent data possessing hierarchical structure (e.g., trees and graphs). In terms of representation learning, hyperbolic spaces offer a provable advantage over Euclidean spaces for such data: objects requiring an exponential number of dimensions in Euclidean space can be represented in a polynomial number of dimensions in hyperbolic space. This has motivated research into efficiently learning a suitable hyperbolic embedding for large-scale datasets.
Despite this impressive representation power, little is known about the benefits of hyperbolic spaces for downstream tasks. For example, suppose one wishes to perform classification on data that is intrinsically hierarchical. One may naïvely ignore this structure and use a standard Euclidean embedding and corresponding classifier (e.g., SVM). However, it has not previously been shown that classification algorithms can be designed that exploit the structure of hyperbolic space and offer provable benefits in terms of performance (e.g., predictive accuracy). This fundamental question has received surprisingly limited attention. Indeed, while some prior work has proposed specific algorithms for learning classifiers in hyperbolic space, these have been primarily empirical in nature, and do not come equipped with theoretical guarantees on convergence and generalization.
Aspects and advantages of embodiments of the present disclosure will be set forth in part in the following description, or can be learned from the description, or can be learned through practice of the embodiments.
One example aspect of the present disclosure is directed to a computer-implemented method to learn a machine-learned classification model in a hyperbolic space. The method includes, for at least one of one or more training iterations: accessing, by a computing system comprising one or more computing devices, a current set of weights of the machine-learned classification model and a plurality of training examples, wherein each of the plurality of training examples comprises a respective input defined within the hyperbolic space and a respective ground truth label; identifying, by the computing system, one or more adversarial training examples respectively for one or more of the plurality of training examples, wherein, for each of the one or more of the plurality of training examples, the respective adversarial training example comprises an alternative input that, among all possible inputs that are contained in the hyperbolic space and that have a respective distance to the input of the training example that is less than an adversarial budget, maximizes a loss function that evaluates an output of machine-learned classification model; determining, by the computing system, an updated set of weights for the machine-learned classification model based at least in part on at least one of the one or more adversarial training examples; and outputting, by the computing system, the updated set of weights for the machine-learned classification model.
Another example aspect of the present disclosure is directed to a computing system for performing machine learning in hyperbolic space. The computing system includes one or more processors and one or more non-transitory computer-readable media that collectively store instructions that, when executed by the one or more processors cause the computing system to perform operations. The operations include, for at least one of one or more training iterations: accessing, by the computing system, a current set of weights of a machine-learned classification model and a plurality of training examples, wherein each of the plurality of training examples comprises a respective input defined within the hyperbolic space and a respective ground truth label. The operations include, for each of the plurality of training examples: generating, by the computing system, a predicted label for the respective input. When the predicted label is different from the respective ground truth label, the operations include determining, by the computing system, an intermediate set of weights for the machine-learned classification model based at least in part on the predicted label for the respective input; and normalizing, by the computing system, the intermediate set of weights to obtain an updated set of weights for which a Minkowski product of the updated set of weights with itself is less than zero. The operations include outputting, by the computing system, the updated set of weights for the machine-learned classification model.
Other aspects of the present disclosure are directed to various systems, apparatuses, non-transitory computer-readable media, user interfaces, and electronic devices.
These and other features, aspects, and advantages of various embodiments of the present disclosure will become better understood with reference to the following description and appended claims. The accompanying drawings, which are incorporated in and constitute a part of this specification, illustrate example embodiments of the present disclosure and, together with the description, serve to explain the related principles.
Detailed discussion of embodiments directed to one of ordinary skill in the art is set forth in the specification, which makes reference to the appended figures, in which:
Reference numerals that are repeated across plural figures are intended to identify the same features in various implementations.
Generally, the present disclosure provides systems and methods for performing machine learning in hyperbolic space. Specifically, techniques are provided which enable the learning of a classifier (e.g., large-margin classifier) for data defined within a hyperbolic space (e.g., which may be particularly beneficial for data that possesses a hierarchical structure).
One example aspect of the present disclosure is a hyperbolic perceptron algorithm, which provably converges to a separating hyperplane. In particular, the present disclosure provides a hyperbolic version of the classic perceptron algorithm and establishes its convergence for data that is separable with a margin. The provided algorithm establishes that it is possible to design classification algorithms that exploit the structure of hyperbolic space, while provably converging to some admissible (not necessarily large-margin) separator.
Another example aspect of the present disclosure provides algorithms to efficiently learn a machine-learned classification model (e.g., a large-margin hyperplane for a large-margin classifier), relying on the careful injection of adversarial examples. In particular, the present disclosure establishes how suitable injection of adversarial examples to gradient-based loss minimization can yield an algorithm which can efficiently learn a classification model. The present disclosure further demonstrates that simply performing gradient descent or using adversarial examples alone typically does not suffice to yield such a classifier efficiently. Thus, the provided algorithms establish that it is further possible to design classification algorithms that provably converge to a large-margin separator, by suitably injecting adversarial examples.
Yet another example aspect of the present disclosure provides proof that for hierarchical data that embeds well into hyperbolic space, the low embedding dimension ensures superior guarantees when learning the classifier directly in hyperbolic space. In particular, the present disclosure compares the Euclidean and hyperbolic approaches for hierarchical data and analyzes the trade-off between low embedding dimensions and low distortion (dimension-distortion trade-off) when learning robust classifiers on embedded data. For hierarchical data that embeds well into hyperbolic space, the low embedding dimension is sufficient to ensure superior guarantees when learning the classifier in hyperbolic space. Therefore, the present disclosure shows that the adaptation of algorithms to the intrinsic geometry of the data can lead to significant performance gains.
Thus, the present disclosure provides systems and methods for performing machine learning (e.g., learning a classification model such as a large-margin classifier) in hyperbolic space. Algorithms are provided for provably learning such classifiers in hyperbolic space. Technical analysis establishes that these can be superior to classifiers learned in naïve Euclidean space. Therefore, by using a hyperbolic space that better reflects the intrinsic geometry of the data, one can see gains in both representation size and performance.
The systems and methods of the present disclosure provide a number of technical effects and benefits. As one example, by enabling machine learning to be performed in hyperbolic space, improved machine-learned models such as classification models can be developed, which better leverage the intrinsic geometry of certain input data such as data which is hierarchical in nature. Thus, enabling machine learning to be performed in hyperbolic space, models can be generated which better account for (e.g., run faster, make better predictions, train faster, etc.) the structure of certain forms of input data.
As another example, aspects of the present disclosure provide algorithms for learning models in hyperbolic space with guaranteed convergence and/or other guarantees. By providing techniques with guaranteed convergence and/or other guarantees, the failure of certain models to converge can be reduced or eliminated. More generally, by providing techniques with guaranteed convergence and/or other guarantees, training attempts or schemes which fail or otherwise represent lost or unproductive usage of computing resources (e.g., process usage, memory usage, network bandwidth, etc.) can be reduced or eliminated, thereby conserving computing resources.
2.1 Hyperbolic Space
Hyperbolic spaces are smooth Riemannian manifolds =d with constant negative curvature K and are as such locally Euclidean spaces. The following introduces basic notation for two popular models of hyperbolic spaces. However, other models of hyperbolic space can be used with the present disclosure as well.
There are several equivalent models of hyperbolic space, each highlighting a different geometric aspect. In this work, the Lorentz model (aka hyperboloid model) is most prominently discussed for consistency. For x, x′∈d+1, let x*x′=x0x′0−Σi=1dxix′i denote their Minkowski product. The Lorentz model is defined as follows:
d
={x∈
d+1
:x*x=1}
(x,x′)=a cos h(x*x′).
The distance (x, y) corresponds to the length of the shortest line (geodesic) along the manifold connecting x and x′ (cf.
Another model of hyperbolic space that can be used is the Poincare half-plane model, which defines a hyperbolic metric space on the upper half of the complex plane as follows:
The Poincare half-plane model can also be defined for higher dimensions. Furthermore, there exists an isometric mapping between both Lorentz model and Poincare half-plane model that preserves the Minkowski product.
2.2 Embeddability of Hierarchical Data
A map ϕ: X1→X2 between metric spaces (X1, d1) and (X2, d2) is called embedding. One can measure embeddability using the following multiplicative notion of distortion: Define cM≥1 such that for all x, x′∈X1
d
2(ϕ(x),ϕ(x′)))≤d1(x,x′)≤cM·d2ϕ(x),ϕ(x′))
Embeddings with multiplicative distortion cM=1 are termed isometric embeddings.
Since hierarchical data is tree-like, one can use classic embeddability results for trees as a reference point. For the embeddability of trees, it has been shown that an N-point metric (i.e., ||=N) embeds into Euclidean space O(log
2.3 Classification in Hyperbolic Space
Example aspects of the present disclosure consider classification problems of the following form: ⊂d denotes the feature space, the label space and ⊂d+1 the model space. For now, consider a binary classification task, i.e., ={±1}. In the following, the training set is denoted as as ⊂×.
This discussion begins by defining geodesic decision boundaries. Consider the Lorentz space d with ambient space d+1. Then every geodesic decision boundary is a hyperplane in d intersecting d and d+1. Further, consider the set of linear separators or decision functions of the form
Note that the requirement w*w<0 in (2.1) ensures that the intersection of d and the decision hyperplane hw is not empty. The geodesic decision boundary corresponding to the decision function hw is then given by
∂w={z∈d:w*z=0}.
The distance of a point x∈d from the decision boundary ∂w can be computed as:
2.4 Large-Margin Classification in Hyperbolic Space
Example aspects of the present disclosure enable learning a large margin classifier in a hyperbolic space. Analogous to the Euclidean setting, the natural notion of margin is the minimal distance to the decision boundary over all training samples:
The goal of large-margin classifier learning is then to find a linear separator hw*defined by:
w*=argmaxw margin(w).
One step towards learning a large-margin classifier is to establish the ability to provably learn some separator. To this end, this section and
3.1 Example Hyperbolic Perceptron Algorithm
The hyperbolic perceptron (cf. Algorithm 1 in
v
t
←w
t
+yx.
In contrast to the Euclidean case, the present disclosure enables learning the hyperbolic perceptron via application of a normalization step:
This ensures that wt+1*wt+1<0; as a result wt+1 defines a meaningful classifier, i.e., d ∩∂w
It remains to establish that this algorithm converges, i.e., finds a solution which correctly classifies all the training samples. To this end, consider the following notion of hyperbolic linear separability with a margin: for X, X′⊆d, it can be said that X and X′ are linearly separable with margin γ, if there exists a w∈d+1 with √{square root over (−w*w=1)} such that
w*x>γ′∀×∈X and w*x′<−γ′∀x′∈X′,
where γ′=a sin h(γ). Assuming our training set is separable with a margin, the hyperbolic perceptron has the following convergence guarantee.
Theorem 3.1. Assume that there is some
steps and returns a solution with margin γ.
The proof of Theorem 3.1 follows the standard proof of the Euclidean perceptron and utilizes the Cauchy-Schwartz inequality for the Minkowski product.
Remark 3.2 Recall that the classic guarantee for the perceptron algorithm in Euclidean space establishes a O(1/γ2) convergence rate When γ˜0, the
convergence rate for hyperbolic spaces can be significantly faster than
indicating that exploiting the structure of hyperbolic space can be beneficial.
3.2 A Challenge of Large-Margin Learning
Theorem 3.1 establishes that the hyperbolic perceptron converges to some linear separator. However, for the purposes of generalization, one would ideally like to converge to a large-margin separator. As with the classic Euclidean perceptron, no such guarantee is possible for the hyperbolic perceptron; this motivates to ask whether a suitable modification can rectify this.
One example way to proceed is to consider the use of margin losses, such as the logistic or hinge loss. Formally, let l: ×{±1}→+ be a loss function of the form
l(x,y;w)=f(y·(w*x)), (3.1)
where f:→+ is some convex, non-increasing function, e.g., the hinge loss. The empirical risk of the classifier parametrized by on the training set ⊂×{±1} is
A common strategy to learn a suitable classifier is to minimize this empirical risk via gradient descent, which for learning rate η>0 generates iterates
Unfortunately, while this will yield a large-margin solution, the following result demonstrates that the number of iterations required may be prohibitively large.
Theorem 3.3 Let ei ∈d+1 be the i-th standard basis vector. Consider the training set ={(e1, 1), (−e1, −1)} and the initialization w0=e2. Suppose {wt}t≥0 is a sequence of classifiers generated by the gradient descent updates (cf. (3.2)). Then, the number of iterations needed to achieve margin γ is Ω(exp(γ)).
While this result appears disheartening, fortunately, the present disclosure presents a simple resolution: by suitably adding adversarial examples, the solution found by the gradient descent converges to a large-margin solution in polynomial time.
Theorem 3.3 reveals that gradient descent on a margin loss is insufficient to efficiently obtain a large-margin classifier. However, this section shows how to alleviate this problem by enriching the training set with adversarial examples before updating the classifier (cf. Algorithm 2 in
The inner optimization defined in (4.2) generates an adversarial example by perturbing a given input feature x on the hyperbolic manifold. Note that the magnitude of the perturbation added to the original example is bounded by α, which is referred to as the adversarial budget. In particular, it is desirable to construct a perturbation that maximizes the loss, i.e., {tilde over (x)}←argmax(x,z)≤αl(z,y;w).
The outer optimization (cf. (4.1)) can be achieved by an iterative optimization procedure, which generates a sequence of classifiers {wt}. The classifier wt can be updated according to an update rule , which accepts as input the current estimate of the weight vector, the original training set, and an adversarial perturbation of the training set. The update rule produces as output a weight vector which approximately minimizes the robust loss Lrob in (4.1).
It is now established that for a gradient based update rule, the above adversarial training procedure will efficiently converge to a large-margin solution.
4.1 Example Fast Convergence Via Gradient-Based Update
Consider Algorithm 2 with (wt, ,t′) being a gradient-based update with learning rate ηt>0:
Note that the normalization is performed to ensure that the update remains valid, i.e., d ∩∂cw≠∅.
To compute the update, one needs to compute gradients of the outer minimization problem, i.e., ∇w, lrob over t′ (cf. (4.1)). However, this function is itself a maximization problem (cf. (4.2)). Therefore the gradient can be computed at the maximizer of this inner maximization problem. Danskin's theorem ensures that this gives a valid descent direction.
The inner maximization can be solved in closed form as:
where b, {hacek over (x)}, and {hacek over (x)}⊥ are defined in Theorem 4.4. Given the closed form expression for the adversarial example {tilde over (x)}, one can compute the gradient of the loss as
where ∇wy(w*{tilde over (x)})=y{tilde over (x)}T=y({tilde over (x)}0, −{tilde over (x)}1, . . . , −{tilde over (x)}n)T. With Danskin's theorem, ∇l({tilde over (x)}, y; w)∈∂lrob(x,y;w), from which one can compute the descent direction and therefore the update step.
4.1.1 Example Convergence Analysis
This subsection establishes that the above gradient-based update converges to a large-margin solution in polynomial time. For this analysis, the following assumptions are used:
Assumption 1.
1. The training set is linearly separable, i.e., there exists a
2. There exists some constant Rx>0, such that (i) ∥x∥≤Rx and (ii) all possible adversarial perturbations remain within this constraint, i.e., ∥{tilde over (x)}∥≤Rx. Furthermore, we assume ∥w∥≤Rw for some constant Rw. Let Rα: =RxRw.
3. The function ƒ(s), underlying the loss (cf. (3.1)), has the following properties: (i) ƒ(s)>0 ∀s; (ii) ƒ′(s)<0 ∀s; (iii) ƒ is differentiable, and (iv) ƒ is β-smooth.
An example loss function that fulfills Assumption 1 is the following hyperbolic equivalent of the logistic regression loss:
where Rα is as defined in Assumption 1. The following focuses on this example choice of the loss function. Other loss functions as well as the derivation of the hyperbolic logistic regression loss can be used instead and are discussed in U.S. Provisional Patent Application No. 63/008,288.
First it is shown that Algorithm 2 with a gradient update is guaranteed to converge to a large-margin classifier.
Theorem 4.1 With constant step size and being the GD update with an initialization w0 with w0*w0<0, limt→∞L(wt; ∩′t)=0.
The proof can be found in U.S. Provisional Patent Application No. 63/008,288. While this result guarantees convergence, it does not guarantee efficiency (e.g., by showing a polynomial convergence rate). Next, we quantify the convergence rate of Algorithm 2, showing that the algorithm with a gradient based update computes a max-margin classifier in polynomial time.
Theorem 4.2 (Convergence rate GD update, Algorithm 2) For a fixed constant c∈(0,1), let the step size
with σmax denoting an upper bound on the maximum singular value of the data matrix, and be the GD update as defined in (4.3a) and (4.3b). Then, the iterates {wt} in Algorithm 1 satisfy the following:
The proof of Theorem 4.2 and the accompanying auxiliary results are presented in the U.S. Provisional Patent Application No. 63/008,288.
4.2 Discussion Regarding Combining Gradient Descent and Adversarial Training
It is noted here that the enrichment of the training set with adversarial examples is significantly important for the polynomial-time convergence. Recall first that by Theorem 3.3, without adversarial training, one can construct a simple max-margin problem that cannot be solved in polynomial time. Interestingly, merely using adversarial examples by themselves does not suffice for fast convergence either.
Consider Algorithm 2 with an ERM as the update rule (t, , ′). In this case, the iterate wt+1 corresponds an ERM solution for ∩′, i.e.,
Let t=, i.e., we utilize the full power of the adversarial training in each step. The following result reveals that even under this optimistic setting, Algorithm 2 may not converge to a solution with a non-trivial margin in polynomial time:
Theorem 4.3 Suppose Algorithm 2 (with an ERM update) outputs a linear separator of ∩′. In the worst case, the number of iteration required to achieve a margin at least E is Ω(exp(d)).
To prove Theorem 4.3, given a spherical code d in with T codewords and θ˜sin h(ε)cos h(α) minimum separation, we construct a training set and subsequently the adversarial examples {t} such that there exists an ERM solution wt on ∩′ (cf. (4.5)) that has margin less than ε. Now the result in Theorem 4.3 follows by utilizing a lower bound on the size of the spherical code with T=Ω(exp(d)) codewords and θ˜sin h(ε)cos h(α) minimum separation. The detailed proof of Theorem 4.3 is presented in the U.S. Provisional Patent Application No. 63/008,288.
4.3 Example Technique for Computing Adversarial Examples
This section returns to the issue of efficiently computing the adversarial examples. Consider the certification problem: Given a classifier w∈d+1 that defines a decision function hW ∈ (cf. (2.1)), a point x∈d and a budget α>1, can we efficiently decide whether there exists an adversarial example with (x,{tilde over (x)})≤α such that hw(x)≠hw({tilde over (x)}). Recall that some example implementations only consider those adversarial examples that lead to misclassification.
For given (x, y) and w, recall that the adversarial example of interest is defined as follows
{tilde over (x)}←argma(x,z)≤αl(z,y;w).
For the underlying loss function (cf. (4.4)), this problem can be equivalently expressed as
where w′=−yw. One can now guess z0, the first coordinate of z in (4.6), which reduces (4.6) to an (Euclidean) linear program with a spherical constraint:
Next, the closed-form solution for (CERT) is provided.
Theorem 4.4 Given the input example (x, y), let x\0=(x1, . . . , xd). One can efficiently compute a solution to CERT or decide that no solution exists. If a solution exists, then (based on a guess of z0 a maximizing adversarial example has the form {tilde over (x)}=z0, √{square root over (z02−1)}(b{hacek over (x)}+√{square root over (1−b2{hacek over (x)})}⊥)). Here,
depends on the adversarial budget α, and {hacek over (x)}⊥ is a unit vector orthogonal to {hacek over (x)}=x\0/∥x\0∥.
The proof of Theorem 4.4 is presented in U.S. Provisional Patent Application No. 63/008,288.
Note that according to Theorem 4.4, it is possible that, for a particular guess of z0, one may not be able to find an adversarial example 5c″ that leads to a prediction that is inconsistent with x, i.e., hw(x)≠hw({tilde over (x)}). Thus, for some t, one may have |′t|<m in Algorithm 2.
So far we have focused on classifying data that is given in either Euclidean spaces d or Lorentz space d′. Now, consider data (, dχ) with similarity metric dχ that was embedded into the respective spaces. We further assume access to maps ϕE:→d and ϕH: →+d′ that embed into the Euclidean space d and the upper sheet of the Lorentz space +d′, respectively. Let cE and cH denote the multiplicative distortion induced by ϕE and ϕH, respectively (cf. § 2.2). Upper bounds on cE and cH can be estimated based on the structure of (e.g., tree-like) and the embedding dimensions (d and d′, respectively).
How does the distortion cE, cH impact our guarantees on the margin? In the previous sections, we noticed that some of the guarantees scale with the dimension of the embedding space. Therefore, we want to analyze the trade-off between the higher distortion resulting from working with smaller embedding dimensions and the higher cost of training robust models due to working with larger embedding dimensions.
Datasets are often encountered in ML applications that are intrinsically hierarchical. Theoretical results on the embeddability of trees (cf. § 2.2) suggest that hyperbolic spaces are especially suitable to represent hierarchical data. Therefore the analysis is restricted to such data. Further, the following assumptions are made on the underlying data and the embedding maps, respectively.
Assumption 2 (1) Both ϕH() and ϕE() are linearly separable in the respective spaces, and (2) X is hierarchical, i.e., has a partial order relation.
Assumption 3 The maps ϕH, ϕE preserve the partial order relation in X and the root is mapped onto the origin of the embedding space.
Example approaches described herein relate the distance between the support vectors to the size of the margin. The distortion of these distances via embedding then gives a bound on the error induced on the margin.
5.1 Example Euclidean Case
In the Euclidean case, one example technique is to relate the distance of the support vectors to the size of the margin via triangle relations. Let x, y, ∈d denote support vectors, such that x, w>0 and y, w<0 and margin(w)=ε. One can rotate the decision boundary, such that the support vectors are not unique. Without loss of generality, assume that x1, x2 are equidistant from the decision boundary and ∥w∥=1. In this setting, we show the following relation between the margin with (ε′) and without (ε) the influence of distortion:
Theorem 5.1 Let ε′ and ε denote the margin with and without distortion. Then
Corollary 5.2 If is a tree embedded into O(log2||), then
The proof of Theorem 5.1 follows from a simple side length-altitude relations in the Euclidean triangle between support vectors (cf.
5.2 Example Hyperbolic Case
As in the Euclidean case, one example technique is to relate the margin to the pairwise distances of the support vectors. Such a relation can be constructed both in the original and in the embedding space, which allows us to study the influence of distortion on the margin in terms of cH. In the following, the half-space model d′ (cf. § 2.1) is used. However, since the theoretical guarantees in the rest of the paper consider the Lorentz model +d′, it may be necessary to map between the two spaces. It is shown in the U.S. Provisional Patent Application No. 63/008,288 that such a mapping exists and preserves the Minkowski product.
The hyperbolic embedding ϕH has two sources of distortion: (1) the multiplicative distortion of pairwise distances, measured by the factor
and (2) the distortion of order relations, in most embedding models captured by the alignment of ranks with the Euclidean norm. Under Assumption 0, order relationships are preserved and the root is mapped to the origin. Therefore, for x∈, the distortion on the Euclidean norms is given as follows:
i.e., the distortion on both pairwise distances and norms is given by a factor CH−1
In d′, the decision hyperplane corresponds to a hypercircle w. We express its radius rw in terms of the hyperbolic distance between a point on the decision boundary and one of the hypercircle's ideal points. The support vectors, lie on hypercircles x and y, which correspond to the set of points of hyperbolic distance E (i.e., the margin) from the decision boundary. We again assume, without loss of generality, that at least one support vector is not unique and let x1, x2 ∈x and y∈y (cf.
Theorem 5.3 Let again ε′, ε denote the margin with and without distortion. If is a tree embedded into +2, ε′≈ε.
The technical proof relies on a construction that reduces the problem to Euclidean geometry via circle inversion on the decision hypercircle.
The user computing device 102 can be any type of computing device, such as, for example, a personal computing device (e.g., laptop or desktop), a mobile computing device (e.g., smartphone or tablet), a gaming console or controller, a wearable computing device, an embedded computing device, or any other type of computing device.
The user computing device 102 includes one or more processors 112 and a memory 114. The one or more processors 112 can be any suitable processing device (e.g., a processor core, a microprocessor, an ASIC, a FPGA, a controller, a microcontroller, etc.) and can be one processor or a plurality of processors that are operatively connected. The memory 114 can include one or more non-transitory computer-readable storage mediums, such as RAM, ROM, EEPROM, EPROM, flash memory devices, magnetic disks, etc., and combinations thereof. The memory 114 can store data 116 and instructions 118 which are executed by the processor 112 to cause the user computing device 102 to perform operations.
In some implementations, the user computing device 102 can store or include one or more machine-learned models 120. For example, the machine-learned models 120 can be or can otherwise include various margin-based classifiers such as large-margin classifiers. In other examples, the machine-learned models 120 can be or can otherwise include machine-learned models such as neural networks (e.g., deep neural networks) or other types of machine-learned models, including non-linear models and/or linear models. Neural networks can include feed-forward neural networks, recurrent neural networks (e.g., long short-term memory recurrent neural networks), convolutional neural networks or other forms of neural networks.
In some implementations, the one or more machine-learned models 120 can be received from the server computing system 130 over network 180, stored in the user computing device memory 114, and then used or otherwise implemented by the one or more processors 112. In some implementations, the user computing device 102 can implement multiple parallel instances of a single machine-learned model 120.
Additionally or alternatively, one or more machine-learned models 140 can be included in or otherwise stored and implemented by the server computing system 130 that communicates with the user computing device 102 according to a client-server relationship. For example, the machine-learned models 140 can be implemented by the server computing system 140 as a portion of a web service. Thus, one or more models 120 can be stored and implemented at the user computing device 102 and/or one or more models 140 can be stored and implemented at the server computing system 130.
The user computing device 102 can also include one or more user input component 122 that receives user input. For example, the user input component 122 can be a touch-sensitive component (e.g., a touch-sensitive display screen or a touch pad) that is sensitive to the touch of a user input object (e.g., a finger or a stylus). The touch-sensitive component can serve to implement a virtual keyboard. Other example user input components include a microphone, a traditional keyboard, or other means by which a user can provide user input.
The server computing system 130 includes one or more processors 132 and a memory 134. The one or more processors 132 can be any suitable processing device (e.g., a processor core, a microprocessor, an ASIC, a FPGA, a controller, a microcontroller, etc.) and can be one processor or a plurality of processors that are operatively connected. The memory 134 can include one or more non-transitory computer-readable storage mediums, such as RAM, ROM, EEPROM, EPROM, flash memory devices, magnetic disks, etc., and combinations thereof. The memory 134 can store data 136 and instructions 138 which are executed by the processor 132 to cause the server computing system 130 to perform operations.
In some implementations, the server computing system 130 includes or is otherwise implemented by one or more server computing devices. In instances in which the server computing system 130 includes plural server computing devices, such server computing devices can operate according to sequential computing architectures, parallel computing architectures, or some combination thereof.
As described above, the server computing system 130 can store or otherwise include one or more machine-learned models 140. For example, the models 140 can be or can otherwise include various machine-learned models. Example machine-learned models include various margin-based classifiers such as large-margin classifiers. In other examples, the machine-learned models 140 can be or can otherwise include neural networks or other multi-layer non-linear models. Example neural networks include feed forward neural networks, deep neural networks, recurrent neural networks, and convolutional neural networks.
The user computing device 102 and/or the server computing system 130 can train the models 120 and/or 140 via interaction with the training computing system 150 that is communicatively coupled over the network 180. The training computing system 150 can be separate from the server computing system 130 or can be a portion of the server computing system 130.
The training computing system 150 includes one or more processors 152 and a memory 154. The one or more processors 152 can be any suitable processing device (e.g., a processor core, a microprocessor, an ASIC, a FPGA, a controller, a microcontroller, etc.) and can be one processor or a plurality of processors that are operatively connected. The memory 154 can include one or more non-transitory computer-readable storage mediums, such as RAM, ROM, EEPROM, EPROM, flash memory devices, magnetic disks, etc., and combinations thereof. The memory 154 can store data 156 and instructions 158 which are executed by the processor 152 to cause the training computing system 150 to perform operations. In some implementations, the training computing system 150 includes or is otherwise implemented by one or more server computing devices.
The training computing system 150 can include a model trainer 160 that trains the machine-learned models 120 and/or 140 stored at the user computing device 102 and/or the server computing system 130 using various training or learning techniques, such as, for example, backwards propagation of errors. For example, a loss function can be backpropagated through the model(s) to update one or more parameters of the model(s) (e.g., based on a gradient of the loss function). Various loss functions can be used such as mean squared error, likelihood loss, cross entropy loss, hinge loss, and/or various other loss functions. Gradient descent techniques can be used to iteratively update the parameters over a number of training iterations.
In some implementations, performing backwards propagation of errors can include performing truncated backpropagation through time. The model trainer 160 can perform a number of generalization techniques (e.g., weight decays, dropouts, etc.) to improve the generalization capability of the models being trained.
In particular, the model trainer 160 can train the machine-learned models 120 and/or 140 based on a set of training data 162. The training data 162 can include, for example, data defined within a hyperbolic space such as, for example, data that has a hierarchical structure. The model trainer 160 can be configured to perform some or all of the algorithms or methods described herein, including Algorithms 1 and/or 2 and/or the methods of
In some implementations, if the user has provided consent, the training examples can be provided by the user computing device 102. Thus, in such implementations, the model 120 provided to the user computing device 102 can be trained by the training computing system 150 on user-specific data received from the user computing device 102. In some instances, this process can be referred to as personalizing the model.
The model trainer 160 includes computer logic utilized to provide desired functionality. The model trainer 160 can be implemented in hardware, firmware, and/or software controlling a general purpose processor. For example, in some implementations, the model trainer 160 includes program files stored on a storage device, loaded into a memory and executed by one or more processors. In other implementations, the model trainer 160 includes one or more sets of computer-executable instructions that are stored in a tangible computer-readable storage medium such as RAM hard disk or optical or magnetic media.
The network 180 can be any type of communications network, such as a local area network (e.g., intranet), wide area network (e.g., Internet), or some combination thereof and can include any number of wired or wireless links. In general, communication over the network 180 can be carried via any type of wired and/or wireless connection, using a wide variety of communication protocols (e.g., TCP/IP, HTTP, SMTP, FTP), encodings or formats (e.g., HTML, XML), and/or protection schemes (e.g., VPN, secure HTTP, SSL).
The computing device 10 includes a number of applications (e.g., applications 1 through N). Each application contains its own machine learning library and machine-learned model(s). For example, each application can include a machine-learned model. Example applications include a text messaging application, an email application, a dictation application, a virtual keyboard application, a browser application, etc.
As illustrated in
The computing device 50 includes a number of applications (e.g., applications 1 through N). Each application is in communication with a central intelligence layer. Example applications include a text messaging application, an email application, a dictation application, a virtual keyboard application, a browser application, etc. In some implementations, each application can communicate with the central intelligence layer (and model(s) stored therein) using an API (e.g., a common API across all applications).
The central intelligence layer includes a number of machine-learned models. For example, as illustrated in
The central intelligence layer can communicate with a central device data layer. The central device data layer can be a centralized repository of data for the computing device 50. As illustrated in
At 602, the method 600 can include accessing by a computing system, a current set of weights of a machine-learned classification model and a plurality of training examples, wherein each of the plurality of training examples comprises a respective input defined within the hyperbolic space and a respective ground truth label.
In some implementations, the machine-learned classification model comprises a large-margin classification model. In some implementations, the machine-learned classification model comprises a binary classification model.
In some implementations, the hyperbolic space is modeled according to a Lorentz model. In some implementations, the hyperbolic space is modeled according to a Poincare model.
At 604, the method 600 can include accessing the next training example.
At 606, the method 600 can include generating, by the computing system, a predicted label for the respective input.
In some implementations, generating, by the computing system, the predicted label for the respective input can include determining a sign of a Minkowski product of the respective input and the current set of weights.
At 608, the method 600 can include determining whether the predicted label is different from the respective ground truth label. If different, the method can proceed to 610; if not different, the method can proceed to 614.
At 610, the method 600 can include determining, by the computing system, an intermediate set of weights for the machine-learned classification model based at least in part on the predicted label for the respective input.
At 612, the method 600 can include normalizing, by the computing system, the intermediate set of weights to obtain an updated set of weights for which a Minkowski product of the updated set of weights with itself is less than zero.
In some implementations, normalizing, by the computing system, the intermediate set of weights to obtain the updated set of weights can include, when a square root of a Minkowski product between a negative of the intermediate set of weights and the intermediate set of weights is less than one: setting, by the computing system, the updated set of weights equal to the intermediate set of weights divided by the square root of the Minkowski product between the negative of the intermediate set of weights and the intermediate set of weights.
At 614, the method 600 can include determining whether additional training examples remain. If additional examples remain, the method can return to 604; if additional examples do not remain, the method can proceed to 616.
At 616, the method 600 can include outputting, by the computing system, the updated set of weights for the machine-learned classification model.
At 702, the method 700 can include accessing, by a computing system comprising one or more computing devices, a current set of weights of the machine-learned classification model and a plurality of training examples, wherein each of the plurality of training examples comprises a respective input defined within the hyperbolic space and a respective ground truth label.
In some implementations, the machine-learned classification model comprises a large-margin classification model. In some implementations, the machine-learned classification model comprises a binary classification model.
In some implementations, the hyperbolic space is modeled according to a Lorentz model. In some implementations, the hyperbolic space is modeled according to a Poincare model.
At 704, the method 700 can include identifying, by the computing system, one or more adversarial training examples respectively for one or more of the plurality of training examples. In some implementations, for each of the one or more of the plurality of training examples, the respective adversarial training example comprises an alternative input that, among all possible inputs that are contained in the hyperbolic space and that have a respective distance to the input of the training example that is less than an adversarial budget, maximizes a loss function that evaluates an output of machine-learned classification model.
In some implementations, for each possible input contained in the hyperbolic space, the respective distance to the input of the respective training example is based at least in part on a Minkowski product between the possible input and the input of the respective training example.
At 706, the method 700 can include determining, by the computing system, an updated set of weights for the machine-learned classification model based at least in part on at least one of the one or more adversarial training examples.
In some implementations, determining, by the computing system, the updated set of weights for the machine-learned classification model based at least in part on the at least one of the one or more adversarial training examples can include performing a gradient descent technique with respect to the loss function.
In some implementations, the loss function comprises a margin loss function that evaluates a Minkowski product between the current set of weights and the respective input.
In some implementations, determining, by the computing system, the updated set of weights for the machine-learned classification model based at least in part on the at least one of the one or more adversarial training examples can include: determining, by the computing system, an intermediate set of weights for the machine-learned classification model based at least in part on the at least one of the one or more adversarial training examples; and normalizing, by the computing system, the intermediate set of weights to obtain the updated set of weights such that a Minkowski product of the updated set of weights with itself is less than zero.
In some implementations, normalizing, by the computing system, the intermediate set of weights to obtain the updated set of weights can include: setting, by the computing system, the updated set of weights equal to the intermediate set of weights divided by a square root of a Minkowski product between a negative of the intermediate set of weights and the intermediate set of weights.
At 708, the method 700 can include outputting, by the computing system, the updated set of weights for the machine-learned classification model.
The technology discussed herein makes reference to servers, databases, software applications, and other computer-based systems, as well as actions taken and information sent to and from such systems. The inherent flexibility of computer-based systems allows for a great variety of possible configurations, combinations, and divisions of tasks and functionality between and among components. For instance, processes discussed herein can be implemented using a single device or component or multiple devices or components working in combination. Databases and applications can be implemented on a single system or distributed across multiple systems. Distributed components can operate sequentially or in parallel.
While the present subject matter has been described in detail with respect to various specific example embodiments thereof, each example is provided by way of explanation, not limitation of the disclosure. Those skilled in the art, upon attaining an understanding of the foregoing, can readily produce alterations to, variations of, and equivalents to such embodiments. Accordingly, the subject disclosure does not preclude inclusion of such modifications, variations and/or additions to the present subject matter as would be readily apparent to one of ordinary skill in the art. For instance, features illustrated or described as part of one embodiment can be used with another embodiment to yield a still further embodiment. Thus, it is intended that the present disclosure cover such alterations, variations, and equivalents.
This application claims priority to and the benefit of U.S. Provisional Patent Application No. 63/008,288, filed Apr. 10, 2020. U.S. Provisional Patent Application No. 63/008,288 is hereby incorporated by reference in its entirety.
Number | Date | Country | |
---|---|---|---|
63008288 | Apr 2020 | US |