VPM (Все сообщения пользователя)

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

Страницы: Пред. 1 ... 8 9 10 11 12 13 14 15 16 17 18 ... 23 След.
Очереди и двойные очереди в луа, Пример из книги Р.Е.
 
Цитата
Nikolay написал:
А лучше добавить параметр -s. Правда если цель - писать скрипты для себя и только для себя, то зачем вообще компилировать. Квик это сам сделает перед запуском.
У меня это в SciTE запрограммировано, делаю это машинально особенно когда переделываешь,

3 кнопки по очереди:
1) сохранил изменения;
2) проверил на исполнение;
3) скомпилировал.

Особенно удобно для индикаторов, так как тело находится в модуле (таблице) , а голова в терминале.
Все основные исправления идут в теле индикатора (три кнопочки), редко голова редактируется так как структуру продумываешь сразу.
Цитата
Nikolay написал:
А лучше добавить параметр -s.
А что это у куда добавить?
Очереди и двойные очереди в луа, Пример из книги Р.Е.
 
Ну прямо не рынок сегодня, а сплошная красота, или я навыки анализа и ручной торговли вспомнил :smile:  
Очереди и двойные очереди в луа, Пример из книги Р.Е.
 
Цитата
VPM написал:
декомпилировать код,
Да на здоровье, я это делаю предполагаю, что так быстрее исполнение луа не отвлекается?
Очереди и двойные очереди в луа, Пример из книги Р.Е.
 
Вот,
Цитата
Nikolay написал:
SciTE хорош
И дальше можно не продолжать :smile:  Я шучу кому как удобно и на чем, я просто привык,
но есть одно неоспоримое преимущество он Стабилен!
Поставил уже на верно лет 20 назад (когда там 5.1 вышло), накидал разного сервиса и забыл как лезть в него.

Цитата
Nikolay написал:
Также советую проверить какую команду выдает SciTE для компиляции.  Скорее всего без -s, что оставит отладочную информацию и позволит декомпилировать код, если он компилировался в чистом виде.
Вот пример компиляции:
>luac54.exe -o "*.luac" "*.lua"
>Exit code: 0    Time: 0.138
Очереди и двойные очереди в луа, Пример из книги Р.Е.
 
"Рекламная пауза" :smile:
Цитата
Nikolay написал:
SciTE не использую, так что не знаю. После VSCode - особого желания нет.
SciTE - это просто, эффективно, наглядно, удобно, быстро компилируется для кодирования в луа супер!
VSCode - За ним самим нужно следить.
Очереди и двойные очереди в луа, Пример из книги Р.Е.
 
Добрый день!

Начну с конца. Решил сбросить на графики индикатор Структура рынка (Market Structure), помогает определить глобальный тренд.
Это тоже самое что всем хорошо известный индикатор Зиг-Заг,
пользовался разработкой Nikolay, это больше чем индикатор, это программа анализа,
зашел к нему на "поседелочки" посмотреть что нового, взял новую разработку "*zz_algo".

Nikolay, Пока не запускал в терминале, но в SciTE(lua 5.1) выдает ошибку:

lua: ...\Untitled11.lua:2390: function at line 1990 has more than 60 upvalues
>Exit code: 1    Time: 0.229

Хотя не знаю может в lua 5.4 не уже ограничения по количеству локальных переменных, но решил Вам оставить сообщение, сам не разбирался.


Кстати если кто знает как перевести SciTE(lua 5.1) на lua 5.4 подскажите пожалуйста?
Компилятор легко перевел!
Очереди и двойные очереди в луа, Пример из книги Р.Е.
 
Риск на день.

Здесь пока никаких переделок. Есть старый скрипт запущу в работу.
Смысл, защита дипозита на просадку (по умолчанию 5% от депозита),
при снижении счета на величину допустимой просадки, просто сбрасывает все позиции, и остановка торговли.

Прежде чем заняться редактированием мани менеджментом,
нужно испрвить работу моего MarketSimulator - это уже просто какое - то наказание для меня. :cry:
Ну нет доверия нужно прверять?

Да выводы конечно делать рано, но при новой организации данных, заработал сборщик мусора, взял под контроль память!
(хотя не все доделал) :lol:  
Очереди и двойные очереди в луа, Пример из книги Р.Е.
 
Риск на сделку, здесь все просто. Сделаю метод для моего класса.

Все начинается с капитала. Размер имеет значение!

Задаю в % (от 1% - 10% заввисит от стратегии по умолчанию 2% (т.е. 50 сделок)
пересчет в cash - для анализа по залогам;
пересчет в pips - для анализа по валотильности.

На выходе:
1) risk на сделку.
2) reward на сделку.
3) contract на сделку.
Очереди и двойные очереди в луа, Пример из книги Р.Е.
 
А как делать можно - нужно?

Вот и подошел в плотную к вопросу менеджмента в трейдинге!
Зачастую просматривая материалы на эту тему, заметил, что не делается различие между
мани менеджментом и риск менеджментом.

У себя я четко провожу линию различия:
риск менеджментом - управление риском;
мани менеджментом - управление позицией (количеством а вернее сказать стоимость).
Хотя эти направления сильно переплетены, но алгоритмы разные.

Начну с риска риск: риск на сделку риск на день.
За структуру данных возьму и создам класс, по примеру класса на позицию описанную выше.
Очереди и двойные очереди в луа, Пример из книги Р.Е.
 
