只做正套,反套可以修改下,合约调换一下,即是反套。
添加两个 交易所对象,第一个季度,第二个当周。
精简了所有能简化的代码,优化空间还很大,教学策略谨慎实盘,跨期有一定风险。
欢迎反馈BUG。
function Hedge (isOpen, priceA, priceB) { exchanges[0].SetDirection(isOpen ? "sell" : "closesell") exchanges[1].SetDirection(isOpen ? "buy" : "closebuy"); (function (routineA, routineB) { Log(routineA.wait(), routineB.wait(), priceA, priceB) })(exchanges[0].Go(isOpen ? "Sell" : "Buy", priceA, _ContractNum), exchanges[1].Go(isOpen ? "Buy" : "Sell", priceB, _ContractNum)); } var slidePrice = 5 function main () { var tickerA, tickerB var arr = [] for (var i = 0 ; i < _Count ; i++) { arr.push({open: _Begin + i * _Add, cover: _Begin + i * _Add - _Profit, isHold: false}) } exchanges[0].SetContractType("quarter") exchanges[1].SetContractType("this_week") while (1) { var tab = {type: "table", title: "状态", cols: ["节点信息"], rows: []} tickerA = exchanges[0].GetTicker() tickerB = exchanges[1].GetTicker() if (tickerA && tickerB) { $.PlotLine("差价:A所-B所", tickerA.Last - tickerB.Last) for (var j = 0 ; j < arr.length; j++) { if (tickerA.Buy - tickerB.Sell > arr[j].open && !arr[j].isHold) { Hedge(true, tickerA.Buy - slidePrice, tickerB.Sell + slidePrice) arr[j].isHold = true } if (tickerA.Sell - tickerB.Buy < arr[j].cover && arr[j].isHold) { Hedge(false, tickerA.Sell + slidePrice, tickerB.Buy - slidePrice) arr[j].isHold = false } tab.rows.push([JSON.stringify(arr[j])]) } } LogStatus(_D(), "\n `" + JSON.stringify(tab) + "`") Sleep(500) } }
爱Jimmy exchanges[0].Go()这个函数文档里面没有说明吧?哪来的,什么意思?求链接。
ll1998 你好,作者,请问这个策略还能用了吗?
fmzero 教学视频在哪里啊
爱Jimmy 哦,多谢,看到了,学习上了
发明者量化-小小梦 API文档有的https://www.fmz.com/api#exchange.go...
发明者量化-小小梦 策略为教学策略,实盘慎用。可以自行修改、扩展、优化。
发明者量化-小小梦 这个源码很简单的,看源码就明白。