
#!/usr/bin/env python
# -*- coding: utf-8 -*-

import numpy as np
import math

class InternVLAnalyzer:
    def __init__(self, cfg, val_path, model, tokenizer):
        self.cfg = cfg
        self.val_path = val_path
        self.model = model
        self.tokenizer = tokenizer

    def hu_acc(self, preds, refs):
        scores = []
        for p, r in zip(preds, refs):
            if not r: scores.append(0.0)
            else: scores.append(1.0 if p.lower().strip() in [ri.lower() for ri in r] else 0.0)
        return np.mean(scores)

    def kl_div(self, p, q, eps=1e-12):
        val = 0.0
        keys = set(p.keys()) | set(q.keys())
        for k in keys:
            pk, qk = max(p.get(k,0.0),eps), max(q.get(k,0.0),eps)
            val += pk * math.log(pk/qk)
        return val

    def evaluate(self):
        print("[Analyzer] Evaluation placeholder (HU-acc, KL-divergence)")
