"""
def _convert_logit_to_probability(logits):
    return torch.softmax(logits, dim=-1)
    
def get_acceptance_rate(self, outputs_drf, outputs_tgt, pad_mask=None):
    candidate_length = len(outputs_drf.logits)
    labels_drf = outputs_drf['sequences'][:, -candidate_length:]

    q_logits = rearrange(torch.stack(outputs_drf.logits), 's b v -> b s v')
    p_logits = outputs_tgt.logits[:, -candidate_length - 1 :]  # excludes the input prompt if present

    # get probability
    q_drf = _convert_logit_to_probability(q_logits) # max_target_length
    p_tgt = _convert_logit_to_probability(p_logits) # max_target_length + 1

    q_drf_labels = torch.gather(q_drf, -1, labels_drf.unsqueeze(-1)).squeeze(-1)
    p_tgt_labels = torch.gather(p_tgt[:, :-1], -1, labels_drf.unsqueeze(-1)).squeeze(-1)

    # probability ratio
    probability_ratio = q_drf_labels / p_tgt_labels

    # acceptance rate
    acceptance_rate = torch.min(probability_ratio, torch.tensor(1))

    return acceptance_rate
"""