MT5 und Geschwindigkeit in Aktion - Seite 14

 

Ich weiß nicht, ob es hier war oder nicht.

Wir brauchen wirklich Box Trees und Hashmaps. Bei Multivolumes ist die Software-Hashmap für weitere Tests sehr langsam.

Und C++17 :)

 

Versuchen Sie bitte den Beta-Build 2577.

Wir haben das Story Sampling verbessert und werden es weiter drastisch überarbeiten.

 
Renat Fatkhullin:

Versuchen Sie bitte den Beta-Build 2577.

Verbessert mit Story Sampling und wird weiterhin dramatisch umgestaltet.

Es scheint noch schlimmer geworden zu sein:

2020.08.19 03:41:43.173         Time[MT4Orders.mqh 434: ::HistorySelect(this.LastTime,D'31.12.3000 23:59:59')] = 11 ms.
2020.08.19 03:41:43.174         Time[MT4Orders.mqh 622: this.RefreshHistory()] = 12 ms.

Am Vortag gab es keine solchen Zahlen für 2573.

 
Andrey Pogoreltsev:

Ich weiß nicht, ob es hier war oder nicht.

Wir brauchen wirklich Box Trees und Hashmaps. Bei Multivolumes ist die Software-Hashmap für weitere Tests sehr langsam.

Und C++17 :)

Die mitgelieferte Hashmap ist die schnellste aller Implementierungen, die ich überprüft habe. Es gibt zwei weitere Varianten, die in CB herumliegen, und es gibt einen Artikel über eine von ihnen, sie sind um eine Größenordnung langsamer. Und welche Art von Hashmap brauchen Sie,keine Software? Wollen Sie keine Hardware-Hashmaps auf FPGA? )) Wie wäre es damit, Elon Musk!

Was ist falsch an Pluspunkten? MQL5 unterstützt das Laden von 64-Bit-DLLs nicht mehr? Schreiben Sie sofort an Renate über diesen Skandal! Ich habe sogar C++ 20 unterstützt! Ich muss es nur noch lernen ))

------------------

Microsoft Visual Studio Enterprise 2019 Vorschau

Version 16.7.0 Vorschau 4.0

Installierte Version: Enterprise

Microsoft Visual C++ 2019

 
Andrey Khatimlianskii:

Es scheint noch schlimmer geworden zu sein:

Am Vortag gab es keine solchen Zahlen für 2573.

Es scheint sich um die ersten kalten Anfragen gehandelt zu haben. Seitdem kein einziger Druck mehr.

 
Renat Fatkhullin:

Versuchen Sie bitte den Beta-Build 2577.

Wir haben das Story Sampling verbessert und werden es weiter drastisch überarbeiten.

