Spaces:
Sleeping
Sleeping
File size: 953 Bytes
d69185d | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 | import torch
import torch.nn as nn
class CardiovascularRNN(nn.Module):
def __init__(self, input_size, hidden_size, num_layers, num_classes):
super(CardiovascularRNN, self).__init__()
self.hidden_size = hidden_size
self.num_layers = num_layers
# RNN layer (using GRU for better performance over plain RNN)
self.gru = nn.GRU(input_size, hidden_size, num_layers, batch_first=True)
# Fully connected layer
self.fc = nn.Linear(hidden_size, num_classes)
def forward(self, x):
# Initialize hidden state
h0 = torch.zeros(self.num_layers, x.size(0), self.hidden_size).to(x.device)
# Forward propagate GRU
out, _ = self.gru(x, h0)
# Decode the hidden state of the last time step
out = out[:, -1, :]
# Output layer
out = self.fc(out)
return out
|