Jméno: Daniil Kniazkin

Login: xkniaz00

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

### Schéma obvodu



#### Popis funkce:

RTL schéma mé implementace se skládá z FSM(Finite State Machine),dvou čítačů(CNT,D\_CNT), demultiplexora,registru a jiných malých částí.

**Konečný automat(FSM)** - přijímá **DIN** signál a na jeho základě vysílá odvetný signál také reguluje čítače a vlastní výstupek.

**CNT** - první čítač po obdržení signálu **M\_CNT\_EN** počítá cyklus **CLK.**Výstup je 5 bitový signál, který se porovnává s **22**, aby mohl poslat dál do **D\_CNT.** 

**D\_CNT** - přijímá signál **D\_CNT\_EN** pro aktivaci.Pak zpracovává signál, který byl přijat z jiného čítače.Výstup 4 bitový signál který určuje počet přijatých bitů.

Zpracované signály skončí demultiplexorem a přes **DOUT** výstup vyjdou.

## Návrh automatu (Finite State Machine)

#### Schéma automatu

Legenda:

Stavy automatu: WAIT\_START\_BIT, WAIT\_ZERO\_BIT, READ\_DATA, WAIT\_STOP\_BIT, VLD.

Vstupní signály: DIN.

Moorove vystupy: *M\_CNT,D\_CNT,DOUT\_VLD*.



#### Popis funkce:

Cyklus automatu obsahuje 4 stupně. Začíná v WAIT\_START\_BT čeká na počáteční bit, zejmena na **DIN** v log. stavu **0.** 

V takovém případě se přepne na stav *WAIT\_ZERO\_BIT* druhý stav automatu. A bude očekávat kdy **M\_CNT** bude se rovnat 22.

Třetí stav automatu je *READ\_DATA*.V něm přijímá vstupy.Přečte až do konce slova, dokud nebude **D\_CNT** roven 8 a pak se přesune do dalšího stavu.

Stav WAIT\_STOP\_BIT.Pro přechod na pristi stav je potreba M\_CNT='1000'.Pokud tak bude prijde na sledujici stav VLD a nastavit DOUT\_VLD na 1 co znamená validita vstupních údajů.A prijde zase na WAIT\_START\_BIT.

# Snímek obrazovky ze simulací

