您現在的位置:程序化交易>> 期貨公式>> 金字塔等>> 金字塔知識>>正文內容

[求助]求救DLL,求金大神指點 [金字塔]

  • 咨詢內容: TCore::TCore( CALCINFO* pData,int x){   if ( pData->m_pfParam1 &&  pData->m_nParam1Start<0 && //參數1有效且為常數     pData->m_pfParam2 &&     pData->m_pfParam3 &&     pData->m_pfParam4)  {  float fParam = *pData->m_pfParam1;  slow= (int)fParam;  float fParam1 = *pData->m_pfParam2;  fast= (int)fParam1;  float fParam2 = *pData->m_pfParam3;  Mid= (int)fParam2;  float fParam3 = *pData->m_pfParam4;  MaSelect= (int)fParam3;  }       //數組初始化     DataLen=pData->m_nNumData;      int realLen=DataLen+10;  H.resize(realLen,0);  L.resize(realLen,0);  MidHL.resize(realLen,0);      RstArray.resize(realLen,0);  BL=6;
     B.resize(realLen,0);  D.resize(realLen,0);  Macd.resize(realLen,0);  Diff.resize(realLen,0);  Dea.resize(realLen,0);

     HB.resize(realLen,0);  HD.resize(realLen,0);  HMacd.resize(realLen,0);  HDiff.resize(realLen,0);  HDea.resize(realLen,0);
     HHB.resize(realLen,0);  HHD.resize(realLen,0);  HHMacd.resize(realLen,0);  HHDiff.resize(realLen,0);  HHDea.resize(realLen,0);
     //----------------------數組初始化       switch (MaSelect)  {  case 1:   {  initEmaData(pData,x);   };  case 2:;  case 3:;  default:;  }

    init emaData

    void TCore::initEmaData( CALCINFO* pData,int x){ float factorB=2.0f/(fast+1.0f); float factorD=2.0f/(slow+1.0f); float factorHB=2.0f/(fast*BL+1.0f); float factorHD=2.0f/(slow*BL+1.0f); float factorHHB=2.0f/(fast*BL*BL+1.0f); float factorHHD=2.0f/(slow*BL*BL+1.0f);
    for(int i=0;i<DataLen;i++) { RstArray[i]=0;//類成員,臨時結果緩存
    H[i]=(pData->m_pData[i].m_fHigh); L[i]=(pData->m_pData[i].m_fLow);

    MidHL[i]=(H[i]+L[i])*0.5f;

    if(i==0) { B[i]=MidHL[0]; D[i]=MidHL[0]; Diff[i]=B[i]-D[i]; Dea[i]=Diff[i];
    HB[i]=MidHL[0]; HD[i]=MidHL[0]; HDiff[i]=HB[i]-HD[i]; HDea[i]=HDiff[i];
    HHB[i]=MidHL[0]; HHD[i]=MidHL[0]; HHDiff[i]=HHB[i]-HHD[i]; HHDea[i]=HHDiff[i]; } else {       float A=MidHL[i]; B[i]=B[i-1]+factorB*(A-B[i-1]); D[i]=D[i-1]+factorD*(A-D[i-1]); Diff[i]=B[i]-D[i]; float factorDea=2.0f/(Mid+1.0f); Dea[i]=Dea[i-1]+factorDea*(Diff[i]-Dea[i-1]); Macd[i]=2.0f*(Diff[i]-Dea[i]);
    HB[i]=HB[i-1]+factorHB*(A-HB[i-1]); HD[i]=HD[i-1]+factorHD*(A-HD[i-1]); HDiff[i]=HB[i]-HD[i]; float factorHDea=2.0f/(Mid*BL+1.0f); HDea[i]=HDea[i-1]+factorHDea*(HDiff[i]-HDea[i-1]); HMacd[i]=2.0f*(HDiff[i]-HDea[i]);
    HHB[i]=HHB[i-1]+factorHHB*(A-HHB[i-1]); HHD[i]=HHD[i-1]+factorHHD*(A-HHD[i-1]); HHDiff[i]=HHB[i]-HHD[i]; float factorHHDea=2.0f/(Mid*BL*BL+1.0f); HHDea[i]=HHDea[i-1]+factorHHDea*(HHDiff[i]-HHDea[i-1]); HHMacd[i]=2.0f*(HHDiff[i]-HHDea[i]); } }

    if(x==-1) { for(int i=0;i<DataLen;i++) { L[i]=(100000-pData->m_pData[i].m_fHigh); H[i]=(100000-pData->m_pData[i].m_fLow);
    Diff[i]=-1*Diff[i]; Dea[i]=-1*Dea[i]; Macd[i]=-1*Macd[i];
    HDiff[i]=-1*HDiff[i]; HDea[i]=-1*HDea[i]; HMacd[i]=-1*HMacd[i];
    HHDiff[i]=-1*HHDiff[i]; HHDea[i]=-1*HHDea[i]; HHMacd[i]=-1*HHMacd[i]; } }


    extern "C" __declspec(dllexport) int WINAPI OPSUP(CALCINFO* pData){   TCore Core(pData,1);   Core.CalCore();   for(int m=0;m<pData->m_nNumData;m++)   {   pData->m_pResultBuf[m] =Core.L[m];   }   return 0;  Core.~TCore();
    return -1;  }

    為什么core.L賦值每間隔幾根就會不賦值,求金字塔大神解救!多謝!

     

  • 金字塔客服:

    有經驗的編程人員會利用寫文件日志的方式來調試你自己的代碼

     

  • 用戶回復: 那你能幫我看下,為什么會賦值有間隔?謝了

 

有思路,想編寫各種指標公式,程序化交易模型,選股公式,預警公式的朋友

可聯系技術人員 QQ: 1145508240  點擊這里給我發消息進行 有償 編寫!不貴!點擊查看價格!


【字體: 】【打印文章】【查看評論

相關文章

    沒有相關內容
主站蜘蛛池模板: 国产精品久久香蕉免费播放| 老头天天吃我奶躁我的动图| 日韩毛片免费看| 国产成人免费福利网站| 久久久久亚洲av无码专区蜜芽| 狠狠色综合网站久久久久久久高清 | 国产精品lululu在线观看| а天堂中文最新一区二区三区| 欧美精品香蕉在线观看网| 国产一区二区三区免费在线视频 | 欧美va久久久噜噜噜久久| 免费在线观看污视频网站| 适合男士深夜看的小说软件| 国产精品人人做人人爽人人添| silk131中字在线观看| 日本tvvivodes人妖| 免费在线h视频| 里番acg※里番acg本子全彩| 国产精品无码无卡在线播放| 久久国产精品-国产精品| 欧美精品亚洲精品日韩专区va| 啦啦啦中文中国免费高清| 黄+色+性+人免费| 国内少妇人妻丰满AV| 三级三级久久三级久久| 永久免费视频网站在线观看| 国产成人亚洲精品大帝| 久久免费国产视频| 欧美粗大猛烈老熟妇| 全彩acg本子| 亚洲日本久久一区二区va| 天天在线欧美精品免费看| 中文无码久久精品| 暖暖在线视频日本| 午夜精品一区二区三区在线观看 | 成年女人黄小视频| 久久综合九色综合精品| 欧美日本一区二区三区道| 国产中文字幕一区| 色老头永久免费网站| 国产麻豆成人传媒免费观看|