Lean  $LEAN_TAG$
ConstantFeeModel.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;
18 
20 {
21  /// <summary>
22  /// Provides an order fee model that always returns the same order fee.
23  /// </summary>
24  public class ConstantFeeModel : FeeModel
25  {
26  private readonly decimal _fee;
27  private readonly string _currency;
28 
29  /// <summary>
30  /// Initializes a new instance of the <see cref="ConstantFeeModel"/> class with the specified <paramref name="fee"/>
31  /// </summary>
32  /// <param name="fee">The constant order fee used by the model</param>
33  /// <param name="currency">The currency of the order fee</param>
34  public ConstantFeeModel(decimal fee, string currency = "USD")
35  {
36  _fee = Math.Abs(fee);
37  _currency = currency;
38  }
39 
40  /// <summary>
41  /// Returns the constant fee for the model in units of the account currency
42  /// </summary>
43  /// <param name="parameters">A <see cref="OrderFeeParameters"/> object
44  /// containing the security and order</param>
45  /// <returns>The cost of the order in units of the account currency</returns>
46  public override OrderFee GetOrderFee(OrderFeeParameters parameters)
47  {
48  return new OrderFee(new CashAmount(_fee, _currency));
49  }
50  }
51 }