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

class SimpleMLP32(nn.Module):
    def __init__(self, n):
        super(SimpleMLP32, self).__init__()
        self.n = n
        # Flatten the input tensor (n x n x n) to a 1D vector
        self.flatten = nn.Flatten()
        # Single Linear layer: input size is n*n*n, output size is n
        self.fc1 = nn.Linear(n * n * n, n * n)
        self.fc2 = nn.Linear(n * n, n * n)
        self.fc3 = nn.Linear(n * n, n * n)
        
    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.tanh(x)
        x = self.fc2(x)
        x = F.tanh(x)
        x = self.fc3(x)
        x = F.tanh(x)

        x = x.view(-1, self.n, self.n)

        #x = self.fc2(x)
        return x

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