MQL4 - automated forex trading   /  

Code Base

Code Base  Индикаторы  Предсказатель на основе самообучающейся нейронной сети Авторизуйтесь или зарегистрируйтесь, чтобы добавить новый код


Скачай MetaTrader 5 и посети MQL5.community Code Base
и торгуй мобильно!
Библиотека программ на новом MQL5
Готовься к Чемпионату -
Не нашёл подходящий код? Закажи его в разделе Работа

Этот скрипт для
MetaTrader 4

и торгуй мобильно!

Имя:
Предсказатель на основе самообучающейся нейронной сети
Автор: gpwr (16.06.2009 10:19)
Рейтинг: 6.9
Скачано: 7580
Скачать:
 BPNN.zip (5.5 Kb)
 BPNN Predictor.mq4 (9.5 Kb) View
 BPNN Predictor with Smoothing.mq4 (9.9 Kb) View
 BPNN.dll (87.5 Kb)

Автор:

gpwr

История версий:

16/06/2009 - в индикаторы BPNN Predictor.mq4 и Buy-Sell Classificator.mq4 добавлены проверки на появление нового бара чтобы тиковое обновление on-line графиков не перезапускало вычисления. Добавлен новый BPNN.zip файл содержащий недостающие системные DLL файлы.

17/06/2009 - добавлена проверка на скорость уменьшения ошибки в BPNN.cpp существенно увиличивающаяся скорость вычислений. Приложены новые файлы BPNN.zip и BPNN.dll.

24/06/2009

  • файл BPNN.dll скомпилирован таким образом что он теперь включает все необходимые системные функции
  • добавлены две новые функции активации нейронов: tanh и рациональная
  • удалена проверка на скорость уменьшения ошибки в BPNN.cpp
  • встроен новый, более надёжный алгоритм обучения iRProp+
  • Старые файлы индикаторов не будут работать с новым BPNN.dll
  • удалён Buy-Sell Classificator.mq4 так как он пока не работает. Он может появиться снова здесь как только я доведу его до ума.
24/06/2009

- добавлен новый индикатор BPNN Predictor with Smoothing.mq, который до предсказания цен сглаживает их скользящей средней

20/08/2009 - исправлен код вычисления функции активации нейрона чтобы предотвратить зашкаливание. Обновлены файлы BPNN.dll и BPNN.cpp.

21/08/2009 - добавлена очистка памяти. Обновлены файлы BPNN.dll и BPNN.cpp.

Описание теории:

Предлагается индикатор использующий нейронную сеть прямого распространения (feedforward neural network), которая самообучается методом Обратного Распространения Ошибки (backpropagation). Сеть загружается через DLL файл, исходный C++ код которого прилагается.

Нейронная сеть это ничто иное как нелинейная модель выходов как функция входов. На входы подаются данные задаваемые пользователем, например выборки временного ряда. Смысл выходных данных также задаётся пользователем, например сигналы 1=buy/0=sell. Структура сети опять же задаётся пользователем. Сеть прямого распространения состоит из

-входного слоя (input layer), элементами которого являются входные данные,

- скрытых слоёв (hidden layers), состоящих из вычислительных узлов называемых нейронами (neurons) и

- выходного слоя (output layer), который состоит из одного или нескольких нейронов, выходы которых являются выходами всей сети.

Все узлы соседних слоёв связаны между собой. Эти связи называются синапсами (synapses). Каждый синапс имеет вес (weight w[i,j,k]), на которой умножаются данные передаваемые по синапсу. Данные передвигается слева направа т.е. от входов сети к её выходам. Отсюда и название, "сеть прямого распространения". Общий пример этой сети изображён на рисунке внизу

Данные перерабатываются нейронами за два шага:

1. Все входы, помноженные на соответствующие веса, сначала суммируются

2. Затем получившиеся суммы обрабатываются функцией активации нейрона (activation or firing function) и посылаются на единственный выход.

