Брокер ВТБ. Если QUIK был запущен ранее,то с началом утренней сессии, выставление заявок на срочном рынке недоступно. Проблема решается отключением/подключением сервера QUIK.
Данная проблема возникает примерно раз в неделю. Но. очень неудобна, т.к. QUIK работает круглосуточно на удалённом сервере. Роботы не могут совершать сделки на срочном рынке. Впервые была замечена после открытия ИИС. У других брокеров такой проблемы не наблюдаю.
Думаю, как временное решение, перезапускать или переподключать QUIK каждое утро через скрипт или планировщик. Но этот "костыль" применять не хочется.
Что делал? 1. Менял все доступные сервера ВТБ. 2. Экспериментировал с настройкой "Очищать данные при смене даты" на "Локальной машине", на "Сервере". 3. Проверял настройку счетов. Все счета добавлены (также при недоступности торгов на срочном рынке) 4. Переустанавливал QUIK, загрузив файл настроек .wnd. 5. Писал в поддержку ВТБ, обещали решить ещё месяц назад, но проблема не решена.
Хотели робота, который закрывает все сделки в плюс? Такой есть у меня. Речь пойдёт о стратегии «Парковщик средств». Тестирую с начала года, результатом доволен. До использования робота у меня постоянно валялись несколько сотен тысяч рублей для резерва на покупку акций или других роботов. При ставке более 15% мне показалось это непозволительной роскошью и я создал эту простейшую стратегию. И, так, встречайте!
Описание.
Торговая система позволяет автоматически размещать свободные средства на счёте в фонды ликвидности, ОФЗ и в прочие долговые инструменты. Например, если остаток средств больше 100т.р., робот купит на сумму, которая более 100т.р., необходимое количество паёв фонда ликвидности. Если остаток средств будет менее 100т.р., например, 190т.р., робот продаст купленные паи на 10т.р., чтобы привести счёт к свободному капиталу 100т.р. Размер свободного капитала указывается для комфортной работы других роботов или ручной торговли собственными стратегиями. Если иная торговля не предусматривается, можно указать свободный капитал, условно, 10т.р. и робот будет докупать паи или ОФЗ при пополнении счёта или поступлении дивидендов.
Идеальным инструментом для парковки средств в моём случае, на момент написания, является фонд ликвидности ВТБ (LQDT), т.к. мой основной брокер ВТБ не взимает брокерскую комиссию по этому инструменту. Аналогичные фонды есть у других брокеров.
Биржевая комиссия не взимается по мейкерским сделкам, поэтому робот был настроен на работу с лимитными заявками по противоположным ценам. Есть возможность выставления в центр спреда и пр.
Если счёт разделён на фондовую и срочную секцию, достаточно сделать перевод из срочной секции в фондовую или обратно, а робот увидит свободные средства и разместит их в долговой инструмент.
Если имеется два счёта, например, обычный и ИИС, можно использовать робот одновременно на нескольких счетах.
Ввиду универсальности робота, возможно выставление заявок по определённым алгоритмам: фронтраннинг, цены по индикаторам, условия по индикаторам и условиям и т.д., что может быть актуальным для качественной покупки облигаций.
🎞️ Видео Торговая система «Парковщик средств»:
Другие стратегии данного робота, которые могут Вас заинтересовать.
«Сетка» - максимально навороченный комбайн для создания сеточных торговых систем на любых индикаторах и инструментах.
«Арбитраж» - максимально навороченный комбайн для создания арбитражных и корзинных торговых систем на любых индикаторах и инструментах.
«Ассистент» - универсальный торговый ассистент, который может выставлять не только стоп-лосс и тейк-профит, но и управлять выставленной заявкой, а также, открывать и закрывать ваши позиции по любым условиям и индикаторам, доступным в QUIK.
«Спреды акций» - пример арбитража на лимитных заявках между фьючерсом на акцию и акцией.
Настало время представить одну из самых успешных и «не убиваемых» торговых систем.
Ранее, я публиковал подобную систему только для покупателей робота, но описание было недостаточным и слишком общим. Соответственно, было много просьб опубликовать материал с подробным описанием.
Сложность системы я оценил 5 из 5, поэтому, если Вы не хотите напрягать свой мозг, лучше сразу закройте эту страницу. Будьте готовы к ошибкам, потерям на счёте, а также, нескольким дням изучения (возможно в пустую).
Торговая стратегия включает в себя основы арбитража и маркетмейкинга.
Торговля на финансовых рынках – самый конкурентный способ заработка. Это очень хорошо будет видно после понимания алгоритма этой системы.
Представленный вариант использования далеко не самый удачный. Арбитраж фьючерса и акции ГМК Норникель слишком очевиден и популярен, чтобы на нём можно было бы зарабатывать. Поэтому, выбрать более свободную поляну для сбора урожая Вам придётся самостоятельно.
Удобство реализации стратегии в роботе (юзабилити) не самое удачное. Например, можно было просто указывать процент без огромной формулы. Но максимальная универсальность робота важнейший фактор. Рано или поздно, потребуется добавление какой-либо возможности и Робот Сетка LUA, скорее всего, будет готов к её реализации.
Описание.
· Тип: арбитражная, сеточная
· Сложность: 5/5
Данная торговая система «Спреды акций» реализована на лимитных заявках.
1. После указания количества входа, робот выставит три заявки по фьючерсу с отступами от расчётной цены с указанной процентной ставкой годовых, например, 21%.
2. Если одна или несколько заявок фьючерса исполнится, робот выставит заявки по акциям с кратным количеством максимально близко к исполнению.
3. Далее, будут выставлены зеркальные заявки тейк-профит по фьючерсам с отступом в процентах годовых, например, 16%.
4. Если заявка тейк-профит по фьючерсам исполнится (уменьшится общее количество позиции по фьючерсам), робот кратно уменьшит количество по акциям.
Преимущества торговой системы.
✅ Благодаря работе лимитными заявками возможен дополнительный заработок на неликвидности (ловле шпилек и широких спредах предложения-спрос).
✅ Благодаря работе лимитными заявками биржевая комиссия зачастую не взимается (мейкерские сделки).
✅ Возможно использование алгоритмов работы в стакане: фронтраннинг (поиск крупного объёма и выставление заявки перед ним), выставление в центр спреда предложения-спрос.
✅ Систему с постоянно выставленными лимитными заявками можно использовать для различных арбитражных идей: фьючерс-фьючерс, корзина фьючерсов-спот, корзина фьючерсов-фьючерс и т.д.
👉 Для прибыльной работы торговой системы важно иметь низкие брокерские комиссии. Например, 0.03% для акций и 0.08 р. для фьючерсов на сделку (вход и выход это две сделки).
👉 Критически важно качественное, непрерывное интернет соединение с сервером брокера. Нужно учесть, что, при значительных движениях на российском фондовом рынке у большинства брокеров значительно замедляется скорость работы (задержка до нескольких минут).
👉 В последний день обращения фьючерса нужно закрывать все позиции максимально близко к моменту экспирации. Но не все брокеры доводят фьючерсы до экспирации. Например, брокер ВТБ приостанавливает торговлю за два дня до экспирации, не позволяя получить полную прибыль от контанго.
Дополнительно.
Дополнительно к стратегии можно использовать другие программы (на работу робота не влияют).
GK – идентификатор графика фьючерсов (указывается на графике: дв.кл.лев.кн.мыши на названии графика/индикатора-Дополнительно-поле Идентификатор-ввести название, не являющееся паттерном, например, "GK ");
GKh – идентификатор графика акций (указывается на графике);
q.LotSize.GKZ4 – количество лотов в фьючерсе;
q.DaysToMatDate.GKZ4 – дней до экспирации фьючерса.
Пожалуй, самая незаменимая в моей торговле разработка Утилита для QUIK «История позиций». Придумал в 2009-м, запрограммировал на QPILE, затем перевёл на QLUA. Программу писал для себя, не под заказ и по своим идеям. Продажи данной программы никогда не отличались большим количеством и стабильностью. Поэтому, считаю её самой недооценённой из десятков своих разработок. Попытаюсь донести полезность утилиты из реальных примеров использования.
Недавно выпустил обновление 20241024.
✅ Учёт комиссий для фондовой секции теперь разделён на биржевую и брокерскую.
✅ Учтена разница комиссий мейкерских и тейкерских заявок.
На скрине видно, как распределяются комиссии биржи и брокера. Сверил с отчётом брокера – всё сходится. Программа сразу рассчитывает и выводит информацию о комиссионных затратах. Напомню, в терминале QUIK информация о биржевой комиссии урезана, а брокерская и, вовсе, недоступна.
✅ Учёт информации о позиции без ограничений.
Мне, как инвестору, очень важно видеть покупки акций пакетами. Например, в период коронавирусного кризиса, на фоне «вертолётных денег» QE, логика мне подсказывала, что, долларов станет больше и на один доллар можно будет купить меньше. Решил инвестировать в акции Полюс золото. Покупал пакетами. Так вот, информацию по этим позициям я мог наблюдать все эти годы. Для меня важный момент - это срок владения. Т.е. я продаю только пакеты, которые куплены более 3 лет назад, чтобы не платить НДФЛ. Вот, недавно продал эти пакеты акций. На скрине видно все мои пакеты покупок. Есть даты покупок, доход в %, доход в рублях, общий накопленный доход от всех пакетов. Дивиденды можно добавлять в таблицу вручную.
✅ Подходит как трейдеру, так и инвестору.
На срочном рынке фьючерсов и опционов вариационная маржа отображается только в пределах сессии. В Истории позиций данные о прибыли хранятся без ограничений, в плоть до экспирации.
Чтобы отделять трейдинг и инвестирование, к заявкам инвестиционных позиций я добавляю комментарий (поручение) «инв…». Таким образом, используя внутренние фильтры программы, я всегда могу вывести отдельно статистику по инвестированию и по трейдингу отдельно. Причём, внутри трейдинга, могу отдельно вывести статистику по отдельным торговым стратегиям.
Продемонстрирую результаты одной из самых интересных стратегий последних месяцев. Я заметил существенную бэквордацию (фьючерс дешевле акции). У меня уже были куплены акции Сегежи ранее. Я продал акции и купил фьючерсы (переложился). Сейчас доход +12040р. или почти +10% за 39 дней. К экспирации переложусь обратно. Но, суть не в стратегии, а в том, насколько удобно вести учёт, применяя Историю позиций. Да, можно записывать цены позиций вручную, пересчитывать на калькуляторе или в EXCEL – но это всё неудобно.
Представляю свою новую программу Утилита для QUIK «Супер таблица».
Утилита предназначена для создания различных таблиц в торговом терминале QUIK. Пользователь может самостоятельно получать различные значения таблиц QUIK, проводить расчёты и выводить результат в Супер таблицу (аналог MS EXCEL). В комплекте готовый пример "Спреды акций":
Находим наибольший годовой процент. Покупаем акции, продаём фьючерсы равного объёма. К экспирации разница нивелируется. Например, на момент написания «iСофтлайн» показывает хороший результат 26.11% годовых.
Есть минусы стратегии.
1. Стоимость акции + ГО фьючерса снижают доходность. Так ГО по S0Z4 сейчас 878.22.
Некоторые брокеры уменьшают ГО фьючерсов при использовании их в синтетической облигации.
2. При малом сроке экспирации доля высока доля издержек.
(0.37+0.45)*2=1.64 брокерская комиссия за вход и выход (акции 0.03%+фьючерсы 0.45₽)
(0.37+0.37)*2=1.48 биржевая комиссия за вход и выход (тейкерские заявки)
2+3=5 спреды (рассматриваемые инструменты не отличаются ликвидностью)
1.64+1.48+5=8.12 общая комиссия
(38.20-8.12)/2130.22*100/44*365=11.71% более реальные проценты годовых (с учётом издержек)
Когда останется менее недели до экспирации, издержки станут выше прибыли.
3. Налог НДФЛ.
(38.20-8.12)*0.87/2130.22*100/44*365=10.19% более реальные проценты годовых (с учётом издержек и налога)
Можно использовать ИИС.
Чтобы получать интересную доходность, нужно:
- выбрать брокера с уменьшенным ГО;
- иметь низкие комиссии, выбирать ликвидные инструменты и работать лимитными мейкерскими заявками;
- работать на ИИС.
✅ Зарабатываем на ошибочных ожиданиях.
Находим наименьший годовой процент.
Разбираемся в причинах, это может быть:
- ожидаемые дивиденды;
- эмиссия акций;
- перепроданность.
Ожидаемые дивиденды.
Смотрим дивиденды для PLZL на сайте «Доход» или в таблице для QUIK «Дивиденды».
Видим, что 2024.12.12 есть прогноз по дивидендам. Срок выплаты до экспирации PZZ4. Далее, посчитаем, верно ли котируется фьючерс.
15250*10*0.21/365*44=3860 спред расчётный при ставке 21% без учёта дивидендов (из таблицы Спреды акций)
1301.75*10=13017.5 дивиденды для объёма фьючерсов (фьючерс дороже акции в 10 раз)
13017.5*0.87=11325.22 дивиденды для объёма фьючерсов с налогом (налог с дивидендов спишут обязательно)
3860-11325.22=-7465.22 спред расчётный при ставке 21% с учётом дивидендов
-7053-(-7465.22)=412.22 разница между реальным и расчётным спредами
Получается, что фьючерс торгуется на 412.22₽ дороже, чем должен.
412.22/(152500+27856.68)*100=0.22% разница в спредах от замороженных средств.
Вывод: спред «PZZ4-PLZL» рассчитывается верно, возможности заработать нет.
Кстати, весь расчёт выше можно уместить в одну ячейку утилиты «Супер таблица».
Но не всегда всё очевидно. Например, в период коронавирусного кризиса 2020, была высокая вероятность невыплаты дивидендов по акциям Сбербанк. Рынок уже заложил дивиденды и фьючерс был в бэквордации. Я продал акции и купил фьючерсы. Таким образом, мне удалось зафиксировать дивиденды. Дивиденды были отменены, фьючерс перешёл из бэквордации в контанго, я продал фьючерсы и вернул купленные акции. Справедливости ради, я забрал немного меньше расчётных дивидендов, т.к. рынок заложил вероятность невыплаты, но недостаточно.
Эмиссия акций.
Фьючерс - это прогноз стоимости акции с добавленной процентной ставкой на момент экспирации. Эмиссия акций, т.е. «размывание» доли акционера, приводит к уменьшению стоимости. По акциям Сегежа ожидается эмиссия, рынок фьючерсов уже заложил, что акция будет дешевле. «Счастливые» владельцы акций Сегежа могут продать свой пакет акций и купить фьючерсы. Независимо от исхода, к экспирации, такая «перекладка» даст прибыль. Но не все брокеры дадут вам удержать фьючерс до конца ВТБ брокер закрывает контракты до экспирации.
Перепроданность.
Т.к. объёмы фьючерса меньше, его легче «продавить» в цене. Так, например, 24.02.2022 акции стоили ~130, а фьючерс ~85. Продать акции было сложно, т.к. были постоянные «планки». Я купил фьючерс SRM2 ниже 90, и продал его после возобновления торгов по 130. Хотя можно было остаться долгосрочным покупателем акций Сбера условно по 85.
Сделал очередное обновление для своей разработки "Утилита для QUIK Дивиденды". В новых версиях появилась возможность переходить на страницу по акции на Смартлаб одним кликом, а также возможность увидеть все свои собственные предполагаемые дивиденды по акции или общее ожидание на предстоящий год. Также, добавил возможность бесплатного использования до середины июля и на демо счёте ARQA без ограничений.
1. Отображение предполагаемой доходности дивидендов на текущий момент. Таблица получает текущую цену акций и рассчитывает на основе полученных данных Доходность выплаты от дивидендов, а также отображает расчёт собственных ожидаемых дивидендов.
2. Подсветка данных по параметру Доходность выплаты. Если упорядочить по сталбцу "Доходность", таблица утилиты выглядит так:
3. Использование базы доходности ИК «Доходъ» http://www.dohod.ru/ik/analytics/dividend. В таблице используются аналитические данные ИК «Доходъ». Зайти по ссылке можно прямо из таблицы, нажав дв.клик.пр.кн.мыши на номере строки таблицы.
4. Возможность сортировки данных по различным параметрам: Доходность выплаты, Дата закрытия реестра (оценка), Капитализация, млн. USD, DSI (индекс стабильности дивидендных выплат) и т.д. Удерживая CTRL, нажмите на название любого столбца таблицы утилиты лев.кн.мыши.
Просто нажимайте клавиши на активной таблице скрипта. Теперь нет необходимости искать файлы и ссылки.
6. Возможность быстрого перехода на страницу выбранной акции на сайте https://smart-lab.ru по кнопке [ SmartLab ].
7. Возможность обновления данных базы в реальном времени. Обновить информацию можно самостоятельно. 1). Откройте страницу http://www.dohod.ru/ik/analytics/dividend (дв.клик.пр.кн.мыши на номере строки)и файл Дивиденды.csv (дв.клик.лев.кн.мыши). 2). На странице сайта выделите и скопируйте строки с данными. 3). Вставьте данные в файл Дивиденды.csv используя конечное форматирование 4). Удалите лишние столбцы 5). Сохраните файл в формате CSV с подтверждением. 5). Данные в таблице утилиты обновятся сразу.
8. Возможность копирования в EXCEL всей таблицы утилиты Дивиденды. 1). Нажмите одновременно Ctrl+Shift+C на активной таблице утилиты. 2). Создайте файл EXCEL. 3). Вставьте данные в созданный файл.
9. Возможность добавления дополнительных новых акций в базу. Просто добавьте в файл Дивиденды.csv строки с необходимыми акциями, указав их код бумаги.
Важно запомнить, вес бумаг постоянно меняется. Чем больше дорожает бумага относительно остальных, тем больше её вес. Также, возможно удаление биржей бумаг из индекса и добавление новых.
- Находим примерный минимальный объём на депозите для реализации. Для этого делим цену каждой акции на коэффициент веса и берём максимальное число.
Например, для акций «Транснф ап» получим:
122300 / (0.55 / 100) = 22 236 363 р.
Где:
122300 – цена акции Транснф ап;
0.55 / 100 – вес в % делим на 100, получаем коэффициент.
Но, даже ₽22млн. Не даст идеального повторения индекса.
Чем больше сумма на депозите, тем больше точность повторения индекса.
Например, если в распоряжении счёт ₽100млн., индекс повторить легко. Просто берём количество акций необходимое для реализации веса. Для акций «Сбербанк» получим:
100 000 000 * (14.82/100) / 235.29 = 62986 акций
Где:
100 000 000 – депозит;
14.82/100 - вес в % делим на 100, получаем коэффициент;
235.29 – цена акции «Сбербанк».
Единственное, нужно учитывать количество лотов. Для акций «Сбербанк» это 10 акций, поэтому, нам нужно купить 62986 / 10 = 6298 лотов.
2. Создаём мини индекс Московской биржи из основных акций.
Т.к. собрать портфель из всех 40 акций (на данный момент) не все смогут, часто обрезают количество акций. Приведу пример индекса из 5-ти акций с самым большим весом.
- Выбираем 5 акций с самым большим весом. Например,
Сбербанк 14.82%
ГАЗПРОМ ао 14.64%
ЛУКОЙЛ 14.54%
ГМКНорНик 6.23%
Новатэк ао 5.07%
- Получаем сумму процентов:
14.82+14.64+14.54+6.23+5.07=55.3
В общем-то, данный расчёт говорит, что мы будем повторять индекс чуть больше, чем на 55%.
- Определяем вес каждой акции для нашего мини индекса.
Получим коэффициент компенсации. На него нужно.
100 / 55.3 = 1.8083
Теперь достаточно просто умножить вес каждой акции на коэффициент компенсации.
Сбербанк 14.82%*1.8083=26.80%
ГАЗПРОМ ао 14.64%*1.8083=26.47%
ЛУКОЙЛ 14.54%*1.8083=26.29%
ГМКНорНик 6.23%*1.8083=11.27%
Новатэк ао 5.07%*1.8083=9.17%
- Вычисляем количество лотов для каждой акции.
Например, для акций «Сбербанк» при депозите 100 000р.
100 000 * (26.80/100) / 235.29 / 10 = 11 лотов
3. Создаём график собственного индекса в QUIK
Штатного индикатора в QUIK нет, но я написал универсальный индикатор Арбитраж PRO при помощи которого можно решить задачу.
Я подготовил архив с готовой вкладкой для QUIK, где индекс уже создан:
- Создаём диаграмму со всеми инструментами, входящими в наш мини индекс. Для этого создаём новый график Сбербанк-нажимаем пр.кн.мыши на графике-Добавить график (индикатор)-Новый-находим нужный инструмент-далее всё подтверждаем.
- Привязываем графики к индикатору. Для этого нажимаем лев.кн.мыши на названии графика-Дополнительно-указываем Идентификатор (можно скопировать из названия). Названия идентификаторов нам потребуются далее. Аналогично нужно задать для остальных инструментов. Можно в этом же окне, выбирая слева инструмент.
- Загружаем индикатор Арбитраж PRO в новую область нашей диаграммы. В
Поле «Выражение» задаём идентификаторы с весами и складываем их:
Например, нам нужно сравнить наш мини индекс с IMOEX.
- Добавляем график IMOEX в область индикатора. Для этого нужно кликнуть именно на область индикатора, аналогично примеру выше, добавить новый инструмент IMOEX, важно убрать галочку «Поместить в новую область». Скорее всего, получим малоинформативный график с большой разницей между значениями индексов.
- Теперь нам нужно найти сближающий коэффициент. Например, мы хотим видеть график, на котором наш индекс приравнен к IMOEX на текущий момент расчёта. Для этого берём последнее значение нашего мини индекса и делим его на значение IMOEX:
318389.35/2630.87=121.02
Далее, нам нужно разделить значение нашего мини индекса на сближающий коэффициент:
Получили более адекватный график, говорящий нам, что в последнее время наш индекс уступает IMOEX. Это произошло из-за отставания ГМКНорНик, Новатэк, ГАЗПРОМ. Сбербанк не смог вытащить эту компанию. Вес каждой акции пересчитывается индикатором Арбитраж PRO на каждый бар отдельно в зависимости от цены.
В примере выше, нулевая точка находится на моменте расчёта. Нулевую точку можно сместить на любой бар, например на начало года. Для этого нужно взять данные обоих индикаторов на последний день прошлого года и вычислить коэффициент сближения, как рассмотрено выше. Правда, для точного расчёта нам потребуются веса в индексе IMOEX на последний день. Найти историю состояния индекса по дням мне не удалось. Веса в прошлом можно вычислить из текущих данных, конечно, без учёта корректировки индекса самой биржей, но это другая история. Для примера вводим текущие веса:
- Есть другой способ, основанный на возможности QUIK создавать графики в процентах. Создадим график процентного изменения с начала года. Для этого соберём последние значения прошлого года:
Наш индекс: 297392.87
IMOEX: 2154.12
Теперь нажимаем лев.кн.мыши на названии графика-Дополнительно-ставим галочку «Процентное изменение»-вводим значение индикатора/графика на момент отсчёта-подтверждаем.
Аналогично поступаем с другими данными диаграммы, в нашем случае с графиком IMOEX. Получаем такой график:
К слову, возможность QUIK «Процентное изменение» позволяет создавать множество интересных графиков. Значение этих графиков может быть подхвачено роботами, например, моим Робот Сетка LUA.
Без всяких дополнительных индикаторов, QUIK способен показать вот такой график:
Обратил внимание на новый неизвестный параметр в Информационном окне - Маркеры рассылки. В инструкциях информации нет, поэтому есть вопросы: 1. Как он формируется и для чего можно использовать. 2. Как вызвать из LUA. Опытным путём выявил, что маркер, во время загрузки терминала принимает значения :0, а после загрузки всех таблиц :1. Это может быть полезно для правильного старта скрипта, когда нам известно, что все таблицы подгрузились.
Имеем: ☑️ QUIK 10.0.0.181 ☑️ Win10 x64 ⛔ Зависаем через 10-600 сек. при запуске незатейливого скрипта:
Код
function main() -- Функция, реализующая основной поток выполнения в скрипте. Для ее выполнения терминал QUIK создает отдельный поток.
is_run = true -- включение бесконечного цикла
while is_run do -- повторяющийся цикл, пока is_run = true
_tab = getItem("depo_limits", 1)
sleep(50) -- приостановка выполнения скрипта в мс. зависает и при 1000, только реже
end -- выход из цикла: повторяющийся цикл, пока is_run = true
end -- выход из функции: main
С 2005-го года занимаюсь разработкой и программированием торговых роботов. За это время реализовал десятки разных торговых систем и идей. Пять лет назад у меня появилась безумная идея объединить все возможности в один, универсальный робот, который бы мог торговать любым инструментом (акции, фьючерсы, опционы, валюты, календарные спреды) по любым индикаторам (штатным и пользовательским), любым условиям, любым параметрам позиции, а также любым параметрам таблицы Текущих торгов. С возможностью строить различные ассистенты торговли, трендовые, контртрендовые, арбитражные, хеджирующие, маркетмейкерские торговые системы.
В начале 2021-го года я опубликовал полноценную версию робота для бесплатного пользования в целях тестирования, т.к. не хотелось продавать «сырой» продукт с ошибками. Тестирование продлеваю уже полтора года.
👉 Робот торгует на моём реальном счёте без вмешательств на удалённом сервере VPS. Результатом работы доволен.
👉 Ошибок всё меньше, но есть над чем работать.
👉 Для кого этот робот? Робот не для тех, кто ждёт кнопку «Бабло». Да, есть возможности загружать готовые стратегии, но необходимо разбираться, что для чего и, как работает. Это отличная игрушка исключительно для тех, кто любит разбираться и думать.
👉 Почему планирую продавать, а не сам зарабатываю своим роботом на рынке? Я зарабатываю на рынке своим роботом, но дополнительный доход не помешает.
👉 На каких стратегиях мне удаётся зарабатывать? Отвечу честно. К сожалению, эта информация не может быть публичной. Любая неэффективность рынка теряет свою неэффективность после её массовой эксплуатации.
👉 В виду занятости в собственном бизнесе, не имею возможности оперативно осуществлять техническую поддержку. Стараюсь отвечать всем пользователям, но задержка с ответом доходит до нескольких дней.
Начиная с QUIK 8.13 все файлы индикаторов нужно помещать исключительно в [QUIK]\LuaIndicators. Ранее, было удобно располагать каждый индикатор в отдельной папке, т.к. индикатор может иметь свои рабочие файлы, инструкции, библиотеки и т.д. Теперь, же приходится всё держать в LuaIndicators. Можно ли вернуть удобную возможность?
if ToNumber2(string.gsub(getInfoParam("CONNECTIONTIME"), '%:', '')) < 10 then -- если терминал на связи не более 10 сек.
sleep(10000) -- пауза 10 сек. (ожидание заполнения таблиц)
end -- выход из условия: если терминал на связи не более 10 сек.
Но данные могут загрузиться, как быстрее, так и позже. Может у кого есть более подходящее решение?
Здравствуйте! 1. Заявка исполняется. 2. В массиве таблицы эта заявка уже со статусом Исполнена. 3. После приходит коллбек. Разве коллбек не имеет приоритет по скорости?
Как запретить QUIK добавлять инструменты самостоятельно?, Кто-то подкидывает в Текущие торги торговые инструменты по своему усмотрению, как бездомных котят..
История такая. Крик души. Перешёл в QUIK 8.9 от брокера Открытие. Сначала всё нравилось, кроме двух гигабайт в оперативке. Но через некоторое время стал замечать, что с каждой новой сессией, в моём QUIK, в Текущих торгах стали появляться какие-то экзотические торговые инструменты . Эти инструменты, за свой небольшой, 15-летний опыт, я ни разу не торговал, и, тем более, не добавлял в Текущие торги. Сначала, в список подозреваемых попала кошка, которая могла бессовестно пройтись по клавиатуре. Но, через несколько дней таких добавлений, подозрения с кошки были сняты, а в QUIK уже было самовольно добавлено более сотни инструментов. Так же, мне подкинули OZON, который я чуть-ли не купил по 3600р. Теперь вопросы. . Кто виноват (брокер, QUIK или пользователь)? . И, что делать, как с этим дальше жить? Заранее благодарю за спасительный ответ!
Потребовалось кое-что сделать при событии закрытия терминала. Но OnClose() и OnStop(flag) не выводит системные сообщения и не выполняет код внутри. Если отключить qlua.dll в окне «Версии компонентов и плагинов», всё работает по инструкции. Как можно объяснить такое поведение?
Код
function OnInit() -- Функция вызывается терминалом QUIK перед вызовом функции main().
is_run = true
return
end -- выход из функции: OnInit()
function main() -- Функция, реализующая основной поток выполнения в скрипте. Для ее выполнения терминал QUIK создает отдельный поток.
while is_run do -- повторяющийся цикл, пока is_run = true
sleep(1000)
end -- выход из цикла: повторяющийся цикл, пока is_run = true
return
end -- выход из функции: main()
function OnClose() -- Функция вызывается перед закрытием терминала QUIK и при выгрузке файла qlua.dll.
-- Под выгрузкой файла qlua.dll подразумевается отключение плагина QLua
-- в окне «Версии компонентов и плагинов» (см. п. 1.9. Раздела 1 Руководства
-- пользователя QUIK).
message("OnCl ose="..tostring(1),1) -- отладка скрипта с выводом системного сообщения
end
function OnStop(flag) -- Функция вызывается терминалом QUIK при остановке скрипта из диалога управления и при закрытии терминала QUIK.
-- При остановке или удалении работающего скрипта Lua из диалога управления «Доступные
-- скрипты» параметр вызова flag принимает значение «1». При закрытии терминала QUIK –
-- значение «2».
message("OnStop flag="..tostring(flag),1) -- отладка скрипта с выводом системного сообщения
is_run = false
return 5000
end
Интересен алгоритм использования памяти. Ниже простой скрипт, который при каждом расчёте обращается к функции "getInfoParam". При запуске, в столбце "Память, КБ" = 41.04, и, с каждым новым расчётом, затраченная память увеличивается: 41.04, 41.07, 41.11... Почему происходит увеличение используемой памяти, ведь данные не накапливаются? Заметил, что в скриптах память увеличивается до определённого предела (примерно в 2 раза больше, чем при старте) затем сбрасывается до начального размера. Возможно, где-то уже это обсуждалось, но не нашёл.
Код
function OnInit() -- Функция вызывается терминалом QUIK перед вызовом функции main().
is_run = true
return
end -- выход из функции: OnInit()
function main() -- Функция, реализующая основной поток выполнения в скрипте. Для ее выполнения терминал QUIK создает отдельный поток.
while is_run do -- повторяющийся цикл, пока is_run = true
ScriptTimeStart = getInfoParam("SERVERTIME") -- Время начала расчёта скрипта
sleep(1000)
end -- выход из цикла: повторяющийся цикл, пока is_run = true
return
end -- выход из функции: main()
function OnStop() -- Функция вызывается терминалом QUIK при остановке скрипта из диалога управления и при закрытии терминала QUIK.
is_run = false
return
end
В последних версиях QUIK, легенда графика не отображается, при добавлении нового графика на диаграмму. Это не удобно, т.к, при добавлении новых графиков, не видно, какие именно индикаторы или графики используются. Приходится включать отображение легенды для каждой области графика. Понятно, что сделано это для экономии рабочего пространства, но неэффективно.
Нужно собрать: w32.dll - для авто логина QUIK https://quik2dde.ru/viewtopic.php?id=78 lfs.dll - для работы с файлами qvcl.dll - для создания визуального интерфейса https://quik2dde.ru/viewtopic.php?id=26 Эти функции будут и бесплатно, но без пинка, в неизвестном будущем. Пинок в виде ₽10К (2+2+6) и народная слава гарантируется. Ссылки на библиотеки выложу.
Учитывая переход на размерность идентификатора заявок и сделок до 19-ти символов, требуется обновления функционала QPILE. Подробнее: https://forum.quik.ru/forum1/topic5117/ Но делать это никто не будет, т.к. поддержка QPILE приостановлена 6 лет назад. В итоге, все роботы QPILE больше не будут торговать. Таблицы QPILE будут работать как и прежде. Всё верно?
У брокера Открытие перестала работать возможность перестановки заявки одним запросом, через MOVE_ORDERS. Аналогичная тема уже поднималась: https://smart-lab.ru/blog/590101.php, но брокер, похоже не знает, что это за ругательство "MOVE_ORDERS". Версия QUIK 7.27.2.1, это последняя версия, на которую позволяет обновиться сервер Открытие. Я вышел из положения путём отправки двойного запроса: удаления и выставления заявки. Долблю сервер в два раза больше, за что прошу прощение. Ещё и мои каждый день стали писать письма, мол моё ПО глючное. Приходится высылать каждый день функционал с двойным запросом. Поэтому, пишу письмо Вам, уважаемые разработчики. Вы, по крайней мере, знаете, что есть такое "MOVE_ORDERS".
Приветствую! Уважаемые разработчики, не могли бы вы немного улучшить поиск. Думаю, моя идея будет интересна и не сложна в реализации. Например, мне нужно найти опцион "SR021500BD8". Я могу найти "sr0215", увижу все опционы всех серий . Чтобы более точно указать запрос, нужно ввести полностью код опциона. Но если введу "sr0215 D8", я могу увидеть только опционы этой серии. Т.е. пробел может служить разделителем частей запроса, ну, и само самой быть пробелом. На практике знаю, что штука удобная.
Мерцание заголовков таблицы QPILE и её содержимого после повторной локальной загрузки любого скрипта в версии QUIK 7.16. При этом, добавляется первая пустая строка. Возможно возникало и в предыдущих версиях. Решается удалением и созданием новой таблицы. Просьба поправить в последующих версиях.
Задача простая. Есть переменная типа string str = "1+(2*3)". Нужно из неё получить результат 7. Есть два способа. Первый - пишем парсерную функцию eval. Хорошая функция, учитывающая скобки, приоритет операций и т.д. занимает около 1000 строк. Второй - просто и изящно передаём строку в назначение переменной, например res = 1+(2*3), будет равен 7.
Код
function calculateString(str) {
return (new Function('return ' + str))();
}
Это пример для JavaScript. Где-то видел аналогичный для LUA, но не могу найти. Помогите с решением задачки.
Приветствую! Появилась ошибка "Неверный код клиента" при вызове транзакции перестановки заявки FORTS. При этом, заявка выставляется и снимается без проблем с аналогичным массивом. Проблема возникла у брокера Открытие, при использовании Единого брокерского счёта и субсчетов. В других вариантах у этого же брокера ошибка не наблюдается.
Здравствуйте! Имеется индикатор, использующий данные графика "А" через функцию getCandlesByIndex(). Каждое утро на сервере происходит перезаказ данных. (Можно эмулировать: Заказ данных - Перезакать данные...) График "А" ещё не получен от сервера, а индикатор уже производит расчёт. Т.к. данных графика "А" нет, индикатор не может быть рассчитан.
Решается входом в "Редактирование настроек графика" и нажатием "Применить" или "Ок". В этом случае, происходит перезапуск OnCalculate() и индикатор перерисовывается.
Как сделать перезапуск OnCalculate() или есть другое решение?
Здравствуйте! В QUIK версий 7 и выше индикаторы (функция OnCalculate) рассчитываются по 2 раза при первой загрузке и при изменении параметров. Причём, при изменении параметров рассчитываются по 2 раза ВСЕ ИНДИКАТОРЫ НА ВСЕХ ДИАГРАММАХ ОКНА (это сильно тормозит систему). При переключении таймфрейма, индикаторы рассчитываются 1 раз, как должно быть. Пожелание по исправлению проблемы зарегистрировано многократно. Может есть какой-то способ обойти лишний вызов в коде индикатора? Спасибо!
Здравствуйте! Стоп-заявка исполняется, выставляется заявка без переноса. Как сделать заявку с переносом? Можно ли как-то в таблице заявок определить переносится ли заявка? Спасибо!
Хотел раскрасить метку из Settings.line[1]["Color"]. Но функции, как получить RGB из числа не нашёл. Нужна такая функция или другое решение. Заранее спасибо!
Здравствуйте! Как лучше обрабатывать событие изменения файла в LUA? Контроль размера файла не подходит. Контроль даты и времени изменения файла не нашёл. Спасибо!
Здравствуйте! 1. Запускаю скрипт, создаётся таблица QLUA, сохраняю координаты окна таблицы, перехожу на другую вкладку, перезапускаю QUIK, таблица появляется на том же месте, НО НА ТЕКУЩЕЙ ВКЛАДКЕ, А НЕ НА ТОЙ, ГДЕ ОНА БЫЛА ОТКРЫТА. Есть ли возможность "запомнить" вкладку? 2. Есть ли возможность задать свою иконку в верхнем левом углу? 3. Очень не хватает возможностей, которые имели место в QPILE таблицах. Ниже приведен список действий, которые не поддерживаются для таблиц, созданных на языке Lua: • таблицы не сохраняются в файл конфигурации (решилась бы проблема сохранения вкладок); • отсутствует диалог редактирования таблицы; • отсутствует контекстное меню таблицы (кроме пункта «Переместить на закладку»); • не создается копия таблицы; • не задается по умолчанию заголовок окна таблицы; • отсутствует экспорт данных из таблицы (особенно важен DDE экспорт, т.к. функциями DDE LUA пользоваться непривычно и неудобно); • недоступно управление «горячими клавишами». Спасибо!
Доброго времени суток! Хотелось бы, когда-нибудь, в будущем, увидеть возможность создания всплывающего списка (Combo Box) и полей ввода в таблице QLUA. Это нужно для удобства настройки параметров скриптов. Открывать отдельную программу для настройки, да ещё и копировать коды бумаг, классов и т.п. весьма не удобно. На данный момент придумал привязку роботов к графику. В ТТТ меняем инструмент, и график привязанный якорем к ТТТ. Данные Кода бумаги беру из легенды. Правда, работает только на фортс, для остальных групп вместо кода бумаги, краткое название. Может подскажите, как удобнее настраивать скрипты?
Отсутствие единых стандартов у брокеров и отсутствие стремления их поддерживать не есть хорошо. От себя могу только пожелать придерживаться единых стандартов.
Например, сегодня брокер «Открытие Брокер» изменит параметр «Фирма» на FORTS, с «SPBFUT» на «MC0139600000». Это означает, что роботы, которые ведут свой учёт, потеряют свои позиции. Это может привести к исполнению лишних сделок. Например, робот потеряет свою прежнюю позицию и откроет новую.
"Уважаемый клиент! Уведомляем Вас о том, что с 29 марта 2016г. «Открытие Брокер» изменит параметр «Фирма», транслируемый в ИТС QUIK с «SPBFUT» на «MC0139600000». Изменения касаются только рынка FORTS. Просим Вас учитывать эту информацию при планировании торговых операций. "
Прошу добавить в ближайшие 50 лет возможность отображения информации на перекрестии, как на скриншоте ниже. Очень удобно отмерять расстояния на графике. Например, увидеть ширину канала в цене или длину тренда в количестве свечей. Ещё хотелось бы добавить расстояние цены в %, в MetaTrader эту возможность не добавили. Заранее, спасибо!
Можно ли получить Код бумаги из Краткого названия бумаги? Например, знаем краткое название "ЛУКОЙЛ". Нам нужно узнать код бумаги при помощи функции QPILE.
Индикатор предназначен для отображения на графике истории счёта, свободных средств, гарантийного обеспечения, а также пользовательских исторических данных.
- Возможность отображения данных: истории счёта, свободных средств, гарантийного обеспечения, пользовательских исторических данных - Возможность отображения истории счёта для счетов всех типов: акций, фьючерсов, валют - Возможность отображения в окне индикатора всех данных или выборочных - Возможность отображения на таймфреймах:М1, М2, М3, М4, М5, М6, М10, М15, М20, М30, H1, H2, H4, D1, W1, MN1 - Возможность накопления данных без ограничений - Возможность самостоятельного редактирования данных - Возможность изменение частоты сохранения данных - Простота использования - Открытый код с описанием всех функций вплоть до каждой строки