О чем история, а история стара как рынок - "Пропустил козла в свой огород". Ну обо всем и по порядку.

Отключил  всех "помощников" - переделываю скрипты от торговли одним инструментом, к торговле портфелем.
(Когда начинал переделку, думал добавил цикл по инструментам и все дела, но не ту-то было. Вот уже больше квартала сижу).
Есть время, пишу, приторговываю руками (дневки или средней срок, стратегии концеп смарт мани + VSA или свою).

Но история то про "козла", зовется GOLD и то когда убыток по риск менеджменту в радость.
Все началось безобидно:
Бычий тренд, сильно отскочили от средней, начала дня - коррекция, нашел шортовый ордер блок,
посчитал цели, объём сделки, открылся, на цели лимитки.
Следующий день, цена не дошла несколько пунктов до цели отскочила, идет откат,
пересчет новые цели - лимитки. Все в пределах моего риск менеджмента.
Следующий день, цена не дошла несколько пунктов до цели отскочила, бычий тренд, и фаза бычья,
плакал мой дневной риск, ну и кто  тут не усреднился бы?
Риск менеджмент уже и не при делах, примерно 80% депозита в удержании данной позиции, в ущерб другим сделкам, просадки в моменте > 30%.
И какова была моя радость сегодняшнему гэпу, когда маркетмейкер перевернул рынок, все прямо по классики!
А когда цена пошла в сторону позиции, я уже не на что не обращал внимания, а при каждом удобном случае уменьшал позицию.
Огромная медвежья, поглощающая свеча, медведи зарабатывают, на конец и я в тренде,
но радовался, я тому что есть возможность закрыть позицию и закрывал!

Вспоминая историю описанную Ларри Вильямсом, когда они (риск - менеджер, у него был РАЛЬФ ВИНС,
написавший книгу "Математика управления капиталом", ныне управляющий фондом),
участвовали в конкурсе и депозит в 10 000$ превратили в миллион и потом терпели просадку почти в миллион чтоб снова подняться.

И Вся эта история про то как делать нельзя.  
Очереди и двойные очереди в луа, Пример из книги Р.Е.
 
Всем добрый вечер!

"В чем сила брат" - сила "братцы" в гэпе! :smile:

Немного хочу отступить от темы обсуждение, рассказать небольшую, но очень поучительную историю.
Но прежде по благодарить Nikolay,  за поддержку в обсуждениях, и его мудрые советы!

После того как "приказала долго жить статистика сайта", такое в впечатление что общение идет в "кругу тихо сам собою". :cry:
Ну если у разработчиков "наплевательское" отношение к нам,
давайте друг с другом обмениваться мнением, и не важно что иногда бываем не правы, высказывайтесь?
Очереди и двойные очереди в луа, Пример из книги Р.Е.
 
Цитата
Nikolay написал:
На примере массива Price, т.к. я вижу где он используется.
Значения дальше P-1 уже не нужны. Поэтому вполне можно написать Price[index - P - 1] = nil.
Хотя алгоритм поиска экстремума за период иногда проще делать иначе, через unpack. (Правда для малых P - это не существенно).

Иногда проще не создавать массивы, а просто ввести переменные, постоянно изменяя значения. На примере той же EMA, если не надо иметь данные дальше чем прошлое значение, то достаточно ввести переменную, отвечающую за прошлое значение EMA, вместо массива.
Не совсем понятно, запись Price[index - P - 1] = nil. запишет в массиве nil как значение или уменьшит этот массив.
Очереди и двойные очереди в луа, Пример из книги Р.Е.
 
Цитата
VPM написал:
function Cached.Channel_PDF_Ehlers()

  ---- Выведение торговли стратегий от Функций Распределения Вероятности (Джон Эхлерс)
  ---- VPM ©
 
  local log=math.log;
  local floor=math.floor;
 
  local fPeriodDC;
  local ftrasform_fisher;

  local Norm={}
  local Psn={}
  local Price={}
  local HH={}
  local LL={}
  local Fich={}
  local Dox={}
  local I1=0;
  local hh,ll=0,0;
  return function( I, FSettings, ds )
     local I=I or 1;
     local ds = ds or nil;
     local FSettings = FSettings or {};
.............................................
end
end
Вот пример, для данного замыкания  эти таблицы будут копить данные, в процессе работы, что ведет к потреблению памяти.
  local Norm={}
  local Psn={}
  local Price={}
  local HH={}
  local LL={}
  local Fich={}
  local Dox={}
  local I1=0;
  local hh,ll=0,0;

Как Высчитаете нужно их чистить, обрезать, еще что то в целях уменьшения потреблению памяти?
Очереди и двойные очереди в луа, Пример из книги Р.Е.
 
Nikolay,  А что думаете насчет все таки восстановить очереди, это примеры с 1 поста данной ветки?
Очереди и двойные очереди в луа, Пример из книги Р.Е.
 
Цитата
Nikolay написал:
Цитата
VPM написал:
Мы один раз продумали структуру данных, а дальше через присвоение пользуемся - "по образу и подобию",
не задумываясь почему там таблица не обновилась, где ты там забыл переменную локализовать, + "синтаксический сахар".
Это просто удобно при использовании портфеля из бумаг.
Это, конечно, так. В теории. Если объект действительно детерминирован. Но, как обычно, примеры ООП из кошек, собак, животных - это просто примеры.
Но это также не отменяет простого подхода через вызов метода, возвращающего готовую структуру. Тоже вызвал, получил экземпляр нового объекта.
Nikolay, Не совсем Вас понимаю,

