: | : | :期货量化学习 | :期货量化 |
返回列表 发帖

【Pennant】

【Pennant】

  1. inputs:
  2.         Len( numericsimple ),
  3.         MaxConsolIndex( numericsimple ),
  4.         BarsPast( numericsimple ),
  5.         oTLHiStartPr( numericref ),
  6.         oTLHiEndPr( numericref ),
  7.         oTLLoStartPr( numericref ),
  8.         oTLLoEndPr( numericref ) ;

  9. variables:
  10.         var0( Len - 1 ),
  11.         var1( 0 ),
  12.         var2( 0 ),
  13.         var3( 0 ),
  14.         var4( 0 ),
  15.         var5( 0 ),
  16.         var6( 0 ),
  17.         var7( 0 ),
  18.         var8( 0 ),
  19.         var9( 0 ),
  20.         var10( 0 ),
  21.         var11( 0 ),
  22.         var12( 0 ),
  23.         var13( 0 ),
  24.         var14( 0 ),
  25.         var15( 0 ),
  26.         var16( 0 ),
  27.         var17( 0 ),
  28.         var18( 0 ),
  29.         var19( 0 ),
  30.         var20( 1000000 ),
  31.         var21( false ) ;

  32. var1 = -1 ;
  33. var2 = AvgTrueRange( Len ) ;
  34. if var2 > 0 then
  35.         var3 = ( HighestFC( TrueHigh, Len ) - LowestFC( TrueLow, Len ) ) /
  36.          AvgTrueRange( Len )
  37. else
  38.         var3 = MaxConsolIndex + 1 ;
  39. if var3 <= MaxConsolIndex then                 
  40.         begin
  41.         Value1 = LinearReg( High, Len, 0, var4, var5, var6,
  42.          var7 ) ;
  43.         Value1 = LinearReg( Low, Len, 0, var8, var9, var10,
  44.          var11 ) ;
  45.         var18 = var8 - var4 ;
  46.         if var18 >= 0 then                  
  47.                 begin
  48.                 var13 = 0 ;
  49.                 var15 = 0 ;
  50.                 for Value1 = 0 to var0
  51.                         begin
  52.                         var12 = High[Value1] - ( var6 + var4 * ( var0 -
  53.                          Value1 ) ) ;
  54.                         var14 = -( Low[Value1] - ( var10 + var8 * ( var0 -
  55.                          Value1 ) ) ) ;
  56.                         if var12 > var13 then
  57.                                 var13 = var12 ;
  58.                         if var14 > var15 then
  59.                                 var15 = var14 ;
  60.                         end ;
  61.                 oTLHiStartPr = var6 + var13 ;
  62.                 oTLHiEndPr = var7 + var13 ;
  63.                 oTLLoStartPr = var10 - var15 ;
  64.                 oTLLoEndPr = var11 - var15 ;
  65.                 var16 = var4 ;
  66.                 var17 = var8 ;
  67.                 if var18 > 0 then
  68.                         var19 = MinList( BarsPast, ( oTLHiEndPr - oTLLoEndPr ) / var18 )
  69.                 else
  70.                         var19 = BarsPast ;
  71.                 var1 = 1 ;
  72.                 end ;
  73.         end ;

  74. if var1 = 1 then
  75.         begin
  76.         var20 = 0 ;
  77.         var21 = false ;
  78.         end
  79. else
  80.         begin
  81.         var20 = var20 + 1 ;
  82.         if var20 <= var19 then
  83.                 begin
  84.                 oTLHiEndPr = oTLHiStartPr + var16 * ( var0 + var20 ) ;
  85.                 oTLLoEndPr = oTLLoStartPr + var17 * ( var0 + var20 ) ;
  86.                 if var21 = false then
  87.                         begin
  88.                         condition1 = High > oTLHiEndPr and Low > oTLLoEndPr ;
  89.                         if condition1 then
  90.                                 begin
  91.                                 var21 = true ;              
  92.                                 var1 = 2 ;
  93.                                 end
  94.                         else
  95.                         begin
  96.                         condition1 = Low < oTLLoEndPr and High < oTLHiEndPr ;
  97.                         if condition1 then
  98.                                 begin
  99.                                 var21 = true ;              
  100.                                 var1 = 3 ;
  101.                                 end ;
  102.                         end ;
  103.                         end;
  104.                 end
  105.         else
  106.                 begin
  107.                 oTLHiEndPr = 0 ;
  108.                 oTLLoEndPr = 0 ;
  109.                 end ;       
  110.         end ;

  111.                                                                                     
  112.                            
  113. Value1 = Pennant[1] ;

  114. Pennant = var1 ;
复制代码

论坛官方微信、群(期货热点、量化探讨、开户与绑定实盘)
 
期货论坛 - 版权/免责声明   1.本站发布源码(包括函数、指标、策略等)均属开放源码,用意在于让使用者学习程序化语法撰写,使用者可以任意修改语法內容并调整参数。仅限用于个人学习使用,请勿转载、滥用,严禁私自连接实盘账户交易
  2.本站发布资讯(包括文章、视频、历史记录、教材、评论、资讯、交易方案等)均系转载自网络主流媒体,内容仅为作者当日个人观点,本网转载此文出于传递更多信息之目的,并不意味着赞同其观点或证实其描述。本网不对该类信息或数据做任何保证。不对您构成任何投资建议,不能依靠信息而取代自身独立判断,不对因使用本篇文章所诉信息或观点等导致的损失承担任何责任。
  3.本站发布资源(包括书籍、杂志、文档、软件等)均从互联网搜索而来,仅供个人免费交流学习,不可用作商业用途,本站不对显示的内容承担任何责任。请在下载后24小时内删除。如果喜欢,请购买正版,谢谢合作!
  4.龙听期货论坛原创文章属本网版权作品,转载须注明来源“龙听期货论坛”,违者本网将保留追究其相关法律责任的权力。本论坛除发布原创文章外,亦致力于优秀财经文章的交流分享,部分文章推送时若未能及时与原作者取得联系并涉及版权问题时,请及时联系删除。联系方式:http://www.qhlt.cn/thread-262-1-1.html
如何访问权限为100/255贴子:/thread-37840-1-1.html;注册后仍无法回复:/thread-23-1-1.html;微信/QQ群:/thread-262-1-1.html;网盘链接失效解决办法:/thread-93307-1-1.html

返回列表