Motivation
As a former TA for machine learning courses—and a learner myself—I’ve noticed that many beginners encounter support vectors as abstract definitions in lecture slides or textbooks. While technically correct, these explanations often lack a visual or intuitive component, making it difficult to see which data points actually matter in practice.
This post is my attempt to bridge that gap. We’ll revisit what support vectors are, why they matter, and—most importantly—how to recognize them visually. By the end, you should be able to look at the plot of a trained SVM and confidently identify the support vectors: the handful of data points that directly define the decision boundary.
The Role of Lagrange Multipliers
In the SVM framework, each training data point is associated with a Lagrange multiplier, denoted as \(\alpha_i\). The decision boundary is computed as:
\[ \mathbf{w}^* = \sum_{i=1}^n \alpha_i y_i \mathbf{x}_i \]
Only those data points for which \(\alpha_i > 0\) contribute to this sum. In other words, if a data point’s corresponding multiplier is zero, it has no impact on the decision boundary. These influential points are what we call support vectors.
Support Vectors in Hard-Margin SVM
For datasets that are perfectly separable, we use a hard-margin SVM. Here, the complementary slackness condition tells us:
\[ \alpha_i(1 - y_i\mathbf{w}^\top\mathbf{x}_i) = 0 \]
This equation means that for points not on the margin (where \(y_i\mathbf{w}^\top\mathbf{x}_i > 1\)), the multiplier \(\alpha_i\) must be 0. Hence, only those points that lie exactly on the margin (where \(y_i\mathbf{w}^\top\mathbf{x}_i = 1\)) have non-zero multipliers and are thus support vectors.
Try yourself!
Can you identify the support vectors in the plot below?

✅ Click to reveal the answer
There are 3 support vectors in the plot above. These are the data points that lie exactly on the margin boundaries. They are the only points with non-zero Lagrange multipliers $\alpha_i > 0$ and directly influence the position of the decision boundary.

Code for generating the plots
Want to experiment yourself? Below is the full code used to generate the plots. Try adjusting the random_state in make_blobs to generate different datasets and see how the support vectors change!
|  |  | 
Support Vectors in Soft-Margin SVM
When data is not perfectly separable, SVMs use a soft-margin approach with slack variables \(\xi_i\). The complementary slackness and KKT conditions become:
\[ \alpha_i(1 - y_i\mathbf{w}^\top\mathbf{x}_i - \xi_i) = 0 \\ (C - \alpha_i)\xi_i = 0 \]We then encounter two cases:
- \(\alpha_i > 0\), \(\xi_i = 0\): 
 The point lies exactly on the margin border. It is a support vector.
- \(\alpha_i > 0\), \(\xi_i > 0\): 
 The point is either inside the margin or misclassified. Here, \(\alpha_i = C\). These points also influence the decision boundary and are support vectors.
In contrast, points with \(\alpha_i = 0\) lie far from the margin and do not affect the model.
Try yourself!
Can you identify the support vectors in the plot below?

✅ Click to reveal the answer
There are 6 support vectors in the plot above. In the soft-margin setting, support vectors are the data points with non-zero Lagrange multipliers $\alpha_i > 0$. These include:
- Points lying exactly on the margin boundaries
- Points that are within the margin
- Points that are misclassified (on the wrong side of the decision boundary)
Only these points influence the position of the decision boundary. Points farther away from the margin have $\alpha_i = 0$ and do not contribute.

Code for generating the plots
|  |  | 
Conclusion
Support vectors are not just a technical detail in SVMs—they are the essential data points that shape the decision boundary. Whether you’re working with a hard-margin or soft-margin SVM, the concept remains the same: Only the data points with non-zero Lagrange multipliers ($\alpha_i > 0$) influence the final classifier.
By now, you should be able to look at an SVM plot and confidently pick out the support vectors, understanding exactly why they matter.
