Overall Statistics
Total Trades
0
Average Win
0%
Average Loss
0%
Compounding Annual Return
0%
Drawdown
0%
Expectancy
0
Net Profit
0%
Sharpe Ratio
NaN
Loss Rate
0%
Win Rate
0%
Profit-Loss Ratio
0
Alpha
0
Beta
0
Annual Standard Deviation
0
Annual Variance
0
Information Ratio
NaN
Tracking Error
NaN
Treynor Ratio
NaN
Total Fees
$0.00
namespace QuantConnect 
{   
    /*
    *   QuantConnect University: Full Basic Template:
    *
    *   The underlying QCAlgorithm class is full of helper methods which enable you to use QuantConnect.
    *   We have explained some of these here, but the full algorithm can be found at:
    *   https://github.com/QuantConnect/QCAlgorithm/blob/master/QuantConnect.Algorithm/QCAlgorithm.cs
    */
    public class BasicTemplateAlgorithm : QCAlgorithm
    {
        private string symbol = "IBB";
        private IndicatorBase<IndicatorDataPoint> _volatility;
        
        //Initialize the data and resolution you require for your strategy:
        public override void Initialize() 
        {
			
            //Start and End Date range for the backtest:
            SetStartDate(2010, 3, 31);         
            SetEndDate(DateTime.Now.Date.AddDays(-1));
            
            //Cash allocation
            SetCash(25000);
            
            //Add as many securities as you like. All the data will be passed into the event handler:
            AddSecurity(SecurityType.Equity, symbol, Resolution.Daily);
            
            var logr = new LogReturn(84);
            RegisterIndicator(symbol, logr, ResolveConsolidator(symbol, Resolution.Daily));
            _volatility = new StandardDeviation("4Month Vol", 84).Of(logr);
            PlotIndicator(symbol, _volatility);
            
        }

        //Data Event Handler: New data arrives here. "TradeBars" type is a dictionary of strings so you can access it by symbol.
        public void OnData(TradeBars data) 
        {
            
        }
    }
    
    public class LogReturn : WindowIndicator<IndicatorDataPoint>
    {
        public LogReturn(string name, int period)
            : base(name, period)
        {
        }

        public LogReturn(int period)
            : base("LOGR" + period, period)
        {
        }

        protected override decimal ComputeNextValue(IReadOnlyWindow<IndicatorDataPoint> window, IndicatorDataPoint input)
        {
            decimal valuef = input;

            decimal value0 = !window.IsReady 
                ? window[window.Count - 1] 
                : window.MostRecentlyRemoved;

            return (decimal) Math.Log((double) (valuef/value0));
        }
    }
}