Lean  $LEAN_TAG$
Messages.Orders.Slippage.cs
1 /*
2  * QUANTCONNECT.COM - Democratizing Finance, Empowering Individuals.
3  * Lean Algorithmic Trading Engine v2.0. Copyright 2014 QuantConnect Corporation.
4  *
5  * Licensed under the Apache License, Version 2.0 (the "License");
6  * you may not use this file except in compliance with the License.
7  * You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0
8  *
9  * Unless required by applicable law or agreed to in writing, software
10  * distributed under the License is distributed on an "AS IS" BASIS,
11  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12  * See the License for the specific language governing permissions and
13  * limitations under the License.
14 */
15 
16 using System.Runtime.CompilerServices;
17 
18 using QuantConnect.Data;
19 
20 using static QuantConnect.StringExtensions;
21 
22 namespace QuantConnect
23 {
24  /// <summary>
25  /// Provides user-facing message construction methods and static messages for the <see cref="Orders.Slippage"/> namespace
26  /// </summary>
27  public static partial class Messages
28  {
29  /// <summary>
30  /// Provides user-facing messages for the <see cref="Orders.Slippage.VolumeShareSlippageModel"/> class and its consumers or related classes
31  /// </summary>
32  public static class VolumeShareSlippageModel
33  {
34  /// <summary>
35  /// Returns a message for an invalid market data type in Volume Share Slippage Model
36  /// </summary>
37  [MethodImpl(MethodImplOptions.AggressiveInlining)]
38  public static string InvalidMarketDataType(BaseData data)
39  {
40  return $"VolumeShareSlippageModel.GetSlippageApproximation(): Cannot use this model with market data type {data.GetType()}";
41  }
42 
43  /// <summary>
44  /// Returns a message for a volume not reported for market data type in Volume Share Slippage Model
45  /// </summary>
46  [MethodImpl(MethodImplOptions.AggressiveInlining)]
47  public static string VolumeNotReportedForMarketDataType(SecurityType securityType)
48  {
49  return Invariant($"VolumeShareSlippageModel.GetSlippageApproximation(): {securityType} security type often ") +
50  "does not report volume. If you intend to model slippage beyond the spread, please consider another model.";
51  }
52 
53  /// <summary>
54  /// Returns a message for a negative or zero bar volume in Volume Share Slippage Model
55  /// </summary>
56  [MethodImpl(MethodImplOptions.AggressiveInlining)]
57  public static string NegativeOrZeroBarVolume(decimal barVolume, decimal slippagePercent)
58  {
59  return Invariant($@"VolumeShareSlippageModel.GetSlippageApproximation: Bar volume cannot be zero or negative. Volume: {
60  barVolume}. Using maximum slippage percentage of {slippagePercent}");
61  }
62  }
63  }
64 }