я не чего не пытаюсь отменить, просто обсуждаю  с сообществом.
я лишь пришел к выводу, что такой подход в нашей задаче, наиболее оптимален, надежен, лаконичен, да просто удобен!

Создали экземпляр если не нежна переменная ставим(--), нет переменной, и не нужно носиться по всему скрипту.
не что не мешает делать так
local a=t[i][j]
внутри блока.

Но и для писателей это не только конструктор портфелей,  но и роботов - "по образу и подобию", мин. изменениями.
Очереди и двойные очереди в луа, Пример из книги Р.Е.
 
Цитата
Nikolay написал:
Очиститься, а точнее, цитируя: "локальная переменная перестает существовать, как только заканчивается ее область видимости, позволяя сборщику мусора освободить память, занимаемую ее значением". Блок же закончился. И в вышеупомянутой книге - это описывается.
Действительно я зарапортовался! :cry:  
Очереди и двойные очереди в луа, Пример из книги Р.Е.
 
Цитата
Nikolay написал:
Что касается примера, основной вопрос - зачем? Какую задачу это решает. Создавать объект ради объекта - это тупиковый путь, хоть и популярный лет 20 назад. А во многих языках даже обязательный. Но это не относится к Lua. Да, здесь многое завязано на таблицы, если не почти все, если считать _G. Но это не значит, что нет других объектов first class citizen.
На мой взгляд это из области "написал и забыл"!

Мы один раз продумали структуру данных, а дальше через присвоение пользуемся - "по образу и подобию",
не задумываясь почему там таблица не обновилась, где ты там забыл переменную локализовать, + "синтаксический сахар".
Это просто удобно при использовании портфеля из бумаг.

"Структура с методами это простейший вариант объекта". т.е. создавая таблицу мы уже создали объект.

"Что же нам это дает? Вся сила мета таблиц в мета методах".

Пока в этом только разбираюсь, но у меня рабочий вариант которым пользуюсь - фреймворк HackTrade!
Написан по этому принципу, и я не устаю "петь дифирамбы" его автору:
надежность, лаконичность, скорость, минимализм, минимальное потребление памяти...
Очереди и двойные очереди в луа, Пример из книги Р.Е.
 
Цитата
Nikolay написал:
Я не использую Дзен, так что, видимо, это не про меня.
"Код торгового робота"  это не Ваше?
Очереди и двойные очереди в луа, Пример из книги Р.Е.
 
nikolz, Вы как то все пытаетесь усложнить,
ну смотрите если "Таблицы в Lua —... — это единственная структура данных",
из которой легко выводятся все остальные, то зачем изобретать очередной "велосипед",
если это прекрасно работает, а примеры описываются первоклассными специалистами.
Берем и пользуемся!
Очереди и двойные очереди в луа, Пример из книги Р.Е.
 
Добрый день!

Да под запутался опять с видимостью переменных, а она напрямую зависит с очисткой.
К истокам!
Цитата
Игорь М написал:
Да какой сарказм-то... Я реально думаю, что автор будет впечатлён тем, что его фраза "Таблицы в Lua —... — это единственная структура данных" способна вызвать действие "перевожу все переменные в формат таблицы луа". Что это такое "перевожу все переменные в формат таблицы луа", как и зачем?
Так вот выше я показываю пример:
Цитата
Вот пример организации таблицы.

local pos={};
function pos:new() -- проинициализируем поля, процедуры и функции нашего класса
---- Создает экземпляр теперь уже объекта, описывает поля объекта и присваивает полям начальные значения.
local obj = {
[0]=0,
['d']='0',
['t']='0',
['o']='x',
['q']=0,
['p']=0,
['id']=0,
['f']=nil,
tp=function(self,v)
          if self.q>0 then
  return self.p+v
elseif self.q<0 then
  return self.p-v
else
  return 0
end
      end,
sl=function(self,v)
          if self.q>0 then
  return self.p-v
elseif self.q<0 then
  return self.p+v
else
  return 0
end
      end,
};
----далее превращаем таблицу в класс
setmetatable(obj,self)
---- объект получает доступ к методам класса
self.__index = self
---- возвращаем наш объект (экземпляр класса)
return obj
end  
Цитата
Вот пример организации таблицы.

local pos={};
function pos:new() -- проинициализируем поля, процедуры и функции нашего класса
---- Создает экземпляр теперь уже объекта, описывает поля объекта и присваивает полям начальные значения.
local obj = {
[0]=0,
['d']='0',
['t']='0',
['o']='x',
['q']=0,
['p']=0,
['id']=0,
['f']=nil,
tp=function(self,v)
           if self.q>0 then
   return self.p+v
elseif self.q<0 then
   return self.p-v
else
   return 0
end
       end,
sl=function(self,v)
           if self.q>0 then
   return self.p-v
elseif self.q<0 then
   return self.p+v
else
   return 0
end
       end,
};
----далее превращаем таблицу в класс
setmetatable(obj,self)
---- объект получает доступ к методам класса
self.__index = self
---- возвращаем наш объект (экземпляр класса)
return obj
end  
"ООП, "которого нет"
Структура с методами это простейший вариант объекта.
Метод это функция, сохраненная в элементе таблицы.
Метатаблица способна менять обычное поведение других таблиц.

Что же нам это дает?

