服务器无法调用gym中的render,采用Monitor保存视频的方法解决

问题

由于服务器上没有图形化界面,所以在调用gym中的render()函数时,会报错pyglet.canvas.xlib.NoSuchDisplayException: Cannot connect to "None"
思路是:把视频保存下来,下载到本地再看。

解决方案

直接调用gym.wrappers.Monitor把视频保存到本地
代码示例如下:

# test.py

import gym
from gym.wrappers import Monitor

outdir = 'video_record'
env = gym.make('MountainCar-v0')
env = Monitor(env, outdir, video_callable=lambda episode_id: True,  force=True) # 主要是修改这行代码,把env传递给Monitor函数
state = env.reset()
done = False
while not done:
    action = env.action_space.sample()
    state_next, reward, done, info = env.step(action)
env.close()

outdir为视频保存路径;video_callable表示多少个episode记录一次视频,可将True改为指定的episode数,只记录特定的episodeforce为是否覆盖之前的视频。

然后在终端输入:

xvfb-run -a -s "-screen 0 640x480x24" python test.py 

如果不适用xvfb运行的话,还是会报错

可能遇到的问题

当运行之后,发现视频无法打开,那是因为在源码中有一个bug,参考Fix video recording
gym/wrappers/monitoring/video_recorder.py源代码如下:

if frame.dtype != np.uint8:
	raise error.InvalidFrame("Your frame has data type {}, but we require uint8 (i.e. RGB values from 0-255).".format(frame.dtype))

	self.proc.stdin.write(frame.tobytes())

应该修改为:

if frame.dtype != np.uint8:
	raise error.InvalidFrame("Your frame has data type {}, but we require uint8 (i.e. RGB values from 0-255).".format(frame.dtype))

self.proc.stdin.write(frame.tobytes())

即:找到gym包的安装目录,把video_recorder.py中的self.proc.stdin.write(frame.tobytes())这一行代码放到if代码块外面来

总结

  • 调用Monitor保存录像
  • 要使用xvfb-run运行代码
  • 修改gym源码中的一个bug

参考资料

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值