Мультитаймфреймовые индикаторы - страница 276
Вы упускаете торговые возможности:
- Бесплатные приложения для трейдинга
- 8 000+ сигналов для копирования
- Экономические новости для анализа финансовых рынков
Регистрация
Вход
Вы принимаете политику сайта и условия использования
Если у вас нет учетной записи, зарегистрируйтесь
демаркер mtf
у кого-нибудь есть работающий индикатор mtf demarker?
спасибо
у кого-нибудь есть работающий индикатор mtf demarker? спасибо.
Вы можете попробовать эту версию, работает со стандартным DeMarker.
Вы можете попробовать эту версию, работает со стандартным 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: Неважно. Разобрался.
Я хотел бы узнать, может ли кто-нибудь показать мне, как сделать индикаторы 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
Вы можете попробовать эту версию, работает со стандартным DeMarker.
не работает. я поставил 2 mtf демаркера на график h4. настройки период 2, tf 1440 и период 3, tf 1440. оба показывают один и тот же график.
в MTF DeMarker.mq4 (3.0 KB) просто добавьте управление периодом в строке83:
ExtDeMarkerMapBuffer=iCustom(NULL,TimeFrame, "DeMarker",ExtDeMarkerPeriod,0,y);
в 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);