Proximal Gradient Method for Huberized Support Vector Machine
The Support Vector Machine (SVM) has been used in a wide variety of classification problems. The original SVM uses the hinge loss function, which is nondifferentiable and makes the problem difficult to solve in particular for regularized SVMs, such as with l1-norm. The Huberized SVM (HSVM) is considered, which uses a differentiable approximation of the hinge loss function. The Proximal Gradient (PG) method is used to solving binary-class HSVM (BHSVM) and then generalized to multi-class HSVM (MHSVM). Under strong convexity assumptions, the algorithm converges linearly. A finite convergence result about the support of the solution is given, based on which the algorithm is further accelerated by a two-stage method.
This application claims the benefit of co-pending United States provisional patent application entitled “PROXIMAL GRADIENT METHOD FOR HUBERIZED SUPPORT VECTOR MACHINE” filed on Mar. 11, 2014 and assigned Ser. No. 61/951,005, the contents of which is hereby incorporated by reference in its entirety herein.
BACKGROUND OF THE INVENTION1. Field of the Invention
The invention relates generally to solving classification problems. More specifically, the invention addresses the use of a support vector machine to solve classification problems with sample data having a large number of correlated features that can be grouped together, such as in medical image analysis.
2. Description of the Prior Art
The original linear support vector machine (SVM) aims to find a hyperplane that separates a collection of data points. Since it was proposed, the SVM has been widely used for binary classifications, such as texture classification, gene expression data analysis and face recognition. Mathematically, given a set of samples {xi}i=1n in p-dimensional space and each xi attached with a label yiε{+1, −1}, the linear SVM learns a hyperplane (w*)Tx+b*=0 from the training samples. A new data point x can be categorized into the “+1” or “−1” class by inspecting the sign of (w*)Tx+b*.
The binary-class SVM (B-SVM) has been generalized to multicategory classifications to tackle problems where the data points belong to more than two classes. The initially proposed multi-class SVM (M-SVM) methods construct several binary classifiers, such as “one-against-all,” “one-against-one,” and “directed acyclic graph SVM.” These M-SVMs may suffer from data imbalance; namely, some classes have far fewer data points than others, which can result in inaccurate predictions. One alternative is to put all the data points together in one model, which results in the so-called “all-together” M-SVMs. The “all-together” M-SVMs train multi-classifiers by considering a single large optimization problem.
A need exists, however, for techniques to assure that both the binary and the multiclass methods converge linearly, and to reduce the run-time of the models.
Medical images such as X-rays images, CAT scans and MRI images provide physicians with non-intrusive techniques for the diagnosis of a wide variety of medical conditions. The analysis of those images often involves the classification of the image as indicating one of two medical conditions, or as indicating one of a larger number of medical conditions.
Manual analysis of medical images is complex and time consuming, and requires experts with extensive experience. For those reasons, computer learning techniques and classification methods have been used to identify medical conditions using images. The classification methods, however, suffer from difficulties with convergence and with long run times, because of the extremely high dimensionality that is typical of medical image classification problems. There is therefore a need for medical image analysis techniques that assure linear convergence and reduce the run-time of the models.
SUMMARY OF THE INVENTIONAccordingly, it is an object of the invention is to provide support vector machine classification models that are capable of solving classification problems with high dimensionality, while assuring convergence and reducing run time. It is another object to provide a classifier capable of classifying medical images.
These and other objects are achieved in one or more embodiments of the invention by a computer-implemented method for training a support vector machine classifier. A hinge loss term of a support vector machine model of the classifier is replaced with a differentiable approximation of the hinge loss term based on a Huber loss function, to produce a differentiable support vector machine model. A proximal gradient method is then applied to solve the differentiable support vector machine model, to produce updates for an algorithm for determining a separating hyperplane of the differentiable support vector machine model. The algorithm is then used to determine the separating hyperplane.
Another exemplary embodiment of the invention features a computer-implemented method for training a binary support vector machine classifier for classifying data items with high dimensionality. A set of n data items x=x1, x2, . . . , xn is received, each data item being a vector with dimensionality m and associated labels yiε{+1, −1}. Also received are a plurality of support vector machine tuning parameters λ1, λ2, λ3 and a parameter δ defining a vicinity around a non-differentiable point of a hinge loss function is approximated by a quadratic smooth function. A constant Lf is computed such that the loss function of the binary support vector machine classifier is Lipschitz continuous.
The method then solves for a maximum margin separating hyperplane u*=(b*, w*) of the classifier by minimizing a function of the data items x and associated labels y:
where φH is a Huberized hinge loss function having values defined by
the minimizing comprising executing successive iterations k, each iteration resulting in a hyperplane uk closer to the maximum margin separating hyperplane u* than a previously found separating hyperplane uk−1, each iteration comprising:
-
- computing ûk−1=uk−1+ωk−1(uk−1−uk−2) wherein û is an intermediate hyperplane defined as a linear combination of hyperplanes found in two previous iterations and ωk−1≦1 is a weight given to hyperplane definitions of two immediately previous iterations;
- updating a Lipschitz constant Lk as min(ζn
k Lk−1, Lƒ), where η>1 is a preselected counter, and nk is an integer computed to guarantee monotonic decrease of the hinge loss function and leads to convergence of the successive iterations; - updating the hyperplane uk as
-
- wherein the function ƒ is defined by:
-
- and wherein Sλ
1 is a component-wise shrinkage operator, and {circumflex over (b)} and ŵ are a bias and a slope of the intermediate hyperplane definition û; and - re-updating uk with ûk−1=uk−1 only if F(uk)>F(uk−1), where F is defined as a function whereby
- and wherein Sλ
In that method, each of the successive iterations k may further comprise storing Vuk−1 and Vuk where V=(v1, . . . , vn)T and vi=(yi;yixi); obtaining Vûk=Vuk+ωk(Vuk−Vuk−1); and computing ∇ƒ (ûk−1) and evaluating F(uk) using Vûk.
That method may further comprise, before solving for a separating hyperplane u*, executing successive iterations k with Lk=Lƒ until wk remains substantially unchanged, the iterations comprising: computing ûk−1=uk−1; updating the hyperplane uk as
and re-updating uk with ûk−1=uk−1 only if F(uk)>F(uk−1); defining a lower-dimensional w by confining w to those elements for which support is substantially greater than 0; and performing the step of solving for a separating hyperplane u* with the lower-dimensional w.
The methods may be expanded as disclosed below to train a support vector machine classifier having more than two classes. The respective features of the exemplary embodiments of the invention may be applied jointly or severally in any combination or sub-combination by those skilled in the art.
The teachings of the exemplary embodiments of the invention can be readily understood by considering the following detailed description in conjunction with the accompanying drawings, in which:
To facilitate understanding, identical reference numerals have been used, where possible, to designate identical elements that are common to the figures.
DETAILED DESCRIPTIONAfter considering the following description, those skilled in the art will realize that the exemplary embodiments of the invention can be utilized in training and using an algorithm for classifying data points.
The original SVM uses the hinge loss in the classification process. A major drawback of the hinge loss is that it is described by a non-differentiable function and as such it limits the application of the efficient optimization algorithms in the solution process of SVMs. For large-scale classification problems, the optimization problems that need to be solved are huge and they may require a lot of time to be solved accurately. Hence the use of fast optimization algorithms is vital.
The Proximal Gradient (PG) method is one of the fastest optimization algorithms. Its application in the original SVM, however, is problematic because of the non-differentiability of the hinge loss. In order to apply the PG method efficiently, the presently described methods transform the original SVM model by replacing the hinge loss with a differentiable approximation based on the Huber loss function. The PG method is then applied on the approximate optimization problem to solve it quickly and accurately. The disclosed methods are general enough to be applied to both Binary and Multi-class classification problems using SVM. By using only first order information (gradients) the technique is able to solve very large classification problems which may involve hundreds of thousands of features. From computational experiments, the inventors have determined that the disclosed algorithms are much faster and more accurate than state-of-the-art methods.
In the present disclosure, both B-SVM and M-SVM are considered. More precisely, both the binary-class huberized SVM (B-HSVM) (see expression (2) below) for B-SVM, and the “all-together” multi-class HSVM (M-HSVM) (see expression (3) below) for M-SVM, are considered. The advantage of HSVM over classic SVM with hinge loss is the continuous differentiability of its loss function, which enables the use of the “fastest” first-order method: Proximal Gradient (PG) method. The present disclosure demonstrates that the PG method is, in general, much faster than existing methods for (regularized) B-SVM and M-SVM, while yielding comparable prediction accuracies. In addition, extensive numerical experiments are presented to compare the presently disclosed method to state-of-the-art methods for both B-SVM and M-SVM on synthetic and also benchmark datasets. Statistical comparison is also performed to show the difference between the proposed method and other methods.
B-HSVM appears to be first considered in L. Wang, J. Zhu, and H. Zou, Hybrid huberized support vector machines for microarray classification and gene selection, Bioinformatics, 24(3):412-419 (2008) (“Wang et al.”), the content of which is incorporated herein in its entirety. That paper demonstrates that B-HSVM can perform better than the original unregularized SVM and also l1-regularized SVM (i.e., expression (1) below with λ2=0) for microarray classification.
A closely related model to that of B-HSVM is the elastic net regularized SVM:
where [1−t]+=max(0,1−t) is the hinge loss function. The l1-norm regularizer has the ability to perform continuous shrinkage and automatic variable selection at the same time, and the l2-norm regularizer can help to reduce the variance of the estimated coefficients and usually results in satisfactory prediction accuracy, especially in the case where there are many correlated variables. The elastic net inherits the benefits of both l1- and l2-norm regularizers and can perform better than either of them alone.
Note that expression (1) uses non-differentiable hinge loss function while B-HSVM uses differentiable huberized hinge loss function. The differentiability makes B-HSVM relatively easier to solve. A path-following algorithm was proposed by Wang et. al for solving B-HSVM. Their algorithm is not efficient in particular for large-scale problems, since it needs to track the disappearance of variables along a regularization path. In Y. Yang and H. Zou, An efficient algorithm for computing the hhsvm and its generalizations, Journal of Computational and Graphical Statistics, (accepted for publication), the content of which is incorporated herein in its entirety, a Generalized Coordinate Descent (GCD) method is proposed, which was, in most cases, about 30 times faster than the path-following algorithm. However, the GCD method needs to compute the gradient of the loss function of B-HSVM after each coordinate update, which makes the algorithm slow.
M-HSVM has been considered in J. Li and Y. Jia, Huberized multiclass support vector machine for microarray classification, Acta Automatica Sinica, 36(3) 399-405 (2010), the content of which is incorporated herein in its entirety, which generalizes work by Wang et al. on B-SVM to M-SVM and also makes a path-following algorithm. Their algorithm, however, could be even worse since it also needs to track the disappearance of variables along a regularization path and M-HSVM often involves more variables than those of B-HSVM. Hence, it is not suitable for large scale problems, either.
The present disclosure develops an efficient PG method to solve the B-HSVM:
and the “all-together” M-HSVM:
In expression (2), yiε{+1, −1} is the label of xi, and
is the huberized hinge loss function. In expression (3), yiε{1, . . . , J} is the i-th label, ∥W∥1=Σi,j|wi,j|, aij=1 if yi≠j and aij=0 otherwise, e denotes the vector with all one's, and wj denotes the j-th column of W. The constraints We=0 and eTb=0 in expression (3) are imposed to eliminate redundancy in W, b and also are necessary to make the loss function
The PG methodology is chosen because it requires only first-order information and converges fast. As shown, for example, in Y. Nesterov, Introductory lectures on convex optimization, 87 (2004), it is an optimal first-order method. Note that the objectives in several other related known classifiers have non-smooth terms and are not differentiable. Hence, direct gradient or second order methods such as the interior point method are not applicable.
The presently disclosed algorithm is sped up by using a two-stage method, which detects the support of the solution at the first stage and solves a lower-dimensional problem at the second stage. For large-scale problems with sparse features, the two-stage method can achieve more than 5-fold acceleration. The convergence of the PG method is also analyzed under fairly general settings.
In addition, the proposed method is compared to state-of-the-art methods for B-SVM and M-SVM on both synthetic and benchmark datasets. Extensive numerical experiments demonstrate that the proposed method can outperform over other compared methods in most cases. Statistical tests are also performed to show significant differences between the compared methods.
Algorithms and Convergence Analysis:
In the following, an overview of the PG method is presented, and PG is then applied to the models represented by expression (2) (B-HSVM) and expression (3) (M-HSVM). Under strong convexity assumptions, the PG method possesses linear convergence.
In an overview of the PG method, composite optimization problems are considered in the form of:
where U⊂m is a convex set, ξ1 is a differentiable convex function with Lipschitz continuous gradient (that is, there exists L>0 such that ∥∇ξ1(ū)−∇ξ1∥≦L∥ū−ũ∥, for all ūεU, and ξ2 is a proper closed convex function. The PG method for solving (4) iteratively updates the solution by
for some nonnegative ωk−1. The extrapolation technique can significantly accelerate the algorithm.
When Lk is the Lipschitz constant of ∇ξ1, it can easily be shown that ξ(u)≦Q(u,ûk−1), and thus this method is a kind of majorization minimization, as shown by the graph 100 of
With appropriate choice of ωk−1 and Lk, the sequence {ξ(uk)} converges to the optimal value ξ*=ξ(u*). It has been shown that if ωk−1≡0 and Lk is taken as the Lipschitz constant of ∇ξ1, the {ξ(uk)} converges to ξ* with the rate O(1/k) namely, ξ(uk)−ξ(u*)≦O(1/k). In addition, using carefully designed ωk−1, it has been shown that the convergence rate can be increased to O(1/k2), which is the optimal rate of first-order methods for general convex problems.
To apply the PG method for binary-class HSVM, expression (2) is first written in the form of expression (4). Let
Then expression (2) can be written as
minb,wF(b,w)≡ƒ(b,w)+g(b,w) (6)
Also, for convenience, the following notation will be used in the rest of this section:
u=(b;w), vi=(ysi;yixi). (7)
The function ƒ defined above is differentiable and convex, and its gradient ∇ƒ is Lipschitz continuous with constant
The proof of this proposition involves standard arguments.
PG may now be applied to expression (2). A proximal operator for a given extended real-valued convex function h(u) on m is defined by:
By replacing ξ1 and ξ2 in (5) with ƒ and g, respectively, the following update is obtained:
where Sv(•) is a component-wise shrinkage operator defined by
Sv(t)=sign(t)max(|t|−v,0).
Lk in expression (9) is dynamically updated by
Lk=min(ηn
where η>1 is a pre-selected constant, Lƒ is defined in expression (8) and nk is the smallest integer such that the following condition is satisfied:
for some weight ωk−1≦1. The inequality in (11) is necessary to make the it satisfied. In the case where Lƒ becomes unnecessarily large, a smaller Lk can speed up the convergence. To make the overall objective non-increasing, uk is re-updated by setting ûk−1=uk−1 in expression (9) whenever F(uk)>F(uk−1). This non-increasing monotonicity is very important, since it is observed that the PG method may be numerically unstable without this modification. In addition, it significantly accelerates the PG method.
The following method will be referred to hereinafter as the B-PGH algorithm. The algorithm is illustrated by block diagram 200 of
The basic idea of the algorithm 200 is to generate a sequence of points that converges fast enough to the optimal solution of the optimization problem (2). The algorithm starts from a point u0 that is defined by the user or chosen randomly by the software. The iterations then generate u1, u2, u3, . . . that are always closer to the optimal solution u*.
In the k-th iteration, the algorithm uses two previous points, uk−1 and uk−2, and defines an intermediate point ûk−1, which may be closer to the optimal point u* than the original point uk−1. By using the intermediate point ûk−1, the algorithm makes larger steps and it is able to arrive to the optimal point u* in fewer steps, and hence the algorithm becomes faster than using simply the original point uk.
In addition, the algorithm 200 selects a proper value of the Lipschitz parameter, defined as Lk, which is responsible for making the loss function, described in equation (2), continuous, The proper value of Lk is defined by using equation (10).
Next the algorithm determines the new step, uk, which is closer to the optimal point u* than any other point determined so far (including ûk−1). The new step uk is determined by using equation (11).
The algorithm iterates between the above three major steps (definition of ûk−1, Lk, and uk) until it reaches the optimal point u*.
In the following, the PG method is generalized for solving for multi-class-ISVYM classification problems. Denote U=(b:W). Let
Then expression (3) can be written as
As with the binary classifier discussion, it can be shown that ∇ulM is Lipschitz continuous with constant
As with the binary classifier discussion, the proof involves standard arguments.
It is now possible to apply the PG method to expression (3) or equivalently to expression (12). U is updated iteratively by solving the b-subproblem
where Lk is chosen is chosen in the same way as in expression (11).
The b-subproblem (14) is relatively easy and has a closed form solution, Let
be the vector comprising the first J−1 components of b, where I denotes the identity matrix. Substituting b=P
Hence, the update in expression (14) can be explicitly written as
bk=P
where
The W-subproblem (15) can be further decomposed into p independent small problems. Each of them involves only one row of W and can be written in the following form:
where
is the i-th row-vector of the matrix
for the i-th small problem. The coexistence of the non-smooth term ∥w∥1 and the equality constraints eTw=0 makes expression (17) a difficult optimization problem to solve. Next is described an efficient yet simple method for solving expression (17) using its dual problem, defined by
Since (17) is strongly convex, γ(σ) is concave and continuously differentiable. Hence, the solution σ* of (18) can be found by solving the single-variable equation γ′(σ)=0. It is easy to verify that γ(zmin−λ)>0 and γ′(zmax+λ)<0, so the solution σ* lies between zmin−λ and Zmax+λ, where zmin and zmax respectively denote the minimum and maximum components of z. In addition, note that Sλ(z−σ) is piece-wise linear about σ, and the breakpoints are at zi±λ, i=1, . . . , J. Hence σ* must be in [vl,v+l+1.] for some l, where v is the sorted vector of (z−λ;z+λ) in the increasing order. Therefore, to solve expression (18), v is first obtained, then the interval that contains σ* is searched by checking the sign of γ′(σ) at the breakpoints, and finally γ′(σ)=0 is solved within that interval. The following algorithm, depicted by the flowchart 300 of
After determining σ*, the solution of (17) can be obtained by setting w*=Sλ(z−σ*). The following algorithm summarizes the main steps of the PG method for efficiently solving the multi-class SVM (M-HSVM) problem (3). The algorithm, depicted by the flowchart 400 of
Instead of analyzing the convergence of algorithms for solving the B-HSVM and M-HSVM problems presented above, the present disclosure analyzes the PG method for expression (4) with general ξ1 and ξ2 and regards the algorithms as special cases. Throughout the analysis, it is assumed that ξ1 is a differentiable convex function and ∇ξ1 is Lipschitz continuous with Lipschitz constant L. It is also assumed that ξ2 is strongly convex with constant μ>0, namely,
for any gvε∂ξ2(v) and u, vεdom(ξ2), where dom(ξ2)={uεm:ξ2(u)<∞} denotes the domain of ξ2.
While similar results have been shown in the literature, the present analysis fits to more general settings. Specifically, dynamic update of the Lipschitz parameter Lk and an acceptable interval of the parameters ωk are allowed. On the other hand, prior results either require Lk to be fixed to the Lipschitz constant of ξ1 or require specific values for the ωk's. In addition, the prior techniques do not perform the re-update step as in operation 270 of the B-PGH algorithm or operation 490 of the M-PGH algorithm.
The PG method was tested under different settings on synthetic datasets, to demonstrate the practical effect that each setting has on the overall performance of the PG method. The numerical results are summarized in the Table 1 below, which shows that the PG method under the presently disclosed settings converges significantly faster than that under the settings used in two selected prior works. Specifically, the table compares the presently disclosed results to those of Y. Nesterov, Gradient methods for minimizing composite objective function, CORE Discussion Papers (2007) (“Nesterov et al.”) and to those of M. Schmidt, N. L. Roux, and F. Bach, Convergence rates of inexact proximal-gradient methods for convex optimization, Arxiv preprint arXiv:1109.2415 (2011) (“Schmidt et al.”). Nesterov et al. sets Lk=Lƒ for all k; neither Nesterov nor Schmidt makes F(xk) non-increasing. The test data was generated synthetically according to a Gaussian distribution; the correlation parameter was set to ρ=0.
To analyze PG method under fairly general settings, the so-called Kurdyka-Lojasiewicz (KL) inequality was used, which has been widely applied in non-convex optimization. The results show that the KL inequality can also be applied and simplify the analysis in convex optimization.
To analyze convergence, let {uk} be the sequence generated by equation (5) Lk≦L and ûk−1=uk−1+ωk−1(uk−1−uk−2) for some
In addition. {ξ(uk)} is made nonincreasing by re-updating uk with ûk−1=uk−1 in expression (5) whenever ξ(uk)>ξ(uk−1). Then uk R-linearly converges to the unique minimizer u* of expression (4), namely, there exist positive constants C and τ<1 such that
∥uk−u*∥≦Cτk,∀k≧0. (21)
U-sing the results of this theorem, the convergence results of the B-PGH algorithm and the M-PGH algorithm are established in the following corollary. Let {uk} and {Uk} be the sequences generated by the two algorithms with λ2, λ3>0 and
Then {uk} and {Uk}R-linearly converge to the unique solutions of the B-PGH algorithm and the M-PGH-algorithm, respectively.
Note that if one of λ2 and λ3 vanishes, there is only sublinear convergence by some appropriate choice of ωk.
A two-stage accelerated method for large-scale problems will now be described. Most of the cost of the B-PGH algorithm at iteration k occurs in the computation of ∇ƒ(ûk−1) and the evaluation of F(uk). Let V=(v1, . . . , vn)T where (v1, . . . , vn) are defined in expression (7). To compute ∇ƒ(ük−1), the values Vûk−1 and ∇ƒi(ûk−1), i=1, . . . , n are needed, which costs O(np) in total. Evaluating F(uk) needs Vuk, which costs O(np). To save the computing time, both Vuk−and Vuk are stored so that Vûk can be obtained by Vûk=Vuk+ωk (Vuk−Vuk−1). That way, Vuk need be computed only once during each iteration, and the total computational cost is O(Tnp) where T is the total number of iterations.
As p is large and the solution of equation (2) is sparse, namely, only a few features are relevant, the cost of the B-PGH algorithm can be further reduced by switching from the original high-dimensional problem to a lower-dimensional one. More precisely, the B-PGH algorithm is first run with Lk=Lƒ and ωk=0 until the support of wk remains almost unchanged. Then equation (2) is reduced to a lower-dimensional problem by confining w to the detected support, namely, all elements out of the detected support are kept zero. Finally, the B-PGH algorithm is employed again to solve the lower-dimensional problem. The two-stage method for (2) is named as B-PGH-2, and its solidness rests on the following:
Let {(bk,wk)} be the sequence generated by the B-PGH algorithm with Lk=Lƒ and ωk=0 starting from any u0=(b0,w0). Suppose u*=(b*,w*) is the unique solution of equation (2) with λ3>0. Let
where wi is the ith component of w. Then supp(w*)⊂ε and wi*=0,∀iεI, where supp(w*) denotes the support of w*. In addition, wik=0,∀iεI and sign (hi(wk))=sign (hi(w*)),∀iεε for all but at most finite iterations.
Suppose the cardinality of the solution support is s. Then the total computational cost of the two-stage method B-PGH-2 is O(T1np+T2ns), where T1, T2 are the numbers of iterations in the first and second stages, respectively. Numerically, it was found that supp(w*) could be detected in several iterations, namely, T1 is usually small. When s<<p, B-PGH-2 can be significantly faster than B-PGH, In the same way, the M-PGH algorithm can be accelerated by a two-stage method.
Numerical Experiments
In the first part of this section, B-PGH, described in Algorithm 200, is compared with two very recent binary-class SVM solvers using ADMM, described in G. B. Ye, Y. Chen, and X. Xie, Efficient variable selection in support vector machines via the alternating direction method of multipliers, In Proceedings of the International Conference on Artificial Intelligence and Statistics (2011), and GCD3, described in Yi Yang and Hui Zou, An efficient algorithm for computing the hhsvm and its generalizations, Journal of Computational and Graphical Statistics, 22(2):396-415 (2013), on both synthetic and real data. ADMM solves model (1) whereas both B-PGH and GCD solve (2). In the second part of this section, the performance of five different multi-class SVMs are compared: the model defined by (3), the l1-regularized M-SVM described in L. Wang and X. Shen, On L-norm multiclass support vector machines, Journal of the American Statistical Association, 102(478):583-594 (2007), the l∞-regularized M-SVM described in H. Zhang, Y. Liu, Y. Wu, and J. Zhu, Variable selection for the multicategory svm via adaptive sup-norm regularization, Electronic Journal of Statistics, 2:149-167 (2008), the “one-vs-all” (OVA) method described in L. Bottou et al., Comparison of classifier methods: a case study in handwritten digit recognition, In Proceedings of the 12th IAPR International Conference on Pattern Recognition, vol. 2, pages 77-82 (IEEE 1994), and the Decision Directed Acyclic Graph (DDAG) method described in J.C. Platt, N. Cristianini, and J. Shawe-Taylor, Large margin dags for multiclass classification, Advances in neural information processing systems, 12(3):547-553 (2000). M-PGH, described in Algorithm 400 above, is used to solve expression (3), and Sedumi, found in J. F. Sturm, Using SeDuMi 1.02, a MATLAB toolbox for optimization over symmetric cones, Optimization methods and software, 11(1-4):625-653 (1999) is used for the l1 and l∞-regularized M-SVMs. Sedumi is called through CVX. All the tests were performed on a computer having an i7-620m CPU and 3-GB RAM and running 32-bit Windows 7 and Matlab 2010b.
Binary-Class SVM:
For B-PGH, the parameters η and L0 were set to η=1.5 and
respectively. We chose
where t0=1 and
The starting point was chosen to be a zero vector. BPGH is stopped if both of the following conditions are satisfied during three consecutive iterations:
where uk=(bk,wk) and Fk=F(uk). The stopping tolerance was set to tol=10−6 for B-PGH and GCD and tol=10−5 for ADMM since tol=10−6 was too stringent. For B-PGH-2, tol=10−3 was taken at the first stage and tol=10−6 at the second stage. The penalty parameters for ADMM were set to μ1=100/n and μ1=50 as suggested in G. B. Ye et al. All the other parameters for ADMM and GCD were set to their default values.
Synthetic data: n samples were generated in p with one half in the “+1” class and the other half in the “−1” class. Specifically, each sample in the “+1” class was generated according to the Gaussian distribution (μ,Σ) and each sample in the “−1” class according to (−μ,Σ). The mean vector
and the covariance matrix
where 1s×s is the matrix of size s×s with all one's, 0 is the matrix with all zero's, and Is×s is an identity matrix of size s×s. The first s variables are relevant for classification and the rest are noise. The speed of the algorithms was tested on different sets of dimension (n, p, s) and the correlation ρ. The smoothing parameter for B-PGH and GCD was set to δ=1 in this subsection, and λ3=λ2 is set in the next subsection. Table 2 lists the average running time (sec) of 10 independent trials. For each run, the time over 25 different pairs of (λ1,λ2) was averaged. From the results, it can be seen that B-PGH was consistently faster than GCD and over 50 times faster than ADMM. In addition, B-PGH-2 was significantly faster than B-PGH when p was large and s<<p.
The prediction accuracy and variable selection of the algorithms was also tested. The problem dimension was set to n=50; p=300; s=20. The optimal pair of (λ1,λ2) was selected from a large grid by 10-fold cross validation. We use nt for the number of selected relevant variables and nf for the number of selected noise variables. In addition, “accu” was used for the prediction accuracy. The average results of 500 independent runs corresponding to p=0 and p=0.8 are shown in Table 3. During each run, the algorithms were compared on a test set of 1000 samples. From the table, it can be seen that B-PGH achieved similar accuracy to that by GCD, and they both performed better than ADMM, especially in the case of p=0.8. In addition, B-PGH-2 obtained similar solutions as B-PGH.
Medium-scale real data: In this subsection, B-PGH, GCD and ADMM are compared on medium-scale real data, as shown in Table 4. The first seven datasets are available from the LIBSVM dataset and the last three from Tom Mitchells neuroinformatics research group. Both rcvl and realsim have large feature dimensions but only about 0.2% nonzeros. colon, duke and leuk are datasets of gene expression profiles for colon cancer, breast cancer and leukemia, respectively. The original dataset of colon consists of 62 samples, of which 30 are randomly chosen for training and the rest for testing. gisette is a hand-writing digit recognition problem from NIPS 2003 Feature Selection Challenge. The training set for gisette is a random subset of the original 6000 samples, and the testing set contains all of the original 1000 samples. rcv1 is a collection of manually categorized news wires from Reuters. Both the training and tesing instances for sub-rcvl are randomly sub-sampled from the original training and testing samples. realsim contains UseNet articles from four discussion groups, for simulated auto racing, simulated aviation, real autos and real aviation. The original dataset of realsim has 72,309 samples, and 500 instances were randomly sub-sampled for training and 1,000 instances for tesing. fMRIa, fMRIb, and fM-RIc are functional MRI (fMRI) data of brain activities when the subjects are presented with pictures and text paragraphs.
λ2=λ3=0 were fixed since the algorithms appeared not sensitive to λ2 and λ3. The optimal λ1's were tuned by 10-fold cross-validation on training sets. The smoothing parameter was set to 6=1 for both B-PGH and GCD. All the other settings are the same as those in the previous test. The results are shown in Table 5. The best prediction accuracy for each data set is highlighted in bold. For comparison, the prediction accuracies by LIBLINEAR with L-regularized L2-loss are also reported. From the results, it can be seen that B-PGH is significantly faster than GCD and ADMM, and it also gives the best prediction accuracy. B-PGH-2 was fastest and achieved the same accuracy as B-PGH except for gisette. Note that GCD can give the same accuracy as B-PGH but it needs to run much longer time.
Statistical comparison: A statistical comparison of B-PGH, GCD, and ADMM was also performed. The Wilcoxon signed-ranks test and Friedman test were done to see if the differences of the compared methods are significant. The former test is for pair-wise comparison and the latter one for multiple comparison. Specifically, for two different methods, denote di as the difference of their score (e.g., prediction accuracy) on the i-th dataset and rank di's based on their absolute value. Let
where N is the number of datasets, T=min(R+,R+), and
Table 6 shows the pair-wise z-values (above diagonal) and the corresponding p-values (below diagonal) of the five compared methods, using Wilcoxon signed-ranks test. At p-value<0.05, there are no significant differences between B-PGH and B-PGH-2 and neither between GCD and ADMM, and any other pair of methods make significant difference.
The Friedman statistic can be calculated by
where K is the number of compared methods, ARj=Σi=1nrij denotes the average rank of the j-th method, and rij is the rank of the j-th method on the i-th dataset. Table 7 shows the ranks of the compared methods according to their prediction accuracies on real data sets, where average ranks are applied to ties. The p-value indicates significant difference among the five methods at p-value<0.05.
A post-hoc test was also done through Holm's step-down procedure. Assuming the p-values for compared classifiers to the control one are ordered as p1≦p2≦ . . . ≦pK−1, Holm's step-down procedure starts from the largest one and compares it to
where α is the target p-value. If
it rejects the corresponding null-hypothesis and compares p2 to
and so on. B-PGH is set as the control classifier and
to find the p-value for the j-th method compared to the control one. The p-values are 0.8875, 0.0072, 0.0477, and 5.57×10−5, respectively, for B-PGH-2, GCD, ADMM, and LIBLINEAR. Hence, at α=0.05, B-PGH made significant difference with GCD and LIBLINEAR but not with B-PGH-2 or ADMM, and at α=0.10, B-PGH made significant difference with all other methods except B-PGH-2.
Large-scale real data: This subsection compares B-PGH, GCD and ADMM on two large-scale datasets. The first one is rcvl, part of which has been tested above. It has 20,242 training samples, and each sample has 47,236 features. We use the same 1,000 samples as above for testing. The second dataset contains all the 72,309 samples of realsim, part of which is used above, and each sample has 20,958 features. We randomly selected 20,000 samples for testing and the rest for training. Both of the two datasets are highly sparse. For all algorithms, we fixed b=0 since we observed that using the bias term would affect the prediction accuracy. For B-PGH and GCD, we set δ=1. The best values of λ1 and λ2 were searched from a large grid by 10-fold cross-validation. The parameters for B-PGH and GCD were set the same as above. ADMM suffered from memory problems since it needs to explicitly form the matrix XTX, which is dense though X is sparse, where the i-th column of X was formed by the i-th data point xi. Hence, we did not report the results of ADMM. The results by B-PGH and GCD are shown in Table 8, where we also report the prediction accuracy by LIBLINEAR for comparison. From the results we can conclude that both or our algorithms, B-PGH and B-PGH-2, are significantly faster (almost 400 times) than the GCD method. In addition, the accuracy of B-PGH and BPGH-2 is very similar to that of GCD.
Effects of the smoothing parameter: We tested how 6 affected B-PGH and GCD on the real datasets used above. Since the cost reduction by B-PGH-2 was not significant for these datasets as shown in Table 5, we did not include it in this test. All parameters were set to the same values as above except for δ, which varied between 0.1 and 0.01. The running time and prediction accuracies are shown in Table 9. Comparing the results with those in Table 5, we find that the algorithms tend to give more accurate predictions. However, the accuracy corresponding to δ=0.01 is hardly improved over δ=0.1. In addition, the solutions have more nonzeros, i.e., more features are selected. For these reasons, we do not recommend choosing very small δ. We observed that δε[0.1,1] was fine in all our tests. Furthermore, comparing the columns that show the time in Tables 5 and 9 we observe that the efficiency of the GCD method was greatly affected by different values of δ. In most cases, GCD can become significantly slow with small δ's. On the contrary, the efficiency of B-PGH was seldom affected by different values of δ.
Multi-Class SVM
This subsection tests the performance of M-PGH for solving expression (3) on a synthetic dataset, eight benchmark datasets, and also two microarray datasets. The parameters of M-PGH were set in the same way as those of B-PGH except we set
where Lm is given in expression (13). For all the tests, δ=1 was set in (3).
Synthetic data: We compare (3), the l1-regularized M-SVM, and the l∞-regularized M-SVM on a four-class example with each sample in p-dimensional space. The data in class j was generated from the mixture Gaussian distribution (μj,Σj),j=1, 2, 3, 4. The mean vectors and covariance matrices are μ2=−μ1, μ4=−μ3, Σ2=Σ1, Σ4=3, which take the form of
This kind of data has been tested above for binary classifications. We took p=500, s=30 and ρ=0, 0.8 in this test. The best parameters for all three models were tuned by first generating 100 training samples and another 100 validation samples. Then we compared the three different models with the selected parameters on 100 randomly generated training samples and 20,000 random testing samples. The comparison was independently repeated 100 times. The performance of different models and algorithms were measured by prediction accuracy, running time (sec), the number of incorrect zeros (IZ), the number of nonzeros in each column (NZ1, NZ2, NZ3, NZ4).
Table 10 summarizes the average results, where we can see that M-PGH is very efficient in solving expression (3). In addition we observe that (3) tends to give the best predictions.
Benchmark data: In this subsection, we compare M-PGH to two popular methods for multi-category classification by binary classifier. The first one is the “one-vs-all” (OVA) method coded in the LIBLINEAR library and the other one the Decision Directed Acyclic Graph (DDAG) method. We compared them on eight sets of benchmark data, all of which are available from the LIBSVM dataset. The problem statistics are shown in Table 11. The original dataset of connect4 has 67,557 data points. We randomly chose 500 for training and 1,000 for testing. All 2,000 data points in the training set of dna were used, and we randomly chose 500 for training and the rest for testing. glass has 214 data points, and we randomly chose 164 for training and another 50 for testing. For letter, we randomly picked 1300 out of the original 15,000 training samples with 50 for each class for training and 500 out of the original 5,000 testing points for testing. The poker dataset has 25,010 training and 1 million testing data points. For each class, we randomly selected 50 out of each class for training except the 6th through 9th classes which have less than 50 samples and hence were all used. In addition, we randomly chose 100 k points from the testing set for testing. protein has 17,766 training data points and 6,621 testing points. We randomly chose 1,500 from the training dataset for training and all the points in the testing dataset for testing. usps is a handwritten digit dataset consisting of 7291 training and 2007 testing digits from 0 to 9. We randomly picked 50 with 5 for each class out of the training set for training and 500 out of the testing set for testing. wine has 128 data points, and we randomly chose 50 for training and the rest for testing.
We fixed λ3=1 in (3) for M-PGH and tuned λ1,λ2. DDAG has two parameters C, γ, which were tuned from a large grid of values. The parameters for OVA were set to their default values in the code of LIBLINEAR. We did the tests for 10 times independently. The average prediction accuracies by the three different methods are reported in Table 12. From the results, we see that M-PGH performs consistently better than OVA except for letter and also comparable with DDAG. When the training samples are sufficiently many, DDAG can give higher prediction accuracies such as for glass and letter. However, it can perform badly if the training samples are few compared to the feature numbers such as for dna and also the tests in the next subsection.
Application to microarray classification: This subsection applies M-PGH to microarray classifications. Two real data sets were used. One is the children cancer data set, which used cDNA gene expression profiles and classified the small round blue cell tumors (SRBCTs) of childhood into four classes: neuroblastoma (NB), rhabdomyosarcoma (RMS), Burkitt lymphomas (BL) and the Ewing family of tumors (EWS). The other is a leukemia data set that used gene expression monitoring and classified the acute leukemias into three classes: B-cell acute lymphoblastic leukemia (B-ALL), T-cell acute lymphoblastic leukemia (TALL) and acute myeloid leukemia (AML). The original distributions of the two data sets are given in Table 13. Both the two data sets have been tested before on certain M-SVMs for gene selection.
Each observation in the SRBCT dataset has dimension of p=2308, namely, there are 2308 gene profiles. We first standardized the original training data in the following way. Let X0=[x1o, . . . , xno] be the original data matrix. The standardized matrix X was obtained by
Similar normalization was done to the original testing data. Then we selected the best parameters of each model by three-fold cross validation on the standardized training data. Finally, we put the standardized training and testing data sets together and randomly picked 63 observations for training and the remaining 20 ones for testing. The average prediction accuracy, running time (sec), number of nonzeros (NZ) and number of nonzero rows (NR) of 100 independent trials are reported in Table 14, from which we can see that all models give similar prediction accuracies. The l∞-regularized M-SVM gives denser solutions, and M-PGH is much faster than Sedumi.
The leukemia data set has p=7,129 gene profiles. We standardized the original training and testing data in the same way as that in last test. Then we ranked all genes on the standardized training data. Specifically, let X=[x1, . . . , xn] be the standardized data matrix. The relevance measure for gene g is defined as follows:
where mg denotes the mean of {xg1, . . . , xgn} and mgj denotes the mean of {xgi:yi=j}. According to R(g),we selected the 3,571 most significant genes. Finally, we put the processed training and testing data together and randomly chose 38 samples for training and the remaining ones for testing. The process was independently repeated 100 times. We compared all the above five different methods for M-SVMs. Table 14 summarizes the average results, which show that M-PGH is significantly faster than Sedumi and that model (3) gives comparable prediction accuracies with relatively denser solutions. In addition, we note that DDAG performs very badly possibly because the training samples are too few.
Statistical comparison: As above, we also performed statistical comparison of M-PGH, OVA, and DDAG on the eight benchmark and two microarray datasets. Table 15 shows their z-values and corresponding p-values of the Wilcoxon signed-rank test. From the table, we see that there is no significant difference between any pair of the three methods at p-value<0.05. However, M-PGH makes significant difference with OVA at p-value<0.10. Average ranks of M-PGH, OVA, and DDAG according to their prediction accuracies on the eight bench-mark and two microarray datasets are shown in Table 16 together with the Friedman statistic and p-value. Again, we see that there is no significant difference among the three methods at p-value<0.05 but there is at p-value<0.10. We further did a post-hoc test using the Holm's stepdown procedure as above. M-PGH was set as the control classifier. The p-values are 0.0253 and 0.0736, respectively, for OVA and DDAG. Hence, MPGH made significant differences with OVA and DDAG at p-value=0.10.
SVMs have been popularly used to solve a wide variety of classification problems. The original SVM model uses the non-differentiable hinge loss function, which together with some regularizers like l1-term makes it difficult to develop simple yet efficient algorithms. We considered the huberized hinge loss function that is a differentiable approximation of the original hinge loss. This allowed us to apply PG method to both binary-class and multi-class SVMs in an efficient and accurate way. In addition, we presented a two-stage algorithm that is able to solve very large-scale binary classification problems. Assuming strong convexity and under fairly general assumptions, we proved the linear convergence of PG method when applied in solving composite problems in the form of (4), special cases of which are the binary and multi-class SVMs. We performed a wide range of numerical experiments on both synthetic and real datasets, demonstrating the superiority of the proposed algorithms over some state-of-the-art algorithms for both binary and multi-class SVMs. In particular for large-scale problems, our algorithms are significantly faster than compared methods in all cases with comparable accuracy. Finally, our algorithms are more robust to the smoothing parameter δ in terms of CPU time.
Although various embodiments that incorporate the teachings of the present invention have been shown and described in detail herein, those skilled in the art can readily devise many other varied embodiments that still incorporate these teachings. The invention is not limited in its application to the exemplary embodiment details of construction and the arrangement of components set forth in the description or illustrated in the drawings. The invention is capable of other embodiments and of being practiced or of being carried out in various ways. Also, it is to be understood that the phraseology and terminology used herein is for the purpose of description and should not be regarded as limiting. The use of “including” “comprising,” or “having” and variations thereof herein is meant to encompass the items listed thereafter and equivalents thereof as well as additional items. Unless specified or limited otherwise, the terms “mounted,” “connected,” “supported,” and “coupled” and variations thereof are used broadly and encompass direct and indirect mountings, connections, supports, and couplings. Further, “connected” and “coupled” are not restricted to physical or mechanical connections or couplings.
Claims
1. A computer-implemented method for training a support vector machine classifier, comprising:
- replacing a hinge loss term of a support vector machine model of the classifier with a differentiable approximation of the hinge loss term based on a Huber loss function, to produce a differentiable support vector machine model;
- applying a proximal gradient method to solve the differentiable support vector machine model, to produce updates for an algorithm for determining a separating hyperplane of the differentiable support vector machine model; and
- determining the separating hyperplane using the algorithm.
2. The method of claim 1, wherein the Huber loss function is defined by φ H ( t ) = { 0, for t > 1, ( 1 - t ) 2 2 δ, for 1 - δ < t ≤ 1, 1 - t - δ 2 for t ≤ 1 - δ, where δ defines a vicinity around a non-differentiable point of the hinge loss term.
3. The method of claim 1, wherein a vicinity near a non-smooth point in the hinge loss term of the support vector machine model is approximated by a differentiable curve in the Huber loss function.
4. The method of claim 1, wherein the support vector machine classifier is a binary support vector machine classifier.
5. The method of claim 1, wherein the support vector machine classifier is a multi-class support vector machine classifier.
6. A computer-implemented method for training a binary support vector machine classifier for classifying data items with high dimensionality, comprising: min b, w 1 n ∑ i = 1 n φ H ( y i ( b + x i T w ) ) + λ 1 w 1 + λ 2 2 w 2 2 + λ 3 2 b 2, where φH is a Huberized hinge loss function having values defined by φ H ( t ) = { 0, for t > 1, ( 1 - t ) 2 2 δ, for 1 - δ < t ≤ 1, 1 - t - δ 2 for t ≤ 1 - δ; { b k = L k b ^ k - 1 - ∇ b f ( u ^ k - 1 ) L k + λ 3 w k = 1 L k + λ 2 S λ 1 ( L k w ^ k - 1 - ∇ w f ( u ^ k - 1 ) ), f i ( b, w ) = φ H ( y i ( b + x i T w ) ), for i = 1, … , n, f ( b, w ) = 1 n ∑ i = 1 n f i ( b, w ), min b, w F ( b, w ) ≡ f ( b, w ) + ( b, w ) where ( b, w ) = λ 1 w 1 + λ 2 2 w 2 + λ 3 2 b 2.
- receiving a set of n data items x=x1, x2..., xn, each data item being a vector with dimensionality m and associated labels yiε{+1, −1}, a plurality of support vector machine tuning parameters λ1,λ2, λ3 and a parameter δ defining a vicinity around a non-differentiable point of a hinge loss function is approximated by a quadratic smooth function;
- computing a constant Lƒ such that the loss function of the binary support vector machine classifier is Lipschitz continuous;
- solving for a maximum margin separating hyperplane u*=(b*,w*) of the classifier by minimizing a function of the data items x and associated labels y:
- the minimizing comprising executing successive iterations k, each iteration resulting in a hyperplane uk closer to the maximum margin separating hyperplane u* than a previously found separating hyperplane uk−1, each iteration comprising: computing ûk−1=uk−1+ωk−1(uk−1−uk−2) wherein û is an intermediate hyperplane defined as a linear combination of hyperplanes found in two previous iterations and ωk−1 is a weight given to hyperplane definitions of two immediately previous iterations; updating a Lipschitz constant Lk as min (ηnkLk−1,Lƒ), where η>1 is a preselected counter, and nk is an integer computed to guarantee monotonic decrease of the hinge loss function and leads to convergence of the successive iterations; updating the hyperplane uk as
- wherein the function ƒ is defined by:
- and wherein Sλ1 is a component-wise shrinkage operator, and {circumflex over (b)} and ŵ are a bias and a slope of the intermediate hyperplane definition û; and re-updating uk with ûk−1=uk−1 only if F(uk)>F(uk−1), where F is defined as a function whereby
7. The method of claim 6, wherein the support vector machine tuning parameters comprise an L1-norm loss function coefficient λ1, an L2-norm loss function coefficient λ2, and a bias coefficient λ3.
8. The method of claim 6, wherein the plurality of support vector machine tuning parameters are determined using cross validation.
9. The method of claim 6, wherein computing a constant Lƒ further comprises evaluating L f = 1 n δ ∑ i = 1 n y i 2 ( 1 + x i 2 ).
10. The method of claim 6, wherein nk is a smallest integer such that the following condition is satisfied: f ( prox h k ( v k - 1 ) ) ≤ f ( u ^ k - 1 ) + 〈 ∇ f ( u ^ k - 1 ), prox h k ( v k - 1 ) - u ^ k - 1 〉 + L k 2 prox h k ( v k - 1 ) - u ^ k - 1 2, where h k ( u ) = 1 L k ( u ), v k - 1 = u ^ k - 1 - 1 L k ∇ f ( u ^ k - 1 ), u ^ k - 1 = u k - 1 + ω k - 1 ( u k - 1 - u k - 2 ) for some weight ωk−1≦1, and vi=(yi;yixi).
11. The method of claim 10, wherein S is defined by
- Sv(t)=sign(t)max(|t|−v,0).
12. The method of claim 6, wherein each of the successive iterations kfurther comprises:
- storing Vuk−1 and Vuk where V=(v1,..., vn)T and vi=(yi;yixi);
- obtaining Vûk=Vuk+ωk(Vuk−Vuk−1); and
- computing ∇ƒ(ûk−1) and evaluating F(uk) using Vûk
13. The method of claim 6, further comprising: { b k = L k b ^ k - 1 - ∇ b f ( u ^ k - 1 ) L k + λ 3 w k = 1 L k + λ 2 S λ 1 ( L k w ^ k - 1 - ∇ w f ( u ^ k - 1 ) ); and
- before solving for a separating hyperplane u*, executing successive iterations k with Lk=Lƒ until wk remains substantially unchanged, the iterations comprising: computing ûk−1=uk−1; updating the hyperplane uk as
- re-updating uk with ûk−1=uk−1 only if F(uk)>F(uk−1);
- defining a lower-dimensional w by confining w to those elements for which support is substantially greater than 0; and
- performing the step of solving for a separating hyperplane u* with the lower-dimensional w.
14. A computer-implemented method for training a multi-class support vector machine classifier for classifying data items with high dimensionality, comprising: min b, W 1 n ∑ i = 1 n ∑ j = 1 J a ij φ H ( b j + x i T w j ) + λ 1 W 1 + λ 2 2 W F 2 + λ 3 2 b 2, s. t. We = 0, e T b = 0, where φH is a Huberized hinge loss function having values defined by φ H ( t ) = { 0, for t > 1, ( 1 - t ) 2 2 δ, for 1 - δ < t ≤ 1, 1 - t - δ 2 for t ≤ 1 - δ; and where ∥W∥1=Σi,j|wi,j|, aij=1 if yi≠j and aij=0 otherwise, e denotes a vector with all one's, and wj denotes the j-th column of W; P = [ I - e T ] ∈ ℝ J × ( J - 1 ), I denotes an identity matrix and bεj−1; λ = λ 1 L k + λ 2 and zT is the i-th row-vector of the matrix L k L k + λ 2 W ^ k - 1 - 1 L k + λ 2 ∇ W l M ( U ^ k - 1 ) and lM is a loss function 1/nΣi=1nΣj=1JaijφH(bj+xiTwj); and G ( U ) = λ 1 W 1 + λ 2 2 W F 2 + λ 3 2 b 2 and u={(b,W):We=0, eTb=0}.
- receiving a set of n data items x=x1, x2,..., xn, each data item being a vector with dimensionality m and associated labels yiε{1,..., J}, a plurality of support vector machine tuning parameters λ1, λ2, λ3, and a parameter δ defining a vicinity around a non-differentiable point of a hinge loss function is approximated by a quadratic smooth function;
- computing a constant Lm such that the loss function of the multi-class support vector machine classifier is Lipschitz continuous;
- solving for a separating hyperplane U*=(b*,W*) of the classifier by minimizing a function of the data items x and associated labels y:
- the minimizing comprising executing successive iterations k, each iteration resulting in a hyperplane Uk closer to a maximum margin separating hyperplane U* than a previously found separating hyperplane Uk−1, each iteration comprising: computing Ûk−1=Uk−1+ωk−1(Uk−1−uk−2) wherein Û is an intermediate hyperplane defined as a linear combination of hyperplanes found in two previous iterations and ωk−1≦1 is a weight given to hyperplane definitions of two immediately previous iterations; updating a Lipschitz constant Lk as min(ηnkLk−1,Lƒ), where η>1 is a preselected counter, and nk is an integer computed to guarantee monotonic decrease of the hinge loss function and leads to convergence of the successive iterations; updating bk as P bk wherein
- updating each row i of Wk by solving minw½∥w−z∥2+λ∥w∥1, st eTw=0, where
- re-updating bk and Wk with Ûk−1=Uk−1 only if H(Uk)>H(Uk−1), where H is defined as a function whereby minUεu H(U)≡lM(U)+G(U) where G(U) where
15. The method of claim 14, wherein updating each row i of Wk by solving minw½∥w−z∥2+λ∥w∥1 further comprises, for each row i of Wk: L k L k + λ 2 W ^ k - 1 - 1 L k + λ 2 ∇ W l M ( U ^ k - 1 ); where Sλ is a component-wise shrinkage operator;
- setting a variable z to the i-th row of
- determining a σ to maximize γ(σ)=½∥Sλ(z−σ)−z∥2+λ∥Sλ(z−σ)∥1+σeTSλ(z−σ),
- setting σ*=σ, and
- setting the i-th row of Wk to be Sλ(z−σ*).
16. The method of claim 15, wherein determining a σ to maximize γ(σ)=½∥Sλ(z−σ)−z∥2+λ∥Sλ(z−σ)∥1+σeTSλ(z−σ) further comprises:
- setting v=[z−λ;z+λ]ε2J;
- sorting v as v1≦v2≦... ≦v2J;
- setting l=J.
- repeating the following until γ′(vl)·γ′(vl+1)≦0: if γ′(vl)>0, then setting l=l+1; if γ′(vl)≦0: then setting l=l−1
- solving γ′(σ)=0 within [vl, vl+1] and output the solution σ*.
17. The method of claim 14, wherein the support vector machine tuning parameters comprise an L1-norm loss function coefficient λ1, an L2-norm loss function coefficient λ2, and a bias coefficient λ3.
18. The method of claim 14, wherein the plurality of support vector machine tuning parameters are determined using cross validation.
19. The method of claim 14, wherein computing a constant Lm further comprises evaluating L m = J n δ ∑ i = 1 n ( 1 + x i 2 )
20. The method of claim 14, wherein each of the successive iterations kfurther comprises:
- storing VUk−1 and VUk where V=(v1,..., vn)T and vi=(yi;yixi);
- obtaining VÛk=VUk+ωk(VUk−VUk−1); and
- computing VlM(Ûk−1) and evaluating H(Uk) using VÛk.
21. The method of claim 14, further comprising:
- before solving for a separating hyperplane U*, executing successive iterations k with Lk=Lm until Wk remains substantially unchanged, the iterations comprising: computing Ûk−1=Uk−1; updating bk as P bk; updating each row i of Wk by solving minw½∥w−z∥2+λ∥w∥1, s.t eTw=0; and re-updating bk and Wk with Ûk−1=Uk−1 only if H(Uk)>H(Uk−1);
- defining a lower-dimensional W by confining W to those elements for which support is substantially greater than 0; and
- performing the step of solving for a separating hyperplane U* with the lower-dimensional W.
Type: Application
Filed: Mar 10, 2015
Publication Date: Sep 17, 2015
Patent Grant number: 10332025
Inventors: Yangyang Xu (Houston, TX), Ioannis Akrotirianakis (Princeton, NJ), Amit Chakraborty (East Windsor, NJ)
Application Number: 14/642,904