Punti di swing statici
Forums › ProRealTime forum Italiano › Supporto ProBuilder › Punti di swing statici
- This topic has 20 replies, 4 voices, and was last updated 8 years ago by Rorschack.
-
-
01/04/2017 at 11:40 PM #19878
Salve,
avrei bisogno di qualche suggerimento per poter creare un indicatore che riesca a disegnare le linee di swing come nello screenshot allegato. Ho creato una versione che disegna le linee in base a minimi e massimi precedenti ma non riesco a capire come faccio a prendere in considerazione solo un determinato periodo storico ( numero di candele ) e come faccio a disegnare una linea solo se il minimo/massimo è stato rimbalzato/respinto più di una volta, nell’intervallo di n candele.
Spero qualcuno possa aiutarmi! Grazie
1 user thanked author for this post.
01/04/2017 at 11:49 PM #1988101/06/2017 at 4:31 PM #20067Questo è un indicatore interessante e sono abbastanza sicuro che un sacco di gente sarà felice di usare e contribuire a migliorarla. Sembra che si è già fatto il codice per disegnare queste linee sul grafico? Al fine di aiutare voi, vi preghiamo di condividere il codice qui e saremo in grado di modificare di conseguenza agli ultimi periodi X.
Circa i rimbalzi sul livello dei prezzi, è un po ‘più difficile, ho avuto le idee per recuperarli però .. vedremo.
01/07/2017 at 9:23 AM #20099@RORSCHACK
CIAO,
GRAZIE PER AVER INIZIATO QUESTA DISCUSSIONE, L’INDICATORE CHE STAI CERCANDO DI CREARE PERMETTEREBBE DI SVILUPPARE MOLTE STRATEGIE, E MOLTO INTERESSANTE.
QUALCHE TEMPO FA’ AVEVO PROVATO MA NON CI ERO RIUSCITO, POTRESTI CONDIVIDERLO?
GRAZIE
ALE
01/07/2017 at 9:35 PM #20140In effetti anch’io ho delle strategie profittevoli e semplici che vorrei automatizzare, che però necessitano di questi punti di swing statici. Per poterle automatizzare, ho bisogno di creare questo indicatore.
Premetto che non ho molto esperienza nella programmazione con PRT ed il codice che sto postando è un po pesante e non è proprio pulito ma facendo varie prove ho visto che le linee che io individuo manualmente, vengono individuate anche dall’indicatore. Il problema è che andrebbero filtrate ulteriormente.
Allora, il codice che è questo:
12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273//vars//n = 21 // periodo per calcolare i massimi ed i minimi precedenti//tolleranza = 10 // (dovrebbe essere espresso in punti )se ci sono due (o più) linee che sono vicine allora mi devi disegnare una linea media//lisciatura = 13DEFPARAM CalculateOnLastBars = 350 //per il calcolo delle swing lines prendiamo in considerazione solamente le ultime X candeleonce linear = 0once lineas = 0once newlinear = 0once newlineas = 0once newlinearr = 0once newlineass = 0resistenze = highest[n]((close+high)/2) // resistenze ( massimi precedenti dove i prezzi sono stati respinti)supporti = lowest[n]((close+low)/2) // supporti ( minimi precedenti dove i prezzi sono stati rimbalzati)if resistenze[n-lisciatura] = resistenze[1] thenlinear = (resistenze[1] + linear) / 2elselinear = linearendif//drawhline(linear) coloured(255,0,0)if supporti[n-lisciatura] = supporti[1] thenlineas = (supporti[1] + lineas) / 2elselineas = lineasendif//drawhline(lineas) coloured(0,255,0)if linear[2] = linear[1] and linear[1] = linear then//drawhline(linear) coloured(255,0,0)newlinear = linearendifif lineas[2] = lineas[1] and lineas[1] = lineas then//drawhline(lineas) coloured(0,255,0)newlineas = lineasendifi = 0valsup = newlinear + tolleranzavalinf = newlinear - tolleranzawhile i <> 350 doif newlinear[i] = 0 then//aiuta ad accorciare il ciclobreakendifcond = (newlinear[i] <= valsup and newlinear[i] >= valinf) or (newlineas[i] <= valsup and newlineas[i] >= valinf)if cond thennewlinearr = (newlinear[i] + newlinear)/2endifi = i+1wendi = 0valsup = newlineas + tolleranzavalinf = newlineas - tolleranzawhile i <> 350 doif newlineas[i] = 0 then//aiuta ad accorciare il ciclobreakendifcond = (newlineas[i] <= valsup and newlineas[i] >= valinf) or (newlinear[i] <= valsup and newlinear[i] >= valinf)if cond thennewlineass = (newlineas[i] + newlineas)/2endifi = i+1wenddrawhline(newlinearr) coloured(0,125,255)drawhline(newlineass) coloured(0,125,255)return newlinearr as "R", newlineass as "S"01/07/2017 at 9:45 PM #20141La variabile “tolleranza” dovrebbe essere espressa in pips anzichè in dollari o qualunque sia la valuta utilizzata. Qualcuno sa come si può fare?
Le mie prove le sto facendo sul grafico del Caffè (KC) per comodità.
Come si può vedere nello screenshot l’indicatore genera le linee blu mentre quelle viola sono state tracciate manualmente.
01/08/2017 at 11:45 AM #20161Ciao,
l’idea di base è ottima e inizio a lavorarci anch’io !!! E’ da qualche settimana che ci stavo pensando ….
Sarebbe già un’ottimo risultato riuscire ad ottenere gli stessi swing di PRT su diversi strumenti e TF; poi dovremmo capire sino a quale livello di densità vuoi scendere xchè i supporti e resistenze a volte possono essere un po’ troppo soggettivi e personalizzabili.
dovremmo impostare il codice in modo da parametrizzare il livello di densità desiderato.
per la variabile tolleranza, se ho capito bene, dovrebbe essere sufficiente utilizzare il pipsize per esprimerla in punti… poi puoi calcolare una percentuale di tolleranza o semplicemente moltiplicare il pipsize per “x” punti.
Ciao.
1 user thanked author for this post.
01/08/2017 at 1:06 PM #20167Grazie per l’invio del codice. Devo ammettere che sono davvero impressionato dal risultato del vostro indicatore! Ben fatto, davvero un buon lavoro!
A proposito di renderlo “universale” per qualsiasi strumento, è necessario modificare il codice come nella schermata allegata.01/08/2017 at 2:19 PM #20182Grazie Dany, grazie Nicolas! Per essere una prima versione in effetti i risultati non sono male.
Le tre variabili servono infatti per parametrizzare la “densità” di PRT.
Un’altra idea è quella di filtrare ulteriormente le linee disegnate in base a due o tre tf superiori. Ovvero se le linee coincidono (oppure si avvicinano con una tolleranza definita dalla variabile) su tf superiori allora vanno disegnate altrimenti no. L’unica preoccupazione è per la “pesantezza” dell’algoritmo quindi per i tempi di calcolo.
To be continued …. 🙂
01/08/2017 at 5:24 PM #20208Sono interessato a questo progetto e realtà sto lavorando su di esso. Scusate se ho perso qualcosa, ma io continuo a non capire chiaramente qual è lo scopo esatto di questo calcolo:
1(resistance[1] + linear) / 2
Cosa stai prendendo il valore lineare precedente in considerazione?
Parli inglese?01/08/2017 at 8:11 PM #20224Ho modificato il codice un po ‘(da tradurre in inglese i parametri per la mia comprensione) e il testo aggiunto di sapere quando e dove i livelli di supporto e resistenza di prezzo dove trovano e tirato. Non esitate a correggere il codice se sbaglio! 🙂
12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788DEFPARAM CalculateOnLastBars = 350 // To calculate the lines swing we take into consideration only the latest X candlesn = 20 // highest and lowest period for support/resistance fetchtolerance = 5 // should be expressed in points) if there are two (or more) lines that are close to me, then you have to draw a center linelookback = 10 // period lookback to confirm support and resistance areasshowSupport = 1//(0=false , 1=true)showResistance = 1 //(0=false , 1=true)once linear = 0once lineas = 0once newlinear = 0once newlineas = 0once newlinearr = 0once newlineass = 0if showResistance thenresistance = highest[n](high) // resistance ( massimi precedenti dove i prezzi sono stati respinti)if resistance[n-lookback] = resistance[1] thenlinear = (resistance[1] + linear) / 2elselinear = linearendifif linear[2] = linear[1] and linear[1] = linear thennewlinear = linearendifi = 0valsup = newlinear + tolerance*pointsizevalinf = newlinear - tolerance*pointsizewhile i <> 350 doif newlinear[i] = 0 then//aiuta ad accorciare il ciclobreakendifcond = (newlinear[i] <= valsup and newlinear[i] >= valinf) or (newlineas[i] <= valsup and newlineas[i] >= valinf)if cond thennewlinearr = (newlinear[i] + newlinear)/2savedbar = barindex//[i]endifi = i+1wenddrawhline(newlinearr) coloured(0,125,255)if newlinearr<>oldtextr thendrawtext("▼ #newlinearr#",savedbar,newlinearr)oldtextr=newlinearrendifendifif showSupport thensupport = lowest[n](low) // support ( minimi precedenti dove i prezzi sono stati rimbalzati)if support[n-lookback] = support[1] thenlineas = (support[1] + lineas) / 2elselineas = lineasendifif lineas[2] = lineas[1] and lineas[1] = lineas thennewlineas = lineasendifi = 0valsup = newlineas + tolerance*pointsizevalinf = newlineas - tolerance*pointsizewhile i <> 350 doif newlineas[i] = 0 then//aiuta ad accorciare il ciclobreakendifcond = (newlineas[i] <= valsup and newlineas[i] >= valinf) or (newlinear[i] <= valsup and newlinear[i] >= valinf)if cond thennewlineass = (newlineas[i] + newlineas)/2savedbar = barindex[i]endifi = i+1wenddrawhline(newlineass) coloured(0,125,255)if newlinearr<>oldtexts thendrawtext("▲ #newlineass#",savedbar,newlineass)oldtexts=newlineassendifendifRETURN01/08/2017 at 11:15 PM #2023801/08/2017 at 11:54 PM #20240Yes, Nicolas, I do speak a little bit of english, in fact I tried to post this on the english forum as well but for some reason it didn’t work out.
So my idea was to calculate these lines starting from the lows and the highs calculated on the shadows and not on the highest/lowest price.The problem is that not all the highs/lows represent an important swing line so I have to reduce the number of those lines. The purpose of this code:
12345<span class="token keyword">if</span> resistance<span class="token punctuation">[</span>n<span class="token operator">-</span>lookback<span class="token punctuation">]</span> <span class="token operator">=</span> resistance<span class="token punctuation">[</span><span class="token number">1</span><span class="token punctuation">]</span> <span class="token keyword">then</span>linear <span class="token operator">=</span> <span class="token punctuation">(</span>resistance<span class="token punctuation">[</span><span class="token number">1</span><span class="token punctuation">]</span> <span class="token operator">+</span> linear<span class="token punctuation">)</span> <span class="token operator">/</span> <span class="token number">2</span><span class="token keyword">else</span>linear <span class="token operator">=</span> linear<span class="token keyword">endif</span>is to make the indicator smoother. The variable that you called “lookback” acts more like a smoothing factor.
I would say that so far the indicator looks pretty good even though the algorithm is a bit heavy (I’m not much of an expert with PRT code). What I would like to do now is filter these lines based on other lines drawn on bigger time frames. I already have some ideas but it would get much much heavier.
Any idea on how to do that or to improve this algorithm?
Thank you for your time!
01/09/2017 at 10:52 AM #2024801/09/2017 at 1:40 PM #20257Nella versione in italiano, postata all’inizio, “lookback” l’ho chiamata “lisciatura”. Il nome spiega tutto.
Lo scopo principale dell’indicatore non è quello di “disegnare” le righe ma di rendere quei valori accessibili ad un eventuale programma e le righe disegnate non lo sono. Cosi come non lo sono le resistenze ed i supporti disegnati da ProReal Trend. Correggetemi se sbaglio.
-
AuthorPosts