2020.08.19 09:30:06.512 Test6 (GBPNZD,H1)       Alert: Time[Test6.mq5 17: CopyTicks(Symb,Ticks,COPY_TICKS_ALL,0,1)] = 1 ms.
2020.08.19 09:30:08.035 Test6 (EURGBP,M1)       Alert: Time[Test6.mq5 40: SymbolInfoDouble(Symb,SYMBOL_TRADE_TICK_VALUE)] = 4 ms.
2020.08.19 09:30:08.038 Test6 (GBPNZD,H1)       Alert: Time[Test6.mq5 13: SymbolInfoTick(Symb,Tick)] = 7 ms.
2020.08.19 09:30:08.042 Test6 (EURNZD,H1)       Alert: Time[Test6.mq5 13: SymbolInfoTick(Symb,Tick)] = 10 ms.
2020.08.19 09:30:08.044 Test6 (EURUSD,H1)       Alert: Time[Test6.mq5 74: SymbolsTotal(true)] = 13 ms.
2020.08.19 09:30:08.046 Test6 (GBPNZD,H1)       Alert: Time[Test6.mq5 39: SymbolInfoDouble(Symb,SYMBOL_ASK)] = 4 ms.
2020.08.19 09:30:08.046 Test6 (EURGBP,M1)       Alert: Time[Test6.mq5 40: SymbolInfoDouble(Symb,SYMBOL_TRADE_TICK_VALUE)] = 7 ms.
2020.08.19 09:30:08.047 Test6 (EURUSD,H1)       Alert: Time[Test6.mq5 75: SymbolName(0,true)] = 3 ms.
2020.08.19 09:30:08.048 Test6 (GBPNZD,H1)       Alert: Time[Test6.mq5 40: SymbolInfoDouble(Symb,SYMBOL_TRADE_TICK_VALUE)] = 2 ms.
2020.08.19 09:30:08.052 Test6 (EURUSD,H1)       Alert: Time[Test6.mq5 13: SymbolInfoTick(Symb,Tick)] = 2 ms.
2020.08.19 09:30:08.053 Test6 (EURGBP,M1)       Alert: Time[Test6.mq5 41: SymbolInfoDouble(Symb,SYMBOL_POINT)] = 5 ms.
2020.08.19 09:30:08.055 Test6 (GBPNZD,H1)       Alert: Time[Test6.mq5 40: SymbolInfoDouble(Symb,SYMBOL_TRADE_TICK_VALUE)] = 3 ms.
2020.08.19 09:30:08.060 Test6 (EURGBP,M1)       Alert: Time[Test6.mq5 42: SymbolInfoInteger(Symb,SYMBOL_DIGITS)] = 5 ms.
2020.08.19 09:30:08.071 Test6 (EURNZD,H1)       Alert: Time[Test6.mq5 40: SymbolInfoDouble(Symb,SYMBOL_TRADE_TICK_VALUE)] = 25 ms.
2020.08.19 09:30:24.489 Test6 (GBPNZD,H1)       Alert: Time[Test6.mq5 74: SymbolsTotal(true)] = 1 ms.
2020.08.19 09:30:25.857 Test6 (EURGBP,M1)       Alert: Time[Test6.mq5 22: HistorySelect(Tick.time,INT_MAX)] = 1 ms.
2020.08.19 09:30:26.092 Test6 (EURUSD,H1)       Alert: Time[Test6.mq5 22: HistorySelect(Tick.time,INT_MAX)] = 1 ms.
2020.08.19 09:30:26.119 Test6 (EURUSD,H1)       Alert: Time[Test6.mq5 22: HistorySelect(Tick.time,INT_MAX)] = 1 ms.
2020.08.19 09:30:29.279 Test6 (EURNZD,H1)       Alert: Time[Test6.mq5 17: CopyTicks(Symb,Ticks,COPY_TICKS_ALL,0,1)] = 1 ms.
2020.08.19 09:30:31.931 Test6 (EURUSD,H1)       Alert: Time[Test6.mq5 42: SymbolInfoInteger(Symb,SYMBOL_DIGITS)] = 2 ms.
2020.08.19 09:30:31.931 Test6 (EURNZD,H1)       Alert: Time[Test6.mq5 40: SymbolInfoDouble(Symb,SYMBOL_TRADE_TICK_VALUE)] = 1 ms.
2020.08.19 09:30:33.402 Test6 (EURNZD,H1)       Alert: Time[Test6.mq5 34: HistoryOrderSelect(0)] = 7 ms.
2020.08.19 09:30:35.686 Test6 (GBPNZD,H1)       Alert: Time[Test6.mq5 74: SymbolsTotal(true)] = 2 ms.
2020.08.19 09:30:37.810 Test6 (EURUSD,H1)       Alert: Time[Test6.mq5 39: SymbolInfoDouble(Symb,SYMBOL_ASK)] = 1 ms.
2020.08.19 09:30:52.415 Test6 (GBPNZD,H1)       Alert: Time[Test6.mq5 22: HistorySelect(Tick.time,INT_MAX)] = 3 ms.
2020.08.19 09:31:10.903 Test6 (EURNZD,H1)       Alert: Time[Test6.mq5 22: HistorySelect(Tick.time,INT_MAX)] = 1 ms.
2020.08.19 09:31:11.414 Test6 (GBPNZD,H1)       Alert: Time[Test6.mq5 40: SymbolInfoDouble(Symb,SYMBOL_TRADE_TICK_VALUE)] = 5 ms.
2020.08.19 09:31:11.414 Test6 (EURNZD,H1)       Alert: Time[Test6.mq5 39: SymbolInfoDouble(Symb,SYMBOL_ASK)] = 9 ms.
2020.08.19 09:31:32.694 Test6 (EURGBP,M1)       Alert: Time[Test6.mq5 42: SymbolInfoInteger(Symb,SYMBOL_DIGITS)] = 2 ms.
2020.08.19 09:31:51.245 Test6 (GBPNZD,H1)       Alert: Time[Test6.mq5 22: HistorySelect(Tick.time,INT_MAX)] = 1 ms.
2020.08.19 09:31:53.989 Test6 (EURGBP,M1)       Alert: Time[Test6.mq5 17: CopyTicks(Symb,Ticks,COPY_TICKS_ALL,0,1)] = 2 ms.
2020.08.19 09:32:11.871 Test6 (GBPNZD,H1)       Alert: Time[Test6.mq5 22: HistorySelect(Tick.time,INT_MAX)] = 1 ms.
2020.08.19 09:32:20.310 Test6 (EURNZD,H1)       Alert: Time[Test6.mq5 42: SymbolInfoInteger(Symb,SYMBOL_DIGITS)] = 3 ms.
2020.08.19 09:32:47.513 Test6 (EURUSD,H1)       Alert: Time[Test6.mq5 22: HistorySelect(Tick.time,INT_MAX)] = 3 ms.
2020.08.19 09:32:49.367 Test6 (EURUSD,H1)       Alert: Time[Test6.mq5 22: HistorySelect(Tick.time,INT_MAX)] = 1 ms.
2020.08.19 09:32:56.358 Test6 (EURGBP,M1)       Alert: Time[Test6.mq5 22: HistorySelect(Tick.time,INT_MAX)] = 1 ms.
2020.08.19 09:33:05.424 Test6 (EURNZD,H1)       Alert: Time[Test6.mq5 75: SymbolName(0,true)] = 2 ms.
2020.08.19 09:33:16.537 Test6 (EURUSD,H1)       Alert: Time[Test6.mq5 40: SymbolInfoDouble(Symb,SYMBOL_TRADE_TICK_VALUE)] = 5 ms.
2020.08.19 09:33:16.551 Test6 (EURNZD,H1)       Alert: Time[Test6.mq5 40: SymbolInfoDouble(Symb,SYMBOL_TRADE_TICK_VALUE)] = 13 ms.
2020.08.19 09:33:47.303 Test6 (EURUSD,H1)       Alert: Time[Test6.mq5 40: SymbolInfoDouble(Symb,SYMBOL_TRADE_TICK_VALUE)] = 7 ms.
2020.08.19 09:33:50.587 Test6 (EURNZD,H1)       Alert: Time[Test6.mq5 22: HistorySelect(Tick.time,INT_MAX)] = 2 ms.
2020.08.19 09:33:56.181 Test6 (EURNZD,H1)       Alert: Time[Test6.mq5 41: SymbolInfoDouble(Symb,SYMBOL_POINT)] = 1 ms.
2020.08.19 09:33:59.244 Test6 (EURNZD,H1)       Alert: Time[Test6.mq5 74: SymbolsTotal(true)] = 1 ms.
2020.08.19 09:34:03.255 Test6 (GBPNZD,H1)       Alert: Time[Test6.mq5 41: SymbolInfoDouble(Symb,SYMBOL_POINT)] = 2 ms.
2020.08.19 09:34:47.388 Test6 (EURNZD,H1)       Alert: Time[Test6.mq5 28: HistoryDealSelect(0)] = 1 ms.
2020.08.19 09:34:47.498 Test6 (EURGBP,M1)       Alert: Time[Test6.mq5 22: HistorySelect(Tick.time,INT_MAX)] = 1 ms.
2020.08.19 09:35:06.001 Test6 (EURGBP,M1)       Alert: Time[Test6.mq5 74: SymbolsTotal(true)] = 3 ms.
2020.08.19 09:35:06.005 Test6 (EURGBP,M1)       Alert: Time[Test6.mq5 75: SymbolName(0,true)] = 1 ms.
2020.08.19 09:35:06.017 Test6 (EURGBP,M1)       Alert: Time[Test6.mq5 22: HistorySelect(Tick.time,INT_MAX)] = 1 ms.
2020.08.19 09:35:06.022 Test6 (EURNZD,H1)       Alert: Time[Test6.mq5 42: SymbolInfoInteger(Symb,SYMBOL_DIGITS)] = 3 ms.
2020.08.19 09:35:06.046 Test6 (EURNZD,H1)       Alert: Time[Test6.mq5 28: HistoryDealSelect(0)] = 12 ms.
2020.08.19 09:35:29.014 Test6 (GBPNZD,H1)       Alert: Time[Test6.mq5 22: HistorySelect(Tick.time,INT_MAX)] = 1 ms.
2020.08.19 09:36:30.289 Test6 (EURUSD,H1)       Alert: Time[Test6.mq5 40: SymbolInfoDouble(Symb,SYMBOL_TRADE_TICK_VALUE)] = 1 ms.
2020.08.19 09:36:55.946 Test6 (EURUSD,H1)       Alert: Time[Test6.mq5 74: SymbolsTotal(true)] = 2 ms.
2020.08.19 09:36:55.950 Test6 (EURNZD,H1)       Alert: Time[Test6.mq5 39: SymbolInfoDouble(Symb,SYMBOL_ASK)] = 3 ms.

