from __future__ import annotations

from typing import TYPE_CHECKING, Any, Dict

from inferno import bnn

if TYPE_CHECKING:
    from lightning import LightningModule


def _nn_hyperparameters(
    lightning_module: LightningModule,
    architecture: str,
    out_size: int,
    lr: float,
    momentum: float,
    nesterov: bool,
    weight_decay: float,
    max_epochs: int,
    scale_mean_input_init_weight: float,
    scale_mean_input_init_bias: float,
    scale_mean_input_lr_weight: float,
    scale_mean_input_lr_bias: float,
    scale_mean_input_forward_weight: float,
    scale_mean_input_forward_bias: float,
    scale_mean_output_init_weight: float,
    scale_mean_output_init_bias: float,
    scale_mean_output_lr_weight: float,
    scale_mean_output_lr_bias: float,
    scale_mean_output_forward_weight: float,
    scale_mean_output_forward_bias: float,
    optimizer: str = "SGD",
) -> Dict[str, Any]:
    """Common hyperparameters for neural network models."""
    return {
        "model": lightning_module.__class__.__name__,
        "inference_method": "None",
        "architecture": architecture,
        "out_size": out_size,
        "num_trainable_parameters": sum(
            p.numel() for p in lightning_module.model.parameters() if p.requires_grad
        ),
        "num_parameters_and_buffers": sum(
            p.numel() for p in lightning_module.model.parameters()
        )
        + sum(b.numel() for b in lightning_module.model.buffers()),
        "parametrization": (
            lightning_module.model.parametrization.__class__.__name__
            if hasattr(lightning_module.model, "parametrization")
            else bnn.params.Standard.__name__
        ),
        "optimizer": optimizer,
        "lr": lr,
        "momentum": momentum,
        "nesterov": nesterov,
        "weight_decay": weight_decay,
        "max_epochs": max_epochs,
        "scale_mean_input_init_weight": scale_mean_input_init_weight,
        "scale_mean_input_init_bias": scale_mean_input_init_bias,
        "scale_mean_input_lr_weight": scale_mean_input_lr_weight,
        "scale_mean_input_lr_bias": scale_mean_input_lr_bias,
        "scale_mean_input_forward_weight": scale_mean_input_forward_weight,
        "scale_mean_input_forward_bias": scale_mean_input_forward_bias,
        "scale_mean_output_init_weight": scale_mean_output_init_weight,
        "scale_mean_output_init_bias": scale_mean_output_init_bias,
        "scale_mean_output_lr_weight": scale_mean_output_lr_weight,
        "scale_mean_output_lr_bias": scale_mean_output_lr_bias,
        "scale_mean_output_forward_weight": scale_mean_output_forward_weight,
        "scale_mean_output_forward_bias": scale_mean_output_forward_bias,
        "scale_cov_input_init_weight": 0.0,
        "scale_cov_input_init_bias": 0.0,
        "scale_cov_input_lr_weight": 0.0,
        "scale_cov_input_lr_bias": 0.0,
        "scale_cov_input_forward_weight": 0.0,
        "scale_cov_input_forward_bias": 0.0,
        "scale_cov_output_init_weight": 0.0,
        "scale_cov_output_init_bias": 0.0,
        "scale_cov_output_lr_weight": 0.0,
        "scale_cov_output_lr_bias": 0.0,
        "scale_cov_output_forward_weight": 0.0,
        "scale_cov_output_forward_bias": 0.0,
    }
