Йцукен (Все сообщения пользователя)

Выбрать дату в календареВыбрать дату в календаре

Страницы: 1
Извечный вопрос: повторные вызовы OnTrade, Даже при заявке на одну акцию
 
Цитата
Nikolay написал:
дождаться их загрузки
Какие варианты?
Например, хранить данные портфеля в файле и не начинать торговлю, пока данные в квике не совпадут с нашими?
Извечный вопрос: повторные вызовы OnTrade, Даже при заявке на одну акцию
 
Цитата
Nikolay написал:
брокер может разорвать соединение, вызвать OnClenUp

OnConnected может быть вызван и без разрыва соединения. И это штатная ситуация.
Цитата
OnConnected

Функция вызывается терминалом QUIK при установлении связи с сервером QUIK и получении терминалом описания хотя бы одного класса. Если в течение торгового дня терминал получает новый класс, то функция вызывается еще раз, при этом параметр вызова flag принимает значение «false».

Но, если брокер разорвал соединение и перезапустил шлюзы с очисткой данных, то OnConnected будет вызван с флагом true.
Получается в скрипте нужно хранить информацию об обработанных заявках/сделках, как минимум, до смены торговой даты.
После обновления на версию 12.8.3.4 появился глюк в таблице "купить-продать", Глюк с фильром инструментов в таблице
 
Как тут скрины вставлять - не понял.
Ivan Smirnov, нажмите "Цитировать" на моём сообщении. Там скрин с настройкой.
После обновления на версию 12.8.3.4 появился глюк в таблице "купить-продать", Глюк с фильром инструментов в таблице
 
Ivan Smirnov,
[img][/img]
Извечный вопрос: повторные вызовы OnTrade, Даже при заявке на одну акцию
 
Цитата
Nikolay написал:
вызвать OnClenUp
Не обратил внимание на данный нюанс. У меня скрипт очищает таблицы при получении OnClenUp.
Надо будет внести правки в скрипт.
Рыночная заявка для торговли фьючерсами
 
Цитата
Ziveleos написал:
MARKET_STOP_LIMIT = "YES" и позиция закроется по рынку.
В отсутствии встречных заявок рыночная заявка будет отклонена, лимитная - встанет в стакан в очередь.
Если выставлять стоп-заявку с ценой исполнения на уровне верхней/нижней планки, то тоже есть нюанс: уровни планок постоянно меняются. Сегодня вы поставили стоп с одной ценой, а завтра при срабатывании стопа планка будет другой, и заявка может оказаться за пределами планок, и будет отклонена.
Нули в индикаторе там, где должны быть пустые интервалы
 
Такая же история, если в настройках диаграммы поставить галку "Показывать пустые интервалы".
Стандартный индикатор экспортируется нормально, а самописный (код выше) - с нулями там, где ничего не должно быть.
Драг энд Дроп в стакане не работает
 
Сделать опциональный параметр, чтобы пользователь мог сам выбрать один из:
1) передвигать первую заявку;
2) передвигать последнюю заявку;
3) объединять все заявки в одну.
Cкорость обмена данными через файлы
 
nikolz, так что, не знаете как в QLua синхронизировать запись из разных скриптов в один файл?
Извечный вопрос: повторные вызовы OnTrade, Даже при заявке на одну акцию
 
Цитата
nikolz написал:
А как Вам это
Бывает.
Сбой в работе алгоритмической системы одного из участников торгов фьючерсами на доллар/рубль на бирже ММВБ-РТС мог принести владельцу максимальный убыток в $4,3 миллиона.
Один из программистов этого робота по секрету поделился, что они не успели протестировать алгоритм, но начальник приказал его запускать в бой. Сказано - сделано.
Извечный вопрос: повторные вызовы OnTrade, Даже при заявке на одну акцию
 
