सिक्के के घेरे को मात्रात्मक रूप से व्यापार करने के लिए एक नया तरीका है - आपको सिक्के के घेरे को मात्रात्मक रूप से लाने के लिए।

लेखक:छोटे सपने, बनाया गयाः 2021-06-09 14:30:43, अद्यतन किया गयाः 2023-09-19 21:45:29

img

सिक्के के घेरे को मात्रात्मक रूप से व्यापार करने के लिए एक नया रूप है और यह आपको सिक्के के घेरे के करीब ले जाता है।

पिछले लेख में हमने एक साथ सोचा था, एक सरल बहुआयामी ग्रिड रणनीति तैयार की थी। इसके बाद, हम व्यापार को मात्रात्मक बनाने के रास्ते पर सीखना जारी रखते हैं, आगे बढ़ते हैं। इस लेख में हम थोड़ा अधिक जटिल रणनीतिक डिजाइन-हेजिंग रणनीति के डिजाइन की तलाश करते हैं। इस लेख में एक बहुआयामी दीर्घकालिक हेजिंग रणनीति डिजाइन करने की योजना बनाई गई है, जो कि दीर्घकालिक हेजिंग रणनीतियों से परिचित है।

दीर्घकालिक प्रतिभूति

यह केवल एक और अनुबंध बनाने, एक और अनुबंध खाली करने और तीन स्थितियों के लिए एक साथ (बहुत, खाली) पोजिशनिंग का इंतजार करने के लिए है।

  • अधिक कमाई, कम कमाई, अधिक कमाई, अधिक कमाई, अधिक कमाई और अधिक हानि के बाद लाभ का एक हिस्सा।
  • बहुत सारा पैसा खोने के लिए, कुछ भी नहीं करने के लिए, एक पैसा खोने के लिए एक से अधिक समय के लिए, एक ही समय में, एक ही समय में,...
  • जो अधिक कमाता है, वह कम भी कमाता है, और वह भी पैसा चाहता है!

