Мультитаймфреймовые индикаторы - страница 276

 

демаркер mtf

у кого-нибудь есть работающий индикатор mtf demarker?

спасибо

 
jackt:
у кого-нибудь есть работающий индикатор mtf demarker? спасибо.

Вы можете попробовать эту версию, работает со стандартным DeMarker.

Файлы:
 
matfx:
Вы можете попробовать эту версию, работает со стандартным DeMarker.

не работает. я поставил 2 mtf демаркера на график h4. настройки период 2, tf 1440 и период 3, tf 1440. оба показывают один и тот же график.

 

демаркер с сигнализацией

привет:

Я использую вчера индикатор demarker, это здорово!

можно ли сделать этот индикатор с сигнализацией?

например:

если MTF_Demarker (0) > 0.7 и MTF_Demarker(15)>0.7 ПОКУПАТЬ и сигнализация

если MTF_Demarker (0) < 0.3 и MTF_Demarker(15)<0.3 ПРОДАВАТЬ и сигнализировать.

заранее спасибо!

 

Создание индикаторов MTF

Мне интересно, может ли кто-нибудь показать мне, как сделать индикаторы MTF. Я могу делать базовое кодирование, но не знаю, как преобразовать стандартный индикатор в MTF. У меня есть куча всего, что я хочу сделать, и я хочу научиться делать это сам. Заранее спасибо.

EDIT: Неважно. Разобрался.

 
jturns23:
Я хотел бы узнать, может ли кто-нибудь показать мне, как сделать индикаторы MTF. Я могу делать базовое кодирование, но не знаю, как преобразовать стандартный индикатор в MTF. У меня есть куча всего, что я хочу сделать, и я хочу научиться делать это сам. Заранее спасибо. EDIT: Не важно. Разобрался.

Начните с чтения первых сообщений. Там все легко объясняется.

 

Mtf_wpr

я тестирую свою систему с помощью индикатора MTF_WPR, он очень полезен.

Кто-нибудь может прикрепить сигнализацию к этому индикатору?

например:

если MTF_WPR(tf=0)>-20 & MTF_WPR(tf=15)>-20 то ПОКУПАТЬ &ALARM

если MTF_WPR(tf=0)<-80 & MTF_WPR(tf=15)<-80 то ПРОДАВАТЬ &ALARM

thx

 
matfx:
Вы можете попробовать эту версию, работает со стандартным DeMarker.
jackt:
не работает. я поставил 2 mtf демаркера на график h4. настройки период 2, tf 1440 и период 3, tf 1440. оба показывают один и тот же график.

в MTF DeMarker.mq4 (3.0 KB) просто добавьте управление периодом в строке83:

ExtDeMarkerMapBuffer=iCustom(NULL,TimeFrame, "DeMarker",ExtDeMarkerPeriod,0,y);

Файлы:
 
fxbs:
в MTF DeMarker.mq4 (3.0 KB) просто добавьте контроль периода в строке83: ExtDeMarkerMapBuffer=iCustom(NULL,TimeFrame, "DeMarker",ExtDeMarkerPeriod,0,y);

спасибо большое. все работает!!!

 

Есть идеи, почему не обновляется?

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

Этот инди называется QQE_Alert_MTF_v5a - это MTF QQE. Он не обновляется. Я пробовал мод Period (), чтобы заставить его обновляться, но безуспешно. Если вы поместите его на 1-минутный график и установите индикатор на 15 минут, дайте ему поработать некоторое время, вы увидите, что произойдет.

Мне пришлось сократить инди, потому что я превысил лимит символов FXTSDMB. Вторая часть будет в следующем ответе.

Прошу прощения за то, что усложнил задачу. Спасибо.

QQE_Alert_MTF_v5a

#property indicator_separate_window

#property indicator_levelcolor Red

#property indicator_levelstyle 0

#property indicator_buffers 3

#property indicator_color1 Blue

#property indicator_color2 CLR_NONE

#property indicator_color3 Black

#property indicator_width1 2

#property indicator_level1 50.0

double g_ibuf_76[];

double g_ibuf_80[];

double g_ibuf_84[];

double g_ibuf_88[];

double g_ibuf_92[];

double g_ibuf_96[];

double g_ibuf_100[];

double g_ibuf_104[];

extern int Smoothing = 5;

extern int TimeFrame = 0;

extern string ALERTS = "------------------------------------------------------";

