【数据挖掘】基于随机森林回归模型的二手车价格预测分析(数据集+源码)

摘要

本研究运用随机森林回归模型对汽车价格进行预测。通过对包含多种汽车属性的数据集进行预处理,包括对分类变量的独热编码,将其划分为训练集与测试集。利用训练集数据拟合随机森林模型,并使用测试集数据进行预测与评估。同时,借助多种可视化手段深入分析模型性能与数据特征。

数据集:https://pan.quark.cn/s/20eb55d25902
数据源:https://www.kaggle.com/datasets/vrajesh0sharma7/used-car-price-prediction

关键词

随机森林回归;汽车价格预测;数据预处理;可视化分析

一、引言

在汽车市场研究领域,准确预测汽车价格对于消费者、经销商以及制造商都具有重要意义。随机森林回归模型作为一种强大的机器学习算法,能够有效处理复杂的非线性关系,在众多预测任务中表现出色。本研究旨在运用该模型对汽车价格进行精准预测,并通过详细的分析揭示各因素对价格的影响。

二、数据处理与模型构建

2.1 数据加载

研究伊始,从"split_file_1.csv"文件中加载数据集,该数据集涵盖了丰富的汽车相关信息,为后续分析提供了基础。

python 复制代码
import pandas as pd
df = pd.read_csv('split_file_1.csv')

2.2 数据预处理

为使数据适用于模型训练,对数据进行了必要的预处理。鉴于数据集中存在诸多分类变量,如汽车品牌(make)、型号(model)、变速器类型(transmission)等,采用独热编码的方式对这些分类变量进行转换。此操作将分类变量转换为数值形式,以便模型能够有效处理。

python 复制代码
categorical_cols = ['make','model', 'transmission', 'fuel_type', 'drivetrain', 'body_type', 'exterior_color', 'interior_color','seller_type', 'condition', 'trim', 'accident_history']
df_encoded = pd.get_dummies(df, columns=categorical_cols)

完成编码后,将数据集划分为特征矩阵X和目标变量y。特征矩阵X包含除价格(price)外的所有变量,而目标变量y即为汽车价格。

python 复制代码
X = df_encoded.drop(['price'], axis=1) 
y = df_encoded['price']

2.3 数据集划分

为评估模型性能,将数据集按比例划分为训练集和测试集。其中,测试集占比20%,训练集占比80%,并通过设置随机种子(random_state = 33)确保划分结果的可重复性。

python 复制代码
from sklearn.model_selection import train_test_split
X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.2, random_state=33)

2.4 模型定义与训练

选择随机森林回归模型作为预测工具,并设定决策树数量为100(n_estimators = 100),同时固定随机种子(random_state = 33)以保证模型训练的一致性。随后,使用训练集数据对模型进行训练。

python 复制代码
from sklearn.ensemble import RandomForestRegressor
rf_model = RandomForestRegressor(n_estimators=100, random_state=33)
rf_model.fit(X_train, y_train)

三、模型预测与评估

3.1 模型预测

利用训练好的随机森林模型对测试集数据进行预测,得到预测价格y_pred

python 复制代码
y_pred = rf_model.predict(X_test)

3.2 模型评估

为衡量模型的预测准确性,采用均方误差(MSE)、均方根误差(RMSE)和R²分数作为评估指标。均方误差反映了预测值与真实值之间误差的平方的平均值;均方根误差则是均方误差的平方根,其单位与目标变量相同,更直观地体现了误差的大小;R²分数用于评估模型对数据的拟合优度,取值范围在0到1之间,越接近1表示模型拟合效果越好。

python 复制代码
from sklearn.metrics import mean_squared_error, r2_score
import numpy as np
mse = mean_squared_error(y_test, y_pred)
rmse = np.sqrt(mse)
r2 = r2_score(y_test, y_pred)

print(f"均方误差 (MSE): {mse}")
print(f"均方根误差 (RMSE): {rmse}")
print(f"R² 分数: {r2}")

经计算,模型在本数据集上取得了一定的预测效果,具体指标数值为深入分析模型性能提供了依据。

四、可视化分析

4.1 实际价格与预测价格对比

绘制实际价格与预测价格的散点图,同时添加一条表示理想预测情况(预测值等于真实值)的对角线。该图直观展示了模型预测值与实际值的分布关系,若预测点紧密分布在对角线上方,则表明模型预测效果良好。

