一元线性回归方法预测鸢尾花

使用线性回归模型对鸢尾花数据集中的特征进行预测的示例。

  1. 载入数据:使用`load_iris()`函数从sklearn.datasets库中导入鸢尾花数据集,并将数据保存为Pandas DataFrame格式。

  2. 数据处理:提取出特征列"petal-length"和"petal-width"作为自变量(x)和因变量(y),并对它们进行归一化操作。

  3. 载入模型:使用`LinearRegression()`函数创建一个线性回归模型,并使用`fit()`函数对模型进行训练,拟合出最佳的回归线。

  4. 预测及结果可视化:使用训练好的模型对自变量x进行预测,将真实值与预测值分别以散点图和线条的形式绘制在图形窗口中,并使用黄色线条连接真实值与对应的预测值。

  5. 输出系数和截距:输出线性回归模型的系数和截距,即回归线的斜率和截距。

  6. 预测:使用训练好的模型对指定长度为3.3的花进行预测,输出预测值。

这个项目可以帮助理解线性回归模型的使用和预测过程,并通过可视化展示模型的拟合效果。在这个示例中,通过花瓣长度预测花瓣宽度,同时展示了真实值、预测值和回归线的关系。

代码展示

python 复制代码
import pandas as pd
import matplotlib.pyplot as plt
from sklearn.datasets import load_iris
from sklearn.linear_model import LinearRegression
# 鸢尾花数据集。这个数据集包含了三种不同类型的鸢尾花(山鸢尾、变色鸢尾和维吉尼亚鸢尾),
# 每种鸢尾花有四个特征(萼片长度、萼片宽度、花瓣长度和花瓣宽度)。


#1.载入数据
iris = load_iris() #导入数据集
#将数据保存为excel数据格式
# iris_data = iris.data
# # 构建Pandas DataFrame
# df = pd.DataFrame(data=iris_data, columns=iris.feature_names)
# df.to_excel('iris.xlsx', index=False)


# 2.数据处理
data = pd.DataFrame(iris.data)
data.columns = ['sepal-length','sepal-width','petal-length','petal-width']#分别添加萼片长度、萼片宽度、花瓣长度和花瓣宽度为列名
x = data['petal-length'].values #x为自变量,y为因变量
y = data['petal-width'].values
x = x.reshape(len(x),1)#归一化操作
y = y.reshape(len(y),1)#归一化操作

# 2.载入模型
clf = LinearRegression()
clf.fit(x,y)#用于训练线性回归模型,其中X是自变量的输入数据,y是因变量的目标值。模型会根据提供的数据拟合出最佳的回归线。相当于训练模型的操作.

# 3.使用pre保存所有预测的结果
pre = clf.predict(x)#使用训练好的模型对输入数据x进行预测。预测结果会保存在变量pre中,它是根据模型和输入数据计算出的因变量的预测值。


# 4.使用散点图表示真实值与预测值以及使用模型训练得到的一元曲线clf
plt.scatter(x,y,s=50) #使用三点图来表示
plt.plot(x,pre,'r-',linewidth=2) #表示绘制一个红色线条('r-'),线条的宽度为2个单位(linewidth=2)。其中,x对应于横坐标轴,pre对应于纵坐标轴。
plt.xlabel('petal-length')
plt.ylabel('petal-width')
for idx,m in enumerate(x):
    plt.plot([m,m], [y[idx],pre[idx]],'y-')#使用plt.plot()函数绘制一条从点(m, y[idx])到点(m, pre[idx])的黄色线条('y-'),表示真实值与对应的预测值之间的连接线。
plt.show()
print(u'系数',clf.coef_)
print(u'截距',clf.intercept_)

# 5.预测
#对长度为3.9的花,预测其花宽度
print("预测值为:",clf.predict([[3.3]]))
相关推荐
火柴盒zhang几秒前
websheet之 编辑器
开发语言·前端·javascript·编辑器·spreadsheet·websheet
景天科技苑8 分钟前
【Rust】Rust中的枚举与模式匹配,原理解析与应用实战
开发语言·后端·rust·match·enum·枚举与模式匹配·rust枚举与模式匹配
知来者逆9 分钟前
计算机视觉——速度与精度的完美结合的实时目标检测算法RF-DETR详解
图像处理·人工智能·深度学习·算法·目标检测·计算机视觉·rf-detr
阿让啊14 分钟前
C语言中操作字节的某一位
c语言·开发语言·数据结构·单片机·算法
এ᭄画画的北北14 分钟前
力扣-160.相交链表
算法·leetcode·链表
椰羊~王小美19 分钟前
LeetCode -- Flora -- edit 2025-04-25
java·开发语言
拾忆-eleven29 分钟前
C语言实战:用Pygame打造高难度水果消消乐游戏
c语言·python·pygame
一只可爱的小猴子35 分钟前
2022李宏毅老师机器学习课程笔记
人工智能·笔记·机器学习
孞㐑¥1 小时前
C++11介绍
开发语言·c++·经验分享·笔记
旦莫1 小时前
Python 教程:我们可以给 Python 文件起中文名吗?
开发语言·python