В процессе загрузки ресурсов... загрузка...

Научить вас преобразовывать одновидовую стратегию Python в многовидовую

Автор:FMZ~Lydia, Создано: 2022-12-20 17:26:27, Обновлено: 2023-09-20 09:45:28

img

Научить вас преобразовывать одновалютную стратегию Python в многовалютную стратегию

I. Научить вас преобразовывать одновалютную стратегию Python в многовалютную стратегию

В последней статье была реализована очень простая стратегия Python:Стратегия покупки победителей версии Python, эта стратегия может управлять аккаунтом для проведения программной торговли на определенной торговой паре. Принцип очень прост, то есть преследовать после увеличения и убивать после уменьшения. Иногда мы хотим использовать одну и ту же логику торговли для работы с разными торговыми парами. Вы можете создать несколько роботов и установить разные торговые пары для проведения транзакций в разных валютах. Если стратегия не очень сложна, ввиду сильной гибкости FMZ Quant Trading Platform, легко превратить стратегию в многовидовую стратегию, так что вы можете запустить несколько торговых пар, создав только один робот.

Источник стратегии после преобразования:

'''backtest
start: 2019-02-20 00:00:00
end: 2020-01-10 00:00:00
period: 1m
exchanges: [{"eid":"OKEX","currency":"BTC_USDT"},{"eid":"OKEX","currency":"ETH_USDT","stocks":30},{"eid":"OKEX","currency":"LTC_USDT","stocks":100}]
'''

import time
import json

params = {
    "arrBasePrice": [-1, -1, -1],     # -1
    "arrRatio": [0.05, 0.05, 0.05],         # 0.05
    "arrAcc": [],           # _C(exchange.GetAccount)
    "arrLastCancelAll": [0, 0, 0], # 0
    "arrMinStocks": [0.01, 0.01, 0.01],     # 0.01
    "arrPricePrecision": [2, 2, 2], # 2
    "arrAmountPrecision": [3, 2, 2], # 2
    "arrTick":[]
}

def CancelAll(e):
    while True : 
        orders = _C(e.GetOrders)
        for i in range(len(orders)) :
            e.CancelOrder(orders[i]["Id"], orders[i])
        if len(orders) == 0 :
            break
        Sleep(1000)

def process(e, index):
    global params
    ticker = _C(e.GetTicker)
    params["arrTick"][index] = ticker
    if params["arrBasePrice"][index] == -1 :
        params["arrBasePrice"][index] = ticker.Last
    if ticker.Last - params["arrBasePrice"][index] > 0 and (ticker.Last - params["arrBasePrice"][index]) / params["arrBasePrice"][index] > params["arrRatio"][index]:
        params["arrAcc"][index] = _C(e.GetAccount)
        if params["arrAcc"][index].Balance * params["arrRatio"][index] / ticker.Last > params["arrMinStocks"][index]:
            e.Buy(ticker.Last, params["arrAcc"][index].Balance * params["arrRatio"][index] / ticker.Last)
            params["arrBasePrice"][index] = ticker.Last
    if ticker.Last - params["arrBasePrice"][index] < 0 and (params["arrBasePrice"][index] - ticker.Last) / params["arrBasePrice"][index] > params["arrRatio"][index]: 
        params["arrAcc"][index] = _C(e.GetAccount)
        if params["arrAcc"][index].Stocks * params["arrRatio"][index] > params["arrMinStocks"][index]:
            e.Sell(ticker.Last, params["arrAcc"][index].Stocks * params["arrRatio"][index])
            params["arrBasePrice"][index] = ticker.Last
    ts = time.time()
    if ts - params["arrLastCancelAll"][index] > 60 * 5 :
        CancelAll(e)
        params["arrLastCancelAll"][index] = ts 

def main():
    global params
    
    for i in range(len(exchanges)) :    
        params["arrAcc"].append(_C(exchanges[i].GetAccount))
        params["arrTick"].append(_C(exchanges[i].GetTicker))
        exchanges[i].SetPrecision(params["arrPricePrecision"][i], params["arrAmountPrecision"][i])

    for key in params :
        if len(params[key]) < len(exchanges):
            raise "params error!"

    while True:
        tblAcc = {
            "type" : "table",
            "title": "account",
            "cols": ["Account information"], 
            "rows": []
        }        

        tblTick = {
            "type" : "table",
            "title": "ticker",
            "cols": ["Market information"], 
            "rows": []
        }
        for i in range(len(exchanges)): 
            process(exchanges[i], i)

        for i in range(len(exchanges)):
            tblAcc["rows"].append([json.dumps(params["arrAcc"][i])])
            tblTick["rows"].append([json.dumps(params["arrTick"][i])])

        LogStatus(_D(), "\n`" + json.dumps([tblAcc, tblTick]) + "`")
        Sleep(500)

II. Найти разницу

Сравнив код, вы заметили, что он сильно отличается от кода из предыдущей статьи? На самом деле, логика торговли остается точно такой же, без каких-либо изменений. Мы только модифицируем стратегию на многовидовую, мы не можем использовать предыдущую форму одной переменной в качестве параметра стратегии. Более разумным решением является превращение параметра в массив, и индекс каждой позиции в массиве соответствует добавленной торговой паре.

img

Затем загрузить код логики торговли в функциюprocess. На цепи основной стратегии, вызвать эту функцию итеративно в соответствии с добавленными торговыми парами, и пусть каждая торговая пара выполняет код логики торговли один раз.

  • Итеративный (переходный) вызов:
for i in range(len(exchanges)): 
    process(exchanges[i], i)
  • Параметры стратегии:
params = {
    "arrBasePrice": [-1, -1, -1],           # -1
    "arrRatio": [0.05, 0.05, 0.05],         # 0.05
    "arrAcc": [],                           # _C(exchange.GetAccount)
    "arrLastCancelAll": [0, 0, 0],          # 0
    "arrMinStocks": [0.01, 0.01, 0.01],     # 0.01
    "arrPricePrecision": [2, 2, 2],         # 2
    "arrAmountPrecision": [3, 2, 2],        # 2
    "arrTick":[]
}

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

  • Отменить все функции Вы можете сравнить изменение этой функции. Эта функция лишь модифицирует небольшой код, а затем подумать о намерении такой модификации.

  • Данные диаграммы строки состояния Добавляется диаграмма для отображения данных рынка и данных активов счета в строке состояния, так что соответствующие активы и рынок каждого объекта биржи могут отображаться в режиме реального времени. Легко ли изменить стратегию Python на многовидовую стратегию после освоения вышеуказанных идей дизайна?

III. Опыт обратной проверки

img img img

Стратегия предназначена только для обучения и обратного тестирования, и вы можете оптимизировать и обновить ее, если вы заинтересованы.Адрес стратегии


Связанные

Больше