Lean  $LEAN_TAG$
DividendYieldModelPythonWrapper.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;
17 using Python.Runtime;
18 using QuantConnect.Data;
19 
20 namespace QuantConnect.Python
21 {
22  /// <summary>
23  /// Wraps a <see cref="PyObject"/> object that represents a dividend yield model
24  /// </summary>
26  {
27  /// <summary>
28  /// Constructor for initializing the <see cref="DividendYieldModelPythonWrapper"/> class with wrapped <see cref="PyObject"/> object
29  /// </summary>
30  /// <param name="model">Represents a security's model of dividend yield</param>
31  public DividendYieldModelPythonWrapper(PyObject model)
32  : base(model)
33  {
34  }
35 
36  /// <summary>
37  /// Get dividend yield by a given date of a given symbol
38  /// </summary>
39  /// <param name="date">The date</param>
40  /// <returns>Dividend yield on the given date of the given symbol</returns>
41  public decimal GetDividendYield(DateTime date)
42  {
43  return InvokeMethod<decimal>(nameof(GetDividendYield), date);
44  }
45 
46  /// <summary>
47  /// Get dividend yield at given date and security price
48  /// </summary>
49  /// <param name="date">The date</param>
50  /// <param name="securityPrice">The security price at the given date</param>
51  /// <returns>Dividend yield on the given date of the given symbol</returns>
52  /// <remarks>Price data must be raw (<see cref="DataNormalizationMode.Raw"/>)</remarks>
53  public decimal GetDividendYield(DateTime date, decimal securityPrice)
54  {
55  return InvokeMethod<decimal>(nameof(GetDividendYield), date, securityPrice);
56  }
57 
58  /// <summary>
59  /// Converts a <see cref="PyObject"/> object into a <see cref="IDividendYieldModel"/> object, wrapping it if necessary
60  /// </summary>
61  /// <param name="model">The Python model</param>
62  /// <returns>The converted <see cref="IDividendYieldModel"/> instance</returns>
63  public static IDividendYieldModel FromPyObject(PyObject model)
64  {
65  if (!model.TryConvert(out IDividendYieldModel dividendYieldModel))
66  {
67  dividendYieldModel = new DividendYieldModelPythonWrapper(model);
68  }
69 
70  return dividendYieldModel;
71  }
72  }
73 }