Alexandr написал: Реализована ли в QLua работа с метатаблицами в полном объеме?
setmetatable ( u, mt )
QLua ничего для работы с мета таблицами не реализует ни в каком объеме. Она не про это. -------------------------- Все реализовано в VM (виртуальной машине) Lua, которую разработчики КВИК просто взяли и ничего даже не изучая и не изменяя, просто вставили в свою сборку терминала КВИК . ---------------------------------------- Поэтому вам и говорят, что это Lua версии 5.3 или 5.4. Т е идете на сайт разработчиков LUA и там смотрите на сишные функции виртуальной машины Lua и изучаете в каком объеме в VM Lua реализована работа с мета таблицами. Потом читаете документацию по луа, а не по QLUA, чтобы понять в каком объеме и что реализовано в VM LUA. ------------------------------ QLua - это библиотека функций написанных на си. Эти функции описаны в документации на QLUA. Эти функции позволяют вам (Нам) из скриптов написанных на луа или из функций написанных на СИ обращаться к возможностям терминала QUIK
Константин написал: В моем случае доверительный интервал это все данные в системе сколько удалось накопить. (3 года)
Вы заблуждаетесь. Доверительный интервал это совершенно другое. ----------------- Если забыли статистику, то хотя бы в Вики посмотрели там сказано: ------------------------- Довери́тельный интерва́л — термин, используемый в математической статистике при интервальной оценке статистических параметров, более предпочтительной при небольшом объёме выборки, чем точечная. Доверительным называют интервал, который покрывает неизвестный параметр с заданной надёжностью.
Доверительным называется интервал, в который попадают измеренные в эксперименте значения, соответствующие доверительной вероятности[1].
Метод доверительных интервалов разработал американский статистик Ежи Нейман, исходя из идей английского статистика Рональда Фишера[ссылка 1].
-------------------------------------------
Если Вы действительно горшок называете "горшком", а вероятность "вероятностью", а не наоборот, то вы должны были в своей статье сделать вывод иначе, чем этот (цитата из Вашей статьи). "... поступило всего 10 сигналов на покупку от разных стратегий. У каждого из них вероятность колебалась от 0.4 до 0.6 (40-60%). Средняя вероятность например получилась 0,59 (59%). Следовательно поступившие сегодня сигналы на покупку с вероятностью 59 % сработают." ------------ Пусть "... поступило всего 10 сигналов на покупку от разных стратегий. У каждого из них вероятность колебалась от 0.4 до 0.6 (40-60%). - - непонятно, чтобы это значило - "вероятность колебалась" Средняя вероятность например получилась 0,59 (59%). --если вы считаете среднее состоятельной оценкой, то откуда вы взяли, что плотность вероятностей для этих сигналов симметрична. как минимум она несимметричная, а следовательно оценка ваша смещенная. В действительности Вы понятия не имеете какой закон распределения ваших сигналов, тогда среднее вообще ни о чем. ------------------------------- Следовательно поступившие сегодня сигналы на покупку с вероятностью 59 % сработают." --------------------- Но даже, если предположить что закон симметричный и среднее реально указывает на центр тяжести, и разброс 40 -60, то среднее 50% Допустим что разброс от среднего в 10% - это сигма, то с вероятностью 0.997, доверительный интервал будет 3 сигма. -------------------- В результате получился такой вывод: При разбросе 40-60 среднее значение успешности сделки по этому сигналу составляет 50% с доверительным интервалом от 20% до 80%. -------------------------------- Т е результат успеха такой же , как , если бы Вы просто подбрасывали монету и "Орешка" - купил. " Орел" - продал, а если на ребро - то пьем кофе. ---------------------- Примерно так.
Скажу Вам по секрету, лучше читать не на заборе, особенно , если там написано русскими словами, как правило, те кто пишет на русском списывают это с англоязычных сайтов и с ошибками, а начинать читать с первоисточника. ------------------- Например , в Вашем случае, смотрим документацию на Lua 5.3 (5.4)
Скрытый текст
A detailed list of events controlled by metatables is given next. Each operation is identified by its corresponding key.
__add: the addition (+) operation. If any operand for an addition is not a number (nor a string coercible to a number), Lua will try to call a metamethod. First, Lua will check the first operand (even if it is valid). If that operand does not define a metamethod for __add, then Lua will check the second operand. If Lua can find a metamethod, it calls the metamethod with the two operands as arguments, and the result of the call (adjusted to one value) is the result of the operation. Otherwise, it raises an error.
__sub: the subtraction (-) operation. Behavior similar to the addition operation.
__mul: the multiplication (*) operation. Behavior similar to the addition operation.
__div: the division (/) operation. Behavior similar to the addition operation.
__mod: the modulo (%) operation. Behavior similar to the addition operation.
__pow: the exponentiation (^) operation. Behavior similar to the addition operation.
__unm: the negation (unary -) operation. Behavior similar to the addition operation.
__idiv: the floor division (//) operation. Behavior similar to the addition operation.
__band: the bitwise AND (&) operation. Behavior similar to the addition operation, except that Lua will try a metamethod if any operand is neither an integer nor a value coercible to an integer (see §3.4.3).
__bor: the bitwise OR (|) operation. Behavior similar to the bitwise AND operation.
__bxor: the bitwise exclusive OR (binary ~) operation. Behavior similar to the bitwise AND operation.
__bnot: the bitwise NOT (unary ~) operation. Behavior similar to the bitwise AND operation.
__shl: the bitwise left shift (<<) operation. Behavior similar to the bitwise AND operation.
__shr: the bitwise right shift (>>) operation. Behavior similar to the bitwise AND operation.
__concat: the concatenation (..) operation. Behavior similar to the addition operation, except that Lua will try a metamethod if any operand is neither a string nor a number (which is always coercible to a string).
__len: the length (#) operation. If the object is not a string, Lua will try its metamethod. If there is a metamethod, Lua calls it with the object as argument, and the result of the call (always adjusted to one value) is the result of the operation. If there is no metamethod but the object is a table, then Lua uses the table length operation (see §3.4.7). Otherwise, Lua raises an error.
__eq: the equal (==) operation. Behavior similar to the addition operation, except that Lua will try a metamethod only when the values being compared are either both tables or both full userdata and they are not primitively equal. The result of the call is always converted to a boolean.
__lt: the less than (<) operation. Behavior similar to the addition operation, except that Lua will try a metamethod only when the values being compared are neither both numbers nor both strings. The result of the call is always converted to a boolean.
__le: the less equal (<=) operation. Unlike other operations, the less-equal operation can use two different events. First, Lua looks for the __le metamethod in both operands, like in the less than operation. If it cannot find such a metamethod, then it will try the __lt metamethod, assuming that a <= b is equivalent to not (b < a). As with the other comparison operators, the result is always a boolean. (This use of the __lt event can be removed in future versions; it is also slower than a real __le metamethod.)
__index: The indexing access operation table[key]. This event happens when table is not a table or when key is not present in table. The metamethod is looked up in table.
Despite the name, the metamethod for this event can be either a function or a table. If it is a function, it is called with table and key as arguments, and the result of the call (adjusted to one value) is the result of the operation. If it is a table, the final result is the result of indexing this table with key. (This indexing is regular, not raw, and therefore can trigger another metamethod.)
__newindex: The indexing assignment table[key] = value. Like the index event, this event happens when table is not a table or when key is not present in table. The metamethod is looked up in table.
Like with indexing, the metamethod for this event can be either a function or a table. If it is a function, it is called with table, key, and value as arguments. If it is a table, Lua does an indexing assignment to this table with the same key and value. (This assignment is regular, not raw, and therefore can trigger another metamethod.)
Whenever there is a __newindex metamethod, Lua does not perform the primitive assignment. (If necessary, the metamethod itself can call rawset to do the assignment.)
__call: The call operation func(args). This event happens when Lua tries to call a non-function value (that is, func is not a function). The metamethod is looked up in func. If present, the metamethod is called with func as its first argument, followed by the arguments of the original call (args). All results of the call are the result of the operation. (This is the only metamethod that allows multiple results.)
что в переводе гугла означает:
Скрытый текст
Далее приведен подробный список событий, управляемых метатаблицами. Каждая операция идентифицируется соответствующей клавишей.
__add: операция сложения (+). Если какой-либо операнд для сложения не является числом (или строкой, приводимой к числу), Lua попытается вызвать метаметод. Сначала Lua проверит первый операнд (даже если он действителен). Если этот операнд не определяет метаметод для __add, тогда Lua проверит второй операнд. Если Lua может найти метаметод, он вызывает метаметод с двумя операндами в качестве аргументов, и результат вызова (скорректированный на одно значение) является результатом операции. В противном случае возникает ошибка.
__sub: операция вычитания (-). Поведение аналогично операции сложения.
__mul: операция умножения (*). Поведение аналогично операции сложения.
__div: операция разделения (/). Поведение аналогично операции сложения.
__mod: операция modulo (%). Поведение аналогично операции сложения.
__pow: операция возведения в степень (^). Поведение аналогично операции сложения.
__unm: операция отрицания (унарная-). Поведение аналогично операции сложения.
__idiv: операция разделения этажей (//). Поведение аналогично операции сложения.
__band: побитовая операция И (&). Поведение аналогично операции сложения, за исключением того, что Lua попытается выполнить метаметод, если какой-либо операнд не является ни целым числом, ни значением, приводимым к целому числу (см. §3.4.3).
__bor: побитовая операция ИЛИ (|). Поведение аналогично побитовой операции И.
__bxor: побитовая исключающая ИЛИ (двоичная~) операция. Поведение аналогично побитовой операции И.
__bnot: побитовая НЕ (унарная~) операция. Поведение аналогично побитовой операции И.
__shl: операция побитового сдвига влево (<<). Поведение аналогично побитовой операции И.
__shr: операция побитового сдвига вправо (>>). Поведение аналогично побитовой операции И.
__concat: операция конкатенации (..). Поведение аналогично операции сложения, за исключением того, что Lua попытается выполнить метаметод, если какой-либо операнд не является ни строкой, ни числом (что всегда приводит к строке).
__len: операция length (#). Если объект не является строкой, Lua попробует его метаметод. Если существует метаметод, Lua вызывает его с объектом в качестве аргумента, и результатом вызова (всегда с поправкой на одно значение) является результат операции. Если метаметода нет, но объект представляет собой таблицу, тогда Lua использует операцию длины таблицы (см. §3.4.7). В противном случае Lua выдает ошибку.
__eq: операция equal (==). Поведение, аналогичное операции сложения, за исключением того, что Lua будет использовать метаметод только тогда, когда сравниваемые значения являются либо обеими таблицами, либо обеими полными пользовательскими данными, и они не являются примитивно равными. Результат вызова всегда преобразуется в логическое значение.
__lt: операция меньше, чем (<) . Поведение аналогично операции сложения, за исключением того, что Lua будет использовать метаметод только тогда, когда сравниваемые значения не являются ни обоими числами, ни обеими строками. Результат вызова всегда преобразуется в логическое значение.
__le: операция less equal (<=) . В отличие от других операций, операция с меньшим равенством может использовать два разных события. Во-первых, Lua ищет __leметаметод в обоих операндах, как в операции меньше, чем. Если он не может найти такой метаметод, то он попробует __ltметаметод, предполагая, что a <= bэто эквивалентно not (b < a). Как и в случае с другими операторами сравнения, результатом всегда является логическое значение. (Это использование __ltсобытия может быть удалено в будущих версиях; это также медленнее, чем настоящий __leметаметод.)
__index: Операция доступа к индексации table[key]. Это событие происходит, когда tableне является таблицей или когда keyотсутствует в table. Метаметод ищется в .table
Несмотря на название, метаметод для этого события может быть либо функцией, либо таблицей. Если это функция, она вызывается с tableаргументами и keyв качестве аргументов, а результат вызова (скорректированный на одно значение) является результатом операции. Если это таблица, конечный результат является результатом индексации этой таблицы с keyпомощью . (Это индексирование является обычным, а не необработанным, и поэтому может вызвать другой метаметод.)
__newindex: Назначение индексации table[key] = value. Как и событие index, это событие происходит, когда tableне является таблицей или когда keyотсутствует в table. Метаметод ищется в .table
Как и в случае с индексацией, метаметодом для этого события может быть либо функция, либо таблица. Если это функция, она вызывается с table, key, и valueв качестве аргументов. Если это таблица, Lua выполняет индексирование для этой таблицы с тем же ключом и значением. (Это назначение является обычным, а не необработанным, и поэтому может вызвать другой метаметод.)
Всякий раз, когда существует __newindexметаметод, Lua не выполняет назначение примитива. (При необходимости сам метаметод может быть вызван rawsetдля выполнения назначения.)
__call: Операция вызова func(args). Это событие происходит, когда Lua пытается вызвать нефункциональное значение (то funcесть не является функцией). Метаметод ищется в .func Если присутствует, метаметод вызывается с funcпервым аргументом, за которым следуют аргументы исходного вызова (args) . Все результаты вызова являются результатом операции. (Это единственный метаметод, который допускает множественные результаты.)
local Labels = {}
function OnCalculate (index)
if index = = 1 then
OnDestroy()
end
.. .
local Label = AddLabel (Settings.tag, Param)
if Label and Label > 0 then
Labels[ # Labels + 1 ] = Label
end
.. .
end
function OnDestroy ()
for i = 1 , # Labels do
PrintDbgStr ( 'DelLabel(' .. Labels[i] .. '): ' .. tostring( DelLabel (Settings.tag, Labels[i])))
end
Labels = {}
end
При закрытии Квика срабатывает OnDestroy, но метки с графиков не удаляются. И при следующем запуске индикатор ставит новые метки поверх старых, что есть не хорошо. Так и было задумано или же ошибка?
Да, это у Вас ошибка в алгоритме. --------------------------- Если хотите удалить все метки при срабатывании OnDestroy то напишите так:
интересное решение, но сложно понять достоверность результата. ------------------ Дело в том, что на истории очень легко получить хороший результат , часто это происходит по тому, что строители стратегий используют индикаторы, которые заглядывают в будущее. например те же свечи. В итоге можно получить прибыль на истории и гарантированные убытки в реале. ------------------------ Вы легко используете понятие "вероятность успешной сделки" при малом числе сигналов. Но это не вероятность, а ее оценка. И эта оценка имеет случайную составляющую. Следовательно надо указывать доверительный интервал, а у вас его нет, а оценка - точечная. А закон распределения плотности вероятности Вашей случайной оценки Вами не установлен. следовательно надежность оценки не доказана, а получаемые Вами % вероятности - случайная величина. ------------ Примерно так.
nikolz написал: на прошлой неделе поставил со сбербанка боевой квик 9.4 ----------------- Сегодня после очередного зависания снес его нафиг и вернул 8.7. ----------------------- Как прекрасен этот мир.
довольно радикально) самое смешное что на сервере сбера как раз таки стоит 9.4.2, а вот у другого брокера, который только брокерской деятельностью и занимается с самого своего основания стоит версия 9.2.3.
сервер и клиент - это две большие разницы. ------------------------ клиент ставите на своей машине, где куча разного и различные версии OC. В итоге может быть все что угодно. --------------- поэтому я всегда делаю так. Если новая версия по каким-то причинам начинает сбоить, а старая работает без нареканий, то я просто возвращаюсь к старой и жду, когда новая отлежится. -------------
TGB написал: 3. Существует вариант построения архитектуры встраивания Lua в QUIK, в которой можно использовать однопоточный (нативный) Lua : 1) вместо регистрации функций обратного вызова, регистрация соответствующих очередей событий (возможно, с теми же именами); 2) вместо sleep, использование служебной функции ожидания либо истечения интервала времени (как в sleep), либо появления данных в очередях событий (с выдачей списка непустых очередей); 3) добавление функции чтения очередей событий (их параметров); 4) реализация функций интерфейса c QUIK в виде отдельного пакета dll, подключаемого в Lua. Подключение новых версий Lua станет в описанной выше архитектуре рутинной задачей. Исчезнут все проблемы, вызванные текущей многопоточностью QLua.
Что такое (нативный) Lua ? Это Ваше изобретение? --------------------------- Один тут "чистый" луа придумал, второй "нативный" ------------------- Для изобретателей мусора : ================
Обратимся к Wiki
Машинный код (также употребляются термины собственный код, или платформенно-ориентированный код, или родной код, или нативный код — от англ. native code) — система команд (язык) конкретной вычислительной машины (машинный язык), который интерпретируется непосредственно микропроцессором или микропрограммами данной вычислительной машины.
==================
еще раз повторю для особо тупых:
нет ни чистого ни нативного Луа,
каждая команда байт-кода луа - это функция, написанная на языке C.
TGB, вообще-то синхронизация потоков требуется лишь в том случае, если оба потока будут писать в одну и туже область памяти. ---------------------------- В приведенных Вами рассуждениях о проблеме функции LUA_API size_t lua_stringtonumber (lua_State *L, const char *s) нет доказательства, что эта функция изменяет параметры стека луа. Явно лишь, что она их читает, т е конфликта эта функция явно не создает. ---------------------- Тот факт, что Вы не умеете работать с потоками, еще не повод давать советы разработчикам как замедлять работу программ на многоядерных процессорах используя лишь последовательное их исполнение. ---------------------- Медленно ездить на телеге, не всегда безопаснее , чем быстро на автомобиле.
Константин написал: Если Вы имеете в наличии классную прибыльную торговую идею, но не обладаете навыками программирования предлагаю обмен. Вы озвучиваете свою идею. Я взамен программирую Вашу идею в своей торговой системе и даю Вам программу бесплатно. Моя система реализована на платформе 1С Предприятие 8+ Pyhton. Торгует на Московской бирже через терминал QUIK от Сбербанк брокер. От Вас потребуется только наличие лицензионной версии 1с Предприятие 8 (~от 13 000 за файловый вариант)
Есть торговая рабочая идея на основе логической (бинарной) нейронной сети. Не могу найти алгоритм оптимизации набора наилучших признаков (сеть логическая!!!). Нет такого алгоритма для логической сети даже в принципе. Надо реализация такого алгоритма на любом языке программирования.
на прошлой неделе поставил со сбербанка боевой квик 9.4 ----------------- Сегодня после очередного зависания снес его нафиг и вернул 8.7. ----------------------- Как прекрасен этот мир.
nikolz написал: фондовый и валютный - две большие разницы.
это понятно, я про то, считаются ли 2 сделки по валюте одной заявкой? порядковый номер отличается от предыдущей на 1 и время с точностью в мкс одинаковое
если выставляли одной - то одна, но исполнять ее могут множеством сделок.
Добрый день, Всем. ---------------------- На форуме очень много буратин и чайников, жизнь которых на рынке только начинается. Поэтому попробую, по мере сил и желания, снять с их ушей лапшу, которую им упорно развешивают некоторые словообильные посетители. -------------------- Начнем с определений: чайник - чел,начинающий программировать робота в QUIK. буратино - чел,начинающий гений торговли и уверенный в быстром обогащении на бирже, мечтающий о халяве. Тики - данные отображающиеся на графике с интервалом -"тиковый" ================ Фейк №1 =============== Есть тики , а есть обезличенные сделки и это разные данные, тики -няка, а обезличенные сделки -бяка. Тики обрабатываются быстрее, чем обезличенные сделки. -------------- Такая тема неоднократно появлялась на форуме. Как правило это связано с самопальными свечами с интервалом меньше 1 минуты. ================ Так вот , противопоставление тиков и обезличенных сделок - это ложь. Тики и обезличенные сделки - это одни и те же данные. =========== Получить эти данные можно тремя способами: 1) подписаться на обезличенные сделки на LUA; 2) заказать обезличенные сделки через меню терминала 3) открыть график с интервалом "тиковые" ----------------------- Во всех трех случаях данные будут поступать в таблицу обезличенных сделок,в колбек скрипта и на график. ============== Доказательство : 1) см документацию: функция CreateDataSource param – Если параметр не задан, то заказываются данные на основании таблицы обезличенных сделок. -------------- 2) без заказа через терминал, откройте тиковый график. А потом откройте таблицу обезличенных сделок. Вы увидите в таблице инструмент с тикового графика. ------------------ 3) сделаем следующий тест. На тиковый график разместим индикатор, который пишет текущую цену инструмента (ТИК) в лог файл. В этот же лог файл пишем параметры обезличенных сделок данного инструмента, полученные скриптом onAllTrade. И дополнительно проверим, что же мы получим по данному инструменту через колбек onParam, т е из ТТП. ----------- Вот результат данного теста:
Резюме: Первым ВСЕГДА отрабатывает колбек onAllTrade, после него данные приходят в индикатор графика. --------------- Колбек onParam , как и ожидалось принимает лишь некоторые тики, которые попадают в текущий срез данных, передаваемых в таблицу текущих параметров. ------------------------
Владимир, Ну вот опять у вас кроме словесного поноса ничего конкретного. ------------------- Если Вы все уже рассказали на форуме, так дайте ссылку, а не трындите про говно и собственную значимость. -------------------- Или вы не можете написать конкретно с числовыми данными ваших достижений, а опять будете соплями по экрану?
Если надо вычислять свечи на интервалах меньше 1 минуты можно использовать два источника ---------------------------- 1) точное вычисление свечей - тиковый график или таблицу обезличенных сделок. 2) приближенное вычисление свечей - колбек onParam. ------------------------- но если решение о сделке принимается резе , чем 1 раз в 10 минут, то делать свечи с интервалом менее 1 минуты практического смысла не имеет. ---------------------
Владимир , Вы сами себе противоречите. Вы говорите, что робот не должен обрабатывать каждый тик, ------------------ а свечи секундные Вы из чего собираете и очевидно вручную? ----------------------------
Владимир написал: nikolz, Может, хватит безграмотные глупости писать?
Никита, Чтобы робот был постоянно в работе, нужно его запустить и больше не останавливать. :: В этом случае возможны проблемы а) если упал Интернет и б) если торги прекратились. Короче, в любой момент, когда возникают перерывы в торговле у клиента, брокера, биржи или даже отдельного тикера. Поэтому скрипт должен уметь определять моменты приостановки и возобновления торгов и реагировать на них соответствующим образом.
А вот "чтобы робот обрабатывал каждый тик" делать не нужно (если, конечно, Вашей задачей не является испортить его до уровня полной неработоспособности). Тиковых массивов полно в Инете, но для отладки они практически бесполезны, поскольку не привязаны ко времени: может быть сотня тиков в секунду, а могут быть и перерывы между ними в десятки минут и более. Когда я отлаживал скрипт по историческим данным, я специально переводил тиковый массив в свечной, усредняя цену сделок, если их было несколько за секунду. В результате массив на 2 миллиона тиков превратился в массив на 6 миллионов секундных свечей. Вот с ним уже можно работать, ибо время, в отличие от тиков, течёт равномерно. То же самое в боевом режиме: тики не нужны никому и никогда, в т.ч. HFT роботам. Точно так же для торговли в Квике нафиг не нужны ни язык программирования CИ, ни интерфейсы FIX/FAST, ни размещение своего компа в дата-центре. Наконец, нынешний софт Квика вовек не позволит Вам получать все эти тики. По крайней мере, вовремя и без глюков. Да и слава богу! ::
Увы, Владимир, это вы пишите чушь. ----------------- Вот пример Вашей глупости. Цитата: "Тиковых массивов полно в Инете, но для отладки они практически бесполезны, поскольку не привязаны ко времени" ---------------------------- Глупость Ваша в том, что тики -это конкретные контракты и они точно привязаны к конкретному времени их заключения на бирже. а вот свечи - это средний объем по интервалу и два плавающих экстремума внутри интервала с неопределенным моментом возникновения. ------------------------------ Более того, свеча это индикатор, который по определению физически не реализуем, так как начало свечи всегда меньше времени первого тика (контракта). ----------------------- В свече лишь объем является усредненным значением. =================== по тикам (т е по обезличенным сделкам ) играют крупные игроки. ================= Если у Вас телега , то это не основание, чтобы считать самолет бесполезным.
Никита написал: Друзья, я только начинаю программировать на языке Lua. Начал разбираться и писать бота, но возник затык. Я запускаю 1 раз программу и хочу обрабатывать каждый тик после этого. Если новый тик соответствует заданным мной условиям, то бот совершает определённые действия (покупка-продажа). Как сделать так, чтобы робот был постоянно в работе и обрабатывал каждый тик? Если возможно, то с примером куска кода
Заранее спасибо всем неравнодушным!
Ну если действительно желаете работать по тикам, то Вам надо ---------------- 1) изучить: язык программирования CИ, интерфейсы FIX/FAST https://habr.com/ru/company/iticapital/blog/243657/ 2) написать" собственное ПО для торговли 3) разместить: свой комп в дата-центре. ------------------------ В итоге у Вас получится HFT робот.
Diver написал: В Справке в примере к методу OnParam в условии If ругается и пишет , что attempt to compare number with string. Я так понял, число(130000 в примере) надо в кавычки брать
либо число X в строку tostring(X), либо строку S в число tonumber(S)
Никита написал: Друзья, я только начинаю программировать на языке Lua. Начал разбираться и писать бота, но возник затык. Я запускаю 1 раз программу и хочу обрабатывать каждый тик после этого. Если новый тик соответствует заданным мной условиям, то бот совершает определённые действия (покупка-продажа). Как сделать так, чтобы робот был постоянно в работе и обрабатывал каждый тик? Если возможно, то с примером куска кода
Заранее спасибо всем неравнодушным!
1) изучите программирование на Lua https://russianblogs.com/article/84611423964/ ---------------------------- 2) Изучите документацию по QLUA.и примеры в документации. ------------------------------------ 3) Если останутся вопросы, то спросите.
Радик написал: Доброе время суток! Квик 9.5.0.42 Подскажите пожалуйста, как с этим бороться? Со временем график начинает отображаться не на всей площади окна. Слева - только что созданное окно, справа - старое. В старом окн е прощелкал все настройки, не меняется. Выход удалять старое, создавать новое окно не очень радует(.
У вас графики отличаются. На левом есть горизонтальная желтая линия, а на правом нет.
Добавлять поддержку архитектуры win32 (первая команда выше) нужно только если ваша система 64-разрядная.
Проблему рано или поздно исправят, так что можно будет пользоваться WINE и без дополнительного репозитория: sudo dpkg --add-architecture i386 sudo apt install wine winetricks
Устанавливаем VC6RedistSetup. Можно его скачать с сайта Майкрософт и запустить при помощи Wine. А можно просто выполнить в терминале winetricks vcrun6
Гораздо проще воспользоваться winetricks, т.к. перед установкой VC6RedistSetup он предложит установить необходимые нам "Wine Mono Installer" и "Wine Gecko Installer". На предложения скачать и установить нужно соглашаться и нажимать на кнопку Install.
Скачиваем Quik с сайта брокера. Если приложение находится в архиве (zip, rar), то его нужно предаварительно распаковать. WINE будем запускать с .exe файлом.
Для установки Quik используйте команду в терминале: LC_ALL=ru_RU.UTF-8 wine64 quik_inst.exe
Где вместо quik_inst.exe нужно подставить имя вашего установщика quik (например, это может быть "quik_8.7.exe"). Обратите внимание, что запускать эту команду нужно из папки, в которой находится этот установщик (installer). Если вы скачали его в папку пользователя Downloads, распаковали ZIP архив именно в эту папку, то переходите в неё при помощи команды cd в терминале: cd ~/Downloads
Копируем ключи secring.txk и pubring.txk в папку /home/USER/.wine/dosdevices/c:/Program Files/BROKER/Keys, где USER - ваше имя пользователя, а BROKER - подпапка в "Program Files (x86)", в которую установлен торговый терминал Quik (Возможно, вы захотите установить Quik не в Program Files, а в корень, например, в C:\SBERBANK. Тогда и ключи копируем в соответствующую папку). Ключи конечно же можно хранить и в другой папке, при этом в "Система" -> "Настройки" -> "Основные настройки" -> "Программа" -> "Шифрование" -> "Шифровать с помощью СКЗИ" -> Qrypto32 -> "Настроить" нужно указать путь к ключам.
Создаем ярлык для запуска. В моем случае это shell скрипт (текстовый файл с расширением sh) на рабочем столе. cd "~/.wine/dosdevices/c:/Program Files/BROKER/" LC_ALL=ru_RU.UTF-8 wine64 "c:/Program Files/BROKER/info.exe" Если опустить параметр "LC_ALL=ru_RU.UTF-8", то часть текста может отображаться некорректно (вместо текста появляются вопросы или кракозябры). Если не перейти в папку с установленной программой перед запуском, то возникают проблемы с настройками. Вместе же две команды решают проблемы с запуском Quik в Ubuntu (Linux).
После создания shell скрипта quik.sh можно открыть свойства этого текстового файла и на вкладке Permissions разрешить выполнение в качестве программы. Но можно переходить в папку с этим скриптом в терминале и запускать его, добавляя "./" перед именем файла: cd ~/Desktop ./quik.sh
После запуска Quik нужно изменить в настройках шрифты. Если этого не сделать, то в некоторых диалогах будут появляться кракозябры, хотя большая часть информации всё же отображается корректно. Для этого в меню выбираем "Система" -> "Настройки" -> "Основные настройки...(F9)" -> "Программа" -> "Шрифты", после чего изменяем шрифты, например, на Arial (или любой другой шрифт, который вам нравится, но который будет корректно отображать русские буквы в Quik).
Если нужно сгенерировать ключи для Quik, то запускаем keygen.exe из под WINE: cd ~/.wine/dosdevices/c:/Program Files (x86)/BROKER/KeyGen LC_ALL=ru_RU.UTF-8 wine64 keygen.exe
Профит!
Данный способ запуска Quik в Linux прекрасно работает для брокеров ВТБ, Открытие, БКС, Финам, Сбербанк, Промсвязьбанк и прочих. В том числе не возникает и проблем, если для входа требуется SMS подтверждение.
Если при запуске через некоторое время возникает ошибка "Не хватило памяти под объекты, без которых приложение работать не может", то первым делом нужно проверить наличие свободной памяти. .
1. Я вынужден согласиться с позицией Владимира, со следующими уточнениями: 1) С его рекомендациями начинающим разрабатывать робота, я, почти полностью, согласен. 2) Если же у кого то есть наработки на языках отличных от QLua, то ему, наверное, следует оценить затраты на перенос своих разработок на QLua и на реализацию интерфейса своих программ с QUIK. --- 2. При том, что вы активно используете IT-терминологию, у меня нет ощущения, что вы «экстра программист» :: . На этом форуме, я думаю, что подавляющее большинство посетителей интересует, как можно заработать на фондовом рынке, а не «танцы» с потоками и потенциальной программной эффективностью. Вы «попали» не на тот форум :: ?.
Мне безразличны ваши ощущения. Но так как Вы слабо разбираетесь в разработке софта, то ваши ощущения также ошибочны как и знания рынка. ------------------- Судя по рассуждениям Владимира он когда-то программировал на ассемблере - давным давно. ------------------- Очевидно, что сейчас уже отстал и не знает современных IDE. Поэтому и плюется на потоки, так как не понимает как с ними работать и очевидно все еще работает на одноядерном компьютере. ------------------------- Чего стоит его разглагольствования о том, что он обрабатывает тысячу инструментов. ------------------ Вам нравится его болтовня о том, что ничего не надо кроме "чистого" луа, одного потока и функции main в одном скрипте, чтобы сделать робота который Вам будет приносить бабло. -------------------- Смешно такое читать. --------------------- В одном с Вами соглашусь, на этом форуме в основном буратины, которые пришли на рынок как на поле чудес в страну дураков и мечтают о халяве. -------------------------- Переубеждать Вас не буду, так как в этом нем смысла.
Виктор написал: Alexey Ivannikov ,скажите, пожалуйста. Есть ли какой то прогресс в этом направлении?
В сложившихся условиях, когда windows могут начать блокировать, было бы очень актуально локализовать quik.
Ну хотя бы мануал напишите как установить и использовать его в нашей национальной системе - Linux Astra. Чтобы скрипты все работале, dll из скриптов корректно подгружались.
1. Windows никто не станет блокировать ибо колониальный принцип "товары за воздух" выгоден пендосам
2. В каком месте астра национальная? в финской либе qt* ? или в омериканском ядре линукса или X11 / wayland ?
В России нет полного цикла ни в одном из ИТ направлений от софта до железа. На это уйдут даже не годы - десятилетия.
Не прошло и года, как Windows в России забанили.
Но разработчики QUIK, видимо, будут тянуть до самого последнего конца, когда либо брокеры наймут других разрабов, либо придётся впопыхах портировать нормально работающий QUIK под linux
много шума из ничего. ------------------------ По словам представителя Microsoft, компания продолжит выполнять свои обязательства перед российскими клиентами, пока действует приостановка новых продаж. ---------------------- Т е если Вы новую винду не покупаете через представительство Microsoft, а например с новым компом из китая, то вам ничего не угрожает. ------------- Обновление уже купленной винды никто не отменял.
Ой, да такими мелкими шажками можно каждый шаг отмазывать, что мол ну это ещё ничего не значит, это же не разом всё заблокировали. А когда через 2-3 года будет заблокировано всё - окажется что, ну надо же, кто бы мог подумать. Ведь ничего похожего и близко не было. Ни с Китаем, ни с оборудованием, ни с санкциями. Но это же всё не с Windows было, так что не считается. Детский сад.
Выше чел написал Вам как ставить приложения винды на линуксе. В интернете достаточно инфы как и что делать. Если Вы это не в силе освоить, то наймите спеца , чтобы Вам настроили.
Евгений написал: Например: Открываю файл в котором на графиках сохранен инструмент SiM2, но срок его закончился или история по нему удалена.
А есть в архиве уже новая история на SiU2, то подгружать историю на SiU2.
Это решит проблему замены инструментов в файлах внд и таб.
Например есть сохраненные внд файлы но в них сохранены инструменты которые уже вышли из обращения и в архиве есть новая история. Остается только пересохранить это файл и все если надо. Так как замена инструментов через меню жутко долгая штука
Виктор написал: Alexey Ivannikov ,скажите, пожалуйста. Есть ли какой то прогресс в этом направлении?
В сложившихся условиях, когда windows могут начать блокировать, было бы очень актуально локализовать quik.
Ну хотя бы мануал напишите как установить и использовать его в нашей национальной системе - Linux Astra. Чтобы скрипты все работале, dll из скриптов корректно подгружались.
1. Windows никто не станет блокировать ибо колониальный принцип "товары за воздух" выгоден пендосам
2. В каком месте астра национальная? в финской либе qt* ? или в омериканском ядре линукса или X11 / wayland ?
В России нет полного цикла ни в одном из ИТ направлений от софта до железа. На это уйдут даже не годы - десятилетия.
Не прошло и года, как Windows в России забанили.
Но разработчики QUIK, видимо, будут тянуть до самого последнего конца, когда либо брокеры наймут других разрабов, либо придётся впопыхах портировать нормально работающий QUIK под linux
много шума из ничего. ------------------------ По словам представителя Microsoft, компания продолжит выполнять свои обязательства перед российскими клиентами, пока действует приостановка новых продаж. ---------------------- Т е если Вы новую винду не покупаете через представительство Microsoft, а например с новым компом из китая, то вам ничего не угрожает. ------------- Обновление уже купленной винды никто не отменял.
скрипт пишет данные в лог файл .csv, который открыт в экселе (я его смотрю глазками).
Закрывать файл каждый раз мануально - не вариант.
Если правильно понял, то Вам надо открыть этот файл в скрипте, а потом открыть его в Excel для просмотра. Тогда закрывать Вы его можете без проблем. если вы сделаете наоборот, то закрыть Вы его можете лишь в Excel. -------------- По умолчанию правило такое - кто открыл, тот и закрывает.
Павел написал: Второй вариант. Когда начинаются лаги интерфейса процесс info.exe занимает: 8-10% ресурсов процессора, около 800МБ памяти, очередь на диске была 0.02
Запустил quik с темной схемой в выходной - все работает в пределах нормы. Графики подгружаются без лагов. В рабочий день тогда сниму данные и пришлю, когда будет лагать.
Вы видите, что у Вас Thunderbird грузит процессор по самые...
После onTransReply() вызывается onDepoLimit() c теми же значениями, что и до SendTransaction(). Изменения в onDepoLimit() происходят только после вызова onOrder(). Правильно ли я понимаю, что меняются какие-то внутренние параметры в depo_limits ?
посмотрите внимательно на параметры:
locked_sell
NUMBER
В продаже. Количество инструментов, заблокированное под исполнение заявок клиента на продажу
locked_buy
NUMBER
В покупке. Количество инструментов в активных заявках клиента на покупку
locked_buy_value
NUMBER
Стоимость инструментов, заблокированных под покупку
locked_sell_value
NUMBER
Стоимость инструментов, заблокированных под продажу
nikolz написал: Все просто, Вы пере заказали данные и получили объем торгов за текущую сессию, так как предыдущие дни у Вас хранились в архиве, на сервере их нет.----------------------- А перезаказ привел к стиранию Вашего архива.
Какая связь перезаказа данных со смещением одного из графиков на 1 торговую сессию назад ? Вчера, 14 июня, проблема повторилась. График оборота в деньгах SBER смещен на 1 торговую сессию назад (на 4 дня, тк предыдущие торги проводились) 10 июня
Перезаказ не привел к стиранию архива, тк я работал с копией, а в конце дня перезагрузил систему из предыдущего состояния до перезаказа Оборот торгов в деньгах из архива не отображается больше , чем за текущий день - об этом уже была тема
Цитата
nikolz написал: Теперь копите данные и будет вам счастье, но когда накопите их в терминале.----------------------- В следующий раз сто раз подумаете, прежде чем перезаказывать.-------------- Либо сохраняйте копию накопленного. ================ "Потерявши голову, по волосам не плачут.."
Quik 9.40
Повторение проблемы 14 июня, в начале дня на графике не было смещения.
Предположительно, смещение графика "Оборот в деньгах SBER" появилось после разрыва связи и восстановления Обратите внимание на несоответствие дат в ТОС - 10 и 14 июня
Странно, что не отвечет техподдержка Quik
Когда у меня такое бывает, очень редко, приходится стирать архив перед перезаказом.
Функция CreateDataSource никогда не возвращает ошибку, И это создаёт большие проблемы при разработке. В неё можно запихнуть любой мусор, и она скажет: "Всё отлично".
nikolz написал: и еще... Если Вы в таблицу текущих торгов установите все доступные классы и все инструменты и все параметры то вы все доступные инструменты получите в колбеке onParam.
Колбэк возникает тогда, когда поступают данные с сервера брокера. Если по инструменту брокер отмалчивается -колбэка не будет. Мне кажется вы не понимаете сути проблемы с молчанием сервера вместо отказа, и так или иначе предлагаете варианты с таймаутом. Тем не менее, благодарю за помощь, ещё раз убедился, что поддержка не зря признала проблему и обещала решение "когда-нибудь".
Не понял про какой тайм-аут Вы говорите. --------------- Я определяю доступные инструменты при запуске квика (скрипта). Нет никакого тайм-аута. Но возможно вас не понял.
Функция CreateDataSource никогда не возвращает ошибку, И это создаёт большие проблемы при разработке. В неё можно запихнуть любой мусор, и она скажет: "Всё отлично".
и еще... Если Вы в таблицу текущих торгов установите все доступные классы и все инструменты и все параметры то вы все доступные инструменты получите в колбеке onParam.
Функция CreateDataSource никогда не возвращает ошибку, И это создаёт большие проблемы при разработке. В неё можно запихнуть любой мусор, и она скажет: "Всё отлично".
nikolz написал: Вы не сможете выбрать больше, чем указано справа в строчках "Классов доступно" "Инструментов доступно" "Параметров доступно"
Если создавать, к примеру, "таблицу текущих торгов" и нажать кнопки "добавить всё"(все доступные инструменты и доступные параметры) - то создаётся таблица со всеми ~10 тыс инструментами и параметрами. Т.е. получается выбрать всё. Все классы и все инструменты. Как и в функциях getClassesList() и getClassSecurities().
Другое дело, что таблица постепенно будет заполняться тем, на что сервер брокера не "отмалчивается".
Цитата
nikolz написал: Кроме этого, инструмент может не торговаться, т е он будет в списках, но по нему не будет изменяющейся текущей информации.Это тоже можно проверять.
К сожалению, это не "проверка", а такое же ожидание по таймауту. А вообще ,надеялся, что подскажете способ программно проверить доступность информации, а не вручную ,через создание и менеджмент окон.
А так, пока не вижу разницы... похоже, при создании ТТТ на 10 тыс инструментов терминал подписывается на всё, а там уж какая информация придёт и заполнит соотв. строки. А почему пустая строка - пусть смотрит и думает пользователь.
я проверяю программно. ------------------- Разница есть, копайте глубже. -------------------- В зависимости от начальных данных, алгоритм может отличаться . ------------------------- То, что программно можно, сто пудов. ------------------ Не понимаю, зачем Вам 10 тысяч инструментов.
Функция CreateDataSource никогда не возвращает ошибку, И это создаёт большие проблемы при разработке. В неё можно запихнуть любой мусор, и она скажет: "Всё отлично".
Да классов много и инструментов много. Но не все доступны конкретному пользователю. Функция CreateDataSource() не предназначена для обнаружения запрещенных для Вас классов и инструментов.
На мой взгляд (и опыт) функция, которая так или иначе "обещает перезвонить", должна это делать, если сделана корректно и дружелюбно к пользователю. Хотя бы потому что заранее неизвестно, по какой причине нет ответа. Запрещены какие-то классы или какие-то другие причины. Если запрещена - так и надо отвечать.
Цитата
nikolz написал: я так и делаю. Если подписка возможно и нужна, то подписываюсь.
И как вы это делаете? Как проверяете, что подписка возможна?
Очень просто. Объясняю: Когда квик соединяется с сервером , то с сервера приходят списки классов, число параметров и инструментов в классах и списки этих инструментов и параметров. Все это Вы видите в терминале, когда выбираете принимаемые параметры и инструменты. -------------------- Вы не сможете выбрать больше, чем указано справа в строчках "Классов доступно" "Инструментов доступно" "Параметров доступно" ------------------- вся эта информация содержится в доступных в скриптах таблицах Классы,Инструменты . Для корректного выполнения торговых операций в скриптах еще надо учитывать таблицы Фирмы Торговые счета и Коды клиентов. Но сейчас не об этом. ----------------------- Резюме: В квике Вы имеете список всех возможных классов. Но те классы, к которым у Вас нед доступа будут пустые по инструментам,а недоступные инструменты будут пустые по параметрам. Вот это вы и должны проверить перед тем, как на них подписываться. ------------------ Кроме этого, инструмент может не торговаться, т е он будет в списках, но по нему не будет изменяющейся текущей информации. Это тоже можно проверять. -------------- примерно так.
TGB написал: Для Lua 5.4.1 аналогичный код (но есть отличие), проверенный мною недавно и устраняющий блокировку потоков в QUIK выполнением длинного цикла пользовательской программы на «чистом» Lua
вот цитата Вашего эссе: Для Lua 5.4.1 аналогичный код (но есть отличие), проверенный мною недавно и устраняющий блокировку потоков в QUIK выполнением длинного цикла пользовательской программы на «чистом» Lua
"чистый" луа - это как "чистая" грязь. понятие бессмысленное. ----------------------------- Рассуждая о "чистом" луа Вы полезли в функции СИ , которые исполняют этот чистый луа, вместо того, чтобы написать грамотно свой длинный цикл. -------------------------------- Длинный цикл в программах обработки данных в реальном времени - верх непрофессионализма в программировании и дилетантства в обработке данных. -------------------- Так как поток колбеков и main имеют общий глобальный стек, то , во многих случаях, проблема зависания квика ликвидируется заменой глобальных переменных локальными.
Функция CreateDataSource никогда не возвращает ошибку, И это создаёт большие проблемы при разработке. В неё можно запихнуть любой мусор, и она скажет: "Всё отлично".
nikolz написал: DDE - это способ обмена данными между приложениями . По-существу это клиент-серверный обмен внутри компьютера.
Да, собственно это и имел ввиду в своём сообщении. Знаю, как в принципе работает DDE. Но буду использовать, если не будет более удобного способа.
Цитата
nikolz написал: Например, в квике DDE это практически единственный разумный способ получить доску опционов или всю таблицу текущих торгов .
Для реализации своих замыслов, я написал DLL , запускаемую скриптом с парой строк. Всё остальное делается через мою DLL и моё приложение (запускаются функции квика, луа и прочее. Но вот CreateDataSource() работает некорректно, из-за чего и возникла эта тема. Печально удивился 5-летней тишине после обещаний довести функцию до ума.
Цитата
nikolz написал: Непонятно, как это - данных нет на сервере, а Вы их запрашиваете.
В API квика есть функции получения классов инструментов и списка инструментов в каждом классе. Всего примерно тысяч 10. Но отзываются - примерно половина. Остальные - молчат. Естественно, что в ТТТ и прочих таблицах отображаются те, для которых данные всё-таки поступили, и только по ним можно что-то передать в стороннее приложение по DDE или ODBC. А вот по половине "молчащих" инструментов - совершенно неясно, почему они молчат. То ли период не тот и надо подождать ,то ли данных в принципе нет и не будет. Но всё это заканчивается замедлением работы программы ,вынужденной опрашивать и ждать таймаутов. :(
Да классов много и инструментов много. Но не все доступны конкретному пользователю. ------------------ Функция CreateDataSource() не предназначена для обнаружения запрещенных для Вас классов и инструментов. Это все можно выявить до того как подписываться. я так и делаю. Если подписка возможно и нужна, то подписываюсь. проблем не испытываю. --------------------- Могу рекомендовать сначала проверить есть ли в желаемом вами классе доступные инструменты а потом подписываться.
добавлю. как то лет ..цать назад этот вопрос на форуме задавали. Ответ был такой: - одно - старое, другое новое. в будущем старое уберут. какое старое, уже не помню.
Сергей написал: Здравствуйте. Чтобы тейк-профит работал корректно в форме тейк-проофит необходимо ввести дополнительное окно, где можно будет указать минимально допустимую цену продажи (или максимально допустимую цену покупки). После "пробития" отступа выставляется лимитная заявка либо с ценой последней сделки +/- спрэд или указанная в дополнительном окне цена. В случае покупки выставляется меньшая из двух цен, а в случае продажи выставляется большая из двух цен. Таким образом сохраняется возможность получить выигрыш при движении котировок в нужном направлении и не получить непредсказуемых отрицательных результатов из-за большого отскока цены в противоположном направлении в результате резкого изменения цены последней сделки. Страшно злит, когда акции проданы по цене много меньше планируемой, а котировки после.отскока снова резко поднялись и намного превысили ту цену, за которую ты хотел продать акции . Те же люди которым очень нужно продать или купить могут не заполнять это окно и тогда тейк-профит будет работать по имеющемуся алгоритму. Пользователи должны понимать, что при выставлении цены из дополнительного окна вероятность сделки будет меньше, чем по имеющемуся алгоритму, но многим это и не важно. Для меня, например, лучше не продать совсем, чем продать по непредсказуемо низкой цене.
Когда-то я реализовывал такой алгоритм. ------------------ В реальной работе получается, что выставленная заявка по цене последней сделки просто повисает, так как при сильном движении рынка, тот уже далеко ушел от этого места. ------------------------------ В итоге реально работающий алгоритм, который исполняет стоп-заявку с минимальными потерями существенно более сложный. ------------------------------------------ Такой алгоритм добавками дополнительного окна не реализуется. В нем надо предусматривать слежение за исполнением заявки и движением рынка и переустанавливать заявку в зависимости от ситуации. -------------------------------- кроме того, лимитная заявка будет исполняться частями и это тоже надо учитывать.
Функция CreateDataSource никогда не возвращает ошибку, И это создаёт большие проблемы при разработке. В неё можно запихнуть любой мусор, и она скажет: "Всё отлично".
поправляю. DDE и CreateDataSource() совершенно разное. DDE - это способ обмена данными между приложениями . По-существу это клиент-серверный обмен внутри компьютера. В квике этот способ обмена реализован для получения данных из любых таблиц терминала. Например, в квике DDE это практически единственный разумный способ получить доску опционов или всю таблицу текущих торгов . ---------------------------- CreateDataSource() - это функция явного запроса (подписки) на данные с сервера брокера. Если эти данные есть в какой-либо таблице или на графике, то очевидно что они уже подписаны для получения. ------------------------- Сомневаюсь, что Вы не будете смотреть те данные, на которые подпишитесь. следовательно, после первого отображения и сохранения квика, они в следующий раз автоматом начнут загружаться. ----------------------- Непонятно, как это - данных нет на сервере, а Вы их запрашиваете. Вы что их сами придумываете?