Startseite Technischer Indikator Beitrag

Harami_Alert – Der Indikator für MetaTrader 5 zur Erkennung von Harami-Mustern

Anhang
22403.zip (3.69 KB, Herunterladen 0 mal)

Autor:

Paul Stringer

Dieser Indikator erkennt Harami-Muster und bietet Benachrichtigungen, E-Mails und Push-Nachrichten.

Um die Benachrichtigungen, E-Mail-Nachrichten und Push-Benachrichtigungen zu implementieren, wurden folgende Änderungen am Indikatorcode vorgenommen:

  1. Neue Eingabeparameter hinzugefügt:
    input uint NumberofBar=1;//Bar-Nummer für das Signal
    input bool SoundON=true; //Benachrichtigungen aktivieren
    input uint NumberofAlerts=2;//Anzahl der Benachrichtigungen
    input bool EMailON=false; //E-Mail für das Signal aktivieren
    input bool PushON=false; //Push-Benachrichtigung auf mobile Geräte aktivieren
    
  2. Drei neue Funktionen am Ende des Indikatorcodes hinzugefügt: BuySignal(), SellSignal() und GetStringTimeframe()
    //+------------------------------------------------------------------+
    //| Funktion für Kaufsignal                                              |
    //+------------------------------------------------------------------+
    void BuySignal(string SignalSirname,      // Text des Indikators für E-Mail- und Push-Nachrichten
                   double &BuyArrow[],        // Indikator-Puffer für Kaufsignale
                   const int Rates_total,     // aktuelle Anzahl der Kerzen
                   const int Prev_calculated, // Anzahl der Kerzen im vorherigen Tick
                   const double &Close[],     // Schlusskurs
                   const int &Spread[])       // Spread
      {
    //---
       static uint counter=0;
       if(Rates_total!=Prev_calculated) counter=0;
    
       bool BuySignal=false;
       bool SeriesTest=ArrayGetAsSeries(BuyArrow);
       int index;
       if(SeriesTest) index=int(NumberofBar);
       else index=Rates_total-int(NumberofBar)-1;
       if(NormalizeDouble(BuyArrow[index],_Digits) && BuyArrow[index]!=EMPTY_VALUE) BuySignal=true;
       if(BuySignal && counter<=NumberofAlerts)
         {
          counter++;
          MqlDateTime tm;
          TimeToStruct(TimeCurrent(),tm);
          string text=TimeToString(TimeCurrent(),TIME_DATE)+" "+string(tm.hour)+":"+string(tm.min);
          SeriesTest=ArrayGetAsSeries(Close);
          if(SeriesTest) index=int(NumberofBar);
          else index=Rates_total-int(NumberofBar)-1;
          double Ask=Close[index];
          double Bid=Close[index];
          SeriesTest=ArrayGetAsSeries(Spread);
          if(SeriesTest) index=int(NumberofBar);
          else index=Rates_total-int(NumberofBar)-1;
          Bid+=Spread[index]*_Point;
          string sAsk=DoubleToString(Ask,_Digits);
          string sBid=DoubleToString(Bid,_Digits);
          string sPeriod=GetStringTimeframe(ChartPeriod());
          if(SoundON) Alert("KAUFSIGNAL 
     Ask=",Ask,"
     Bid=",Bid,"
     currtime=",text,"
     Symbol=",Symbol()," Period=",sPeriod);
          if(EMailON) SendMail(SignalSirname+": KAUFSIGNAL-Benachrichtigung","KAUFSIGNAL bei Ask="+sAsk+", Bid="+sBid+", Datum="+text+" Symbol="+Symbol()+" Period="+sPeriod);
          if(PushON) SendNotification(SignalSirname+": KAUFSIGNAL bei Ask="+sAsk+", Bid="+sBid+", Datum="+text+" Symbol="+Symbol()+" Period="+sPeriod);
         }
    
    //---
      }
    //+------------------------------------------------------------------+
    //| Funktion für Verkaufssignal                                             |
    //+------------------------------------------------------------------+
    void SellSignal(string SignalSirname,      // Text des Indikators für E-Mail- und Push-Nachrichten
                    double &SellArrow[],       // Indikator-Puffer für Verkaufssignale
                    const int Rates_total,     // aktuelle Anzahl der Kerzen
                    const int Prev_calculated, // Anzahl der Kerzen im vorherigen Tick
                    const double &Close[],     // Schlusskurs
                    const int &Spread[])       // Spread
      {
    //---
       static uint counter=0;
       if(Rates_total!=Prev_calculated) counter=0;
    
       bool SellSignal=false;
       bool SeriesTest=ArrayGetAsSeries(SellArrow);
       int index;
       if(SeriesTest) index=int(NumberofBar);
       else index=Rates_total-int(NumberofBar)-1;
       if(NormalizeDouble(SellArrow[index],_Digits) && SellArrow[index]!=EMPTY_VALUE) SellSignal=true;
       if(SellSignal && counter<=NumberofAlerts)
         {
          counter++;
          MqlDateTime tm;
          TimeToStruct(TimeCurrent(),tm);
          string text=TimeToString(TimeCurrent(),TIME_DATE)+" "+string(tm.hour)+":"+string(tm.min);
          SeriesTest=ArrayGetAsSeries(Close);
          if(SeriesTest) index=int(NumberofBar);
          else index=Rates_total-int(NumberofBar)-1;
          double Ask=Close[index];
          double Bid=Close[index];
          SeriesTest=ArrayGetAsSeries(Spread);
          if(SeriesTest) index=int(NumberofBar);
          else index=Rates_total-int(NumberofBar)-1;
          Bid+=Spread[index]*_Point;
          string sAsk=DoubleToString(Ask,_Digits);
          string sBid=DoubleToString(Bid,_Digits);
          string sPeriod=GetStringTimeframe(ChartPeriod());
          if(SoundON) Alert("VERKAUFSSIGNAL 
     Ask=",Ask,"
     Bid=",Bid,"
     currtime=",text,"
     Symbol=",Symbol()," Period=",sPeriod);
          if(EMailON) SendMail(SignalSirname+": VERKAUFSIGNAL-Benachrichtigung","VERKAUFSIGNAL bei Ask="+sAsk+", Bid="+sBid+", Datum="+text+" Symbol="+Symbol()+" Period="+sPeriod);
          if(PushON) SendNotification(SignalSirname+": VERKAUFSIGNAL bei Ask="+sAsk+", Bid="+sBid+", Datum="+text+" Symbol="+Symbol()+" Period="+sPeriod);
         }
    //---
      }
    //+------------------------------------------------------------------+
    //|  Ermitteln des Zeitrahmens als String                               |
    //+------------------------------------------------------------------+
    string GetStringTimeframe(ENUM_TIMEFRAMES timeframe)
      {
    //----
       return(StringSubstr(EnumToString(timeframe),7,-1));
    //----
      }
    


  3. Ein paar Aufrufe der Funktionen BuySignal() und SellSignal() nach den Berechnungszyklen des Indikators im OnCalculate()-Block hinzugefügt:
    //---     
       BuySignal("Harami_Alert",BuyBuffer,rates_total,prev_calculated,close,spread);
       SellSignal("Harami_Alert",SellBuffer,rates_total,prev_calculated,close,spread);
    //---   
    

Die Variablen BuyBuffer und SellBuffer sind die Namen der Indikator-Puffer, die die Kauf- und Verkaufssignale speichern. Die leeren Werte in den Indikator-Puffern sollten entweder Null oder EMPTY_VALUE sein.

Es wird davon ausgegangen, dass nur ein Aufruf der Funktionen BuySignal() und SellSignal() im OnCalculate()-Block des Indikatorcodes verwendet wird.

Ursprünglich wurde dieser Indikator in MQL4 geschrieben und erstmals am Code Base am 14.06.2016 veröffentlicht.

Fig. 1. Harami_Alert Indikator im Chart

Fig. 1. Harami_Alert Indikator im Chart


Fig. 2. Harami_Alert. Erzeugung von Benachrichtigungen

Fig. 2. Harami_Alert. Erzeugung von Benachrichtigungen

Verwandte Beiträge

Kommentar (0)