import torch.nn as nn
import torch.nn.functional as F

class SimpleMLP20(nn.Module):
    def __init__(self, n):
        super(SimpleMLP20, self).__init__()
        # Flatten the input tensor (n x n) to a 1D vector
        self.flatten = nn.Flatten()
        # Single Linear layer: input size is n*n, output size is n
        self.fc1 = nn.Linear(n * n, n)
        self.fc2 = nn.Linear(n, n)
        self.fc3 = nn.Linear(n, 1)
        
    def forward(self, x):
        # Flatten the input and pass through the linear layer
        x = self.flatten(x)
        x = self.fc1(x)

        #return x

        x = F.relu(x)
        #x = F.tanh(x)
        x = self.fc2(x)


        x = F.relu(x)
        x = self.fc3(x)
        # non-lin
        return F.relu(x).squeeze(1)
        #return F.tanh(x)