/*
* 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; }
}
}