支持向量机SVM推理(预测)代码实现

文章介绍了如何将使用sklearn库训练的支持向量机(SVM)模型,特别是使用径向基函数(rbf)核函数的模型,提取关键参数并移植到C语言环境中,以便在嵌入式系统中进行预测。主要涉及clf.support_vectors_,clf.intercept_,clf.dual_coef_和clf.gamma等参数的使用。

使用sklearn训练的SVM模型要怎样移植到C语言中进行嵌入式开发呢?本文提供了将训练的支持向量机模型从sklearn抽取出来的方法。

clf = SVC(kernel='rbf', C=10.0, gamma=0.01)
    
clf.fit(X_train, y_train)

# 使用sklearn自带的predict函数
y_predict = clf.predict(X_validate)
print(confusion_matrix(y_validate, y_predict))


# 使用训练好的SVC模型中的clf.support_vectors_, clf.intercept_,clf.dual_coef_和clf.gamma参数,
# 根据核函数类型实现预测功能
fp = np.zeros((X_validate.shape[0], 1))
for i in range(X_validate.shape[0]):
    K = np.exp(-np.sum((X_validate[i, :] - clf.support_vectors_) * (X_validate[i, :] - 
    clf.support_vectors_), 1) * clf.gamma)
    fp[i] = np.dot(clf.dual_coef_, K) + clf.intercept_
fps = fp.squeeze()
fps[fps >= 0] = 1
fps[fps < 0] = 0
print(confusion_matrix(y_validate, fps))

这里使用的是径向基函数rbf核函数,X_train和y_train是训练样本的输入特征和标签,X_validate和y_validate是测试集的输入特征和标签,clf是训练的SVC模型。

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值