Python糖尿病人预测是否患癌症_diabetes_x[:-20]-程序员宅基地

技术标签: 机器学习  Python  

Python糖尿病人预测是否患癌症

统计回归分析的任务,就在于根据x1.x2,x3...xp线性回归和Y的观察值,去估计函数f,寻求变量之间近似的函数关系。

我们常用的是,假定f函数的数学形式已知,其中若干个参数未知的观察值去估计未知的参数值。这叫“参数回归”。其中应用最广泛的是f为线性函数的假设:这种情况叫“线性回归”。

自变量只有一个时,叫一元线性回归:

自变量有多个时,叫做端元线性回归。

分类(Classification)与回归(Regression)都属于监督学习,他们的区别在于:

分类:用于预测有限的离散值,如是否得了癌症(0,1),或手写数字的判断,是0,1,2,3,4,5,6,7,8还是9等。分类中,预测的可能的结果是有限的,且提前给定的。

回归:用于预测实数值,如给定了房子的面积,地段和房间数,预测房子的价格。

 

LinearRegression模型在Sklearn.linear_model下,它主要通过fit(x,y),的方法来训练模型,其中x为数据的属性,y为所属类型。

sklearn中引用回归模型的代码如下:

输出的函数原型如下所示:

fit(x,y): 训练。分析模型参数,填充数据集。其中x为特征,y为标记或类属性。

Predict():预测。它通过fit()算出的模型参数构成的模型,对解释变量进行预测其类属性。预测方法将返回预测值y_pred。

(以下我们用的数据都是再sklearn下载的)

import matplotlib.pyplot as plt
import numpy as np
from sklearn import datasets, linear_model
# 从sklearn的datasets中导入数据
diabetes = datasets.load_diabetes()
# 只用到数据集的一种特征
diabetes_x = diabetes.data[:, np.newaxis, 2]
# print(diabetes_x[0:10,])
# 将数据分成训练和测试集
diabetes_x_train = diabetes_x[:-20]     #训练标记
diabetes_x_test = diabetes_x[-20:]      #测试样本为后20行

#将标签分成测试和训练集
diabetes_y_train = diabetes.target[:-20]        #训练样本
diabetes_y_test = diabetes.target[-20:]         #预测对比标记

#回归训练及预测
regr = linear_model.LinearRegression()
regr.fit(diabetes_x_train,diabetes_y_train)
# coefficients
print('coefficients = %f\n'%float(regr.coef_))
# 均方误差(残差)
print('Residual sum of squares:%.2f'%np.mean((regr.predict(diabetes_x_test)-diabetes_y_test)**2))
# 编译指数,为1时最优
print('variance score:.2f'%regr.score(diabetes_x_test,diabetes_y_test))
# 输出图
plt.title(u'LinearRegression Diabetes')     #标题
plt.xlabel(u'Attributes')                   #X轴坐标
plt.ylabel(u'Measure of disease')           #Y轴坐标
# 点的准确位置
plt.scatter(diabetes_x_test,diabetes_y_test,color='r')
plt.plot(diabetes_x_test,regr.predict(diabetes_x_test),color='green',linewidth=3)
plt.show()

下面是对上述代码的优化,增加了斜率、截距的计算,同时增加了点图到线性方程的距离,保存图片设hi像素。

from sklearn import datasets
import numpy as np
d = datasets.load_diabetes()
x = d.data
print('获取x特征')
print(len(x),x.shape)
print(x[:4])
# 获取一个特征 第3列数据
x_one = x[:, np.newaxis, 2]
print(x_one[:4])
# 获取的正确结果
y = d.target
print('获取的结果')
print(y[:4])
# x特征划分
x_train = x_one[:-42]
x_test = x_one[-42: ]
print(len(x_train), len(x_test))
y_train = y[:-42]
y_test = y[-42:]
print(len(y_train),len(y_test))

# 线性回归实现
from sklearn import linear_model
clf = linear_model.LinearRegression()
print(clf)
clf.fit(x_train, y_train)
pre = clf.predict(x_test)
print('预测结果')
print(pre)
print('真实结果')
print(y_test)
# 第三步 评价结果
cost = np.mean(y_test-pre)**2
print('次方',2**5)
print('平方和计算:',cost)
print('系数',clf.coef_)
print('截距',clf.intercept_)
print('方差',clf.score(x_test,y_test))

# 第四步 绘图
import matplotlib.pyplot as plt
plt.title('diabetes')
plt.xlabel('x')
plt.ylabel('y')
plt.plot(x_test,y_test,'k.')
plt.plot(x_test,pre,'g-')
for idx, m in enumerate(x_test):
    plt.plot([m, m],[y_test[idx],pre[idx]],'r-')
