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

2023-11-16

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()

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Python糖尿病人预测是否患癌症 的相关文章

随机推荐

  • CV01-语义分割笔记和两个模型VGG & ResNet的笔记

    目录 一 语义分割 二 VGG模型 2 1 VGG特征提取部分 2 2 VGG图像分类部分 三 ResNet模型 3 1 为什么是ResNet 3 2 1 1卷积调整channel维度大小 3 3 ResNet里的BottleNeck 3
  • Mac 使用终端彻底格式化U盘

    最近U盘不知道怎么回事中毒了 不管是格式化 还是使用DiskGenius删除分区格式化都不好使 火绒等杀毒软件也败下阵来 于是高人指点 在Mac 下 用 zero 彻底覆盖所有扇区 好用了 膜拜 学习 1 插入U盘 看当前是disk几 使用
  • Altium Designer使用-----芯片焊盘之间的距离规则设定(AD6.9)

    设计 规则 Clearance 新建新规则 PadToPad 第一对象 高级的 询问 询问构建者 条件类型 Object Kind is 条件值 Pad 确定 第二对象 高级的 询问 询问构建者 条件类型 Object Kind is 条件
  • 逻辑回归中的损失函数的解释

    1 Logistic Regression 逻辑回归 逻辑回归是机器学习中的一个非常常见的模型 逻辑回归模型其实仅在线性回归的基础上 套用了一个逻辑函数 逻辑回归可以看做是两步 第一步和线性回归模型的形式相同 即一个关于输入x的线性函数 第
  • java有趣的技术分享ppt_【干货分享】盘点2020年流行的五大Java技术

    Java作为编程语言的老大 在编程语言排行榜一直占据前三地位 受到众多编程爱好者的追捧 再加上Java语言在各个领域的开发应用和高于其他行业的薪资待遇 使它成为许多零基础学习者的首选编程语言 为了帮助更多Java初学者 下面小编就和大家分享
  • 挑战利用ChatGPT写代码,真的能成功吗?

    使用姿势 1 由于ChatGPT的注册门槛较高 国内很多网站都是付费的或者有各种限制 我在 多御浏览器 中使用 无需注册就能免费体验ChatGPT 2 使用ChatGPT4 我的问题有些口水文 但是它依然能懂 设计一个表 支持树形结构 可以
  • VR原理讲解及开发入门

    本文是作者obuil根据多年心得专门为想要入门的VR开发者所写 由52VR网站提供支持 1 VR沉浸感和交互作用产生的原理 在之前 我们观看一个虚拟的创造内容是通过平面显示器的 52VR上次发布过一篇文章 一张图让你认识VR 在其中 你会看
  • python 安装scrapy是报错 building 'twisted.test.raiser' extension error: Microsoft Visual C++ 14.0 is req

    问题描述 在win7下 python 3 7 3 64位 在windows下 在dos中运行pip install Scrapy报错 building twisted test raiser extension error Microsof
  • 集群服务器安装时间同步服务(chrony)

    摘要 服务器之间的时间需要同步 但并不是所有机器可以直接连外网 这时可以用Chrony工具解决 解决方法是将其中一台设为时间服务器 然后其它服务器和这台时间服务器同步即可 chrony是两个用来维持计算机系统时钟准确性的程序 这两个程序命名
  • 表单页面美化(html、css)

    表单页面美化 html css 效果图片 实现代码 html部分就是平常的输入框 div class mainfont h1 在线预约 h1 div div class form div
  • OSW

    OSWatcher 工具 下载文档 Metalink Doc ID 301137 1 Oswatcher 主要用于监控主机资源 如CPU 内存 网络以及私有网络等 其中私有网络需要单独配置 需要说明的执行OSWatcher用户需要常见OS
  • 密码学概述

    一 密码学的起源与发展 密码学英文名称为Cryptography 密码学最为一门学科 是最近几十年开始迅速被人们重视和发展起来的 密码学往往与信息安全四个字精密的联系着 最早的密码学的 始祖 可以说是早在公元前几百年就已经出现了 当然 当时
  • 使用JDWP远程debug

    JDWP JDWP是Java Debug Wire Protocol 的缩写 它 定义了调试器 debugger 和被调试的Java虚拟机 target vm 之间的通信协议 SpringBoot debug 1 springboot框架搭
  • detr复现

    https github com IDEA Research detrex 先跑通 相关原理和代码后续解读
  • springboot不同版本整合elasticsearch

    使用springboot整合elasticsearch时候 需要注意版本的对应关系 不然问题会非常多 对应关系如下 springboot2 1整合 elasticsearch的两个方式 通过spring data es springboot
  • Typora软件下载与安装及使用技巧(保姆式教学)

    Typora的下载安装 当前 Typora 是一款支持实时预览的 Markdown 文本编辑器 深受广大程序员的喜爱 简洁明了 方便操作 下面来讲一下它的详细下载安装过程叭 下载安装过程 Typora的下载官网 https typoraio
  • 微信小程序云开发上传图片无法预览显示

    这是图片无法预览显示的情况 而且文件格式显示也不显示为图片格式 不要忘记要在起完名字后加上你希望的图片格式后缀名 加完之后就可以正常显示了
  • Linux链接脚本lds概述

    一 概论 ld 用来把一定量的目标文件跟档案文件链接在一起 并重新定位它们的数据 链接符号引用 一般编译一个程序时 最后一步就是运行ld进行链接 每一个链接过程都由链接脚本 linker script 一般以lds作为文件的后缀名 控制 链
  • 说说你对Object.defineProperty()的理解

    代码在最后 定义 Object defineProperty 方法会直接在一个对象上定义一个新属性 或者修改一个对象的现有属性 并返回此对象 Object defineProperty obj prop descriptor obj 要定义
  • Python糖尿病人预测是否患癌症

    Python糖尿病人预测是否患癌症 统计回归分析的任务 就在于根据x1 x2 x3 xp线性回归和Y的观察值 去估计函数f 寻求变量之间近似的函数关系 我们常用的是 假定f函数的数学形式已知 其中若干个参数未知的观察值去估计未知的参数值 这