[Lean主页][1] | [文档][2] | [下载Zip][3] | [Docker Hub][8] | [Nuget][9]
简介
Lean引擎是一个开源的算法交易引擎,专为便捷的策略研究、回测和实时交易而设计。我们与常见的数据提供商和经纪商集成,让您能够快速部署算法交易策略。
LEAN引擎的核心是用C#编写的,但它可以在Linux、Mac和Windows操作系统上无缝运行。它支持用Python 3.11或C#编写的算法。Lean驱动了基于网络的算法交易平台[QuantConnect][4]。
自豪地由以下机构赞助
想在这里展示您公司的logo吗?[赞助LEAN](https://github.com/sponsors/QuantConnect),成为彻底开放的算法交易创新的一部分。
QuantConnect正在招聘!
加入我们的团队,解决量化金融领域最具挑战性的问题。如果您对算法交易充满热情,我们很乐意听到您的声音。我们始终欢迎出色的C#工程师。申请时,请务必提及您是通过GitHub了解到我们的:
-
C#工程师:远程职位,通过开源项目LEAN扩展LEAN的核心。
-
TypeScript/KnockOut开发人员:改进用户体验、图表和其他用户界面。
系统概览
该引擎被分为多个模块化部分,可以在不触及其他文件的情况下进行扩展。这些模块在config.json中被配置为"环境"。您可以通过这些环境控制LEAN以所需的模式运行。
最重要的插件包括:
-
结果处理 (IResultHandler)
处理算法交易引擎的所有消息。决定应发送什么以及消息应该去向何处。结果处理系统可以将消息发送到本地GUI或网络界面。
-
数据馈源 (IDataFeed)
连接并下载算法交易引擎所需的数据。对于回测,该提供程序从磁盘获取文件;对于实时交易,它连接到数据流并生成数据对象。
-
交易处理 (ITransactionHandler)
处理新的订单请求,可以使用算法提供的填充模型或实际经纪商。将处理后的订单发回算法的投资组合以进行填充。
-
实时事件管理 (IRealtimeHandler)
生成实时事件 - 如每日结束事件。触发实时事件处理程序的回调。对于回测,这是模拟的,以在模拟时间上工作。
-
算法状态设置 (ISetupHandler)
配置算法现金、投资组合和请求的数据。初始化所有所需的状态参数。
这些都可以在Launcher项目的config.json文件中进行配置。
使用Visual Studio Code Dev Containers进行开发
Dev Containers扩展让您可以使用Docker容器作为全功能开发环境。该扩展启动(或连接到)运行_quantconnect/research:latest_镜像的开发容器。
使用Visual Studio Code Dev Containers开发Lean的详细说明可以在VS Code集成项目中找到。
使用Lean CLI进行开发
QuantConnect推荐使用Lean CLI进行本地算法开发。这是因为它是一个非常好的工具,可以在本地处理您的算法,同时仍能部署到云端并访问Lean数据。它还可以通过我们的官方docker镜像在您的本地机器上运行算法,使用您的数据。
请参考QuantConnect关于Lean CLI的文档
安装说明
本节将介绍如何在您的环境中本地安装lean以供使用。有关使用本地IDE与Lean的详细指南,请参阅以下readme文件:
要本地安装,请下载包含最新主分支的zip文件,并解压到您喜欢的位置。或者,安装Git并克隆仓库:
git clone https://github.com/QuantConnect/Lean.git
cd Lean
macOS
-
在Visual Studio中打开
QuantConnect.Lean.sln
Visual Studio 将自动开始恢复 NuGet 包。如果没有自动恢复,请在菜单栏点击"项目 > 还原 NuGet 包"。 -
在菜单栏中,点击"运行 > 开始调试"。
或者,运行编译后的 dll 文件。首先,在菜单栏中点击"生成 > 生成所有",然后:
cd Lean/Launcher/bin/Debug
dotnet QuantConnect.Lean.Launcher.dll
Linux (Debian, Ubuntu)
- 安装 dotnet 6:
- 编译 Lean 解决方案:
dotnet build QuantConnect.Lean.sln
- 运行 Lean:
cd Launcher/bin/Debug
dotnet QuantConnect.Lean.Launcher.dll
Windows
- 安装 Visual Studio
- 在 Visual Studio 中打开
QuantConnect.Lean.sln
- 通过点击"生成"菜单 -> "生成解决方案"来构建解决方案(这应该会触发 NuGet 包的还原)
- 按
F5
运行
Python 支持
完整的 Python 安装过程说明可以在 Algorithm.Python 项目中找到。
本地-云混合开发
在您喜欢的开发环境中无缝地进行本地开发,具有完整的自动完成和调试支持,可以快速轻松地识别策略中的问题。更多信息请参阅 CLI 主页。
问题和功能请求
请将 bug 和功能请求作为 issue 提交到 [Lean 仓库][5]。在提交 issue 之前,请阅读说明以确保不会重复。
邮件列表
项目的邮件列表可以在 [LEAN 论坛][6]上找到。请使用此论坛询问有关安装和设置的问题。
贡献者和拉取请求
我们热烈欢迎贡献,但我们要求您阅读现有代码,了解其格式和注释方式,并确保贡献与现有风格相匹配。所有代码提交必须包含相应的测试。请查看[贡献者指南][7]。所有被接受的拉取请求将在 QuantConnect 获得 50 美元的云点数。一旦您的拉取请求被合并,请发邮件至 support@quantconnect.com,附上您的 PR 链接,以申领您的免费实盘交易。QC <3 开源。
致谢
如果没有先驱者的支持,QuantConnect 的开源化是不可能实现的。先驱者们组成了 QuantConnect 的核心 100 名早期采用者,他们订阅并允许我们将项目开源。
Ryan H, Pravin B, Jimmie B, Nick C, Sam C, Mattias S, Michael H, Mark M, Madhan, Paul R, Nik M, Scott Y, BinaryExecutor.com, Tadas T, Matt B, Binumon P, Zyron, Mike O, TC, Luigi, Lester Z, Andreas H, Eugene K, Hugo P, Robert N, Christofer O, Ramesh L, Nicholas S, Jonathan E, Marc R, Raghav N, Marcus, Hakan D, Sergey M, Peter McE, Jim M, INTJCapital.com, Richard E, Dominik, John L, H. Orlandella, Stephen L, Risto K, E.Subasi, Peter W, Hui Z, Ross F, Archibald112, MooMooForex.com, Jae S, Eric S, Marco D, Jerome B, James B. Crocker, David Lypka, Edward T, Charlie Guse, Thomas D, Jordan I, Mark S, Bengt K, Marc D, Al C, Jan W, Ero C, Eranmn, Mitchell S, Helmuth V, Michael M, Jeremy P, PVS78, Ross D, Sergey K, John Grover, Fahiz Y, George L.Z., Craig E, Sean S, Brad G, Dennis H, Camila C, Egor U, David T, Cameron W, Napoleon Hernandez, Keeshen A, Daniel E, Daniel H, M.Patterson, Asen K, Virgil J, Balazs Trader, Stan L, Con L, Will D, Scott K, Barry K, Pawel D, S Ray, Richard C, Peter L, Thomas L., Wang H, Oliver Lee, Christian L.