Hub 文档

在 Hugging Face Hub 上使用 sample-factory

Hugging Face's logo
加入 Hugging Face 社区

并获得增强的文档体验

开始使用

在 Hugging Face 上使用 sample-factory

sample-factory 是一个用于高吞吐量异步强化学习的代码库。它与 Hugging Face Hub 集成,可以共享包含评估结果和训练指标的模型。

探索 Hub 中的 sample-factory

你可以在模型页面左侧进行筛选,找到 sample-factory 模型。

Hub 上的所有模型都附带了有用的功能

  1. 一个自动生成的模型卡片,包含描述、训练配置等信息。
  2. 有助于发现的元数据标签。
  3. 与其他模型进行比较的评估结果。
  4. 一个视频小部件,您可以在其中观看您的智能体执行任务。

安装库

要安装 sample-factory 库,你需要安装该包

pip install sample-factory

已知 SF 可以在 Linux 和 MacOS 上运行。目前不支持 Windows。

从 Hub 加载模型

使用 load_from_hub

要从 Hugging Face Hub 下载模型以与 Sample-Factory 一起使用,请使用 load_from_hub 脚本

python -m sample_factory.huggingface.load_from_hub -r <HuggingFace_repo_id> -d <train_dir_path>

命令行参数如下:

  • -r: 要下载的 HF 仓库的 repo ID。repo ID 的格式应为 <username>/<repo_name>
  • -d: 一个可选参数,用于指定保存实验的目录。默认为 ./train_dir,它将把仓库保存到 ./train_dir/<repo_name>

直接下载模型仓库

Hugging Face 仓库可以直接使用 git clone 下载

git clone git@hf.co:<Name of HuggingFace Repo> # example: git clone git@hf.co:bigscience/bloom

使用下载的模型与 Sample-Factory

下载模型后,你可以使用对应环境的 enjoy 脚本运行仓库中的模型。例如,如果你下载了一个 mujoco-ant 模型,可以使用以下命令运行:

python -m sf_examples.mujoco.enjoy_mujoco --algo=APPO --env=mujoco_ant --experiment=<repo_name> --train_dir=./train_dir

请注意,如果你的本地 `train_dir` 路径与 `cfg.json` 中的路径不同,你可能需要指定 `--train_dir`。

共享你的模型

使用 push_to_hub

如果你想在不生成评估指标或重放视频的情况下上传,可以使用 push_to_hub 脚本。

python -m sample_factory.huggingface.push_to_hub -r <hf_username>/<hf_repo_name> -d <experiment_dir_path>

命令行参数如下:

  • -r: 要推送到 HF Hub 的 repo_id。这与 enjoy 脚本中的 hf_repository 相同,必须采用 <hf_username>/<hf_repo_name> 的形式。
  • -d: 要上传的实验目录的完整路径。

使用 enjoy.py

你可以使用环境的 enjoy 脚本以及 --push_to_hub 标志将模型上传到 Hub。使用 enjoy 上传还可以生成评估指标和重放视频。

评估指标是通过在指定环境中运行模型多个回合,并报告这些运行的平均奖励和标准差来生成的。

其他相关命令行参数包括:

  • --hf_repository: 要推送到的仓库。必须采用 <username>/<repo_name> 的形式。模型将保存到 https://huggingface.co/<username>/<repo_name>
  • --max_num_episodes: 上传前要评估的回合数。用于生成评估指标。建议使用多个回合以生成准确的平均值和标准差。
  • --max_num_frames: 上传前要评估的帧数。max_num_episodes 的替代方案。
  • --no_render: 一个标志,禁用渲染和显示环境步骤。建议设置此标志以加快评估过程。

你还可以使用 --save_video 标志保存模型在评估期间的视频,以便上传到 Hub。

  • --video_frames: 视频中要渲染的帧数。默认为 -1,表示渲染整个回合。
  • --video_name: 要保存的视频名称。如果为 None,则将保存到实验目录中的 replay.mp4

例如:

python -m sf_examples.mujoco_examples.enjoy_mujoco --algo=APPO --env=mujoco_ant --experiment=<repo_name> --train_dir=./train_dir --max_num_episodes=10 --push_to_hub --hf_username=<username> --hf_repository=<hf_repo_name> --save_video --no_render
< > 在 GitHub 上更新