Цитата
VPM написал:
мой алгоритм оставленный мной без присмотра, поймал какую то  ошибку (уже и не припомню причину) наделал столько заявок, что брокер заблокировал канал, а затем выставил штраф.
Я думаю, тут надо какую-то защиту "от дурака" реализовывать: типа, при превышении заданного порога количества ошибочных транзакций подряд, останавливать скрипт до выяснения причин.
Извечный вопрос: повторные вызовы OnTrade, Даже при заявке на одну акцию
 
Цитата
Nikolay написал:
А во время простоя исполнились ордера, то колбеки пропущены
Ещё раз:
Цитата
Йцукен написал:
При запуске скрипта обработка таблиц происходит в OnInit.

Цитата
Nikolay написал:
Если только при запуске Вы сами не проверите что изменилось в таблицах с прошлого запуска.
Скрипт сохраняет, допустим, номер своей активной заявки или id транзакции в файл. И при запуске он в состоянии проверить результат транзакции/заявки, пробежав однократно по соответствующим таблицам.

Цитата
Nikolay написал:
брокер может разорвать соединение, вызвать OnClenUp и тогда приедут ВСЕ колбеки с начала сессии
Да и пофиг: скрипт запомнил, какие заявки/сделки (в т.ч. и те, что были в таблицах при запуске скрипта) он обработал и дубли проигнорирует.
Извечный вопрос: повторные вызовы OnTrade, Даже при заявке на одну акцию
 
Цитата
TGB написал:
Обработка перезапусков скрипта по любой неконтролируемой вами причине у вас не предусмотрена? Пока он перезапускается заявки на бирже могут быть выполнены, а коллбеки пропущены.
При запуске скрипта обработка таблиц происходит в OnInit. Соответственно, все новые колбеки будут получены и обработаны после выхода из OnInit.

Цитата
TGB написал:
Вы предполагаете что и коллбеки в работающем скрипте не теряются?
Если колбеки потеряются, то и данные в таблицах квика не будут заполняться.
Извечный вопрос: повторные вызовы OnTrade, Даже при заявке на одну акцию
 
Цитата
TGB написал:
можно проверять циклически, по изменению их размеров, нужные вам таблицы QUIK (таблицы заявок, стоп-заявок, сделок и т.д.)?
Думаю такой подход сложнее, чем обработка колбеков.
На примере данной ситуации: если пришедший колбек не содержит значения нужных мне параметров, то я его пропускаю и жду колбек, который их содержит.
В случае же обработки таблиц вместо колбеков, нужно хранить не просто индекс последней обработанной строки таблицы, а индексы всех обработанных строк либо общее количество строк и индексы необработанных строк (пропущенных по причине отсутствия в них значений нужных параметров). И циклически проверять, не появились ли новые значения в пропущенных строках.
получение параметров индикатора, обращение к line
 
При добавлении индикатора из контекстного меню "Добавить график (индикатор)..."
Init
OnCalculate
OnCalculate


При изменении таймфрейма:
OnCalculate

При изменении инструмента в режиме связанных окон:
Init
OnChangeSettings
OnCalculate
получение параметров индикатора, обращение к line
 
Цитата
Старатель написал:
индикатор рассчитывается три раза (!), причём первый расчёт идёт со старым значением, но уже после нажатия на кнопку OK.

Сохраню для будущих поколений  :smile:
В общем случае при добавлении индикатора через меню "Редактирование настроек графика" происходит вызов функций в таком порядке:
Init
OnCalculate - с дефолтными значениями, заданными в скрипте
OnChangeSettings - тут скрипт читает значения, заданные пользователем вручную в диалоговом окне
OnCalculate
OnCalculate

При запуске QUIK на один OnCalculate меньше:
Init
OnChangeSettings
OnCalculate
OnCalculate
Вопрос о целостности данных при работе с таблицей из разных вычислительных потоков
 
Цитата
nikolz написал:
Поправьте так и ничего не повесится
А слона-то вы и не заметили. Я специально модифицировал скрипт, чтобы показать, какие инструкции выполняются под блокировкой (в используемой версии Lua).
Извечный вопрос: повторные вызовы OnTrade, Даже при заявке на одну акцию
 
