| |
| import numpy as np |
|
|
| import annotator.uniformer.mmcv as mmcv |
|
|
| try: |
| import torch |
| except ImportError: |
| torch = None |
|
|
|
|
| def tensor2imgs(tensor, mean=(0, 0, 0), std=(1, 1, 1), to_rgb=True): |
| """Convert tensor to 3-channel images. |
| |
| Args: |
| tensor (torch.Tensor): Tensor that contains multiple images, shape ( |
| N, C, H, W). |
| mean (tuple[float], optional): Mean of images. Defaults to (0, 0, 0). |
| std (tuple[float], optional): Standard deviation of images. |
| Defaults to (1, 1, 1). |
| to_rgb (bool, optional): Whether the tensor was converted to RGB |
| format in the first place. If so, convert it back to BGR. |
| Defaults to True. |
| |
| Returns: |
| list[np.ndarray]: A list that contains multiple images. |
| """ |
|
|
| if torch is None: |
| raise RuntimeError('pytorch is not installed') |
| assert torch.is_tensor(tensor) and tensor.ndim == 4 |
| assert len(mean) == 3 |
| assert len(std) == 3 |
|
|
| num_imgs = tensor.size(0) |
| mean = np.array(mean, dtype=np.float32) |
| std = np.array(std, dtype=np.float32) |
| imgs = [] |
| for img_id in range(num_imgs): |
| img = tensor[img_id, ...].cpu().numpy().transpose(1, 2, 0) |
| img = mmcv.imdenormalize( |
| img, mean, std, to_bgr=to_rgb).astype(np.uint8) |
| imgs.append(np.ascontiguousarray(img)) |
| return imgs |
|
|