Если речь идёт о параметре "Количество сделок за сегодня", можно написать такой скрипт, которые будет работать с этим параметром, при условии, что сервер брокера получает этот параметр из торговой системы МБ. Проверить это можно по списку доступных параметров для рассматриваемого класса в окне настройки фильтра списка заказываемых классов и инструментов и параметров ( в терминалах 8.12 и новее - это пункт меню Система/Настройки/Основные настройки/Программа/Получение данных/Котировки).
Если параметр недоступен - можно обратиться к брокеру и уточнить у него, возможно ли обеспечить трансляцию этого параметра. Если параметр доступен - Вы можете заказать его терминалом, например, явным образом отметив параметр для заказа, или используя умный заказ данных. Название параметра для заказа данных по нему с использованием функций QLUA - "NUMTRADES".
Если речь идёт о параметре "Количество сделок за сегодня", можно написать такой скрипт, которые будет работать с этим параметром, при условии, что сервер брокера получает этот параметр из торговой системы МБ. Проверить это можно по списку доступных параметров для рассматриваемого класса в окне настройки фильтра списка заказываемых классов и инструментов и параметров ( в терминалах 8.12 и новее - это пункт меню Система/Настройки/Основные настройки/Программа/Получение данных/Котировки).
Если параметр недоступен - можно обратиться к брокеру и уточнить у него, возможно ли обеспечить трансляцию этого параметра. Если параметр доступен - Вы можете заказать его терминалом, например, явным образом отметив параметр для заказа, или используя умный заказ данных. Название параметра для заказа данных по нему с использованием функций QLUA - "NUMTRADES".
Хотелось бы индикатор, показывающий среднюю величину сделки, только не за сегодня, а "общее количество", только без всяких сглаживаний. Аналогично индикатору объема, с возможностью вывода в виде линии, гистограммы и т.д. Раз его не существует, значит и согласовывать не надо не с кем по поводу авторских прав. Если есть возможность добавьте его в quik или хотя бы в архив
Если Вас интересует параметр, отображающие количество "всех сделок" за "всё время торгов", т.е. за текущую торговую сессию, + все прошедшие - то у нас нет информации о том, чтобы какая-либо биржа транслировала эту информацию. Наиболее вероятно, она не транслируется вовсе.
Пожелания по написанию и добавлению скриптов в рабочее место QUIK мы не принимаем, т.к. эта задача может быть решена пользователем самостоятельно. Вы можете найти готовое решение, заказать его у какого-либо разработчика, либо создать его самостоятельно.
Документация по функциям QLUA и примеры доступны для скачивания с нашего сайта по ссылке:
.
Пользователь
Сообщений: Регистрация: 21.02.2020
20.05.2021 17:45:27
Цитата
Andrey Bezrukov написал: Если Вас интересует параметр, отображающие количество "всех сделок" за "всё время торгов", т.е. за текущую торговую сессию, + все прошедшие - то у нас нет информации о том, чтобы какая-либо биржа транслировала эту информацию. Наиболее вероятно, она не транслируется вовсе.
Странно, в справке к приложению написано совсем другое: Контрактов во всех сделках - Общее количество - Объем совершенных в текущей сессии сделок, штук. Вот такой параметр доступен для построения графика. Где неправда?
Kander написал: Не нашел ни одного скрипта отслеживающего такой параметр, как количество сделок, на ммвб он доступен.
Мы Вам , что да, параметр, отражающий количество сделок за сегодня есть, доступен обращения при помощи функций QLUA по строке "NUMTRADES".
Далее, Вы уточняете, что Вас интересуют данные не только за текущую сессию, а за весь период торгов, что мы поняли как, условно - "несколько сессий, много прошедших сессий".
Цитата
Kander написал: Хотелось бы индикатор, показывающий среднюю величину сделки, только не за сегодня, а "общее количество"
На что мы ответили, что такого параметра ТС не транслирует, и в QUIK такого параметра нет. Вы можете только самостоятельно как-то выполнять накопление и учёт этих данных из сессии в сессию. Или построить график истории изменения параметра без использования lua-индикаторов. Возможно, если брокер ведёт накопление данных истории изменения этого параметра - Вы также получите и график за прошлые торговые сессии. Но этот момент лучше уточнить непосредственно у брокера. Для этого при добавлении графика измените источник данных с обезличенных сделок на изменения этого параметра
То, что Вы приводите в последнем сообщении - это другой параметр, но он тоже отображает данные только за текущую торговую сессию, и да, его можно использовать в скриптах на LUA и функциях QLUA. Чтобы узнать его текстовый идентификатор - Вы можете добавить его в таблицу текущих торгов и выполнить по DDE в Excel с формальными заголовками. Заголовок, указанный для этого столбца и будет его строковым идентификатором. Этот же подход можете применять и для других параметров. И по нему также можно построить график истории изменения параметра без использования LUA-индикатаров
Если же Вы имеете что-то другое и с нашей стороны имеет место недопонимание Вашей задачи - просьба подробно описать что именно Вам нужно.
Пользователь
Сообщений: Регистрация: 21.02.2020
21.05.2021 14:40:59
Цитата
Andrey Bezrukov написал: На что мы ответили, что такого параметра ТС не транслирует, и в QUIK такого параметра нет. Вы можете только самостоятельно как-то выполнять накопление и учёт этих данных из сессии в сессию.
Несколько раз перечитал, ваш ответ и нахожусь в недоумении. Что бы не припираться, я покажу скрин, а вы ответьте, что показывает параметр на графике "общее количество". Это разрешит обсуждаемый вопрос.
Скрытый текст
В справке к приложению написано, что он показывает - Объем совершенных в текущей сессии сделок, штук Если это не количество сделок за каждую сессию, как написано в справке, то что?
написал: Контрактов во всех сделках - Общее количество - Объем совершенных в текущей сессии сделок, штук.
Контракт и переводится как сделка. Вы можете дать вменяемый ответ, можно ссылкой на статью. Почему из вас надо сутками ответ выбивать?
О каких контрактах идет речь на скрине выше(акции Five)?
контракт - это обязательство, которое возникает вследствие сделки по определённым активам. Например, на акциях Газпрома возникает позиция по акциям, на фьючерсах Газпрома возникает позиция по контрактам. Контракт есть обязательство выполнить определенные действия к какому то сроку (например купить или продать акции)
не нужно наезжать, сначала имеет смысл определиться в терминологии.
Пасхалочка для Алексея Иванникова:
Пользователь
Сообщений: Регистрация: 21.02.2020
24.05.2021 16:09:38
Цитата
s_mike@rambler.ru написал: не нужно наезжать, сначала имеет смысл определиться в терминологии.
Я не наезжаю, а как раз пытаюсь разобраться, если бы вы нормально, так что бы не возникало вопросов, заполнили справочную информацию, мы бы не тратили свое время на выяснение.
Мы сейчас не говорим о срочном рынке(деривативах), фьючерсах или опционах, мы говорим о фондовом рынке, о рынке акций. Конкретно о акциях компании "Пятерочка", график которых на скрине выше. Где есть сделки, лоты и акции, ну и их денежное выражение в валюте(лента сделок)
Откуда взялись контракты? Откуда берется информация о этих контрактах? В общей ленте сделок нет никаких контрактов. В чем измеряются эти контракты и как они соотносятся со сделками?
Пользователь
Сообщений: Регистрация: 04.08.2021
04.08.2021 13:46:03
Кто-нибудь может поделиться индикатором скользящей средней Laguerre? Я бы и сам мог написать, но формулу не до конца понял. Может, кто-нибудь может подсказать?
H и L это максимум и минимум свечи? L0[1] это значение для предыдущей свечи?
Пользователь
Сообщений: Регистрация: 30.01.2015
04.08.2021 17:02:08
Цитата
Dobrota написал: Кто-нибудь может поделиться индикатором скользящей средней Laguerre? Я бы и сам мог написать, но формулу не до конца понял. Может, кто-нибудь может подсказать?
if (L0 >= L1) CU = L0 - L1; else CD = L1 - L0; if (L1 >= L2) CU = CU + L1 - L2; else CD = CD + L2 - L1; if (L2 >= L3) CU = CU + L2 - L3; else CD = CD + L3 - L2;
if (CU + CD != 0) LRSI = CU / (CU + CD); val1[i] = LRSI; i--; }
Пасхалочка для Алексея Иванникова:
Пользователь
Сообщений: Регистрация: 04.08.2021
17.08.2021 21:50:55
Вернулся к попыткам написать скользящую среднюю LaguerreMA. Не могу найти ошибку в коде(в программировании полный новичок) - индикатор постепенно улетает куда-то в космос после нескольких первых значений. По аналогичной схеме написал уже код для других 5-6 индикаторов, там все четко отображает. Часть кода:
function Init() local index_1 = 0 myEMA = cached_LMA() return 1 end
function OnCalculate(index) if index == 0 then return nil end if index ~= index_1 then index_1 = index return myLMA(index, Settings.value_type, Settings.gamma) end end
function cached_LMA() local cache={} local L0 = {} local L1 = {} local L2 = {} local L3 = {}
return function(ind, v_t, kk)
local v_type = v_t local index = ind local k = kk
if index == 1 then L0[index] = dValue(index, v_type) L1[index] = dValue(index, v_type) L2[index] = dValue(index, v_type) L3[index] = dValue(index, v_type) cache[index] = dValue(index, v_type) else L0[index] = (1 - k)* dValue(index-1, v_type) + L0[index-1] L1[index] = L0[index-1] + k * L1[index-1] - k * L0[index] L2[index] = L1[index-1] + k * L2[index-1] - k * L1[index] L3[index] = L2[index-1] + k * L3[index-1] - k * L2[index] cache[index] = (L0[index]+2*L1[index]+2*L2[index]+L3[index])/6
end
return cache[index] end end
Функция dValue просто определяет значение цены в зависимости от индекса и типа цены. Можете подсказать, в чем ошибка?
Пользователь
Сообщений: Регистрация: 04.08.2021
17.08.2021 21:54:04
В начале myLMA = cached_LMA() конечно
Пользователь
Сообщений: Регистрация: 27.08.2021
27.08.2021 21:39:52
Возникла проблема, что не подгружаются вообще никакие индикаторы. Может быть я что-то делаю не так? QUIK 8.13.3.1 предлагает на выбор запуск Lua 5.4.1 или Lua 5.3.5 Например, копирую код с этого форума от 24.05.2019 16:47:09 в файл с расширением .lua Сервис-Луа скрипты-добавить. Жму на любом графике Добавить график (индикатор) и в списке нет нового имени...
Пользователь
Сообщений: Регистрация: 27.08.2021
28.08.2021 00:09:13
Разобрался. QLUA.chm в помощь. ...расположены в папке LuaIndicators в каталоге терминала. Если папка отсутствует в каталоге, необходимо создать ее вручную. Список скриптов не доступен из диалога Сервисы / LUA скрипты....
Пользователь
Сообщений: Регистрация: 29.03.2017
07.09.2021 15:35:25
Индикатор RSI вылетает с ошибкой
эта строка выглядит так
Код
local val_Up = RSI_MA_U(it.l, {Period=P, Metod = M, VType=ANY}, {[it.l] = Up})
Вот код индикатора, уж не знаю какая это редакция, может не свежая.
Вызывается следующим блоком:
Код
func = RSI() ;
local rsi_count={}
nk=ds[real]:Size()
for i=1,nk do rsi_count[i]=func(i, {Period=rsi_period, VType="Typical"}, ds[real]) end
if rsi_count[nk]~=nil then
rsi0=rsi_count[nk]
rsi1=rsi_count[nk-1]
rsi2=rsi_count[nk-2]
rsi3=rsi_count[nk-3]
rsi4=rsi_count[nk-4]
max_rsi=math.max(rsi0,rsi1,rsi2,rsi3,rsi4)
in_rsi=math.min(rsi0,rsi1,rsi2,rsi3,rsi4)
else
mm (real.." "..nk.." rsi_count[num_candles]=nil") ; sleep (100)
end
Подскажите пожалуйста, в чём может быть дело.
Пользователь
Сообщений: Регистрация: 29.03.2017
07.09.2021 15:42:28
P.S. скрипт работает и всё считает нормально, но в какой-то момент вылетает с этой ошибкой.
Пользователь
Сообщений: Регистрация: 05.01.2022
08.01.2022 14:02:50
Добрый день!
Может быть есть готовый индикатор пропущенных данных для графиков ? Если нет, возможно его размещение средствами LUA в заголовке окна или только в области графика? [img][/img][img][/img]
Пользователь
Сообщений: Регистрация: 05.01.2022
08.01.2022 14:05:30
Добрый день!
Может быть есть готовый индикатор пропущенных данных для графиков ? Если нет, возможно его размещение средствами LUA в заголовке окна или только в области графика?
Если Вас интересует параметр, отображающие количество "всех сделок" за "всё время торгов", т.е. за текущую торговую сессию, + все прошедшие - то у нас нет информации о том, чтобы какая-либо биржа транслировала эту информацию. Наиболее вероятно, она не транслируется вовсе.
Пожелания по написанию и добавлению скриптов в рабочее место QUIK мы не принимаем, т.к. эта задача может быть решена пользователем самостоятельно. Вы можете найти готовое решение, заказать его у какого-либо разработчика, либо создать его самостоятельно.
Документация по функциям QLUA и примеры доступны для скачивания с нашего сайта по ссылке:
.
Добрый день! Скачал папку LuaIndicators, вставил в QUIK. Но при открытии программы, новые индикаторы не появляются. Меня интересует только индикатор Зигзаг. Вопрос, как мне его добавить в программу?
Если Вас интересует параметр, отображающие количество "всех сделок" за "всё время торгов", т.е. за текущую торговую сессию, + все прошедшие - то у нас нет информации о том, чтобы какая-либо биржа транслировала эту информацию. Наиболее вероятно, она не транслируется вовсе.
Пожелания по написанию и добавлению скриптов в рабочее место QUIK мы не принимаем, т.к. эта задача может быть решена пользователем самостоятельно. Вы можете найти готовое решение, заказать его у какого-либо разработчика, либо создать его самостоятельно.
Документация по функциям QLUA и примеры доступны для скачивания с нашего сайта по ссылке:
.
Добрый день! Скачал папку LuaIndicators, вставил в QUIK. Но при открытии программы, новые индикаторы не появляются. Меня интересует только индикатор Зигзаг. Вопрос, как мне его добавить в программу?
откройте в текстовом редакторе исходники индикаторов. уберите лишние. сохраните под именем индикатора. поместите его в папку ...QUIK\LuaIndicators
Пользователь
Сообщений: Регистрация: 23.03.2023
23.03.2023 18:03:47
Всем добрый день!
Скажите, пожалуйста, встречал ли кто-нибудь индикатор, который может отобразить график зеркально - цена в реальности идёт вверх, а на графике - вниз? Такие индикаторы есть - например, для MetaTrader - ReverseSymbol Для другой программы он называется Mirror bars.
Заранее спасибо!
Пользователь
Сообщений: Регистрация: 08.04.2021
31.07.2023 09:59:29
Добрый день, понадобился для Quik индикатор WMA, скопировал всю папку с индикаторами в Quik, при выборе MA индикатора программа подвисает на некоторое время с ошибкой.
...\LuaIndicators\MA.lua:234: attempt to index a nil value (global 'arg')
в чем может быть дело? Штатные индикаторы MA нормально работают.
Верно понимаем, что скрипты индикаторов были загружены с нашего сайта ()? Выберите версию Lua 5.3.5 для скриптов-индикаторов, удалите из окна графика ранее добавленные Lua-индикаторы, затем добавьте нужный индикатор повторно.
Верно понимаем, что скрипты индикаторов были загружены с нашего сайта ( )? Выберите версию Lua 5.3.5 для скриптов-индикаторов , удалите из окна графика ранее добавленные Lua-индикаторы, затем добавьте нужный индикатор повторно.
Нет, я ваши не нашел, скачал такую же папку с гитхаба, они там ссылались на эту ветку форума. Поставил вашу папку - все завелось сразу. Сравнил файлы MA.lua, есть различие примерно в 400 байт, ваш файл больше по размеру и работает. Спасибо за помощь.
Пользователь
Сообщений: Регистрация: 10.08.2023
10.08.2023 16:30:58
добрый день помгите пожалуйста, делаю индикатор для quik Хай лоу пред дня + ATR , вот как мне прибавить значение atr к линии хая и лоя? что совсем не пойму
Settings = { Name = "1-HLDAY+ATR", line = { { Name = "HIGH", Color = RGB(0,200,0), Type = TYPE_DASH, Width = 2 }, { Name = "LOW", Color = RGB(200,0,0), Type = TYPE_DASH, Width = 2 } } }
function Init() func = ATR() return #Settings.line end
function OnCalculate(Index) local Out = ConvertValue(Settings, func(Index, Settings)) local HL = tonumber(Settings.Horizontal_line) if Out then local prev = GetValue(Index-1, 2) or GetValue(Index-1, 3) or 0 if Out > prev then return HL,Out,nil else return HL,nil,Out end else return HL,nil,nil end end
function ATR() --Average True Range ("ATR") local f_TR = TR() local tmp = {pp=nil, p=nil} local it = {p=0, l=0} return function (I, Fsettings, ds) local Fsettings=(Fsettings or {}) local P = (Fsettings.Period or 14) if (P > 0) then if I == 1 then tmp = {pp=nil, p=nil} it = {p=0, l=0} end local tr = f_TR(I,ds) if CandleExist(I,ds) then if I~=it.p then it = {p=I, l=it.l+1} tmp.pp = tmp.p end if it.l < P then tmp.p = (tmp.pp or 0) + tr elseif it.l == P then tmp.p = ((tmp.pp or 0) + tr) / P return tmp.p elseif it.l > P then tmp.p = ((tmp.pp or 0) * (P-1) + tr) / P return tmp.p end end end return nil end end
function TR() --True Range ("TR") local it = {pp=0, p=0, l=0} return function (I, ds) if I == 1 then it = {pp=0, p=0, l=0} end if CandleExist(I,ds) then if I~=it.p then it={pp=it.p, p=I, l=it.l+1} end if it.l == 1 then return math.abs(GetValueEX(it.p,DIFFERENCE, ds)) else return math.max(math.abs(GetValueEX(it.p,DIFFERENCE, ds)), math.abs(GetValueEX(it.p,HIGH,ds) - GetValueEX(it.pp,CLOSE,ds)), math.abs(GetValueEX(it.pp,CLOSE,ds)-GetValueEX(it.p,LOW,ds))) end end return nil end end
function Squeeze(I,P) return math.fmod(I-1,P+1) end
function ConvertValue(T,...) local function r(V, R) if R and string.upper®== "ON" then R=0 end if V and tonumber® then if V >= 0 then return math.floor(V * 10^R + 0.5) / 10^R else return math.ceil(V * 10^R - 0.5) / 10^R end else return V end end local arg = {...} arg.n = select('#', ...) if arg.n > 0 then for i = 1, arg.n do arg[i]=arg[i] and r(arg[i] * ((T and T.Multiply) or 1), (T and T.Round) or "off") end return unpack(arg) else return nil end end
function GetValueEX(I,VT,ds) VT=(VT and string.upper(string.sub(VT,1,1))) or ANY if VT == OPEN then --Open return (O and O(I)) or (ds and ds:O(I)) elseif VT == HIGH then --High return (H and H(I)) or (ds and ds:H(I)) elseif VT == LOW then --Low return (L and L(I)) or (ds and ds:L(I)) elseif VT == CLOSE then --Close return (C and C(I)) or (ds and ds:C(I)) elseif VT == VOLUME then --Volume return (V and V(I)) or (ds and ds:V(I)) elseif VT == MEDIAN then --Median return ((GetValueEX(I,HIGH,ds) + GetValueEX(I,LOW,ds)) / 2) elseif VT == TYPICAL then --Typical return ((GetValueEX(I,MEDIAN,ds) * 2 + GetValueEX(I,CLOSE,ds))/3) elseif VT == WEIGHTED then --Weighted return ((GetValueEX(I,TYPICAL,ds) * 3 + GetValueEX(I,OPEN,ds))/4) elseif VT == DIFFERENCE then --Difference return (GetValueEX(I,HIGH,ds) - GetValueEX(I,LOW,ds)) else --Any return (ds and ds[I]) end return nil end function Init() return #Settings.line end local atr = tonumber(function ATR()) local hl = { -- year -- month -- day -- high -- low }
function OnCalculate(index)
local dt = T(index) if not C(index) then return end local trdt = getTradeDate()
if dt.day ~= trdt.day or dt.month ~= trdt.month or dt.year ~= trdt.year then
if dt.day ~= hl.day or dt.month ~= hl.month or dt.year ~= hl.year then hl.year = dt.year hl.day = dt.day hl.month = dt.month hl.high = H(index) hl.low = L(index) else hl.high = (math.max(hl.high,H(index))) + atr hl.low = math.min(hl.low,L(index)) end
else return hl.high,hl.low
end
end
Пользователь
Сообщений: Регистрация: 24.04.2018
06.09.2023 10:00:59
Добрый день! Подскажите где взять indicators.zip под lua 5.4. У меня часть индикаторов на 5.4. и вместе на одном графике они не уживаются с 5.3.
Пользователь
Сообщений: Регистрация: 30.01.2015
06.09.2023 19:41:09
Цитата
написал: Добрый день! Подскажите где взять indicators.zip под lua 5.4. У меня часть индикаторов на 5.4. и вместе на одном графике они не уживаются с 5.3.
indicators.zip Это какой-то архив? Вы где его взяли? Вы думаете, что все должны знать, что у Вас в этом архиве?
Пользователь
Сообщений: Регистрация: 24.04.2018
06.09.2023 20:17:50
Цитата
Цитата
См
Цитата
Смотрите пост 80.Там есть ссылка, но там только lua 5.3, который не работает вместе с 5.4. Один индикатор psar я починил заменой unpack(arg) на table.unpack(arg), но не все можно так просто починить, нужно к автору этих индикаторов обращаться. И было бы здорово переделать их под 5.4, а не чтобы каждый сам их прилаживал под себя. Хотя и так тоже наверное можно. Вот переделанный мной Psar под lua 5.4
Код
Settings = {
Name = "*PSAR (Parabolic SAR)",
Step = 0.02,
MaxStep = 0.2,
line = {{
Name = "Horizontal line",
Type = TYPE_LINE,
Color = RGB(140, 140, 140)
},
{
Width = 3,
Name = "PSAR_Up",
Type = TYPE_POINT,
Color = RGB(221, 44, 44)
},
{
Width = 3,
Name = "PSAR_Down",
Type = TYPE_POINT,
Color = RGB(0, 206, 0)
}
},
Round = "off",
Multiply = 1,
Horizontal_line="off"
}
function Init()
func = PSAR()
return #Settings.line
end
function OnCalculate(Index)
local Out = ConvertValue(Settings, func(Index, Settings))
local HL = tonumber(Settings.Horizontal_line)
if Out then
if Out > ((H(Index)-L(Index))/2)+L(Index) then
return HL,Out,nil
else
return HL,nil,Out
end
else
return HL,nil,nil
end
end
function PSAR() --Parabolic SAR ("PSAR")
local tmp = {pp=nil, p=nil}
local it = {ppp=0, pp=0, p=0, l=0}
return function (I, Fsettings, ds)
local Out = nil
local Fsettings=(Fsettings or {})
local Step = (Fsettings.Step or 0.02)
local MaxStep = (Fsettings.MaxStep or 0.2)
if I == 1 then
tmp = {pp=nil, p=nil}
it = {ppp=0, pp=0, p=0, l=0}
end
if CandleExist(I,ds) then
if I~=it.p then
it={ppp=it.pp, pp=it.p, p=I, l=it.l+1}
tmp.pp = tmp.p
end
local cand = {ppp=nil, pp=nil, p=nil}
tmp.p = {Val = nil, Step = 0, Ext = 0, Long = true}
cand.p = {H = GetValueEX(it.p,HIGH,ds), L = GetValueEX(it.p,LOW,ds)}
if it.l==2 then
tmp.p = {Val = GetValueEX(it.p,HIGH,ds), Step = Step, Ext = cand.p.H, Long = true}
end
if it.l > 2 then
local Revers = false
tmp.p.Val = tmp.pp.Val + tmp.pp.Step * (tmp.pp.Ext - tmp.pp.Val)
tmp.p.Long = tmp.pp.Long
tmp.p.Ext = tmp.pp.Ext
tmp.p.Step = tmp.pp.Step
if tmp.pp.Long then
if cand.p.L < tmp.p.Val then
tmp.p = {Val = tmp.pp.Ext, Step = Step, Ext = cand.p.L, Long = false}
Revers = true
end
else
if cand.p.H > tmp.p.Val then
tmp.p = {Val = tmp.pp.Ext, Step = Step, Ext = cand.p.H, Long = true}
Revers = true
end
end
if not Revers then
cand.pp = {H = GetValueEX(it.pp,HIGH,ds), L = GetValueEX(it.pp,LOW,ds)}
cand.ppp = {H = GetValueEX(it.ppp,HIGH,ds), L = GetValueEX(it.ppp,LOW,ds)}
if tmp.pp.Long then
if cand.p.H > tmp.pp.Ext then
tmp.p.Ext = cand.p.H
tmp.p.Step = tmp.pp.Step + Step
if tmp.p.Step > MaxStep then tmp.p.Step = MaxStep end
end
if cand.pp.L < tmp.p.Val then tmp.p.Val = cand.pp.L end
if cand.ppp.L < tmp.p.Val then tmp.p.Val = cand.ppp.L end
else
if cand.p.L < tmp.pp.Ext then
tmp.p.Ext = cand.p.L
tmp.p.Step = tmp.pp.Step + Step
if tmp.p.Step > MaxStep then tmp.p.Step = MaxStep end
end
if cand.pp.H > tmp.p.Val then tmp.p.Val = cand.pp.H end
if cand.ppp.H > tmp.p.Val then tmp.p.Val = cand.ppp.H end
end
end
end
return tmp.p.Val
end
return nil
end
end
SMA,MMA,EMA,WMA,SMMA,VMA = "SMA","MMA","EMA","WMA","SMMA","VMA"
OPEN,HIGH,LOW,CLOSE,VOLUME,MEDIAN,TYPICAL,WEIGHTED,DIFFERENCE,ANY = "O","H","L","C","V","M","T","W","D","A"
function CandleExist(I,ds)
return (type(C)=="function" and C(I)~=nil) or
(type(ds)=="table" and (ds[I]~=nil or (type(ds.Size)=="function" and (I>0) and (I<=ds:Size()))))
end
function Squeeze(I,P)
return math.fmod(I-1,P+1)
end
function ConvertValue(T,...)
local function r(V, R)
if R and string.upper(R)== "ON" then R=0 end
if V and tonumber(R) then
if V >= 0 then return math.floor(V * 10^R + 0.5) / 10^R
else return math.ceil(V * 10^R - 0.5) / 10^R end
else return V end
end
local arg = {...}
arg.n = select('#', ...)
if arg.n > 0 then
for i = 1, arg.n do
arg[i]=arg[i] and r(arg[i] * ((T and T.Multiply) or 1), (T and T.Round) or "off")
end
return table.unpack(arg)
else return nil end
end
function GetValueEX(I,VT,ds)
VT=(VT and string.upper(string.sub(VT,1,1))) or ANY
if VT == OPEN then --Open
return (O and O(I)) or (ds and ds:O(I))
elseif VT == HIGH then --High
return (H and H(I)) or (ds and ds:H(I))
elseif VT == LOW then --Low
return (L and L(I)) or (ds and ds:L(I))
elseif VT == CLOSE then --Close
return (C and C(I)) or (ds and ds:C(I))
elseif VT == VOLUME then --Volume
return (V and V(I)) or (ds and ds:V(I))
elseif VT == MEDIAN then --Median
return ((GetValueEX(I,HIGH,ds) + GetValueEX(I,LOW,ds)) / 2)
elseif VT == TYPICAL then --Typical
return ((GetValueEX(I,MEDIAN,ds) * 2 + GetValueEX(I,CLOSE,ds))/3)
elseif VT == WEIGHTED then --Weighted
return ((GetValueEX(I,TYPICAL,ds) * 3 + GetValueEX(I,OPEN,ds))/4)
elseif VT == DIFFERENCE then --Difference
return (GetValueEX(I,HIGH,ds) - GetValueEX(I,LOW,ds))
else --Any
return (ds and ds[I])
end
return nil
end
Наши примеры Lua-индикаторов, доступные сейчас на сайте, действительно работают только с Lua версии 5.3.
Мы зарегистрировали Ваше пожелание на добавление индикаторов, совместимых с Lua 5.4. Мы постараемся рассмотреть его и сообщить Вам результаты анализа. Впоследствии, по результатам анализа, будет приниматься решение о реализации пожелания в будущих версиях ПО.
Пользователь
Сообщений: Регистрация: 31.01.2015
01.10.2023 19:33:12
У вас какая-то странная формула у скользящей средней SMMA. Не могли бы вы её расшифровать, а то я запутался в её смысле.
Формула SMMA: SMMAi = (sum(Pi) - SMMAi-1 + Pi) / n, где Pi - значение цены в i-ом периоде, SMMAi-1 - значение SMMA в предыдущем периоде, n - установленное в параметрах индикатора количество периодов.
Если необходимо рассмотреть что-то более подробно, просим Вас уточнить вопрос.
Пользователь
Сообщений: Регистрация: 30.07.2017
25.06.2024 19:16:32
Подскажите как с помощью индикатора ADX получить данные DI+ и DI-. Нужен пример.
Пользователь
Сообщений: Регистрация: 30.01.2015
25.06.2024 20:07:14
Цитата
написал: Подскажите как с помощью индикатора ADX получить данные DI+ и DI-. Нужен пример.
Никак. ---------- Это ADX вычисляется через D+ и D-, а не наоборот. -------------------- Можно вычислить индикаторы D+ и D-: D+ это EMA от High(i)-High(i-1) D- 'это EMA от Low(i)-Low(i-1) ----------------- см. в интернете.
Пользователь
Сообщений: Регистрация: 17.09.2018
08.07.2024 21:54:24
Добрый день, написал маленький индикатор, который показывает просадку.
Пользователь
Сообщений: Регистрация: 17.09.2018
08.07.2024 22:07:45
Цитата
Сергей написал: Добрый день, написал маленький индикатор, который показывает просадку.
продолжение... написал маленький индикатор, который показывает просадку от максимума. Проблема в том, что при выводе на график выходят не те данные, что приходят в месседж. Почему-то последний максимум применяется для всех свечей, а нужно что-бы максимум применялся только для тех свечей, которые идут после вычисления очередного максимума.
Settings = { Name = "*Vet_Rollback", line = { { Color = RGB(153, 204, 0), Type = TYPE_HISTOGRAM, Width = 0 },
} }
function Init() maxh = 0 return #Settings.line end
function OnCalculate(idx) if idx > 1 and H(idx)~= nil then if maxh < H(idx) then maxh = H(idx) rollback = (L(idx) - maxh) / maxh * 100 else rollback = (L(idx) - maxh) / maxh * 100
end message(tostring(maxh).." "..H(idx).." "..L(idx)) message(tostring(rollback)) return rollback end
end
Пользователь
Сообщений: Регистрация: 30.01.2015
09.07.2024 09:32:35
Цитата
Сергей написал: Settings = { Name = "*Vet_Rollback", line = { { Color = RGB(153, 204, 0), Type = TYPE_HISTOGRAM, Width = 0 }, }}function Init() maxh = 0 return #Settings.lineendfunction OnCalculate(idx) if idx > 1 and H(idx)~= nil then if maxh < H(idx) then maxh = H(idx) rollback = (L(idx) - maxh) / maxh * 100 else rollback = (L(idx) - maxh) / maxh * 100 end message(tostring(maxh).." "..H(idx).." "..L(idx)) message(tostring(rollback)) return rollback end end
При выводе на график выходят те данные, что приходят в месседж. Верно?
Пользователь
Сообщений: Регистрация: 17.09.2018
09.07.2024 11:50:21
Да, данные правильно приходят, потому как хай у вас в начале графика,
но если взять например такой график, то видно, что расчет значения в месендже правильный, а на графический вывод подаёт значение высчитанное с самого большого хая, т.е (желтые стрелки) реальное значение должно быть -0,67, а на графике оно -17.
Пользователь
Сообщений: Регистрация: 17.09.2018
09.07.2024 11:57:44
что бы понятнее было, на графике просадка составила -31%, а на индикаторе -36, как от самого последнего хая.
Пользователь
Сообщений: Регистрация: 30.01.2015
10.07.2024 07:15:58
Цитата
Сергей написал: что бы понятнее было, на графике просадка составила -31%, а на индикаторе -36, как от самого последнего хая.
У Вас так и считает скрипт. Т е просадка вычисляется от самого большого High. ------------------- Есть такая особенность в расчетах индикаторов: -------------------- Индикатор при запуске вычисляется два раза. В первый раз в нем запомнится самый большой максимум на графике Во второй раз вы и получите просадку всех значений относительного этого максимума. -------------- Такой способ вычисления индикаторов это такой прикол создателей QUIK. Чтобы жизнь медом не казалась. ------------- Про это писал лет ...надцать назад. Потом еще многие и много. ---------------- Пишите скрипт с учетом этого факта.
Пользователь
Сообщений: Регистрация: 17.09.2018
10.07.2024 15:52:37
Благодарю, я так и предположил, что двойной расчёт идет. Написал "костыль", теперь показывает верно, правда только с первого просмотра, после обновления свечи опять слетает, но мне достаточно для анализа. ------------------------------- Создателям QUIK 'респект'
Пользователь
Сообщений: Регистрация: 30.01.2015
10.07.2024 17:13:20
Цитата
Сергей написал: Благодарю, я так и предположил, что двойной расчёт идет. Написал "костыль", теперь показывает верно, правда только с первого просмотра, после обновления свечи опять слетает, но мне достаточно для анализа. ------------------------------- Создателям QUIK 'респект'
проблема решается путем установки в начальное значение всех переменных при индексе=1 например,так ваш скрипт:
Код
name="*Vet_Rollback"
Settings={Name =name};
function OnCalculate(i)
local Hi,Li=H(i),L(i)
if i==1 then
maxh=0
else
if Hi then
if maxh<Hi then maxh = Hi end
rollback=(Li-maxh)/maxh * 100
message(tostring(maxh..";"..Hi..";"..Li..";"..rollback))
end
end
return rollback
end
function Init()
Settings.line ={ { Color = RGB(153, 204, 0),Type = TYPE_HISTOGRAM,Width = 0}}
return #Settings.line
end
Пользователь
Сообщений: Регистрация: 17.09.2018
10.07.2024 18:35:50
nikolz, то, что нужно. Я так не смог придумать как максимум обнулять, теперь Вашими стараниями принцип я понял. Благодарю ещё раз.
написал: Подскажите как с помощью индикатора ADX получить данные DI+ и DI-. Нужен пример.
Никак. ---------- Это ADX вычисляется через D+ и D-, а не наоборот. -------------------- Можно вычислить индикаторы D+ и D-: D+ это EMA от High(i)-High(i-1) D- 'это EMA от Low(i)-Low(i-1) ----------------- см. в интернете
DI+ и DI- явно вычисляются в Осталось понять как получить. Интернет не даёт результатов при поиске))