コインローブには手動取引をする友人が多いが,プログラミング設計の入門は長い時間がかかる. このような必要性に基づいて,この記事を共同で設計した.
まず,需要分析をします. このロボットの機能は,あるアカウントで買い物が行われると,他のアカウントがそれを実行することを実行することです. この2つの主体について,まず2つの主体について説明します.
参考アカウントの動きをどのように識別するか? 参考アカウントの動きをどのように識別するか?
参考口座の監視は,現金口座では非常に簡単で,最新の口座情報データと最新の口座情報データとの比較だけでできます. 現在の取得された最新のアカウント情報データ内のコインの数が前回の記録よりも多くなった場合,参照アカウントが購入操作を実行し,購入が成功したことを証明します.逆にコインが少なくなった場合は,参照アカウントに販売操作を実行します.この動作を発見した後,他の取引所のアカウントに同じ操作を実行させることができます.
参照アカウントが取引を行ったことを発見した後に,新しい取引行動がないかどうかを判断するために,次の取得したアカウント情報との比較のために,最新のアカウントデータレコーディングを更新することが必要です.
戦略コードで説明する論理は以下の通りです.
// 检测跟单
var amount = (nowAcc.Stocks + nowAcc.FrozenStocks) - (initAcc.Stocks + initAcc.FrozenStocks) // 检测币数发生的变化
var func = null
if (amount > 0) { // 币变多了
func = $.Buy // 买入
} else if (amount < 0) { // 币变少了
func = $.Sell // 卖出
} else {
continue
}
// 执行跟单
Log("跟单!数量:", Math.abs(amount), "#FF0000")
for (var i = 1 ; i < exchanges.length ; i++) { // i 等于 0 时,是参考交易所,不处理,处理其它的跟单交易所
func(exchanges[i], Math.abs(amount)) // 执行具体的交易函数,可能是$.Buy 或者是 $.Sell ,具体看amount 是大于0,还是小于0
}
// 执行跟单之后更新参考交易所账户信息记录
initAcc = nowAcc // 更新参考交易所最近一次的账户信息,用于下次对比
策略の主な検出論理は上記のコードである. 簡潔な設計のために,策略はFMZの公式の$.Buy
, $.Sell
このテンプレートの関数は,次の操作を実行する機能である.
詳細は以下の通りです. 詳細は以下の通りです.
function test() {
// 测试函数
var ts = new Date().getTime()
if (ts % (1000 * 60 * 60 * 6) > 1000 * 60 * 60 * 5.5) {
Sleep(1000 * 60 * 10)
var x = Math.random()
if (x > 0.5) {
$.Buy(exchange, x / 10)
} else {
$.Sell(exchange, x / 10)
}
}
}
function main() {
LogReset(1)
if (exchanges.length < 2) {
throw "没有跟单的交易所"
}
var exName = exchange.GetName()
// 检测参考交易所
if (exName.includes("Futures_")) {
throw "仅支持现货跟单"
}
Log("开始监控", exName, "交易所", "#FF0000")
// 检测跟单交易所
for (var i = 1 ; i < exchanges.length ; i++) {
if (exchanges[i].GetName().includes("Futures_")) {
throw "不支持期货交易所跟单"
}
}
var initAcc = _C(exchange.GetAccount)
while(1) {
if(IsVirtual()) {
// 测试函数
test()
}
Sleep(5000)
// 更新参考账户当前的账户信息
var nowAcc = _C(exchange.GetAccount)
// 参考交易所账户信息
var refTbl = {
type : "table",
title : "参考交易所",
cols : ["名称", "币", "冻结币", "钱", "冻结钱"],
rows : []
}
refTbl.rows.push([exName, nowAcc.Stocks, nowAcc.FrozenStocks, nowAcc.Balance, nowAcc.FrozenBalance])
// 跟单交易所账户信息
var followTbl = {
type : "table",
title : "跟单交易所",
cols : ["名称", "币", "冻结币", "钱", "冻结钱"],
rows : []
}
for (var i = 1 ; i < exchanges.length ; i++) {
var acc = _C(exchanges[i].GetAccount)
var name = exchanges[i].GetName()
followTbl.rows.push([name, acc.Stocks, acc.FrozenStocks, acc.Balance, acc.FrozenBalance])
}
// 状态栏显示
LogStatus(_D(), "\n`" + JSON.stringify(refTbl) + "`", "\n`" + JSON.stringify(followTbl) + "`")
// 检测跟单
var amount = (nowAcc.Stocks + nowAcc.FrozenStocks) - (initAcc.Stocks + initAcc.FrozenStocks)
var func = null
if (amount > 0) {
func = $.Buy
} else if (amount < 0) {
func = $.Sell
} else {
continue
}
// 执行跟单
Log("跟单!数量:", Math.abs(amount), "#FF0000")
for (var i = 1 ; i < exchanges.length ; i++) {
func(exchanges[i], Math.abs(amount))
}
// 执行跟单之后更新参考交易所账户信息记录
initAcc = nowAcc
}
}
FMZのwexAppシミュレーション取引所の実用テストを行います. ここで私は3つのwexAppアカウントを追加しました.
機械が自動的に注文するかどうかを確認するために,FMZの取引端末で次の单元を手動に移動します.
ロボットが取引を検知し,順序操作を実行しているのが見えます.
海外のメディアは,https://www.fmz.com/strategy/255182
この戦略は学習のみで,問題があればコメントをありがとうございます.
サイア人こんにちは. 配備の費用を払って手伝ってくれませんか. ありがとうございます.
サイア人こんにちは. 配備の費用を払って手伝ってくれませんか. ありがとうございます.
太った子吊り箱は吊り箱を検知できるのか?
13169222039このコインの番号は,このコインの上の番号です.
発明者 量化 - 微かな夢この策略はオープンソースで,策略広場で公開されている. FMZコミュニティが掲示したチュートリアルを見ることができます. 初級チュートリアルは教育用であり,基本的な用途は展開できます.
ルーツメコインに遅れがあるので,あなたの価格が彼らの価格と大きく異なる可能性があります.