Problemchen (Kreuzung MAs)
Liste der Anhänge anzeigen (Anzahl: 2)
Hallo,
eine kurze Frage zu meinem programmierten EA. Es geht um die Kreuzung von e MAs. Der EA funtioniert und läuft - allerdings wirft die Kontrolle auf dem Diagramm Fragen auf. Manchmal wird richtig buy/sell gesetzt und manchmal nicht (siehe Bild). #13 wird buy geordert, obwohl sell geordert werden müsste. Und bei #11 ist es auch fehlerhaft. Ich habe erst angefangen mit mql - vielleicht kann mir ja einer helfen. Die Abfrage ist eigentlich korrekt: // Buy Signal if(MA_lang < MA_kurz && MA_lang_Vorperiode >=MA_kurz_Vorperiode) Dennoch muss er ja irgendwie bei der Abfrage auf falsche Werte zugreifen. Ich weiß auch nicht wie man die Parameter aktuell anzeigen lassen kann - also wie in matlab z.B. - da konnte ich es immer kontrollieren. Da komme ich derzeit einfach nicht weiter. Falls einer antwortet - danke schonmal VG Sven |
Zitat:
|
Zitat:
Kaufsignal wenn: zur aktuellen Periode der Wert des langsamen MAs (MA(30) hier) kleiner ist als der des schnellen MAs (MA(8) hier) - und zusätzlich in der Periode davor der Wert vom MA(30) aber größer war als der vom MA(8)...... also gerade der Wechsel stattgefunden hat und der schnelle jetzt über dem langsamen liegt.............also für mich erscheint das noch als richtig oder wo siehst du da das Problem?.....der erste Teil in der Bedingung ist die aktuelle Periode und danch kommt die Periode davor...... P.S.:ich bin für jeden Einwurf dazu dankbar |
Da widerspricht sich gar nichts.
Wenn ich es richtig gelesen habe, willst Du die Kreuzung auf der aktuellen! Kerze ausnutzen. Da rate ich immer ab, weil es häufig falsch-positive Signale gibt, denn während des Kerzenaufbaus kommt es häufig wieder zur Revidierung der Kreuzung und das evtl. mehrmals innerhalb der aktuellen Kerze. Prinzipiell löst man die Erkennung der Kreuzung genau über die Betrachtung der Indikatorwerte zu zwei verschiedenen Perioden. Demnach für Buy: if (MA0_Lang < MA0_Kurz && MA1_Lang >= MA1_Kurz) bzw. für Sell: if (MA0_Lang > MA0_Kurz && MA1_Lang <= MA1_Kurz) So, nun musst Du nur noch die entsprechenden MA-Werte, ermittelt aus der iMA() oben einsetzen und gut ist. Will man die Kreuzung auf der letzten geschlossenen Kerze betrachten, dann bedeutet die 0 (aktuelle Kerze) dann die 1 (letzte geschlossene Kerze) und die 1 wird zur 2 (vorletzte geschlossene Kerze). traderdoc |
Zitat:
Danke für die ANtwort traderdoc. Im festsetzen der iMAs habe ich das aber glaube schon so beachtet wie du das meintest...... // Marktdaten ermitteln double MA_lang = iMA(NULL,0,MA_lang,0,0,0,1); double MA_lang_Vorperiode = iMA(NULL,0,MA_lang,0,1,0,2); double MA_kurz = iMA(NULL,0,MA_kurz,0,0,0,1); double MA_kurz_Vorperiode = iMA(NULL,0,MA_kurz,0,1,0,2); 1 für die vorherige und die 2 für die davor......ich glaube es muss an etwas anderem liegen... |
Zitat:
Denn du verwendest die Variable MA_lang / MA_kurz für 2 unterschiedliche Dinge. double MA_lang = iMA(NULL,0,MA_lang,0,0,0,1); |
Zitat:
ja das ist aus dem Echtcode - ich glaube dafür kamen Warnhinweise (in gelben Dreiecken) aber keine richtigen Fehlermeldungen. Meinen Sie das es so richtig ist?......aber jetzt kommt immer noch ein gelbes Dreieck: 'declaration of 'MA_lang' hides global declaration' ....... // Marktdaten ermitteln double MA_lang = iMA(NULL,0,int (MA_lang),0,0,0,1); double MA_lang_Vorperiode = iMA(NULL,0,int (MA_lang),0,0,0,2); double MA_kurz = iMA(NULL,0,int (MA_kurz),0,0,0,1); double MA_kurz_Vorperiode = iMA(NULL,0,int (MA_kurz),0,0,0,2); also die Fehlermeldung erscheint jetzt für die hier 1. und 3. Zeile.....das meinst du bestimmt in irgendeiner Form oder? |
achso entsprechend meiner Vorlage muss ich glaube vorne MAlang und MAkurz schreiben (also ohne Unterstrich)
und nach dem Gleichzeichen in der Fkt. iMA steht es mit Unterstrich also....MA_lang und MA_kurz........... ja das könnte auch das Problem sein.....ich probiere es mal aus.... |
Er soll also erst öffnen, wenn der Schnelle den langsamen gerade erst überholt hat. Dann wird es aber oft passieren, dass er nen Trend
verschläft oder erst zu spät einsteigt. Lass diese Regel raus. An den Unterstrichen wirds nicht liegen. |
Zitat:
Ganz einfach, der Code muß wie folgt lauten: Code:
double MA_lang = iMA(NULL,0,MA_Periode_lang,0,0,0,1); D.h. Du benötigst eine MA_Periode_kurz und eine MA_Periode_lang. Fertig! traderdoc |
Liste der Anhänge anzeigen (Anzahl: 1)
Zitat:
Beim kompilieren kommen aber nur noch Wrnhinweise 'implicit conversion from string to number'. Aber das kann doch nicht der Grund sein oder doch? Code:
#property copyright "Copyright 2016, MetaQuotes Software Corp." |
Wenn nach dem Schließen durch TP/SL die Öffnungsbedingungen
immer noch gegeben sind... Poste mal Bilder zum besseren Verständnis. |
Liste der Anhänge anzeigen (Anzahl: 1)
Zitat:
hier sind noch mal meine Bedingungen im Code: if (LongSignal == false && ShortSignal == false) { // Handelssignale ermitteln if(NeuePeriodeBegonnen == true) { // Buy Signal if(MA_lang < MA_kurz && MA_lang_Vorperiode >= MA_kurz_Vorperiode) { LongSignal = true; } else LongSignal = false; // Sell Signal if(MA_lang > MA_kurz && MA_lang_Vorperiode <= MA_kurz_Vorperiode) { ShortSignal = true; } else ShortSignal =false; } else { LongSignal = false; ShortSignal = false; } |
Mit dem TP ist das so ne Sache. Er wird nach diesem immer
wieder ne neue Order öffnen, solange entsprechende Bedingungen gegeben sind. Versuch vielleicht z.B. nen Buy ohne TP zu schließen wenn Close Bar 1 < MA_kurz. Buy öffnen wenn Close Bar 1 > MA_kurz && MA_kurz > MA_lang Umgedreht mit Sells. Dann kann er mal verschnaufen bzw. Seitwärtsphasen auslassen. Wobei ich immer noch nicht ganz kapiere, was das mit der Vorperiode soll. :confused: Kannst Du das mal mit Chart-Bildern erklären? |
Liste der Anhänge anzeigen (Anzahl: 2)
Zitat:
Mit der Vorperiode meine ich die Periode, die genau vor der anderen Vergleichsperiode kommt - deswegen ist bei Vorperiode der Shift auf 2 gesetzt und bei den anderen auf 1 (siehe unten in rot) double MA_lang = iMA(NULL,0,MA_Periode_lang,0,0,0,1); double MA_lang_Vorperiode = iMA(NULL,0,MA_Periode_lang,0,0,0,2); double MA_kurz = iMA(NULL,0,MA_Periode_kurz,0,0,0,1); double MA_kurz_Vorperiode = iMA(NULL,0,MA_Periode_kurz,0,0,0,2); Im Bild sieht man dass die sich da genau kreuzen - nach dem TP wird sofort die neue Order eröffnet (siehe 2. Bild). Das komische ist aber, dass doch dort garnicht die gesamte Bedingung erfüllt ist also Der rote Teil ist nicht erfüllt aus meiner Sicht: // Buy Signal if(MA_lang < MA_kurz && MA_lang_Vorperiode >= MA_kurz_Vorperiode) schon komisch :) |
Ich habe jetzt nur kurz drübergelesen über deinen Code, aber auf den ersten Blick würde ich sagen, dass du dein LongSignal / ShortSignal zurücksetzen musst.
Du checkst die Bedingung mit if (LongSignal == false && ShortSignal == false) {....} und setzt nur dort drinnen die Signale zurück. Wenn du aber bereits LongSignal=true hast, ein Trade eröffnet wird, dieser per TP geschlossen wird, kommt sofort der nächste Trade da LongSignal=true ist. (noch immer) |
hab auch nur über den thread geschaut, aber ich bin mir sicher dass Susanne recht hat.
Wenn immer wieder neue Order eröffnet werden, dann nur weil die EntrySignale nicht zurück gesetzt werden oder die Variable einfach falsch ist. Glaub damit hat jeder Neuling zu kämpfen, kenn das auch ganz gut. Versuchs mal so: Code:
double MA_lang = iMA(NULL,0,MA_Periode_lang,0,0,0,1); Es gibt zich Tutorials zu C++. Würd dir empfehlen erst mal Basics zu lernen bevor du weiter machst, denn dann tust du dich nicht so schwer, das hält doppelt und dreifach auf.Wenn man nicht weiß wofür int, double oder string steht,dann macht das echt keinen Sinn. Bin auch kein Profi also quereinsteiger und tuh mich oft trotz einigem Wissen noch schwer. Gelernte Programmierer haben es eben leichter :o LG |
Alle Zeitangaben in WEZ +2. Es ist jetzt 00:17 Uhr. |
Powered by vBulletin® Version 3.8.5 (Deutsch)
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
SEO by vBSEO 3.6.1
Powered by vBCMS® 2.7.0 ©2002 - 2024 vbdesigns.de
Copyright ©2009 - 2023 by Expert-Advisor.com - Das Metatrader Forum