Merger DMX

Merger DMX
Pobierz PDF Download icon
W systemach DMX nierzadko jest konieczne dołączenie do sieci więcej niż jednej konsoli, choćby ze względu na zwiększenie liczby obsługiwanych urządzeń. Nie można po prostu połączyć równolegle ich zacisków wyjściowych, bo konsole będą się wzajemnie zakłócały. Konieczne jest zastosowanie mergera. Rekomendacje: urządzenie jest kontynuacją publikacji związanych z systemem DMX - przyda się osobom zajmujących się aranżacją i obsługą techniczną sceny.

Rysunek 1. Schemat ideowy Mergera DMX

Budowa mergera nie jest tak prosta, jak opisywanego w poprzednim numerze EP splittera, w którym wystarczyło "rozdzielić" sygnał na kilka wyjść, co daje się łatwo zrobić z użyciem kilku driverów MAX485.

W mergerze trzeba zsumować dwa niezsynchronizowane ze sobą strumienie DMX. Każdy ze strumieni może przenosić od 24 do 512 bajtów danych.

Funkcjonalność taką można zrealizować z użyciem mikrokontrolera mającego dwa interfejsy UART. Wskazane, aby można było ustalić, jaką część strumienia wykorzystują poszczególne wejścia, co umożliwi połączenie kaskadowe wielu mergerów. Do skonfigurowania takiego urządzenia, co prawda, wystarczyłyby zworki, ale większe możliwości daje impulsator i wyświetlacz alfanumeryczny.

Budowa i zasada działania

Listing 1. Procedura obsługi przerwania od USART0

Schemat ideowy projektu mergera DMX pokazano na rysunku 1. Napięcie zasilające 230 VAC jest obniżane w transformatorze, następnie prostowane za pomocą diod D1 i D2, po czym stabilizowane przez układ U1. Dane wejściowe konwertowane są w układach U2 i U3, a następnie trafiają na wejścia UART mikrokontrolera.

Przeważnie merger będzie jedynym urządzeniem podłączonym do konsoli czy interfejsu komputera, dlatego zworki JP2 i JP3 powinny być założone. Przekształcone dane wyjściowe z mikrokontrolera są konwertowane za pomocą U5.

Mikrokontroler steruje także alfanumerycznym wyświetlaczem LCD oraz odczytuje informacje z impulsatora. Wyświetlacz i impulsator umieszczono na osobnej płytce, zamontowanej pod kątem 90 stopni w stosunku do płyty głównej.

Jak widać, budowa urządzenia jest nieskomplikowana, program już niestety taki nie jest. Oprogramowanie mikrokontrolera odbiera dane z obu interfejsów USART i zapamiętuje je w tablicy. Obsługa USART odbywa się z użyciem przerwań. Realizuje to procedura (dla USART0) pokazana na listingu 1.

Listing 2. Kopiowanie danych do bufora nadawczego

Przy odbiorze danych z USART z użyciem mechanizmu przerwań należy pamiętać, aby zadeklarować przerwanie jako "Signal". W przeciwnym wypadku dojdzie do przepełnienia stosu, gdyż znacznik przerwania jest kasowany po zakończeniu jego obsługi, a nie po wejściu w przerwanie, tak jak to się dzieje w wypadku przerwań od timerów i innych peryferii. Jeśli konieczne byłoby przerwanie wielopoziomowe, należy postąpić w następujący sposób:

  • Zadeklarować przerwanie jako "Signal".
  • Odblokować przerwania za pomocą "sei()".
  • Obsłużyć przerwanie.

Listing 3. Generowanie sygnałów BREAK i MAB, wysłanie danych

Przerwania nie trzeba odblokowywać przy wychodzeniu z procedury jego obsługi. Dzieje się to automatycznie przy odtwarzaniu rejestru CREG.

