转载需注明出处:http://blog.csdn.net/minimicall,http://cloudtrade.top/

指标(Indicator)由三大关键组件组成:
1. 实现你指标的类
2. 在ACAlgorithm基类中的Helper方法,用于简化对你指标实现的调用。
3. 测试方法用于测试指标的表现。
为了实现一个指标,上述所有组件需要实现。下面的教程会带你浏览这些组件。我们将会使用  AroonOscillator作为案例。我们不会去介绍指标的基本概念。

1. 实现你的指标(Implementing Your Indicator)

你的指标类应该在工程根下的QuantConnect.Indicators项目下实现。它必须是一个单独的类,不能缩写,名如“AroonOscillator.cs”。
第一步
指标必须是下面指标基类的一个派生:
Indicator – 如果你的指标只需要单个值(例如ExponontialMovingAverage),你就可以用Indicator作为基类。
TradeBarIndicator – 如果你的指标需要用到TradeBars,那么你的指标必须是由TradeBarIndicator类扩展而来的。(例如AroonOscillator)。
WindowIndicator<T> - 如果你的指标需要一个rolling window of data(数据的滚动窗口),那么你就要继承这个类。(例如Minimum)。

所有的指标都必须实现下面四个组件,为了在Lean中正常运作。
Constructor – 实现你的构造函数,用于接收和保存必要的指标配置信息。例如Aroon指标需要Aroon Up 和 Aroon Down值。
IsReady – 它是一个Boolean值,用于指示算法是否有了充足的历史价格数据用于算出指标的值。Aroon只有当有了n个周期的样本数据后才能开始计算。
ComputeNextValue()- 用提供的数据,计算和返回下一个指标的值。这里是你实现指标具体算法的地方。
保持可扩展性
Aroon作为案例是非常有代表性的,它有多个属性,Aroon-Up和Aroon-Down。这两个值在计算Aroon的时候都需要用到,但只有delta(up – down)会返回。这个例子中的dela叫做Aroon Percentage(比例)。许多指标会有一个主值(Primary value),多个属性,用于交易决策。

为了处理这些情况-每个属性都应该作为子指标(sub-indicator)。你可以查看下AroonOscillator.cs的源码。Aroon创建了AroonUp,AroonDown指标作为属性。这使得你可以单独的使用这些子指标。
例如下面的代码:
var smaAroonUp = sma.Of( aroon.AroonUp )
就直接用属性(子指标)。

现在我们贴出AroonOscillator的代码:

using QuantConnect.Data.Market;namespace QuantConnect.Indicators
{/// <summary>/// The Aroon Oscillator is the difference between AroonUp and AroonDown. The value of this/// indicator fluctuats between -100 and +100. An upward trend bias is present when the oscillator/// is positive, and a negative trend bias is present when the oscillator is negative. AroonUp/Down/// values over 75 identify strong trends in their respective direction./// </summary>public class AroonOscillator : TradeBarIndicator{/// <summary>/// Gets the AroonUp indicator/// </summary>public IndicatorBase<IndicatorDataPoint> AroonUp { get; private set; }/// <summary>/// Gets the AroonDown indicator/// </summary>public IndicatorBase<IndicatorDataPoint> AroonDown { get; private set; }/// <summary>/// Gets a flag indicating when this indicator is ready and fully initialized/// </summary>public override bool IsReady{get { return AroonUp.IsReady && AroonDown.IsReady; }}/// <summary>/// Creates a new AroonOscillator from the specified up/down periods./// </summary>/// <param name="upPeriod">The lookback period to determine the highest high for the AroonDown</param>/// <param name="downPeriod">The lookback period to determine the lowest low for the AroonUp</param>public AroonOscillator(int upPeriod, int downPeriod): this(string.Format("AROON({0},{1})", upPeriod, downPeriod), upPeriod, downPeriod){}/// <summary>/// Creates a new AroonOscillator from the specified up/down periods./// </summary>/// <param name="name">The name of this indicator</param>/// <param name="upPeriod">The lookback period to determine the highest high for the AroonDown</param>/// <param name="downPeriod">The lookback period to determine the lowest low for the AroonUp</param>public AroonOscillator(string name, int upPeriod, int downPeriod): base(name){var max = new Maximum(name + "_Max", upPeriod + 1);AroonUp = new FunctionalIndicator<IndicatorDataPoint>(name + "_AroonUp",input => ComputeAroonUp(upPeriod, max, input),aroonUp => max.IsReady,() => max.Reset());var min = new Minimum(name + "_Min", downPeriod + 1);AroonDown = new FunctionalIndicator<IndicatorDataPoint>(name + "_AroonDown",input => ComputeAroonDown(downPeriod, min, input),aroonDown => min.IsReady,() => min.Reset());}/// <summary>/// Computes the next value of this indicator from the given state/// </summary>/// <param name="input">The input given to the indicator</param>/// <returns>A new value for this indicator</returns>protected override decimal ComputeNextValue(TradeBar input){AroonUp.Update(input.Time, input.High);AroonDown.Update(input.Time, input.Low);return AroonUp - AroonDown;}/// <summary>/// AroonUp = 100 * (period - {periods since max})/period/// </summary>/// <param name="upPeriod">The AroonUp period</param>/// <param name="max">A Maximum indicator used to compute periods since max</param>/// <param name="input">The next input data</param>/// <returns>The AroonUp value</returns>private static decimal ComputeAroonUp(int upPeriod, Maximum max, IndicatorDataPoint input){max.Update(input);return 100m * (upPeriod - max.PeriodsSinceMaximum) / upPeriod;}/// <summary>/// AroonDown = 100 * (period - {periods since min})/period/// </summary>/// <param name="downPeriod">The AroonDown period</param>/// <param name="min">A Minimum indicator used to compute periods since min</param>/// <param name="input">The next input data</param>/// <returns>The AroonDown value</returns>private static decimal ComputeAroonDown(int downPeriod, Minimum min, IndicatorDataPoint input){min.Update(input);return 100m * (downPeriod - min.PeriodsSinceMinimum) / downPeriod;}/// <summary>/// Resets this indicator and both sub-indicators (AroonUp and AroonDown)/// </summary>public override void Reset(){AroonUp.Reset();AroonDown.Reset();base.Reset();}}
}

