Теоретическая разница получения данных CreateDataSource+SetUpdateCallback или getNumCandles()+getCandlesByIndex(), В чем разница получения данных 1 способом и 2 способом
Николай Камынин написал: CreateDataSource+SetUpdateCallback - получаем данный в момент прихода их с сервера,
Т.е если таймфрейм установлен в 3 минуты - то получение данных ~ 1 раз в 3 минуты, т.е. объективную информацию по последней свечке(текущей) мы не знаем, знаем только по предпоследней?
нет не так. Будут приходить тики, которые отображаются как close не закрытой свечи. Т е фактически вне зависимости от тайма Вы будете получать тики.
Теоретическая разница получения данных CreateDataSource+SetUpdateCallback или getNumCandles()+getCandlesByIndex(), В чем разница получения данных 1 способом и 2 способом
Разница в следующем: ------------------------------------ CreateDataSource+SetUpdateCallback - получаем данный в момент прихода их с сервера, т е до помещения в хранилище в терминале. т е один раз, в момент поступления в терминал. ------------------------------------------ getNumCandles()+getCandlesByIndex() - читаем данные из хранилища. Сколько угодно раз после поступления в хранилище терминала.
В системах реального времени используется Watchdog. Это таймер, который необходимо перезапускать через время, меньшее, чем его срабатывание. Если его не перезапустили, то он вызывает прерывание и начинает посылает сообщения об ошибке. Если его вовремя кормят, то он молчит. Можете применить такой же способ.
Тогда при таком требовании, Вы должны отдавать себе отчет в том, что когда программа выжрет всю оперативку (а при наличии на машине ее меньше 4Г это случится очень быстро) вся система просто встанет колом.
...
А если оперативки 8 ГБ, есть ли разница? Quik же бывает только 32битный, т.е. не может использовать всю память? Т.е. вопрос: можно ли на нем развертывать большие проекты на клуа с сотней ботов?
Большой проект с сотней роботов невозможно развертывать в QLUA . По двум причинам - медленность VM LUA и медленная реакция QUIK. При сотнях роботов надо использовать многопоточность, API C for LUA, и выделенные сервера. При использовании API C нет проблем задействовать любой объем оперативной памяти.
Когда не было в квике луа решал эту задачу на avtoit. Сейчас это делается с помощью winAPI в LUA , используя модуль Alien. Если умеете писать на СИ, то с помощью API C for LUA. .
проблема в том, что на компе нет библиотек, которые есть на компе разработчика. проверьте свою dll на зависимости на компе разработчика и пользователя. Потом установите у пользователя недостающие библиотеки среды разработчика. обычно это делается через манифест. читайте у майкрософт.
помогите исправить ошибку attempt to index field(a nil value), при запуске скрипта если стакан не полный то вылезает ошибка attempt to index field(a nil value)
Роман написал: s_mike@rambler.ru - визжишь ты, сливая деньги на счете. Тебе написали что вопрос не в программирование, а в алгоритме запуска скрипта!
Вот так поедешь в отпуск, а на бирже очередной сбой, график косой, скрипт запрашивает Клоз, а его нет и программа падает и не запускается, а цена идёт против тебя. А ты жопу греешь на солнце не зная об этом. Если бы скрипт запустился следующий раз, то он пошел бы дальше работать оставив ошибку в логе, так как биржа бы исправила косяк.
Sergey Gorokhov - да, это же ваши косяки или косяки биржи - это ошибку вызывают.Как от вас избавишься? Или выпускайте продукт, что бы вообще не одной ошибки не было в нём. А то сидите и рассказываете задним числом как работать надо!
Посмотрите на проблему немного иначе. КВИК , по определению, это программа подачи поручений брокеру. Есть другие способы подачи таких поручений -телефон, бумажный носитель. -------------------------------------- Все , что есть в квике кроме возможности подачи поручений - это бесплатное приложение (Увы, но это юридически именно так). --------------------------------------- Поэтому получается, что никто ничего Вам не должен. --------------------------------------------- Полагаю, что не только Вам хочется, чтобы скрипт работал вечно и без вмешательства. Но увы, реалия такова, что если скрипт написан плохо, то КВИК то квик его закрывает. Так сделали разработчики и это их право. -------------------------------------- Хотите иначе - пишите пожелания, делайте проверки внутри скрипта, ставьте защиту от падения. Ваше право. ----------------------------- Успехов.
Sergey Gorokhov написал: Для решения проблемы не используйте относительные пути при доступе к сторонним файлам.
Там нет относительных путей! Понятно что скрипт доделывать нужно, но одно если он был запущен - то нужно и запускать каждый раз когда загружается квик, а не выключать загрузку скрипта при каком либо сиюминутном сбое! Там х.з. что может быть (биржа мутит как), мы же не можем прописать всё и вся сразу!
так как скрипт без ошибок надо запускать лишь один раз, то Полагаю,что у Вас следующая проблема: ------------------------- Когда Вы запускаете скрипт кнопкой, то в КВИКЕ уже загружены все данные, которые использует Ваш скрипт и он нормально запускается. ------------------------ Потом Вы выключаете КВИК. При следующем запуске КВИКА с включенным скриптом, скрипт начинает работу сразу же при запуске КВИКА, но информация с сервере еще не пришла. В результате Ваш скрипт натыкается на nil и завершает свою работу по ошибке. ------------------------- Вы полагаете, что скрипт был выключен при закрытии КВИКА, а он просто не может возобновить свою работу. ------------------------- В результате Вы опять вынуждены его запускать нажатием кнопки при новом запуске КВИКА. -------------- Верно ?
не совсем то, так как QLUA на основе Lua 5.1 в которой /* @@ LUAI_MAXCALLS limits the number of nested calls. ** CHANGE it if you need really deep recursive calls. This limit is ** arbitrary; its only purpose is to stop infinite recursion before ** exhausting memory. */ #define LUAI_MAXCALLS 20000 /* @@ LUAI_MAXCSTACK limits the number of Lua stack slots that a C function @* can use. ** CHANGE it if you need lots of (Lua) stack space for your C ** functions. This limit is arbitrary; its only purpose is to stop C ** functions to consume unlimited stack space. (must be smaller than ** -LUA_REGISTRYINDEX) */ #define LUAI_MAXCSTACK 8000
дополню предыдущий ответ. Полагаю, что такая ситуация не возникает, так как свечи рассчитывает сервер. Поэтому терминал принимает их пакетом . Пропуск внутри пакета невозможен, так как сервер рассчитал пакет свеча за свечой.
При открытии графика все свечки строятся сразу или возможна ситуация что данные по какой то свече не пришли а через пару тиков появились и эта свеча нарисовалась?
Должны всегда строиться сразу, согласно таблицы обезличенных сделок.
Вот слово должны немного смущает. Вопрос возник по следующей причине: В мт5 могут быть получены не все данные, но при появлении новых данных, в индикаторе, есть параметр: prev_calculated (рассчитанных баров ранее) который обнуляется и на следующем тике я проведу расчёт по более полной истории. Здесь у меня ничего подобного нет, поэтому и решил уточнить. В таком случае, если мне нужно в одном индикаторе для расчёта получать данные по разным бумагам, синхронизировав данные единожды, я больше к этому вопросы могу не возвращаться ? или с синхронизацией есть какие-то другие подводные камни ?
Это не так просто как кажется, так как могут быть интервалы в которых нет сделок в одном из инструментов.
Вызов в форме return functioncall называется концевым вызовом. Lua также поддерживает концевой вызов «себя» (или рекурсивный концевой вызов): в этом случае вызванная функция использует стек вызывающей функции. Поэтому количество вложенных концовых вызовов может быть любым. Заметим только, что концевой вызов стирает отладочную информацию о вызывающей функции.
А разве это не верно: Для получения размера стека используйте функцию lua_checkstack. Для вызова из Lua кода на C необходимо иметь в наличии свободной памяти по крайней мере на LUA_MINSTACK позиций стека. LUA_MINSTACK по умолчанию равно 20. Если размера стека не хватает, его можно увеличить функцией lua_checkstack.
Sergey Gorokhov написал: Проверьте настройки терминала меню Система - Настройки - Основные настройки в "Получение данных" установить галку "Исходя из настроек открытых пользователем таблиц" в "Сохранение данных" установить галку "Данные, отражающие текущее состояние и всю историю изменений" и "Получать пропущенные данные"
Спасибо, все появилось.
Цитата
Sergey Gorokhov написал: Все проще, достаточно установить колбек через SetUpdateCallback
Ок, я сделал так:
Код
ds = CreateDataSource ( "SPBOPT" , "RI95000BI6" , INTERVAL_M1, "theorprice" )
lastCandleIndex = ds: Size ()
ds: SetUpdateCallback (ddd)
function ddd (idx)
if idx > lastCandleIndex then
message ( 'Свеча закрылась. Ее цена закрытия Close = ' .. ds:C(idx))
lastCandleIndex = idx
end
end
Но чем предыдущий код отличается от этого:
Код
new = getParamEx ( "SPBOPT" , "RI95000BI6" , "theorprice" ).param_value + 0
if new ~ = last then
message ( "новое значение " .. new)
end
last = new
Выдают они в одно и то же время одно и то же значение. Или я опять в коде с CreateDataSource намудрил? Если посмотреть на график теоретической цены, то на нем нет горизонтальных линий. Лишь экстремумы, правда не с интервалом в 1 минуту.
Т.е. обновление теории на то же самое значение не бывает и я зря вас мучаю? Достаточно просто ждать актуального изменения и работать?
В первом случае Вы получаете все значения. Во втором лишь значения из срезов пришедших в ТТП. Т е во втором случае возможны пропуски.
помогите исправить ошибку attempt to index field(a nil value), при запуске скрипта если стакан не полный то вылезает ошибка attempt to index field(a nil value)
Алекс Лепс написал: Спасибо за вашу помощь, я попробую переделать.
В примере написано две проверки первый if проверяет существования стакана и очереди в нем Циклы делаются по фактической длине очереди У вас циклы делались на фиксированную длину очереди. Примерно так.
помогите исправить ошибку attempt to index field(a nil value), при запуске скрипта если стакан не полный то вылезает ошибка attempt to index field(a nil value)
mm=getQuoteLevel2("SPBFUT","NKZ6") if mm and mm.bit_count and mm.offer_count then ------------------------- local n=mm.bid_count; while n>0 do a0=mm.bid[n].quantity b0=mm.bid[n].price c0=math.ceil(b0*1000000) d0=tostring((c0/1000000)+1) n=n-1; end ------------------------ n=mm.bid_count; while n>0 do aa0=mm.offer[n].quantity bb0=mm.offer[n].price cc0=math.ceil(bb0*1000000) dd0=tostring((cc0/1000000)-1) n=n-1 end -------------------- end ----------------------------------- -примерно так
помогите исправить ошибку attempt to index field(a nil value), при запуске скрипта если стакан не полный то вылезает ошибка attempt to index field(a nil value)
mm=getQuoteLevel2("SPBFUT","NKZ6") if mm and mm.bit_count and mm.offer_count then a0=mm.bid[mm.bid_count-i].quantity <--------ОШИБКА ЗДЕСЬ b0=mm.bid[mm.bid_count-i].price c0=math.ceil(b0*1000000) d0=tostring((c0/1000000)+1) aa0=mm.offer[mm.offer_count-i].quantity bb0=mm.offer[mm.offer_count-i].price cc0=math.ceil(bb0*1000000) dd0=tostring((cc0/1000000)-1) end
А премию за выявленную ошибку? Вот сейчас работаю с SDK на чип , так фирма за каждую выявленную ошибку всем желающим выплачивает 2000$. Вам тоже не мешало бы перенять опыт передовиков.
Алексей Орешкин написал: 3. Правильно ли я понимаю что функцию main в роботе могу и не использовать, тогда скрипт выполнится 1 раз и всё, далее он будет завершён? А если я без этой функции просто поставлю цикл while что будет тогда, он будет там постоянно крутиться ?
александр михальцов написал: Хочешь сказать что я хочу купить пакет акций, на один квартал то мне нужно вломится в кабинет брокеру и сказать ему , там один на форуме посоветовал что только в письменном виде это возможно. Брокер скажет эй трейдер иди сюда я тебе покажу как это в терминале делается. А я сделаю вывод что 90% трейдеров это- мудаки
Попробую пояснить. КВИК - это способ подать заявку брокеру. Но это не единственный способ. Проблема КВИКА в том, что из него заявки, при наличии денег, уходят в торговую систему в текущие торги, либо исчезают в прошлом. И по-существу КВИК это система заявок на один день. ------------------------------------------ Если Вы хотите купить по какой-то цене, которая будет исполнена возможно в следующем году, то это делается просто - надо дать брокеру поручение в письменном(бумажном виде) до отмены. Т е приносите в офис поручение и вручаете брокеру. И все. ------------------------- Брокер обязан его принять и исполнить при возможности и сообщить Вам об исполнении. Если до исполнения передумаете, то принесете бумажку об отмене поручения.
Василий Арефьев написал: Спасибо, я нашел взаимосвязи между таблицами. Но в решении второго вопроса это не помогло.
Перефразирую, какое поле в таблице заявок или сделок ссылается на саму себя и указывает на заявку или сделку ранее открытую? Например, сделана заявка №100 на продажу, далее позиция закрыта заявкой №101 на покупку. Как узнать, что заявка №101 закрывает заявку №100? То же самое и по таблице сделок. Или эти две строки одной таблицы никак не связаны и связь между строками заключается в равенстве количества, большей дате и обратной операции (Покупка -> Продажа)?
Заявки ничего не открывают и не закрывают. Поэтому существует связь заявка - сделка. Т к биржа - это место совершения независимых сделок.
На самом деле индикатор Fractals не совсем рассчитывается. Ведь расчет это когда из одного значения получается другое, а Fractals выбирает максимумы и минимумы из того что есть. Алгоритм поиска описан в документации на терминал
РАССЧИТЫВАТЬ, рассчитать, рассчесть, распределять счетом; сделать рассчет. Рассчитай, по чем на брата придется. Рассчесть кого, рассчитав что ему следует за работу, за службу, расплатиться и уволить его. На умах не рассчитаешь, не разочтешь, а на счетах разочту. | Рассчитывать на кого, на что, считать, полагаться, надеяться, основаться. На чужую помощь не рассчитывай. -ся, страд., взаимн. по смыслу. Мы с тобой еще не рассчитались, не разочлись, не покончили счетов. Разочлись - как вода разлилась (оба ни при чем). Рассчитыванье, -читанье, расчёт, действие по гл.; счет, выкладка, числовой вывод, с показанием всех данных. Расчет постройки, смета. Расчет с рабочими, с подрядчиком, разделка, расплата по счетам. У всякого свой расчет, свои виды, цели, намеренья. Тут нет расчета, не из чего, не для чего. Он сделал это без расчета, спроста, без задней мысли, без особенной цели; или нерассудительно, опрометчиво. Жить с рассчетом, бережливо, не издерживая лишнего. Мы с ним в расчете, рассчитались, квиты, поверстались. Конец игре-расчет. У купца расчет, а у покупателя другой (свой). В своей семье какой (что за) расчет! Расчётная книга, счет с каждым верителем и должником. Расчетливый, - тистый человек, соблюдающий во всем расчет, осмотрительный, осторожный в делах, бережливый: неидущий на неверные обороты, но и неупускающий надежных. Расчетливость жен. свойство, качество, способность эта. Расчетчик, -чица, делающий какой-либо расчет. Толковый словарь Даля. В.И. Даль. 1863-1866. ------------------------------------------------------------------------------ рассчитывать — Разбирать, соображать, смекать. См. намереваться … Словарь синонимов ----------------------------- т е индикатор Fractals рассчитывается.
PFelix написал: И есть ли в этом разница для калбеков OnAllTrade? Спасибо.
Все очень просто. Приходит пакет от сервера брокера в терминал. терминал начинает его разбирать(парсить) вытаскивает обезличенные сделки строчка за строчкой. Потом вызывает колбек и передает ему эту строчку. При возврате из колбека запихивает эту строчку в ТВС. ------------------------------------ Теперь можете ответить на свои вопросы сами. все, что пришло попадет сначала в колбек. Если это пришло раньше и уже есть в ТВС, то снова это не придет и в колбек повторно не попадет. Т е если Вы прервали работу своего скрипта, то при новом запуске будете принимать в колбеке пропущенные терминалом ( т е если был разрыв связи с сервером), а не вашим скриптом, и новые.
yako-v написал: Интересует сохранение и перевыставление снятых по оконч. сессии заявок ( перенос их в карман похоже невозможен ?). Есть такой пункт в меню ПКМ : сохр-ть заяв. в файл . Выбираю , сохраняю , присваивая имя файлу txt . Вопрос : 1. Как и когда можно правильно извлечь эти сохраненные заявки 2. Как преобразовать эти снятые заявки в стоп-заявки с укладыванием их в карман (или просто как их уложить в карман без подключения к серверу) ?
Как варианты: 1) сделать DDE таблицы заявок в Excel. 2) Написать скрипт который конвертирует записи из таблицы заявок в их первозданный вид для кармана или еще для чего угодно.
WennY написал: Доброго времени суток. Увы, ордера, полученные посредством getItem("stop_orders", i) идут по порядку начиная с первого и до последнего. В итоге чтобы получить последний ордер мне нужно как-то получить все стопы, пересчитать их и только затем уже ловить последний из них. Какие-то более цивилизованные методы существуют? Возможно я просто проморгал что-то в ФАКе. Спасибо.
Есть как минимум два способа решения этой задачи. 1) Каждый раз делать полный перебор - поиск по таблице (это Вы написали) - самый простой и самый затратный способ. Самый затратный способ. Особенно, если стопы постоянно переставляются. -------------------------------- 2) Использование OnStopOrder. В этом случае Вы через OnStopOrder. получите новый стоп. Но если запустите свой скрипт повторно при наличии активных стопов, то придется применить способ 1, так как OnStopOrder уже не сработает на существующие и ранее принятые квиком стопы. ======================== В том случае, когда Вы не пользуете колбеки (например при создании робота в индикаторе) возможен лишь способ 1 из известных. ============================. Рассмотрим мой алгоритм решения данной задачи. Этот алгоритм я разработал еще до внедрения VM LUA в КВИК и использовал его в QLUA. Он в десятки и сотни раз повышает быстродействие роботов , работающих со следящими стопами на тиках. В некоторых случаях без этого алгоритма Ваш робот просто перестанет работать, так как загрузит процессор переборам тысяч мертвых стопов. ------------------------------- Пользуйтесь: --------------------------------- 3) Алгоритм Николая Камынина(kamnik@mail.ru): Полный перебор таблицы стопов делаем один раз при запуске скрипта. В процессе этого перебора мы запоминаем в таблице (назовем ее списком активных стопов) номера строк активных стопов из таблицы стопов. ---------------------------------------- Таким образом мы получаем список строк с активными стопами. Если у нас всегда лишь один активный стоп, то в списке будет лишь одна запись. -------------------------------- Теперь посмотрим, каким образом мы будем работать дальше. ----------------------------------- Чтобы проверить состояние последней стоп заявки мы всегда читаем из таблицы стопов строку по ее номеру в списке. ----------------------------------- Т е полный перебор мы делаем всего один раз при запуске. после этого нет никаких переборов вообще. ---------------------- Кроме того, необходимо решить задачу обнаружения выставления новой стоп заявки. --------------------------------------- Эта задача решается путем сравнения числа строк таблицы стоп-заявок на предыдущем тике и на текущем. Если выставлена новая заявка, например вместо снятой или передвинутой, то число строк в таблице стоп заявок увеличится и это есть признак что есть новая стоп заявка , а ее номер строки определяется через число строк таблицы. ------------------------ Если активных стопов много, то мы периодически проверяем по нашему списку их активность и удаляем из списка неактивные. ----------------------------------- Таким образом получаем следующее преимущество перед полным перебором: Как правило роботы со следящими стопами порождают тысячи стоп-заявок, которые все забивается в таблицу стоп-заявок. при полном переборе мы на каждом тике перебираем эти тысячи. В моем алгоритме такой перебор делается лишь при запуске робота. В результате данный алгоритм в десятки и сотни раз быстрее полного перебора. ------------------------------------------------ На этом лекция на тему: "Как создать умного робота, который никогда не умрет" завершена. -------------------------- Всем спасибо, все свободны.
Imersio Arrigo написал: Че вы гадаете :( В мануале на квик все написано:
[img][/img] Я считал по этой формуле - все сходится. Не нужно изобретать двухколеное ТС.
Цитата
Николай Камынин написал: если обратитесь к литературе, то обнаружите, что EMA это простейший цифровой фильтр с бесконечной импульсной характеристикой. Так как фильтрацию делаем на конечном интервале, то вне 3000 значений мы как бы придумываем
Если вы обратитесь к этой литературе сами, то обнаружите что БИХ-фильтр - с бесконечной ХАРАКТЕРИСТИКОЙ, а не рядом входных значений. т.е. входное значение может быть одно, а отклик фильтра - бесконечным. Ну так, к сведению :)
Да, дремучий лес. отклик будет полубесконечным, т е начнется он лишь с первого отсчета из 3000 а до первого отсчета - Вы придумываете сами.
Как начинающему, советую начать с изучения языка луа на простых примерах. потом написать эти индикаторы самостоятельно по формулам инета. В результате размер кода будет раз в 10 меньше (получится примерно 5 строчек кода) и исполняться будет быстрее и у Вас будет понимание того, что делаете. -------------------------------------- Примечание: Если не обращать внимание на громкие и пустые фразы вокруг этих индикаторов, то реально индикаторы по сути самые примитивные фильтры первого порядка. Реально показывают лишь слабые знания математики и богатое воображение у их автора.