Structured support vector machine

From Wikipedia, the free encyclopedia
  (Redirected from Structured SVM)
Jump to: navigation, search

The structured support vector machine is a machine learning algorithm that generalizes the Support Vector Machine (SVM) classifier. Whereas the SVM classifier supports binary classification, multiclass classification and regression, the structured SVM allows training of a classifier for general structured output labels.

As an example, a sample instance might be a natural language sentence, and the output label is an annotated parse tree. Training a classifier consists of showing pairs of correct sample and output label pairs. After training, the structured SVM model allows one to predict for new sample instances the corresponding output label; that is, given a natural language sentence, the classifier can produce the most likely parse tree.

Training[edit]

For a set of \ell training instances (\boldsymbol{x}_n,y_n) \in \mathcal{X}\times\mathcal{Y}, n=1,\dots,\ell from a sample space \mathcal{X} and label space \mathcal{Y}, the structured SVM minimizes the following regularized risk function.

\underset{\boldsymbol{w}}{\min} \quad \|\boldsymbol{w}\|^2 + C \sum_{n=1}^{\ell}
   \underset{y\in\mathcal{Y}}{\max} \left(\Delta(y_n,y) + \boldsymbol{w}'\Psi(\boldsymbol{x}_n,y) - \boldsymbol{w}'\Psi(\boldsymbol{x}_n,y_n)\right)

The function is convex in \boldsymbol{w} because the maximum of a set of affine functions is convex. The function \Delta: \mathcal{Y} \times \mathcal{Y} \to \mathbb{R}_+ measures a distance in label space and is an arbitrary function (not necessarily a metric) satisfying \Delta(y,z) \geq 0 and  \Delta(y,y)=0 \;\; \forall y,z \in \mathcal{Y}. The function \Psi: \mathcal{X} \times \mathcal{Y} \to \mathbb{R}^d is a feature function, extracting some feature vector from a given sample and label. The design of this function depends very much on the application.

Because the regularized risk function above is non-differentiable, it is often reformulated in terms of a quadratic program by introducing one slack variable \xi_n for each sample, each representing the value of the maximum. The standard structured SVM primal formulation is given as follows.

\begin{array}{cl}
  \underset{\boldsymbol{w},\boldsymbol{\xi}}{\min} & \|\boldsymbol{w}\|^2 + C \sum_{n=1}^{\ell} \xi_n\\
  \textrm{s.t.} & \boldsymbol{w}' \Psi(\boldsymbol{x}_n,y_n) - \boldsymbol{w}' \Psi(\boldsymbol{x}_n,y) + \xi_n \geq \Delta(y_n,y),\qquad n=1,\dots,\ell,\quad \forall y \in \mathcal{Y}
  \end{array}

Inference[edit]

At test time, only a sample \boldsymbol{x} \in \mathcal{X} is known, and a prediction function f: \mathcal{X} \to \mathcal{Y} maps it to a predicted label from the label space \mathcal{Y}. For structured SVMs, given the vector \boldsymbol{w} obtained from training, the prediction function is the following.

f(\boldsymbol{x}) = \underset{y \in \mathcal{Y}}{\textrm{argmax}} \quad \boldsymbol{w}'\Psi(\boldsymbol{x},y)

Therefore, the maximizer over the label space is the predicted label. Solving for this maximizer is the so-called inference problem and similar to making a maximum a-posteriori (MAP) prediction in probabilistic models. Depending on the structure of the function \Psi, solving for the maximizer can be a hard problem.

Separation[edit]

The above quadratic program involves a very large, possibly infinite number of linear inequality constraints. In general, the number of inequalities is too large to be optimized over explicitly. Instead the problem is solved by using delayed constraint generation where only a finite and small subset of the constraints is used. Optimizing over a subset of the constraints enlarges the feasible set and will yield a solution which provides a lower bound on the objective. To test whether the solution \boldsymbol{w} violates constraints of the complete set inequalities, a separation[disambiguation needed] problem needs to be solved. As the inequalities decompose over the samples, for each sample (\boldsymbol{x}_n,y_n) the following problem needs to be solved.

y_n^* = \underset{y \in \mathcal{Y}}{\textrm{argmax}} \left(
   \Delta(y_n,y) + \boldsymbol{w}'\Psi(\boldsymbol{x}_n,y) - \boldsymbol{w}'\Psi(\boldsymbol{x}_n,y_n) - \xi_n\right)

The right hand side objective to be maximized is composed of the constant -\boldsymbol{w}'\Psi(\boldsymbol{x}_n,y_n) - \xi_n and a term dependent on the variables optimized over, namely \Delta(y_n,y) + \boldsymbol{w}'\Psi(\boldsymbol{x}_n,y). If the achieved right hand side objective is smaller or equal to zero, no violated constraint for this sample exist. If it is strictly larger than zero, the most violated constraint with respect to this sample has been identified. The problem is enlarged by this constraint and resolved. The process continues until no violated inequalities can be identified.

If the constants are dropped from the above problem, we obtain the following problem to be solved.

y_n^* = \underset{y \in \mathcal{Y}}{\textrm{argmax}} \left(\Delta(y_n,y) + \boldsymbol{w}'\Psi(\boldsymbol{x}_n,y)\right)

This problem looks very similar to the inference problem. The only difference is the addition of the term \Delta(y_n,y). Most often, it is chosen such that it has a natural decomposition in label space. In that case, the influence of \Delta can be encoded into the inference problem and solving for the most violating constraint is equivalent to solving the inference problem.

References[edit]