Стратегия высокочастотных долгосрочных опционов

Автор:Да ладно тебе, Маленький Волшебник., Дата: 2020-05-12 21:55:43
Тэги:

Стратегические указания

Например, в Китае, в Китае, в Китае, в Китае, в Китае, в Китае, в Китае.

Данные о ценовой разнице: BTC устойчивый - BTC квартальный ((исключить проверку совпадения)

Цикл сделок: 1 минута

头寸匹配:1:1

Тип сделки: однородный период

Условия открытия длительного дифференцированного опциона: если текущий счет не имеет акций, и длительный дифференцированный опцион < (долгосрочный уровень дифференцированного опциона - порог), то длительный дифференцированный опцион; т.е.: купить BTC постоянно, продать BTC квартально.

Условия открытия дифференцированной сделки: если текущий счет не имеет акций, и дифференцированная цена > (долгосрочный уровень дифференциации + порог), дифференцированная сделка осуществляется; то есть: продать BTC постоянно, купить BTC квартально.

Условия проведения длительного дифференцированного баланса: если текущий счет имеет длительный дифференцированный баланс BTC и имеет квартальный дифференцированный баланс BTC, и дифференцированный баланс > длительный дифференцированный баланс, то длительный дифференцированный баланс.

Условия проведения дифференцированного баланса: если текущий счет имеет постоянные вакансии BTC и имеет несколько квартальных ордеров BTC, а дифференциация <долгосрочный уровень дифференциации, то дифференциация будет длиться длительное время.

Например:Предположим, что длительная разница между BTC и BTC длится около 35 дней. Если длительная разница достигнет 50 дней, мы ожидаем, что она вернется до 35 и ниже в будущем. Тогда можно продать BTC длительным, а также купить BTC в течение периода, чтобы покрыть эту разницу.

Контактная информация

:point_right: Если вы заинтересованы в этой стратегии, пожалуйста, +V:Irene11229 (Нажмите на мою страницу, я буду постоянно обновлять больше стратегий, а также получать данные о рыночном анализе на нескольких ведущих биржах)


#!/usr/bin/env python3
# -*- coding: utf-8 -*-

import json
import time

from kumex.client import Trade, Market


class Hf(object):

    def __init__(self):
        # read configuration from json file
        with open('config.json', 'r') as file:
            config = json.load(file)

        self.api_key = config['api_key']
        self.api_secret = config['api_secret']
        self.api_passphrase = config['api_passphrase']
        self.sandbox = config['is_sandbox']
        self.symbol_a = config['symbol_a']
        self.symbol_b = config['symbol_b']
        self.spread_mean = float(config['spread_mean'])
        self.leverage = float(config['leverage'])
        self.size = int(config['size'])
        self.num_param = float(config['num_param'])
        self.trade = Trade(self.api_key, self.api_secret, self.api_passphrase, is_sandbox=self.sandbox)
        self.market = Market(self.api_key, self.api_secret, self.api_passphrase, is_sandbox=self.sandbox)

    def get_symbol_price(self, symbol):
        ticker = self.market.get_ticker(symbol)
        return float(ticker['price'])


if __name__ == '__main__':
    hf = Hf()
    while 1:
        # ticker of symbols
        price_af = hf.get_symbol_price(hf.symbol_a)
        price_bf = hf.get_symbol_price(hf.symbol_b)
        # position of symbols
        position_a = hf.trade.get_position_details(hf.symbol_a)
        position_a_qty = int(position_a['currentQty'])
        position_b = hf.trade.get_position_details(hf.symbol_b)
        position_b_qty = int(position_b['currentQty'])
        # interval of price
        new_spread = price_af - price_bf
        print('new_spread =', new_spread)

        if position_a_qty == position_b_qty == 0 and new_spread < (hf.spread_mean - hf.num_param):
            buy_order = hf.trade.create_limit_order(hf.symbol_a, 'buy', hf.leverage, hf.size, price_af + 1)
            print('buy %s,order id =%s' % (hf.symbol_a, buy_order['orderId']))
            sell_order = hf.trade.create_limit_order(hf.symbol_b, 'sell', hf.leverage, hf.size, price_bf - 1)
            print('sell %s,order id =%s' % (hf.symbol_b, sell_order['orderId']))
        elif position_a_qty == position_b_qty == 0 and new_spread > (hf.spread_mean + hf.num_param):
            buy_order = hf.trade.create_limit_order(hf.symbol_a, 'sell', hf.leverage, hf.size, price_af - 1)
            print('sell %s,order id =%s' % (hf.symbol_a, buy_order['orderId']))
            sell_order = hf.trade.create_limit_order(hf.symbol_b, 'buy', hf.leverage, hf.size, price_bf + 1)
            print('buy %s,order id =%s' % (hf.symbol_b, sell_order['orderId']))
        elif position_a_qty > 0 and position_b_qty < 0 and new_spread > hf.spread_mean:
            buy_order = hf.trade.create_limit_order(hf.symbol_a, 'sell', position_a['realLeverage'],
                                                    position_a_qty, price_af + 1)
            print('sell %s,order id =%s' % (hf.symbol_a, buy_order['orderId']))
            sell_order = hf.trade.create_limit_order(hf.symbol_b, 'buy', position_a['realLeverage'],
                                                     position_a_qty, price_bf - 1)
            print('buy %s,order id =%s' % (hf.symbol_b, sell_order['orderId']))
        elif position_a_qty < 0 and position_b_qty > 0 and new_spread < hf.spread_mean:
            buy_order = hf.trade.create_limit_order(hf.symbol_a, 'buy', position_a['realLeverage'],
                                                    position_a_qty, price_af - 1)
            print('buy %s,order id =%s' % (hf.symbol_a, buy_order['orderId']))
            sell_order = hf.trade.create_limit_order(hf.symbol_b, 'sell', position_a['realLeverage'],
                                                     position_a_qty, price_bf + 1)
            print('sell %s,order id =%s' % (hf.symbol_b, sell_order['orderId']))

        time.sleep(60)

Больше

принимающийВы говорите наоборот, что постоянные цены почти такие же, как и текущие цены, и цены значительно выше. Должно быть, цены выше в квартале, как это будет покупать в квартале, должно быть покупать в квартале, продавать в квартале.