【svm】matlab svm的可视化----使用quadprog 求解SVM对偶问题

matlab svm的可视化----使用quadprog 求解SVM对偶问题2020年12月6日00:09:50解决问题: matlab求解凸优化工具箱使用​ SVM 的原始数据、支持向量、决策边界可视化​ 高斯非线性核函数​ 简单的调参过程可优化扩展方向:其他经典模型的实现​ 其他核函数的实现​ 代码优化----减少循环嵌套quadprog Quadratic programming.codemain.mcl
摘要由CSDN通过智能技术生成

matlab svm的可视化----使用quadprog 求解SVM对偶问题

2020年12月6日00:09:50

解决问题: matlab求解凸优化工具箱使用

SVM 的原始数据、支持向量、决策边界可视化

高斯非线性核函数

简单的调参过程

可优化扩展方向:其他经典模型的实现

其他核函数的实现

代码优化----减少循环嵌套

quadprog Quadratic programming.

img

code

main.m
clc;clear
%%
% main 
% 使用quadprog 求解凸优化实现 SVM-软间隔基本问题
% @author haoqi
% @version 1
% */
%% 载入数据
load('trainData.txt')
X = trainData(:,1:2);
X  = zscore(X); % 数据标准化
Y = trainData(:,3);

% 2-8 fold

X_test = X(ceil(length(X)*0.8):end,:)
Y_test = Y(ceil(length(X)*0.8):end,:)

X = X(1:ceil(length(X)*0.8),:);
Y = Y(1:length(X),:);


class1 = X((Y(:,1)==1),:);
class2 = X((Y(:,1)==-1),:);
[m n]=size(X);
%% 设置参数调整过程
c = [1 10 100 1000 ];
sigma = [0.001 0.01 0.1 1 10 ];
lambda = zeros(m,1,5,6);
b = zeros(1,5,6);
accuracy = zeros(4,5);
k = 0;% idx of subplot

%% 生成阵点
xx = linspace(min(X(:,1)),max(X(:,1)),50);
yy = linspace(min(X(:,2)),max(X(:,2)),50);
[x1,y1] = meshgrid(xx,yy);

for i=1:4
    for j=1:5
        k= k+1;
        [lambda(:,:,i,j) b(:,i,j)] = svm_dual(X,Y,c(i),sigma(j));
        W= lambda(:,:,i,j);
        subplot(4,5,k)
        %% plot orgin data
            
         scatter(class1(:,1),class1(:,2),'y','filled');
         hold on
         scatter(class2(:,1),class2(:,2),'b','filled');
         suppter_v_index = find(W>0.9); % support vectors(SVs)
         suppter_v = X(suppter_v_index,:);
         hold on 
         plot(suppter_v(:,1),suppter_v(:,2),'o')
         hold o
  • 3
    点赞
  • 25
    收藏
    觉得还不错? 一键收藏
  • 14
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 14
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值