사용자 도구

사이트 도구


visdom

Visdom

이미지 축 변환

일반 이미지(height x widht x channel)에서 torch (channel x height x width)로 변환

def hwc2chw(img):
    assert img.shape == (84, 84, 3)
    return np.transpose(img, (2, 0, 1))  # (3, 84, 84)
 
 
def chw2hwc(img):
    assert img.shape == (3, 84, 84)
    return np.transpose(img, (1, 2, 0))  # (84, 84, 3)

이미지 보이기

viz.image(o, win='name', opts=dict(width=256, height=256))

viz_line 편의함수

viz = visdom.Visdom()
 
 
def viz_line_(viz, title, x, y, window_size=25, width=None, height=None, ymin=None, ymax=None):
    title_ = title.replace(' ', '_')
 
    if type(y) == dict:
        _, update = getattr(viz, '_{}'.format(title_), (None, None))
        legend, xs, ys = [], [], []
        for k, v in sorted(y.items()):
            k_ = k.replace(' ', '_')
            dq, _ = getattr(viz, '_{}'.format(k_), (collections.deque(maxlen=window_size), None))
            dq.append(v)
            legend.append(k)
            xs.append([x])
            ys.append([np.mean(dq)])
 
        viz.line(X=np.column_stack(xs), Y=np.column_stack(ys), win=title, update=update,
            opts=dict(title=title, width=width, height=height, legend=legend))
        setattr(viz, '_{}'.format(title_), (None, 'append'))
    else:
        dq, update = getattr(viz, '_{}'.format(title_), (collections.deque(maxlen=window_size), None))
        dq.append(y)
        y_mean = np.mean(dq)
 
        viz.line(X=[x], Y=[y_mean], win=title, update=update, 
            opts=dict(title=f'{title}: {y_mean}', width=width, height=height, ytickmin=ymin, ytickmax=ymax))
        setattr(viz, '_{}'.format(title_), (dq, 'append'))
 
viz_line = functools.partial(viz_line_, viz)
visdom.txt · 마지막으로 수정됨: 2024/03/23 02:38 저자 127.0.0.1