我要一个使用PyTorch框架的LSTM回归预测代码:特征变量为6,输出变量为1
时间: 2024-04-08 11:29:28 浏览: 69
当然,我可以为您提供一个使用PyTorch框架的LSTM回归预测代码。以下是一个示例代码:
```python
import torch
import torch.nn as nn
# 定义LSTM模型
class LSTMRegressor(nn.Module):
def __init__(self, input_size, hidden_size, output_size):
super(LSTMRegressor, self).__init__()
self.hidden_size = hidden_size
self.lstm = nn.LSTM(input_size, hidden_size, batch_first=True)
self.fc = nn.Linear(hidden_size, output_size)
def forward(self, x):
out, _ = self.lstm(x)
out = out[:, -1, :]
out = self.fc(out)
return out
# 定义输入和输出的维度
input_size = 6
output_size = 1
# 定义模型超参数
hidden_size = 64
learning_rate = 0.001
num_epochs = 100
# 创建模型实例
model = LSTMRegressor(input_size, hidden_size, output_size)
# 定义损失函数和优化器
criterion = nn.MSELoss()
optimizer = torch.optim.Adam(model.parameters(), lr=learning_rate)
# 创建输入数据和目标数据(示例数据)
input_data = torch.randn(100, 10, input_size) # (batch_size, sequence_length, input_size)
target_data = torch.randn(100, output_size) # (batch_size, output_size)
# 训练模型
for epoch in range(num_epochs):
# 前向传播
output = model(input_data)
loss = criterion(output, target_data)
# 反向传播和优化
optimizer.zero_grad()
loss.backward()
optimizer.step()
# 打印训练信息
if (epoch+1) % 10 == 0:
print(f'Epoch [{epoch+1}/{num_epochs}], Loss: {loss.item():.4f}')
# 使用模型进行预测
input_test = torch.randn(1, 10, input_size) # (batch_size, sequence_length, input_size)
output_test = model(input_test)
print(f'Prediction: {output_test.item()}')
```
这个代码定义了一个包含一个LSTM层和一个全连接层的模型,用于回归预测任务。您可以根据自己的数据和需求进行相应的修改和调整。
阅读全文