Sie verpassen Handelsmöglichkeiten:
- Freie Handelsapplikationen
- Über 8.000 Signale zum Kopieren
- Wirtschaftsnachrichten für die Lage an den Finanzmärkte
Registrierung
Einloggen
Sie stimmen der Website-Richtlinie und den Nutzungsbedingungen zu.
Wenn Sie kein Benutzerkonto haben, registrieren Sie sich
OK, tolles Thema !!!!
Was ist dann das Volumen? die Anzahl der Tick-Änderungen, oder die Anzahl der Trades, oder die Menge des Handelsfonds in einer Periode?
Um es noch einmal zu sagen:
Meine grundlegende Erkenntnis ist, dass, wenn es eine Änderung in MarketInfo() für das Paar gibt, ein "Tick" empfangen wird.
.
Es kann Ausnahmen geben, wie z.B. "keine Änderungen gefunden", aber ein Tick wurde empfangen, aber das ist sehr selten.
Ticks, die ohne Preisänderung empfangen werden, sind nicht selten und signalisieren eine andere Änderung in MarketInfo für das Paar.
.
Das Volumen entspricht der Anzahl der empfangenen Ticks, d.h. der Anzahl der Aufrufe der start()-Funktion, es handelt sich nicht speziell um Trades oder Bid/Ask-Änderungen. Eine Änderung in der MarketInfo() löst einen Tick aus, und die Anzahl der Ticks ist gleich dem Volumen.
.
Das Volumen entspricht der Anzahl der empfangenen Ticks, d.h. wie oft die start()-Funktion aufgerufen wurde.
Ja, aber einige Ticks können verpasst werden (die Funktion start() wurde nicht aufgerufen), weil die vorherige Funktion start() noch nicht abgeschlossen ist.
Bei Eingang eines neuen Kurses wird die start()-Funktion der angehängten Experten und benutzerdefinierten Indikatoren ausgeführt. Wenn die start()-Funktion, die beim vorangegangenen Kurs gestartet wurde, bereits lief, als ein neuer Kurs eintraf, wird der neue Kurs vom Experten übersprungen. Alle neuen Kurse, die während der Ausführung des Programms eingehen, werden vom Programm übersprungen, bis die aktuelle Ausführung der start()-Funktion abgeschlossen ist. Danach wird die start()-Funktion nur noch ausgeführt, wenn ein weiterer neuer Kurs eintrifft. Bei benutzerdefinierten Indikatoren wird die start()-Funktion zur Neuberechnung gestartet, nachdem das aktuelle Chart-Symbol oder der Zeitrahmen unabhängig von neu eingehenden Kursen geändert wurde. Die start()-Funktion wird nicht ausgeführt, wenn das Fenster mit den Experteneigenschaften geöffnet ist. Letzteres kann während der Ausführung des Experten nicht geöffnet werden.
Ich verwende nicht die Funktion Start() zum Auslösen, sondern ein Skript mit einer Endlosschleife zur Untersuchung von MarketInfo().
Ich werde das Skript neu schreiben, da das Experiment eine unerwartete Richtung eingeschlagen hat.
.
Empfangene Ticks mit Preisänderung oder ohne Preisänderung, Tickanzahl = Volumen.
Aber Client MT vielleicht nicht empfangen ALLE Ticks für einige reaseons wie Netz Pause vorübergehend einige seconeds.
dann Tick count = Volumen ist es zählen oder ändern Zeiten auf dem Server. oder definiert durch Broker wollen ihren Preis wie viel mal in einem Zeitraum zu ändern.
Ist das richtig?
Für einen Broker, der am Markt teilnimmt, um seine Kundenpositionen abzusichern, wird das Volumen auch durch den Broker definiert, der seinen Preis wie oft in einem Zeitraum ändern möchte.
Mein Gott!
Wie kann man die Volumendaten verwenden?
Fragen zu Marketinfo().
Werden übermäßige Marketinfo()-Aufrufe in einer Endlosschleife vom Broker als Spam angesehen?
Was würde nicht als Spam angesehen werden?
Wie oft kann man Marketinfo() ausführen, ohne den Broker zu verärgern?
Zieht der Befehl Marketinfo() aus dem Cache des Brokers oder handelt es sich um einen echten Requote?
Vielen Dank
MarketInfo()-Aufrufe gehen nicht an den Händler, sondern lesen die neuesten Werte, die bereits vom Händler empfangen wurden.
Die Aufrufe an den Dealer benötigen jeweils etwa 100-300 Millisekunden bis zur Fertigstellung.
// script int start(){ int startTime = GetTickCount(); for(int i = 0; i < 10000; i++){ int spread = MarketInfo(Symbol(), MODE_SPREAD); } int endTime = GetTickCount(); Print("Time to collect 10000 instances of data = " + (endTime -startTime) + " milliseconds"); startTime = GetTickCount(); OrderSend(Symbol(), OP_BUY, 1, Ask, 0, 0, 0 , "", 0, 0, CLR_NONE); endTime = GetTickCount(); Print("Time to send one order to Server = " + (endTime -startTime) + " milliseconds"); return(0); }
Phy - Entschuldigung, dass ich dieses Thema wieder aufmache :-)
Ich denke, dass es eine Diskrepanz gibt zwischen dem, was Sie über die Natur einer Zecke glauben, und Ihrer Methode zur Berechnung von Gewinn/Risiko usw. (nach dem Lesen einiger früherer Beiträge).
Das heißt, dass Sie MarketInfo(Symbol(),MODE_TICKVALUE) allein verwenden, um den Pip-Wert des Paares in Bezug auf die Einzahlungswährung zu bestimmen.
Wenn das, was Sie über Ticks im MT4 glauben, richtig ist, kann sich der Tick-Wert um einen Faktor der Anzahl der Pips zwischen den Ticks ändern.
Mit anderen Worten: Wenn der Kurs plötzlich ein paar Pips springt, könnte ein vorheriger Aufruf von MarketInfo ergeben, dass TICKSIZE und TICKVALUE 0,0001 bzw. 7,16 betragen. Der nächste Aufruf könnte dann 0,0002 und 14,32 ergeben.
In diesem Fall müssten Sie immer sowohl MarketInfo(Symbol(),MODE_TICKSIZE) als auch MarketInfo(Symbol(),MODE_TICKVALUE) in Ihre Gewinn-/Risiko-Formeln einbeziehen und niemals MarketInfo(Symbol(),MODE_TICKVALUE) allein.
Ist dies korrekt?
CB
.
Für Euro bei MBTrading:
10000 MODE_LOTSIZE Losgröße in der Basiswährung.
0.1 MODE_TICKVALUE Tickwert in der Depotwährung.
0,00001 MODE_TICKSIZE Tick-Größe in der Kurswährung.
.
Ersetzen Sie oben das Wort "Tick" durch "Pip", wenn Sie möchten.
.
Dieser Broker verwendet Mini-Lot als Standardgröße -- MODE_LOTSIZE
Sie verwenden 3/5 Ziffern für den Preis -- MODE_TICKSIZE
Der Wert eines dieser "Ticks" beträgt $0,10 -- MODE_TICKVALUE
.
Für GBPAUD:
.
10000 MODE_LOTSIZE Losgröße in der Basiswährung.
0.080262 MODE_TICKVALUE Tickwert in der Einzahlungswährung.
0.00001 MODE_TICKSIZE Tick-Größe in der Kurswährung.
.
GBPAUD ein Pip Bewegung auf einem Lot zahlt $0.080262
.
Ihre Idee zur Berechnung der Preisänderung Ihrer Order von einem Moment zum nächsten...
PositionsWertVeränderung = PreisVeränderungInPips * MarketInfo( OrderSymbol(), MODE_TICKVALUE) * OrderLots();
.