import torch
import numpy as np
import random

def _log1mexp(x: torch.Tensor) -> torch.Tensor:
    # x <= 0  -> log(1 - exp(x))
    x = torch.minimum(x, torch.zeros((), dtype=x.dtype, device=x.device))
    x = torch.clamp(x, max=-1e-12)  # evita exp(x)=1
    LOG_HALF = torch.log(torch.tensor(0.5, dtype=x.dtype, device=x.device))
    out = torch.empty_like(x)
    m = x < LOG_HALF
    out[m]  = torch.log1p(-torch.exp(x[m]))
    out[~m] = torch.log((-torch.expm1(x[~m])).clamp_min(torch.finfo(x.dtype).tiny))
    return out

def set_seed(seed: int = 42):
    random.seed(seed)
    np.random.seed(seed)
    torch.manual_seed(seed)
    if torch.cuda.is_available():
        torch.cuda.manual_seed(seed)
        torch.cuda.manual_seed_all(seed)
    torch.backends.cudnn.deterministic = True
    torch.backends.cudnn.benchmark = False
    torch.use_deterministic_algorithms(True, warn_only=True)