【adaboost分类】基于adaboost实现一维数据分类附matlab代码

简介: 【adaboost分类】基于adaboost实现一维数据分类附matlab代码

✅作者简介:热爱科研的Matlab仿真开发者,修心和技术同步精进,matlab项目合作可私信。

🍎个人主页:Matlab科研工作室

🍊个人信条:格物致知。

更多Matlab仿真内容点击👇

智能优化算法       神经网络预测       雷达通信      无线传感器        电力系统

信号处理              图像处理               路径规划       元胞自动机        无人机

⛄ 内容介绍

分类是数据挖掘研究范畴中为了解决分类问题而提出的方法,同时它也是一种重要的分析数据的技术.作为一种有效的科学研究工具,组合分类器在医疗诊断,手写体识别,人脸识别,推荐系统等领域有着广泛的应用.

⛄ 部分代码

% Example for adaboost.m

%

% Type "edit adaboost.m" to see the code




% Make training data of two classes "red" and "blue"

% with 2 features for each sample (the position  x and y).

 angle=rand(200,1)*2*pi; l=rand(200,1)*40+30; blue=[sin(angle).*l cos(angle).*l];

 angle=rand(200,1)*2*pi; l=rand(200,1)*40;    red=[sin(angle).*l cos(angle).*l];


% All the training data

 datafeatures=[blue;red];

 dataclass(1:200)=-1; dataclass(201:400)=1;


% Show the data

 figure, subplot(2,2,1), hold on; axis equal;

 plot(blue(:,1),blue(:,2),'b.'); plot(red(:,1),red(:,2),'r.');

 title('Training Data');

 

% Use Adaboost to make a classifier

 [classestimate,model]=adaboost('train',datafeatures,dataclass,50);


% Training results

% Show results

 blue=datafeatures(classestimate==-1,:); red=datafeatures(classestimate==1,:);

 I=zeros(161,161);

 for i=1:length(model)

     if(model(i).dimension==1)

         if(model(i).direction==1), rec=[-80 -80 80+model(i).threshold 160];

         else rec=[model(i).threshold -80 80-model(i).threshold 160 ];

         end

     else

         if(model(i).direction==1), rec=[-80 -80 160 80+model(i).threshold];

         else rec=[-80 model(i).threshold 160 80-model(i).threshold];

         end

     end

     rec=round(rec);

     y=rec(1)+81:rec(1)+81+rec(3); x=rec(2)+81:rec(2)+81+rec(4);

     I=I-model(i).alpha; I(x,y)=I(x,y)+2*model(i).alpha;    

 end

subplot(2,2,2), imshow(I,[]); colorbar; axis xy;

colormap('jet'), hold on

plot(blue(:,1)+81,blue(:,2)+81,'bo');

plot(red(:,1)+81,red(:,2)+81,'ro');

title('Training Data classified with adaboost model');


% Show the error verus number of weak classifiers

error=zeros(1,length(model)); for i=1:length(model), error(i)=model(i).error; end

subplot(2,2,3), plot(error); title('Classification error versus number of weak classifiers');


% Make some test data

 angle=rand(200,1)*2*pi; l=rand(200,1)*70; testdata=[sin(angle).*l cos(angle).*l];


% Classify the testdata with the trained model

 testclass=adaboost('apply',testdata,model);


% Show result

 blue=testdata(testclass==-1,:); red=testdata(testclass==1,:);


% Show the data

 subplot(2,2,4), hold on

 plot(blue(:,1),blue(:,2),'b*');

 plot(red(:,1),red(:,2),'r*');

 axis equal;

 title('Test Data classified with adaboost model');

⛄ 运行结果

⛄ 参考文献

[1] 董庆伟. 基于Adaboost算法的不平衡数据集分类效果研究[J]. 长春师范大学学报, 2022, 41(6):4.

[2] 黄道, 何晋, 刘志愿,等. 分类算法adaboostM1和multiboostAB对草药数据分类的比较[J]. 中国新通信, 2014, 16(6):1.

[3] 胡燕祝, 王松. 一种基于AdaBoost算法的感知器网络数据分类方法:, CN109726767A[P]. 2019.

⛳️ 完整代码

❤️部分理论引用网络文献,若有侵权联系博主删除
❤️ 关注我领取海量matlab电子书和数学建模资料



相关文章
|
2月前
|
算法
【MATLAB】语音信号识别与处理:一维信号NLM非局部均值滤波算法去噪及谱相减算法呈现频谱
【MATLAB】语音信号识别与处理:一维信号NLM非局部均值滤波算法去噪及谱相减算法呈现频谱
40 1
|
4天前
|
SQL 移动开发 算法
MATLAB改进模糊C均值聚类FCM在电子商务信用评价应用:分析淘宝网店铺数据|数据分享
MATLAB改进模糊C均值聚类FCM在电子商务信用评价应用:分析淘宝网店铺数据|数据分享
10 1
|
5天前
|
机器学习/深度学习 数据可视化
Matlab决策树对空气质量和天气温度及天气数据做交通出行推荐预测|数据分享
Matlab决策树对空气质量和天气温度及天气数据做交通出行推荐预测|数据分享
12 0
|
5天前
|
数据挖掘 数据库
数据分享|MATLAB、R基于Copula方法和k-means聚类的股票选择研究上证A股数据
数据分享|MATLAB、R基于Copula方法和k-means聚类的股票选择研究上证A股数据
10 0
|
5天前
|
计算机视觉
MATLAB偏最小二乘回归(PLSR)和主成分回归(PCR)分析光谱数据
MATLAB偏最小二乘回归(PLSR)和主成分回归(PCR)分析光谱数据
13 0
|
7天前
|
数据采集 算法 数据可视化
MATLAB、R用改进Fuzzy C-means模糊C均值聚类算法的微博用户特征调研数据聚类研究
MATLAB、R用改进Fuzzy C-means模糊C均值聚类算法的微博用户特征调研数据聚类研究
14 1
|
11天前
|
机器学习/深度学习 传感器 数据可视化
MATLAB用深度学习长短期记忆 (LSTM) 神经网络对智能手机传感器时间序列数据进行分类
MATLAB用深度学习长短期记忆 (LSTM) 神经网络对智能手机传感器时间序列数据进行分类
25 1
MATLAB用深度学习长短期记忆 (LSTM) 神经网络对智能手机传感器时间序列数据进行分类
|
16天前
|
传感器 存储 数据可视化
matlab数据可视化交通流量分析天气条件、共享单车时间序列数据
matlab数据可视化交通流量分析天气条件、共享单车时间序列数据
35 5
|
16天前
|
机器学习/深度学习 存储 资源调度
matlab用马尔可夫链蒙特卡罗 (MCMC) 的Logistic逻辑回归模型分析汽车实验数据
matlab用马尔可夫链蒙特卡罗 (MCMC) 的Logistic逻辑回归模型分析汽车实验数据
30 6
|
16天前
|
机器学习/深度学习 数据采集 并行计算
Matlab用深度学习长短期记忆(LSTM)神经网络对文本数据进行分类
Matlab用深度学习长短期记忆(LSTM)神经网络对文本数据进行分类
18 0

热门文章

最新文章