"""
Similarity metrics for code comparison.
"""
import numpy as np
from typing import Union
from sklearn.metrics.pairwise import cosine_similarity as sklearn_cosine


def cosine_sim(v1: Union[list, np.ndarray], v2: Union[list, np.ndarray]) -> float:
    """
    Compute cosine similarity.

    Args:
        v1: First vector
        v2: Second vector

    Returns:
        Similarity in [-1, 1]
    """
    v1 = np.asarray(v1).reshape(1, -1)
    v2 = np.asarray(v2).reshape(1, -1)
    return sklearn_cosine(v1, v2)[0, 0]
