while(true){
//strategy content
Sleep(Interval * 1000) //Sleep
}
}

記錄歷史數據

由于各種原因,機器人可能會反復重啟,如錯誤、參數更新、策略更新等,因此需要保存一些數據以便下次啟動。以下是如何保存初始凈值以計算回報的示例。_G() 函數可以存儲各種數據。_G(key, value) 可以存放 value 的值,并用 _G(key) 調用它,其中 key 是一個字符串。

let init_eq = 0 //defining initial equity
if(!_G('init_eq')){ //If there is no storage, _G('init_eq') returns null.
init_eq = total_eq
_G('init_eq', total_eq) //Since there is no storage, the initial equity is the current equity and is stored here
}else{
init_eq = _G('init_eq') //If stored, read the value of the initial equity
}

策略容錯

在通過 API 獲取持倉、行情等數據時,可能由于各種原因返回錯誤。直接調用數據可能導致策略因錯誤停止,因此需要一種容錯機制。_C() 函數將在遇到錯誤時自動重試,直到返回正確的數據。或者檢查返回后的數據是否可用。

let pos = _C(exchange.GetPosition, pair)

let ticker_A = exchange.GetTicker(pair_a)
let ticker_B = exchange.GetTicker(pair_b)
if(!ticker_A || !ticker_B){
continue //If the data is not available, exit the loop.
}

多幣種兼容 API

GetPosition、GetTicker 和 GetRecords 等函數可以加上交易對參數來獲取相關數據,無需設置交易所綁定的交易對,這大大提升了多交易對策略的兼容性。有關具體的升級內容,請參見文章:https://www.fmz.com/bbs-topic/10456。當然,您需要最新的 docker 來支持它。如果您的 docker 版本過舊,則需要進行升級。

策略參數

完成策略說明

如果您仍然不明白,您可以使用 FMZ 的 API 文檔、調試工具以及市面上常用的 AI 對話工具來解決您的問題。

function GetPosition(pair){
let pos = _C(exchange.GetPosition, pair)
if(pos.length == 0){ //Returns null to indicate no position
return {amount:0, price:0, profit:0}
}else if(pos.length > 1){ //The strategy should be set to unidirectional position mode
throw 'Bidirectional positions are not supported'
}else{ //For convenience, long positions are positive and short positions are negative
return {amount:pos[0].Type == 0 ? pos[0].Amount : -pos[0].Amount, price:pos[0].Price, profit:pos[0].Profit}
}
}

function GetRatio(){
let kline_A = exchange.GetRecords(Pair_A+"_"+Quote+".swap", 60*60, N) //Hourly K-line
let kline_B = exchange.GetRecords(Pair_B+"_"+Quote+".swap", 60*60, N)
let total = 0
for(let i= Math.min(kline_A.length,kline_B.length)-1; i >= 0; i--){ //Calculate in reverse to avoid the K-line being too short.
total += kline_A[i].Close / kline_B[i].Close
}
return total / Math.min(kline_A.length,kline_B.length)
}

function GetAccount(){
let account = _C(exchange.GetAccount)
let total_eq = 0
if(exchange.GetName == 'Futures_OKCoin'){ //Since the API here is not compatible, only OKX Futures Exchange obtains the total equity currently.
total_eq = account.Info.data[0].totalEq //The equity information of other exchanges is also included. You can look for it yourself in the exchange API documentation.
}else{
total_eq = account.Balance //Temporary use of available balances on other exchanges will cause errors in calculating returns, but will not affect the use of strategies.
}
let init_eq = 0
if(!_G('init_eq')){
init_eq = total_eq
_G('init_eq', total_eq)
}else{
init_eq = _G('init_eq')
}
LogProfit(total_eq - init_eq)
return total_eq
}