Смысл функции активации нейрона заключается в моделировании работы нейрона мозга: нейрон срабатывает только после того как информация достигла определённого порога. В математическом аспекте, эта функция как раз и придаёт нелинейность сети. Без неё, нейронная сеть была бы линейной авторегрессионной моделью (linear prediction model). В прилагаемых библиотечных функциях возможен выбор трёх функций активации нейрона

  • сигмоидальная функция sigm(x)=1/(1+exp(-x)) (#0)
  • гиперболический тангенс tanh(x)=(1-exp(-2x))/(1+exp(-2x)) (#1)
  • рациональная функция x/(1+|x|) (#2)


Порог активации этих функций равен 0. Этот порог может быть сдвинут по горизонтальной оси за счёт дополнительного входа нейрона называемом входом смещения (bias input), которому приписан определённый вес таким же образом как и к другим входам нейрона.

Таким образом, количество входов, слоев, нейронов в каждом слою и веса входов нейронов полностью определяют нейронную сеть, т.е. нелинейную модель, которую она создаёт. Чтобы пользоваться этой моделью необходимо знать веса. Веса вычисляются путём обучения сети на прошлых данных: на входы сети подаются нескольков наборов входных и соответствующих выходных данных и рассчитывается среднеквадратичная ошибка отклонения выхода сети от тестируемого. Цель обучения сети заключается в уменьшении этой ошибки путём оптимизации весов. Существуют несколько методов оптимизации, среди которых основными эвляются метод Обратного Распространения Ошибки (ОРО) и метод генетической оптимизации. Метод ОРО является пу существу методом градиентного спуска и вкратце опиан здесь

ru.wikipedia.org/wiki/Метод_обратного_распространения_ошибки

В прилагаемой функции Train() используется разновидонсть метода ОРО называемая "Улучшенный Эластичный метод ОРО" (Improved Resilient back-Propagation, IRProp). Этот алгоритм описан здесь

http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.17.1332

Прилагаемые файлы:

  • BPNN.dll - библиотечный файл
  • BPNN.zip - архив всех файлов необходимых для создания ДЛЛ файла
  • BPNN Predictor.mq4 - индикатор предсказывающий будущее значение цены
  • BPNN Predictor with Smoothing.mq4 - индикатор предсказывающий будущее значение цены, сглаженной ЕМА

Библиотечный файл BPNN.cpp содержит две функции: Train() и Test(). Train() предназначен для обучения сети для предоставленных входных и выходных данных. Test() предназначен для вычисления выходных данных на основе весов полученных после прогона Train().

Входными (зелёный цвет) и выходными (синий цвет) параметрами функции Train() являются:

double inpTrain[] - обучивающие входные данные (старый первый)
double outTarget[] - обучивающие выходные данные (старый первый)
double outTrain[] - выходы сети после обучения
int ntr - количество обучающих наборов входы-выходы
int UEW - ключ управляющий использованием внешних значений для инициализации весов (1=используем extInitWt[], 0=используем случайные числа)
double extInitWt[] - исходные значения весов
double trainedWt[] - значения весов после обучения
int numLayers - количество слоев в сети включая входной, скрытые и выходной
int lSz[] - одомерный массив размера numLayers, в котором хранятся количества нейронов в каждом слою. lSz[0] задаёт количество входов сети
int AFT - тип функции активации (0-сигмоидальная, 1-гиперболический тангенс, 2-рациональная)
int OAF - ключ использования функции активации в выходны нейронах (1=используем функцию активации, 0=нет)
int nep - максимальное количество обучающих шагов (эпох). Эпоха состоит из проверки всех обучающих наборов.
double maxMSE - среднеквадратичная ошибка, при которой обучения останавливается.

Входными (зелёный цвет) и выходными (синий цвет) параметрами функции Test() являются:

double inpTest[] - входные данные (старый первый)
double outTest[] - выходные данные

int ntt - колчиство наборов в входных и выходных данных
double extInitWt[] - исходные значения весов
int numLayers - количество слоев в сети включая входной, скрытые и выходной
int lSz[] - одомерный массив размера numLayers, в котором хранятся количества нейронов в каждом слою. lSz[0] задаёт количество входов сети
int AFT -
тип функции активации (0-сигмоидальная, 1-гиперболический тангенс, 2-рациональная)
int OAF - ключ использования функции активации в выходны нейронах (1=используем функцию активации, 0=нет)

Использование функции активации в выходных нейронах зависит от характера выходны данных. Если выходами сети являются биноминальные сигналы (0/1 или -1/1), то нужно использовать функцию активации (OAF=1). Причём учтите что для функции №0, уровни сигнала 0 и 1, а для функций №1 и 2 уровни -1 и 1. Если выходом сети является предсказание цены, то функция активации в выходном слое не нужна (OAF=0).

Примеры индикаторов использующих нейронную сеть:

BPNN Predictor.mq4 - предсказывает будущие цены. Входными параметрами сети являются относительные приращения цен:

x[i]=Open[test_bar]/Open[test_bar+delay[i]]-1.0

где delay[i] берётся из ряда Фибоначи. Выходом сети является предсказываемое относительное приращение будущей цены. Фунцкия активации в выходном слое отключена.

Входными параметрами индикатора являются

extern int lastBar - номер последнего бара
extern int futBars - количество будущих предсказываемых баров
extern int numLayers - количество слоев в сети включая входной, скрытые и выходной
extern int numInputs - количество входов сети
extern int numNeurons1 - количество нейронов в слое №1
extern int numNeurons2 - количество нейронов в слое №2
extern int numNeurons3
extern int numNeurons4
extern int numNeurons5
extern int ntr - количество обучающих наборов входы-выходы
extern int nep - максимальное количество обучающих шагов (эпох)
extern int maxMSEpwr - экспонента используемая для расчёта максимальной допустимой среднеквадратической ошибки обучения maxMSE=10^maxMSEpwr
extern int AFT -
тип функции активации (0-сигмоидальная, 1-гиперболический тангенс, 2-рациональная)

Индикатор выдаёт такую картинку, где

  • красный цвет - предсказания от последней цены Open
  • чёрный цвет - прошлые тренировочные цены Open, по котором (как ожидаемым выходным данным) проводилось обучение сети
  • синий цвет - выходы обученной сети на тренировочных данных

BPNN Predictor with Smoothing.mq4 - тоже предсказывает цены, но с предварительным сглаживанием цен экспоненциальной скользящей средней (EMA) с периодом smoothPer.


Установка файлов:

  1. Копируйте приложенный BPNN.DLL файл в C:\Program Files\MetaTrader 4\experts\libraries
  2. Включайте использование DLL в метатрейдере: Tools - Options - Expert Advisors - Allow DLL imports

Если приложенный DLL файл не работает, то компилируйте сами. Все необходимые файлы содержатся в BPNN.zip.

Советы:

  • Сеть с 3-ми слоями (numLayers=3: один входной, один скрытый и один выходной) достаточна для подавляющего большинства применений. По теоремe Cybenko (1989) сеть с одним скрытым слоем может моделировать любую непрерывную нелинейную фунцкию и сеть с двумя скрытыми слоями способна описать функцию с разрывами (http://en.wikipedia.org/wiki/Cybenko_theorem):

  • Количество нейронов в скрытом слую определяйте экспериментально. В литературе встречаются такие рекомендации: кол-во скрытых нейронов = (кол-во входов + кол-во выходов)/2, либо SQRT(кол-во входов * кол-во выходов). Следите за сообщениями о среднеквадратичной ошибки обучения в окне experts метатрейдера.
  • Для получения хорошего обобщения, количество обучающих выборок должно в 2-3 раза превышать количество оптимизируемых весов. Например, в опубликованных примерах, количество весов равно (12+1)*5 на входах скрытого слоя плюс (5+1) на входах выходоного слоя, т.е. 71. Поэтому количество обучающих выборок должно быть по крайней мере 142. Концепт обобщения объяснён на рисунке внизу для одномерного случая y(x).
  • Увеличения количества обучающих эпох может не повысить точность предсказаний на тестируемых данных даже если ошибка обучения (MSE) уменьшилась. При большом количестве весов сеть становится переученной (см объяснения внизу).
  • Входные данные должны преобразоваться в стационарный ряд. Цены сами по себе таковым рядом не являются. Рекомендуется также нормализовывать входные данные к диапазону -1..1.

На этом графике показана линейная функция y=b*x (x-вход, y-выход) с добавленным шумом к выходам. Из-за этого шума, измерения функции (чёрные точки) не лежат на прямой. Функция y=f(x) может быть смоделирована нейронной сетью. Сеть с большим количеством весов (степеней свободы) способна уменьшить ошибку обучения по всем имеюшимся измерениям до нуля и описать тренировочные выходные данные плавной кривой. Но эта кривая (показана красным цветом) не имеет ничего общего с нашей линейной фунцкией y=b*x (показана зелёным цветом). Использование такой сети для предсказания будущих значений функции y при новых входных значениях x приведёт к большим ошибкам так как шум не предсказуем.


Уважительная Просьба: eсли вам удастся создать прибыльный советник на основе этих файлов, пожалуйста поделитесь идеей в личку или vlad1004@yahoo.com.

109 комментариев: 1 2 3 4 5 6 7 8 9 10 11   Авторизуйтесь или зарегистрируйтесь, чтобы добавить новый комментарий

Здравствуйте!

Кто нибудь может подсказать по какой причине с вложенной DLL работает, а с созданной из приложенного кода не работает?

Может кто имеет код С++ из которого был создан этот DLL?

Заранее благодарю!!!

20.03.2012 14:36 liza

Здравствуйте!

Если кто знает как откомрелировать fann?

Пробовала при помощи Visual C+++ нет щгксу ашдуы

20.10.2011 11:46 liza
Очень интересно.сейчас пытаюсь написать советник на этом индикаторе.Если получится - попробую опубликовать.
11.07.2011 15:26 Segun1966
Очень нестабильные прогнозы получаются. Если открыть свойства индикатора и НЕ меняя ничего нажать ОК - результат перерисовывается. Например продолжение тренда может смениться резким разворотом! И это даже при большой обучающей выборке и итерациях обучения.
10.03.2011 13:18 Demonzero
Ставлю оценку 5 за перегруз мозга. Но нехрена не понятно.
24.11.2010 20:22 Anton1
Спасибо за такую работу!
07.10.2010 16:05 Noterday
Поскольку мне продолжают регулярно приходить просьбы о публикации подправленной версии BPNN.dll, а прикрепить ей здесь нельзя, сделал отдельный топик на форуме - http://forum.mql4.com/ru/35699.
05.10.2010 11:44 marketeer

ну и народ у нас... заколебал уже с вопросами... как запустить. Я час пое... и сделал. ... А теперь еще народу настройки подавай... да такие, что бы деньги гребсти. 

gpwr Мне Вас жаль... Вы выложили такую громадную работу...  А в конце остались непонятым и неуслышанным. Спасибо за Ваш великий труд. Может когда нибудь сюда зайдет человек которого Вы ждали, что бы продолжить Ваше начинание. 

07.08.2010 20:05 vldim

Подскажите, пожалуйста!!! Я чего-то не догоняю!!! Как правильно пользоваться индикатором. если он перерисовывается?! Поделитесь параметрами индикатора, если кто менял или оптимизировал!!! Заранее благодарю!!!


26.02.2010 15:31 yusis
val77 писал(а):

Original'naja DLL privodila k oshibke i terminal samoproizvol'no zakanchval raboty. :-(

Ja perecompiliroval v Embarcadero RAD 2010 C++ Builder.

1. Uchel ispravlenija kotorye privedeny zdes'.

2. Zamenil funkcii sprintf_s(..) na sprintf(..)

3. Takzhe izmenil stroky v stdafx.h file vot tak:

#define MT4_EXPFUNC extern "C" __declspec(dllexport)

Poprobujte - mozhet zarabotaet....

Valera

A kak dobavit' faily? Podskazhite....


21.02.2010 19:08 val77