"""
active_acquisition.py
Active data acquisition strategies for AWML.
Implements greedy information gain selection and ensemble-based uncertainty.
"""

import torch
import torch.nn.functional as F


def information_gain(model, candidate_actions, prior_entropy):
    """
    Approximate information gain for candidate actions.
    """
    gains = []
    for a in candidate_actions:
        pred = model(a)
        entropy = -torch.sum(F.softmax(pred, dim=-1) * F.log_softmax(pred, dim=-1), dim=-1).mean()
        gains.append(prior_entropy - entropy.item())
    return gains


def greedy_acquisition(model, candidate_actions, budget=10):
    prior_entropy = 1.0
    gains = information_gain(model, candidate_actions, prior_entropy)
    topk = torch.topk(torch.tensor(gains), budget)
    return [candidate_actions[i] for i in topk.indices.tolist()]
