import numpy as np


def xover(arr: np.ndarray, cut: float) -> int:
    """Return index of first element greater than cut.

    Args:
        arr: Array to search.
        cut: Cut-off value.

    Returns:
        Index of first element greater than cut.
    """
    x = arr > cut
    return x.argmax().item() if x.any() else -1


def top_k_ohe(arr: np.ndarray, top_k: int) -> np.ndarray:
    """Returns one-hot encoding of top k values of the last dimension.

    Args:
        arr: Array to encode.
        k: Number of top values to encode.

    Returns:
        One-hot encoding of top k values in arr. Same shape as arr.
    """
    assert top_k < arr.shape[-1], f"k must be less than {arr.shape[-1]}"
    topk_idx = np.argpartition(arr, -top_k, axis=-1)[..., -top_k:]
    result = np.zeros_like(arr, dtype=arr.dtype)
    np.put_along_axis(result, topk_idx, 1.0, axis=-1)
    return result