Es wurde viel besser. Im Kampf, noch nicht getestet.


Die Logs der ZZY Combat Version zeigen, dass es noch viel zu verbessern gibt...

 
Alexey Volchanskiy:

Die mitgelieferte Hashmap ist die schnellste von allen Implementierungen, die ich überprüft habe. Es gibt zwei weitere Varianten in der CB, und es gibt einen Artikel über eine davon, sie sind um eine Größenordnung langsamer. Welche Art von Hashmap brauchen Sie,keine Software? Wollen Sie keine Hardware-Hashmaps auf FPGA? )) Wie wäre es damit, Ilon Musk!

Ich meine std:: ohne Implementierung in der ausführbaren Sprache mql5, weil es deutlich langsamer als native Implementierung auf Plus ist.


Was ist falsch an Pluspunkten? MQL5 unterstützt nicht mehr das Laden von 64-bit DLL? Schreiben Sie sofort an Renate über diesen Skandal! Ich habe sogar C++ 20 unterstützt! Ich muss nur noch den Dreh rauskriegen))!

Die Option der nativen DLL ist schön, aber sie hat viele Nachteile:

  1. Vom Strategietester nicht unterstützt
  2. Kann nicht im selben Geschäft bleiben
  3. Nicht alle Benutzer möchten den EA mit ihrer DLL ausführen
  4. Soweit ich verstehe (korrigieren Sie mich, wenn ich falsch liege), wird die DLL bei jedem Aufruf geladen/entladen
