Jméno: Michal Wagner

Login: xwagne12

Architektura navrženého obvodu (na úrovni RTL)

# Schéma obvodu



# Popis funkce

Obvod se řídí podle signálů z FSM, který přijímá příchozí bity z DIN. Nastavuje výstupy RECIEVE\_EN a COUNTER\_EN. Když je CLOCK v polovině prvního vstupního bitu (8b), tak se CNT1 vynuluje a poté se začnou postupně zapisovat vstupní bity na výstup. CNT1 se navyšuje po 16ti CLOCK a na výstup zapíše vstupní bit, pokud je povolen RECIEVE\_EN, tak je zapnut DMUX. DMUX na výstup posílá aktuální hodnotu DIN na pozici danou CNT2 (0-7).

# Návrh automatu (Finite State Machine)

#### Schéma automatu



## Legenda:

- Stavy automatu: WAIT\_START\_BIT, WAIT\_FIRST\_BIT, RECIEVE\_DATA, WAIT STOP BIT, DATA VALID
- Vstupní signály: DIN, CNT1, CNT2, RST, CLK
- Moorove výstupy: RECIEVE EN, COUNTER EN, DOUT VALID

## Popis funkce

Automat čeká ve stavu WAIT\_START\_BIT, dokud není DIN = 0, což signalizuje START bit. Pokud bude DIN=1, tak se stav nezmění. Poté se přepne do stavu WAIT\_FIRST\_BIT a na přechod do následujícího stavu je potřeba, aby počítadlo CNT1 bylo rovné 16 (po 16hodinových cyklech načte 1 bit a čteme v midbit) a přepíná se do RECIEVE\_DATA. V tomto stavu je potřeba, aby CNT2 mělo hodnotu 8 (načítá celkem 8 bitů). Na každý RECIEVE\_DATA je čekání 16hodinových cyklů. Přepíná se do WAIT\_STOP\_BIT, kde čeká až DIN=1 (STOP bit). Následně se přepne do stavu DATA\_VALID a znovu do stavu WAIT\_START\_BIT, kde čeká na zahájení dalšího vysílání.

# Snímky simulace



