1. Technical Field
The present invention relates to support vector machines for machine learning and more particularly to a generalized Sequential Minimum Optimization (SMO) system and method for solving the support vector machine optimization problem.
2. Description of the Related Art
Support vector machines (SVMs) are a set of related supervised learning methods used for classification and regression. SVMs belong to a family of generalized linear classifiers. A special property of SVMs is that they simultaneously minimize empirical classification error and maximize geometric margin; hence they are also known as maximum margin classifiers.
Support vector machines map input vectors to a higher dimensional space where a maximal separating hyperplane is constructed. Two parallel hyperplanes are constructed on each side of the hyperplane that separates the data. The separating hyperplane is the hyperplane that maximizes the distance between the two parallel hyperplanes. An assumption is made that the larger the margin or distance between these parallel hyperplanes the better the generalization error of the classifier will be.
Data is classified as a part of a machine-learning process. Each data point is represented by a p-dimensional vector (a list of p numbers). Each of these data points belongs to only one of two classes. We are interested in whether we can separate them with a “p minus 1” dimensional hyperplane. This is a typical form of a linear classifier. There are many linear classifiers that might satisfy this property. However, we are additionally interested in finding out if we can achieve maximum separation (margin) between the two classes. By this we mean that we pick the hyperplane so that the distance from the hyperplane to the nearest data point is maximized. That is to say that the nearest distance between a point in one separated hyperplane and a point in the other separated hyperplane is maximized. Now, if such a hyperplane exists, it is clearly of interest and is known as the maximum-margin hyperplane and such a linear classifier is known as a maximum margin classifier.
Recently, a generalization of a support vector machine (SVM) technique, called support vector machine plus (SVM+), was proposed by V. Vapnik, in Estimation of Dependences Based on Empirical Data: Empirical Inference Science, Springer, 2006. The SVM+ approach is designed to take advantage of structure in training data (for example, noise present in data, or invariants in the data). By leveraging this structure, the SVM+ technique can have a better generalization by lowering the overall system's VC-dimension.
While multiple methods for training SVM have been proposed (the leading one being Sequential Minimum Optimization (SMO)), there are no available methods for training SVM+.
SVM and Its Computation Using SMO: In 1995, the SVM method for constructing an optimal hyperplane for non-separable data was introduced (see C. Cortes, V. Vapnik, “Support vector networks,” Machine Learning, vol. 20, pp. 273-297, 1995. The method deals with the following problem.
Given training data: ({right arrow over (x)}1,y1), . . . , ({right arrow over (x)}l,yl) yε{−1,1}, {right arrow over (x)}ε find the parameters {right arrow over (w)} and b of the hyperplane ({right arrow over (w)}, {right arrow over (x)})+b=0 that separate the data {({right arrow over (x)}1,y1), . . . , ({right arrow over (x)}l,yl)} (perhaps, with some errors) and minimize the functional:
under the constraints: yi[({right arrow over (w)}, {right arrow over (x)}i)+b]≧1−ξi, ξi≧0, i=1, . . . , l.
Here slack variables ξi characterize the values of training errors, while C′ is the penalty of these errors in the functional. Using standard techniques, this problem can be converted to the dual form, which would then require minimizing the functional;
over parameters αi (Lagrange multipliers), subject to the constraints:
The desired separating hyperplane has the form
where parameters α1, . . . , αl and b are the solution of the above optimization problem.
Generally, one cannot expect that the data {({right arrow over (x)}1,y1), . . . , ({right arrow over (x)}l,yl)} can be separated by a linear function (hyperplane). Thus, B. Baser, I. Guyon, V. Vapnik, “A Training Algorithm for Optimal Margin Classifiers,” in Proceedings of the Fifth Annual Workshop on Computational Learning Theory, Vol. 5, pp. 144-152, 1992, it was shown how the so-called “kernel trick” can be used for constructing wide classes of nonlinear separating functions. To employ the kernel trick, one maps input vectors {right arrow over (x)}εX (original feature space) into vectors {right arrow over (z)}εZ (new feature space, image space), where one constructs the separating hyperplane
with parameters α1, . . . , αl and b that maximize the functional subject to the constraints
According to the Mercer's theorem (as explained in Boser et al.), for any inner product ({right arrow over (z)}i,{right arrow over (z)}j) in the image space Z there exists a positive definite function K({right arrow over (x)}i,{right arrow over (x)}j) in space X such that ({right arrow over (z)}i,{right arrow over (z)}j)=K({right arrow over (x)}i,{right arrow over (x)}j), i, j=1, . . . , l.
Conversely, for any positive definite function K({right arrow over (x)}i,{right arrow over (x)}j) in the space X, there exists such a space Z that K({right arrow over (x)}i,{right arrow over (x)}j) forms an inner product ({right arrow over (z)}i,{right arrow over (z)}j) in space Z. Therefore, to construct a nonlinear separating function
in the image space Z, one has to maximize the functional:
subject to the constraints:
This problem is a special form of a quadratic optimization problem, where the constraints consist of one equality constraint and l box constraints. As it was demonstrated in the past, the problem can be solved much more efficiently than a general quadratic programming problem (see details in D. Bertsekas, Convex Analysis and Optimization, Athena Scientific, 2003).
J. Platt, in “Fast Training of Support Vector Machines using Sequential Minimal Optimization,” in Advances in Kernel Methods—Support Vector Learning, B. Schölkopf, C. Burges, and A. Smola, eds., pp. 185-208, MIT Press, 1999, proposed one of the most efficient algorithms for solving this problem, the so-called sequential minimal optimization (SMO) algorithm. The idea was to solve the optimization problem by sequentially, in each step selecting a pair of Lagrange multipliers αi, αj and maximizing the functional over them while keeping the rest of Lagrange multipliers fixed. The resulting two-dimensional optimization problem has a closed-form solution, which can be found extremely fast. By choosing appropriate pairs of Lagrange multipliers for each step for sequentially maximizing the functional, the SMO algorithm finds the desired solution quickly. This SMO algorithm made the SVM method extremely efficient for problems involving large amount of data in high-dimensional spaces.
SVM+ as an Extension of SVM: In the book, V. Vapnik, Estimation of Dependences Based on Empirical Data: Empirical Inference Science, Springer, 2006, and technical report, V. Vapnik, M. Miller, “SVM+: A new learning machine that considers the global structure of the data,” NECLA TR 2005-L141, 2005, a generalization of the SVM method of constructing separating functions, the so-called SVM+ method, was introduced. The idea of the generalization is the following. Consider the slack variables ξi in the form ξi=ψ({right arrow over (x)}i,δ), δεD, where ψ({right arrow over (x)}i,δ) belongs to some admissible set of functions (we call them correcting functions). In classical SVM slacks, ξi can take arbitrary values. By introducing slacks that are a realization of one of the admissible functions, we try to reduce the overall VC dimension; improve the generalization quality of the decision rule; introduce a richer training environment: instead of an oracle (providing just +1 or −1 for classification yi), we can exploit the teacher's input (providing hidden knowledge on classification errors ξi).
Note that extra hidden information is only used during training, not in actual testing. In SVM+, we map any input vector {right arrow over (x)} into two different spaces: space {right arrow over (z)}εZ as in SVM method (called the space of decision functions ξi) and in another space {right arrow over (z)}εZ+ (called the space of correcting functions) defining our admissible set of functions as follows: ψ({right arrow over (x)},δ)=({right arrow over (w)}, {right arrow over (z)})+d, where {right arrow over (w)}+εZ+ and dε Therefore, given the training data and two spaces Z and Z+, we define triplets (y1,{right arrow over (z)}1,{right arrow over (z)}1+), . . . , (yl,{right arrow over (z)}l,{right arrow over (z)}l+).
Our goal is to construct the separating hyperplane ({right arrow over (w)},{right arrow over (z)})+b=0, in the decision space Z subject to the constraints
that minimizes the functional
The dual form solution to this problem is to maximize the functional
subject to the constraints:
The solution (over parameters α, β, b, d) defines the separating function (in the decision space Z)
the correcting function has the form:
Using the same kernel trick for two different spaces Z and Z+ and denoting by K({right arrow over (x)}i,{right arrow over (x)}j) and K+({right arrow over (x)}i,{right arrow over (x)}j) the corresponding kernels for these spaces (we can call them decision space kernel and correction space kernel), we can formulate the SVM+ problem as follows. Maximize the functional;
subject to the constraints:
The decision function for SVM+ has the form
the correcting function has a form
In V. Vapnik, Estimation of Dependences Based on Empirical Data: Empirical Inference Science, Springer, 2006, a new setting of the learning problem was introduced (we call it learning hidden information), where for the training stage one is given triplets: (y1,{right arrow over (x)}1,{right arrow over (x)}1+), . . . , (yl,xl,{right arrow over (x)}l+), yε{−1,1}, {right arrow over (x)}ε{right arrow over (x)}+ε It is required to construct a decision rule y=f({right arrow over (x)}) that partitions the data {{right arrow over (x)}1, . . . , {right arrow over (x)}l} into two categories. Vector {right arrow over (x)}+ can be considered as a hint: it is available only for the training stage, and it will be hidden for the test stage. The problem of learning using hidden information can be solved using the SVM+ method where the vector {right arrow over (x)} is mapped into space Z and the vector {right arrow over (x)}+ is mapped into the space Z+. In order to construct a decision rule, SVM+ takes into account hidden information.
A system and method for support vector machine plus (SVM+) computations include selecting a set of indexes for a target function to create a quadratic function depending on a number of variables, and reducing the number of variables to two in the quadratic function using linear constraints. An extreme point is computed for the quadratic function in closed form. A two-dimensional set is defined where the indexes determine whether a data point is in the two-dimensional set or not. A determination is made of whether the extreme point belongs to the two-dimensional set. If the extreme point belongs to the two-dimensional set, the extreme point defines a maximum and defines a new set of parameters for a next iteration. Otherwise, the quadratic function is restricted on at least one boundary of the two-dimensional set to create a one-dimensional quadratic function. The steps are repeated until the maximum is determined.
These and other features and advantages will become apparent from the following detailed description of illustrative embodiments thereof, which is to be read in connection with the accompanying drawings.
The disclosure will provide details in the following description of preferred embodiments with reference to the following figures wherein:
The present principles provide a new generalized minimal sequential optimization (gSMO) method for fast training of SVM+. Although SVM+ has twice as many variables as SVM, the gSMO methods in accordance with the present principles are of the same level of complexity as a classical sequential minimal optimization (SMO) approach, which is the most efficient method developed for SVM thus far. gSMO can be also fine-tuned for specialized kernels in SVM+ while retaining its complexity level.
SVM+ is an extension of the standard SVM technique designed to take advantage of structures in the training data (for example, the noise present in the data, or invariants in the data). By leveraging these structures, the SVM+ technique can provide a basis for better generalization by lowering the overall system's VC-dimension.
In computational learning theory, the VC dimension (for Vapnik-Chervonenkis dimension) is a measure of the capacity of a statistical classification algorithm, defined as the cardinality of the largest set of points that the algorithm can shatter. Informally, the capacity of a classification model is related to how complicated it can be.
SVM+ also has a potential of new settings in pattern recognition: instead of traditional oracle-like teachers (providing simple classification for training data), it expands the role of a real teacher that can provide additional hints and hidden information during the training process, Performance advantages of SVM+ over SVM are provided, which are reflected in both improved classification accuracy and a reduced number of support vectors, on synthetic Gaussian data samples: a marginal error rate of SVM+ (above the Bayesian optimal rate) was shown to be about two times less than that of classical SVM.
A new generalized minimal sequential optimization optimization (gSMO) method of fast training of SVM+ is described. Although SVM+ has twice as many variables as SVM, the proposed gSMO method is of the same level of complexity as the classical sequential minimal optimization (SMO) approach (the most efficient algorithm developed for SVM so far). gSMO can be also fine-tuned for specialized kernels in SVM+ while retaining its complexity level.
Embodiments described herein may be entirely hardware, entirely software or including both hardware and software elements. In a preferred embodiment, the present invention is implemented in software, which includes but is not limited to firmware, resident software, microcode, etc.
Embodiments may include a computer program product accessible from a computer-usable or computer-readable medium providing program code for use by or in connection with a computer or any instruction execution system. A computer-usable or computer readable medium may include any apparatus that stores, communicates, propagates, or transports the program for use by or in connection with the instruction execution system, apparatus, or device. The medium can be magnetic, optical, electronic, electromagnetic, infrared, or semiconductor system (or apparatus or device) or a propagation medium. The medium may include a computer-readable medium such as a semiconductor or solid state memory, magnetic tape, a removable computer diskette, a random access memory (RAM), a read-only memory (ROM), a rigid magnetic disk and an optical disk, etc.
Referring now to the drawings in which like numerals represent the same or similar elements and initially to
Performance of SVM+: Simulations. Using standard techniques of quadratic programming, we conducted simulations for the following 2-dimensional problem. The problem has two classes (class I and class II), where each class has a Gaussian distribution. Each class is also further subdivided into two subclasses 10, 20 and 30, 40, respectively, including 80% and 20% of the sample, as shown in
Using this error rate as a baseline, we compared solutions given by SVM (with radial basis kernels in the space) and SVM+ (with two radial basis kernels in the spaces 42 and 44).
Optimal parameters were selected using a validation set which was different from the training and the test. As results illustrate, SVM+ achieves the error rate 4.3%, while SVM's error rate is 4.8%. Thus, the deviation 0.4% of SVM+from the Bayesian error rate is half of that of SVM (which is 0.9%). Also, SVM+ needs only 18 support vectors versus 59 support vectors for SVM. The difference in performance is due in part to the fact that the parameters can take more values.
Although the computation time on these samples (both of size 100) took less than a minute, generic quadratic programming approaches cannot be used efficiently for larger samples in multi-dimensional cases. We describe herein a generalized SMO method (gSMO) that can solve SVM+ as efficiently as SMO can solve SVM.
Generalized Sequential Minimal Optimization in accordance with the present principles (gSMO) follows, in general the structure of SMO. As SMO, gSMO is a sequential process of maximizing a target function. At each of the steps of this sequential process, a pair (working set) of indexes i and j is selected. The function then becomes a quadratic function depending on four variables: αi, αj, βi and βj. Linear constraints reduce the number of variables to two: αj and βj. An extreme point (αj+, βj+) of the restricted 2-dimensional quadratic function W is then computed in a closed form. Also, linear constraints are used to define the 2-dimensional set D (which turns out to be either a rectangle or a triangle, depending on whether indexes i and j correspond to two data points {right arrow over (x)}i and {right arrow over (x)}j belonging to the same classification class or not; in other words, whether yiyj is equal to +1 or −1. If the extreme point (αj+,βj+) belongs to D, it delivers the maximum and defines a new set of parameters (Lagrange multipliers); otherwise, the function W is further restricted on one or two of the corresponding boundaries of D (where it becomes a 1-dimensional quadratic function), where extreme points are again calculated in a closed form and compared to select the one that delivers the largest value for W—it is then selected for the new set of parameters (Lagrange multipliers).
We apply this gSMO reasoning to two cases of correction space kernels K+: a general correction space kernel and a diagonal correction space kernel. While the first case follows the outline of gSMO, the second one is amenable to further simplifications stemming from a special structure of the correction space kernel.
Case of a General Correction Space Kernel: Consider the case of a general correction space kernel K+. In this case, the optimization problem has the following form. Maximize:
under the constraints:
and the additional constraint:
For maximizing our objective function we focus on the smallest possible subproblem involving two examples, say, i and j and focus on maximizing W(αi,αj,βi,βj) part of the objective function that depends on the Lagrange multipliers corresponding to selected examples. Then, the function has the form:
W(αi,αj,βi,βj)=W+(αi,αj)+W+(αi,αj,βi,βj), where
is the same function as in the SMO method, and
is the additional function corresponding to the SVM+ case.
Here:
and the terms Wconstant and Wconstant+ do not depend on αi, αj, βi and βj. Due to the first linear constraint involving α's, we can write αi=Δ−sαj. Similarly the second linear constraint involving α's and β's yields (αi+βi−C)=μ−(αj+βj−C).
Using these substitutions the objective function takes the form:
Then, function W(αj,βj) can be written as:
The function W(αj,βj) has zero derivatives on αj and βj for
Note that the extreme point (αj+,βj+) does not depend on γ. The new extreme point can be expressed in terms of old values of αj and βj by using the gradient of the objective function. Let Gi denote the gradient of W+( ) and gi denote the gradient of W+( ) without the factor γ, i.e.,
then we can rewrite νi, νj, νi+ and νj+ as:
νi=1−Gi−αiKii−sαjKij,
νj=1−Gj−αjKjj−sαiKij,
νi+=−gi−(αi+βi−C)Kii+−(αj+βj−C)Kij+
νj+=−gj−(αj+βj−C)Kjj+−(αi+βi−C)Kij+
So,
sνi−νj=s−1−sGi+Gj+αj(Kii−2Kij+Kjj)+sΔ(Kij−Kii)
νi+−νj+=gj−gi+(αj+βj−C)(Kii+−2Kij++Kjj+)+μ(Kij+−Kii+)
Note that the above expressions are computed using the old values of αj, and βj, in other words, the values at the beginning of the current iteration. Using the above expressions for sνi−νj and νi+−νj+ we can represent αj+ and βj+ in terms their old values as follows:
Now that we have calculated the extreme point (αj,βj), to maximize the function W(αj,βj) on the 2-dimensional space {αj,βj}, we need to find the feasible domain D where the following four constraints (stemming from non-negativity of all variables α and β) of the problem hold:
We consider two cases s=+1 and s=−1 separately.
Case 1: s=+1. In this case, the constraints describing the domain D have the form
Observe that the domain D is non-empty, because Δ≧0 and μ−Δ+2C≧0. Indeed, since s=1, then Δ=αi+αj≧0. Also, βi+βj=μ−(αi+αj)+2C=μ−Δ+2C≧0. The domain D is shown in
If the inequalities
hold, then the extreme point (αj+,βj+) belongs to D (as shown in the upper part of
For the following cases, we need to consider the function W(αj,βj) restricted to a horizontal or a vertical line. On the horizontal boundaries of the domain, βj is constant, say βj=b, reducing the objective function to W(αj,b)=W(αj), while for the vertical boundaries, αj is constant, say αj=α, and the objective function reduces to W(α,βj)=W(αj). On the horizontal line W(αj) has a zero derivative for αj|βj=b (given below). Similarly, W(βj) on the vertical line has a zero derivative for βj|αj=α expressed below:
Case 1.1: Lower boundary of D In this case, βj=0 and the restriction of the function W(αj,βj) on the lower boundary of D is a function of αj, where the ends of segments are determined by the coordinates
The function W has zero derivative on αj for αj1.1 that can be obtained by substituting s=1 and b=0 in αj+|βj=b, i.e.,
so the potential maximum point Z1.1 of the function W(αj,βj) on the left boundary of D has the form Z1.1={αjαj1.1, βj=0}. If Z1.1 belongs to the segment determined by the points
we select M1.1=W(Z1.1) as the maximum value achievable for Case 1.1; otherwise we select
Case 1.2: Upper boundary of D. In this case βj=μ−Δ+2C, and the restriction of the function W(αj,βj) on the upper boundary of D is a function of αj, where the ends of segments are determined by the values
The function W has zero derivative on αj for αj1.2 which can be obtained by substituting s=1 and b=μ−Δ+2C in αj+|βj=b, i.e.,
so the potential maximum point Z1.2 of the function W(αj,βj) on the left boundary of D has the form Z1.2={αj=αi1.2, βj=μ−Δ+2C}. If Z1.2 belongs to the segment determined by the points
we select M1.2=W(Z1.2) as the maximum value achievable for Case 1.2; otherwise we select
Case 1.3: Left boundary of D. In this case, αj=0 and the restriction of the function W(αj,βj) on the upper boundary of D is a function of βj, where the ends of the segment are determined by the values
The function W has zero derivative on βj for βj1.3 which can be obtained by substituting s=1 and α=0 in βj+|αj=α, i.e.,
so the potential maximum point Z1.3 of the function W(αj,βj) on the left boundary of D has the form Z1.3={αj=0, β=βj1.3}. If Z1.3 belongs to the segment determined by the points
we select M1.3=W(Z1.3) as the maximum value achievable for Case 1.3; otherwise we select
Case 1.4: Right boundary of D In this case, αj=Δ and the restriction of the function W(αj,βj) on the upper boundary of D is a function of βj, where the ends of segments are determined by the values
The function W has zero derivative on βj for βj1.4 which can be obtained by substituting s=1 and α=Δ in βj+|αj=α, i.e.,
so the potential maximum point Z1.4 of the function W(αj,βj) on the left boundary of D has the form Z1.4={αj=Δ, β=βj1.4}. If Z1.4 belongs to the segment determined by the points
we select M1.4=W(Z1.4) as the maximum value achievable for Case 1.4; otherwise we select
After all four cases (boundaries) are analyzed in this manner, we compare the four values M1.1, M1.2, M1.3, M1.4, and select the point {αj+,βj+} corresponding to the maximum one.
Case 2: s=−1. In this case, the constraints describing the domain D have the form
We denote H=(μ−Δ+2C)/2; then L≦αj≦H and 0≦βj≦2(H−L). Here we assume that H≧L; if this condition does not hold, the method stops. The domain D is shown in
If the inequalities
hold, then the extreme point (αj+,βj+) belongs to D (as shown in the upper part of
Case 2.1: Lower boundary of D. In this case, βj=0 and the restriction of the function W(αj,βj) on the lower boundary of D is a function of αj, where the ends of segments are determined by the values
The function W has zero derivative on αj for αj2.1 that can be obtained by substituting s=1 and b=0 in αj+|βj=b i.e.,
so the potential maximum point Z2.1 of the function W(αj,βj) on the lower boundary of D has the form Z2.1={αjαj2.1, βj=0}. If Z2.1 belongs to the segment determined by the points
we select M2.1=W(Z2.1) as the maximum value achievable for Case 2.1; otherwise we select
Case 2.2: Vertical boundary of D. In this case, αj=L and the restriction of the function W(αj,βj) on the vertical boundary of D is a function of βj, where the ends of segments are determined by the values
The function W has zero derivative on βj for βj2.2 which can be obtained by substituting s=1 and α=L in βj+|αj=α, i.e.,
so the potential maximum point Z2.2 of the function W(αj,βj) on the lower boundary of D has the form Z2.2={αj=L, βj=βj2.2}. If Z2.2 belongs to the segment determined by the point
we select M2.2=W(Z2.2) as the maximum value achievable for Case 2.2; otherwise we select
Case 2.3: Slant boundary of D. In this case, βj=2H−2αj and the restriction of the function W(αj,βj) on the upper boundary of D is a function of αj, where the ends of segments are determined by the values
The function W has zero derivative on αj for
so the potential maximum point Z2.3 of the function W(αj,βj) on the lower boundary of D has the form Z2.2={αj=αj2.3, βj=2H−2αj2.3}. If Z2.3 belongs to the segment determined by the point
we select M2.3=W(Z2.3) as the maximum value achievable for Case 2.3; otherwise we select
After all three cases (triangle boundaries) are analyzed in this manner, we compare the three values M2.1, M2.2, M2.3, and select the point {αj+,βj+} corresponding to the maximum one.
Special Case of Identity Correction Space Kernel: Consider the case of an identity correction space kernel K+, where K+({right arrow over (x)}i+,{right arrow over (x)}j+)=1 for all i=j and K+({right arrow over (x)}i+,{right arrow over (x)}j+)=0 otherwise. In this case, the optimization problem has a simpler structure than in the general case, and can be solved by a more simple version of gSMO. The problem has the following form. Maximize:
under the constraints
Select two of Lagrange multipliers αi and αj. Then the function W has the form W(αi,αj)=W+(αi,αj)+W+(αi,αj), where
is the same function as in Platt's SMO algorithm and
is the additional function corresponding to the SVM+ case.
Here,
and Wconstant are the terms that do not depend on αi,αj. Since αi=Δ−sαj, the function W has the form W(αj)=W+(αj)+W+(αj), where
We now seek for the maximum αjnew of the function W(αj) on the segment L≦αj≦H, where boundaries L and H are defined jointly from the inequalities of the problem and the sign of s. We calculate the extreme point αj+ of W(αj) and the boundaries L and H for the following four different cases separately:
Case 1: αi<C; αj<C.
Case 2: αi≧C; αj≧C.
Case 3: αi<C; αj≧C.
Case 4: αi≧C; αj<C.
Case 1: αi<C; αj<C In this case, the non-positive function W+(αi,αj) reaches its maximum 0 for βi=C−αi and βj=C−αj. Then W(αi,αj)=W+(αi,αj). The function W has zero derivative on αj for
Then, depending on s, as illustrated in
if s=+1 then L=max(0,Δ−C), H=min(C,Δ);
if s=−1 then L=max(0,−Δ), H=inn(C,C−Δ).
Case 2: αi≧C; αj≧C. In this case, the function W+(αi,αj) reaches its maximum for βi=βj=0. Then
Therefore,
Denote yiαi+yjαj=δ and multiply this equality by yi: αi+αjs=Δ where Δ=δyi and s=±1. The function W has zero derivative on αj for
Then, depending on s, as illustrated in
if s=+1 then L=C, H=Δ−C;
if s=−1 then L=C+max(0,−Δ), H=+∞.
Case 3: αi<C; αj≧C. In this case, the function W+(αi,αj) reaches its maximum for βi=C−αi and βj=0. Then,
Therefore,
Denote yiαi+yjαj=δ and multiply this equality by yi: αi+αjs=Δ where Δ=δyi and s=±1. The function W has zero derivative on αj for
Then, depending on s, as illustrated in
if s=+1 then L=max(C,Δ−C), H=Δ;
if s=−1 then L=C+max(0,−Δ−C), H=−ΔC.
Case 4: αi≧C; αj<C. In this case, the function W+(αi,αj) reaches its maximum for βj=C−αj and βi=0. Then,
Therefore,
Denote γiαi+γjαj=δ and multiply this equality by yi: αi+αjs=Δ, where Δ=δyi and s=±1. The function TV has zero derivative on αj for
Then, depending on s, as illustrated in
if s=+1 then L=0, H=min(Δ−C,C);
if s=−1 then L=max(0,2C−Δ), H=C.
Now that we computed αj+, L, and H for each of the four cases, we compute αjnew in the following way:
Case A: If L≦αj+≦H, then we select the maximum of the three values W0=W(L), W+=W(αj+), W1=W(H), and then select the corresponding values of αjnew: αjnew=Liαjnew=αj+ or αjnew=H.
Case B: If L≦αj+≦H is not true, then we select the maximum of the two values W0=W(L), W1=W(H) and then select the corresponding values of αjnew: αjnew=L, or αjnew=H.
After that we compute αinew as αinew=Δ−αjnews, which completes the step of computing two new Lagrange multipliers αjnew and αinew.
gSMO Complexity: As illustrated, generalized SMO (gSMO), is faster than generic quadratic optimization since it uses a closed-form computation. gSMO is thus applicable to SVM+ problems handling large samples in large-dimensional spaces. gSMO is specially designed for SVM+, whereas SMO is applicable for SVM. While SVM+ has twice as many variables as SVM, gSMO employs the same order of magnitude of computations of W as SMO. Indeed, SMO computes W once and then compares the extreme point with L and H; gSMO may need to compute W in two extreme points (corresponding to vertical and horizontal directions) and in three vertices of D).
The SVM+ approach provides a basis for better generalization (lower VC-dimension) and is a potential new setting of learning which includes a real teacher (not just an oracle). We have showed that SVM+ can perform better than SVM in terms of its error rate. We introduced a specialized optimization technique, SVM+, which appears to be as efficient as standard techniques for SVM. Additional optimization of gSMO (covering speed-up of individual steps, mechanisms for working set selection (including more than two working vectors), and parameters selection) is also contemplated. The realization of gSMO within the framework of standard SVM libraries is expected to bring more data for further improvement of the method.
Referring to
In block 206, the number of variables is reduced to two variables in the quadratic function using linear constraints. In block 208, an extreme point is computed for the quadratic function in closed form. This may include computing zero derivatives for each of the two variables to determine the extreme point.
In block 212, a two-dimensional set is defined where the indexes determine whether a data point is in the two-dimensional set or not. The two-dimensional set may form/define a rectangle, a triangle or other the two-dimensional shape.
In block 216, a determination of whether the extreme point belongs to the two-dimensional set is made. If the extreme point belongs to the two-dimensional set, the extreme point defines a maximum and the extreme point defines a new set of parameters for a next iteration in block 218. The new set of parameters may include Lagrange multipliers.
Otherwise, the quadratic function is further restricted on at least one boundary of the two-dimensional set to create a one-dimensional quadratic function in block 230. This may include analyzing boundaries of the two-dimensional set in block 220 and selecting a maximum based upon a comparison of a result from each boundary in block 222.
The steps are preferably repeated until the maximum is determined in block 232. In block 234, the maximum may be employed as a determination of a maximum distance to a hyperplane.
Having described preferred embodiments of a system and method for generalized sequential minimal optimization for svm+ computations (which are intended to be illustrative and not limiting), it is noted that modifications and variations can be made by persons skilled in the art in light of the above teachings. It is therefore to be understood that changes may be made in the particular embodiments disclosed which are within the scope and spirit of the invention as outlined by the appended claims. Having thus described aspects of the invention, with the details and particularity required by the patent laws, what is claimed and desired protected by Letters Patent is set forth in the appended claims.
This application claims priority to provisional application Ser. No. 60/908,264 filed on Mar. 27, 2007, incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
20060074908 | Selvaraj et al. | Apr 2006 | A1 |
20060112026 | Graf et al. | May 2006 | A1 |
20090204553 | Gates | Aug 2009 | A1 |
Number | Date | Country | |
---|---|---|---|
20080243731 A1 | Oct 2008 | US |
Number | Date | Country | |
---|---|---|---|
60908264 | Mar 2007 | US |