Русский

Учебник по MQL4  О сложных программах

Общая характеристика сложных программ


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

Порядок исполнения программы


Как правило, в обычной программе основной код сосредоточен в специальной функции start(), запускаемой на исполнение клиентским терминалом. В подавляющем большинстве случаев время исполнения функции start() значительно меньше периода между тиками. Это значит, что большую часть времени программа "простаивает" в ожидании тика. Подобные процессы характеризуются скважностью. Скважность - это отношение периода повторяющегося процесса к длительности самого процесса. Время исполнения специальной функции start() Т1 составляет приблизительно от 10 до 100 миллисекунд, а время Т2 между тиками в среднем равно 5 секундам. Таким образом, работа эксперта характеризуется скважностью, достигающей Т2/Т1=1000 и более (см. Рис. 159). Иными словами, обычный работающий эксперт выполняет полезную работу в течение 0,1% всего времени, а всё остальное время простаивает.

Иногда в эксперте могут выполняться сложные расчёты, в результате чего время исполнения функции start() может быть большим, достигать десятков секунд. В таких случаях start() запускается на исполнение не на каждом тике, а лишь на тех тиках, которые приходят в момент, когда start() находится в режиме ожидания тика. На Рис. 159 показано, что тик, пришедший в период исполнения start(), а именно в момент t 4, не приводит к новому запуску специальной функции, и в следующий раз start() запускается в момент t 5. При этих условиях также возникает пауза между окончанием текущего исполнения и началом следующего исполнения функции start().


Рис. 159 Различная скважность при исполнении функции start(),
запускаемой клиентским терминалом, и зацикленной функции start().

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

//--------------------------------------------------------------------
start() // Специальная функция start()
{
while(!IsStopped()) // До тех пор, пока пользователь..
{ // ..не прекратит исполнение программы
RefreshRates(); // Обновление данных
//......................Здесь указывается основной код программы
Sleep(5); // Небольшая пауза
}
return; // Управление возвращается терминалу
}
//--------------------------------------------------------------------

Весь основной код указывается в теле оператора цикла while, а единственным условием выхода из цикла является получение от клиентского терминала команды на завершение программы. Если функцию start(), построенную на указанном принципе, запустить на исполнение, то она будет исполняться бесконечно долго и вернёт управление клиентскому терминалу только в тот момент, когда пользователь вручную отсоединит программу из окна финансового инструмента или при некоторых других условиях (см. Свойства специальных функций).

Исполнение зацикленной функции start() выполняется непрерывно, поэтому не существует и периода, в течение которого программа находится в режиме ожидания нового тика (см. Рис. 159), поэтому скважность процесса исполнения зацикленной программы равна 1. Функция start(), основанная на указанном принципе, запускается клиентским терминалом на исполнение всего один раз. Это значит, что обновление данных (например, рыночных котировок) необходимо выполнять принудительно, используя функцию RefreshRates(). Для того, чтобы процесс вычислений не потреблял много ресурсов, в конце тела цикла можно указать небольшую паузу.

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

Предоставляемый сервис


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

Если обычная программа может отреагировать на какие-либо события (в том числе, инициируемые пользователем), как правило, при очередном запуске функции start() на ближайшем тике, то зацикленная программа может обрабатывать все события моментально (!). В этом случае задержка может случиться лишь на непродолжительное время, не большее, чем время исполнения одного цикла функции start() (приблизительно не более 10 - 100 мс).

Сложная программа может использовать графические объекты для отображения характеристик ордера или правил его модификации. Например, обычно ордера всех типов отображаются в окне финансового инструмента линиями зелёного цвета, а стоп-приказы - красного цвета. При этом, если на экране одновременно отображается несколько ордеров, то определить зрительно какому ордеру принадлежит та или иная линия бывает затруднительно. Если же на каждую ордерную линию наложить графический объект "горизонтальная линия" нужного цвета и стиля, то отличать ордера и их стоп-приказы станет значительно удобнее.

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

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

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

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

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

Автоматический и ручной режимы работы программы


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

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

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

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


Все указанные свойства программы можно реализовать на основе языка программирования MQL4, специально предназначенного для этой цели. Правильно составленная сложная программа обладает рядом неоспоримых достоинств, к которым трейдер легко привыкает и стремится использовать в торговле.