александр михальцов написал: Хочешь сказать что я хочу купить пакет акций, на один квартал то мне нужно вломится в кабинет брокеру и сказать ему , там один на форуме посоветовал что только в письменном виде это возможно. Брокер скажет эй трейдер иди сюда я тебе покажу как это в терминале делается. А я сделаю вывод что 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 строчек кода) и исполняться будет быстрее и у Вас будет понимание того, что делаете. -------------------------------------- Примечание: Если не обращать внимание на громкие и пустые фразы вокруг этих индикаторов, то реально индикаторы по сути самые примитивные фильтры первого порядка. Реально показывают лишь слабые знания математики и богатое воображение у их автора.
Алексей Украинцев написал: вернее сказать: и так бывает, и наоборот - в квике есть - в БД нет...именно это поле
В качестве рабочей гипотезы могу предложить следующее: Если внимательно посмотреть на приведенные случаи то заметим следующее: Потеря id происходит в пакетах по одной цене и с разницей времени в миллисекунды. Возможно, что id не переносит сервер биржи по этой причине, или сервер КВИК и очень маловероятно, что ошибка на стороне терминала.
И опять же вопрос к разработчикам и писателям документации: почему такие важные моменты не отражаются в документации? т.е. вообще, ноль. По умолчанию полагаешь, что установил хэндлер и спишь спокойно, а на практике - возможные лоси. Это безответственный подход в отношении софта, работающего с живыми деньгами.
Поделюсь опытом. У меня реализована специальная функция - начало сессии. Она учитывает не только смену даты, но и наличие свечей с неравными High и Low. Таким образом, я различаю предторговый период, послеторговый период предыдущего дня и начало торгов.
Знаю что Вы очень заняты, и у Вас очень много важных дел. Тем не менее сохраняю надежду на вашу доброту и милость.
Почему бы Вам не добавить в качестве скриптового языка PHP. А не этот недоязык LUA, который чисто по недоразумению стал таким популярным.
Тем более что готовые решения уже есть нужно только DLL откомпилировать. Работы на пару недель всего то.
Спасибо!
Полагаю, что если очень хочется, то можно писать на джава. В луа непосредственно либо через СИ можно запускать любые проги в т ч и на джава. Правда не знаю зачем это надо, но если хочется, то можно.
Александр Пупкин написал: Здравствуйте, может кто - то показать пример работы стоп приказа тейк профит + стоп лимит
Если в тейк профите к примеру я укажу цену >=67000 Отступ от max = 50, и стоит галочка "по рыночной цене"
Что это будет значить?.. читал в справке, но что - то не совсем понял как работает отступ ((
из документации:
«Тэйк-профит» – это заявка с условием вида «исполнить при ухудшении цены на заданную величину от достигнутого максимума (на продажу) или минимума (на покупку)». Заявка работает следующим образом (пример для заявки на продажу): после достижения ценой последней сделки условия стоп-цены начинается определение максимума цены последней сделки. Если цена последней сделки снижается от максимума на величину, превышающую установленный «отступ», то создается лимитированная заявка с ценой, меньшей цены последней сделки на величину «защитного спрэда». Величины «отступа» и «защитного спрэда» могут указываться как в значениях цены, так и в процентах. НАЗНАЧЕНИЕ: Закрытие позиции по инструменту с максимальной прибылью.
-------------------------------------------- Применительно к примеру: ------------------------------------- Рынок движется вверх. если цена сделки >=67000, то сервер начинает проверять условие отступа. Далее , если текущая цена ниже предыдущей на 50, то выставляется биржевая заявка по рыночной цене.
Александр Волфовиц написал: Николай Камынин , благодарю, это известно, просто индикатор планируется использовать с разными инструментами, неохота несколько экземпляров создавать. Я думал, м.б. есть что-то наподобие H L O C
УВЫ, HLOCV создает сервер квик. Больше он ничего не создает. Остальное все поступает с биржи либо срезами в ТТП,либо пакетами в ТВС.
Александр Волфовиц написал: Можно ли в индикаторе получить "Общ.спрос", "Общ.предл"?
getParamEx Функция предназначена для получения значений всех параметров биржевой информации из Таблицы текущих торгов. С помощью этой функции можно получить любое из значений Таблицы текущих торгов для заданных кодов класса и бумаги. Формат вызова: getParamEx (STRING class_code, STRING sec_code, STRING param_name)
Как сохранить значение переменной (счетчик) чтобы при новой итерации программа обращалась к последнему сохраненному значению и считала от него счетчик далее.
Digit Service написал: Николай, пробовал.. при первом прогоне переменной COUNT присваивается значение 0.. и все.. В конце прогона программы хочу сохранить в переменную COUNT значение 1, но переменная не переназначается. При следующем запуске программы опять берется значение переменной 0. Как можно решить мою проблему?
глобальная переменная устанавливается в начальное значение при запуске и сохраняет значение в последующих циклах вычисления поэтому ее можно использовать в циклах расчета скрипта, но не в следующем запуске --------------------------------------------------. если хотите сохранять для следующего запуска, то пишите в файл и при запуске читайте.
Как сохранить значение переменной (счетчик) чтобы при новой итерации программа обращалась к последнему сохраненному значению и считала от него счетчик далее.
Полагаю, проблема в том, что getParamEx при каждом вызове ходит в хранилище текущих параметров, а это очень накладная операция. При медленном интернете, обновление ТТП будет медленнее и возможно getParamEx многократно читает одно и тоже значение из хранилища. О какой синхронности Вы говорите?
это не фьючерсы. Поэтому Вы не закрываете позицию а покупаете акции которые будут Вам зачислены через два дня и в результате чего Вы вернете брокеру взятые у него акции. Таким образом Вы закрыли то, что хотели.
Ильдус Серезетдинов написал: Ранее я мог построить мувинг на своём стационарном компьютере с периодом 39000 simpl. Но сейчас у меня идёт зависание. Я улучшил оперативную память до 4-х гигабайт, удалил все сторонние программы, но мувинг не грузится. Тиковый график без мувингов загружается, а с тяжёлым мувингом-нет. Обновление программы до версии 7.2.2.3 также не помогло. Брокер ничего толкового сказать не смог. Прошу помочь с решением данной проблемы.
Если график прямой линии не тормозит, то полагаю, что код Вашего мувинга можно облегчить от 10 до 100 раз, так как время расчета мувинга не должно зависеть от длины истории.
Как облегчить код мувинга? Как это делается?
пришлите код на почту или покажите здесь, посмотрю и скажу.
Ильдус Серезетдинов написал: Ранее я мог построить мувинг на своём стационарном компьютере с периодом 39000 simpl. Но сейчас у меня идёт зависание. Я улучшил оперативную память до 4-х гигабайт, удалил все сторонние программы, но мувинг не грузится. Тиковый график без мувингов загружается, а с тяжёлым мувингом-нет. Обновление программы до версии 7.2.2.3 также не помогло. Брокер ничего толкового сказать не смог. Прошу помочь с решением данной проблемы.
Если график прямой линии не тормозит, то полагаю, что код Вашего мувинга можно облегчить от 10 до 100 раз, так как время расчета мувинга не должно зависеть от длины истории.
Антон написал: Необходимо реализовать классическую конструкцию определения таймера по условию, после чего функция, определённая в таймере, запускается через определённый временной промежуток. Решения на основе циклов с sleep или os.time тормозят либо процессор в целом либо непосредственно поток QUIK. Подскажите, пожалуйста, адекватное решение ::
Уточните вопрос, так как Вы указали в посте , что конструкция классическая, следовательно Вам известная, а в названии просите подсказать конструкцию, т е она как бы вам неизвестная. ------------------------------------------------------- Есть много способов реализовать запуск функции в заданное время, но решение зависит от допустимой погрешности.
Sergey Denegin написал: А если он завис в результате отладки, то состояние макросов опять будет забыто.
И это абсолютно правильное поведение и меняться оно категорически не будет Ибо иначе скрипт бы постоянно приводил к зависанию. И избавиться от этого было бы нельзя. То есть терминал стал бы просто неработоспособен.
может быть сделать кнопку "запомнить список" или "обновить", а пользователь сам решит надо запоминать новый скрипт в списке или нет в текущем состоянии КВИКА?
Sergey Denegin написал: Николай, если спрашиваю, значит надо! Оставьте свои комментарии при себе.
Ваш ответ (впрочем как часто и бывает) бесполезен. Во-первых, о таком способе и так понятно было, а во-вторых, когда речь идет о массиве данных из 20-30 полей, да еще и структура данных с текстовыми индексами, то это вообще составляет целую проблему и потребует написания целой функции. Так что дайте, пожалуйста, ответить на этот вопрос тем, кто может дать дельный совет!
Вы зря обиделись. Я написал Вам ответ на ваш вопрос "как копировать таблицу"- цикл Вам предложили, поэтому я дал Вам вариант без цикла. Других вариантов не существует. -------------------------------- Если хотите получить более конструктивный ответ, то сформулируйте задачу. Как следует из дальнейших Ваших высказываний, вас интересует вообще-то не копирование таблицы, а организация обработки больших массивов данных. А это совершенно ругая задача, чем заявленная в Вашем вопросе. Так что, увы, Вам оно ( то что Вы спросили изначально), как раз и не нужно .
Космонавт написал: А если компьютер на ночь уходил в гибернацию без выключения КВИКА, а утром ожил? Запомнятся ли переменные и будет ли читаться код до функции main?
Код читается один раз при запуске скрипта. Поскольку перезапуска скрипта не произошло, то код продолжит выполняться с точки останова. При этом все переменные сохранят свои значения.
Цитата
Николай Камынин написал: Полагаю, что при смене сессии , все начнется сначала.
При смене сессии всё не начнётся сначала. Код будет работать в соответствии с заложенной в него логикой. Так, если в коде предусмотрено "обнулять" значения переменных при смене сессии, то так и будет. Если "обнуление" не предусмотрено, то значения сохранятся.
На самом деле все менее предсказуемо, так как при смене сессии или времени (как установлено) КВИК обновляет таблицы, индикаторы и сессия из текущей переходит во вчерашнюю. ---------------------------------------- Конечно, если Вы не перезагружали КВИК, то код до main исполнятся не будет, так он исполняется один раз при запуске квика или запуске скриптов . --------------------------------------------------------- Но так как при начале новой сессии, состояние робота внезапно превращается из сегодня во вчера, то логичнее выполнить инициализацию начала сессии, что фактически означает перезапуск робота. -------------------------------------------------- Подобный перезапуск целесообразно делать и при разрыве соединений, так как состояние робота внезапно переходит из текущего в устаревшее.
вместо этого A = arr_test[4] ---------------------------------- надо записать так: A={a=arr_test[4].a,b=arr_test[4].b} ----------------------------- но оно Вам надо?
Космонавт написал: А если компьютер на ночь уходил в гибернацию без выключения КВИКА, а утром ожил? Запомнятся ли переменные и будет ли читаться код до функции main?
Полагаю, что при смене сессии , все начнется сначала.
По-моему мнению - так и задумано изначально в QUIK. Дело в том, что Вы строите график по параметрам из TTП. Для строительства таких графиков информация сохраняется в info.log файле, который очищается на начало новой сессии. -------------------------- Выход лишь один - сохранять историю с помощью скрипта и отображать ее с помощью самописного индикатора.