30分钟搭建强化学习开发环境:蘑菇书🍄零基础入门指南
你还在为配置强化学习环境头疼?CUDA版本不匹配、依赖包冲突、代码运行报错?本文将带你30分钟从零搭建稳定的Easy RL开发环境,让你专注于算法学习而非环境调试。读完本文你将获得:
- 适配蘑菇书代码的Python环境配置方案
- GPU/CPU版本PyTorch安装指南
- Jupyter Notebook快速启动方法
- 常见环境问题解决方案
环境准备
系统要求
- 操作系统:Windows/macOS/Linux
- Python版本:3.7(推荐,notebooks/requirements.txt明确依赖)
- 可选GPU:NVIDIA显卡(支持CUDA加速)
安装工具选择
推荐使用Anaconda管理Python环境,可通过官网下载对应系统版本。Anaconda已集成conda包管理器和Python,避免手动配置环境变量。
环境搭建步骤
1. 创建虚拟环境
打开终端(Windows用户建议使用Anaconda Prompt),执行以下命令创建并激活名为joyrl的虚拟环境:
conda create -n joyrl python=3.7
conda activate joyrl
2. 安装核心依赖
环境激活后,通过项目提供的requirements.txt安装基础依赖:
pip install -r notebooks/requirements.txt
文件notebooks/requirements.txt包含以下关键依赖:
matplotlib==3.5.3:用于绘制训练曲线gym==0.25.2:强化学习环境库pandas==1.3.5:数据处理工具torch==1.10.0:深度学习框架
3. 安装PyTorch
根据硬件配置选择合适的安装命令:
CPU版本
conda install pytorch==1.10.0 torchvision==0.11.0 torchaudio==0.10.0 cpuonly -c pytorch
GPU版本(需提前安装CUDA 11.3)
conda install pytorch==1.10.0 torchvision==0.11.0 torchaudio==0.10.0 cudatoolkit=11.3 -c pytorch -c conda-forge
国内镜像加速
pip install torch==1.10.0+cu113 torchvision==0.11.0+cu113 torchaudio==0.10.0 --extra-index-url https://download.pytorch.org/whl/cu113
验证环境配置
启动Jupyter Notebook
cd notebooks
jupyter notebook
在浏览器中打开生成的链接,尝试运行示例代码:
- notebooks/DQN.ipynb:深度Q网络实现
- notebooks/PolicyGradient.ipynb:策略梯度算法
测试代码示例
创建测试文件test_env.py,输入以下代码验证Gym环境:
import gym
env = gym.make('CartPole-v1')
observation = env.reset()
for _ in range(1000):
env.render()
action = env.action_space.sample()
observation, reward, done, info = env.step(action)
if done:
observation = env.reset()
env.close()
运行后应能看到CartPole游戏窗口,说明环境配置成功。
常见问题解决
依赖冲突
若出现ImportError,尝试重新安装指定版本:
pip install gym==0.25.2
Jupyter内核问题
python -m ipykernel install --user --name=joyrl
CUDA版本不匹配
通过nvidia-smi查看显卡支持的CUDA版本,选择对应的PyTorch安装命令。
资源获取
- 官方教程:docs/README.md
- 代码仓库:https://gitcode.com/datawhalechina/easy-rl
- 在线阅读:https://datawhalechina.github.io/easy-rl/
提示:环境配置完成后,可开始学习[notebooks/Value Iteration/value_iteration.ipynb](https://gitcode.com/datawhalechina/easy-rl/blob/fc4ece6ee54966f7f293f5b071a61a47dda4cb30/notebooks/Value Iteration/value_iteration.ipynb?utm_source=gitcode_repo_files)中的价值迭代算法,开启强化学习之旅!
如果本文对你有帮助,欢迎点赞、收藏、关注Datawhale社区,获取更多强化学习学习资源!下一期我们将介绍Q-Learning算法的实现与应用。
Kimi-K2.5Kimi K2.5 是一款开源的原生多模态智能体模型,它在 Kimi-K2-Base 的基础上,通过对约 15 万亿混合视觉和文本 tokens 进行持续预训练构建而成。该模型将视觉与语言理解、高级智能体能力、即时模式与思考模式,以及对话式与智能体范式无缝融合。Python00
GLM-4.7-FlashGLM-4.7-Flash 是一款 30B-A3B MoE 模型。作为 30B 级别中的佼佼者,GLM-4.7-Flash 为追求性能与效率平衡的轻量化部署提供了全新选择。Jinja00
VLOOKVLOOK™ 是优雅好用的 Typora/Markdown 主题包和增强插件。 VLOOK™ is an elegant and practical THEME PACKAGE × ENHANCEMENT PLUGIN for Typora/Markdown.Less00
PaddleOCR-VL-1.5PaddleOCR-VL-1.5 是 PaddleOCR-VL 的新一代进阶模型,在 OmniDocBench v1.5 上实现了 94.5% 的全新 state-of-the-art 准确率。 为了严格评估模型在真实物理畸变下的鲁棒性——包括扫描伪影、倾斜、扭曲、屏幕拍摄和光照变化——我们提出了 Real5-OmniDocBench 基准测试集。实验结果表明,该增强模型在新构建的基准测试集上达到了 SOTA 性能。此外,我们通过整合印章识别和文本检测识别(text spotting)任务扩展了模型的能力,同时保持 0.9B 的超紧凑 VLM 规模,具备高效率特性。Python00
KuiklyUI基于KMP技术的高性能、全平台开发框架,具备统一代码库、极致易用性和动态灵活性。 Provide a high-performance, full-platform development framework with unified codebase, ultimate ease of use, and dynamic flexibility. 注意:本仓库为Github仓库镜像,PR或Issue请移步至Github发起,感谢支持!Kotlin07
compass-metrics-modelMetrics model project for the OSS CompassPython00