2 在QCAlgorithm中安装Helper方法

在你实现了indicator(指标)之后,i需要将它安装到基类中。指标可以手工的创建和更新,不过我们加你使用helper方法,这样后面使用起来会简单很多。
在Aroon的案例中,实现是在AroonOscillator类,但它的helper方法是在QCAlgorithm中。这个helper方法—AROON—总是是大写的,总是返回一个指标实现类的实例对象。

public AroonOscillator AROON(string symbol, int upPeriod, int downPeriod, Resolution? resolution = null)  {var name = CreateIndicatorName(symbol, string.Format("AROON({0},{1})", upPeriod, downPeriod), resolution);var aroon = new AroonOscillator(name, upPeriod, downPeriod);RegisterIndicator(symbol, aroon, resolution);return aroon;
}

在helper方法中,你需要创建你指标的一个唯一的名字,使用你指标实现类的构造函数去构造一个指标实例,将其注册(注册后意味着指标的值会随着symbol(指定证券)的价格数据变动而自动的变动)。

3 创建测试方法

3.1 准备测试数据

将准备好的测试数据放到QuantConnect.Tests\TestData目录下。

3.2 写测试类

在QuantConnect.Tests\Indicators下面。可以拷贝已经有的进行改写。

using System;
using NUnit.Framework;
using QuantConnect.Data.Market;
using QuantConnect.Indicators;namespace QuantConnect.Tests.Indicators
{[TestFixture]public class AroonOscillatorTests{[Test]public void ComparesWithExternalData(){var aroon = new AroonOscillator(14, 14);TestHelper.TestIndicator(aroon, "spy_aroon_oscillator.txt", "Aroon Oscillator 14",(i, expected) => Assert.AreEqual(expected, (double)aroon.Current.Value, 1e-3));}[Test]public void ResetsProperly(){var aroon = new AroonOscillator(3, 3);aroon.Update(new TradeBar{Symbol = "SPY",Time = DateTime.Today,Open = 3m,High = 7m,Low = 2m,Close = 5m,Volume = 10});aroon.Update(new TradeBar{Symbol = "SPY",Time = DateTime.Today.AddSeconds(1),Open = 3m,High = 7m,Low = 2m,Close = 5m,Volume = 10});aroon.Update(new TradeBar{Symbol = "SPY",Time = DateTime.Today.AddSeconds(2),Open = 3m,High = 7m,Low = 2m,Close = 5m,Volume = 10});Assert.IsFalse(aroon.IsReady);aroon.Update(new TradeBar{Symbol = "SPY",Time = DateTime.Today.AddSeconds(3),Open = 3m,High = 7m,Low = 2m,Close = 5m,Volume = 10});Assert.IsTrue(aroon.IsReady);aroon.Reset();TestHelper.AssertIndicatorIsInDefaultState(aroon);TestHelper.AssertIndicatorIsInDefaultState(aroon.AroonUp);TestHelper.AssertIndicatorIsInDefaultState(aroon.AroonDown);}}
}

