"""Utility functions for quantization."""

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

if torch.cuda.is_available():
    from fast_hadamard_transform import hadamard_transform


def hadamard_transform_adaptive(A, scale):
    """Apply Hadamard transform with automatic CPU/GPU handling."""
    if A.is_cuda:
        return hadamard_transform(A, scale=scale)
    else:
        return F.linear(A, torch.tensor(scipy.linalg.hadamard(A.shape[-1]), dtype=torch.float32)) * scale
