Spaces:
Running
Running
import torch | |
import torch.nn as nn | |
import torch.nn.functional as F | |
class ClassifierModel(nn.Module): | |
def __init__(self, num_classes): | |
super(ClassifierModel, self).__init__() | |
# Apply adaptive average pooling to convert (512, 14, 14) to (512) | |
self.adaptive_pool = nn.AdaptiveAvgPool2d((1, 1)) | |
# Define multiple fully connected layers | |
self.fc1 = nn.Linear(512, 256) # First FC layer, reducing to 256 features | |
self.fc2 = nn.Linear(256, 128) # Second FC layer, reducing to 128 features | |
self.fc3 = nn.Linear(128, num_classes) # Final FC layer, outputting num_classes for classification | |
#dropout for regularization | |
self.dropout = nn.Dropout(0.2) | |
def forward(self, x): | |
# Flatten the output from the adaptive pooling | |
x = self.adaptive_pool(x) | |
x = torch.flatten(x, 1) | |
# Pass through the fully connected layers with ReLU activations and dropout | |
x = F.relu(self.fc1(x)) | |
x = self.dropout(x) | |
x = F.relu(self.fc2(x)) | |
x = self.dropout(x) | |
x = self.fc3(x) # No activation, raw scores | |
x = F.softmax(x, dim=1) | |
return x |