Вся сила метатаблиц в метаметодах.
Метаметоды - Это "магические" методы, которые позволяют менять существующее поведение таблицы.
"Магические" они потому, что их логика зависит от того, как они называются."

Маленькая книга о Lua
Очереди и двойные очереди в луа, Пример из книги Р.Е.
 
Цитата
Nikolay написал:
Локальные переменные по выходу из области видимости (функции, например) уничтожаются сборщиком мусора.
Область видимости это как минимум 3 блока, если записать так
Код
do 
    local a=1
end
то она не очистится, получается так?
Очереди и двойные очереди в луа, Пример из книги Р.Е.
 
Да забыл сказать, таблицу луа организую с помощью setmetatable, может они плохо чистятся?
Вот пример организации таблицы.

local pos={};
function pos:new() -- проинициализируем поля, процедуры и функции нашего класса
---- Создает экземпляр теперь уже объекта, описывает поля объекта и присваивает полям начальные значения.
local obj = {
[0]=0,
['d']='0',
['t']='0',
['o']='x',
['q']=0,
['p']=0,
['id']=0,
['f']=nil,
tp=function(self,v)
           if self.q>0 then
   return self.p+v
elseif self.q<0 then
   return self.p-v
else
   return 0
end
       end,
sl=function(self,v)
           if self.q>0 then
   return self.p-v
elseif self.q<0 then
   return self.p+v
else
   return 0
end
       end,
};
----далее превращаем таблицу в класс
setmetatable(obj,self)
---- объект получает доступ к методам класса
self.__index = self
---- возвращаем наш объект (экземпляр класса)
return obj
end  
Очереди и двойные очереди в луа, Пример из книги Р.Е.
 
Nikolay, Спасибо, Вы как всегда лаконичны!

Посмотрел Вас на дзене, кое что интересного нашел для себя, переделаю работу со временем.

Касаемо памяти, выше я привел пример индикатора, это основной мой подход,
он написан так чтоб можно было использовать и торговом алгоритме без переделок, так  я и делаю.
Нет я конечно понимаю что там есть область констант которые будут накапливаться,
да еще передача целого массива данных, она хоть и локальна но все равно растет, особенно на малых тайм фреймах.

Можете здесь что то посоветовать, в организации переменных и их очистке?
Я собственно начинал эту веточку с организации очередей, но Вы и Владимир не советовали с этим связываться?
Очереди и двойные очереди в луа, Пример из книги Р.Е.
 
Цитата
Игорь М написал:
Цитата
VPM написал:
Прислушался к автору, "Таблицы в Lua — это не одна из структур данных, — это единственная структура данных.",
перевожу все переменные в формат таблицы луа,
не знаю поможет?
Я думаю, что автор будет впечатлён.
Не понимаю к чему этот сарказм?
Очереди и двойные очереди в луа, Пример из книги Р.Е.
 
Но все это лирика,
а вот организация структуры данных в программе, оказывается не простым делом в луа.
В очередной раз поймал утечку памяти в скрипте. 1000кВ на старте до 30000кВ на конец дня  :cry:
Такое поведение, раньше замечалось при наличии ошибки в программе, которую луа по какой то причине пропускает.

Прислушался к автору, "Таблицы в Lua — это не одна из структур данных, — это единственная структура данных.",
перевожу все переменные в формат таблицы луа,
не знаю поможет?

Другая проблема локальная переменная внутри блока не обновляется, помнит свое первое значение,
в формате таблицы обновляется в качестве локальной нет? Кто то знаком с такой проблемой?
Очереди и двойные очереди в луа, Пример из книги Р.Е.
 
Поясню для всех, о чем собственно разговор (или обо всем и по порядку).

Так как мы занимаемся алгоритмической торговлей,
то один из подходов для успешной торговли, это получение цифровой модели поведения цены.
А что еще нужно, у Вас есть функция получаете ответ и торгуете! :smile:

Упрощенное представление модели, это разложение источника на примитивы.
В тех. анализе:
- низкочастотная составляющая (тренд) - это средние, регрессия и т.д.;
- высокочастотная составляющая - это осцилляторы.
В сумме это модель.

Мое утверждение что скрин отражает лишь одну из компонент более сложной модели.
TGB,  усмотрел  в этом модель.  
Очереди и двойные очереди в луа, Пример из книги Р.Е.
 
Что делает алгоритм:

1) За период находит Мах Мин;
2) Проводится нормировка;
3) Усредняем полученный результат, получаем задержку в 1 бар;
4) Применяем преобразование Фишера  (усиление сигнала на хвостах, перевод к норм. распределению, что позволяет оперировать аппаратом т. вероятности)
5) Компенсация отставания.

Гасит низко частотные колебания, сохраняя при этом высоко частотную компоненту с минимальной задержкой.
Я искал замену стандартному схоластику, работает точнее и с минимальным отставанием.
Очереди и двойные очереди в луа, Пример из книги Р.Е.
 
Добрый день!

Цитата
TGB написал:
Цитата
VPM написал:
скорее это фильтр (detrender),
    Как ни странно, но ваш фильтр это грубая модель учета
Цитата
TGB написал:
пирамидального поведения "толпы" рвущейся за прибылью
::
TGB, Не совсем понимаю, что Вы имеете ввиду?
Вероятно Вы хорошо знакомы с организацией бух. учета, и имеете ввиду модели используемые 1С?

Что это модель - "грубая модель учета пирамидального поведения "толпы" рвущейся за прибылью"?

