# Copyright (c) 2026 Anonymous
# All Rights Reserved
# This codebase is provided for peer review purposes only.

import torch
import torch.nn as nn
from config.config_template import ConfigTemplate


class LayerNorm(nn.Module):
    def __init__(self, config: ConfigTemplate):
        super().__init__()
        # Define attributes
        self.emb_size   = config.emb_size
        self.use_affine = config.norm_use_affine
        self.use_bias   = config.norm_use_bias
        self.eps        = config.norm_eps
        # Define layers
        if self.use_affine:
            self.weight = nn.Parameter(torch.ones(self.emb_size))
        else:
            self.weight = None
        if self.use_affine and self.use_bias:
            self.bias = nn.Parameter(torch.zeros(self.emb_size))
        else:
            self.bias = None

    @torch.compile()
    def forward(self, x):
        mean = x.mean(dim=-1, keepdim=True)
        var = x.var(dim=-1, keepdim=True, unbiased=False)
        x_norm = (x - mean) * torch.rsqrt(var + self.eps)
        if self.weight is not None:
            x_norm = x_norm * self.weight
        if self.bias is not None:
            x_norm = x_norm + self.bias
        return x_norm
