Discussione: TS: BreakOut Dinamico in Easy Language
-
21-10-13, 11:54 #11
- Data Registrazione
- Jan 2011
- Località
- Genova
- Messaggi
- 1,306
-
21-10-13, 12:01 #12
-
21-10-13, 13:41 #13
- Data Registrazione
- Sep 2013
- Località
- Monza
- Messaggi
- 186
Ciao Tiziano,
come ho già scritto in passato spero di utilizzare beeTrader con WeBank,
una volta terminata la fase di studio ed individuato un TS convincente.
Quindi non è che provi soddisfazione o gratificazione particolare ad
elencare quello che io considero gli attuali limiti di beeTrader nei miei post.
Lo faccio solo a fin di bene, per spingervi a migliorare il prodotto !!!
-
Vedo che continui a porre l'accento sulla semplicità,
e ti ho già scritto come la penso in proposito nei miei post passati.
E certamente tutti siamo partiti dalle cose semplici.
Il classico crossover di due medie è sempre il punto di partenza
per tutti quanti. Ma anche il lattaio, quando capisce dal backtest,
che il crossover non basta a guadagnare, allora inizia ad aggiungere condizioni
o cercare qualcosa di diverso dall'incrocio di una manciata di indicatori.
E appena si va un po' oltre, pur rimanendo nella estrema semplicità di poche righe di codice (vedi esempio sopra), viene fuori l'attuale limite della natura vettoriale di beeTrader.
-
Se poi, per superare questo limite, metterete a disposizione nuove funzioni,
io ne sarò solo felice, e avrò raggiunto il mio scopo che è semplicemente
quello di avere una beeTrader migliore da utilizzare per il mio trading !!!
E' logico che se beeTrader non sarà adeguata, per la famosa legge del
mercato, purtroppo a malincuore, toccherà tornare alle altre piattaforme.
-
Alle prossime
Cordialmente
Massimo
-
21-10-13, 13:47 #14
Salve,
nella release di oggi verrà aggiunta una funzione specifica per l'iterazione barra per barra:
BARLOOP ( initialValue, offset, operator, operand, minimumValue, maximumValue )
Tutti i parametri, ad eccezione di initialValue, possono essere delle qualsiasi espressioni valide in EasyScript.
- Il parametro initialValue rappresenta il valore iniziale da utilizzare nel calcolo: può essere un qualsiasi valore numerico.
- Il parametro offset specifica il numero di barre trascorse a cui voglio riferirmi, deve essere un valore positivo.
- Il parametro operator identifica l'operatore matematico da utilizzare, tra ADD, SUBSTRCT, MULTIPLY e DIVIDE (vedi funzione LOOP).
- Il parametro operand specifica il secondo operando dell'operazione matematica da eseguire, e può essere una qualsiasi espressione (valore numerico, risultato di un'altra funzione, ecc.).
- I parametri minimumValue e maximumValue rappresentano l'eventuale range minimo e massimo dei valori in uscita dalla funzione. Se non è necessario limitare il valore minimo o massimo del risultato, è possibile utilizzare NAN. NAN è una nuova costante, che reppresenta "Not A Number", cioè un valore non numerico, utile quando quel particolare valore non deve essere utilizzato.
Il seguente esempio di EasyLanguage:
// Alla prima barra viene caricato in EntryLB un valore iniziale di 20
-
if CurrentBar = 1 Then EntryLB = 20;
-
// Quindi si carica in YestEntryLB il valore di EntryLB precedente, che verrà poi modificato
// nelle istruzioni successive. Ed è questo il grande limite di beeTrader di cui parlavo.
// beeTrader questo attualmente non lo può fare, o almeno io non ho ancora trovato il modo.
-
YestEntryLB = EntryLB;
-
// Quindi viene modificato EntryLB che dovrà essere utilizzato per calcolare
// alla "prossima" barra il valore della linea precedente. Non possibile nel vettoriale !!!
EntryLB = YestEntryLB * (1 + DeltaHistVol);
EntryLB = MaxList(EntryLB, MinLB);
EntryLB = MinList(EntryLB, MaxLB);
SET EntryLB = BARLOOP(20, 1, MULTIPLY, (1 + DeltaHistVol), MinLB, MaxLB)
Restituisce un valore numerico calcolato progressivamente, barra per barra. Il calcolo utilizza 20 come valore iniziale. Il numero 1 rappresenta il valore della barra precedente, che viene moltiplicato per (1 + DeltaHistVol), e limitato entro il range MinLB e MaxLB.
Max Francario
-
21-10-13, 17:34 #15
- Data Registrazione
- Apr 2010
- Messaggi
- 800
Ottimo......
Aspettiamo la nuova Release con trepidazione...--- Trend my Friend ---
-
21-10-13, 18:49 #16
-
21-10-13, 20:53 #17
- Data Registrazione
- Apr 2010
- Messaggi
- 800
Ok scaricato,
ora bisogna mettere insieme tutti i pezzi del Puzzle e dovrebbe venire fuori il listato corretto e funzionante...--- Trend my Friend ---
-
22-10-13, 01:30 #18
- Data Registrazione
- Sep 2013
- Località
- Monza
- Messaggi
- 186
Salve Max,
sto tentando di usare la nuova funzione per tradurre il codice in EasyScript,
ma mi sono incastrato su un messaggio d'errore.
Ho scritto il seguente codice:
# Volatilità Thalos
INPUTS: @MaxLB(60), @MinLB(20)
SET HistVol= SDV(CLOSE, 30, 1, SIMPLE)
SET YestHistVol = REF(HistVol, 1)
SET DeltaHistVol = (HistVol - YestHistVol)/HistVol
SET EntryLB = BARLOOP (20 , 1, MULTIPLY , (1 + DeltaHistVol),@MinLB, @MaxLB)
....
ma mi segnala Error Division by Zero per la linea
SET DeltaHistVol = (HistVol - YestHistVol)/HistVol
e non riesco a trovare il modo di superare l'intoppo.
Potresti suggerirmi come fare ?
Grazie
Saluti
Massimo
P.S.
Ho provato anche con:
SET DeltaHistVol = IF ( (YestHistVol <> 0) , (HistVol - YestHistVol)/HistVol , 0)
ma segnala sempre errore Division by zeroUltima modifica di maxmax68; 22-10-13 alle 02:20
-
22-10-13, 09:12 #19
Buongiorno maxmax68,
ho notato che Massimiliano ha risposto ad una domanda analoga che si trova a questo post:
http://www.playoptions.it/vbforum/sh...5890#post65890
buona giornata,
MarcoI computer sono incredibilmente veloci, accurati e stupidi. Gli uomini sono incredibilmente lenti, inaccurati e intelligenti. L’insieme dei due costituisce una forza incalcolabile. (Albert Einstein)
-
22-10-13, 12:00 #20
Si, ho provato anch'io con l'artifizio indicato da Max ma non ha funzionato però puoi risolvere in maniera meno elegante con un altro artificio ovvero basta che aggiungi alla definizione della HistVol una piccola ininfluente quantità infinitesimale in modo che il risultato sia sempre diverso da zero e non ci sono problemi poi di divisione al denominatore nella successiva definizione della DeltaHistVol.
la riga diventa quindi
SET HistVol= SDV(CLOSE, 30, 1, SIMPLE)+0.0001
tutto il resto rimane invariato
ApoUltima modifica di Apocalips; 22-10-13 alle 12:16
....non si desidera ciò che è facile ottenere (Ovidio)....