Type/to search
8
Follow
1364
Followers
Pythonの単一製品戦略を複数製品戦略に変換する方法を段階的に教えます
Discussions
Created 2020-01-20 17:33:36  Updated 2023-10-17 21:18:46
 14
 4783

img

1. Pythonの単一製品戦略を複数製品戦略に変換する方法を教えます

前回の記事では、非常にシンプルな Python 戦略が実装されました。「追い上げて売り下げる戦略のPython版」この戦略では、アカウントを操作して、特定の取引ペアでプログラムされた取引を行うことができます。原理は非常にシンプルで、上昇を追いかけて下落時に売るというものです。場合によっては、同じ取引ロジックを使用して異なる取引ペアを操作したいことがあります。複数のロボットを作成し、さまざまな取引ペアを設定して、さまざまな通貨を取引できます。戦略がそれほど複雑でない場合は、発明者の定量取引プラットフォームの強力な柔軟性が考慮されています。戦略をマルチプロダクト戦略に変換するのは非常に簡単なので、1 つのロボットを作成するだけで複数の取引ペアを実行できます。

変換された戦略のソースコード:

'''backtest start: 2019-02-20 00:00:00 end: 2020-01-10 00:00:00 period: 1m exchanges: [{"eid":"OKEX","currency":"BTC_USDT"},{"eid":"OKEX","currency":"ETH_USDT","stocks":30},{"eid":"OKEX","currency":"LTC_USDT","stocks":100}] ''' import time import json params = { "arrBasePrice": [-1, -1, -1], # -1 "arrRatio": [0.05, 0.05, 0.05], # 0.05 "arrAcc": [], # _C(exchange.GetAccount) "arrLastCancelAll": [0, 0, 0], # 0 "arrMinStocks": [0.01, 0.01, 0.01], # 0.01 "arrPricePrecision": [2, 2, 2], # 2 "arrAmountPrecision": [3, 2, 2], # 2 "arrTick":[] } def CancelAll(e): while True : orders = _C(e.GetOrders) for i in range(len(orders)) : e.CancelOrder(orders[i]["Id"], orders[i]) if len(orders) == 0 : break Sleep(1000) def process(e, index): global params ticker = _C(e.GetTicker) params["arrTick"][index] = ticker if params["arrBasePrice"][index] == -1 : params["arrBasePrice"][index] = ticker.Last if ticker.Last - params["arrBasePrice"][index] > 0 and (ticker.Last - params["arrBasePrice"][index]) / params["arrBasePrice"][index] > params["arrRatio"][index]: params["arrAcc"][index] = _C(e.GetAccount) if params["arrAcc"][index].Balance * params["arrRatio"][index] / ticker.Last > params["arrMinStocks"][index]: e.Buy(ticker.Last, params["arrAcc"][index].Balance * params["arrRatio"][index] / ticker.Last) params["arrBasePrice"][index] = ticker.Last if ticker.Last - params["arrBasePrice"][index] < 0 and (params["arrBasePrice"][index] - ticker.Last) / params["arrBasePrice"][index] > params["arrRatio"][index]: params["arrAcc"][index] = _C(e.GetAccount) if params["arrAcc"][index].Stocks * params["arrRatio"][index] > params["arrMinStocks"][index]: e.Sell(ticker.Last, params["arrAcc"][index].Stocks * params["arrRatio"][index]) params["arrBasePrice"][index] = ticker.Last ts = time.time() if ts - params["arrLastCancelAll"][index] > 60 * 5 : CancelAll(e) params["arrLastCancelAll"][index] = ts def main(): global params for i in range(len(exchanges)) : params["arrAcc"].append(_C(exchanges[i].GetAccount)) params["arrTick"].append(_C(exchanges[i].GetTicker)) exchanges[i].SetPrecision(params["arrPricePrecision"][i], params["arrAmountPrecision"][i]) for key in params : if len(params[key]) < len(exchanges): raise "params error!" while True: tblAcc = { "type" : "table", "title": "account", "cols": ["账户信息"], "rows": [] } tblTick = { "type" : "table", "title": "ticker", "cols": ["行情信息"], "rows": [] } for i in range(len(exchanges)): process(exchanges[i], i) for i in range(len(exchanges)): tblAcc["rows"].append([json.dumps(params["arrAcc"][i])]) tblTick["rows"].append([json.dumps(params["arrTick"][i])]) LogStatus(_D(), "\n`" + json.dumps([tblAcc, tblTick]) + "`") Sleep(500)

2. 違いを見つける

コードを比較すると、前の記事のコードと大きく異なることがわかりますか?
実際、トレーディングロジックはまったく同じで、変更はありません。戦略を複数の種類に変更したため、以前の「戦略パラメータとして単一の変数」という形式を使用できないだけです。より合理的な解決策は次のとおりです。パラメータ配列を作成するには、配列内の各ポジションのインデックスが追加された取引ペアに対応します。

img

次に、トランザクションロジックコードを関数にカプセル化します。process戦略のメイン ループでは、追加された取引ペアに応じてこの関数が繰り返し呼び出され、取引ロジック コードが各取引ペアに対して 1 回実行されます。

  • 反復(トラバーサル)呼び出し:

    for i in range(len(exchanges)): process(exchanges[i], i)
  • 戦略パラメータ:

    params = { "arrBasePrice": [-1, -1, -1], # -1 "arrRatio": [0.05, 0.05, 0.05], # 0.05 "arrAcc": [], # _C(exchange.GetAccount) "arrLastCancelAll": [0, 0, 0], # 0 "arrMinStocks": [0.01, 0.01, 0.01], # 0.01 "arrPricePrecision": [2, 2, 2], # 2 "arrAmountPrecision": [3, 2, 2], # 2 "arrTick":[] }

    この設計により、各取引ペアに独自のパラメータを設定できます。各取引ペアの価格は大きく異なる可能性があり、パラメータも異なる場合があるため、差別化された設定が必要になることがあります。

  • すべてキャンセル機能

    この機能の変更を比較することができます。この関数はコードを少し変更するだけなので、この変更の意図について考えてみましょう。

  • ステータスバーチャートデータ

    ステータスバーにマーケットデータと口座資産データを表示するチャートを追加し、各取引所オブジェクトに対応する資産とマーケットデータをリアルタイムで表示できるようになりました。

上記の設計アイデアを習得した後、Python 戦略を多品種戦略に変更するのは非常に簡単ではないでしょうか?

3. バックテスト

img

img

img

この戦略は参考、バックテスト、テストのみを目的としています。興味があれば、最適化してアップグレードすることができます。
ポリシーアドレス

Related Recommendations
Comment
All comments (14)

    孟总,请问为什么,你这个策略下单不用设置exchange.SetDirection("buy")方向,还有个e. 不是exchange.吗,我最近在学习策略

    4 years ago

    这个策略最低本金是多少啊

    6 years ago

    没有实盘过,该策略为教学策略,学习为主,可以自行修改、扩展、优化跑实盘。

    6 years ago

    怎么不交易啊,半天没有反应。。。。。

    6 years ago

    好了,好了,弄好了,我弄成币本位了,怪不得呢

    6 years ago

    img 现在好了,但是我账户里是有钱的,你这个策略最少本金要投入多少啊,是不是我账户里的钱不够

    6 years ago

    可以具体看下这个策略源码, 策略公开的,策略逻辑很简单就是追涨杀跌。注意,这个是个数字货币现货策略,不能跑期货,可以自己修改成期货的。

    6 years ago

    img 是添加的托管者IP啊,没错啊

    6 years ago

    GetAccount: 400: {"error_message":"Invalid IP","code":30011,"error_code":"30011","message":"Invalid IP"}
    IP我也添加到API里面了,怎么还是出错

    6 years ago

    申请API KEY 的时候,设置的IP地址是允许访问的白名单地址,你设置了以后,就只有这个IP地址可以使用你的API KEY访问API接口。你设置的是你的托管者的IP地址么?

    6 years ago

    img 这个怎么解决

    6 years ago

    托管者所在服务器安装一下python。

    6 years ago

    机器人K线周期设置多少

    6 years ago

    这个策略不看K线的, 随便设置都行,回测的话因为影响tick粒度,设置为1分钟。

    6 years ago
  • 1
iPhone Download
Forums
PINE Language
© 2015 - ∞ INVENTOR PTE LTD (SG)