plt.savefig('power.png',dpi=300)
plt.show()

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/Z__XY_/article/details/85039443

智能推荐

Linux环境 docker启动redis命令_linux docker 重启 redis-程序员宅基地

文章浏览阅读1.1k次。docker启动redis命令_linux docker 重启 redis

【总结】插头DP-bzoj1210/2310/2331/2595_dp插头模型-程序员宅基地

文章浏览阅读325次。插头DP小结_dp插头模型

关于测试工作效率低的一些思考和改进方法_测试人员不足与改进-程序员宅基地

文章浏览阅读3.5k次。关于测试工作效率低的一些思考和改进方法引子  汇总统计了一下项目组近期测试项目实际工作量与基线工作量的对比,发现一个严重问题。就是工作效率特别低下。下面简单列举一下几个项目预期工作量和实际工作量以及时间耗费严重的地方、项目简要背景。  1、B版本测试。版本预期工作量15人天,实际耗费工作量在30人天。更为严重的是测试人员并没有因为测试周期延长和工作量投入加大而测试的更轻松,反而是测试期..._测试人员不足与改进

级联样式表_级联样式表| 第三部分-程序员宅基地

文章浏览阅读173次。级联样式表 CSS-难以成熟 (CSS — Difficult to maturation)Unlike software, the CSS specifications are developed by successive versions, which would allow a browser to refer to a particular version. CSS was devel..._级联样式表是哪年产生的

sql server学习笔记——批处理语句、存储过程_sql的批处理-程序员宅基地

文章浏览阅读1.7k次。目录批处理语句1、批处理语句简介示例一:示例二:存储过程一、什么是存储过程1、存储过程的简介2、存储过程包含的内容3、存储过程的优点4、存储过程的分类系统存储过程:用户定义存储过程5、常用的系统储存过程(1)一般常用的存储过程(2)xp_cmdshell二、创建存储过程1、定义存储过程的语法2、不带参数的存储过程3、带参数..._sql的批处理

css代码的定位及浮动

上次,我们解除了css的内外边距、鼠标悬停及其练习。现在我们学习css元素练习和定位。

随便推点

Flutter Widget显示隐藏_flutter判断控制是否被遮住-程序员宅基地

文章浏览阅读7.6k次。在Android中我们可以用visibility来控制控件的显示和隐藏,那在Flutter中我们怎么控制呢?其实,在Flutter中控制Widget显示和隐藏有3中方法:不过3种方法的核心思想都是根据变量的值去判断的,所以先定义一个变量:bool visible = true;变量的值可以在事件中去控制,比如: onPressed: () { setS..._flutter判断控制是否被遮住

求助生物源排放模型MEGAN_megan v2.04-程序员宅基地

文章浏览阅读673次。有没有师兄师姐有meganv2.04以上的版本小弟只有低版本的 需要高版本运行一下有偿!_megan v2.04

java/jsp/ssm网络文学网站【2024年毕设】-程序员宅基地

文章浏览阅读32次。springboot基于springboot的小型超市库存管理系统。springboot基于SpringBoot的校园失物招领系统。springboot基于springboot的残障人士社交平台。springboot基于springboot的酒店管理系统。springboot基于springboot的电商购物系统。springboot基于微信小程序的Sunmoon口红商城。springboot基于云平台的便民物流速递信息管理系统。springboot基于微服务的固定资产管理系统。

还在用PPT做组织架构图?公司都在用的架构图软件是什么?_书本里印刷的结构图是用什么软件做的-程序员宅基地

文章浏览阅读3.1k次。还在用PPT、Word和Excel画企业组织结构图吗?对于人力资源的同事来说,画组织结构图是一键非常头疼的事情,尤其是对于一些大公司和人员变动较大的公司来说,需要经常更换组织结构图,每次变动都要耗费大量的时间和精力去重新绘图。其实绘制织结构图很简单,之所以难是因为没有找对工具和方法!今天小编就教你如何用亿图图示轻松绘制一个既美观又专业的组织结构图!下图是一个简单的组织结构图例子,小编就以此为例,详细讲解一下好看清晰、实用的公司组织结构图是怎么画出来的。1、新建组织结构图2、创建组织结构_书本里印刷的结构图是用什么软件做的

ESP32-C3 BLE5.0 扩展蓝牙名称长度的流程_蓝牙广播名称过长-程序员宅基地

文章浏览阅读1.8k次,点赞4次,收藏5次。BLE5.0 扩展蓝牙名称长度_蓝牙广播名称过长

centos8安装NVIDIA显卡驱动,docker模式运行机器学习_centos8安装显卡驱动-程序员宅基地

文章浏览阅读3.5k次。centos8安装NVIDIA显卡驱动,docker模式运行机器学习_centos8安装显卡驱动

推荐文章

热门文章

相关标签