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

第三部分、常用到的bar数据元素计算函数【数值型,适合直接做逻辑判断用】

第三部分、常用到的bar数据元素计算函数【数值型,适合直接做逻辑判断用】

公式模块增加:
  1. //第三类函数(常用到的bar数据元素计算函数,数值型,适合直接做逻辑判断用)
  2. double test::SummationFC(string period, string inst, int num)
  3. {
  4.         double sum = 0;//声明一个临时存储和的变量
  5.         int n = 0;//声明一个统计循环次数的临时变量
  6.         map<string, TKVALUE>::reverse_iterator it;
  7.         for (it = mapK[period][inst].rbegin(); it != mapK[period][inst].rend(); ++it)
  8.         {
  9.                 sum = sum + it->second.dClose;//收盘价加总
  10.                 n++;
  11.                 if (n >= num)break; //当循环次数n大于等于num时跳出循环(如果bar的数目小时num周期,就按有多少bar就计算多少bar的)
  12.         }
  13.         return sum;
  14. }
  15. //均线average计算公式开始
  16. double test::averageFC(string period, string inst, int num)
  17. {
  18.         double d = 0;
  19.         int n = 0;
  20.         map<string, TKVALUE>::reverse_iterator it;
  21.         //  InsertLog(to_string(mapK[period][inst].size()));
  22.         for (it = mapK[period][inst].rbegin(); it != mapK[period][inst].rend(); ++it)
  23.         {
  24.                 d += it->second.dClose;
  25.                 n++;
  26.                 if (n >= num)break;
  27.         }
  28.         return d / n;
  29. }
  30. //均线average[1]计算公式开始
  31. double test::averagerefFC(string period, string inst, int num, int ref)
  32. {
  33.         double d = 0;
  34.         int n = 0;
  35.         int r = 0;
  36.         map<string, TKVALUE>::reverse_iterator it;
  37.         //  InsertLog(to_string(mapK[period][inst].size()));
  38.         for (it = mapK[period][inst].rbegin(); it != mapK[period][inst].rend(); ++it)
  39.         {
  40.                 r++;
  41.                 if (r <= ref)continue;
  42.                 d += it->second.dClose;
  43.                 n++;
  44.                 if (n >= num)break;
  45.         }
  46.         return d / n;
  47. }
  48. //最高价highest计算公式开始
  49. double test::highestFC(string period, string inst, int num)
  50. {
  51.         double d = 0;
  52.         int n = 0;
  53.         map<string, TKVALUE>::reverse_iterator it;
  54.         for (it = mapK[period][inst].rbegin(); it != mapK[period][inst].rend(); ++it)
  55.         {
  56.                 if (d < it->second.dHigh)d = it->second.dHigh;
  57.                 n++;
  58.                 if (n >= num)break;
  59.         }
  60.         return d;
  61. }
  62. //最高价highest[1]计算公式开始
  63. double test::highestrefFC(string period, string inst, int num, int ref)
  64. {
  65.         double d = 0;
  66.         int n = 0;
  67.         int r = 0;
  68.         map<string, TKVALUE>::reverse_iterator it;
  69.         for (it = mapK[period][inst].rbegin(); it != mapK[period][inst].rend(); ++it)
  70.         {
  71.                 r++;
  72.                 if (r <= ref)continue;
  73.                 if (d < it->second.dHigh)d = it->second.dHigh;
  74.                 n++;
  75.                 if (n >= num)break;
  76.         }
  77.         return d;
  78. }
  79. //最低价lowest计算公式
  80. double test::lowestFC(string period, string inst, int num)
  81. {
  82.         double d = 0;
  83.         int n = 0;
  84.         map<string, TKVALUE>::reverse_iterator it;
  85.         for (it = mapK[period][inst].rbegin(); it != mapK[period][inst].rend(); ++it)
  86.         {
  87.                 if (d == 0)d = it->second.dLow;
  88.                 if (d > it->second.dLow)d = it->second.dLow;
  89.                 n++;
  90.                 if (n >= num)break;
  91.         }
  92.         return d;
  93. }
  94. //最低价lowest[1]计算公式开始
  95. double test::lowestrefFC(string period, string inst, int num, int ref)
  96. {
  97.         double d = 0;
  98.         int n = 0;
  99.         int r = 0;
  100.         map<string, TKVALUE>::reverse_iterator it;
  101.         for (it = mapK[period][inst].rbegin(); it != mapK[period][inst].rend(); ++it)
  102.         {
  103.                 r++;
  104.                 if (r <= ref)continue;
  105.                 if (d == 0)d = it->second.dLow;
  106.                 if (d > it->second.dLow)d = it->second.dLow;
  107.                 n++;
  108.                 if (n >= num)break;
  109.         }
  110.         return d;
  111. }
  112. //ATR,averagetruerange计算公式开始
  113. double test::avgtruerangeFC(string period, string inst, int num)
  114. {
  115.         double dPreClose = 0;
  116.         int n = 0;
  117.         double sumatr = 0;
  118.         vector<double>vAtr;
  119.         if (mapK[period][inst].size() < num) return 0;
  120.         map<string, TKVALUE >::iterator it;
  121.         for (it = mapK[period][inst].begin(); it != mapK[period][inst].end(); ++it)
  122.         {

  123.                 if (dPreClose != 0)
  124.                 {
  125.                         double d = it->second.dHigh - it->second.dLow;
  126.                         double dHC = abs(it->second.dHigh - dPreClose);
  127.                         double dLC = abs(it->second.dLow - dPreClose);
  128.                         if (d < dHC)d = dHC;
  129.                         if (d < dLC)d = dLC;
  130.                         vAtr.push_back(d);
  131.                 }
  132.                 dPreClose = it->second.dClose;
  133.         }
  134.         for (int i = 1; i <= num; i++)
  135.         {
  136.                 sumatr += vAtr[vAtr.size() - i];
  137.         }
  138.         return  sumatr / num;
  139. }

  140. //布林带(bollingerbands)开始
  141. double test::bollingerbandsFC(string period, string inst, int num, int ref)
  142. {
  143.         double avg1 = averageFC(sPeriod, sInst, num);//中间均线
  144.         int n = 0;
  145.         double sumdev = 0;
  146.         double madev = 0;
  147.         if (mapK[period][inst].size() < num) return 0;
  148.         map<string, TKVALUE>::reverse_iterator it;
  149.         for (it = mapK[period][inst].rbegin(); it != mapK[period][inst].rend(); ++it)
  150.         {
  151.                 sumdev += pow(it->second.dClose - avg1, 2); //diff平方加总
  152.                 n++;
  153.                 if (n >= num)break;
  154.         }
  155.         madev = sqrt(sumdev / num); //得到方差后再取标准差
  156.         return avg1 + ref * madev;
  157. }

  158. //方差计算公式开始
  159. double test::VarianceFC(string period, string inst, int num)
  160. {
  161.         double avg1 = averageFC(sPeriod, sInst, num);//中间均线
  162.         int n = 0;
  163.         double sumdev = 0;
  164.         double madev = 0;
  165.         if (mapK[period][inst].size() < num) return 0;
  166.         map<string, TKVALUE>::reverse_iterator it;
  167.         for (it = mapK[period][inst].rbegin(); it != mapK[period][inst].rend(); ++it)
  168.         {
  169.                 sumdev += pow(it->second.dClose - avg1, 2); //偏离平方加总
  170.                 n++;
  171.                 if (n >= num)break;
  172.         }
  173.         return sumdev / n;
  174. }

  175. // 方差计算公式结束
  176. //标准差计算公式开始
  177. double test::StandardDevFC(string period, string inst, int num)
  178. {
  179.         double value1 = 0;
  180.         if (mapK[period][inst].size() < num) return 0;
  181.         value1 = VarianceFC(sPeriod, sInst, num);
  182.         return sqrt(value1);
  183. }
  184. // 标准差计算公式结束

  185. //xaverage计算公式(跟下面ema函数为同一函数,方便大家偏好)
  186. double test::xaverageFC(string period, string inst, int num)
  187. {
  188.         double d = 0;
  189.         int r = 0;
  190.         map<string, TKVALUE >::iterator it;
  191.         for (it = mapK[period][inst].begin(); it != mapK[period][inst].end(); ++it)
  192.         {
  193.                 if (r < num)//当数据不够num个bar时用总和/(bar个数加1)
  194.                 {
  195.                         d = (d + it->second.dClose) / (r + 1);
  196.                         r++;
  197.                 }
  198.                 else //当bar的总个数大于num个周期时,ema = a*close + (1-a)*ema[1],a一般为2/(num+1)
  199.                 {
  200.                         d = (2 * it->second.dClose + (num - 1) * d) / (num + 1);
  201.                 }
  202.         }
  203.         return d;
  204. }
  205. //ema计算公式开始
  206. double test::emaFC(string period, string inst, int num)
  207. {
  208.         double d = 0;
  209.         int r = 0;
  210.         map<string, TKVALUE >::iterator it;
  211.         for (it = mapK[period][inst].begin(); it != mapK[period][inst].end(); ++it)
  212.         {
  213.                 if (r < num)//当数据不够num个bar时用总和/(bar个数加1)
  214.                 {
  215.                         d = (d + it->second.dClose) / (r + 1);
  216.                         r++;
  217.                 }
  218.                 else //当bar的总个数大于num个周期时,ema = a*close + (1-a)*ema[1],a一般为2/(num+1)
  219.                 {
  220.                         d = (2 * it->second.dClose + (num - 1) * d) / (num + 1);
  221.                 }
  222.         }
  223.         return d;
  224. }
  225. //获得close[ref]值
  226. double test::closerefFC(string period, string inst, int ref)
  227. {
  228.         int d = 0;
  229.         int r = 0;
  230.         map<string, TKVALUE>::reverse_iterator it;//逆向迭代
  231.         for (it = mapK[sPeriod][sInst].rbegin(); it != mapK[sPeriod][sInst].rend(); it++) //逆向遍历所有K线
  232.         {
  233.                 r++;
  234.                 if (r <= ref)continue; //跳过ref个bar
  235.                 d = it->second.dClose; //将ref个bar前一个bar的收盘价赋值给d ;
  236.                 break;
  237.         }
  238.         return d;
  239. }
  240. //第三类函数(常用到的bar数据元素计算函数,逆序版,适合直接做逻辑判断用)
复制代码

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

返回列表