function main(){
var precision = exchange.GetMarkets() //Get the precision here
var last_get_ratio_time = Date.now()
var ratio = GetRatio()
var total_eq = GetAccount()
while(true){
let start_loop_time = Date.now()
if(Date.now() - last_get_ratio_time > 10*60*1000){ //Update the average price and account information every 10 minutes
ratio = GetRatio()
total_eq = GetAccount()
last_get_ratio_time = Date.now()
}
let pair_a = Pair_A+"_"+Quote+".swap" //The trading pair is set as BTC_USDT.swap
let pair_b = Pair_B+"_"+Quote+".swap"
let CtVal_a = "CtVal" in precision[pair_a] ? precision[pair_a].CtVal : 1 //Some exchanges use sheets to represent quantity, such as one sheet represents 0.01 coin, so you need to convert.
let CtVal_b = "CtVal" in precision[pair_b] ? precision[pair_b].CtVal : 1 //No need to include this field
let position_A = GetPosition(pair_a)
let position_B = GetPosition(pair_b)
let ticker_A = exchange.GetTicker(pair_a)
let ticker_B = exchange.GetTicker(pair_b)
if(!ticker_A || !ticker_B){ //If the returned data is abnormal, jump out of this loop
continue
}
let diff = (ticker_A.Last / ticker_B.Last - ratio) / ratio //Calculate the ratio of deviation
let aim_value = - Trade_Value * diff / Pct //Target holding position
let id_A = null
let id_B = null
//The following is the specific logic of opening a position
if( -aim_value + position_A.amount*CtVal_a*ticker_A.Last > Trade_Value && position_A.amount*CtVal_a*ticker_A.Last > -Max_Value){
id_A = exchange.CreateOrder(pair_a, "sell", ticker_A.Buy, _N(Ice_Value / (ticker_A.Buy * CtVal_a), precision[pair_a].AmountPrecision))
}
if( -aim_value - position_B.amount*CtVal_b*ticker_B.Last > Trade_Value && position_B.amount*CtVal_b*ticker_B.Last < Max_Value){
id_B = exchange.CreateOrder(pair_b, "buy", ticker_B.Sell, _N(Ice_Value / (ticker_B.Sell * CtVal_b), precision[pair_b].AmountPrecision))
}
if( aim_value - position_A.amount*CtVal_a*ticker_A.Last > Trade_Value && position_A.amount*CtVal_a*ticker_A.Last < Max_Value){
id_A = exchange.CreateOrder(pair_a, "buy", ticker_A.Sell, _N(Ice_Value / (ticker_A.Sell * CtVal_a), precision[pair_a].AmountPrecision))
}
if( aim_value + position_B.amount*CtVal_b*ticker_B.Last > Trade_Value && position_B.amount*CtVal_b*ticker_B.Last > -Max_Value){
id_B = exchange.CreateOrder(pair_b, "sell", ticker_B.Buy, _N(Ice_Value / (ticker_B.Buy * CtVal_b), precision[pair_b].AmountPrecision))
}
if(id_A){
exchange.CancelOrder(id_A) //Cancel directly here
}
if(id_B){
exchange.CancelOrder(id_B)
}
let table = {
type: "table",
title: "trading Information",
cols: ["initial equity", "current equity", Pair_A+"position", Pair_B+"position", Pair_A+"holding price", Pair_B+"holding price", Pair_A+"profits", Pair_B+"profits", Pair_A+"price", Pair_B+"price", "current price comparison", "average price comparison", "deviation from average price", "loop delay"],
rows: [[_N(_G('init_eq'),2), _N(total_eq,2), _N(position_A.amount*CtVal_a*ticker_A.Last, 1), _N(position_B.amount*CtVal_b*ticker_B.Last,1),
_N(position_A.price, precision[pair_a].PircePrecision), _N(position_B.price, precision[pair_b].PircePrecision),
_N(position_A.profit, 1), _N(position_B.profit, 1), ticker_A.Last, ticker_B.Last,
_N(ticker_A.Last / ticker_B.Last,6), _N(ratio, 6), _N(diff, 4), (Date.now() - start_loop_time)+"ms"
]]
}
LogStatus("" + JSON.stringify(table) + "") //This function will display a table containing the above information on the robot page. Sleep(Interval * 1000) //Sleep time in ms } }

如何找到更多同類API?

冪簡集成是國內領先的API集成管理平臺,專注于為開發者提供全面、高效、易用的API集成解決方案。冪簡API平臺可以通過以下兩種方式找到所需API:通過關鍵詞搜索API、或者從API Hub分類頁進入尋找。

原文鏈接:https://medium.com/@FMZQuant/introduction-to-the-source-code-of-digital-currency-pair-trading-strategy-and-the-latest-api-of-fmz-56b912a28231

熱門推薦
一個賬號試用1000+ API
助力AI無縫鏈接物理世界 · 無需多次注冊
3000+提示詞助力AI大模型
和專業工程師共享工作效率翻倍的秘密
返回頂部
上一篇
GraphQL API 的 5 個安全提示
下一篇
GraphQL 與 RESTAPI 哪個更有利于 API 可觀察性
国内精品久久久久影院日本,日本中文字幕视频,99久久精品99999久久,又粗又大又黄又硬又爽毛片
国产欧美日韩在线观看| 国内精品久久久久影院薰衣草| 1024精品合集| 成人高清视频在线观看| 国产精品另类一区| 成人一区二区三区| 中文字幕日韩精品一区| 欧美在线免费观看亚洲| 亚洲亚洲精品在线观看| 欧美一区二区三级| 国产**成人网毛片九色 | 亚洲女爱视频在线| 欧美吻胸吃奶大尺度电影| 麻豆91免费看| 亚洲视频网在线直播| 欧美日韩成人一区二区| 国产一区 二区 三区一级| 中文在线免费一区三区高中清不卡| 91免费视频网| 国产在线精品一区二区三区不卡| 中文字幕亚洲区| 日韩视频在线观看一区二区| 91麻豆swag| 国内久久婷婷综合| 亚洲va国产va欧美va观看| 国产精品乱子久久久久| 欧美久久免费观看| 91首页免费视频| 国产一二三精品| 偷偷要91色婷婷| 亚洲美女电影在线| 久久综合av免费| 日韩一区二区在线免费观看| 色综合久久中文字幕综合网| 成人一级片在线观看| 蜜臀av亚洲一区中文字幕| 一区二区三区在线免费播放| 欧美激情一区在线观看| 337p粉嫩大胆色噜噜噜噜亚洲| 欧美精选午夜久久久乱码6080| 国产精品1区2区| 久久99久久99| 久久爱www久久做| 日本不卡一区二区| 天堂久久一区二区三区| 性欧美疯狂xxxxbbbb| 亚洲精品美腿丝袜| 亚洲制服欧美中文字幕中文字幕| 亚洲精品乱码久久久久久黑人| 亚洲女子a中天字幕| 亚洲精选在线视频| 一区二区三区在线不卡| 亚洲一级不卡视频| 青青草97国产精品免费观看 | 精品久久久久久久人人人人传媒| 欧美第一区第二区| 精品国产1区2区3区| 国产日韩精品一区二区三区在线| 国产三级精品三级| 亚洲欧洲日产国码二区| 亚洲精品老司机| 午夜视频在线观看一区二区| 免费精品视频在线| 国产精品影视网| 色综合一个色综合亚洲| 欧美日韩久久一区二区| 精品美女被调教视频大全网站| 久久精品人人爽人人爽| 亚洲视频在线观看一区| 亚洲成人av电影| 韩国在线一区二区| 91美女在线观看| 欧美一区二区三区四区久久 | 欧美大尺度电影在线| 国产精品网站一区| 亚洲成人精品一区| 国产伦理精品不卡| 欧美丝袜丝交足nylons| 久久久精品综合| 亚洲一级二级三级| 成人av综合一区| 欧美一级日韩免费不卡| 国产精品精品国产色婷婷| 视频一区欧美精品| 99re视频这里只有精品| 日韩欧美色电影| 亚洲精品国产一区二区精华液| 麻豆91在线播放免费| 91视频免费看| 国产亚洲精品中文字幕| 天堂在线一区二区| 在线免费不卡视频| 18涩涩午夜精品.www| 国产美女娇喘av呻吟久久| 欧美中文字幕一二三区视频| 日本一区二区成人| 久久99久久久欧美国产| 欧美视频一区二区三区在线观看| 国产精品午夜久久| 国产成人av电影| 久久精品视频网| 久久99久久99小草精品免视看| 欧美日本视频在线| 午夜精品爽啪视频| 91成人免费在线| 亚洲图片欧美色图| 欧美日韩三级一区二区| 亚洲丰满少妇videoshd| 99久久精品费精品国产一区二区| 国产精品人人做人人爽人人添| 国产精品一区不卡| 国产欧美va欧美不卡在线| 国产一本一道久久香蕉| 久久精品一区二区三区不卡 | 国产精品久久久久久久久果冻传媒| 成人深夜在线观看| 性做久久久久久免费观看| 精品国产区一区| 久久婷婷久久一区二区三区| 91免费观看视频在线| 在线观看av一区| 94-欧美-setu| 在线不卡a资源高清| 国产精品电影一区二区三区| 精品奇米国产一区二区三区| 欧美日韩一区二区三区免费看| 免费看日韩a级影片| 欧美一二三在线| 亚洲高清久久久| 777a∨成人精品桃花网| 欧美这里有精品| 这里是久久伊人| 久久久久久免费网| 亚洲欧美一区二区视频| 亚洲日本一区二区三区| 亚洲欧洲日韩在线| 中文字幕一区二区三区色视频 | 国产精品久久久一本精品 | 91啪亚洲精品| 欧美日韩一区高清| 国产精品色哟哟网站| 久久99精品久久久久久久久久久久 | 一区二区三区在线播放| 日韩电影在线一区二区三区| www.欧美精品一二区| 久久久久久久综合日本| 亚洲福利视频三区| 欧美亚洲综合久久| 天天综合日日夜夜精品| 久久精品夜夜夜夜久久| 久久久久久久电影| 高清国产一区二区| 粉嫩av一区二区三区粉嫩| 日本91福利区| 99在线精品观看| 国产精品麻豆99久久久久久| 激情综合色播五月| 国产精品伦理在线| 97se亚洲国产综合在线| 欧美激情一区二区三区蜜桃视频| 欧美一三区三区四区免费在线看| 亚洲成av人片一区二区三区| 国产丝袜美腿一区二区三区| 国产成人鲁色资源国产91色综| 日韩成人午夜电影| 亚洲午夜免费视频| 五月天视频一区| 久久亚洲二区三区| 成人深夜在线观看| 日韩电影在线观看一区| 欧美一区二区三级| 国产麻豆精品95视频| 亚洲视频精选在线| 91精品国产91综合久久蜜臀| 99精品欧美一区二区三区小说 | 亚洲国产精品av| 国产成人免费av在线| 亚洲a一区二区| 亚洲欧美日韩一区| 亚洲国产中文字幕在线视频综合| 欧美成人一区二区三区| 美国毛片一区二区三区| 欧美高清性hdvideosex| 中文字幕va一区二区三区| 国产一区二区按摩在线观看| 国产精品嫩草影院av蜜臀| 91片在线免费观看| 国产1区2区3区精品美女| 男女性色大片免费观看一区二区| 亚洲午夜精品网| 欧美国产日韩亚洲一区| 精品国产乱码久久久久久浪潮| 91.麻豆视频| 成人欧美一区二区三区在线播放| 久久久国产一区二区三区四区小说 | 成人蜜臀av电影| 欧美专区日韩专区| 精品成人a区在线观看| 自拍偷拍欧美精品| 男女性色大片免费观看一区二区|