当前位置: 首页 > news >正文

打卡Day55

作业:手动构造类似的数据集(如cosx数据),观察不同的机器学习模型的差异

模型比较

1. 线性回归

from sklearn.linear_model import LinearRegression
from sklearn.metrics import mean_squared_error# 线性回归
lr = LinearRegression()
lr.fit(X_train, y_train)
y_pred = lr.predict(X_test)
mse = mean_squared_error(y_test, y_pred)
print(f"Linear Regression MSE: {mse:.4f}")

2. 随机森林

from sklearn.ensemble import RandomForestRegressorrf = RandomForestRegressor(n_estimators=100, random_state=42)
rf.fit(X_train, y_train)
y_pred = rf.predict(X_test)
mse = mean_squared_error(y_test, y_pred)
print(f"Random Forest MSE: {mse:.4f}")

3. 支持向量回归(SVR)

from sklearn.svm import SVR
from sklearn.preprocessing import StandardScaler# 标准化数据
scaler = StandardScaler()
X_train_scaled = scaler.fit_transform(X_train)
X_test_scaled = scaler.transform(X_test)svr = SVR(kernel='rbf', C=100, gamma=0.1, epsilon=0.1)
svr.fit(X_train_scaled, y_train)
y_pred = svr.predict(X_test_scaled)
mse = mean_squared_error(y_test, y_pred)
print(f"SVR MSE: {mse:.4f}")

4. 简单RNN

from tensorflow.keras.models import Sequential
from tensorflow.keras.layers import SimpleRNN, Dense# 重塑数据为RNN需要的形状 [样本数, 时间步数, 特征数]
X_train_rnn = X_train.reshape((X_train.shape[0], X_train.shape[1], 1))
X_test_rnn = X_test.reshape((X_test.shape[0], X_test.shape[1], 1))# 构建RNN模型
model = Sequential([SimpleRNN(50, activation='tanh', input_shape=(X_train_rnn.shape[1], 1)),Dense(1)
])
model.compile(optimizer='adam', loss='mse')# 训练模型
history = model.fit(X_train_rnn, y_train, epochs=50, batch_size=32, validation_data=(X_test_rnn, y_test), verbose=0)y_pred = model.predict(X_test_rnn)
mse = mean_squared_error(y_test, y_pred)
print(f"Simple RNN MSE: {mse:.4f}")

5. LSTM

from tensorflow.keras.layers import LSTM# 构建LSTM模型
model = Sequential([LSTM(50, activation='tanh', input_shape=(X_train_rnn.shape[1], 1)),Dense(1)
])
model.compile(optimizer='adam', loss='mse')# 训练模型
history = model.fit(X_train_rnn, y_train, epochs=50, batch_size=32, validation_data=(X_test_rnn, y_test), verbose=0)y_pred = model.predict(X_test_rnn)
mse = mean_squared_error(y_test, y_pred)
print(f"LSTM MSE: {mse:.4f}")

可视化比较

import matplotlib.pyplot as plt# 绘制预测结果对比
plt.figure(figsize=(12, 6))
plt.plot(y_test[:100], label='True')
plt.plot(lr.predict(X_test)[:100], label='Linear Regression')
plt.plot(rf.predict(X_test)[:100], label='Random Forest')
plt.plot(svr.predict(X_test_scaled)[:100], label='SVR')
plt.plot(model.predict(X_test_rnn)[:100], label='LSTM')
plt.legend()
plt.title('Comparison of Model Predictions')
plt.show()

在这里插入图片描述

http://www.lryc.cn/news/572458.html

相关文章:

  • C++实现手写strlen函数
  • LeeCode2294划分数组使最大值为K
  • SQL分片工具类
  • C#上位机通过WebApi访问WinCC
  • 图像特征检测算法ORB
  • 目标检测之YOLOV11谈谈OBB
  • 基于Uniapp+PHP的教育培训系统开发指南:网校源码实战剖析
  • 【机械视觉】Halcon—【十五、一维码(条形码)和二维码识别】
  • SpringBoot扩展——发送邮件!
  • Java求职者面试指南:Spring, Spring Boot, Spring MVC, MyBatis技术点深度解析
  • Windows 10开始菜单优化方案,如何实现Win7风格开始菜单的还原
  • 火山引擎TTS使用体验
  • 类与对象(中)(详解)
  • 多卡解决报错torch.distributed.elastic.multiprocessing.errors.ChildFailedError的问题
  • API 接口:程序世界的通用语言与交互基因
  • 【音视频】PJSIP库——示例简介、C++类说明
  • 深度学习——激活函数
  • # python正则表达式——实战学习+理论
  • 跟踪大型语言模型的思想:对语言之间共享;提前规划;cot
  • RK3588调试之旅:adbd服务配置全攻略
  • stm32之使用中断控制led灯
  • 新生活的开启:从 Trae AI 离开后的三个月
  • linux操作命令(最常用)
  • 打破物理桎梏:CAN-ETH网关如何用UDP封装重构工业网络边界
  • 大模型更重要关注工艺
  • 目标检测之YOLOV11自定义数据使用OBB训练与验证
  • Neo4j常用语法-path
  • JS红宝书笔记 8.3 继承
  • 煤矿井下Modbus转Profibus网关的传感器与PLC互联解决方案
  • 机器学习×第十二卷:回归树与剪枝策略——她剪去多余的分支,只保留想靠近你的那一层