pytorch visdom可视化工具学习—2—详细使用-3-Generic Plots和Others

4)Generic Plots

注意,服务器API遵循数据和布局对象的规则,这样您就可以生成自己的任意Plotly可视化:

# Arbitrary visdom content
trace = dict(x=[1, 2, 3], y=[4, 5, 6], mode="markers+lines", type='custom',
             marker={'color': 'red', 'symbol': 104, 'size': "10"},
             text=["one", "two", "three"], name='1st Trace')
layout = dict(title="First Plot", xaxis={'title': 'x1'},
              yaxis={'title': 'x2'})

viz._send({'data': [trace], 'layout': layout, 'win': 'mywin'})

图示:

 

 

5)Others

  • vis.close : 通过id关闭窗口
  • vis.delete_env : 通过env_id删除环境
  • vis.win_exists : 通过id检查窗口是否已经存在
  • vis.get_env_list : 获取服务器上所有环境的列表
  • vis.win_hash: 获取窗口内容的md5散列
  • vis.get_window_data: 获取窗口的当前数据
  • vis.check_connection: 检查服务器是否连接
  • vis.replay_log: 重播所提供的日志文件中的操作

1》 vis.replay_log

 

2》vis.delete_env

此函数完全删除指定的env。它接受env id :eid作为输入。

注意:delete_env删除一个环境的所有数据,并且是不可逆的。除非绝对想要删除环境,否则不要使用。

 

 一开始有三个环境,打算将test环境删除

调用:

viz.delete_env('test')

返回:

''

然后就可以看见test环境不见了:

 

3》vis.win_exists

此函数返回一个bool,指示服务器上是否已经存在窗口win。如果出现错误,则返回None。

可选参数:

  • env:在Environment中搜索窗口。默认是没有的。
    win = viz.scatter(
        X=np.random.rand(255, 2),
        opts=dict(
            markersize=10,
            markercolor=np.random.randint(0, 255, (255, 3,)),
        ),
    )

    #断言该窗口是否存在
    assert viz.win_exists(win), 'Created window marked as not existing'

    # 添加新的追踪到散点图中
    viz.scatter(
        X=np.random.rand(255),
        Y=np.random.rand(255),
        win=win,
        name='new_trace',
        update='new'
    )

 图示:

 

4》vis.get_env_list

此函数返回调用时服务器上所有环境的列表。它不需要任何参数。

调用:

viz.get_env_list()

返回:

['main', 'default', '']

 

5》vis.win_hash

如果存在于服务器上,此函数将返回win窗口内容的md5散列。否则返回None。

可选参数:

  • env:在Environment中搜索窗口。默认是没有的。
viz.win_hash('default')

什么都没有返回

正确的使用方式是:

win = viz.scatter(
    X=np.random.rand(255, 2),
    opts=dict(
        markersize=10,
        markercolor=np.random.randint(0, 255, (255, 3,)),
    ),
)
viz.win_hash(win)

返回:

'b144c351f2f68f59d8b0dc5f28688b63'

 

6》vis.get_window_data

viz.get_window_data('default')

返回:

''

 

正确的使用方式是:

win = viz.scatter(
    X=np.random.rand(255, 2),
    opts=dict(
        markersize=10,
        markercolor=np.random.randint(0, 255, (255, 3,)),
    ),
)
viz.get_window_data(win)

返回:

'{"command": "window", "id": "window_3739ceea81b772", "title": "", "inflate": true, "width": null, "height": null, "contentID": "3739ceea81b79c", "content": {"data": [{"x": [0.04551835890074274, 0.9772260473924358, 0.9009148817295527, 0.539562493921608, 0.24118526960032582, 0.46977995598941924, 0.060850500332354174, 0.7347072292427027, 0.5412919280211997, 0.09581282770005128, 0.810341818084029, 0.41717700845083594, 0.1368515602012041
...
6], "name": "1", "type": "scatter", "mode": "markers", "textposition": "right", "line": {}, "marker": {"size": 10, "symbol": "dot", "color": ["#ebbb47", "#1818ad", "#7bd242", "#333f7d", "#f2f7c4", "#f7c7c0", "#c2025f", "#ac2ca9", 
...
"#bbc91d", "#156b58", "#315d0d", "#96c8e2", "#1c1291", "#3def07", "#5adcbc", "#f1baec", "#a67050", "#373313", "#025bd9"], "line": {"color": "#000000", "width": 0.5}}}], "layout": {"showlegend": false, "margin": {"l": 60, "r": 60, "t": 60, "b": 60}}}, "type": "plot", "i": 15}'

 

7》vis.check_connection

举例:

viz = Visdom(port=DEFAULT_PORT, server=DEFAULT_HOSTNAME)

assert viz.check_connection(timeout_seconds=3), \
    'No connection could be formed quickly'

textwindow = viz.text('Hello World!') #生成一个窗口,里面带文本Hello World!

#生成另一个窗口,里面带文本Hello World! More text should be here
updatetextwindow = viz.text('Hello World! More text should be here') 
#断言查看updatetextwindow窗口对象是否存在
assert updatetextwindow is not None, 'Window was none'
#窗口存在的话,就在该窗口中添加下面的文本,win指定添加到的窗口对象,append指定进行的操作是在元原有的基础上添加
viz.text('And here it is', win=updatetextwindow, append=True)

返回生成的窗口编号:

'window_373974331dca16'

图示:

 

8》vis.close

这个函数关闭一个特定的窗口。它接受输入窗口id:win和环境id:eid。使用win=None,即不设置win关闭环境中的所有窗口

关闭上面生成的text窗口

# close text window:
viz.close(win=textwindow)

返回:

''

图示:

 

posted @ 2019-04-05 20:50  慢行厚积  阅读(1527)  评论(0编辑  收藏  举报