The present application is claims priority of Japanese Patent Application Serial No. 2008-238950, filed Sep. 18, 2008, the content of which is hereby incorporated by reference in its entirety.
1. Field of the Invention
The present invention relates to a support vector (SV) reduction method for multi-class support vector machine (hereinafter, “SVM”), and particularly relates to an SV reduction method for multi-class SVM by which a number of SVs can be reduced at high precision and high speed. In the following, “support vector” may at times be indicated as “SV.”
2. Description of the Related Art
Although initially, support vector machines were designed for binary-class classification tasks, support vector machines designed for multi-class classification have also been developed in recent years. In a multi-class classification problem, more than one SVM are used to perform classification into multiple classes. In a multi-class SVM, a final decision function ft is calculated based on a function ft (where t=1, 2, . . . , T) of time t that is from 1 to T:
In the above, K(x, y) is a kernel function that calculates a dot product of two vectors x and y in some feature space. A time complexity of calculation of Formula (1) above increases with a number xi (i=1, . . . , NS) of SVs.
Reduced set methods for reducing the number of SVs are thus being studied. A main task is to construct a new set of vectors zi (i=1, . . . , NZ) that are reduced in number and coefficients βti (i=1, . . . , Nz, t=1, . . . , T) corresponding thereto. The new functions f′t are as indicated in Formula (2) below.
In the above, NZ<<NS, and the new functions f′t(x) are thus calculated simpler and run faster when evaluating a new vector x.
As conventional methods for deriving Formula (2) from Formula (1), in other words, as conventional methods for reducing the number of SVs, the following methods (1) to (3) have been proposed.
(1) Top-Down Method for Two-Class SVM (Binary SVM) (Non-Patent Documents 1 and 2)
In a two-class SVM (an SVM for performing a process of classifying into two classes), each SV is associated with a single coefficient. In the method described in Non-Patent Documents 1 and 2, temporary vectors zi (i=1, 2, . . . , Nz) are derived using Formulae (3) and (4) shown below. Once the temporary vectors zi are derived, the coefficients βi are determined.
In the above, ψi is expressed by Formula (4) shown below:
The classification function Φ(z) of Formula (3) is a multivariable function of multiple variables z (=z1, z2, . . . , zn) and thus a problem of a local minimum optimization solution occurs as be described below.
(2) Bottom-Up Method for Two-Class SVM (Non-Patent Document 3)
A method of reducing the number of SVs by a bottom-up method, that is, a method of iteratively selecting two SVs and replacing these by a newly constructed vector is proposed in Non-Patent Document 3.
(3) Top-Down Method for Multi-Class SVMs (Non-Patent Document 4)
A method of simplifying multi-class SVMs by extension of the reduced set construction method of Non-Patent Documents 1 and 2 is proposed in Non-Patent Document 4. In each iteration, a single, new, reduced SVz in a single SVM is generated and shared with the others by retraining all of the SVMs.
However, the conventional methods (1) to (3) described above have the following issues:
1. Top-Down Method for Two-Class SVM (Binary SVM) (Non-Patent Documents 1 and 2)
Main drawbacks of this method are that the SVM is poor in performance in that trapping in a local minimum optimization solution occurs readily and that the search for z in Formula (3) must be repeated many times to obtain a satisfactorily simplified SVM. A cause of becoming trapped in the local minimum optimization solution is that the classification function Φ(z) is a multivariable function.
2. Bottom-Up Method for Two-Class SVM (Non-Patent Document 3)
This method has the issues of being poor in precision due to trapping in a local minimum occurring readily and being applicable only to a two-class SVM with which each SV simply corresponds to only a single coefficient.
3. Top-Down Method for Multi-Class SVMs (Non-Patent Document 4)
In this method, the two-class SVM is extended and there is thus the issue of the SVMs being poor in precision due to trapping in a local minimum optimization solution occurring readily. To alleviate the problem of the local minimum optimization solution, a different evolution algorithm is used in combination with a gradient descent method in the process of constructing the reduced vectors. However, due to the nature of the problem, the classification result is unstable.
An object of the present invention is to provide an SV reduction method for multi-class SVMs, with which the number of SVs contained in the multi-class SVMs can be reduced without becoming trapped in a local minimum optimization solution. Another object is to provide an SV reduction method for multi-class SVMs, with which the number of SVs can be reduced at high precision and high speed.
In order to achieve the object, the invention is characterized by that an SV reduction method for multi-class SVMs comprises a first step of selecting, from a plurality of initially present support vectors, support vector pairs zi, zj (i, j=1, 2, . . . , NS), a second step of preparing a single-variable objective function with a single global maximum and determining a maximum value k of the objective function, a third step of applying the maximum value k to the support vector pairs zi, zj to determine a temporary vector Ztemp[i] with small classification errors, and a fourth step of representing the support vector pair zi, zj by the temporary vector Ztemp[i].
Additionally, the invention is characterized by that the SV reduction method for multi-class SVMs further comprises a fifth step of selecting, from among the temporary vectors Ztemp[i], a temporary vector Ztemp[i] with the smallest classification error, a sixth step of selecting pairs from among the selected temporary vector Ztemp[i] and the remaining initial support vectors zi and zj, a seventh step of applying the maximum value k to the selected support vector pairs and determining temporary vectors Ztemp[i] of small classification errors, and an eighth step of representing the support vector pairs by the temporary vectors Ztemp[i], and wherein the fifth to eighth steps are executed repeatedly and ending the support vector reduction process when a size of the support vector becomes equal to a reduction target size NZ.
With the present invention, temporary vectors Ztemp[i] of low classification error can be determined from pairs of SVs without becoming trapped in a local minimum optimization solution.
Thus in comparison to the conventional methods (1) to (3), the SV reduction process can be performed at high speed and multi-class SVMs that are highly efficient, stable, and high in processing speed can be provided.
The present invention shall now be described in detail with reference to the drawings. First, principal portions of the present invention shall be described and thereafter, an embodiment according to the present invention shall be described.
By the present invention, SVs are reduced without becoming trapped in a local minimum optimization solution as in Non-Patent Documents 1, 2, 3, and 4. In a case where the kernel function K of Formula (1) and Formula (2) described above is a Gaussian kernel, that is, in the case where Kij=K(zi, zj)=exp(−γ∥zi−zj∥2), the SVs are reduced upon replacing zi and zj, which are two SVs, by a newly constructed vector z (hereinafter referred to as the “temporary vector z”) using Formula (5) and Formula (6) shown below. Coefficients βt of the temporary vector z are determined from Formula (9) shown below.
z=κz
i+(1−κ)zj (5)
Here, k is expressed by Formula (6):
“arg” in Formula (6) is an abbreviation of “argument”. h(k) in Formula (6) is an objective function optimized for a Gaussian kernel.
The objective function h(k) is an objective function derived from a condition of minimizing a classification error Err(z) (see Formula below) of the vector z, and detailed description thereof shall be omitted. Φ(z) is a classification function.
Err(z)=∥Φ(z)−(mΦ(zi)+(1−m)Φ(zj)∥
In a case of a polynomial kernel, that is, in the case where Kij=K(zi, zj)=(zizj)p, the SVs are reduced upon replacing zi and zj, which are two SVs, by a newly constructed vector z using Formula (7) and Formula (8) shown below. Coefficients βt of the temporary vector z are determined from Formula (9) shown below.
g(k) in Formula (8) is an objective function optimized for the polynomial kernel. As with the objective function h(k), the objective function g(k) is an objective function derived from a condition of minimizing the classification error Err(z) of the vector z.
As shown in
As mentioned above, each of the objective functions h(k) and g(k) is a single-variable function (convex function) having a single global maximum in the interval [0, 1], and a single, new support vector z (that is, the temporary vector z) can thus be determined from two support vectors zi and zj without ending up with the local minimum optimization solution problem by solving Formula (5) under the restriction of Formula (6) in a case of a Gaussian kernel and by solving Formula (7) under the restriction of Formula (8) in a case of a polynomial kernel.
As is clear from the above, a main point of the present invention is that Formula (5) is solved under the restriction of the objective function h (k) as expressed by Formula (6) or Formula (7) is solved under the restriction of the objective function g(k) as expressed by Formula (8).
An algorithm of an embodiment of an SV reduction method for multi-class SVMs according to the present invention shall now be described with reference to the flowcharts of
In step S10 of
In step S20, for each zi, a pair (counterpart), j=Pair[i], of shortest distance is selected from among the support vectors zk (k≠i, k=1, 2, . . . , NS). For example, the pairs z1-z2, z3-z1, z4-z5, and z5-z2 in
Next, in step S30, the temporary vectors z=Ztemp[i] are calculated using Formula (5) and Formula (6). Each z is an SV resulting from internally dividing a pair so as to minimize the classification error Err within the pair and, for example, the each z corresponds to Ztemp[1], Ztemp[3], Ztemp[4], and Ztemp[5] shown in
In step S40, the coefficients Beta[t, i] of the respective SVs are calculated using Formula (9).
In step S50, the classification errors Err[i] of Ztemp[i] are determined. In the formula, Φ is the classification function. For example, Err[1] of Ztemp[1], Err[3] of Ztemp[3], etc. shown in
The processes of a first stage of determining the temporary vectors Ztemp[i], the coefficients Beta[t, i], and the classification errors Err[i] of Ztemp[i] for the support vectors (Red) to be reduced are ended with the above.
Next, in step S60, a size is set as: size=NS. Here, the size NS is the initial size of the SVs. For example, in the present example, the initial size of the SVs is equal to 5 as shown in
In step S70, it is determined whether or not a condition, size≧NZ, holds. Here, the size NZ is a target size for SV reduction, with NZ<<NS. For example, NZ=( 1/10)NS.
In step S80, the argument of a minimum member in the set of Err[k] is set as i. The argument of the pair counterpart with the minimum member of argument i is set as j. In step S90, Ztemp[i], with the minimum error, is set as the support vector zi and the coefficients βti of this zi are determined.
In step S100, the counterpart of the pair is null, that is, deleted. Thus in step S110, the size of the SVs is reduced by just one and becomes: (size-1).
For example, if Err[1] is the minimum error in
Next, step S120 of
In step S130, z=Ztemp[I] are calculated using Formula (5) and Formula (6) in the same manner as in step S30. For example, Ztemp[3]′ and Ztemp[5]′ are determined anew as shown in
In step S140, the coefficients Beta [t, I] of the respective SVs are calculated using Formula (9) in the same manner as in step S40.
In step S150, the classification errors Err[I] of Ztemp[I] are determined in the same manner as in step S50. For example, Err[3] of Ztemp[3]′, Err[5] of Ztemp[5′], etc. are determined as shown in
When the processes of a second stage of determining the temporary vectors Ztemp[I], the coefficients Beta[t, I], and the classification errors Err[I] of Ztemp[I] for the case where the size of the SVs has been reduced by one are thus ended, a return to step S70 of
If in step S70, the size of the SVs is determined to be still greater than the reduction target size NZ, step S80 is entered again, and the pair counterpart j, corresponding to the smallest classification error among the classification errors Err[I] of Ztemp[I], which were determined in step S150, is selected. For example, if Ztemp[4] in
In step S90, Ztemp[i] is set as the support vector zi and the coefficients βti of this zi are determined. For example, as shown in
In step S100, the pair counterpart z5 is null, that is, z5=NULL, and the size is reduced by one in step S110. As a result, the size of the SVs becomes equal to 3 as shown in
Step S120 of
The processes of steps S70 to S150 are thus performed repeatedly, the size is reduced by one in each single cycle, and when the determination of step S70 is negative, that is when the size of the SVs reaches the reduction target size NZ, the process enters step S160 of
The processes of steps S160 to 180 are processes of correcting the support vectors zi that have been reduced as described above and the coefficients βti thereof.
In step S160, a set (zi, βti) with the reduced size is set as the reduced support vectors (Red).
In step S170, a computation of minimizing a function F(z) while keeping the coefficients βti fixed is performed. The function F(z) is a known optimization function. As the coefficients βti in the function F(z), the values determined in S140 are used.
In step S180, a process of optimizing the coefficients βti while keeping the determined vectors zi in S170 fixed is performed. Whereas the above computation processes took time for computation conventionally because computations of determining optimal solutions that minimize the function F(z) were performed using the vectors zi and coefficients βti of the F(z) as variables, in the present invention, the computation speed can be made significantly high in comparison to the conventional case because the computation of minimizing the function F(z) while keeping the coefficients βti fixed is performed in step S170 and the computation of optimizing the coefficients βt while keeping the vectors zi fixed is performed in step S180.
As is clear from
Although the present invention has been described above by way of an embodiment, the present invention is not restricted to the embodiment and clearly, various modifications are possible within a range not falling outside the scope of the present invention.
Number | Date | Country | Kind |
---|---|---|---|
2008-238950 | Sep 2008 | JP | national |