程序员的量化交易(34)--QuantConnect_Lean如何定义Indicator指标2相关推荐

  1. 程序员的量化交易之路(1)----规划开篇

    其实,一直对量化交易有一定的理解和情节.早在中大读研究生的时候实验室师兄,已经去了中国平安核心投资团队,做高频交易研究的国源师兄的影响,就开始对金融世界产生了浓厚的兴趣.看了丁磊编著的<量化投资 ...

  2. 程序员转行量化交易可行吗?

    程序员转量化交易,其实是一件挺顺理成章的事,有一位网友他想向我佐证一下,职业量化交易这一条路,他可以做下去吗,以及其它一些细枝末节的问题. 他以前是某日系合资企业的程序工程师,程序背景是C++与pyt ...

  3. 热议:程序员转行量化交易可行吗?

    程序员转量化交易,其实是一件挺顺理成章的事,就在上周,有一位网友来我的店里拜访我,其实他来的目的也特别简单,他想向我佐证一下,职业量化交易这一条路,他可以做下去吗,以及其它一些细枝末节的问题. 他以前 ...

  4. 程序员的量化交易之路(35)--Lean之DataFeed数据槽3

    转载需注明出处:http://blog.csdn.net/minimicall,http://cloudtrade.top/ Lean引擎的模块划分非常的规范.其中DataFeed是数据槽,就是供应数 ...

  5. 程序员的量化交易之路(25)--Cointrader之MarketData市场数据实体(12)

    转载需注明出处:http://blog.csdn.net/minimicall,http://cloudtrade.top/ 前面一节我们说到了远端事件.其中,市场数据就属于远端事件.市场数据有什么? ...

  6. 程序员的量化交易之路(17)--Cointrader之Temporal实体(5)

    转载需要注明:http://blog.csdn.net/minimicall,http://cloudtrader.top/ 这一小节说明一个时间实体Temporal实体,它的代码很简单. packa ...

  7. 程序员的量化交易之路(26)--Cointrader之Listing挂牌实体(13)

    转载须注明出处:http://blog.csdn.net/minimicall?viewmode=contents,http://cloudtrade.top Listing:挂牌.比如某只股票在某证 ...

  8. 通达信程序接口与量化交易之间的关系

    通达信程序接口与量化交易之间的关系,分布式节点共识算法. 1.通达信程序接口每当产生一个新的块,即数据更新时,需要通过算法识别整个网络中超过一半的节点,从而形成一个新的块,即投票机制,等等.超过一半的 ...

  9. 《那些年啊,那些事——一个程序员的奋斗史》——34

    搬家之后,段伏枥上班也算不上很近,毕竟以前还有地铁,时间上还是可控的,现在只能挤着公交,确实有点不太方便.可能最为郁闷的是,在泥岗村根本没有到公司的公交,只能步行两个站的距离到银湖汽车站去乘坐4路公交 ...

最新文章

  1. InnoDB调优-索引优化策略
  2. 更改Linux用户的登录shell环境
  3. PHP和MySQL入门(3)
  4. CentOS 7下宿主机使用virsh console访问KVM的设置
  5. GraphQL入门之进一步了解GraphQL
  6. 连接格点(信息学奥赛一本通-T1394)
  7. datatable 参数详细说明
  8. Atitit 学校工作手册attilax艾提拉总结 目录 1. 团队文化 宗旨 与使命 2 1.1. 学术教育vs 技术教育vs 技能职业教育 2 1.2. 天堂模式vs地狱模式 2 2. 组织结构
  9. android 应用程序Activity之间数据传递与共享的几种途径
  10. 朗途职业规划之一 职业发展报告 (北森测评)
  11. 深入理解JVM虚拟机读书笔记——垃圾回收器
  12. 集团企业信息化规划和实施研究
  13. 数据挖掘实战—航空公司客户价值分析
  14. 英文投稿的一点经验【转载】
  15. 联机带AI版3D桌球游戏源码
  16. maya海龟烘焙法线_maya法线烘焙
  17. SM干货篇:你应该具备的提问技巧!
  18. 大学平均绩点计算器_【采访合集】大一必知“绩点”与“奥方面试”
  19. Windows7更改自己的计算机名,方便局域网内的用户识别
  20. 软件测试常见面试题及答案

热门文章

  1. python金融代码_Python2爬虫代码之获取金融品种行情数据
  2. r roc函数_R语言画ROC曲线总结
  3. 模拟京东快递单号的查询效果
  4. 【FPGA】SRIO IP核系统总览以及端口介绍(二)(I/O Port 含义介绍)
  5. FPGA设计思想之“逻辑复制”
  6. 初识Tcl(一):Tcl 命令
  7. 数据库持久层封装设计
  8. CBAC ftp测试
  9. Mac写文件到U盘的方法
  10. console.log()的兼容性