/*
* 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 Newtonsoft.Json;
using System;
namespace QuantConnect.Optimizer.Parameters
{
///
/// Defines the step based optimization parameter
///
public class OptimizationStepParameter : OptimizationParameter
{
///
/// Minimum value of optimization parameter, applicable for boundary conditions
///
[JsonProperty("min")]
public decimal MinValue { get; }
///
/// Maximum value of optimization parameter, applicable for boundary conditions
///
[JsonProperty("max")]
public decimal MaxValue { get; }
///
/// Movement, should be positive
///
[JsonProperty("step")]
public decimal? Step { get; set; }
#pragma warning disable CS1574
///
/// Minimal possible movement for current parameter, should be positive
///
/// Used by to determine when this parameter can no longer be optimized
[JsonProperty("minStep")]
#pragma warning restore CS1574
public decimal? MinStep { get; set; }
///
/// Create an instance of based on configuration
///
/// parameter name
/// minimal value
/// maximal value
public OptimizationStepParameter(string name, decimal min, decimal max)
: base(name)
{
if (min > max)
{
throw new ArgumentException(Messages.OptimizationStepParameter.InvalidStepRange(min, max));
}
MinValue = min;
MaxValue = max;
}
///
/// Create an instance of based on configuration
///
/// parameter name
/// minimal value
/// maximal value
/// movement
public OptimizationStepParameter(string name, decimal min, decimal max, decimal step)
: this(name, min, max, step, step)
{
}
///
/// Create an instance of based on configuration
///
/// parameter name
/// minimal value
/// maximal value
/// movement
/// minimal possible movement
public OptimizationStepParameter(string name, decimal min, decimal max, decimal step, decimal minStep) : this(name, min, max)
{
// with zero step algorithm can go to infinite loop, use default step value
if (step <= 0)
{
throw new ArgumentException(Messages.OptimizationStepParameter.NonPositiveStepValue(nameof(step), step));
}
// EulerSearch algorithm can go to infinite range division if Min step is not provided, use Step as default
if (minStep <= 0)
{
throw new ArgumentException(Messages.OptimizationStepParameter.NonPositiveStepValue(nameof(minStep), minStep));
}
if (step < minStep)
{
throw new ArgumentException(Messages.OptimizationStepParameter.StepLessThanMinStep);
}
Step = step;
MinStep = minStep;
}
}
}