
LeetCode Hard Gym 是一个专门用于评估代码生成代理在 LeetCode 困难题目上表现的强化学习环境。该项目由 GammaTauAI 团队开发,旨在为研究人员和开发者提供一个标准化的平台,以测试和比较不同代码生成模型的性能。
多语言支持:LeetCode Hard Gym 支持多种编程语言,包括 Python、Java、C++、JavaScript 等 18 种主流编程语言。这使得研究人员可以在不同语言环境下评估代码生成模型的表现。
基于 OpenAI Gym:项目建立在 OpenAI 的 Gym 框架之上,这使得它能够与现有的强化学习算法和工具无缝集成。
实时评估:通过与 LeetCode 的提交服务器接口,LeetCode Hard Gym 能够实时评估生成的代码,提供即时反馈。
标准化评估指标:项目提供了 Pass@1 等标准化的评估指标,便于不同模型之间的横向比较。

要开始使用 LeetCode Hard Gym,您需要按照以下步骤进行设置:
git clone https://github.com/GammaTauAI/leetcode-hard-gym.git cd leetcode-hard-gym
python -m venv venv source venv/bin/activate python -m pip install -e .
LEETCODE_SESSION 和 LEETCODE_CSRF_TOKEN 环境变量。这些可以从已登录的 LeetCode 会话中获取。export LEETCODE_SESSION=... export LEETCODE_CSRF_TOKEN=...
以下是一个简单的示例,展示如何使用 LeetCode Hard Gym:
from leetcode_env.types import LeetCodeSubmission, ProgrammingLanguage from leetcode_env.environment import LeetCodeEnv # 编写代码 code = """ class Solution: def twoSum(self, nums, target): l = len(nums) for i in range(l - 1): for j in range(i + 1, l): if nums[i] + nums[j] == target: return [i, j] """ # 创建提交 sub = LeetCodeSubmission(code=code, lang=ProgrammingLanguage.PYTHON3, question_slug='two-sum', timeout=5) # 实例化环境 env = LeetCodeEnv() # 执行提交 status, reward, done, submission_result = env.step(sub) print(status, reward, done, submission_result)
除了提供评估环境,LeetCode Hard Gym 项目还包含了一个用于构建未被污染的 LeetCode 困难题目数据集的脚本。这个数据集的格式类似于 HumanEval,可以用于进一步的研究和模型训练。
要构建数据集,您可以使用以下命令:
python build.py --langs python3 rust --log_level INFO --output_dir ./build
这个脚本会执行以下操作:

LeetCode Hard Gym 提供了一个标准化的评估指标:Pass@1。以下是一些主要模型在 Python 语言的 LeetCode 困难题目上的表现:
这些结果表明,即使是最先进的模型在解决 LeetCode 困难题目时仍面临着巨大挑战。LeetCode Hard Gym 为研究人员提供了一个 宝贵的工具,以推动代码生成技术的进步。
LeetCode Hard Gym 项目为代码生成和程序合成领域的研究提供了一个强大而灵活的工具。通过标准化的评估环境和数据集,它使得不同模型和方法的比较变得更加容易和公平。随着人工智能和机器学习技术在编程领域的不断进步,我们可以期待看到更多创新的解决方案来应对 LeetCode 困难题目的挑战。
对于有兴趣深入研究或使用 LeetCode Hard Gym 的开发者和研究人员,项目的 GitHub 仓库 提供了详细的文档和使用说明。我们鼓励社区贡献者参与到项目的改进和扩展中来,共同推动代码生成技术的发展。
如果您在研究中使用了 LeetCode Hard Gym,请引用以下论文:
@misc{shinn2023reflexion,
title={Reflexion: Language Agents with Verbal Reinforcement Learning},
author={Noah Shinn and Federico Cassano and Edward Berman and Ashwin Gopinath and Karthik Narasimhan and Shunyu Yao},
year={2023},
eprint={2303.11366},
archivePrefix={arXiv},
primaryClass={cs.AI}
}
通过 LeetCode Hard Gym,我们期待看到更多突破性的研究成果,推动代码生成技术向着更高效、更准确的方向发展。🚀👨💻👩💻


职场AI,就用扣子
AI办公助手,复杂任务高效处理。办公效率低?扣子空间AI助手支持播客生成、PPT制作、网页开发及报告写作,覆盖科研、商业、舆情等领域的专家Agent 7x24小时响应,生活工作无缝切换,提升50%效率!


多风格AI绘画神器
堆友平台由阿里巴巴设计团队创建,作为一款AI驱动的设计工具,专为设计师提供一站式增长服务。功能覆盖海量3D素材、AI绘画、实时渲染以及专业抠图,显著提升设计品质和效率。平台不仅提供工具,还是一个促进创意交流和个人发展的空间,界面友好,适合所有级别的设计师和创意工作者。


零代码AI应用开发平台
零代码AI应用开发平台,用户只需一句话简单描述需求,AI能自动生成小程序、APP或H5网页应用,无需编写代码。


免费创建高清无水印Sora视频
Vora是一个免费创建高清无水印Sora视频的AI工具


最适合小白的AI自动化工作流平台
无需编码,轻松生成可复用、可变现的AI自动化工作流

大模型驱动的Excel数据处理工具
基于大模型交互的表格处理系统,允许用户通过对话方式完成数据整理和可视化分析。系统采用机器学习算法解析用户指令,自动执行排序、公式计算和数据透视等操作,支持多种文件格式导入导出。数据处理响应速度保持在0.8秒以内,支持超过100万行数据的即时分析。


AI辅助编程,代码自动修复
Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。


AI论文写作指导平台
AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。


AI一键生成PPT,就用博思AIPPT!
博思AIPPT,新一代的AI生成PPT平台,支持智能生成PPT、AI美化PPT、文本&链接生成PPT、导入Word/PDF/Markdown文档生成PPT等,内置海量精美PPT模板,涵盖商务、教育、科技等不同风格,同时针对每个页面提供多种版式,一键自适应切换,完美适配各种办公场景。


AI赋能电商视觉革命,一站式智能商拍平台
潮际好麦深耕服装行业,是国内AI试衣效果最好的软件。使用先进AIGC能力为电商卖家批量提供优质的、低成本的商拍图。合作品牌有Shein、Lazada、安踏、百丽等65个国内外头部品牌,以及国内10万+淘宝、天猫、京东等主流平台的品牌商家,为卖家节省将近85%的出图成本,提升约3倍出图效率, 让品牌能够快速上架。
最新AI工具、AI资讯
独家AI资源、AI项目落地

微信扫一扫关注公众号