构建第一个模型:KNN算法(Iris_dataset)
2024-10-13 01:43:44
利用鸢尾花数据集完成一个简单的机器学习应用~万丈高楼平地起,虽然很基础,但是还是跟着书敲了一遍代码。
一、模型构建流程
1、获取数据
- 本次实验的Iris数据集来自skicit-learn的datasets模块
from sklearn.datasets import load_iris
iris_dataset = load_iris()
查看一下数据:
可以发现iris_dataset类似一个字典,里面包含键和值,其中键值对包括数据的简介(DESC)、标签值(target)、数据样本(data),标签名(target name)等
2、数据预处理
- 本次使用的数据无需预处理,已经处理好了,目标值也被表示为0,1,2的数字标签,data和target都是ndarray数组。
3、特征工程
- 本次数据还比较简单,特征也少,无需特征选择,
- 这里利用pandas的scatter.metrix将数据进行可视化一下,进行观察各个特征之间的关系,
在此之前先划分一下训练集和测试集
- 这里利用pandas的scatter.metrix将数据进行可视化一下,进行观察各个特征之间的关系,
#划分训练集,测试集
X_train,X_test,y_trian,y_test = train_test_split(irs_dataset['data'],irs_dataset['target'],random_state = 0)
#利用pd,画散点图,观察数据是否有异常值
irs_dataframe = pd.DataFrame(X_train,columns=irs_dataset.feature_names)
grr = pd.plotting.scatter_matrix(irs_dataframe,c=y_trian,figsize=(8,8),marker='o',
hist_kwds={'bins':20},s=60,alpha=.8)
4、(机器学习)构建模型
考虑到这个数据特点,这里使用KNN算法
KNN:在判断一个数据X的标签时,会计算距离它与其他所有样本x1,x2,x3,...,的距离,选择距离它最近的k个样本的标签值,作为该数据X的标签值。
#建立模型:KNN算法
knn = KNeighborsClassifier(n_neighbors=2) #把k值设为2
knn.fit(X_train, y_trian) #基于训练集构建模型,两个参数都是Numpy 数组
5、模型评估
怎么知道该模型在预测新数据时的有效性呢?有很多评估指标,比如说精确率、召回率...
这里使用精确率:正确预测列别的数据,占所有数据的比例
#评估模型
y_pred = knn.predict(X_test)
print(y_pred)
print("precision={:.2f}".format(np.mean(y_pred==y_test)))
print(knn.score(X_test, y_test))
二、遇到的问题
- 按照书上所写使用pandas的scatter.metrix画散点图做相关性分析时遇到’module ‘pandas’ has no attribute ‘scatter_matrix’'这个问题
解决方法:
现在的pandas的scatter_matrix用法已经发生变化了,在使用时需要加上plotting,即:pandas.plotting.scatter_matrix
三、参考文献
《python机器学习基础教程》--【德】Adreas C.Muller
最新文章
- [SQL] SQL 基础知识梳理(一)- 数据库与 SQL
- 11.Configure Many-to-Many(配置多对多关系)【Code-First系列】
- Android自定义控件7--自定义开关--绘制界面内容
- IOS 7 风格Checkbox
- 全新的跨平台app软件开发工具——Lae软件开发平台
- android事件分发笔记
- VS2008下编译BOOST 1.39的ASIO库
- h3c dhcp snooping
- 怎样让一个div高度自适应浏览器高度
- 用于浏览器桌面通知的Web API 接口 -notification
- Python的IO编程
- laravel 关联查询
- (效率低下)77. Combinations C++回溯法 组合
- uoj#272. 【清华集训2016】石家庄的工人阶级队伍比较坚强
- WPF样式(Style)入门
- 微信小程序 功能函数 购物车商品删除
- 20155216 2016-2017-2 《Java程序设计》第九周学习总结
- TPO 02 - The Origins of Cetaceans
- java----EL表达式
- iOS内存管理(objective-c)
热门文章
- 国际化相对时间格式化API:Intl.RelativeTimeFormat
- Web 开发中 Blob 与 FileAPI 使用简述
- link和@import的区别浅析
- mixin和composition api
- 《头号玩家》AI电影调研报告(四)
- 基于Debian搭建Hyperledger Fabric 2.4开发环境及运行简单案例
- 从实例学习 Go 语言、";并发内容"; 学习笔记及心得体会、Go指南
- Python打印表格
- JavaWeb和WebGIS学习笔记(六)——使用ArcGIS for Server发布地图服务
- 【题解】金牌导航-高斯消元/Luogu P3232 游走