前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >简单易学的机器学习算法——Rosenblatt感知机的对偶解法

简单易学的机器学习算法——Rosenblatt感知机的对偶解法

作者头像
felixzhao
发布2018-03-16 17:14:15
6090
发布2018-03-16 17:14:15
举报
文章被收录于专栏:null的专栏null的专栏

一、Rosenblatt感知机回顾   

二、Rosenblatt感知机的对偶形式   

三、算法流程

四、实验的仿真

    利用博文“简单易学的机器学习算法——Rosenblatt感知机”中的数据集,原始数据集如下图所示:

(原始数据点)

MATLAB代码

代码语言:javascript
复制
%% Rosenblatt感知机的对偶解法
clear all;
clc;

%读入数据
x=[3,3;4,3;1,1];
y=[1;1;-1];
[m,n] = size(x);%取得数据集的大小

%% 画出原始的点
hold on
axis([0 5 0 5]);%axis一般用来设置axes的样式,包括坐标轴范围,可读比例等
for i = 1:m
    plot(x(i,1),x(i,2),'.');
end

%% 初始化
alpha = zeros(1,m);
b = 0;
yita = 1;%学习率
gram = zeros(m,m);

%% 计算Gram矩阵
for i = 1:m
    for j = 1:m
        gram(i,j)=x(i,:)*x(j,:)';
    end
end

%% 更新
for i = 1:m
    tmp = 0;
    for j = 1:m
        tmp = tmp + alpha(j)*y(j)*gram(i,j);
    end
    tmp = tmp + b;
    tmp = y(i)*tmp;
    if tmp <= 0
        alpha(i) = alpha(i)+yita;
        b = b + y(i);
    end
end
% 要使得数据集中没有误分类的点
flag = 0;%标志位,用于标记有没有误分类的点
i = 1;
while flag~=1
    while i <= 3
        tmp = 0;
        for j = 1:m
            tmp = tmp + alpha(j)*y(j)*gram(i,j);
        end
        tmp = tmp + b;
        tmp = y(i)*tmp;
        if tmp <= 0
            alpha(i) = alpha(i)+yita;
            b = b + y(i);
            i = 1;%重置i
            break;
        else
            i = i+1;
        end
        if i == 4
            flag = 1;
        end
    end
end

%% 重新计算w和b
for i = 1:m
    x_new(i,:) = x(i,:) * y(i);
end
w = alpha * x_new;

%% 画出分隔线
x_1 = (0:3);
y_1 = (-b-w(1,1)*x_1)./w(1,2);
plot(x_1,y_1);

最终的分离超平面:

(最终分离超平面)

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、Rosenblatt感知机回顾   
  • 二、Rosenblatt感知机的对偶形式   
  • 三、算法流程
  • 四、实验的仿真
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档