И зачем ее вообще нужно описывать поведения "толпы"?
У толпы всегда есть вожак (Маркет Мейкер).
Очереди и двойные очереди в луа, Пример из книги Р.Е.
 
Очереди и двойные очереди в луа, Пример из книги Р.Е.
 
TGB, Ну вот добрались и до "модели рынка", а все начиналось с безобидной статистической экспрес оценки сделок торговой системы.

Ну давайте сначала, речь идет о преобразовании данных, с применением прямого преобразования Фишера:

Утверждение 1) "Преобразование Фишера, изменяет плотность распределения любой волны таким образом,
что оно приближается к нормальному (гауссову) распределению";
Утверждение 2) Преобразование Фишера, увеличивает идентификацию маловероятного события - “черного лебедя”;

В приведённом примере, торговая стратегия, основана (не на событии) на предсказании возвращения назад к норме (к своей средней),
после выявленного маловероятного события "черного лебедя".

Нету здесь не вероятностной модели рынка, не еще какой либо, скорее это фильтр (detrender), который можно интерпретировать и как стратегию во флате.  
Очереди и двойные очереди в луа, Пример из книги Р.Е.
 
P. S.
Скрипт выводит 6 линий:
2 это придельные для наглядности нужно перевести значение на 1.5;
сам ответ функции;
опережающая линия компенсация отставания;
гистограммы зеленая и красная отражают ускорение.
Ниже 0 - медведи, выше 0 -  быки.

Это полноценная торговая стратегия, конечно применять без дополнительного фильтра нужно осторожно.
Функция циклическая сильно зависит от периода оценки.
Я использую как дополнительный фильтр для оценки зон пере(куплено/продано).

Если будут идеи пишите. Удачной торговли.
Очереди и двойные очереди в луа, Пример из книги Р.Е.
 
Цитата
nikolz написал:
Оказывается,  выборочное распределение  этой преобразованной переменной следует  нормальному распределению  .
Ну так вот же
Цитата
VPM написал:
"Преобразование Фишера, изменяет плотность распределения любой волны таким образом, что оно приближается к нормальному (гауссову) распределению".
Код
local trasform_fisher=function()--преобразования Фишера (Fisприводятсяher Transform)
--Преобразование Фишера имеет вид: 0.5* (log( (1 + x) / (1 - x) ) )

   local log=math.log
local F={}; F[1] = 0
local start=true
   return function(I,x)

if I == 1 or start then F={}; F = 0; start=false end
x = x and (x>=1 and 0.999 or x 1 and F[I-1] or 0)
local fich = (1-x)~=0 and 0.25*log((1+x)/(1-x)) + 0.5*f1 or 0
F = fich
   return F--fich
end
end
Очереди и двойные очереди в луа, Пример из книги Р.Е.
 
Цитата
nikolz написал:
Можете пояснить, как Вы вычисляете Коэффициент корреляции Пирсона и какое он имеет отношения к цене акций?
Так выше же представлен код?
это полноценный индикатор, сейчас работает у меня, нужно ему прикрутить голову, и все пробуйте.
Там и все есть расчеты, Кроме модуля оценки несущей частоты, но он не нужен.
Цену Лучше брать  медианную или по другому усреднённую,  по умолчанию это СLOSE, на больших  тайм фреймах будет перерисовывать.

Вот голова:

Settings={}
Settings.Name = "1Channel_PDF_Ehlers";
Settings.Depth=600;
Settings.v_t = "C";
Settings.period = 20;
--Settings.transform = 1 --0
--Settings.widhl = 0
Settings.avto_P = 0;
Settings.up=3.0;
Settings.dw=-3.0;
--Settings.up1=1.62;
--Settings.dw1=-1.62;

local f;
function Init()
 
f = Channel_PDF_Ehlers();


   Settings.line={
--{Name = '0',Type = TYPE_DASHDOT, Width = 1, Color = RGB(0, 0, 0) },
--{Name = '+1',Type = TYPE_DASHDOT, Width = 1, Color = RGB(0, 0, 0) },
--{Name = '-1',Type = TYPE_DASHDOT, Width = 1, Color = RGB(0, 0, 0) },
{Name = '+3',Type = TYPE_DASHDOT, Width = 1, Color = RGB(0, 0, 0) },
{Name = '-3',Type = TYPE_DASHDOT, Width = 1, Color = RGB(0, 0, 0) },
{Name = 'Red',Type = TYPE_HISTOGRAM, Width = 1 ,Color = RGB(180, 0, 0) },
{Name = 'Green',Type = TYPE_HISTOGRAM, Width = 1 ,Color = RGB(0,180, 0) },
{Name = 'PDF1',Type = TYPE_DASHDOT, Width = 1 ,Color = RGB(240, 100, 40) },
{Name = 'PDF',Type = TYPE_LINE, Width = 2 ,Color = RGB(180, 200, 240) }
   };
return #Settings.line
end

OnCalcul ate = function (index)
return  f( index, Settings )
end
Очереди и двойные очереди в луа, Пример из книги Р.Е.
 
Да. если найдется щшибка в коде, напишите,
Скрин шот не получилось вставить ну да ладно.
Очереди и двойные очереди в луа, Пример из книги Р.Е.
 
Я же в своей торговой системе применяю этот подход иначе.
Суть, в определении зон перепроданости / перекуплености (вместо стандартного стохастика),
так как данный алгоритм имеет отставание 1-2 бара, и компенсация еще убирает 1 бар.
Фактически "шагаем в ногу со временем"!  :smile:  
Очереди и двойные очереди в луа, Пример из книги Р.Е.
 