Und MQL5 selbst ist ein C++-Analogon, nur in C99, also genau das, worüber wir sprechen.


PS. Ich werde versuchen, meinen Roboter in DLL zu übersetzen - es kann schneller sein, Tests zu bestehen und im Allgemeinen zu arbeiten

Тестирование стратегий - Алгоритмический трейдинг, торговые роботы - Справка по MetaTrader 5
Тестирование стратегий - Алгоритмический трейдинг, торговые роботы - Справка по MetaTrader 5
  • www.metatrader5.com
Тестер стратегий позволяет тестировать и оптимизировать торговые стратегии (советники) перед началом использования их в реальной торговле. При тестировании советника происходит его однократная прогонка с начальными параметрами на исторических данных. При оптимизации торговая стратегия прогоняется несколько раз с различным набором параметров...
 
b2579.
Dateien:
2579_lags.txt  653 kb
 
fxsaber:
In OnTick fordere ich die Tick-Historie des vorherigen Ticks an.

Eigentlich geht es nicht um Verzögerungen, aber ich frage trotzdem. Wofür ist die Geschichte gut? Können Zecken übersehen werden? MT4 hat dies praktiziert, aber MT5 sollte dies nicht tun, nicht wahr?

 
traveller00:

Eigentlich geht es nicht um Verzögerungen, aber ich frage trotzdem. Wofür ist die Geschichte gut? Können Zecken übersehen werden? MT4 hat das praktiziert, und MT5 sollte das nicht tun, oder?

DasNewTick-Ereignis wird erzeugt, wenn neue Kurse eintreffen, und wird vonOnTick() in angehängten EAs behandelt. Wenn beim Eintreffen eines neuen Kurses die OnTick-Funktion, die auf dem vorherigen Kurs läuft, ausgeführt wird, wird der eingehende Kurs vom Expert Advisor ignoriert, da das entsprechende Ereignis nicht in die EA-Ereigniswarteschlange gestellt wird.

https://www.mql5.com/ru/docs/runtime/event_fire#newtick