/* * QUANTCONNECT.COM - Democratizing Finance, Empowering Individuals. * Lean Algorithmic Trading Engine v2.0. Copyright 2014 QuantConnect Corporation. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ using System; using QuantConnect.Securities; namespace QuantConnect.Interfaces { /// /// User settings for the algorithm which can be changed in the method /// public interface IAlgorithmSettings { /// /// Gets whether or not WarmUpIndicator is allowed to warm up indicators /// bool AutomaticIndicatorWarmUp { get; set; } /// /// True if should rebalance portfolio on security changes. True by default /// bool? RebalancePortfolioOnSecurityChanges { get; set; } /// /// True if should rebalance portfolio on new insights or expiration of insights. True by default /// bool? RebalancePortfolioOnInsightChanges { get; set; } /// /// The absolute maximum valid total portfolio value target percentage /// /// This setting is currently being used to filter out undesired target percent values, /// caused by the IPortfolioConstructionModel implementation being used. /// For example rounding errors, math operations decimal MaxAbsolutePortfolioTargetPercentage { get; set; } /// /// The absolute minimum valid total portfolio value target percentage /// /// This setting is currently being used to filter out undesired target percent values, /// caused by the IPortfolioConstructionModel implementation being used. /// For example rounding errors, math operations decimal MinAbsolutePortfolioTargetPercentage { get; set; } /// /// Configurable minimum order margin portfolio percentage to ignore bad orders, or orders with unrealistic sizes /// /// Default minimum order size is $0 value decimal MinimumOrderMarginPortfolioPercentage { get; set; } /// /// Gets/sets the SetHoldings buffers value. /// The buffer is used for orders not to be rejected due to volatility when using SetHoldings and CalculateOrderQuantity /// decimal? FreePortfolioValue { get; set; } /// /// Gets/sets the SetHoldings buffers value percentage. /// This percentage will be used to set the /// based on the /// decimal FreePortfolioValuePercentage { get; set; } /// /// Gets/sets if Liquidate() is enabled /// bool LiquidateEnabled { get; set; } /// /// True if daily strict end times are enabled /// bool DailyPreciseEndTime { get; set; } /// /// True if extended market hours should be used for daily consolidation, when extended market hours is enabled /// bool DailyConsolidationUseExtendedMarketHours { get; set; } /// /// Gets/sets the maximum number of concurrent market data subscriptions available /// /// /// All securities added with are counted as one, /// with the exception of options and futures where every single contract in a chain counts as one. /// [Obsolete("This property is deprecated. Please observe data subscription limits set by your brokerage to avoid runtime errors.")] int DataSubscriptionLimit { get; set; } /// /// Gets the minimum time span elapsed to consider a market fill price as stale (defaults to one hour) /// TimeSpan StalePriceTimeSpan { get; set; } /// /// The warmup resolution to use if any /// /// This allows improving the warmup speed by setting it to a lower resolution than the one added in the algorithm Resolution? WarmupResolution { get; set; } /// /// Gets or sets the number of trading days per year for this Algorithm's portfolio statistics. /// /// /// This property affects the calculation of various portfolio statistics, including: /// - /// - /// - /// - /// - /// - . /// /// The default values are: /// - Cryptocurrency Exchanges: 365 days /// - Traditional Stock Exchanges: 252 days /// /// Users can also set a custom value for this property. /// int? TradingDaysPerYear { get; set; } /// /// Gets the time span used to refresh the market hours and symbol properties databases /// TimeSpan DatabasesRefreshPeriod { get; set; } /// /// Determines whether to terminate the algorithm when an asset is not supported by Lean or the brokerage /// bool IgnoreUnknownAssetHoldings { get; set; } } }