当前位置:   article > 正文

2024年第三届钉钉杯大学生大数据挑战赛B题第3问_钉钉杯b题数据处理

钉钉杯b题数据处理

赛题:

 问题3:

.结合上述两个模型,构建集成学习模型,针对康复医学科三病房,预测对应的门诊收入数据。已提供的三病房数据可作为集成学习模型微调训练的基础数据。

思路:

为了完成第三小问的任务,即构建集成学习模型来预测康复医学科三病房的门诊收入数据,我们将按照以下步骤进行:

  1. 数据预处理:清洗数据、填充缺失值、创建有用的特征。
  2. 探索性数据分析:可视化数据,理解数据分布和趋势。
  3. 模型构建:利用之前构建的两个模型(例如 ARIMA 和随机森林),并结合集成学习的方法来构建最终的预测模型。
  4. 模型训练与评估:使用训练数据训练模型,并在测试数据上评估模型性能。

解题思路

  1. 准备数据:从 Excel 文件中读取康复医学科三病房的相关数据。
  2. 特征工程:清洗数据、处理缺失值、创建有用的特征。
  3. 模型集成:使用之前构建的 ARIMA 和随机森林模型的结果作为输入,构建一个集成模型(例如使用 Stacking 方法)来预测康复医学科三病房的门诊收入。
  4. 模型训练与评估:使用训练数据训练集成模型,并在测试数据上评估模型性能。

代码:

  1. import pandas as pd
  2. import numpy as np
  3. import matplotlib.pyplot as plt
  4. from statsmodels.tsa.arima.model import ARIMA
  5. from sklearn.ensemble import RandomForestRegressor, StackingRegressor
  6. from sklearn.model_selection import train_test_split
  7. from sklearn.metrics import mean_squared_error
  8. from sklearn.preprocessing import StandardScaler
  9. # 1. 加载数据
  10. data = pd.read_excel('数据.xlsx')
  11. # 2. 数据预处理
  12. # 选择康复医学科三病房的数据
  13. ward_data = data[data['当日病房收入对应科室'] == '康复医学科三病房']
  14. # 填充缺失值
  15. ward_data.fillna(method='ffill', inplace=True)
  16. # 创建有用的特征
  17. ward_data['日期'] = pd.to_datetime(ward_data['日期'])
  18. ward_data['Month'] = ward_data['日期'].dt.month
  19. ward_data['DayOfWeek'] = ward_data['日期'].dt.dayofweek
  20. # 准备训练和测试数据
  21. X = ward_data[['门诊患者人次数', '药品总收入', '当日病房收入', 'Month', 'DayOfWeek']]
  22. y = ward_data['门诊收入OBS_T01_MZSR68']
  23. # 3. 探索性数据分析
  24. plt.figure(figsize=(14, 7))
  25. plt.plot(ward_data['日期'], ward_data['门诊收入OBS_T01_MZSR68'])
  26. plt.title('康复医学科三病房门诊收入随时间的变化')
  27. plt.xlabel('日期')
  28. plt.ylabel('门诊收入')
  29. plt.show()
  30. # 4. 模型构建
  31. # 4.1 ARIMA 模型
  32. # 选择 p, d, q 参数
  33. p = 1
  34. d = 1
  35. q = 1
  36. # 4.2 随机森林模型
  37. rf = RandomForestRegressor(n_estimators=100, random_state=42)
  38. # 5. 模型训练与评估
  39. # 划分训练集和测试集
  40. X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.2, random_state=42)
  41. # ARIMA 模型训练
  42. # 需要将时间序列数据转换为监督学习格式
  43. def series_to_supervised(data, n_in=1):
  44. df = pd.DataFrame(data)
  45. cols = list()
  46. for i in range(n_in, 0, -1):
  47. cols.append(df.shift(i))
  48. cols.append(df)
  49. agg = pd.concat(cols, axis=1)
  50. agg.dropna(inplace=True)
  51. return agg.values
  52. values = ward_data['门诊收入OBS_T01_MZSR68'].values
  53. supervised_data = series_to_supervised(values, 1)
  54. train = supervised_data[:int(len(supervised_data)*0.8)]
  55. test = supervised_data[int(len(supervised_data)*0.8):]
  56. history = [x for x in train]
  57. predictions = list()
  58. for t in range(len(test)):
  59. model = ARIMA(history, order=(p,d,q))
  60. model_fit = model.fit()
  61. output = model_fit.forecast()
  62. yhat = output[0]
  63. predictions.append(yhat)
  64. obs = test[t]
  65. history.append(obs)
  66. print('predicted=%f, expected=%f' % (yhat, obs))
  67. # 计算 MSE
  68. mse = mean_squared_error(test[:, 0], predictions)
  69. print('ARIMA Test MSE: %.3f' % mse)
  70. # 随机森林模型训练
  71. scaler = StandardScaler()
  72. X_train_scaled = scaler.fit_transform(X_train)
  73. X_test_scaled = scaler.transform(X_test)
  74. rf.fit(X_train_scaled, y_train)
  75. # 6. 集成学习模型
  76. # 使用 Stacking Regressor
  77. estimators = [
  78. ('arima', ARIMA(X_train_scaled, order=(p,d,q))),
  79. ('rf', rf)
  80. ]
  81. stacking_regressor = StackingRegressor(estimators=estimators, final_estimator=RandomForestRegressor(n_estimators=100, random_state=42))
  82. # 训练集成模型
  83. stacking_regressor.fit(X_train_scaled, y_train)
  84. # 7. 评估模型性能
  85. y_pred_arima = predictions
  86. y_pred_rf = rf.predict(X_test_scaled)
  87. y_pred_stacking = stacking_regressor.predict(X_test_scaled)
  88. # 计算 MSE
  89. mse_arima = mean_squared_error(y_test, y_pred_arima)
  90. mse_rf = mean_squared_error(y_test, y_pred_rf)
  91. mse_stacking = mean_squared_error(y_test, y_pred_stacking)
  92. print('ARIMA Test MSE: %.3f' % mse_arima)
  93. print('Random Forest Test MSE: %.3f' % mse_rf)
  94. print('Stacking Regressor Test MSE: %.3f' % mse_stacking)

说明

  1. 数据预处理:我们选择了康复医学科三病房的数据,并填充了缺失值。我们还创建了一些有用的特征,如月份和星期几。
  2. 探索性数据分析:我们绘制了一个趋势图来展示康复医学科三病房门诊收入随时间的变化。
  3. 模型构建:我们构建了 ARIMA 和随机森林模型,并使用 Stacking Regressor 方法将这两个模型集成起来。
  4. 模型训练与评估:我们使用了训练数据来训练模型,并在测试数据上评估了模型性能。
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/木道寻08/article/detail/966361
推荐阅读
相关标签
  

闽ICP备14008679号