Procedura odbiorcza jest zabezpieczona przed przepełnieniem bufora. Jak wspomniano, konsola może wysyłać od 24 do 512 bajtów danych. W zmiennej curLenDmx znajduje się liczba odebranych danych. Gdy dwa razy zostanie odebrana taka sama ich liczba (zmienna prevLenDmx), jest ona zapamiętywana w LenDmx0 dla USART0 lub LenDmx1 dla USART1.

Listing 4. Obsługa przerwania USART - wysłanie danych

Procedura odbioru danych z USART1 jest taka sama, jak z USART0. Różni się tylko nazwami rejestrów. Odebrane dane są kopiowane do bufora nadawczego. Realizuje to procedura pokazana na listingu 2.

Zależnie od zmiennej podzial jest kopiowana część pierwszego bufora odbiorczego do nadawczego. Następnie, drugi bufor odbiorczy jest kopiowany do nadawczego za danymi pierwszego bufora. Jeśli długość przekroczyłaby maksymalna liczbę danych, jest ona ograniczana. Jeśli jest mniejsza, to po wyliczeniu jest zapamiętywana w zmiennej newLen.

Listing 5. Procedura obsługi impulsatora

Procedura transmisyjna korzysta z tej zmiennej, dzięki czemu nie wysyła niepotrzebnych danych, co zwiększa częstotliwość odświeżania. Dane wysyłane są z użyciem przerwań, jednak najpierw generowane są sygnały BREAK i MAB (listing 3).

Ponadto, ta procedura wpisuje pierwszy bajt do USART, co powoduje jego wysłanie i wygenerowanie przerwania. Pozostałe dane są wysyłane z wykorzystaniem mechanizmu przerwań (listing 4).

Procedura obsługi impulsatora została zrealizowana z użyciem mechanizmu przerwań, dzięki czemu jest nieskomplikowana. Pokazano ją na listingu 5.

Wykaz elementów

Rezystory: (SMD 1206)
R2, R3, R5, R6, R9, R10: 120 Ω
R4, R8: 510 Ω
R7: 10 kΩ

Kondensatory:
C1, C4: 470 µF/16 V (elektrolit.)
Kondensatory SMD 1206:
C2, C3, C5...C8, C10, C11: 100 nF (SMD 1206)
C9, C14: 15 nF (SMD 1206)
C12, C13: 22 pF (SMD 1206)

Półprzewodniki:
U1: 7805
U2, U3, U5: MAX485
U4: ATmega1280-16AU
D1, D2: SN4007
D3: dioda LED żółta, 3 mm
D4: dioda LED, zielona, 3 mm

Inne:
P1: 10 kΩ (PT10LV pot. montażowy)
P2: ED1212S-24C24-30F (impulsator z włącznikiem, długa ośka)
Q1: 16 MHz (kwarc HC49/HC49S)
F1: F63 mA (bezpiecznik 5×20)
J1: TB-5.0-PP-2P, TB-5.0-PIN (złącze TB z listwą kołkową)
J3: listwa kątowa goldpin 1×20
J8: listwa kątowa goldpin 1×10
J4, J5: NS25-W3 (gniazdo NS25 3 pin), NS25-G3 (wtyk NS25 3 pin), NS25-T (3 szt. terminali do wtyku NS25)
XLR-3G-C: wtyk XRL-3 do obudowy
J6: NS25-W3 (gniazdo NS25 3 pin)
NS25-G3: wtyk NS25 3 pin
NS25-T: 3 szt. terminali do wtyku NS25
XLR-3G-CH: gniazdo XRL-3 do obudowy
JP4: IDC10MLP (gniazdo "wannowe" 2×5)
JP1: LCD 2×16 (wyświetlacz z listwą goldpin + gniazdo do płytki)
TR1: TZ2VA 2×9 V (transformator sieciowy, zalewany 2×9 V/100 mA)
PPIN8: podstawka precyzyjna 8 pin (3 szt.)

Montaż i uruchomienie

Rysunek 2. Schemat montażowy Mergera DMX

