codifica pacchetti NMRA
Moderatore: Seba55
-
- DCCReady
- Messaggi: 16
- Iscritto il: martedì 9 agosto 2005, 10:35
- Scala: H0
- Ho il plastico: Si
- La mia centrale digitale.: Analogico
- Località: Roma
codifica pacchetti NMRA
Salve a tutti,
Dall`articolo di Tardioli presente sul sito si dice che la codifica del bit a 1 da parte dei decoder NMRA e` dovuta a due semionde larghe 58 us e di conseguenza la codifica del bit 0 e`dovuta a due semionde larghe il doppio della precedente.
Da alcuni sorgenti che ho esaminato si specifica esattamente il contrario il bit a 0 e` quello meno largo mentre quello a 1 e` quello piu` largo.
Data l`importanza della specifica volevo sapere, da parte di chi ha implementato progetti grossi sul DCC o da qualcuno di buona volonta`, come si sono comportati rispetto a questo standard.
Grazie
Alesssandro7235
Dall`articolo di Tardioli presente sul sito si dice che la codifica del bit a 1 da parte dei decoder NMRA e` dovuta a due semionde larghe 58 us e di conseguenza la codifica del bit 0 e`dovuta a due semionde larghe il doppio della precedente.
Da alcuni sorgenti che ho esaminato si specifica esattamente il contrario il bit a 0 e` quello meno largo mentre quello a 1 e` quello piu` largo.
Data l`importanza della specifica volevo sapere, da parte di chi ha implementato progetti grossi sul DCC o da qualcuno di buona volonta`, come si sono comportati rispetto a questo standard.
Grazie
Alesssandro7235
-
- Site Admin
- Messaggi: 16428
- Iscritto il: lunedì 2 febbraio 2004, 17:25
- Scala: H0
- Ho il plastico: Si
- La mia centrale digitale.: TMWDCC TBX zDCC Lokmaus2 HornbySelect Arnold Intellibox Claudia_CommandStation
- Località: Torino
- Contatta:
Bah in più occasioni ho analizzato il segnale DCC con oscillo e questor ispecchiava le specifiche descritte sul sito.
Fondatore e amministratore di DCCWorld
http://www.DCCWorld.com - il sito dedicato interamente ai sistemi di controllo digitale per il modellismo ferroviario.
http://www.DCCWorld.com - il sito dedicato interamente ai sistemi di controllo digitale per il modellismo ferroviario.
-
- DCCReady
- Messaggi: 16
- Iscritto il: martedì 9 agosto 2005, 10:35
- Scala: H0
- Ho il plastico: Si
- La mia centrale digitale.: Analogico
- Località: Roma
Beh allora non ci dovrebbero essere dubbi.
0 largo
1 stretto
Se dai uno sguardo al sorgente nmra.c del progetto DDl linux noterai nella sezione iniziale dei commenti e precisamente alla riga 73 questa dicitura:
NMRA-0-Bit: 01 (52 usec low and 52 usec high)
NMRA-1-Bit: 0011 (at least 100 usec low and high)
il che significa
0 stretto
1 largo.
In effetti sul sorgente ci sono molte cose oscure, (innanzi tuuto non riesce a tradurre secondo le teorie dell`autore tutti i pacchetti DCC, e questa e` una cosa che non capisco proprio come abbia fatto) per cui penso che Tardioli abbia ragione. Altre conferme sono bene accette.
Grazie
Ale7235
0 largo
1 stretto
Se dai uno sguardo al sorgente nmra.c del progetto DDl linux noterai nella sezione iniziale dei commenti e precisamente alla riga 73 questa dicitura:
NMRA-0-Bit: 01 (52 usec low and 52 usec high)
NMRA-1-Bit: 0011 (at least 100 usec low and high)
il che significa
0 stretto
1 largo.
In effetti sul sorgente ci sono molte cose oscure, (innanzi tuuto non riesce a tradurre secondo le teorie dell`autore tutti i pacchetti DCC, e questa e` una cosa che non capisco proprio come abbia fatto) per cui penso che Tardioli abbia ragione. Altre conferme sono bene accette.
Grazie
Ale7235
-
- Site Admin
- Messaggi: 16428
- Iscritto il: lunedì 2 febbraio 2004, 17:25
- Scala: H0
- Ho il plastico: Si
- La mia centrale digitale.: TMWDCC TBX zDCC Lokmaus2 HornbySelect Arnold Intellibox Claudia_CommandStation
- Località: Torino
- Contatta:
Personalmente non ho guardato il sorgente..greenant potrebbe aiutarti,
In ogni caso non fare riferimento alla traduzione italiana di Tardioli ma guarda le specifiche direttametne su www.dcc.info
In ogni caso non fare riferimento alla traduzione italiana di Tardioli ma guarda le specifiche direttametne su www.dcc.info
Fondatore e amministratore di DCCWorld
http://www.DCCWorld.com - il sito dedicato interamente ai sistemi di controllo digitale per il modellismo ferroviario.
http://www.DCCWorld.com - il sito dedicato interamente ai sistemi di controllo digitale per il modellismo ferroviario.
-
- DCCReady
- Messaggi: 16
- Iscritto il: martedì 9 agosto 2005, 10:35
- Scala: H0
- Ho il plastico: Si
- La mia centrale digitale.: Analogico
- Località: Roma
Thank you Bud,
Ho visto le specifiche NMRA, credo che la traduzione del Tardioli sia esatta
1 stretto
0 largo.
Probabilmente il sorgente fa riferimento a specifiche vecchie, e` probabile che ci siano degli aggiornamenti in altre sezioni del codice. Se non ci sono credo che il sistema DDL linux non possa piu` funzionare con i nuovi standard.
ciao
Ho visto le specifiche NMRA, credo che la traduzione del Tardioli sia esatta
1 stretto
0 largo.
Probabilmente il sorgente fa riferimento a specifiche vecchie, e` probabile che ci siano degli aggiornamenti in altre sezioni del codice. Se non ci sono credo che il sistema DDL linux non possa piu` funzionare con i nuovi standard.
ciao
-
- Site Admin
- Messaggi: 16428
- Iscritto il: lunedì 2 febbraio 2004, 17:25
- Scala: H0
- Ho il plastico: Si
- La mia centrale digitale.: TMWDCC TBX zDCC Lokmaus2 HornbySelect Arnold Intellibox Claudia_CommandStation
- Località: Torino
- Contatta:
Lo standard è cosi da parecchi anni e le DDL vanno.
Forse c'è da studiare meglio il software.
Forse c'è da studiare meglio il software.
Fondatore e amministratore di DCCWorld
http://www.DCCWorld.com - il sito dedicato interamente ai sistemi di controllo digitale per il modellismo ferroviario.
http://www.DCCWorld.com - il sito dedicato interamente ai sistemi di controllo digitale per il modellismo ferroviario.
-
- DCCReady
- Messaggi: 16
- Iscritto il: martedì 9 agosto 2005, 10:35
- Scala: H0
- Ho il plastico: Si
- La mia centrale digitale.: Analogico
- Località: Roma
-
- Site Admin
- Messaggi: 16428
- Iscritto il: lunedì 2 febbraio 2004, 17:25
- Scala: H0
- Ho il plastico: Si
- La mia centrale digitale.: TMWDCC TBX zDCC Lokmaus2 HornbySelect Arnold Intellibox Claudia_CommandStation
- Località: Torino
- Contatta:
Svelato l'arcano ?
Fondatore e amministratore di DCCWorld
http://www.DCCWorld.com - il sito dedicato interamente ai sistemi di controllo digitale per il modellismo ferroviario.
http://www.DCCWorld.com - il sito dedicato interamente ai sistemi di controllo digitale per il modellismo ferroviario.
-
- DCCReady
- Messaggi: 16
- Iscritto il: martedì 9 agosto 2005, 10:35
- Scala: H0
- Ho il plastico: Si
- La mia centrale digitale.: Analogico
- Località: Roma
-
- DCCReady
- Messaggi: 16
- Iscritto il: martedì 9 agosto 2005, 10:35
- Scala: H0
- Ho il plastico: Si
- La mia centrale digitale.: Analogico
- Località: Roma
Stufo di aspettare risposte mi sono messo a scrivere un algoritmo in PHP che compone e codifica i pacchetti DCC secondo le norme NMRA e successivamente li scrive sulla porta seriale di un PC.
Per il momento l`applicazione che ho creato contiene un pannello di controllo, attivabile tramite un browser web, in cui e` possibile comporre:
1) pacchetti per il controllo della velocita` e direzione in un decoder, ad indirizzamento 7 bit, impostato per 14/28/128 step.
2) pacchetti per il controllo luci e funzioni F1-F4
3) pacchetti per il controllo funzioni F5-F8
4) pacchetti per il controllo di un decoder accessorio, ad indirizzamento 9 bit, 8 funzioni.
L`applicazione contiene un server, attivabile sempre tramite browser web, che legge i pacchetti e li scrive sulla porta seriale del PC.
Chiaramente si tratta di una applicazione in bozza notevolmente migliorabile in cui si possono aggiungere anche algoritmi per la composizione e la codifica dei pacchetti per il service mode (lettura e scrittura CV).
Prima di effettuare miglioramenti avrei bisogno di testare l`applicazione su di un sistema digitale, siccome io ne sono sprovvisto vi chiederei se c-e` una persona di buona volonta`che in zona Roma mi potrebbe aiutare a tetstarlo (magari successivamente per questo attivero` un topic apposito).
Come potete capire e` importantissimo verificarne il funzionamento per vedere se e` il caso di andare avanti e correggere gli errori fatti.
Ciao a tutti.
Per il momento l`applicazione che ho creato contiene un pannello di controllo, attivabile tramite un browser web, in cui e` possibile comporre:
1) pacchetti per il controllo della velocita` e direzione in un decoder, ad indirizzamento 7 bit, impostato per 14/28/128 step.
2) pacchetti per il controllo luci e funzioni F1-F4
3) pacchetti per il controllo funzioni F5-F8
4) pacchetti per il controllo di un decoder accessorio, ad indirizzamento 9 bit, 8 funzioni.
L`applicazione contiene un server, attivabile sempre tramite browser web, che legge i pacchetti e li scrive sulla porta seriale del PC.
Chiaramente si tratta di una applicazione in bozza notevolmente migliorabile in cui si possono aggiungere anche algoritmi per la composizione e la codifica dei pacchetti per il service mode (lettura e scrittura CV).
Prima di effettuare miglioramenti avrei bisogno di testare l`applicazione su di un sistema digitale, siccome io ne sono sprovvisto vi chiederei se c-e` una persona di buona volonta`che in zona Roma mi potrebbe aiutare a tetstarlo (magari successivamente per questo attivero` un topic apposito).
Come potete capire e` importantissimo verificarne il funzionamento per vedere se e` il caso di andare avanti e correggere gli errori fatti.
Ciao a tutti.
-
- Site Admin
- Messaggi: 16428
- Iscritto il: lunedì 2 febbraio 2004, 17:25
- Scala: H0
- Ho il plastico: Si
- La mia centrale digitale.: TMWDCC TBX zDCC Lokmaus2 HornbySelect Arnold Intellibox Claudia_CommandStation
- Località: Torino
- Contatta:
Complimenti per il tuo lavoro. Ma ti so un suggerimento dettatomi dall'esperienza che do a te ma ho anche dato a chi ti ha preceduto. Prima di intraprendere la progettazione di un sistema digitale è meglio fare qualche piccola esperienza co con qualcosa di commerciale o con progetto diy già realizzato da qualcuno.
La tua domanda sinceramente è poco chiara. Mi sembra di aver capito che esci dalla seriale già con l'onda quadra DCC quinti non ti serve un sistema digitale (poi quale?) ma ti basta un semplice booster ed una locomotiva dotata di decoder. Ma in ogni caso puoi iniziare le prove utilizzando lo showdcc collegato direttamente alla seriale.Prima di effettuare miglioramenti avrei bisogno di testare l`applicazione su di un sistema digitale, siccome io ne sono sprovvisto vi chiederei se c-e` una persona di buona volonta`che in zona Roma mi potrebbe aiutare a tetstarlo (magari successivamente per questo attivero` un topic apposito).
Fondatore e amministratore di DCCWorld
http://www.DCCWorld.com - il sito dedicato interamente ai sistemi di controllo digitale per il modellismo ferroviario.
http://www.DCCWorld.com - il sito dedicato interamente ai sistemi di controllo digitale per il modellismo ferroviario.
-
- DCCReady
- Messaggi: 16
- Iscritto il: martedì 9 agosto 2005, 10:35
- Scala: H0
- Ho il plastico: Si
- La mia centrale digitale.: Analogico
- Località: Roma
Certo esco gia` con un`onda quadra, verificata tramite oscillo, che rispetta le codifiche NMRA per quello che e` possibile.
Quando dico per quello che e` possibile mi reiferisco al fatto che non tutti i pacchetti NMRA sono perfettamente traducibili perche` la seriale inserisce dei bit per conto suo (start e stop).
Ad esempio se devo trasmettere questa sequenza di bit 11111 non ho problemi perche` la seriale con l`ausilio dei bit di start e stop origina l`onda quadra che identifica l`esatta sequenza di bit leggibile dal decoder.
* _* _* _* _* _
_| |_| |_| |_| |_|
Ma se devo trasmettere questa sequenza 11110 con il quinto bit meno significativo pari a 0, devo trasmettere questa sequenza per incastrare i bit di start e stop della seriale
* _* _* _* _* __
_| |_| |_| |_| .... |__
questa sequenza di bit, in particolare gli ultimi cinque bit (di cui gli ultimi 4 cadono nel byte successivo), origina sequenze di onde quadre non previste nelle specifiche NMRA, per cui i decoder potrebbero non valutare il bit pari a 0 e rendere intraducibile il comando. Nelle specifiche si parla di streched 0 bit che fortunatamente mi permette di tradurre con sicurezza la maggioranza dei pacchetti ma questo non e` uno streched 0 bit dovrebbe essere uno 0 bit.
Se non fosse per questo problema sicuramente l`applicazione funzionerebbe per tutti i pacchetti altrimenti avrebbe dei problemi a codificare i byte in cui si associano 4 bit consecutivi ad 1 con il quinto bit pari a 0.
Per questo, quando nel precedente messaggio parlavo di sistema digitale mi riferivo all`opportunita` di provare l-applicazione, riguardo solo a questo possibile problema, su di un plastico o piu` semplicemente su di un ovale con una locomotiva provvista di decoder.
Non ho la possibilita soprattutto per mancanza di spazio di costruire o comprare un sistema digitale rudimentale, anche per questo chiedevo un possibile aiuto.
Solo in questo modo posso verificare cosa fa il decoder quando riceve un`onda quadra formattata in quella maniera, se legge il bit 0 allora l`applicazione e`perfetta e non necessita altri interventi strutturali, per cui si potrebbe pensare di ampliarla, altrimenti l-applicazione contiene dei bug ma funzionerebbe bene per la stragrande maggioranza dei pacchetti.
ciao a tutti e a presto.
Quando dico per quello che e` possibile mi reiferisco al fatto che non tutti i pacchetti NMRA sono perfettamente traducibili perche` la seriale inserisce dei bit per conto suo (start e stop).
Ad esempio se devo trasmettere questa sequenza di bit 11111 non ho problemi perche` la seriale con l`ausilio dei bit di start e stop origina l`onda quadra che identifica l`esatta sequenza di bit leggibile dal decoder.
* _* _* _* _* _
_| |_| |_| |_| |_|
Ma se devo trasmettere questa sequenza 11110 con il quinto bit meno significativo pari a 0, devo trasmettere questa sequenza per incastrare i bit di start e stop della seriale
* _* _* _* _* __
_| |_| |_| |_| .... |__
questa sequenza di bit, in particolare gli ultimi cinque bit (di cui gli ultimi 4 cadono nel byte successivo), origina sequenze di onde quadre non previste nelle specifiche NMRA, per cui i decoder potrebbero non valutare il bit pari a 0 e rendere intraducibile il comando. Nelle specifiche si parla di streched 0 bit che fortunatamente mi permette di tradurre con sicurezza la maggioranza dei pacchetti ma questo non e` uno streched 0 bit dovrebbe essere uno 0 bit.
Se non fosse per questo problema sicuramente l`applicazione funzionerebbe per tutti i pacchetti altrimenti avrebbe dei problemi a codificare i byte in cui si associano 4 bit consecutivi ad 1 con il quinto bit pari a 0.
Per questo, quando nel precedente messaggio parlavo di sistema digitale mi riferivo all`opportunita` di provare l-applicazione, riguardo solo a questo possibile problema, su di un plastico o piu` semplicemente su di un ovale con una locomotiva provvista di decoder.
Non ho la possibilita soprattutto per mancanza di spazio di costruire o comprare un sistema digitale rudimentale, anche per questo chiedevo un possibile aiuto.
Solo in questo modo posso verificare cosa fa il decoder quando riceve un`onda quadra formattata in quella maniera, se legge il bit 0 allora l`applicazione e`perfetta e non necessita altri interventi strutturali, per cui si potrebbe pensare di ampliarla, altrimenti l-applicazione contiene dei bug ma funzionerebbe bene per la stragrande maggioranza dei pacchetti.
ciao a tutti e a presto.
-
- Site Admin
- Messaggi: 16428
- Iscritto il: lunedì 2 febbraio 2004, 17:25
- Scala: H0
- Ho il plastico: Si
- La mia centrale digitale.: TMWDCC TBX zDCC Lokmaus2 HornbySelect Arnold Intellibox Claudia_CommandStation
- Località: Torino
- Contatta:
Usa lo showdcc., praticamente è un decoder software che su PC ti fa vedere i pacchetti ricevuti.Per questo, quando nel precedente messaggio parlavo di sistema digitale mi riferivo all`opportunita` di provare l-applicazione, riguardo solo a questo possibile problema, su di un plastico o piu` semplicemente su di un ovale con una locomotiva provvista di decoder.
Fondatore e amministratore di DCCWorld
http://www.DCCWorld.com - il sito dedicato interamente ai sistemi di controllo digitale per il modellismo ferroviario.
http://www.DCCWorld.com - il sito dedicato interamente ai sistemi di controllo digitale per il modellismo ferroviario.
-
- DCCReady
- Messaggi: 16
- Iscritto il: martedì 9 agosto 2005, 10:35
- Scala: H0
- Ho il plastico: Si
- La mia centrale digitale.: Analogico
- Località: Roma
In pratica se ho capito bene:
1) dalla porta seriale faccio uscire un pacchetto contenente, in un byte, questa sequenza di bit NMRA 11110 mediante le relative onde quadre.
2) il booster riceve l`onda quadra e la manda amplificata su di un singolo binario
3) lo strumentino showDCC insieme con il relativo software legge l-onda sul binario e la trasforma nella sequenza di bit, alla stessa maniera di come avrebbe fatto un decoder di una locomotiva. Se visualizzo sul PC mediante il software showDCC la sequenza 11110 allora e` tutto corretto altrimenti no ed il decoder avrebbe reagito fregandosene completamente del comando che avrei voluto dare alla locomotiva oppure lo avrebbe valutato in un comando diverso
E` corretto tutto cio`?
Se e` corretto allora ho bisogno di:
1) un booster?
2) un binario?
3) dovrei costruirmi lo strumentino disegnato sull`help di showDCC
Vi saluto ragazzi e vi ringrazio per la pazienza di leggere i miei messaggi.
1) dalla porta seriale faccio uscire un pacchetto contenente, in un byte, questa sequenza di bit NMRA 11110 mediante le relative onde quadre.
2) il booster riceve l`onda quadra e la manda amplificata su di un singolo binario
3) lo strumentino showDCC insieme con il relativo software legge l-onda sul binario e la trasforma nella sequenza di bit, alla stessa maniera di come avrebbe fatto un decoder di una locomotiva. Se visualizzo sul PC mediante il software showDCC la sequenza 11110 allora e` tutto corretto altrimenti no ed il decoder avrebbe reagito fregandosene completamente del comando che avrei voluto dare alla locomotiva oppure lo avrebbe valutato in un comando diverso
E` corretto tutto cio`?
Se e` corretto allora ho bisogno di:
1) un booster?
2) un binario?
3) dovrei costruirmi lo strumentino disegnato sull`help di showDCC
Vi saluto ragazzi e vi ringrazio per la pazienza di leggere i miei messaggi.