python 复制代码
import matplotlib.pyplot as plt
plt.figure(figsize=(10, 6))
plt.scatter(y_test, y_pred, alpha=0.5)
plt.plot([y.min(), y.max()], [y.min(), y.max()], 'k--', lw=2)
plt.xlabel('实际价格')
plt.ylabel('预测价格')
plt.title('实际价格 vs 预测价格')
plt.show()

4.2 残差分析

计算并绘制残差图,以预测价格为横坐标,残差(实际价格 - 预测价格)为纵坐标,并添加一条水平参考线(y = 0)。理想情况下,残差应随机分布在参考线周围,无明显规律。若残差呈现特定趋势,则可能暗示模型存在一定问题。

python 复制代码
residuals = y_test - y_pred
plt.figure(figsize=(10, 6))
plt.scatter(y_pred, residuals, alpha=0.5)
plt.axhline(y=0, color='r', linestyle='--')
plt.xlabel('预测价格')
plt.ylabel('残差')
plt.title('残差图')
plt.show()

4.3 特征重要性评估

通过分析随机森林模型中各特征的重要性,筛选出最重要的20个特征,并绘制特征重要性条形图。该图能够直观展示各特征对汽车价格预测的贡献程度,帮助我们理解哪些因素在价格决定中起着关键作用。

python 复制代码
importances = rf_model.feature_importances_
indices = np.argsort(importances)[-20:] 
plt.figure(figsize=(10, 8))
plt.title('随机森林特征重要性')
plt.barh(range(len(indices)), importances[indices], align='center')
plt.yticks(range(len(indices)), [X.columns[i] for i in indices])
plt.xlabel('特征重要性')
plt.show()

4.4 不同品牌价格分布

选取汽车品牌(make)作为分析对象,展示数量最多的10个品牌的汽车价格分布情况。通过箱线图,可以清晰观察到不同品牌汽车价格的中位数、四分位数以及异常值等信息,有助于深入了解各品牌在价格方面的差异。

python 复制代码
import seaborn as sns
plt.figure(figsize=(12, 6))
top_makes = df['make'].value_counts().nlargest(10).index 
sns.boxplot(data=df[df['make'].isin(top_makes)],
            x='make',
            y='price')
plt.xticks(rotation=45)
plt.title('不同品牌车型价格分布')
plt.xlabel('汽车品牌')
plt.ylabel('价格')
plt.show()

五、结论

本研究通过运用随机森林回归模型对汽车价格进行预测,并结合多种可视化分析手段,深入探讨了汽车价格与各属性之间的关系。模型评估指标表明,随机森林回归模型在本数据集上具有一定的预测能力。可视化分析不仅直观展示了模型的性能,还揭示了不同特征对汽车价格的影响程度以及不同品牌价格的分布特点。

相关推荐
qq_436962186 小时前
奥威BI:打破数据分析的桎梏,让决策更自由
人工智能·数据挖掘·数据分析
B站计算机毕业设计之家6 小时前
大数据python招聘数据分析预测系统 招聘数据平台 +爬虫+可视化 +django框架+vue框架 大数据技术✅
大数据·爬虫·python·机器学习·数据挖掘·数据分析
私域实战笔记1 天前
企业微信SCRM怎么选?工具适配与落地实操指南
人工智能·数据挖掘·企业微信·scrm·企业微信scrm
m0_748248021 天前
基于 C++ 的高性能批量媒体文件压缩程序
c++·人工智能·数据挖掘
OpenBayes1 天前
OCR 新范式!DeepSeek 以「视觉压缩」替代传统字符识别;Bald Classification数据集助力高精度人像分类
人工智能·深度学习·分类·数据挖掘·ocr·数据集·deepseek
汤姆yu1 天前
基于大数据的短视频流量数据分析与可视化
大数据·数据挖掘·数据分析
青云交1 天前
Java 大视界 --Java 大数据机器学习模型在金融风险压力测试中的应用与验证
java·随机森林·机器学习·lstm·压力测试·联邦学习·金融风险
R-G-B1 天前
【P27 回归算法及应用实践】有监督的机器学习、分类与回归、一元线性回归、最小二乘法、多元回归与梯度下降、学习率
人工智能·回归·最小二乘法·梯度下降·一元线性回归·有监督的机器学习·分类与回归
Dev7z1 天前
结合HOG特征与支持向量机(SVM)的车牌字符识别系统
人工智能·分类·数据挖掘
geneculture1 天前
官学商大跨界 · 产学研大综合:融智学新范式应用体系
大数据·人工智能·物联网·数据挖掘·哲学与科学统一性·信息融智学