python线性回归算法

小小编辑 1年前 ⋅ 175 阅读

线性回归是一种用于建立和预测连续数值的机器学习算法。它通过找到一个最佳拟合直线(或超平面)来建立输入特征和目标值之间的线性关系。在Python中,你可以使用NumPy和Scikit-learn库来实现线性回归。

以下是使用Python进行简单线性回归的示例:

首先,确保你已经安装了所需的库。在Python中,你可以使用NumPy和Scikit-learn来实现线性回归。

pip install numpy
pip install scikit-learn

接下来,使用下面的示例代码来实现线性回归:

import numpy as np
import matplotlib.pyplot as plt
from sklearn.model_selection import train_test_split
from sklearn.linear_model import LinearRegression
from sklearn.metrics import mean_squared_error

# 生成随机数据集
np.random.seed(0)
X = np.random.rand(100, 1) * 10
y = 2 * X + 1 + np.random.randn(100, 1)

# 将数据集划分为训练集和测试集
X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.2, random_state=42)

# 创建线性回归模型
model = LinearRegression()

# 在训练集上训练模型
model.fit(X_train, y_train)

# 在测试集上进行预测
y_pred = model.predict(X_test)

# 计算均方误差
mse = mean_squared_error(y_test, y_pred)
print("Mean Squared Error:", mse)

# 绘制训练数据和拟合直线
plt.scatter(X_train, y_train, color='blue', label='Training Data')
plt.scatter(X_test, y_test, color='green', label='Test Data')
plt.plot(X_test, y_pred, color='red', linewidth=3, label='Fitted Line')
plt.xlabel('X')
plt.ylabel('y')
plt.legend()
plt.show()

在这个示例中,我们首先生成一个随机的一维数据集,并根据线性关系生成对应的目标值。然后,将数据集划分为训练集和测试集。接着,使用LinearRegression类创建线性回归模型,并在训练集上训练模型。最后,使用测试集进行预测,并计算均方误差来评估模型的性能。

运行代码后,你会看到绘制的散点图,其中蓝色点表示训练数据,绿色点表示测试数据,红色线表示拟合的直线。

这只是线性回归的一个简单示例,实际应用中可能需要对数据进行更多的预处理和特征工程,并进行调参等操作来提高模型性能。但这个示例可以帮助你了解线性回归在Python中的基本用法。