Spaces:
Running
on
Zero
Running
on
Zero
| import torch | |
| import torch.nn.functional as F | |
| def apply_delay_pattern(codes: torch.Tensor, mask_token: int): | |
| codes = F.pad(codes, (0, codes.shape[1]), value=mask_token) | |
| return torch.stack([codes[:, k].roll(k + 1) for k in range(codes.shape[1])], dim=1) | |
| def revert_delay_pattern(codes: torch.Tensor): | |
| _, n_q, seq_len = codes.shape | |
| return torch.stack([codes[:, k, k + 1 : seq_len - n_q + k + 1] for k in range(n_q)], dim=1) | |