#!/usr/bin/env python
# -*- coding: utf-8 -*-
"""Define a multilayer perceptron architecture tailored for regression tasks."""

import torch
from torch import nn


class MLPRegression(nn.Module):
    """Implement a one-hidden-layer MLP that produces continuous outputs.

    The network comprises a linear input mapping, a hidden layer, and an
    output projection suitable for scalar or low-dimensional regression.

    Attributes:
        layers: Sequential container encapsulating the network layers.
    """

    def __init__(self, input_dim: int, hidden_dim: int, output_dim: int):
        """Initializes the MLPRegression model.

        Args:
            input_dim: The dimension of the input features.
            hidden_dim: The number of neurons in the hidden layer.
            output_dim: The dimension of the output (typically 1 for regression).
        """
        super().__init__()
        self.layers = nn.Sequential(
            nn.Linear(input_dim, hidden_dim),
            # Note: A non-linear activation like nn.ReLU() could be added here
            # depending on the complexity of the regression task.
            nn.Linear(hidden_dim, output_dim),
        )

    def forward(self, x: torch.Tensor) -> torch.Tensor:
        """Execute the forward pass after flattening the input tensor."""
        # Flatten the input tensor to a 2D shape [batch_size, num_features]
        x = x.view(x.size(0), -1)
        return self.layers(x)
