/*
* 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 Python.Runtime;
using QuantConnect.Algorithm.Framework.Portfolio;
using QuantConnect.Data.UniverseSelection;
using QuantConnect.Python;
using System;
namespace QuantConnect.Algorithm.Framework.Execution
{
///
/// Provides an implementation of that wraps a object
///
public class ExecutionModelPythonWrapper : ExecutionModel
{
private readonly BasePythonWrapper _model;
///
/// Constructor for initialising the class with wrapped object
///
/// Model defining how to execute trades to reach a portfolio target
public ExecutionModelPythonWrapper(PyObject model)
{
_model = new BasePythonWrapper(model, false);
foreach (var attributeName in new[] { "Execute", "OnSecuritiesChanged" })
{
if (!_model.HasAttr(attributeName))
{
throw new NotImplementedException($"IExecutionModel.{attributeName} must be implemented. Please implement this missing method on {model.GetPythonType()}");
}
}
}
///
/// Submit orders for the specified portfolio targets.
/// This model is free to delay or spread out these orders as it sees fit
///
/// The algorithm instance
/// The portfolio targets to be ordered
public override void Execute(QCAlgorithm algorithm, IPortfolioTarget[] targets)
{
_model.InvokeMethod(nameof(Execute), algorithm, targets).Dispose();
}
///
/// Event fired each time the we add/remove securities from the data feed
///
/// The algorithm instance that experienced the change in securities
/// The security additions and removals from the algorithm
public override void OnSecuritiesChanged(QCAlgorithm algorithm, SecurityChanges changes)
{
_model.InvokeMethod(nameof(OnSecuritiesChanged), algorithm, changes).Dispose();
}
}
}