
Ti stai perdendo delle opportunità di trading:
- App di trading gratuite
- Oltre 8.000 segnali per il copy trading
- Notizie economiche per esplorare i mercati finanziari
Registrazione
Accedi
Accetti la politica del sito e le condizioni d’uso
Se non hai un account, registrati
Aggiornato al 2269. Risultati del profiler di un grande EA (non sintetico).
Tester
Virtuale
Probabilmente, il profiler fa delle misurazioni sbagliate. Altrimenti risulta che OrderSend cinque richiede 912 ms in media.
Tutti i doppi normalizzati con lo stesso algoritmo (ad esempio tramite NormalizeDouble) possono essere confrontati direttamente tra loro.
Questo fatto ovvio permette di evitare costose costruzioni di confronto di numeri reali in molti casi. Che in alcuni compiti può aumentare significativamente le prestazioni.
Forse uno dei più esemplari di questi compiti è Tester. Analizziamolo con un esempio.
C'è BuyLimit. Ad ogni tick, il tester deve confrontare BuyLimit con il prezzo Ask. Il tester standard lo fa attualmente in questo modo
Cioè qualsiasi livello di trade(ordine pendente o SL/TP) fa scattare una normalizzazione.
Ma possiamo sempre cavarcela con un costrutto di confronto molto efficace se i prezzi sono stati normalizzati in precedenza (prima del backtest).
if (BuyLimit_Price >= Ask) BuyLimit -> Buy;
Proviamo un confronto. Ho eseguito questo robot in Tester attraverso Virtual.
Confronto dei prezzi attraverso la normalizzazione.
Senza normalizzazione.
Possiamo vedere che il guadagno è più del 20% se non facciamo la normalizzazione quando confrontiamo i prezzi.
Di conseguenza, se il Tester interno viene passato ai prezzi normalizzati e non fa la normalizzazione interna quando confronta i prezzi, si può ottenere un serio miglioramento delle prestazioni.
Dopo l'assegnazione diretta senza mat. operazioni anche
Il prefisso, ovviamente, copia la rappresentazione in byte del numero in modo invariato.
Dovremmo fare un test più lungo di un secondo per chiarezza?
C'è una diffusione di 3 volte in una versione: passaggio più breve 0:00:00.604, passaggio più lungo 0:00:01.743. cosa confrontiamo?
Forse fare un test di più di un secondo per chiarezza?
C'è una diffusione di 3 volte in una versione: passaggio più breve 0:00:00.604, passaggio più lungo 0:00:01.743. cosa confrontiamo?
Confrontando il più corto, naturalmente. Sono abituato a correre su zecche filtrate. Preparerà quelli non filtrati più tardi.
Stiamo confrontando il più corto, ovviamente.
Perché? L'ottimizzazione non consiste in un solo passaggio. Che differenza fa che un passaggio sia così veloce, se la media non è molto diversa.
Sono abituato a correre su zecche filtrate. Più tardi preparerò quelli non filtrati.
Posso semplicemente fare un intervallo più lungo. Almeno 30 secondi per il test.
Perché? Non è che l'ottimizzazione consista in un solo passaggio. Che differenza fa che un passaggio sia così veloce, se la media non è molto diversa.
Questo parametro è ottimizzato.
E non influisce sulla logica. Ecco perché è più breve.
Questo parametro è ottimizzato
E non influisce sulla logica. Ecco perché è più breve.
Cosa c'entra la logica EA? Stiamo misurando la velocità del tester.
Cosa c'entra la logica dell'EA? Stiamo misurando la velocità del tester.
Questo è il modo in cui funziona un agente, conta consecutivamente la stessa cosa. Se si toglie tutta la casualità, la performance netta è vicina a quella più breve.