extern bool CrossFiftyAlert = FALSE;

extern bool CrossFiftyEmail = FALSE;

extern bool CrossLineAlert = FALSE;

extern bool CrossLineEmail = FALSE;

extern bool BothAlert = FALSE;

extern bool BothEmail = FALSE;

extern string MESSAGES = "------------------------------------------------------";

extern string FiftyUpMessage = "QQE пересек 50 линию вверх !!!";

extern string FiftyDownMessage = "QQE пересек 50 линию ВНИЗ !!!";

extern string QQECrossUpMessage = "Линии QQE пересеклись вверх !!!";

extern string QQECrossDownMessage = "Линии QQE пересеклись ВНИЗ !!!";

extern string BothUpMessage = "Линии QQE пересечены, а линия 50 пробита вверх !!!";

extern string BothDownMessage = "Линии QQE пересекаются и 50 линия сломана ВНИЗ !!!";

extern string SOUNDS = "------------------------------------------------------";

extern string FiftyUpSound = "alert.wav";

extern string FiftyDownSound = "alert.wav";

extern string QQECrossUpSound = "alert.wav";

extern string QQECrossDownSound = "alert.wav";

extern string BothUpSound = "alert.wav";

extern string BothDownSound = "alert.wav";

extern string DOT_VISIBILITY = "------------------------------------------------------";

extern bool FiftyUpDot = FALSE;

extern bool FiftyDownDot = FALSE;

extern bool QQECrossUpDot = FALSE;

extern bool QQECrossDownDot = FALSE;

extern bool BothUpDot = FALSE;

extern bool BothDownDot = FALSE;

extern string DOT_COLORS = "------------------------------------------------------";

extern color FiftyUpColor = DodgerBlue;

extern color FiftyDownColor = Crimson;

extern color QQECrossUpColor = Teal;

extern color QQECrossDownColor = Розовый;

extern color BothUpColor = Синий;

extern color BothDownColor = Red;

extern string DOT_DISTANCE = "------------------------------------------------------";

extern int Distance = 30;

int gi_unused_336 = 0;

int gi_unused_340 = 0;

int gi_344 = 0;

int init() {

string ls_unused_8;

string ls_20;

IndicatorBuffers(8);

SetIndexBuffer(0, g_ibuf_80);

SetIndexBuffer(1, g_ibuf_84);

SetIndexBuffer(2, g_ibuf_88);

SetIndexBuffer(3, g_ibuf_76);

SetIndexBuffer(4, g_ibuf_92);

SetIndexBuffer(5, g_ibuf_96);

SetIndexBuffer(6, g_ibuf_100);

SetIndexBuffer(7, g_ibuf_104);

switch (TimeFrame) {

case 1:

ls_20 = "Period_M1";

break;

case 5:

ls_20 = "Period_M5";

break;

случай 15:

ls_20 = "Период_M15";

break;

case 30:

ls_20 = "Период_М30";

break;

case 60:

ls_20 = "Период_H1";

break;

case 240:

ls_20 = "Period_H4";

break;

case 1440:

ls_20 = "Period_D1";

break;

case 10080:

ls_20 = "Period_W1";

break;

case 43200:

ls_20 = "Period_MN1";

break;

default:

ls_20 ="Текущий таймфрейм";

}

MathSrand(TimeLocal());

string ls_0 = "QQE " + ls_20;

IndicatorShortName(ls_0);

return (0);

}

int deinit() {

string l_name_4;

for (int li_0 = 32768; li_0 > 0; li_0--) {

l_name_4 = "QQE-" + li_0;

ObjectDelete(l_name_4);

}

return (0);

}