Schemat montażowy Mergera DMX pokazano na rysunku 2. Montaż jest typowy i nie wymaga omawiania. Jeśli płytki wykonujemy samodzielnie, to płytę główną można wykonać jako jednowarstwową. Wtedy jest konieczne zamontowanie kilkunastu zwór z drutu.

Płytkę wyświetlacza i impulsatora montujemy pod kątem 90 stopni w stosunku do płyty bazowej, za pośrednictwem goldpina kątowego. Należy zwrócić uwagę na jego typ. Szczegóły można zobaczyć na fotografii 3.

Złącze J8 zastosowano tylko w celu wzmocnienia mechanicznego płytki. Wyświetlacz montujemy na gnieździe goldpin. Po włączeniu zasilania dioda D4 powinna świecić natomiast D3 migać z częstotliwością około 1 Hz.

Na wyświetlaczu powinien pojawić się ekran powitalny. Jeśli nic nie widać lub kontrast jest za mały, regulujemy go potencjometrem P1. Pod układy MAX485 warto zastosować podstawki. Jeśli procesor nie jest zaprogramowany można to zrobić przez złącze JP4 (JTAG). Ustawienie bitów konfiguracyjnych pokazano na rysunku 4. Płytka Mergera DMX jest przystosowana do zamontowania w obudowie KM-60.

Obsługa

Fotografia 3. Sposób zamontowania płytek drukowanych

Po włączeniu zasilania pojawi się ekran powitalny, po czym ukaże się ekran roboczy, a na nim komunikat:

1: aaa* 2: bbb*
P: ccc N: ddd

Poszczególne symbole oznaczają: aaa - liczba odebranych danych na pierwszym wejściu DMX, gwiazdka za liczbą oznacza trwającą transmisję (on-line), znak minus, brak transmisji przez co najmniej 1 sekundę (off-line).
bbb - jak wyżej, ale dla wejścia drugiego.
ccc - liczba danych, które zostaną wysłane z pierwszego kanału na wyjście; za nimi zostaną przesłane dane z drugiego kanału (miejsce podziału bufora nadawczego).
ddd - liczba danych wysyłanych na wyjście.

Porada: urządzenie, które wysyła dłuższe ramki powinno być włączone do pierwszego kanału. Dzięki temu, zależnie od ustawienia mergera i liczby danych odbieranych w drugim kanale, ,merger będzie wysyłał mniej niż 512 bajtów danych, co zwiększy częstotliwość odświeżania urządzeń odbiorczych.

Rysunek 4. Ustawienie ważniejszych fusebitów

Rysunek 5. Przykładowy sposób włączenia mergerów

Kręcąc impulsatorem zmieniamy liczbę danych wysyłanych z pierwszego kanału. Tę liczbę można zmieniać z krokiem 16. Aby zapamiętać nastawę należy nacisnąć impulsator. Przykładowy sposób włączenia meregerów można zobaczyć na rysunku 5.

Sławomir Skrzyński, EP

Artykuł ukazał się w
Elektronika Praktyczna
grudzień 2014
DO POBRANIA
Pobierz PDF Download icon
Materiały dodatkowe
Elektronika Praktyczna Plus lipiec - grudzień 2012

Elektronika Praktyczna Plus

Monograficzne wydania specjalne

Elektronik styczeń 2025

Elektronik

Magazyn elektroniki profesjonalnej

Raspberry Pi 2015

Raspberry Pi

Wykorzystaj wszystkie możliwości wyjątkowego minikomputera

Świat Radio styczeń - luty 2025

Świat Radio

Magazyn krótkofalowców i amatorów CB

Automatyka, Podzespoły, Aplikacje listopad - grudzień 2024

Automatyka, Podzespoły, Aplikacje

Technika i rynek systemów automatyki

Elektronika Praktyczna styczeń 2025

Elektronika Praktyczna

Międzynarodowy magazyn elektroników konstruktorów

Elektronika dla Wszystkich styczeń 2025

Elektronika dla Wszystkich

Interesująca elektronika dla pasjonatów