利用鸢尾花数据集完成一个简单的机器学习应用~万丈高楼平地起,虽然很基础,但是还是跟着书敲了一遍代码。

一、模型构建流程

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将数据进行可视化一下,进行观察各个特征之间的关系,

      在此之前先划分一下训练集和测试集
#划分训练集,测试集
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

最新文章

  1. [SQL] SQL 基础知识梳理(一)- 数据库与 SQL
  2. 11.Configure Many-to-Many(配置多对多关系)【Code-First系列】
  3. Android自定义控件7--自定义开关--绘制界面内容
  4. IOS 7 风格Checkbox
  5. 全新的跨平台app软件开发工具——Lae软件开发平台
  6. android事件分发笔记
  7. VS2008下编译BOOST 1.39的ASIO库
  8. h3c dhcp snooping
  9. 怎样让一个div高度自适应浏览器高度
  10. 用于浏览器桌面通知的Web API 接口 -notification
  11. Python的IO编程
  12. laravel 关联查询
  13. (效率低下)77. Combinations C++回溯法 组合
  14. uoj#272. 【清华集训2016】石家庄的工人阶级队伍比较坚强
  15. WPF样式(Style)入门
  16. 微信小程序 功能函数 购物车商品删除
  17. 20155216 2016-2017-2 《Java程序设计》第九周学习总结
  18. TPO 02 - The Origins of Cetaceans
  19. java----EL表达式
  20. iOS内存管理(objective-c)

热门文章

  1. 国际化相对时间格式化API:Intl.RelativeTimeFormat
  2. Web 开发中 Blob 与 FileAPI 使用简述
  3. link和@import的区别浅析
  4. mixin和composition api
  5. 《头号玩家》AI电影调研报告(四)
  6. 基于Debian搭建Hyperledger Fabric 2.4开发环境及运行简单案例
  7. 从实例学习 Go 语言、"并发内容" 学习笔记及心得体会、Go指南
  8. Python打印表格
  9. JavaWeb和WebGIS学习笔记(六)——使用ArcGIS for Server发布地图服务
  10. 【题解】金牌导航-高斯消元/Luogu P3232 游走