API Reference
lean optimize
Description
Runs a local optimization in a Docker container using the quantconnect/lean Docker image.
The logs of the optimizer are shown in real-time and the full results of the optimizer and all executed backtests are stored in the <project> / optimizations / <timestamp> directory.
You can use the --output
option to change the output directory.
The given <project>
argument must be either a project directory or a file containing the algorithm to optimize.
If it is a project directory, the CLI looks for a main.py or Main.cs file, assuming the first file it finds to contain the algorithm to optimize.
By default, an interactive wizard is shown letting you configure the optimizer.
When --optimizer-config
or --strategy
is given, the command runs in non-interactive mode and doesn't prompt for input.
When the --optimizer-config <config file>
option is given, the specified config file is used.
This option must point to a file containing a full optimizer config (the algorithm-type-name
, algorithm-language
and algorithm-location
properties may be omitted).
See the Optimizer.Launcher / config.example.json file in the LEAN repository for an example optimizer configuration file, which also contains documentation on all the required properties.
When --strategy
is given, the optimizer configuration is read from the command-line options.
This means the --strategy
, --target
, --target-direction
, and --parameter
options become required.
Additionally, you can also use --constraint
to specify optimization constraints.
In non-interactive mode, the parameters can be configured using the --parameter
option.
This option takes the following values: the name of the parameter, its minimum value, its maximum value, and its step size.
You can provide this option multiple times to configure multiple parameters.
In non-interactive mode, the constraints can be configured using the --constraint
option.
This option takes a "statistic operator value" string as value, where the statistic must be a path to a property in a backtest's output file, like "TotalPerformance.PortfolioStatistics.SharpeRatio".
This statistic can also be shortened to "SharpeRatio" or "Sharpe Ratio", in which case the command automatically converts it to the longer version.
The value must be a number and the operator must be <
, >
, <=
, >=
, ==
, or ==
.
You can provide this option multiple times to configure multiple constraints.
You can use the --data-provider-historical
option to change where the data is retrieved.
This option updates the Lean configuration file, so you don't need to use this option multiple times for the same data provider if you are not switching between them.
The following table shows the available data providers and their required options in non-interactive mode:
--data-provider-historical | Required Options |
---|---|
AlphaVantage | --alpha-vantage-api-key |
--alpha-vantage-price-plan | |
IEX | --iex-cloud-api-key |
--iex-price-plan | |
IQFeed | --iqfeed-iqconnect |
--iqfeed-username | |
--iqfeed-password | |
--iqfeed-version | |
--iqfeed-host | |
Local | N/A |
Polygon | --polygon-api-key |
QuantConnect | N/A |
"Terminal Link" | --terminal-link-connection-type |
--terminal-link-environment | |
--terminal-link-server-host | |
--terminal-link-server-port | |
--terminal-link-emsx-broker | |
--terminal-link-openfigi-api-key | |
--terminal-link-server-auth-id if you use --terminal-link-connection-type SAPI | |
ThetaData | --thetadata-subscription-plan |
You can use the --download-data
flag as an alias for --data-provider-historical QuantConnect
. This data provider automatically downloads the required data files when your backtest requests them. After it downloads a data file, it stores it in your local data directory so that in future runs, it won't have to download it again. If the file contain data for multiple days (for example, daily Equity price data files), the ApiDataProvider
re-downloads the file if your local version is at least 7 days old. To adjust this setting, update the downloader-data-update-period
value in your Lean configuration file.
Example non-interactive usage:
$ lean optimize "My Project" \ --strategy "Grid Search" \ --target "Sharpe Ratio" \ --target-direction "max" \ --parameter my-first-parameter 1 10 0.5 \ --parameter my-second-parameter 20 30 5 \ --constraint "Drawdown < 0.5" \ --constraint "Sharpe Ratio >= 1"
To estimate the cost of running an optimization job without actually running it, add the --estimate
option to the command. You need to backtest the project at least once in order to estimate the cost of optimizing it.
To set the maximum number of concurrent backtests to run, use the --max-concurrent-backtests
option.
The Docker image that's used contains the same libraries as the ones available on QuantConnect. If the selected project is a C# project, it is compiled before starting the optimization.
By default, the official LEAN engine image is used.
You can override this using the --image <value>
option.
Alternatively, you can set the default engine image for all commands using lean config set engine-image <value>
.
The image is pulled before running the optimizer if it doesn't exist locally yet or if you pass the --update
flag.
Options
The lean optimize
command supports the following options:
Option | Description |
---|---|
--output <path> | Directory to store results in (defaults to <project> / optimizations / <timestamp>). |
--detach , -d | Run the optimization in a detached Docker container and return immediately. The name of the Docker container is shown before the command ends. You can use Docker's own commands to manage the detached container. |
--optimizer-config <path> | The optimizer configuration file that should be used (the algorithm-type-name , algorithm-language and algorithm-location properties may be omitted). See the Optimizer.Launcher / config.example.json file in the LEAN repository for an example optimizer config file. |
--strategy <value> | The optimization strategy to use in non-interactive mode. Must be Grid Search or Euler Search . |
--target <value> | The path to the property in the backtest's output file to target, like "TotalPerformance.PortfolioStatistics.SharpeRatio". May also be a shortened version, like "SharpeRatio" or "Sharpe Ratio". |
--target-direction <value> | min if the target must be minimized, max if it must be maximized. |
--parameter <name> <min> <max> <step> | The 'parameter min max step' pairs configuring the parameters to optimize. May be used multiple times. |
--constraint <value> | The 'statistic operator value' pairs configuring the constraints of the optimization. May be used multiple times. |
--data-provider-historical | The historical data source. |
--download-data | Update the Lean configuration file to download data from the QuantConnect API, alias for --data-provider-historical QuantConnect . |
--data-purchase-limit | |
--release | Compile C# projects in release configuration instead of debug. |
--image <value> | The LEAN engine image to use (defaults to quantconnect/lean:latest ). |
--update | Pull the LEAN engine image before running the optimizer. |
--estimate | Estimate optimization runtime without running it. |
--max-concurrent-backtests <value> | Maximum number of concurrent backtests to run (x >= 1). |
--extra-docker-config | |
--no-update | Use the local LEAN engine image instead of pulling the latest version. |
--iqfeed-iqconnect <path> | The path to your IQConnect binary. |
--iqfeed-username <value> | Your IQFeed username. |
--iqfeed-password <value> | Your IQFeed password. |
--iqfeed-version <value> | The product version of your IQFeed developer account. |
--iqfeed-host | The IQFeed host address. |
--polygon-api-key <value> | Your Polygon.io API Key. |
--iex-cloud-api-key | Your IEX Cloud API Key. |
--iex-price-plan | Your IEX Cloud price plan. Launch , Grow , or Enterprise . |
--alpha-vantage-api-key | Your Alpha Vantage API Key. |
--alpha-vantage-price-plan | Your Alpha Vantage price plan. Free , Plan30 , Plan75 , Plan150 , Plan300 , Plan600 , or Plan1200 . |
--coinapi-api-key | |
--coinapi-product | |
--terminal-link-connection-type <value> | The Terminal Link connection type, which must be SAPI or DAPI . |
--terminal-link-server-auth-id <value> | Your unique user identifier (UUID). The UUID is a unique integer identifier that's assigned to each Bloomberg Anywhere user. If you don't know your UUID, contact Bloomberg. |
--terminal-link-environment <value> | The environment to run in, which must be Production or Beta . |
--terminal-link-server-host <value> | The host on which the Terminal Link server is running. |
--terminal-link-server-port <value> | The port on which the Terminal Link server is running. |
--terminal-link-openfigi-api-key <value> | The Open FIGI API key to use for mapping Options. |
--lean-config <path> | The Lean configuration file that should be used (defaults to the nearest lean.json file). |
--verbose | Enable debug logging. |
--help | Display the help text of the lean optimize command and exit. |