संसाधन लोड हो रहा है... लोड करना...

समुद्र तट रणनीति बीटीसी त्वरित संस्करण

लेखक:गुयमाइन, दिनांकः 2021-06-10 01:03:22
टैगःकछुए का व्यापार

यह देखने के लिए कि मंच पर कोई सार्वजनिक पायथन समुद्री डाकू रणनीति नहीं है, मैंने खुद एक सरल कंकड़ फेंक दिया। यह मूल संस्करण के करीब है, लेकिन यह बहुत अधिक अनुकूलित नहीं है, इसलिए यदि आप इसे फिर से परीक्षण करते हैं, तो आप इसे फिर से अनुकूलित कर सकते हैं।

खुलने वालाः डोंगजियांग से ऊपर की ओर बढ़ोतरीः 0.5ATR से ऊपर की कीमत में बढ़ोतरी स्टॉप-लॉस स्टॉप-रोलः पिछले ट्रेड की कीमत के नीचे या नीचे गिरने पर - 2ATR सभी स्टॉप-रोल

एक साल के आंकड़ों का पुनर्मूल्यांकन किया गया, 80% वार्षिक, अधिकतम 16% पीछे हट गया

इस तरह के एक नए नियम के तहत, एक व्यक्ति को एक ऋणदाता के रूप में पंजीकृत किया जाता है।


'''backtest
start: 2019-01-01 00:00:00
end: 2020-03-02 00:00:00
period: 1d
exchanges: [{"eid":"OKEX","currency":"BTC_USDT","stocks":0}]
args: [["fresh_rete",24],["DC_range",20],["atrlength",14]]
'''


import numpy as np
import pandas as pd
import datetime


data = {'ordertime':[],'id':[],'price':[]}
hisorder = pd.DataFrame(data)
    
def turtle():
    #声明全局变量
    global hisorder
    
    acct = exchange.GetAccount()

    records=exchange.GetRecords(fresh_rete*60*60)

    ticker = exchange.GetTicker()
    

    portfolio_value = acct.Balance+acct.FrozenBalance+(acct.Stocks+acct.FrozenStocks)*records[-1]['Close']
    atr = TA.ATR(records, atrlength)[-1]
    #计算得到unit大小
    value = portfolio_value*trade_percent
    unit =  min(round(value/atr,4),round(acct.Balance/(ticker['Last']+100),4))
    #unit =  round(value/atr,2)

    df = pd.DataFrame(records)
    current_price = records[-1]['Close']
    last_price = 0
    if len(hisorder)!=0:
        last_price = hisorder.iloc[-1]['price']
    max_price = df[-DC_range:-2]['High'].max()
    min_price = df[-int(DC_range/2):-2]['Low'].min() 
    
    opensign = len(hisorder)==0 and current_price > max_price
    

    addsign = len(hisorder)!=0 and current_price > last_price + 0.5*atr


    stopsign = len(hisorder)!=0 and current_price < min_price
    
    
    closesign = len(hisorder)!=0 and current_price < (last_price - 2*atr)

    
#    if _D(records[-1]['Time']/1000) == '2020-01-25 00:00:00':
#        Log("records[-1]",records[-1])





    if opensign | addsign:
        if acct.Balance >= (ticker['Last']+10)*unit and unit >0:
            id = exchange.Buy(ticker['Last']+10,unit)
            orderinfo = exchange.GetOrder(id)
            data = {'ordertime':_D(records[-1]['Time']/1000),'id':id,'price':records[-1]['Close']}
            hisorder = hisorder.append(data,ignore_index=True)
            Log('买入后,最新账户信息:', exchange.GetAccount())
            Log("opensign",opensign,"addsign",addsign)
    #    else:
    #        Log('余额已不足,请充值......', exchange.GetAccount())
    if stopsign | closesign:
        exchange.Sell(-1, acct.Stocks+acct.FrozenStocks)
        data = {'ordertime':[],'id':[],'price':[]}
        hisorder = pd.DataFrame(data)
        Log('卖出后,最新账户信息:', exchange.GetAccount())
        Log("stopsign",stopsign,"closesign",closesign)

    

    
def main():
    while True:
        turtle()
        Sleep(fresh_rete*60*60*1000)        

संबंधित

अधिक