# Projekt : Terminál pre odomykanie / zamykanie dverí pomocou PIN kódu

# Členovia tímu

Baránek Michal, Bartoň Jan, Bařina Tadeáš, Bekeč Alexander

Odkaz na zložku s projektom: https://github.com/xbarto0c/Digital-electronics-1/tree/main/Labs/Project\_code\_lock/DE1\_project\_code\_lock

# Ciele projektu

Cieľom projektu bolo navrhnúť terminál pre odomykanie dverí pomocou štvromiestneho PIN kódu. Projekt mal obsahovať tlačidlá pre zadávanie PIN kódu, štyri sedemsegmentové dipleje pre zobrazenie hesla a relé pre ovladanie zámku.

# Popis hardvéru

Základným hardvérom projektu je doska Arty A7-35T. Nakoľko táto doska neobsahuje niektoré súčasti, ktoré boli potrebné pri návrhu projektu, bola navrhnutá periféria - DPS obsahujúca potrebné súčasti (sedemsegmentový dispej, tlačidlá pre zadávanie PIN kódu s CR článkami pre vytvorenie pulzu pri stlačení tlačidla, piezo bzučiak, relé...):







# Popis a simulácia VHDL modulov

Upozornenie: Všetky moduly majú upravené pomery a trvania pre účely simulácie, preto simulácie ukazujú hlavný princíp a nie presný beh projektu a modulov.

# clock\_divider

Odkaz na zdrojový kód: https://github.com/xbarto0c/Digital-electronics-1/blob/main/Labs/Project\_code\_lock/DE1\_project\_code\_lock/DE1\_project\_code\_lock.srcs/sources\_1/new/clock\_divider.vhd

Popis: Modul clock\_divider delí frekvenciu hodinového signálu, teda vytvára signál s menšou frekvenciou ako samotný hodinový signál.

#### Simulácia:



# clock\_enable

Odkaz na zdrojový kód: https://github.com/xbarto0c/Digital-electronics-

1/blob/main/Labs/Project\_code\_lock/DE1\_project\_code\_lock/DE1\_project\_code\_lock.srcs/sources\_1/new/clock \_enable.vhd

Popis: Modul clock\_enable vytvára pulz po priebehu určitého počtu periód hodinového signálu.

#### Simulácia:



# cnt\_up\_down

Odkaz na zdrojový kód: https://github.com/xbarto0c/Digital-electronics-

1/blob/main/Labs/Project\_code\_lock/DE1\_project\_code\_lock/DE1\_project\_code\_lock.srcs/sources\_1/new/cnt\_up\_down.vhd

Popis: Modul cnt\_up\_down je up/down bitový čítač.

#### Simulácia:



# display\_driver\_7seg\_4digits

Odkaz na zdrojový kód: https://github.com/xbarto0c/Digital-electronics-1/blob/main/Labs/Project\_code\_lock/DE1\_project\_code\_lock/DE1\_project\_code\_lock.srcs/sources\_1/new/display\_driver7seg\_digit.vhd

Popis: Modul display\_driver\_7seg\_4digits je ovladač štvromiestneho sedemsegmentového dipleja. Vyberá spravnú pozíciu čísla a časovanie výstupov.

#### Simulácia:



# door\_lock\_core

Odkaz na zdrojový kód: https://github.com/xbarto0c/Digital-electronics-1/blob/main/Labs/Project\_code\_lock/DE1\_project\_code\_lock/DE1\_project\_code\_lock.srcs/sources\_1/new/door\_lock\_core.vhd

Popis: Modul door\_lock\_core je v podstate hlavným modulom celého projektu. rieší spracovanie PIN kódu, jeho kontrolu, zmenu na nový PIN kód, spúšťanie a kontrolu RGB diódy, piezo bzučiaka, spínanie relé. Jeho

#### jadro tvorí stavový automat:



#### Simulácia:





# hex\_7\_seg

Odkaz na zdrojový kód: https://github.com/xbarto0c/Digital-electronics-1/blob/main/Labs/Project\_code\_lock/DE1\_project\_code\_lock/DE1\_project\_code\_lock.srcs/sources\_1/new/hex\_ 7\_seq.vhd

Popis: Modul hex\_7\_seg je dekodérom štvorbitového výstupu na výstup pre ovladanie sedemsegmentového displeja. Pre účely použitia v tomto projekte bol výstup pre A zmenený na - (pomĺčku) a B na prázdny displej.

#### Simulácia:



# keyboard\_decoder

Odkaz na zdrojový kód: https://github.com/xbarto0c/Digital-electronics-1/blob/main/Labs/Project\_code\_lock/DE1\_project\_code\_lock/DE1\_project\_code\_lock.srcs/sources\_1/new/keyboard\_decoder.vhd

Popis: Modul keyboard\_decoder prijíma výstupy jednotlivých tlačidiel, ktoré následne spojí do jedného signálu, ktorý dekóduje na štvorbitový reťazec pre modul door\_lock\_core. Modul má "zabudovanú" ochranu

proti stlačeniu dvoch tlačidiel naraz.

#### Simulácia:



# mux\_2to1

Odkaz na zdrojový kód: https://github.com/xbarto0c/Digital-electronics-1/blob/main/Labs/Project\_code\_lock/DE1\_project\_code\_lock/DE1\_project\_code\_lock.srcs/sources\_1/new/mux\_ 2to1.vhd

Popis: Modul mux\_2to1 je multiplexer s dvoma datovými vstupmi (jednobitovými), jedným vstupom rozhodovacím (tiež jednobitový) a jedným výstupom.

#### Simulácia:



# piezo\_driver

Odkaz na zdrojový kód: https://github.com/xbarto0c/Digital-electronics-1/blob/main/Labs/Project\_code\_lock/DE1\_project\_code\_lock/DE1\_project\_code\_lock.srcs/sources\_1/new/piezo\_driver.vhd

Popis: Modul piezo\_driver je ovládač piezo bzučiaka. Generuje obdlžníkový signál s frekvenciou 1000 Hz a zároveň podľa dvojbitového vstupu (mode\_i) rozhoduje, či má byť výstup nulový, konštantný tón alebo pípanie (prepínanie medzi stavom vypnutý - konštantný tón)

#### Simulácia:



# Popis a simulácia TOP modulu

Odkaz na zdrojový kód: https://github.com/xbarto0c/Digital-electronics-

1/blob/main/Labs/Project\_code\_lock/DE1\_project\_code\_lock/DE1\_project\_code\_lock.srcs/sources\_1/new/top.v hd



V rámci top modulu sa prijímajú vstupy z periférie (hlavne výstupy tlačidiel) a hodinový signál z hlavnej dosky. Pulzy z tlačidiel sú spracované dekodérom keyboard\_decoder na štvorbitový výstup, ktorý je pripojený na vstup modulu door\_lock\_core, kde sa tento vstup postupne zapisuje na jednotlivé pozície zadávaného hesla, overí sa platnosť a na základe toho sa presúva do požadovaného stavu. Postupným chodom medzi stavami sú určené aj jednotlivé výstupy, ktoré sú pripojené na prislušné výstupy top modulu (RGB LED dióda, piezo bzučiak, relé), prípadne na dekóder a ovladač štvromiestneho sedemsegmentového displeja, ktorého výstup je následne pripojený na výstupy top modulu pre displej.

#### Simulácia:







# Video

# Referencie

Informácie a nápady boli čerpané prevažne z predošlých počítačových cvičení.