Цитата
User12501 написал:
Являются ли эти три поля синхронными всегда? (Т.е. либо все три равны 0, либо все три не равны 0?)
Нет
Извечный вопрос: повторные вызовы OnTrade, Даже при заявке на одну акцию
 
Цитата
User12501 написал:
Гарантируется ли, что вызов OnTrade, в котором эти поля нулевые, является не последним
Нет.
trans_id и uid в некоторых ситуациях могут иметь и нулевые значения.
Вопрос о целостности данных при работе с таблицей из разных вычислительных потоков
 
nikolz, вы же сами дали ссылку на статью:
Цитата
Атомарность операций может обеспечиваться аппаратно (аппаратурой) и программно (программным кодом). В первом случае используются особые машинные инструкции, атомарность выполнения которых гарантируется аппаратурой. Во втором случае используются специальные программные средства синхронизации, с помощью которых осуществляется блокировка разделяемого ресурса; после блокировки выполняется операция, которую требуется выполнить атомарно. Блокировка представляет собой атомарную операцию, которая либо предоставляет ресурс в пользование потоку, либо сообщает потоку о том, что ресурс уже используется другим потоком или процессом (занят).

Теперь если ваш код модифицировать следующим образом:
Код
local x, y
function main()
  while true do
    y = 99
    x = 199
    x, y = y, x
    if x ~= 99 or y ~= 199 then
      s = tostring(x)..","..tostring(y).."\n"
    end
  end 
end
и запустить, то QUIK повесится (версия Lua: 5.4.1).

Если же конкатенацию строк с си-функцией tostring вынести за пределы блока if
Код
local x, y
function main()
  while true do
    y = 99
    x = 199
    x, y = y, x
    if x ~= 99 or y ~= 199 then end
    s = tostring(x)..","..tostring(y).."\n"
  end 
end
то QUIK, хоть и загрузит одно ядро на 100%, но остаётся доступным и позволяет остановить скрипт.
Что, как бы, намекает, что инструкции
Код
    y = 99
    x = 199
    x, y = y, x
    if x ~= 99 or y ~= 199 then
выполняются под блокировкой.
А вот преобразование числа в строку - нет.
Отсюда и ответ на 2-й вопрос: вы не сможете таким образом гарантированно вывести в файл значения переменных x и y, которые были в момент проверки их оператором if, поскольку другой поток может подменить их значения в этот момент.
Cкорость обмена данными через файлы
 
Цитата
nikolz написал:
Что получается?
Если писать из main разных скриптов, то часть данных теряется
Вопрос о целостности данных при работе с таблицей из разных вычислительных потоков
 
Цитата
nikolz написал:
x,y=y,x;
       if x~=99 or y~=199 then
           Log:write(tostring(x)..","..tostring(y).."\n")
Даже если вы поймаете тут ошибку, то подумайте вот о чём:
1) Может ли другой поток поменять значения переменных перед if ? Будет ли это означать отсутсвие атомарности в операторе присваивания?
2) Может ли другой поток поменять значения переменных перед выводом их в файл, т.е. гарантированно ли вы получите те значения, которые проверяли в if ?

Скрытый текст
Вопрос о целостности данных при работе с таблицей из разных вычислительных потоков
 
Цитата
Йцукен написал:
В моём тесте неатомарность проявится, если значение любой из переменных (a1, a2, a3, a4, a5, a6, a7, a8, a9) в любой момент времени будет отличным от остальных. Это будет означать, что поток main стал читать значения переменных в то время, когда в другом потоке произошла запись значений только части из них.
Другими словами, если мы попадём внутрь блока
Код
      if a1 ~= a2 or a1 ~= a3 or a1 ~= a4 or a1 ~= a5 or a1 ~= a6 or a1 ~= a7 or a1 ~= a8 or a1 ~= a9 or a1 == nil then
        error("error")
      end
Вопрос о целостности данных при работе с таблицей из разных вычислительных потоков
 
