資源の読み込みに... 荷物...

コモディティフューチャーとデジタル通貨取引所のAPIの違い

作者: リン・ハーン小草, 作成日:2019-09-21 17:37:21, 更新日:2024-12-17 20:41:43

商品期货与数字货币交易所API的异同

商品先物CTPとデジタル通貨APIには,デジタル通貨のプログラム化取引に慣れていない人が,商品先物プログラム化に慣れていない人が,簡単なコピー体験できない.この投稿は,それらの違いを概要します.

歴史的なデータ

CTPインターフェイスは,歴史的な市場を提供していない. 取引先によって処理される. 登陸が未行または登陸断線が取引データを失う場合,CTPは取引復元メカニズムを提供していない. デジタル通貨は,通常,K線と取引履歴にアクセスするためのインターフェースを提供している.

協定は違います

デジタル通貨APIは一般的にRESTとwebsocketプロトコルで,CTPはネットワーク関連ロジックを内部に包み,TCPプロトコルに基づくFTDプロトコルを使用してCTPのバックグラウンドと通信する.

  • リクエスト応答モード:クライアントがリクエストを主動的に開始し,CTPのバックグラウンドがリクエストを受信し,応答する
  • ラジオ通信モード:クライアントが契約取引を購読した後に,CTPはラジオを通じて市場情報を押し出す.
  • プライベート通信モード:クライアントが契約を委託した後に,請求書情報,取引返信など,CTPによって点点推しが行われます.

CTPプロトコルのすべての取引および注文の取引は,変更後に通知されるが,注文,アカウント,保有を問い合わせることは主動的な問い合わせである.上記の3つのモデルはデジタル通貨APIで同様の形式で見つけることができます.

データの精度が違います

CTPプロトコルの深さは1回購入1回販売1回販売1回販売1回販売1回販売1回販売1回販売1回販売5回取引費は高価で,デジタル通貨は一般的に全深度または200回取引が可能です.CTPは実際の取引をプッシュしません.ただし,保有資産の変化を反転させることができます.デジタル通貨取引所APIは実際の分譲取引をプッシュできます.国内CTPプラットフォームの取引データティックのレベルは1秒2つのティックです.デジタル通貨取引所のウェブソケットは最大で1秒10回を行うことができます.

アクセス制限は異なります

デジタル通貨取引所では一般的に1秒10回まで制限されている. 注文の撤回については特に要求されていない. CTPは主動的な要求の制限が厳しく,一般的に2sで比較的に安全であり,撤回回数についても要求されている.

安定度

CTPプロトコルは安定しており,エラーやネットワーク上の問題はほとんどありません. デジタル通貨は制限が少なく,取引時間が長く,保守,データ遅延,ネットワーク上のエラーなどの状況が一般的です.

FMZ量化プラットフォーム CTPプロトコルのベストプラクティス

CTPのデフォルトモードでは,GetTicker,GetDepth,GetRecordsなどのインターフェイスがキャッシュされているため,最新のデータを取得できます.データがない場合,データが常に待たされるので,Sleepを使用することはできません. 状況が変化すると,ticker,depth,recordsは更新されます.このとき,任意のインターフェイスが呼び戻されます.

市場を取得するたびにデータを取得したい場合,古いデータであっても,市場を即時更新モード exchange.IO (mode, 0) に切り替えることができます.この時点で,ポリシーはイベント駆動で記述することはできません.迅速な死回りを避けるために,SLeep イベントを追加する必要があります.いくつかの低周波のポリシーはこのモードを使用することができます.

単一のコントラクトを操作する際にはデフォルトモードを使用することもできます.しかし,複数のコントラクトである場合,コントラクトが市場更新がなく,市場インターフェースへのアクセスが詰まっており,他のコントラクトの市場更新が入手できない可能性があります.この問題を解決するには,即時更新モードを使用できますが,高周波戦略を書くのは不便です.この場合はイベントプッシュモードを使用して,注文と市場を入手できます.

行事ティックの変更プッシュ: {Event: tick, Index: 取引所インデックス ((ロボット取引所によって順序で追加), Nano: イベント・ナノ秒次時間, Symbol: 契約名} オーダープッシュ: {Event:order, Index:取引所インデックス, Nano:イベントナ秒級時間, Order:オーダー情報 ((GetOrderと一致) }

戦略構造は以下のように書ける:

function on_tick(symbol){
    Log("symbol update")
    exchange.SetContractType(symbol)
    Log(exchange.GetTicker())
}

function on_order(order){
    Log("order update", order)
}

function main(){
    while(true){
        if(exchange.IO("status")){ //判断链接状态
            exchange.IO("mode", 0)
            _C(exchange.SetContractType, "MA888")//订阅MA,只有第一次是真正的发出订阅请求,接下来都是程序切换,不耗时间。
            _C(exchange.SetContractType, "rb888")//订阅rb
            while(True){
                var e = exchange.IO("wait")
                if(e){
                    if(e.event == "tick"){
                        on_tick(e.Symbol)
                    }else if(e.event == "order"){
                        on_order(e.Order)
                    }
                }
           }
        }else{
            Sleep(10*1000)
        }
    }
}

関連コンテンツ

もっと見る