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

金字塔VBA判斷三角形向上突破源碼[金字塔模型]

  • 金字塔自帶的判斷三角形向上突破的一個VBA的范例
  • 轉載保留出處 www.tumamayizhan.com

     

    Function TriangleShape(Formula,Cyc,SCyc,ECyc)
        'msgbox cyc & "-" & scyc & "-" & ecyc
     '該函數計算當前位置圖形是否是三角形突破,如果是則返回1,否則返回0。該函數只有在選股時才能使用。
     TriangleShape=0
     
     '如果是分時數據或者分筆成交那么直接返回
     If Formula.ParentGrid.DataType = 0 or Formula.ParentGrid.CycType = 10 Then
      Exit Function
     End If
     
     '得到K線數據對象
     Set History = Formula.ParentGrid.GetHistoryData()
     
     If History.Count < Cyc+3 Then
      Exit Function
     End If
     
     '為了加快處理速度,只有公式在執行最后一個周期時使用。這就意味著只能在選股時使用該函數
     '如果你在公式測試中使用,請注釋掉以下語句
     If Formula.IndexData < History.Count-1 Then Exit Function
     
     '下面的代碼判斷當前圖形是否可能為三角形態
     '開始位置SCyc周期內的高低價格為三角形態的開始
     StartPos = Formula.IndexData - (Cyc+2)
     EndPos = Formula.IndexData-3
     High = History.High(StartPos)
     Low  = History.Low(StartPos)
     For I = StartPos To StartPos+SCyc
      If History.High(I) > High Then
       High = History.High(I)
      End If
      If History.Low(i) < Low Then
       Low = History.Low(I)
      End If
     Next
     
     'ECyc周期內的周期高低價格為三角的結束
     High2 = History.High(EndPos - ECyc)
     Low2  = History.Low(Endpos-ECyc)
     for i = endpos - ECyc to endpos
      If History.High(I) > High2 Then
       High2 = History.High(I)
      End If
      If History.Low(i) < Low2 Then
       Low2 = History.Low(I)
      End If
     next
     
     '最后圖形范圍為開始圖形的1/2的話,初步表明是可以做為三角形的結束
     if high2-low2 <= 0 then
      exit function
     end if
     
     If (High-Low) / (high2-low2) < 2 Then
      Exit Function
     End if
     
     if high2 > high or low2 < low then
      exit function
     end if
     
     '如果中間有超過三角形邊界的地方,三角圖形則不成立
     '用斜率計算圖形邊界
     '計算上邊界
     Slope = (high2-high) / (Endpos-StartPos)
     b = high - slope * startpos
     
     for i = startpos+SCyc to endpos
      temp = slope * i + b
      price = (history.open(i)+history.close(i))/2
      if temp < price then
       exit function
      end if
     next
     
     '計算下邊界
     slope = (low2-low) / (endpos - startpos)
     b = low - slope * startpos
     
     for i = startpos to endpos-3
      temp = slope * i + b
      price = (history.open(i)+history.close(i))/2
      if temp > price then
       exit function
      end if
     next 
     
     '如果3日后的價格突破了三角型結束的上邊線認為突破成功
     if history.close(Formula.IndexData) > high2 then
      TriangleShape = 1
     end if
     
     
    End Function

 

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

可聯系技術人員 QQ: 262069696  點擊在線交流進行 有償 編寫!不貴!點擊查看價格!

 


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

相關文章

    沒有相關內容
  主站蜘蛛池模板: 欧美最猛黑人xxxx黑人猛交| 麻豆精品一区二区综合av| 成人精品免费视频在线观看| 亚洲国产成人资源在线软件| 精品国精品国产自在久国产应用男 | 成人午夜精品无码区久久| 亚洲αv在线精品糸列| 玖玖精品在线视频| 国产乱人视频在线播放不卡| 1000部又爽又黄的做黄禁片| 女人被男人桶爽| 久久av高潮av无码av喷吹| 欧洲成人午夜精品无码区久久| 人与动性xxxxx免费| 美女扒开内裤无遮挡网站| 国产性夜夜夜春夜夜爽| 57pao国产成视频免费播放| 女人被男人桶爽| 中文成人无字幕乱码精品区| 最近免费中文在线视频| 亚洲永久精品ww47| 粗暴hd另类另类| 四虎成人精品无码| 高清欧美性猛交xxxx黑人猛交| 国产精品日韩欧美| 9一14yosexyhd| 少妇人妻无码精品视频| 丰满人妻熟妇乱又伦精品软件| 日韩精品国产另类专区| 亚洲国产欧美国产综合一区| 特级黄色一级片| 全部免费a级毛片| 色综合合久久天天综合绕视看| 国产成人精品免费视频大全五级| 51国产偷自视频区视频| 在车子颠簸中进了老师的身体| 一区二区三区欧美视频| 手机看片1024旧版| 久久午夜无码免费| 曰批全过程免费视频网址| 亚洲国产婷婷六月丁香|