我试图了解训练线性支持向量机的过程。我意识到 SMV 的属性允许它们比使用二次规划求解器更快地优化,但出于学习目的,我想看看它是如何工作的。
训练数据
set.seed(2015)
df <- data.frame(X1=c(rnorm(5), rnorm(5)+5), X2=c(rnorm(5), rnorm(5)+3), Y=c(rep(1,5), rep(-1, 5)))
df
X1 X2 Y
1 -1.5454484 0.50127 1
2 -0.5283932 -0.80316 1
3 -1.0867588 0.63644 1
4 -0.0001115 1.14290 1
5 0.3889538 0.06119 1
6 5.5326313 3.68034 -1
7 3.1624283 2.71982 -1
8 5.6505985 3.18633 -1
9 4.3757546 1.78240 -1
10 5.8915550 1.66511 -1
library(ggplot2)
ggplot(df, aes(x=X1, y=X2, color=as.factor(Y)))+geom_point()
找到最大边距超平面
根据这篇关于支持向量机的维基百科文章,找到我需要解决的最大边距超平面
服从 (对于任何 i = 1, ..., n)
如何将我的样本数据“插入”到 R 中的 QP 求解器(例如quadprog)以确定?