import torch

def _eval_indices(T: int, T_sub: int, equidist: bool) -> torch.LongTensor:
    if equidist:
        # evenly spaced indices in [0, T-1]
        lin = torch.linspace(0, T - 1, steps=T_sub).round().long()
        lin.clamp_(0, T - 1)
        # uniquify in case of collisions
        uniq = torch.unique(lin, sorted=True)
        while uniq.numel() < T_sub:
            uniq = torch.unique(torch.cat([uniq, torch.tensor([T - 1])]), sorted=True)
        return uniq[:T_sub]
    else:
        return torch.sort(torch.randperm(T)[:T_sub]).values