""""""
from __future__ import annotations

from typing import Iterable, List

import numpy as np

try:
    import torch
    from torch import nn
except Exception as exc:
    torch = None
    nn = None


def shared_gradient_vector(
    shared_parameters: Iterable["torch.nn.Parameter"],
) -> np.ndarray:
    """\nshared_parameters: Iterable['torch.nn.Parameter']\n    """
    if torch is None:
        raise RuntimeError(
            "PyTorch is not available; this helper requires torch."
        )
    grads: List["torch.Tensor"] = []
    for p in shared_parameters:
        if p.grad is None:
            continue
        grads.append(p.grad.detach().reshape(-1))
    if not grads:
        raise ValueError("No gradients found on shared parameters")
    flat = torch.cat(grads)
    return flat.cpu().numpy().astype("float32")
