鱼C论坛

 找回密码
 立即注册
查看: 1229|回复: 3

[已解决]CartPole环境里的小疑问

[复制链接]
发表于 2020-3-7 16:10:14 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
【问题】:step函数返回的最后一项{}是什么?我自己跑了一下,传出来的是空白字典,请问为啥要设置这个输出?
  1. def step(self, action):
  2.         assert self.action_space.contains(action), "%r (%s) invalid"%(action, type(action)) #用于判断一个表达式,在表达式条件为 false 的时候触发异常。
  3.         state = self.state
  4.         x, x_dot, theta, theta_dot = state #设置状态
  5.         force = self.force_mag if action==1 else -self.force_mag
  6.         costheta = math.cos(theta)
  7.         sintheta = math.sin(theta)
  8.         temp = (force + self.polemass_length * theta_dot * theta_dot * sintheta) / self.total_mass
  9.         thetaacc = (self.gravity * sintheta - costheta* temp) / (self.length * (4.0/3.0 - self.masspole * costheta * costheta / self.total_mass))
  10.         xacc  = temp - self.polemass_length * thetaacc * costheta / self.total_mass
  11.         if self.kinematics_integrator == 'euler':
  12.             x  = x + self.tau * x_dot
  13.             x_dot = x_dot + self.tau * xacc
  14.             theta = theta + self.tau * theta_dot
  15.             theta_dot = theta_dot + self.tau * thetaacc
  16.         else: # semi-implicit euler
  17.             x_dot = x_dot + self.tau * xacc
  18.             x  = x + self.tau * x_dot
  19.             theta_dot = theta_dot + self.tau * thetaacc
  20.             theta = theta + self.tau * theta_dot
  21.         self.state = (x,x_dot,theta,theta_dot)
  22.         done =  x < -self.x_threshold \
  23.                 or x > self.x_threshold \
  24.                 or theta < -self.theta_threshold_radians \
  25.                 or theta > self.theta_threshold_radians
  26.         done = bool(done)

  27.         if not done:
  28.             reward = 1.0
  29.         elif self.steps_beyond_done is None:
  30.             # Pole just fell!
  31.             self.steps_beyond_done = 0
  32.             reward = 1.0
  33.         else:
  34.             if self.steps_beyond_done == 0:
  35.                 logger.warn("You are calling 'step()' even though this environment has already returned done = True. You should always call 'reset()' once you receive 'done = True' -- any further steps are undefined behavior.")
  36.             self.steps_beyond_done += 1
  37.             reward = 0.0

  38.         return np.array(self.state), reward, done, {}
复制代码
最佳答案
2020-3-9 18:07:14
xjtu_wong 发表于 2020-3-9 17:55
能否讲一下具体的功能?是用来调试环境的参数吗?感觉没必要设置这个输出啊


这个返回值是为了调用设计的。因为传入了空字典,相当于没有设置调试项,但是step ()必须把四个参数都返回才能被正确调用,调用后程序就是看你返回的四个东西来进行操作。
即调用step()方法的东西规定step()必须给我返回四个东西,调试项不管有没有先返回再说。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-3-7 19:25:08 | 显示全部楼层
step()函数在仿真器中扮演物理引擎的角色。其输出是:下一步状态,立即回报,是否终止,调试项
字典里可以按照需要放你想放的调试内容。
希望对你有所帮助~
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-3-9 17:55:20 | 显示全部楼层
dlnb526 发表于 2020-3-7 19:25
step()函数在仿真器中扮演物理引擎的角色。其输出是:下一步状态,立即回报,是否终止,调试项。
字典里可 ...

能否讲一下具体的功能?是用来调试环境的参数吗?感觉没必要设置这个输出啊
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-9 18:07:14 | 显示全部楼层    本楼为最佳答案   
xjtu_wong 发表于 2020-3-9 17:55
能否讲一下具体的功能?是用来调试环境的参数吗?感觉没必要设置这个输出啊


这个返回值是为了调用设计的。因为传入了空字典,相当于没有设置调试项,但是step ()必须把四个参数都返回才能被正确调用,调用后程序就是看你返回的四个东西来进行操作。
即调用step()方法的东西规定step()必须给我返回四个东西,调试项不管有没有先返回再说。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-6-2 10:16

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表