import torch
# Matern eigenvalue function
def matern_eigs_2d(H, W, sigma0, rho0, nu0, device, dtype=torch.float32, Lx=1.0, Ly=1.0):
    """
    q_{mn} = sigma0^2 * (kappa^2 + lambda_{mn})^{-(nu0 + d/2)}, with d=2, where
    lambda_{mn} = (pi*m/Lx)^2 + (pi*n/Ly)^2   (Laplacian eigenvalues)

        Q: (H, W) tensor of nonnegative eigenvalues.
    """
    device = device or torch.device("cuda")

    kappa = 1.0 / rho0
    alpha = nu0 + 1.0  # nu + d/2, d=2

    m = torch.arange(H, device=device, dtype=dtype)
    n = torch.arange(W, device=device, dtype=dtype)

    lam_m = (torch.pi * m / Ly) ** 2  # height direction
    lam_n = (torch.pi * n / Lx) ** 2  # width direction

    lam = lam_m[:, None] + lam_n[None, :]  # (H, W)

    Q = (sigma0 ** 2) * (kappa**2 + lam).pow(-alpha)

    return Q