По просьбам "местных трудящихся",
Цитата
nikolz написал:
И где Вы его применили в своем роботе? Покажите.
Поправил, публикую как есть. подключил у себя :lol:

Это скрипт на стратегию Выведение торговли стратегий от Функций Распределения Вероятности опубликованную Джон Эхлерс  в его  статье, скрипт простой написан мною.
О чем разговор:
Суть стратегии от автора, определение маловероятного события, т.е. выброса цены в зону > 3G or <-3G. В примере приведенным nikolz, это Зарплата директора 450 тысяч.
Это событие является сигналом на совершение сделки.
Так как событие статистически значимое, то нужно ожидать возврата цены к ее среднему значению. В общем и все.
Код
function Cached.Channel_PDF_Ehlers()

   ---- Выведение торговли стратегий от Функций Распределения Вероятности (Джон Эхлерс)
   ---- VPM ©
   
   local log=math.log;
   local floor=math.floor;
   
   local fPeriodDC;
   local ftrasform_fisher;

   local Norm={}
   local Psn={}
   local Price={}
   local HH={} 
   local LL={} 
   local Fich={}
   local Dox={}
   local I1=0;
   local hh,ll=0,0;
   return function( I, FSettings, ds )
      local I=I or 1;
      local ds = ds or nil;
      local FSettings = FSettings or {};
                local v_t = FSettings.v_t or 'C';
      local P = FSettings.period or 20;
      local up = FSettings.up or 3.0;
      local dw = FSettings.dw or -3.0;
      --local up1 = FSettings.up1=1.62;
      --local dw1 = FSettings.dw1=-1.62;
      
      local N = FSettings.N or 8;
      local avto_P = FSettings.avto_P or 0;
      local BaseDepthInBars=FSettings.depth or 0;
      ----------------------------------------
      
      local c0 = Value( I,'C',ds ) or 0;
      local newbar = I>1 and I>I1 or false;
      if I == 1 then 
         
         Price={}; Price[I] = c0;
         HH={}; HH[I] = c0;
              LL={}; LL[I] = c0;
         Norm={}; Norm[I] = 0;
         Psn={}; Psn[I] = 0;
         Fich={}; Fich[I] = 0;
         
         fPeriodDC=Cached.DominantCycle()--Cached.PeriodDC()
         ftrasform_fisher=trasform_fisher()
         I1=0;
      end
      
      --local c1 = I>1 and Value( I-1,'O',ds ) or c0;
      
      local p1 = I>1 and Value( I-1,v_t,ds ) or c0; --Price[I-1]
      local p0 = Value( I,v_t,ds ) or 0;
      Price[I] = p0; --if v_t == '4' then Price[I] = p0 end
      
      ---- avto Period:
      if avto_P == 1 then

         --local transform = FSettings.transform or 1;              --local metod = (FSettings.metod or 1 )
              --local bw_ss = (FSettings.bw_ss or 1 )
              --local pole_ss = (FSettings.pole_ss or 0 )

                        P = fPeriodDC( I, { ['v_t']='M',['period']=P,['N']=N}, ds )
         P = floor( P )
      end
      
      if I>P then  --and newbar 
          hh,ll=Price[I-P],Price[I-P];
         for i=P,1, -1 do
         
               if Price[I-i]>hh then hh=Price[I-i] end
               if Price[I-i]<ll then ll=Price[I-i] end
               
          end
      end
      
      ---- Norm
      local norm1 = I>1 and Norm[I-1] or 0;
      local norm2 = I>2 and Norm[I-2] or norm1;
      local hl=(hh-ll);
      local norm = hl~=0 and (p0-ll)/hl or 0;
      Norm[I] = norm;

      ---- Psn
      local psn1=I>1 and Psn[I-1] or norm;
      local psn=(norm + 2*norm1 + norm2)*0.25;
      Psn[I] = psn;
      
      ---- Fich
      local fich1 = I>1 and Fich[I-1] or psn;
      local fich2 = I>2 and Fich[I-2] or fich1;
      local fich = ftrasform_fisher(I,(psn-0.5)*2 )--0.25*log( (2+psn)/(2-psn) )+ 0.5*fich1
      Fich[I]=fich;
      
      ---- lead
      local lead = 2*fich-fich1;
      -----------------------------
      
      local out1,out = fich1,fich;
      local red,green = nil,nil;
      if out > out1 then
          red,green = nil,out;
         if lead>up then
             red,green = nil,lead;
         end
      elseif out < out1 then
          red,green = out,nil;
         if lead<dw  then
              red,green = lead,nil;
         end
      end
      
      I1=I;
      ------------------------------
      
      local size = ds==nil and Size() or ds:Size() or 0;
      if BaseDepthInBars>0 and size-BaseDepthInBars>0 and I <= size-BaseDepthInBars then return nil,nil end
      
      --message( I ..' '.. tostring(red)..' '..tostring(green)..' '..tostring(out1)..' '..tostring(out) )
      return up,dw,red,green,lead,out
      
   end
end
Очереди и двойные очереди в луа, Пример из книги Р.Е.
 
Цитата
nikolz написал:
И где Вы его применили в своем роботе? Покажите.
Робот звучит гордо! :smile:

Свой подход я публиковал выше,  модульность в написании робота обсуждалась здесь.

