# -*- coding: utf-8 -*-
from typing import List, Dict, Tuple, Set
from config import TH_CONTRA_DEFAULT
from nli import nli_many
from io_utils import normalize_text

def filter_conflict_vs_truth(facts: List[str], truth_texts: List[str], contra_thres: float = TH_CONTRA_DEFAULT) -> List[str]:
    if not facts: return []
    pairs = []
    for f in facts:
        for t in truth_texts:
            pairs.append((t, f))
            pairs.append((f, t))
    lp = nli_many(pairs) if pairs else {}
    kept = []
    for f in facts:
        bad = False
        for t in truth_texts:
            l1, p1, _ = lp[(t, f)]
            l2, p2, _ = lp[(f, t)]
            if (l1 == "contradiction" and p1 >= contra_thres) or (l2 == "contradiction" and p2 >= contra_thres):
                bad = True; break
        if not bad: kept.append(f)
    return kept

def _neutral_adj(facts: List[str]) -> Dict[int, Set[int]]:
    n = len(facts)
    if n <= 1: return {i:set() for i in range(n)}
    pairs = []
    for i in range(n):
        for j in range(i+1, n):
            pairs.append((facts[i], facts[j]))
            pairs.append((facts[j], facts[i]))
    lp = nli_many(pairs)
    adj = {i:set() for i in range(n)}
    for i in range(n):
        for j in range(i+1, n):
            lfg, _, _ = lp[(facts[i], facts[j])]
            lgf, _, _ = lp[(facts[j], facts[i])]
            if lfg == "neutral" and lgf == "neutral":
                adj[i].add(j); adj[j].add(i)
    return adj

def _bron_kerbosch_pivot(R: Set[int], P: Set[int], X: Set[int], adj: Dict[int, Set[int]], best: List[int], pivot_choice=True):
    if not P and not X:
        if len(R) > len(best): best[:] = list(R)
        return
    if pivot_choice and (P or X):
        U = (P | X)
        u = max(U, key=lambda v: len(adj[v])) if U else None
        if u is not None:
            candidates = P - adj[u]
        else:
            candidates = set(P)
    else:
        candidates = set(P)
    for v in list(candidates):
        _bron_kerbosch_pivot(R | {v}, P & adj[v], X & adj[v], adj, best, pivot_choice)
        P.remove(v)
        X.add(v)

def largest_neutral_clique(facts: List[str]) -> List[str]:
    if len(facts) <= 1: return list(facts)
    adj = _neutral_adj(facts)
    R, P, X = set(), set(range(len(facts))), set()
    best: List[int] = []
    _bron_kerbosch_pivot(R, P, X, adj, best, pivot_choice=True)
    return [facts[i] for i in sorted(best)]