int start() {

int lia_20[];

double ld_28;

double ld_36;

int li_44;

string l_name_48;

int li_0 = IndicatorCounted();

if (li_0 < 0) return (-1);

if (li_0 > 0) li_0--;

int li_24 = Bars - li_0;

int li_unused_12 = Smoothing;

ArrayCopySeries(lia_20, 5, Symbol(), TimeFrame);

int li_4 = 0;

int li_8 = 0;

while (li_4 < li_24) {

if (Time[li_4] < lia_20[li_8]) li_8++;

g_ibuf_76[li_4] = iRSI(NULL, TimeFrame, 14, PRICE_CLOSE, li_8);

li_4++;

}

li_4 = 0;

li_8 = 0;

while (li_4 < li_24) {

if (Time[li_4] < lia_20[li_8]) li_8++;

g_ibuf_80[li_8] = iMAOnArray(g_ibuf_76, 0, Smoothing, 0, MODE_EMA, li_8);

li_4++;

}

for (li_4 = 0; li_4 < li_24; li_4++) {

ld_28 = MathMax(g_ibuf_80[li_4 + 1], g_ibuf_80[li_4]);

ld_36 = MathMin(g_ibuf_80[li_4 + 1], g_ibuf_80[li_4]);

g_ibuf_96[li_4] = ld_28 - ld_36;

}

for (li_4 = 0; li_4 < li_24; li_4++) g_ibuf_92[li_4] = iMAOnArray(g_ibuf_96, 0, 27, 0, MODE_EMA, li_4);

for (li_4 = 0; li_4 < li_24; li_4++) g_ibuf_100[li_4] = 2.618 * iMAOnArray(g_ibuf_92, 0, 27, 0, MODE_EMA, li_4);

for (li_4 = li_24; li_4 >= 0; li_4--) {

if (g_ibuf_80[li_4] == g_ibuf_84[li_4 + 1]) g_ibuf_84[li_4] = g_ibuf_80[li_4];

иначе {

if (g_ibuf_80[li_4 + 1] < g_ibuf_84[li_4 + 1] && g_ibuf_80[li_4] < g_ibuf_84[li_4 + 1]) g_ibuf_84[li_4] = MathMin(g_ibuf_84[li_4 + 1], g_ibuf_80[li_4] + g_ibuf_100[li_4]);

else {

if (g_ibuf_80[li_4 + 1] > g_ibuf_84[li_4 + 1] && g_ibuf_80[li_4] > g_ibuf_84[li_4 + 1]) g_ibuf_84[li_4] = MathMax(g_ibuf_84[li_4 + 1], g_ibuf_80[li_4] - g_ibuf_100[li_4]);

else {

if (g_ibuf_80[li_4] > g_ibuf_84[li_4 + 1]) g_ibuf_84[li_4] = g_ibuf_80[li_4] - g_ibuf_100[li_4];

else g_ibuf_84[li_4] = g_ibuf_80[li_4] + g_ibuf_100[li_4];

}

}

}

}

for (li_4 = 0; li_4 < li_24; li_4++) g_ibuf_104[li_4] = 4.236 * iMAOnArray(g_ibuf_92, 0, 27, 0, MODE_EMA, li_4);

for (li_4 = li_24; li_4 >= 0; li_4--) {

if (g_ibuf_80[li_4] == g_ibuf_88[li_4 + 1]) g_ibuf_88[li_4] = g_ibuf_80[li_4];

иначе {

if (g_ibuf_80[li_4 + 1] < g_ibuf_88[li_4 + 1] && g_ibuf_80[li_4] < g_ibuf_88[li_4 + 1]) g_ibuf_88[li_4] = MathMin(g_ibuf_88[li_4 + 1], g_ibuf_80[li_4] + g_ibuf_104[li_4]);

else {

if (g_ibuf_80[li_4 + 1] > g_ibuf_88[li_4 + 1] && g_ibuf_80[li_4] > g_ibuf_88[li_4 + 1]) g_ibuf_88[li_4] = MathMax(g_ibuf_88[li_4 + 1], g_ibuf_80[li_4] - g_ibuf_104[li_4]);

else {

if (g_ibuf_80[li_4] > g_ibuf_88[li_4 + 1]) g_ibuf_88[li_4] = g_ibuf_80[li_4] - g_ibuf_104[li_4];

else g_ibuf_88[li_4] = g_ibuf_80[li_4] + g_ibuf_104[li_4];

}

}

}

}

if (gi_344 == Time[0]) return (0);

for (li_4 = li_24 - 1; li_4 >= 0; li_4--) {

if (g_ibuf_80[li_4 + 1] > 50.0 && g_ibuf_80[li_4 + 2] <= 50.0 && FiftyUpDot) {

li_44 = MathRand() + 1;

l_name_48 = "QQE-" + li_44;

ObjectCreate(l_name_48, OBJ_ARROW, 0, Time[li_4], Low[li_4] - Distance * Point);

ObjectSet(l_name_48, OBJPROP_COLOR, FiftyUpColor);

ObjectSet(l_name_48, OBJPROP_ARROWCODE, 108);

Причина обращения: