找回密码
 会员注册
查看: 26|回复: 0

使用gym搭建自定义(以二维迷宫为例)环境并实现强化学习python

[复制链接]

4

主题

0

回帖

13

积分

新手上路

积分
13
发表于 2024-9-10 19:43:22 | 显示全部楼层 |阅读模式
1.查看所有环境Gym是一个包含各种各样强化学习仿真环境的大集合,并且封装成通用的接口暴露给用户,查看所有环境的代码如下importgymnasiumasgymfromgymimportenvsprint(envs.registry.all())2.编写文件放置首先找到自己的环境下面的gym环境包envs(也可以在pycharm的外部库Lib/site-packages/gymnasium/envs中找到):我的路径是D:\anaconda\anaconda\envs\gym\Lib\site-packages\gymnasium\envs之后我们要创建自己的myenv.py文件,确保自己创建的环境可以在gymnasium里使用,可以进入classic_control文件新建一个myenv的文件夹。也可以直接将我们的环境放入classic_control中,只是新建一个文件夹不容易混淆。注意:不推荐把文件放到robotics、mujoco文件夹里,因为这里是gym机器人环境的编辑文件,我们放进去后在运行调试会出错。3.注册自己的模拟器①打开classic_control文件夹中的__init__.py文件,添加fromgymnasium.envs.classic_control.myenv.myenvimportMyEnv【直接将我们的环境放入classic_control中时添加fromgymnasium.envs.classic_control.myenvimportMyEnv】②返回gymnasium/envs目录,在该目录的__init__.py中注册环境:添加自己创建的环境 register(id="MyEnv-v0",entry_point="gymnasium.envs.classic_control:MyEnv",max_episode_steps=200,reward_threshold=195.0,)注意:MyEnv-v0中v0代表环境类的版本号,在定义类的的时候名字里可以不加,但是在id注册的时候要加,后面import的时候要加。至此,就完成了环境的注册,就可以使用自定义的环境了!4.自定义环境实现直接上代码,在我们自定义的环境myenv/myenv.py中写入(详细讲解在6)importgymnasiumfromgymnasiumimportspacesimportpygameimportnumpyasnpclassMyEnv(gymnasium.Env):metadata={"render_modes":["human","rgb_array"],"render_fps":4}def__init__(self,size=5):self.size=size#Thesizeofthesquaregridself.window_size=512#ThesizeofthePyGamewindow#Observationsaredictionarieswiththeagent'sandthetarget'slocation.#Eachlocationisencodedasanelementof{0,...,`size`}^2,i.e.MultiDiscrete([size,size]).self.observation_space=spaces.Dict({"agent":spaces.Box(0,size-1,shape=(2,),dtype=int),"target":spaces.Box(0,size-1,shape=(2,),dtype=int),})#Wehave4actions,correspondingto"right","up","left","down","right"self.action_space=spaces.Discrete(4)"""Thefollowingdictionarymapsabstractactionsfrom`self.action_space`tothedirectionwewillwalkinifthatactionistaken.I.e.0correspondsto"right",1to"up"etc."""self._action_to_direction={0:np.array([1,0]),1:np.array([0,1]),2:np.array([-1,0]),3:np.array([0,-1]),}"""Ifhuman-renderingisused,`self.window`willbeareferencetothewindowthatwedrawto.`self.clock`willbeaclockthatisusedtoensurethattheenvironmentisrenderedatthecorrectframerateinhuman-mode.Theywillremain`None`untilhuman-modeisusedforthefirsttime."""self.window=Noneself.clock=Nonedef_get_obs(self):return{"agent":self._agent_location,"target":self._target_location}def_get_info(self):return{"distance":np.linalg.norm(self._agent_location-self._target_location,ord=1)}defreset(self,seed=None,return_info=False,options=None):#Weneedthefollowinglinetoseedself.np_randomsuper().reset(seed=seed)#Choosetheagent'slocationuniformlyatrandomself._agent_location=self.np_random.integers(0,self.size,size=2,dtype=int)#Wewillsamplethetarget'slocationrandomlyuntilitdoesnotcoincidewiththeagent'slocationself._target_location=self._agent_locationwhilenp.array_equal(self._target_location,self._agent_location):self._target_location=self.np_random.integers(0,self.size,size=2,dtype=int)observation=self._get_obs()info=self._get_info()return(observation,info)ifreturn_infoelseobservationdefstep(self,action):#Maptheaction(elementof{0,1,2,3})tothedirectionwewalkindirection=self._action_to_direction[action]#Weuse`np.clip`tomakesurewedon'tleavethegridself._agent_location=np.clip(self._agent_location+direction,0,self.size-1)#Anepisodeisdoneifftheagenthasreachedthetargetdone=np.array_equal(self._agent_location,self._target_location)reward=1ifdoneelse0#Binarysparserewardsobservation=self._get_obs()info=self._get_info()returnobservation,reward,done,info,{}defrender(self,mode="human"):ifself.windowisNoneandmode=="human":pygame.init()pygame.display.init()self.window=pygame.display.set_mode((self.window_size,self.window_size))ifself.clockisNoneandmode=="human":self.clock=pygame.time.Clock()canvas=pygame.Surface((self.window_size,self.window_size))canvas.fill((255,255,255))pix_square_size=(self.window_size/self.size)#Thesizeofasinglegridsquareinpixels#Firstwedrawthetargetpygame.draw.rect(canvas,(255,0,0),pygame.Rect(pix_square_size*self._target_location,(pix_square_size,pix_square_size),),)#Nowwedrawtheagentpygame.draw.circle(canvas,(0,0,255),(self._agent_location+0.5)*pix_square_size,pix_square_size/3,)#Finally,addsomegridlinesforxinrange(self.size+1):pygame.draw.line(canvas,0,(0,pix_square_size*x),(self.window_size,pix_square_size*x),width=3,)pygame.draw.line(canvas,0,(pix_square_size*x,0),(pix_square_size*x,self.window_size),width=3,)ifmode=="human":#Thefollowinglinecopiesourdrawingsfrom`canvas`tothevisiblewindowself.window.blit(canvas,canvas.get_rect())pygame.event.pump()pygame.display.update()#Weneedtoensurethathuman-renderingoccursatthepredefinedframerate.#Thefollowinglinewillautomaticallyaddadelaytokeeptheframeratestable.self.clock.tick(self.metadata["render_fps"])else:#rgb_arrayreturnnp.transpose(np.array(pygame.surfarray.pixels3d(canvas)),axes=(1,0,2))defclose(self):ifself.windowisnotNone:pygame.display.quit()pygame.quit()5.测试环境importgymnasiumasgymenv=gym.make('MyEnv-v0')env.action_space.seed(42)observation,info=env.reset(seed=42,return_info=True)for_inrange(1000)bservation,reward,done,info,_=env.step(env.action_space.sample())env.render()ifdonebservation,info=env.reset(return_info=True)env.close() 运行成功!6.自定义环境以及测试代码解释 自定义环境,首先要继承环境基类env。reset(self):重置环境的状态,即初始化状态step(self,action):环境针对action的反馈,返回observation(下一个状态),reward(奖励),done(结束标记),info(自定义信息)render(self,mode=‘human’,close=False):重绘环境的一帧,即可视化渲染seed:随机数种子close(self):关闭环境,并清除内存对于step的详细说明上面我们只是每次做随机的action,为了更好的进行action,我们需要知道每一步step之后的返回值.事实上,step会返回四个值①观测Observation(Object):当前step执行后,环境的观测。②Reward(Float):执行上一步动作(action)后,智能体(agent)获得的奖励(浮点类型),不同的环境中奖励值变化范围也不相同,但是强化学习的目标就是使得总奖励值最大;③完成Done(Boolen):表示是否需要将环境重置env.reset。大多数情况下,当Done为True时,就表明当前回合(episode)或者试验(tial)结束。④信息Info(Dict):针对调试过程的诊断信息。在标准的智体仿真评估当中不会使用到这个info。在Gym仿真中,每一次回合开始,需要先执行reset()函数,返回初始观测信息,然后根据标志位done的状态,来决定是否进行下一次回合。所以更恰当的方法是遵守done的标志.7.gym模块中环境的常用函数gym的初始化importgymnasiumasgymenv=gym.make('CartPole-v0')#定义使用gym库中的某一个环境,'CartPole-v0'可以改为其它环境env=env.unwrapped#unwrapped是打开限制的意思gym的各个参数的获取env.action_space #查看这个环境中可用的action有多少个,返回Discrete()格式env.observation_space#查看这个环境中observation的特征【状态空间】,返回Box()格式n_actions=env.action_space.n#查看这个环境中可用的action有多少个,返回intn_features=env.observation_space.shape[0]#查看这个环境中observation的特征有多少个,返回int刷新环境env.reset()#用于一个done后环境的重启,获取回合的第一个observationenv.render() #用于每一步后刷新环境状态observation_,reward,done,info=env.step(action)#获取下一步的环境、得分、检测是否完成。参考链接:使用gym搭建自定义(以二维迷宫为例)环境并实现强化学习python_gym编写迷宫环境-CSDN博客
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 会员注册

本版积分规则

QQ|手机版|心飞设计-版权所有:微度网络信息技术服务中心 ( 鲁ICP备17032091号-12 )|网站地图

GMT+8, 2025-1-5 09:55 , Processed in 0.645751 second(s), 25 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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