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

【TPO_VA_HighLow】

【TPO_VA_HighLow】

  1. inputs:
  2.         VAPercent(NumericSimple),
  3.         VAHigh(NumericRef),
  4.         VALow(NumericRef);


  5. if (VAPercent < 0 or VAPercent > 100) then
  6.         raiseruntimeerror("Incorrect VAPercent input value! Supported values are from 0 to 100.");

  7. if (TPO_POC < 0) then
  8.         raiseruntimeerror("TPO_VA_HighLow function can be applied to TPO resolution only!");

  9. vars: _total(0), _target(0), _upLvlSearch(0), _dnLvlSearch(0), _summBlocks(0), _ticksize(TickSize), _candidateUp(0), _candidateUpPrice(0), _candidateDn(0), _candidateDnPrice(0), _skipZeroIdx(0);

  10. TPO_VA_HighLow = 0;

  11. _total = TPO_TotalBlocks;
  12. _target = intportion(_total * VAPercent * 0.01);

  13. if (TPO_POC_Value >= _target) then begin
  14.         VAHigh = TPO_POC;
  15.         VALow = TPO_POC;
  16.         #return;
  17. end;

  18. if (_target > _total - minlist(TPO_Levels_Value(TPO_Levels_Low, 0), TPO_Levels_Value(TPO_Levels_High, 0))) then begin
  19.         VAHigh = TPO_Levels_High;
  20.         VALow = TPO_Levels_Low;
  21.         #return;
  22. end;

  23. _upLvlSearch = TPO_POC;
  24. _dnLvlSearch = TPO_POC;
  25. _summBlocks = TPO_POC_Value;

  26. while _summBlocks < _target begin
  27.         // can move up
  28.         if (_upLvlSearch < TPO_Levels_High) then begin

  29.                 // can move down
  30.                 if (_dnLvlSearch > TPO_Levels_Low ) then begin

  31.                         _candidateUpPrice = _upLvlSearch + _ticksize;
  32.                         _candidateUp = TPO_Levels_Value(_candidateUpPrice, 0);
  33.                        
  34.                         // skip possible zero blocks
  35.                         _skipZeroIdx = 2;
  36.                         while (_candidateUp <= 0 and _upLvlSearch + _skipZeroIdx * _ticksize <= TPO_Levels_High) begin
  37.                                 _candidateUpPrice = _upLvlSearch + _skipZeroIdx * _ticksize;
  38.                                 _candidateUp = TPO_Levels_Value(_candidateUpPrice, 0);
  39.                                 _skipZeroIdx += 1;
  40.                         end;

  41.                         _candidateDnPrice = _dnLvlSearch - _ticksize;
  42.                         _candidateDn = TPO_Levels_Value(_candidateDnPrice, 0);

  43.                         // skip possible zero blocks
  44.                         _skipZeroIdx = 2;
  45.                         while (_candidateDn <= 0 and _dnLvlSearch - _skipZeroIdx * _ticksize >= TPO_Levels_Low) begin
  46.                                 _candidateDnPrice = _dnLvlSearch - _skipZeroIdx * _ticksize;
  47.                                 _candidateDn = TPO_Levels_Value(_candidateDnPrice, 0);
  48.                                 _skipZeroIdx += 1;
  49.                         end;

  50.                         // If both 'next'/adjacent prices have the same number of TPO's we choose the higher price.
  51.                         if (_candidateUp >= _candidateDn) then begin
  52.                                 _upLvlSearch = _candidateUpPrice;
  53.                                 _summBlocks += _candidateUp;
  54.                         end
  55.                         else begin
  56.                                 _dnLvlSearch = _candidateDnPrice;
  57.                                 _summBlocks += _candidateDn;
  58.                         end;
  59.                 end
  60.                 else begin
  61.                         _upLvlSearch += _ticksize;
  62.                         _summBlocks += TPO_Levels_Value(_upLvlSearch, 0);
  63.                 end;
  64.         end
  65.         else begin
  66.                 _dnLvlSearch -= _ticksize;
  67.                 _summBlocks += TPO_Levels_Value(_dnLvlSearch, 0);
  68.         end;
  69. end;

  70. VAHigh = _upLvlSearch;
  71. VALow = _dnLvlSearch;
复制代码

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

返回列表