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

【ParabolicSAR】

【ParabolicSAR】

  1. inputs:
  2.         AfStep( numericsimple ),                                                   
  3.         AfLimit( numericsimple ),                                                   
  4.         oParCl( numericref ),                                                            
  5.         oParOp( numericref ),                              
  6.         oPosition( numericref ),                                          
  7.         oTransition( numericref ) ;                                                      

  8. variables:
  9.         var0( 0 ),
  10.         var1( 0 ),
  11.         var2( 0 ) ;

  12. if CurrentBar = 1 then
  13.         begin
  14.         oParOp = High ;
  15.         oPosition = -1 ;
  16.         var0 = High ;
  17.         var1 = Low ;
  18.         end ;

  19. oTransition = 0 ;
  20. if High > var0 then var0 = High ;
  21.                                                                         
  22. if Low  < var1 then var1 = Low ;
  23.                                                                       

  24. if oPosition = 1 then
  25.                                                                      
  26.         begin
  27.         if Low <= oParOp then
  28.                                                                                  
  29.                 begin
  30.                 oPosition = -1 ;
  31.                 oTransition = -1 ;
  32.                                                                                           
  33.                 oParCl = var0 ;
  34.                                                                      
  35.                 var0 = High ;
  36.                                                                                
  37.                 var1  = Low ;
  38.                                                                               
  39.                 var2 = AfStep ;
  40.                                                        
  41.                 oParOp = oParCl + var2 * ( var1 - oParCl ) ;
  42.                                                                                
  43.                 if oParOp < High    then oParOp = High ;
  44.                                                                                     
  45.                 if oParOp < High[1] then oParOp = High[1] ;
  46.                                                              
  47.                 end
  48.         else
  49.                                                                             
  50.                 begin
  51.                 oParCl = oParOp ;
  52.                                           
  53.                 condition1 = var0 > var0[1] and var2 < AfLimit ;
  54.                 if condition1 then
  55.                                                                                      
  56.                         var2 = MinList( var2 + AfStep, AfLimit ) ;
  57.                                                          
  58.                 oParOp = oParCl + var2 * ( var0 - oParCl ) ;
  59.                                                                       
  60.                 if oParOp > Low    then oParOp = Low ;
  61.                                                                                   
  62.                 if oParOp > Low[1] then oParOp = Low[1] ;
  63.                                                              
  64.                 end ;
  65.         end
  66. else
  67.                                                                       
  68.         begin
  69.         if High >= oParOp then
  70.                                                                                  
  71.                 begin
  72.                 oPosition = 1 ;
  73.                 oTransition = 1 ;
  74.                                                                                           
  75.                 oParCl = var1 ;
  76.                                                                      
  77.                 var0 = High ;
  78.                                                                                
  79.                 var1  = Low ;
  80.                                                                               
  81.                 var2 = AfStep ;
  82.                                                        
  83.                 oParOp = oParCl + var2 * ( var0 - oParCl ) ;
  84.                                                                                
  85.                 if oParOp > Low    then oParOp = Low ;
  86.                                                                                   
  87.                 if oParOp > Low[1] then oParOp = Low[1] ;
  88.                                                              
  89.                 end
  90.         else
  91.                                                                                
  92.                 begin
  93.                 oParCl = oParOp ;

  94.                 condition1 = var1 < var1[1] and var2 < AfLimit ;                                                                                                   
  95.                 if condition1 then
  96.                                                                                      
  97.                         var2 = MinList( var2 + AfStep, AfLimit ) ;
  98.                                                          
  99.                 oParOp = oParCl + var2 * ( var1 - oParCl ) ;
  100.                                                                       
  101.                 if oParOp < High    then oParOp = High ;
  102.                                                                                     
  103.                 if oParOp < High[1] then oParOp = High[1] ;
  104.                                                              
  105.                 end ;
  106.         end ;

  107. ParabolicSAR = 1 ;
复制代码

论坛官方微信、群(期货热点、量化探讨、开户与绑定实盘)
 
期货论坛 - 版权/免责声明   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

返回列表