import json
import os
from typing import List, Dict, Any
from dotenv import load_dotenv
import math

load_dotenv()


class memory_retriever:
    """
    ABOUTME: Memory retrieval implementation using embedding-based similarity search
    ABOUTME: Implements cosine similarity search with OpenAI embeddings
    """

    def __init__(self):
        var = None

    @staticmethod
    def _cosine_similarity(vec1: List[float], vec2: List[float]) -> float:
        """Compute cosine similarity between two vectors"""
        if len(vec1) != len(vec2):
            raise ValueError("Embedding vectors must be of same length")
        dot_product = sum(a * b for a, b in zip(vec1, vec2))
        norm1 = math.sqrt(sum(a * a for a in vec1))
        norm2 = math.sqrt(sum(b * b for b in vec2))
        if norm1 == 0.0 or norm2 == 0.0:
            return 0.0
        return dot_product / (norm1 * norm2)

    def retrieve_most_similar_memory(self,
                                     query_embedding: List[float],
                                     memories: List[Dict[str, Any]]) -> int:
        """
        Find the index of the memory whose embedding is most similar to query_embedding
        using cosine similarity.

        Returns:
            int: index of the most similar memory in the memories list; -1 if none found
        """
        max_sim = -1.0
        best_index = -1

        for idx, memory in enumerate(memories):
            emb = memory.get("embedding")
            if not emb:
                continue  # skip if no embedding in this memory
            try:
                sim = self._cosine_similarity(query_embedding, emb)
            except ValueError:
                continue  # skip if embedding length mismatch
            if sim > max_sim:
                max_sim = sim
                best_index = idx

        return best_index
