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

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

  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]]))
相关推荐
8Qi827 分钟前
LeetCode 516:最长回文子序列
算法·leetcode·职场和发展·动态规划
秋934 分钟前
Go语言(Golang)开发工程师全景解析:岗位职责·语言优势与使用场景·各城市薪资·发展前景·高考志愿填报(2026版)
开发语言·golang·高考
无风听海1 小时前
多租户系统中的 OIDC:Discovery 端点与联合登录的深度实践
后端·python·flask
CTA终结者1 小时前
期货量化主力换月程序怎么移仓:天勤 underlying_symbol 与任务切换
python·区块链
huangdong_1 小时前
1688商品图片采集技术解析:登录态处理与SKU图自动分类
开发语言
马士兵教育1 小时前
Java还有前景吗?Java+AI大模型学习路线及项目?
java·人工智能·python·学习·机器学习
youngerwang2 小时前
【从搬运工到协处理器:网卡芯片架构、算法、验证与边缘演进深度剖析】
网络·算法·架构·芯片
chase_my_dream2 小时前
C++ + SLAM 高频面试问题整理
开发语言·c++·面试
KaMeidebaby2 小时前
卡梅德生物技术快报|纯化重组蛋白实操详解
人工智能·python·tcp/ip·算法·机器学习
Cloud_Shy6182 小时前
解读《Effective Python 3rd Edition》:从练气到老魔(第五章 Item 30 - 32)
开发语言·人工智能·笔记·python·学习方法