Мой подход;
1) Торговая стратегия - это набор правил (на открытие, закрытие и т.д.);
2) Торговая система - это набор торговая стратегий;
3) Робот - это голова, ноги (чтоб можно было убежать вовремя), руки (что бы сделки совершать), в общем полная самостоятельность;

Я пишу подробно что бы можно было изъясняться на одном языке, а не поучаю.

У меня запрограммирована одна токая Торговая стратегия - "Выведение Торговли Стратегий От Функций Распределения Вероятности".
Она очень простая. При на писании допустил концептуальную ошибку, сейчас не пользуюсь - отключил, нужно править.
Очереди и двойные очереди в луа, Пример из книги Р.Е.
 
nikolz, за приведенные ссылки спасибо, полистаю на досуге.

Касаемо моих замечаний:

1) Знание мои так себе, (последние четверть века занимался другими вещами).
2) Книгу Вам привел потому, что там не только описаны распределения, моменты и много еще чего,
но и то как пользоваться, а главное приводятся запрограммированные примеры (берете код и пробуете, можно даже в квике).
3) Касаемо Вашего примера, нужно вспомнить правило 3 сигм (куда с какой вероятностью попадаю результаты),
ну и конечно, простое среднее здесь применять нельзя, ну про Вы сами накидали ссылок.
4) Ни о каком распределение Фишера речи нет,
я говорю о необходимости подготовки данных прежде чем использовать нормальное распределение,
одним из таких является  - Преобразование Фишера.

"Преобразование Фишера, изменяет плотность распределения любой волны таким образом, что оно приближается к нормальному (гауссову) распределению".
Код
local trasform_fisher=function()--преобразования Фишера (Fisприводятсяher Transform)
--Преобразование Фишера имеет вид: 0.5* (log( (1 + x) / (1 - x) ) )

    local log=math.log
local F={}; F[1] = 0
local start=true
    return function(I,x)

if I == 1 or start then F={}; F[I] = 0; start=false end
x = x and (x>=1 and 0.999 or x<=-1 and (-0.999) or x) or 0
local f1=(I>1 and F[I-1] or 0)
local fich = (1-x)~=0 and 0.25*log((1+x)/(1-x)) + 0.5*f1 or 0
F[I] = fich
    return F[I]--fich
end
end
Очереди и двойные очереди в луа, Пример из книги Р.Е.
 
nikolz, я у Вас спрашивал про методы робастного оценивания или  ссылку где посмотреть? Ну да ладно.

Не знаю как  уж там Росстат считает не хочу вдаваться, но Ваш пример некуда не годится,
это распространенное смысловое заблуждение. Вы бы ещё среднею температуру по больнице по считали бы.

Если вкратце, то среднее у нормального распределения ==0,
в Вашем примере расчет простого среднего служит для привидения к такому виду и не для каких других целей.
В трейдинге самое простое привидение считают доходности  р1/р2 - 1, при этом нужно удалить тренд.
Преобразование Фишера любые переменные приводит к такому виду.
Я не хочу азбукой заниматься, вот ссылка John R. Hauser "Numerical Methods for Nonlinear Engineering Models"
с примерами  написанными на луа 5.1, если интересно смотрите можно и поэкспериментировать.
Очереди и двойные очереди в луа, Пример из книги Р.Е.
 
Добрый день!

Можно подвести промежуточный итог, на тему обсуждаемую выше.
Собрал небольшую программу, в основе лежит функция поиска приложенная  Nikolay,  за что ему скажем отдельное спасибо!
Пока не очень разобрался как работает, но работает супер, (а к хорошему привыкаешь быстро :smile: ).

То, для чего и как, много сказано выше, здесь лишь о своей реализации.
Подход: на оси времени графика есть текущее значение цены,
правая сторона от текущее значение цены - это зона прогнозов;
леваявая сторона - это история, определяя период тестирования определяем зону тестирования.

Я в своих подходах, зону тестирования еще делю на две.
1) фон - служит для определения того что происходит на рынке при старте торгового алгоритма; и для разгона алгоритмов использующих историю данных.
2) собственно сам тест то что сообственно обсуждалось выше.

Для прогона теста задаю количество дней тестируемых, сдвигаю индекс на таймфрейме дня, находим начальную дату и время.
(Установил ограничения только внутридневные не больше 60 мин. такова пока особенность ф. поиска).
От общего итератора пока тоже отказался, просто в алгоритм добавил счетчик для сдвига индексов тайм фреймов.
Прогоняем стратегию, результат W/L обрабатываю методом описанным выше получаю экспресс оценку, торговой стратегии,
если необходимо то и торговой системы целиком.
Да добавил визуализацию вывод на график сигналов и параметров RM.

Теперь обрабатывает портфель из бумаг, в общем то и все,
еще раз спасибо Nikolay, и удачной торговли!  
Очереди и двойные очереди в луа, Пример из книги Р.Е.
 
Цитата
nikolz написал:
В результате этого появилась теория и методы робастного оценивания.
Так о что с примером?
Очереди и двойные очереди в луа, Пример из книги Р.Е.
 
Да это согласен можно найти, но ведь речь идет о простом алгоритме в рамках единого итератора с переходом к реальным торгам.
Очереди и двойные очереди в луа, Пример из книги Р.Е.
 
