浅析自助算法

   今天晚上用matlab实现了自助算法,虽然过程有些曲折,但是最终还是实现了,下面先贴出源码,然后再一一做解释。

   源码如下:

   clear all;

   close all;

   data = csvread('watermelon4.0.csv');

   [m,n]= size(data);

   middleVector = 1:m;

   Sindex = randi([1,m],1,m)

   notInT = unique(Sindex);

   Tindex = setdiff(middleVector,notInT);

   S = data(Sindex,:);

   T = data(Tindex);

    首先,了解一下自助算法的原理。假设样本有M条数据,定义为D,训练数据为S,随机从D中取M次数据,并保存,测试数据T,是所有不包含S数据的D。

   其次,我们分析一下开篇贴出的源码clear all,close all是将之前的数据清除,以保证数据的正确性;data = csvread('watermelon4.0.csv');是获取初始数据;[m,n] = size(data);是获取初始数据的行数和列数;sum = 1:m;生成一个1行m列的向量;Sindex=randi([1,m],1,m);随机生成m行的矩阵的索引,即训练数据的矩阵S的索引;notInT=unique(Sindex);对训练数据索引去重;Tindex=setdiff(middleVector,notInt);由setdiff函数求得不包含S数据的D的测试数据索引。最后两句是根据索引给S,T赋值。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值