![]() |
ma se il problema non fosse nello sketch ma dovuto alla mancanza di un filtro passa basso? oppure un toroide intorno ai fili dei segnali in entrata? :unsure: per ipotesi una resitenza in serie al segnale e un condensatore tra segnale e ground? però non so determinare quali valori per questi componenti. sparo bischerate? |
Buon giorno, ieri sera avevo un po' di tempo e ho fatto qualche prova... La macchina a stati non l'ho analizzata perché non credo porti beneficio in questa applicazione (ovviamente è solo un mio parere) ma con uno sketch nuovo, quindi privo dei calcoli, ho riscontrato un particolare: Facendo leggere all'arduino un canale solo, I valori sono corretti e senza disturbi, mentre, facendo leggere due canali, i valori letti sono molto sballati e si rivelano precisi su un canale solo scollegando fisicamente il pin dell'altro canale mentre arduino esegue le letture. Stessa cosa sul secondo canale scollegando il pin del primo. Se la lettura non è affidabile non può esserlo nemmeno il risultato quindi sarebbe meglio utilizzare un codice che lavori direttamente sul micro, quindi senza l'ausilio delle librerie che sicuramente hanno i propri limiti. Inviato dal mio PRA-LX1 utilizzando Tapatalk |
Citazione:
:yeah: |
Citazione:
Per l'applicazione in oggetto vedrei molto meglio un PIC od un ARM, la differenza di costo dei componenti è risibile ed anche per questi micro gli ambienti di sviluppo sono gratuiti ed esiste moltissima documentazione in rete ed anche alcune librerie (spesso sviluppate dalle case costruttrici) decenti. Ho sempre sostenuto che Arduino è stata una grande idea ma ha generato un effetto collaterale: quello di far credere a molti di svegliarsi una mattina e saper sviluppare firmware e nel caso del modellismo senza neanche avere le basi del HW. :yeah: |
Forse è un'idea malsana ma una strada percorribile potrebbe essere quella di far leggere solo il canale dello sterzo e dare al servo delle ruote posteriori un andamento esponenziale... Del resto in massima velocità difficilmente si porta lo stick dello sterzo a fine corsa...credo[emoji848] Con la lettura di un solo canale, dalle prove che ho fatto, mi è sembrato che i valori acquisiti siano abbastanza precisi. Inviato dal mio PRA-LX1 utilizzando Tapatalk |
Citazione:
Ma ElNonino mi hai hato un idea. invece di guardare il Software guardiamo dal lato HW (hardware) il problema. Bene facciamo gli elettronici seri (sono sempre un pochino arruggito ma ci provo) Quindi ho fatto un paio di prove Inserito il serial.print nel sofware ho verificato senza toccare la radio quali valori venissero letti da pulsein. Erano un po' ballerini ma neanche eccessivamente meno del 1% di errori. Quindi per capire se il problema fosse la radio che si fa? si piglia un vecchio ma serio oscilloscopio digitale Tektronix 100MHz e si misurano gli impulsi. Risultato? valori inchiodati quindi non e' la ricevente che genera errori. Bene e le tensioni? il segnale della radio verso il servo e' un onda quadra circa 3.5Volt compatibile con ingresso di Arduino. quindi non e' li' il problema. Proviamo a mettere i pullup? magari con un diodo? non cambia nulla quindi eliminato. Quindi dato che arduino usa per pulsein il Timer1 interno al processore, che viene usato anche per altro la soluzione sarebbe quella di usare un pulsein che adoperasse il timer2 ad esempio. Oppure… Fermiamo interrupt (blocca le interruzioni ai timer tra le altre cose) Leggiamo il valore Riabilitiamo Interrupt e... Miracolo senza mettere un processore quantistico abbiamo un valore che balla +/-1 lultima cifra.. Un milionesimo di secondo badate bene… Sto programmando un plc per lavoro (Ebbene si' lo confesso faccio questo lavoro) ma più tardi posto il codice modificato… La linea da da inserire e' la seguente: noInterrupts(); e dopo i pulsein interrupts(); per riabilitarli Provate per credere oppure aspettate un paio d'ore che produco.. Smsteves |
con un solo canale funziona perfettamente l'altro sketch, quello nel quale decidi solo la corsa e il verso. certo che a tutto gas ti trovi a dare tutto sterzo.. il senso di questa applicazione è solo quella di limitarlo proporzionalmente quando superi un certo valore del gas, altrimenti va benissimo l'altra dove il gas non è collegato. mi riferisco a questa che funziona benissimo https://pastebin.com/s27QJ37c comunque la soluzione è questa Codice: #include <Servo.h> |
Ma in Arduino per iniziallizzare un array a 0 occore fare così: for ( int i=0; i<N_STORIASTERZO; i++ ) storiaSterzo[ i ] = 0; for ( int i=0; i<N_STORIAGAS; i++ ) storiaGas[ i ] = 0; Per il resto la soluzione adottata è una semplice media mobile (credo si potrebbe fare meglio anche in Wire) sul segnale d'ingresso che è evidentemente "ballerino", sarebbe da verificare il tempo di risposta all'impulso di tali filtri, considerando che il mezzo è lento non dovrebbe dare problemi. Se i campionamenti sono multipli di 2 (ed è bene che lo siano) anzichè usare la divisione spesso conviene usare lo spostamento a dx di n bit, mentre la divisone richiede diversi cicli del microprocessore lo shifright ne usa uno solo. :wink: :yeah: |
in pratica questo è un filtro. La funzione mediaStoria ( entrambe, sono uguali) funzionano un po' come se mettessi un condensatore in parallelo al filo che porta i valori: invece di darti il valore diretto lo media con i precedenti. se i valori oscillano intorno al valore 10, come 7, 9, 11, 12, 10 la loro media è 9. Se il prossimo valore fosse 13, si butta via il 7, la media diventa 11. Se il prossimo fosse 8 la media sarà 10. Quindi le oscillazioni vengono ammortizzate. Più grande è il numero di elementi che vengono conservati e meno pesa un valore difforme dagli altri, quindi tutto si stabilizza. Ma accelerando devono uscire diversi valori bassi prima che i nuovi valori alti prevalgano e alzino la media, quindi si ottiene una maggiore lentezza della risposta. Il tutto si svolge in microsecondi ad ogni giro. il ritmo effettivo lo determina pulseIn che sta fermo a misurare la linea in attesa dei fronti del segnale. questo è lo sketch ripulito dai commenti, rivisto e corretto. perfettamente stabile e funzionante. Codice: |
Eccomi di ritorno. Un po' di dati Frequenza segnale in uscita dalla radio 50 Hz (alcune anche 60Hz) numero di impulsi in un secondo quindi 50. se per fare il calcolo ne aspettiamo 2 di impulsi abbiamo un ritardo di 1sec/50cicli=20msx2=40 mS. Attendendo i 7 necessari a fare la media diventano 20*7=140 ms. Abbiamo un ritardo di 1.4 decimi di secondo.. Non va bene per la reattività giusto?:rolleyes: avete letto il post 106 ? |
| Tutti gli orari sono GMT +2. Adesso sono le 01:16. |
Basato su: vBulletin versione 3.8.11
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
E' vietata la riproduzione, anche solo in parte, di contenuti e grafica. Copyright 1998/2019 - K-Bits P.I. 09395831002