FMex 분류 채굴 복수 버전 코드 사용 설명서
//보증권 시장의 위험은 매우 높고, 당신은 언제든지 100% 손실을 당할 수 있습니다. // ((주식 공백 또는 격동을 고려할 경우, 파라미터와 코드 지점을 유연하게 변경할 수 있습니다.) // 현재 최대 포지션 (轉向計算), 0.5-5배 이내에 권장된다. 0.1B, 3배의 레버, 전환 포지션 약 2700, 최대 포지션 3200, 10배의 레버로 조정하면 전환 포지션은 9000u, 최대 포지션 10000u, 단량 300-500u로 조정할 수 있다. // 디스크 주소:https://api.fmex.com테스트 웹 http://api.fmextest.net// 참고: 먼저 수동으로 long1-1000u를 보관하십시오. // (WeChat:ying5737)전략적 원칙:
사진은 참고로만https://wx1.sinaimg.cn/mw690/c5775633ly1gaajdxk8a8j20u10f4dhx.jpg
무작위 거래 / 이 전략은 기본적으로 여러 개의 지점을 보유하는 경향이 있습니다. 참고: 먼저 long1u-1000u를 보관하십시오.- 기존 주문이 한계를 초과하는지 확인하고, 초과되면 즉시 주문을 취소합니다. - 거래가 포지션을 형성하는지 검증하고, 포지션 xu보다 크면 포지션을 설정된 포지션 아래로 줄입니다.
몇 가지 예시:
전 세계 목록:시상사 전략을 구분하기 위해, 특정 정의 원격 정렬은 挂列. 파라미터 조정 가능, 현재 8개 정도이다.
시가수 (매매 목록이 붙어있다):최대 멀티 헤드 포지션 커스터마이징, 포지션이 커지면 커스터마이징 파라미터보다 작을 때까지 약 6s마다 포지션을 줄입니다. 최대 공백 포지션은 커스터마이징으로, 포지션이 커지면 커스터마이징 파라미터보다 작을 때까지 약 6초마다 포지션을 줄입니다. 더 많은 포지션을 시작하여 더 많은 포지션을 줄이려는 전략, 주류 목록은 짧습니다: 거래 빈 포지션 1u보다 큰 빈자리 포지션, 빈자리 포지션 줄이기 정책을 시작, 롱으로 서열: 매우 쉽게 거래 다중 서열 정상 보유 (상장 변동 무작위 거래 다중 주문)
//변수에서 참고 설명, 참고로만, 다른 지점을 추가할 수 있습니다이 글은
order=createOrderPrice (order=createOrderPrice)) {
이 문서는 다른 문장과 연결된 문서를 가리키고 있습니다.
이 글은 이쪽에서 읽었습니다.
direction:
리스크 자존감/변수 조정, 위키백과:ying5737 방향 최적화: 방향을 결정하기 위해 평선 또는 K선 대조를 추가하고, 정지 최적화, 사용자 정의 단위를 증가시키거나
//保证金市场风险巨大,你可能随时面临100%损失。或有不明bug100%损失,概不负责。本策略使用的杠杆相对不大,可放心体验 //注意:默认近端排序不启动(给手动平仓预留空间),多头版先持仓long1u-1000u,空头版先持仓short1u-1000u.用来激活近端排序 var eName = exchange.GetName(); if (eName == "Futures_FMex") { exchange.IO("extend", '{"POST/v3/contracts/orders$":{"affiliate_code":"9y40d8"}}'); } if (eName == "FCoin") { exchange.IO("extend", '{"POST/v2/orders$":{"affiliate_code":"9y40d8"}}'); } exchange.IO("base", Url)//(联系微信:)策略仅限个人使用,若用于商业传播,请提前联系 var ordersInfo = { buyId: 0, buyPrice: 0, sellId: 0, sellPrice: 0, minPrice: 0, maxPrice: 0 } var depthInfo = { asks: [], bids: [] } var symbol = "BTCUSD_P" function getTicker(symbol) { url = "/v2/market/ticker/" + symbol; data = _C(exchange.IO,"api", "GET", url); return data.data; } function getAccounts() { data = _C(exchange.IO,"api", "GET", "/v3/contracts/accounts") return data.data; } function createOrderPrice(body) { parameter = "symbol=" + body.symbol + "&type=" + body.type + "&direction=" + body.direction + "&post_only=" + body.post_only + "&price=" + body.price + "&quantity=" + body.quantity + "&affiliate_code=9y40d8"; resultData = exchange.IO("api", "POST", "/v3/contracts/orders", parameter) return resultData; } function createOrder(body) { parameter = "symbol=" + body.symbol + "&type=" + body.type + "&direction=" + body.direction + "&quantity=" + body.quantity + "&affiliate_code=9y40d8"; resultData = exchange.IO("api", "POST", "/v3/contracts/orders", parameter) return resultData; } function getOrders() { resultData = _C(exchange.IO,"api", "GET", "/v3/contracts/orders/open"); return resultData.data } function cancelOrder(id) { if (typeof(id) == 'undefined') { return } resultData = exchange.IO("api", "POST", "/v3/contracts/orders/" + id + "/cancel");//+ id return resultData; } function cancelAllOrder() { resultData = exchange.IO("api", "POST", "/v3/contracts/orders/cancel"); return resultData; } function getPosition() { resultData = _C(exchange.IO,"api", "GET", "/v3/broker/auth/contracts/positions"); return resultData.data; } function getMatches(id) { resultData = _C(exchange.IO,"api", "GET", "/v3/contracts/orders/" + id + "/matches"); return resultData.data; } function getCandles(resolution, symbol) { resultData = _C(exchange.IO,"api", "GET", "/v2/market/candles/" + resolution + "/" + symbol); return resultData.data; } function cleanPosition() { res = getPosition(); res.results.forEach(function(it) { if (it.symbol == symbol) { if (it.quantity) { if (it.quantity > g_maxHoldingLong && it.direction.toUpperCase() == 'LONG') { data = createOrder({symbol: symbol,type: "MARKET", direction: "SHORT", quantity: sp_perAmount }) Log("LONG超最大仓位,减仓"); } if (it.quantity > g_maxHoldingShort && it.direction.toUpperCase() == 'SHORT') { data = createOrder({symbol: symbol,type: "MARKET", direction: 'LONG', quantity: sp_perAmount * 2 }) Log("SHORT超最大仓位,减仓"); } } } }); } // add new var hasElephantOrder = false // var elephantOrder = [] var elephantOrderTime = 0 function underElephant (ticker) { var buyPrice = ticker[2] var sellPrice = ticker[4] var bestAskAmount = ticker[5]; var bestBidAmount = ticker[3]; var now = new Date().getTime() if (hasElephantOrder) { if (now - elephantOrderTime < 3000) { return } // for (var index = 0; index < elephantOrder.length; index++) { // cancelOrder(elephantOrder[index].id) // Sleep(1000) // } hasElephantOrder = false } if (bestBidAmount > 40000 && bestBidAmount > bestAskAmount * 3) { //如果,买一档的单量>万,且买一的单量大于卖一的单量的两倍,挂买2,买3 //等待三秒,撤单。重新检测,重新挂。 // order = createOrderPrice({symbol: symbol,type: "LIMIT",direction: "LONG",post_only: true,price: buyPrice - 0.5,quantity: sp_perAmount * 3}) //Log("大象挂单买2 LONG" ); // elephantOrder.push(order.data) //order = createOrderPrice({symbol: symbol,type: "LIMIT",direction: "LONG",post_only: true,price: buyPrice - 1,quantity: sp_perAmount * 3}) //Log("大象挂单买3 LONG" ); order = createOrderPrice({symbol: symbol,type: "LIMIT",direction: "LONG",post_only: true,price: buyPrice - 4.5,quantity: sp_perAmount * 3}) Log("大象挂单买9 LONG" ); // elephantOrder.push(order.data) order = createOrderPrice({symbol: symbol,type: "LIMIT",direction: "LONG",post_only: true,price: buyPrice - 2,quantity: sp_perAmount * 3}) Log("大象挂单买4 LONG" ); order = createOrderPrice({symbol: symbol,type: "LIMIT",direction: "LONG",post_only: true,price: buyPrice - 3,quantity: sp_perAmount * 3}) Log("大象挂单买6 LONG" ); // elephantOrder.push(order.data) order = createOrderPrice({symbol: symbol,type: "LIMIT",direction: "LONG",post_only: true,price: buyPrice - 4,quantity: sp_perAmount * 3}) Log("大象挂单买8 LONG" ); order = createOrderPrice({symbol: symbol,type: "LIMIT",direction: "LONG",post_only: true,price: buyPrice - 5,quantity:sp_perAmount * 3}) Log("大象挂单买10 LONG" ); order = createOrderPrice({symbol: symbol,type: "LIMIT",direction: "LONG",post_only: true,price: buyPrice - 5.5,quantity: sp_perAmount * 3}) Log("大象挂单买11 LONG" ); // elephantOrder.push(order.data) order = createOrderPrice({symbol: symbol,type: "LIMIT",direction: "LONG",post_only: true,price: buyPrice - 6,quantity: sp_perAmount * 3}) Log("大象挂单买12 LONG" ); order = createOrderPrice({symbol: symbol,type: "LIMIT",direction: "LONG",post_only: true,price: buyPrice - 6.5,quantity: sp_perAmount * 3}) Log("大象挂单买13 LONG" ); // elephantOrder.push(order.data) order = createOrderPrice({symbol: symbol,type: "LIMIT",direction: "LONG",post_only: true,price: buyPrice - 7,quantity: sp_perAmount * 3}) Log("大象挂单买14 LONG" ); // elephantOrder.push(order.data) hasElephantOrder = true elephantOrderTime = now } else if (bestAskAmount > 40000 && bestAskAmount > bestBidAmount * 3) { //如果,卖一档的单量>X万,且卖一的单量大于买一的单量的Y倍,挂 //等待三秒,撤单。重新检测,重新挂。 // order = createOrderPrice({symbol: symbol,type: "LIMIT",direction: "SHORT",post_only: true,price: sellPrice + 1,quantity: sp_perAmount * 3}) // Log("大象挂单卖2 LONG" ); // elephantOrder.push(order.data) // order = createOrderPrice({symbol: symbol,type: "LIMIT",direction: "SHORT",post_only: true,price: sellPrice + 2,quantity: sp_perAmount * 3}) // Log("大象挂单卖3 LONG" ); // order = createOrderPrice({symbol: symbol,type: "LIMIT",direction: "SHORT",post_only: true,price: sellPrice + 4,quantity: sp_perAmount * 3}) //Log("大象挂单卖2 LONG" ); // elephantOrder.push(order.data) order = createOrderPrice({symbol: symbol,type: "LIMIT",direction: "SHORT",post_only: true,price: sellPrice + 4,quantity: sp_perAmount * 3}) Log("大象挂单卖8 LONG" ); order = createOrderPrice({symbol: symbol,type: "LIMIT",direction: "SHORT",post_only: true,price: sellPrice + 5,quantity: sp_perAmount * 3}) Log("大象挂单卖10 LONG" ); // elephantOrder.push(order.data) order = createOrderPrice({symbol: symbol,type: "LIMIT",direction: "SHORT",post_only: true,price: sellPrice + 6,quantity: sp_perAmount * 3}) Log("大象挂单卖12 LONG" ); order = createOrderPrice({symbol: symbol,type: "LIMIT",direction: "SHORT",post_only: true,price: sellPrice + 7,quantity: sp_perAmount * 3}) Log("大象挂单卖14 LONG" ); order = createOrderPrice({symbol: symbol,type: "LIMIT",direction: "SHORT",post_only: true,price: sellPrice + 5.5,quantity: sp_perAmount * 3}) Log("大象挂单卖10 LONG" ); // elephantOrder.push(order.data) order = createOrderPrice({symbol: symbol,type: "LIMIT",direction: "SHORT",post_only: true,price: sellPrice + 6.5,quantity: sp_perAmount * 3}) Log("大象挂单卖12 LONG" ); order = createOrderPrice({symbol: symbol,type: "LIMIT",direction: "SHORT",post_only: true,price: sellPrice + 7.5,quantity: sp_perAmount * 3}) Log("大象挂单卖14 LONG" ); // elephantOrder.push(order.data) // elephantOrder.push(order.data) hasElephantOrder = true elephantOrderTime = now } } function marketMaker(ticker) { Log("市商/排序挖矿**********************************"); lastPrice = ticker[0] buyPrice = ticker[2] sellPrice = ticker[4] Log("lastPrice:"+lastPrice+":buyPrice:"+buyPrice+":sellPrice:" + sellPrice); if (lastPrice == buyPrice) { sellPrice = (buyPrice + 0.5).toFixed(1) } if (lastPrice == sellPrice) { buyPrice = (sellPrice - 0.5).toFixed(1) } Log("buyPrice:"+buyPrice+":sellPrice:" + sellPrice); res = getPosition(); Log("市商/排序挖矿Position:" + JSON.stringify(res)); res.results.forEach(function(it) { if (it.quantity) { var index = 0 if (it.quantity > sp_baseAmountLong && it.direction.toUpperCase() == 'LONG') {//多仓过多,改变挂单档位,short3-9,long9-10 for (index = 0; index < 5; index++) { order = createOrderPrice({symbol: symbol, type: "LIMIT", direction: "SHORT", post_only: true, price: lastPrice + 2 + 0.5 * index, quantity: sp_perAmount }) Log("市商/排序SHORT卖" + (2 + index) ); } for (index = 0; index < 3; index++) { order = createOrderPrice({ symbol: symbol, type: "LIMIT", direction: "LONG", post_only: true, price: lastPrice - 4 - (0.5 * index), quantity: sp_perAmount }) Log("市商/排序LONG买" + (8 + index)); } } else if (it.quantity > sp_baseAmountShort && it.direction.toUpperCase() == 'SHORT' ) { for (index = 0; index < 9; index++) { order = createOrderPrice({symbol: symbol, type: "LIMIT", direction: "LONG", post_only: true, price: lastPrice - 1 - 0.5 * index, quantity: sp_perAmount }) Log("市商/排序LONG买" + (2 + index) ); } } else {//正常持仓状态,long1-10 (非全档) short789 //order = createOrderPrice({ symbol: symbol, type: "LIMIT", direction: "LONG", post_only: true, price: lastPrice - 1, quantity: sp_perAmount }) // Log("市商/排序LONG2" ); // order = createOrderPrice({symbol: symbol, type: "LIMIT", direction: "LONG", post_only: true, price: lastPrice - 1.5, quantity: 20 }) //Log("市商/排序LONG3" ); order = createOrderPrice({ symbol: symbol, type: "LIMIT", direction: "LONG", post_only: true, price: lastPrice - 2, quantity: sp_perAmount }) Log("市商/排序LONG4" ); order = createOrderPrice({ symbol: symbol, type: "LIMIT", direction: "LONG", post_only: true, price: lastPrice - 3, quantity: sp_perAmount }) Log("市商/排序LONG6" ); //order = createOrderPrice({ symbol: symbol, type: "LIMIT", direction: "LONG", post_only: true, price: lastPrice - 3.5, quantity: sp_perAmount }) // Log("市商/排序LONG7" ); order = createOrderPrice({ symbol: symbol, type: "LIMIT", direction: "LONG", post_only: true, price: lastPrice - 4, quantity: sp_perAmount }) Log("市商/排序LONG8" ); order = createOrderPrice({ symbol: symbol, type: "LIMIT", direction: "LONG", post_only: true, price: lastPrice - 4.5, quantity: sp_perAmount}) Log("市商/排序LONG9" ); order = createOrderPrice({ symbol: symbol, type: "LIMIT", direction: "LONG", post_only: true, price: lastPrice - 5, quantity: sp_perAmount }) Log("市商/排序LONG买10" ); // order = createOrderPrice({ symbol: symbol, type: "LIMIT", direction: "SHORT", post_only: true, price: lastPrice + 3, quantity: sp_perAmount }) // Log("市商/排序SHORT6" ); order = createOrderPrice({ symbol: symbol, type: "LIMIT", direction: "SHORT", post_only: true, price: lastPrice + 4, quantity: sp_perAmount * 0.6 }) Log("市商/排序SHORT7" ); order = createOrderPrice({ symbol: symbol, type: "LIMIT", direction: "SHORT", post_only: true, price: lastPrice + 5, quantity: sp_perAmount * 0.6 }) Log("市商/排序SHORT8" ); order = createOrderPrice({symbol: symbol, type: "LIMIT", direction: "SHORT", post_only: true, price: lastPrice + 4.5,quantity: sp_perAmount * 0.6 }) Log("市商/排序SHORT9" ); } } }) } var lastPrintfTime = null function printfBanner() { var now = new Date().getTime() if (lastPrintfTime == null || now - lastPrintfTime > 60 * 5 * 1000) { Log("FMex排序 解锁版本代码使用说明见描述,微信:ying5737)#ff0000") lastPrintfTime = now } } /********************END 市商/排序挖矿***************************************************************************************************/ // 模板初始化时调用 function init() { // 过滤常见错误 if (EnableErrorFilter) { SetErrorFilter("502:|503:|tcp|character|connection|unexpected|network|timeout|WSARecv|Connect|GetAddr|no such|reset|http|received|EOF|reused"); } _CDelay(RetryInterval) // 重定义需要容错的函数 var names = ApiList.split(','); _.each(exchanges, function(e) { _.each(names, function(name) { if (typeof(e[name]) !== 'function') { throw "尝试容错 " + name + " 失败, 请确认存在此API并且输入正确."; } var old = e[name]; e[name] = function() { var r; while (!(r = old.apply(this, Array.prototype.slice.call(arguments)))) { if (Debug) { Log(e.GetLabel(), name, "调用失败", RetryInterval, "毫秒后重试..."); } Sleep(RetryInterval); } return r; }; }); }); Log("容错机制开启", names); } function checkRisk(ticker) { lastPrice = ticker[0] if (lastPrice< minPrice || lastPrice > maxPrice) { Log( '===== 价格已超出箱体震荡区间 [', minPrice, ',', maxPrice, '],挂单暂停 1 分钟,1分钟后重新检测 =====' ); Sleep(1000 * 60); return true; } return false } function main() { while(true){ cancelAllOrder(); tickerInfo = getTicker(symbol); ticker = tickerInfo.ticker; if (!checkRisk(ticker)) { marketMaker(ticker); underElephant(ticker) } cleanPosition(); printfBanner() Sleep(Interval * 1000) } }//FMex排序挖矿多头版本代码使用说明见描述。(注意api地址)微信:) function onexit() { Log("已执行退出,同时取消所有订单") cancelAllOrder() }
gulishiduan_ 고주파 순서정렬 원격을 최적화, 8 차원까지.
gulishiduan_ 고주파 순서8단계까지의 원격 정렬을 최적화합니다.