अन्य स्थिति में, आप घाटा उठाते हैं, रोकते हैं, या आगे बढ़ते हैं। (क्योंकि एकतरफा उतार-चढ़ाव के मुकाबले अंतर में उतार-चढ़ाव अधिक होता है, सापेक्ष जोखिम कम होता है, ध्यान केवल सापेक्ष है!

设A1为合约A在1时刻的价格,设B1为合约B在1时刻的价格,此时做空A合约,做空价格A1,做多B合约,做多价格B1。
设A2为合约A在2时刻的价格,设B2为合约B在2时刻的价格,此时平仓A合约(平空),平空价格A2,平仓B合约(平多),平多价格B2。

1时刻的差价:A1 - B1 = X 
2时刻的差价:A2 - B2 = Y 
X - Y = A1 - B1 - (A2 - B2)
X - Y = A1 - B1 - A2 + B2
X - Y = A1 - A2 + B2 - B1

可以看到,A1 - A2 就是A合约平仓的盈利差价。
B2 - B1就是B合约平仓的盈利差价。只要这两个平仓总体是正数,即:A1 - A2 + B2 - B1 > 0 就是盈利的。也就是说只要X - Y > 0。
因为:X - Y = A1 - A2 + B2 - B1

得出结论,只要开仓时的差价X大于平仓时的差价Y就是盈利的(注意是做空A,做多B开仓,搞反了就是相反的了),当然这个是理论上的,实际上还要考虑手续费、滑点等因素。

चूंकि डिजिटल मुद्रा एक्सचेंजों में सौदे के लिए दरें होती हैं, इसलिए स्थायी अनुबंध भी होते हैं; और स्थायी अनुबंध की कीमतें हमेशा मौद्रिक दरों के कारण वास्तविक कीमतों के करीब होती हैं; इसलिए हम सौदे के लिए दरों और स्थायी अनुबंधों के लिए हेजिंग सूट का उपयोग करना चुनते हैं; अनुपात अनुबंध एक लंबी अवधि के अनुबंध का चयन करता है, ताकि अक्सर हेजिंग अनुबंध स्थापित न किए जाएं।

पहले एक बहु-प्रजाति मूल्य अंतर के बारे में बात करते हैं।

मूल सिद्धांतों के साथ परिचित होने के बाद, आपको अपनी रणनीति लिखने में जल्दबाजी नहीं करनी चाहिए। पहले एक अंतर आंकड़ा बनाएं, एक ग्राफ बनाएं, अंतर देखें। एक साथ कई प्रकार की रणनीति ग्राफ सीखें।

हम आधारित हैंओकेएक्स अनुबंधडिजाइन करने के लिए, एफएमजेड पर ग्राफ बनाना बहुत आसान है, और अच्छी तरह से पैक किए गए फ़ंक्शन का उपयोग करके ग्राफ बनाना बहुत आसान है।उच्च चार्ट◎ एपीआई दस्तावेज़ में चित्र फ़ंक्शन का वर्णनःhttps://www.fmz.com/api#chart...

चूंकि यह कई किस्में हैं, इसलिए चित्र को प्रिंट करने से पहले किस्में के अंतर का पता लगाना आवश्यक है। कोड में पहले दो सूत्र लिखें, जो अनुबंध को इंगित करते हैं।

var arrSwapContractType = ["BTC-USDT-SWAP", "LTC-USDT-SWAP", "ETH-USDT-SWAP", "ETC-USDT-SWAP"]   // 永续合约
var arrDeliveryContractType = ["BTC-USDT-210924", "LTC-USDT-210924", "ETH-USDT-210924", "ETC-USDT-210924"]  // 交割合约

अनुबंध कोड के आधार पर, यहाँ सेट किए गए ग्राफ़ कॉन्फ़िगरेशन को आरंभ करें. यह ग्राफ़ कॉन्फ़िगरेशन निश्चित रूप से मर नहीं सकता है, क्योंकि आपको यह भी नहीं पता कि कौन सी किस्म, कई किस्मों को करना है (ये arrDeliveryContractType और arrSwapContractType के मान के आधार पर निर्धारित होते हैं), इसलिए ग्राफ़ कॉन्फ़िगरेशन एक फ़ंक्शन द्वारा लौटाया जाता है.

function createCfg(symbol) {
    var cfg = {
        extension: {
            // 不参于分组,单独显示,默认为分组 'group'
            layout: 'single', 
            // 指定高度,可以设置为字符串,"300px",设置数值300会自动替换为"300px"
            height: 300,      
            // 指定宽度占的单元值,总值为12
            col: 6
        },
        title: {
            text: symbol
        },
        xAxis: {
            type: 'datetime'
        },
        series: [{
            name: 'plus',
            data: []
        }]
    }

    return cfg
}

function main() {
    // 声明arrCfg
    var arrCfg = []                                    // 声明一个数组,用来存放图表配置信息
    _.each(arrSwapContractType, function(ct) {         // 迭代记录永续合约代码的数组,用合约名称XXX-USDT部分作为参数传给createCfg函数,构造图表配置信息,返回
        arrCfg.push(createCfg(formatSymbol(ct)[0]))    // createCfg返回的图表配置信息push进arrCfg数组
    })
    var objCharts = Chart(arrCfg)                      // 调用FMZ平台的图表函数Chart,创建图表控制对象objCharts
    objCharts.reset()                                  // 初始化图表内容
    
    // 以下省略.....
}

अब हम डेटा तैयार करते हैं, और हम OKEX अनुबंध के एक एग्रीगेटेड मार्केट इंटरफेस का उपयोग करते हैंः

USDT के लिए स्थायी अनुबंधः

https://www.okex.com/api/v5/market/tickers?instType=SWAP

USDT का लेन-देन अनुपात लगभगः

https://www.okex.com/api/v5/market/tickers?instType=FUTURES

हम एक फ़ंक्शन लिखते हैं जो इन दोनों इंटरफेस के कॉल को संभालता है और डेटा को एक प्रारूप में बदल देता हैः

function getTickers(url) {
    var ret = []
    try {
        var arr = JSON.parse(HttpQuery(url)).data
        _.each(arr, function(ele) {
            ret.push({
                bid1: parseFloat(ele.bidPx),             // 买一价
                bid1Vol: parseFloat(ele.bidSz),          // 买一价的量
                ask1: parseFloat(ele.askPx),             // 卖一价
                ask1Vol: parseFloat(ele.askSz),          // 卖一价的量
                symbol: formatSymbol(ele.instId)[0],     // 格式成交易对
                type: "Futures",                         // 类型
                originalSymbol: ele.instId               // 原始合约代码
            })
        })
    } catch (e) {
        return null 
    }
    return ret 
}

और फिर एक फ़ंक्शन को संसाधित करने के लिए अनुबंध कोड लिखें

function formatSymbol(originalSymbol) {
    var arr = originalSymbol.split("-")
    return [arr[0] + "_" + arr[1], arr[0], arr[1]]
}

अब आपको केवल प्राप्त डेटा का पुनरावर्ती मिलान करना है, अंतर की गणना करना है, चार्ट आउटपुट करना है, आदि। यहाँ पर हम Q2 210,924 और स्थायी अनुबंध के बीच अंतर का परीक्षण करते हैं। पूरा कोडः

// 临时参数
var arrSwapContractType = ["BTC-USDT-SWAP", "LTC-USDT-SWAP", "ETH-USDT-SWAP", "ETC-USDT-SWAP"]
var arrDeliveryContractType = ["BTC-USDT-210924", "LTC-USDT-210924", "ETH-USDT-210924", "ETC-USDT-210924"]
var interval = 2000

function createCfg(symbol) {
    var cfg = {
        extension: {
            // 不参于分组,单独显示,默认为分组 'group'
            layout: 'single', 
            // 指定高度,可以设置为字符串,"300px",设置数值300会自动替换为"300px"
            height: 300,      
            // 指定宽度占的单元值,总值为12
            col: 6
        },
        title: {
            text: symbol
        },
        xAxis: {
            type: 'datetime'
        },
        series: [{
            name: 'plus',
            data: []
        }]
    }

    return cfg
}

function formatSymbol(originalSymbol) {
    var arr = originalSymbol.split("-")
    return [arr[0] + "_" + arr[1], arr[0], arr[1]]
}

function getTickers(url) {
    var ret = []
    try {
        var arr = JSON.parse(HttpQuery(url)).data
        _.each(arr, function(ele) {
            ret.push({
                bid1: parseFloat(ele.bidPx), 
                bid1Vol: parseFloat(ele.bidSz), 
                ask1: parseFloat(ele.askPx), 
                ask1Vol: parseFloat(ele.askSz), 
                symbol: formatSymbol(ele.instId)[0], 
                type: "Futures", 
                originalSymbol: ele.instId
            })
        })
    } catch (e) {
        return null 
    }
    return ret 
}

function main() {
    // 声明arrCfg
    var arrCfg = []
    _.each(arrSwapContractType, function(ct) {
        arrCfg.push(createCfg(formatSymbol(ct)[0]))
    })
    var objCharts = Chart(arrCfg)
    objCharts.reset()
    
    while (true) {
        // 获取行情数据        
        var deliveryTickers = getTickers("https://www.okex.com/api/v5/market/tickers?instType=FUTURES")
        var swapTickers = getTickers("https://www.okex.com/api/v5/market/tickers?instType=SWAP")
        if (!deliveryTickers || !swapTickers) {
            Sleep(2000)
            continue
        }

        var tbl = {
            type : "table",
            title : "交割-永续差价",
            cols : ["交易对", "交割", "永续", "正对冲", "反对冲"],
            rows : []
        }
        
        var subscribeDeliveryTickers = []
        var subscribeSwapTickers = []
        _.each(deliveryTickers, function(deliveryTicker) {
            _.each(arrDeliveryContractType, function(symbol) {
                if (deliveryTicker.originalSymbol == symbol) {
                    subscribeDeliveryTickers.push(deliveryTicker)
                }
            })
        })
        _.each(swapTickers, function(swapTicker) {
            _.each(arrSwapContractType, function(symbol) {
                if (swapTicker.originalSymbol == symbol) {
                    subscribeSwapTickers.push(swapTicker)
                }
            })
        })
        
        var pairs = []
        var ts = new Date().getTime()
        _.each(subscribeDeliveryTickers, function(deliveryTicker) {
            _.each(subscribeSwapTickers, function(swapTicker) {
                if (deliveryTicker.symbol == swapTicker.symbol) {
                    var pair = {symbol: swapTicker.symbol, swapTicker: swapTicker, deliveryTicker: deliveryTicker, plusDiff: deliveryTicker.bid1 - swapTicker.ask1, minusDiff: deliveryTicker.ask1 - swapTicker.bid1}
                    pairs.push(pair)
                    tbl.rows.push([pair.symbol, deliveryTicker.originalSymbol, swapTicker.originalSymbol, pair.plusDiff, pair.minusDiff])
                    for (var i = 0 ; i < arrCfg.length ; i++) {
                        if (arrCfg[i].title.text == pair.symbol) {
                            objCharts.add([i, [ts, pair.plusDiff]])
                        }                        
                    }                    
                }
            })
        })

        LogStatus(_D(), "\n`" + JSON.stringify(tbl) + "`")        
        Sleep(interval)
    }
}

वास्तविक डिस्क चल रहा है

img

कुछ देर के लिए दौड़ो।

img

एक बार फिर, एक बार फिर, एक बार फिर, एक बार फिर!img


संबंधित

अधिक

जीवों का मार्गयह सीधे चल सकता है, ओकेएक्स के अगले सीज़न में नकदी की कमी हो सकती है या कुछ और, गिरने पर गिरावट, गिरने पर उछाल।

माइनस क्वांटिफाइंगबहुत अच्छा, बहुत अच्छा।