|
import os |
|
import numpy as np |
|
from PIL import Image |
|
import sys |
|
|
|
|
|
class Results(object): |
|
def __init__(self, root_dir): |
|
self.root_dir = root_dir |
|
|
|
def _read_mask(self, sequence, frame_id): |
|
try: |
|
mask_path = os.path.join(self.root_dir, sequence, f'{frame_id}.png') |
|
return np.array(Image.open(mask_path)) |
|
except IOError as err: |
|
sys.stdout.write(sequence + " frame %s not found!\n" % frame_id) |
|
sys.stdout.write("The frames have to be indexed PNG files placed inside the corespondent sequence " |
|
"folder.\nThe indexes have to match with the initial frame.\n") |
|
sys.stderr.write("IOError: " + err.strerror + "\n") |
|
sys.exit() |
|
|
|
def read_masks(self, sequence, masks_id): |
|
mask_0 = self._read_mask(sequence, masks_id[0]) |
|
masks = np.zeros((len(masks_id), *mask_0.shape)) |
|
for ii, m in enumerate(masks_id): |
|
masks[ii, ...] = self._read_mask(sequence, m) |
|
num_objects = int(np.max(masks)) |
|
tmp = np.ones((num_objects, *masks.shape)) |
|
tmp = tmp * np.arange(1, num_objects + 1)[:, None, None, None] |
|
masks = (tmp == masks[None, ...]) > 0 |
|
return masks |
|
|