Цитата
nikolz написал:
Вы, очевидно, ждете системные ошибки, типа ошибок обращения к памяти. Верно?
Не верно. В моём тесте неатомарность проявится, если значение любой из переменных (a1, a2, a3, a4, a5, a6, a7, a8, a9) в любой момент времени будет отличным от остальных. Это будет означать, что поток main стал читать значения переменных в то время, когда в другом потоке произошла запись значений только части из них.

Цитата
nikolz написал:
Вот вам тест:
И? Результаты, выводы?
Вопрос о целостности данных при работе с таблицей из разных вычислительных потоков
 
Цитата
nikolz написал:
как вы проверили, что выполняется атомарно?  Где доказательство?
Вот: #11
Цитата
Йцукен написал:
такой код работает без ошибок

Можете опровергнуть?
Вопрос о целостности данных при работе с таблицей из разных вычислительных потоков
 
Похоже, операция множественного присвоения выполняется атомарно.
Вот такой код работает без ошибок:
Скрытый текст
Cкорость обмена данными через файлы
 
Цитата
nikolz написал:
Но если это разные потоки или приложения, то надо синхронизировать
Как в QLua синхронизировать запись из разных скриптов в один файл?
Вопрос о целостности данных при работе с таблицей из разных вычислительных потоков
 
Цитата
nikolz написал:
При множественном присваивании Lua сначала вычисляет все значения, а затем выполняет присваивание.
А если все значения уже вычислены, как в примерах выше?
Вопрос о целостности данных при работе с таблицей из разных вычислительных потоков
 
Является ли атомарной операция присвоения одновременно нескольким переменным?
Код
a, b = 1, 2
или
Код
x, y = y, x
Нули в индикаторе там, где должны быть пустые интервалы
 
Вот код тестового индикатора:
Код
Settings = {
  Name = "Test",
  line = {{ Name = "Test" }}
}

function Init()
  return 1
end

function OnCalculate(index)
  if true == CandleExist(index) then
    return C(index)
  end
  --return nil
end
Если его добавить на диаграмму с несколькими графиками и сделать экспорт в текстовый файл, то на тех свечах, где индикатор не рассчитывался будут нули.
Нули в индикаторе там, где должны быть пустые интервалы
 
Пишу индикатор. При отсутсвии свечки OnCalculate не рассчитывает значение (когда на одну диаграмму добавляется несколько графиков).
Но если сохранить индикатор в текстовый файл (ПКМ - Сохранить данные в файл), то на месте нерассчитанных значений будут нули.
На примере Moving Average:
Цитата
CHU2 [SPBFUT],1,20251130,175500,94927.555556
CHU2 [SPBFUT],1,20251130,175900,95014.000000
CHU2 [SPBFUT],1,20251130,180100,95059.111111
CHU2 [SPBFUT],1,20251130,180400,0.000000
CHU2 [SPBFUT],1,20251130,180900,0.000000
CHU2 [SPBFUT],1,20251130,181200,0.000000
CHU2 [SPBFUT],1,20251130,181300,0.000000
CHU2 [SPBFUT],1,20251130,181700,0.000000
CHU2 [SPBFUT],1,20251130,182100,95076.111111
При этом, если сохранить стандартный квиковский индикатор с тогой же диаграммы, то он будет без нулей:
Цитата
CHU2 [SPBFUT],1,20251130,175500,94927.555556
CHU2 [SPBFUT],1,20251130,175900,95014.000000
CHU2 [SPBFUT],1,20251130,180100,95059.111111
CHU2 [SPBFUT],1,20251130,182100,95076.111111
Вопрос: как в самописном индикаторе сделать так же?

Пробовал возвращать и nil и ничего не возвращать в OnCalculate
Код
function OnCalculate(index)
  ...
  if v ~= nil then return v
  else return nil end
end
Код
function OnCalculate(index)
  ...
  if v ~= nil then return v end
end
Результат одинаковый.
Страницы: 1
Наверх