Цитата
Nikolay написал:
Отлаживать не так и сложно, если в необходимых местах осуществлять проверки на тип данных, сами данные. Выводит отладочную информацию в лог. Сразу будет видно, где что не так.
Не поверите другой раз не могу лог загрузить из-за  объема после дня работы скрипта. Да тип данных начал добавлять согласен.
Цитата
Nikolay написал:
Как я написал выше - самый надежный, и самый простой вариант - это циклом пройтись от первого или последнего бара, проверяя время каждого бара. Как только оно пересечется с искомым - вот он ваш индекс.
И тут не все благополучно, поджидают  подводные камни, так как время открытия бара разное на разных тф. на клиринге расходится. Уже молчу про выпадающее бары.
Очереди и двойные очереди в луа, Пример из книги Р.Е.
 
Цитата
Nikolay написал:
Вот простейшая реализация
Алгоритм мне понравился, нужно привыкнуть и погонять, пока смущает сложность,
Вы сами в самом начале писали про надежность.
Я несколько скриптов бросал с хорошими идеями из-за сложности, поиск ошибок занимает значительное время, теперь все упрощаю, что бы было понятно с первого взгляда.
Очереди и двойные очереди в луа, Пример из книги Р.Е.
 
Цитата
Nikolay написал:
Ну так все зависит от задачи. Алгоритм простой. Можно все еще проще сделать. Просто циклом бежать от последнего к первому бару и найти тот, где время входит в бар.
Задачу не очень наверно понятно описываю, попробую по другому.

Так как торговля внутридневная , то анализ делаем дневного бара на истории которую хранит квик.
наименьший день  которую хранит квик будет определять наименьший  тф М1,
так как все тф. меньше дневного входят в него, то прогоняя цену ds[M1]:C(index)  по разным тф. >M1 < D1,
можно оценивать т.входа, т.выхода, стоплосс, такепрофит, оценивать алгоритмы и много чего, с выводом необходимых меток на график.

Как я делал был 1 инструмент, данные читал с графика,
задавал точку входа да и просто циклом пробегал, беря цену закрытия с М1, по свечам допустим Н1, при этом необходимо свечи разных тф синхронизировать(т.е. если если наступил новый час нужно перевести минуту и час)

Писатель с меня еще тот, если что не понятно написал лучше спросите.  
Очереди и двойные очереди в луа, Пример из книги Р.Е.
 
Понятно, написал и забыл не получится покрупней мере у меня :sad:

А что делать с ценной открытия, это даже не техническая ошибка.
Не хочется таких слов произносить, но другие не находятся - это выглядит как "прямая манипуляция рынком".
Но это уже вопрос к разработчикам?
Как такое возможно?
Очереди и двойные очереди в луа, Пример из книги Р.Е.
 
Проба пера, вот время заказа  os.time({hour = 9, min = 00, sec = 0, day = 14, month = 11, year = 2023})

ответ с 4 тайм фреймах
[Tue Nov 14 15:50:16 2023] Trace: Source:  SPBFUT, BRZ3, 1
[Tue Nov 14 15:50:16 2023] Trace: Source:  SPBFUT, BRZ3, 5
[Tue Nov 14 15:50:16 2023] Trace: Source:  SPBFUT, BRZ3, 120
[Tue Nov 14 15:50:16 2023] Trace: Source:  SPBFUT, BRZ3, 1440
[Tue Nov 14 15:50:16 2023] Info: BRZ3; 1; 65537!
[Tue Nov 14 15:50:16 2023] Info: [65537] 14/11/2023; 9:0:0; o[65537]=83.42; h[65537]=83.43; l[65537]=83.33; c[65537]=83.35
[Tue Nov 14 15:50:16 2023] Info: BRZ3; 5; 65537!
[Tue Nov 14 15:50:16 2023] Info: [65537] 14/11/2023; 9:0:0; o[65537]=83.42; h[65537]=83.43; l[65537]=83.33; c[65537]=83.4
[Tue Nov 14 15:50:16 2023] Info: BRZ3; 120; 5516!
[Tue Nov 14 15:50:16 2023] Info: [5516] 14/11/2023; 10:0:0; o[5516]=83.4; h[5516]=83.42; l[5516]=83.03; c[5516]=83.27
[Tue Nov 14 15:50:16 2023] Info: BRZ3; 1440; 1093!
[Tue Nov 14 15:50:16 2023] Info: [1093] 14/11/2023; 0:0:0; o[1093]=83.43; h[1093]=83.43; l[1093]=82.42; c[1093]=82.82


На минутных отрабатывает, на Н2 идет сбой?
Цена открытия сессии
на D1 14/11/2023; 0:0:0; o[1093]=83.43;
на M1 M5  [65537] 14/11/2023; 9:0:0; o[65537]=83.42;
Очереди и двойные очереди в луа, Пример из книги Р.Е.
 
Цитата
Nikolay написал:
Вот простейшая реализация
Не чего себе простейшая? Прокомментируйте пожалуйста ф. обратного вызова. Не понимаю откуда возникают gthtvtyyst bi, ei ?
Очереди и двойные очереди в луа, Пример из книги Р.Е.
 
Nikolay, Спасибо ушел разбираться.
Очереди и двойные очереди в луа, Пример из книги Р.Е.
 
Цитата
В результате этого появилась теория и методы робастного оценивания.
написал: nikolz, Приведите пример.
Цитата
Nikolay написал:
С этим не поспоришь.
Да еще как поспоришь, но речь не об этом. Быть успешным не обязательно быть умным и грамотным :smile:  
Страницы: Пред. 1 ... 8 9 10 11 12 13 14 15 16 17 18 ... 23 След.
Наверх