以文本方式查看主题

-  金字塔客服中心 - 专业程序化交易软件提供商  (http://222.73.7.161/bbs/index.asp)
--  高级功能研发区  (http://222.73.7.161/bbs/list.asp?boardid=5)
----  移动平均线  (http://222.73.7.161/bbs/dispbbs.asp?boardid=5&id=53111)

--  作者:ywqp0718
--  发布时间:2013/6/17 17:17:15
--  移动平均线
__declspec(dllexport) int WINAPI MYMACLOSE(CALCINFO* pData)
{
if ( pData->m_pfParam1 && //参数1有效
pData->m_nParam1Start<0 && //参数1为常数
pData->m_pfParam2==NULL ) //仅有一个参数
{
float fParam = *pData->m_pfParam1;
int nPeriod = (int)fParam; //参数1
if(nPeriod>0)
{
float fTotal;
int i, j;
for ( i = nPeriod-1; i < pData->m_nNumData; i++ )//计算nPeriod周期的均线,数据从nPeriod-1开始有效
{
fTotal = 0.0f;
for ( j = 0; j < nPeriod; j++ ) //累加
fTotal += pData->m_pData[i-j].m_fClose;
pData->m_pResultBuf[i] = fTotal/nPeriod; //平均
}
return nPeriod-1;
}
}

return -1;
}


问题1  :这是金子塔自带的开发范例里对MA指标的代码,pData->m_nNumData我不是太明白,是界面里所有bar的个数么

问题2  :求20日的指数移动平均  下面是TB里的系统指标源码

length=20;
sFcactor = 2 / ( Length + 1 );
if (CurrentBar == 0 )   //图标上的第一根bar 指数异动平均初始值为第一根bar的收盘价  ---这句不知道这个在金字塔接口中要怎么写
{
XAvgValue = Price;
}else
{
XAvgValue = XAvgValue[1] + sFcactor * ( Price - XAvgValue[1] ) ;
}
Return XAvgValue;

这个与金字塔里的EMA函数很相似 Y=EMA(X,N);  Y=[2*X+(N-1)*Y\']/(N+1) ;  


我想问怎么用金字塔的接口函数表达,能帮我写一个完整的指数移动平均的函数么


问了这么多问题都没赠过金币自己都过意不去了,呵呵,什么方式可获得金币啊


--  作者:王锋
--  发布时间:2013/6/17 17:55:00
--  
问题请稍等,待研发人员确定好问题后一并回答,感谢您对金字塔的支持。
--  作者:ywqp0718
--  发布时间:2013/6/18 9:45:32
--  
嗯 先谢谢了!
--  作者:王锋
--  发布时间:2013/6/18 22:01:51
--  

这是基于序列模式下的EMA的C++算法

 

//计算收盘价的均价,一个常数参数,表示计算周期
//调用方法:
// "STOCKFUNC@MYEMA"(5)

__declspec(dllexport) int WINAPI MYEMA(CALCINFO* pData)
{
 if ( pData->m_pfParam1 &&    //参数1有效
   pData->m_nParam1Start<0 &&   //参数1为常数
   pData->m_pfParam2==NULL )   //仅有一个参数
 {
  float dbPrvValues = 0;
  float fParam = *pData->m_pfParam1;
  int nPeriod = (int)fParam;   //参数1
  if(nPeriod>0)
  {
   float fTotal;
   int i, j;
   for ( i = nPeriod-1; i < pData->m_nNumData; i++ )//计算nPeriod周期的均线,数据从nPeriod-1开始有效,这里的pData->m_nNumData就是参与图表计算的k线数据数量
   {
    if(i == nPeriod-1)
    {
     pData->m_pResultBuf[i] = pData->m_pData[i].m_fClose;
     dbPrvValues = pData->m_pData[i].m_fClose;
    }
    else
    {
     double dbEma = (2 * pData->m_pData[i].m_fClose + (nPeriod - 1) * dbPrvValues) / (nPeriod + 1);
     
     pData->m_pResultBuf[i] = dbEma;
     dbPrvValues = dbEma;
    }

    if(!_finite(pData->m_pResultBuf[i]))
    {
     pData->m_pResultBuf[i] = pData->m_pData[i].m_fClose;
     dbPrvValues = pData->m_pData[i].m_fClose;
    }
   }
   return nPeriod-1;
  }
 }

 return -1;
}

 

这是附带的EMA工程C++源码范例

 下载信息  [文件大小:   下载次数: ]
点击浏览该文件:fmldevelope.rar

 

PEL公式调用如下:

aa:"STOCKFUNC@MYEMA"(5);
bb:ema(close,5);

 

测试后你会发现效果与金字塔的EMA是一模一样的

[此贴子已经被作者于2013/6/18 22:05:35编辑过]

--  作者:ywqp0718
--  发布时间:2013/6/21 16:56:49
--  
近期忙刚看到,太谢谢你了,很全面很详细,下次一定指定让您给解答!!