User Tools

Site Tools


project:proj_list

Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Both sides previous revision Previous revision
Next revision
Previous revision
Last revision Both sides next revision
project:proj_list [2015/05/10 17:27]
xkubalik [Available projects]
project:proj_list [2024/02/12 12:52]
xkubalik [Current projects]
Line 2: Line 2:
 ===== Current projects ===== ===== Current projects =====
  
-  * **Softwarová podpora hardwarového rozšíření pro platformu Raspberry PI (Software library used for hardware extension of Raspberry Pi)** (BP - Vico Bohdan- Proveďte tyto úkoly: +  * **Platební terminál pro bezhotovostní platby přes nezávislý platební systém ​(Payment terminal ​for non-cash payments via an independent payment system)** (DP – Čtvrtečka Karel
-    * Prostudujte ​existující řešení.  +    * Prozkoumejte ​existující řešení ​zadané problematiky
-    * Vyberte operační systém vhodný pro ovládání a komunikaci s hardware přes rozšiřující rozhraní+    * Analyzujte možné způsoby realizace terminálu
-    * Vytvořte knihovnu funkcí v programovacím jazyce C pro ovládání jednotlivých pinů rozšiřujícího rozhraní včetně sériové linky+    * Navrhněte vlastní ​řešení terminálu a vyberte pro něj vhodnou hw platformu
-    * Propojte vývojovou desku Raspberry PI s PC s pomocí sériové linky+    * HW platforma bude podporovat použití OS Linux
-    * Pro ovládání periferií vytvořte jednoduché webové rozhraní, kde bude možné nastavovat ​číst jednotlivé stavy pinů rozhraní+    * Řešení ​bude splňovat tyto požadavky: 
-    * Umožněte s pomocí ​webového rozhraní posílat a číst informace ze sériové linky+      - Zařízení bude přenosné ​napájené z baterie
-    * Pro zvolený operační systém vytvořte aplikaci, která zprostředkovává komunikaci webového rozhraní ​hardware+      - Přehledný grafický displej. 
-    * Vytvořená aplikace bude obsahovat soubor proměnných,​ které bude možné nastavovat s pomocí webového rozhraní ​s pomocí PC přes sériovou linku+      - Ovládání terminálu bude možné s pomocí ​tlačítek
-    * Vytvořte podrobnou dokumentaci popisující důležité kroky nutné k přidání dalšího rozhraní a odpovídající modifikaci webového rozhraní.+      - Čtení RFID karet Mifare. 
 +      - Bezdrátová komunikace se serverem přes Wifi. 
 +      - Komunikace se serverem přes REST API. 
 +      - Monitorování systému ​nástroji Prometheus. 
 +      - Podpora OTA update
 +    * Navržené zařízení zrealizujte ​a řádně otestujte
 +    * Pro výsledné ​řešení napište obslužnou aplikaci demonstrující funkčnost všech částí terminálu.
  
-  * **Zařízení ​pro sledování objektu s nízkou spotřebou** ​(Low power camera trap used for property surveillance)(BP - Václav Vanc+  * **Programovatelný ​řídicí systém ​pro ovládání periferií náročných na přesné časování ​(Programmable control system ​for controlling peripherals requiring precise timing)** (BP - Fujda Martin
-    * Prostudujte ​existující řešení. +    * Prozkoumejte ​existující řešení ​zadané problematiky
-    * Navrhněte vlastní zařízení umožňující pořízení ​odeslání fotografie přes internet z okolí sledovaného objektu, který není připojen trvale k internetu ani k elektrické sítí+    * Analyzujte dostupné periférie, protokoly komunikace ​ovládaní moduly
-    * Vyberte ​vhodný procesor sloužící ke komunikaci s GSM modulem ​kamerou+    * Vyberte ​vhodnou HW platformu ​navrhněte pro ni integrační desku
-    * Důraz bude kladen ​na velmi nízkou spotřebu a co nejmenší pořizovací cenu+    * Navrhněte vlastní zařízení založené ​na zvolené architektuře
-    * Zařízení bude napájeno ​12V baterie+    * Zařízení ​se bude skládat ​z: kontroléru,​ síťového modulu, LCD TFT displeje s SD kartou
-    * Zařízení bude umožňovat data ukládat na SD kartu. +    * Zařízení bude navrhnuto tak, aby bylo možné ​připojit externí periferie ​pomocí ​nastavitelného portu
-    * Nastavení parametrů a doby snímání fotografie bude možné ​pomocí ​SMS zpráv+    * Realizujte obslužnou aplikaci pro zařízení ​periferie. 
-    * Navržené zařízení ​zrealizujte. +    * Řešení ​se bude skládat ze serverové ​části na pozadí a obslužné uživatelské části
-    * Vytvořte knihovnu funkcí umožňující ovládat dostupné ​periferie. +    * Implementujte funkční prototyp, ​řádně ho zdokumentujte a otestujte.
-    * Pro výsledné řešení ​vytvořte demonstrační aplikaci+
-    * Výsledné zařízení ​otestujte.+
  
-  * **Multiplatformní grafická aplikace pro simulaci mikroprogramovaného procesoru DOP v3(Cross-platform graphical simulator of micro-programmed processor DOP)** (DP - Miškovský Vojtěch) 
-    * Prostudujte existující řešení. 
-    * V programovacím jazyku C++ implementujte simulátor výukového procesoru DOP-v3. 
-    * Aplikaci bude možné spouštět pod OS Microsoft Windows i OS Linux. 
-    * Simulátor musí obsahovat editor mikroprogramu a překladač zdrojových mikroprogramů (mikroassembler). 
-    * Syntaxe zdrojového mikroprogramu musí být stejná jako u stávajícího simulátoru používaného pro výuku předmětu BI-JPO (jednotky počítače). 
-    * Simulátor musí umožňovat krokování mikroprogramu po jednotlivých mikroinstrukcích i spouštění úseku k zadanému bodu zastavení. 
-    * Simulátor musí umožňovat zobrazit aktuální stav jednotlivých registrů procesoru DoP a to včetně těch, které jsou programátorsky nedostupné. 
-    * Pro uživatele vytvořte jednoduchou uživatelskou příručku. 
-    * Výsledné řešení otestujte. 
  
-  * **Programovatelný stmívač světel pro domácí zvířata** (Programmable light dimmer for domestic animals)(BP - Červenka Ondřej+  * **Wireless smart cube for time tracking with application Clockify (Bezdrátová chytrá kostka určená ke sledování času s aplikací Clockify)** (BP - Sobíšek David
-    * Prostudujte existující řešení+    * Research existing solutions for wireless smart objects for easier time-tracking
-    * Vyberte vhodný procesor pro realizaci+    * Design your solution based on the ESP8266 platform
-    * Zařízení bude umožňovat nastavení stmívání pro 2 místnosti. +    * The designed solution will meet these requirements:​ 
-    * Ovládání bude možné lokálně u zařízení s pomocí displeje ​tlačítek ​také vzdáleně s pomocí PC+      - It will be tracking ​project assigned by the user to side tilted upwards
-    * Pro ovládání stmívání ​detekcí vnějšího osvětlení vytvořte knihovnu v jazyce c pro zvolený procesor+      - The user will be able to communicate with the device using WiFi. 
-    * Pro ovládání s PC vytvořte jednoduchou aplikaci+      - The tracked data will be sent to the application Clockify using their public REST API interface or stored on microSD card when WiFi is not reachable
-    * Navržené zařízení zrealizujte a vytvořenou knihovnu včetně aplikace v PC otestujte.+      - LEDs inside the device will light up to indicate the actions and states of the device. 
 +      - Its batteries will be charged wirelessly
 +    * Implement your proposed solution and adequately test it.
  
-  * **FPGA deska řízená procesorem ARM** (FPGA board controlled by ARM processor)(BP - Elena Filipenková) 
-    * Prostudujte existující řešení. 
-    * Navrhněte zařízení obsahující FPGA obvod a procesor ARM. 
-    * Zvolte vhodnou desku obsahující:​ FPGA obvod, tlačítka, přepínače,​ display. 
-    * Pro řízení FPGA obvodu použijte vývojový kit Raspberry Pi osazený obvodem ARM. 
-    * Mezi těmito obvody vytvořte komunikační linku vhodnou pro řízení FPGA obvodu s pomoci procesoru ARM. 
-    * Řízení a zjištění stavu desky bude možné s pomocí minimálně 32x16b registrů. 
-    * Vytvořte knihovnu funkcí pro FPGA desku umožňující nastavovat a ovládat základní periferie této desky procesorem ARM. 
-    * Pro FPGA desku vytvořte aplikaci umožňující zobrazovat stav registrů určených pro nastavení parametrů desky. 
-    * Pro procesor ARM vytvořte jednoduchou aplikaci umožňující nastavovat a zjišťovat stav FPGA desky. 
-    * Výsledné řešení otestujte 
  
-  * **Generátor elektrických obvodů pro předmět ČAO** ​(Automatic ​analog ​circuit generator)(BP - František Veselý+  * **Dálkově ovládaný analogový zesilovač zvuku ovládaný s pomocí IR ovladače ​(Remote controlled ​analog ​sound amplifier using an IR controller)** (BP - Vacek Kryštof
-    * Prozkoumejte existující řešení ​pro kreslení elektrických obvodů+    * Prozkoumejte existující řešení. 
-    * Vytvořte aplikaci, která bude umožňovat na základě zadaných parametrů automaticky náhodně generovat jednoduché obvody složené ze zdroje napájení, kondenzátorů,​ rezistorů a cívek. +    * Analyzujte technologii dálkového ovládání s pomocí IR ovladače
-    * Aplikace bude umožňovat nastavit hodnoty a typ součástky v obvodu+    * Navrhněte vlastní zařízení založené na mikrokontroleru ATmega
-    * Výsledné schéma bude možné překreslit tak, aby se změnila pouze pozice součástky. +    * Zařízení ​bude splňovat ​tyto požadavky:​ 
-    * Vygenerované schéma bude možné uložit do formátu XML a opětovně ​načíst+      - Ovládání bude prováděno, ​jak pomocí IR dálkového ovládání, tak na samotném zařízení ​s pomocí ​rotačního enkodéru a tlačítek
-    * Aplikace ​bude umožňovat ​popsat obvod s pomocí rovnic a to jak v časové oblasti, tak s pomocí ​fázorů+      - Zařízení ​bude zobrazovat aktuální stav nastavení zesilovače
-    * Aplikace bude dále umožňovat generovat rovnice pro celkovou impedanci na vstupních svorkách a přenos. +      - Zařízení ​bude umožňovat výběr mezi různými vstupy
-    * Vygenerované rovnice ​bude možné bez úprav vložit do programu Wolfram Mathematica ​zpracovat+    * Navržené ​řešení ​zrealizujte a řádně ​otestujte.
-    * Při generování rovnic ​bude možné zvolit směr proudu a napětí ručně, popřípadě automaticky+
-    * Výsledné ​řešení otestujte.+
  
-  * **Modul pro snímání teploty při převozu materiálu v dopravě** ​(Temperature monitoring module ​for material car transporting purpose)(BP - Jiří Šeda+  * **Kamerové zařízení pro monitorování vzdáleného prostoru pomocí ESP32-CAM a SIM800L modulů ​(Camera device ​for remote space monitoring using ESP32-CAM and SIM800L modules)** (BP - Staes Adam
-    * Prozkoumejte existující řešení ​bezdrátových zařízení hlídajících teplotu dostupná na trhu+    * Prozkoumejte existující řešení. 
-    * Navrhněte zařízení ​umožňující monitorování teploty přepravních boxů. +    * Navrhněte ​vlastní ​zařízení ​založené na platformě esp32-cam
-    * Pro řízení sledování teploty a komunikaci s nadřazeným systémem zvolte vhodnou konfiguraci senzorů a procesoru+    * Zařízení bude splňovat ​tyto požadavky: 
-    * Zařízení bude umožňovat ​sledovat teplotu u více boxu. +      - pořízení snímku ​i detekci pohybu ​na SD kartu, 
-    * V případě ​ekročení minimální nebo maximální hlídané hodnoty informujte řidiče pomocí zvukového upozornění ​na telefonu. +      - se zařízením ​bude možné komunikovat ​přes SMS příkazy a síť WIFI, 
-    * Informaci o teplotě je nutné ukládat po celou dobu jízdy. +      - zařízení umožní odeslání pořízené fotografie na email přes GPRS GSM sítě, 
-    * Komunikace s řidičem ​bude provedena s pomocí mobilního telefonu ​přes rozhraní bluetooth. +      - k určení času pořízení snímku bude řešení obsahovat RTC obvod
-    * Pro komunikaci procesoru s telefonem vytvořte vhodný ​síťový protokol zaručující bezpečný přenos informací+    * Navržené řešení ​zrealizujte. 
-    * Navržené ​zařízení ​zrealizujte. +    * Součástí realizace bude vytvoření plošného spoje vhodného pouzdra
-    * Pro zvolený procesor ​vytvořte knihovnu funkcí ​obslužnou aplikaci demonstrující správnou funkcí celého zařízení+    * Výsledné řešení řádně ​otestujte.
-    * Výsledné ​zařízení ​otestujte.+
  
-  * **Rozšíření síťového simulátoru o Spanning tree protocol** (Network simulation module extension implementing Spanning tree protocol)(BP - Peter Bábics) 
-    * Prostudujte existující simulátor počítačové sítě [1, 2, 3, 4, 5].  
-    * Prozkoumejte možnosti implementace Spanning tree protokolu do existujícího řešení. 
-    * Pro tento simulátor napište modul v jazyce Java, který bude umožňovat využití Spanning tree protokolu v simulovaných přepínačích. 
-    * Vytvořené řešení začleňte do existujícího simulátoru. 
-    * Napište návod pro použití simulátoru a to včetně vytvořeného modulu. 
-    * Vytvořte několik příkladů použití vytvořeného modulu. 
-    * Výsledné řešení včetně návodu otestujte. 
-    * [1] Pitřinec, T.,.: „Síťový simulátor pro výukové účely na bázi prvků OS Linux“, DP – 2012, ČVUT FIT. 
-    * [2] Švihlík, M.,:​“Vizualizace virtuální počítačové sítě“, DP-2012, ČVUT FIT. 
-    * [3] Lukáš, M.,:“ Podpůrné komponenty simulátoru počítačové sítě“, DP-2012, ČVUT FIT. 
-    * [4] Horáček, M.,:“ Rozšíření síťového simulátoru o možnost použití konfiguračních souborů pro konfiguraci síťových prvků “, BP-2014, ČVUT FIT. 
-    * [5] Mach, V.,:“ Rozšíření síťového simulátoru o připojení do reálné sítě“, BP-2014, ČVUT FIT. 
  
-  * **Levné zařízení ​pro ření veličin a zobrazování informací založené na existujícím wifi routeru** (Low cost device used for data colection based on wifi router)(BP - Adam Benda+  * **Nástroje ​pro podpora výuky bezpečnostních kódů v prostředí Wolfram Mathematica (Tools to support the teaching of security codes in the Wolfram Mathematica environment)** (BP - Linhartová Helena
-    * Prostudujte ​existující řešení. +    * Prozkoumejte ​existující řešení ​nástrojů vhodných k výuce bezpečnostních kódů
-    * Vyberte vhodný wifi router za účelem modifikace a vylepšení jeho funkcí+    * Analyzujte problémy studentů při výuce bezpečnostních kódů
-    * Na základě vybraného wifi routeru navrhněte a sestavte zařízeníke kterému připojíte teplotní a jiné senzory, a malý displej+    * Zaměřte se zejména na tyto kódy: sudá parita, křížová paritaHammingův kód, rozšířený i zkrácený Hammingův kódcyklický kód, součinový kód RM kód
-    * Navrhněte ​a implementujte aplikaci, která agreguje ze zařízení naměřené hodnoty, skladuje je a umožňuje jejich prohlížení+    * Navrhněte ​vlastní nástroje vhodné k výuce těchto kódů
-    * Navrhněte a implementujte aplikaci, která na zařízení zobrazuje data získaná ze sítě Internet (napřpřehled zpráv, nejbližší ​odjezd autobusu)+    * Zaměřte se zejména na oblast generování,​ dekódování ​opravy těchto kódů. 
-    * Navržené ​zařízení otestuje.+    * Nástroje budou umožňovat generovat nejen výukové notebooky pro program Wolfram Mathematica,​ ale i VHDL kódy a testbenche pro lepší představu jejich implementace v hardware. 
 +    * Nástroj bude podporovat i vložení chyby a jeji opravu
 +    * Navržené řešení realizujte a řádně otestujte.
  
-===== Available projects ===== 
  
-**Pokud máte o téma zájemnapište mi emailRezervace ​systému bpm nemá žádnou váhu.**+  ​* **Programovatelná elektronická zátěž (Programmable electronic load)** (BP - Pánek Miloš) 
 +    - Prozkoumejte existující řešení programovatelné elektronické zátěže. 
 +    - Analyzujte problémy současných řešení a navrhněte vlastní řešení. 
 +    - Navržené řešení bude podporovat tyto režimy: stálý proudstálý odpor, stálý výkon a stálé napětí. 
 +    - Programovatelná zátěž bude splňovat tyto požadavky:​ 
 +      - nastavení všech parametru zátěže přes rozhraní na samotném zařízení,​ 
 +      - komunikace s PC aplikací přes bluetooth, USB a wifi, 
 +      - záznam naměřených dat lokálně na SD kartu, 
 +      - jednoduchý protokol pro komunikaci s PC s možným rozšířením pro další funkcionalitu. 
 +    - Pro PC navrhněte a naprogramujte aplikaci v jazyce C# s grafickým rozhraním. 
 +    - Aplikace ​PC bude umožňovat nastavit všechny parametry zátěže, včetně průběžného sledování naměřených hodnot a jejich zobrazení přímo v aplikaci.  
 +    - Parametry zátěže bude možné v průběhu měření měnit podle předem nastavených hodnot. 
 +    - Navržené řešení zrealizujte a řádně otestujte.
  
-  * **Generátor referencí na základě dat uložených ve formátu XML** - Proveďte rešerší existujících řešení. Navrhněte a zrealizujte aplikaci pro generování seznamu referencí na základě dat uložených v XML souboru a šablony pro generování referencí. Reference bude možné vytvářet i hierarchicky. Výstupní formát bude možné konfigurovat s pomocí konfiguračního souboru. Aplikace bude umožňovat editovat jednotlivé záznamy uložené v souboru XML a vytvářet vazby mezi referencemi,​ jako je například tento článek byl citovat v těchto publikacích. BP - doba práce 2 semestry (volné) (100% SW) 
  
-  * **Linuxové jádro ​pro vestavěný procesor** - Proveďte rešerši existujících linuxových jader pro vestavěné procesory a najděte vhodné ​řešení ​pro procesor ARM osazený na desce beagleboardPro tuto desku s pomocí linuxového jádra rozchoďte všechny ​periférie a napište ​demo aplikaci. ​BP, DP doba práce 2-4 semestry (volné) (100% SW)+  * **Zařízení ​pro ovládání základních periferií připojených k FPGA obvodu (Device for controlling basic peripherals connected to the FPGA circuit)** (BP Šebek Michal) 
 +    - Prozkoumejte existující ​řešení ​ovládání periferií z FPGA obvodu firmy XILINX. 
 +    - Zaměřte se zejména na tyto periférie: OLED displej, alfanumerický displej, tlačítka, přepínače,​ led diody. 
 +    - Navrhněte vlastní knihovnu zaměřenou na ovládání periferií zejména přes sběrnici I2C. 
 +    - Navrženou knihovnu zrealizujte ​řádně otestujte. 
 +    - Pro demonstraci správné funkce periférií ​napište ​obslužnou ​aplikaci ​pro FPGA Artix-7. 
 +    ​Aplikace bude obsahovat menu pro volbu testování periférií a nastavení obsahu registrů. 
 +    ​Výsledné řešení řádně otestujte. ​
  
-  * **Programovatelný softwarový generátor všech typů paketů** BP - doba práce 2 semestry (volné) (100% SW) 
  
-  * **Programovatelný hardwarový generátor všech typů paketů** BP, DP - doba práce 2-4 semestry ​(volné(80% SW20% HW)+  * **Multiplatformní nástroj pro odposlech dat z rádiového přenosu pomocí SDR (A multi-platform wireless data sniffing tool using SDR)** (DP - Šimůnek Martin) 
 +    ​Analyzujte technologii SDR(softwarově definovaného rádiaa jeho možnosti pro odchytávání bezdrátových zařízení. 
 +    - Zaměřte se zejména na zařízení pracující v pásmu 433MHz a 868MHz. 
 +    - Prozkoumejte existující řešení pro odchytávání a analýzu těchto zařízení. 
 +    - Využijte SDR a navrhněte nástroj pro odposlech dat přenášených rádiovým signálem v pásmu 433MHz a 868 MHz. 
 +    - Nástroj by měl být tvořen knihovnou a grafickým rozhraním pro odposlech a zpracování naměřených dat. 
 +    - Podporována budou zejména zařízení typu: bezdrátový teplotní senzorbezdrátové senzory v automobilu a bezdrátové měřiče tepla v domácnostech.  
 +    - Nastroj bude umožňovat analyzovat přenos, a to jak nešifrovaný,​ tak i šifrovaný. 
 +    - Pokud bude k dispozici klíč pro dešifrování,​ bude nástroj umožňovat i dešifrování,​ a to zejména pro bezdrátové měřiče tepla v domácnostech. 
 +    - Navržené řešení zrealizujte a řádně otestujte.
  
-  * **Jednoduchý překladač z jazyka c do mikroprogramu - Simple translator from C to microcode description** - Navrhněte a zrealizujte překladač z programu popsaného podmnožinou příkazů jazyka c do mikroprogramu popsaného v jazyce VHDL. Prozkoumejte existující řešení. Jazyk c bude podporovat vybrané celočíselné a binární typy proměnnýchPřekladač bude schopen ​eložit následující prvky jazyka C: aritmetické ​logické operacepodmíněný výraz if (else ifelse)cyklus while, cyklus for a příkaz gotoImplementace ​bude s ohledem na multiplatformnost provedena v jazyce Java. (BPDP) doba práce 2-4 semestry (volné) (90% SW, 10% HW)+  * **Zařízení pro ovládání aplikace Adobe Lightroom s pomocí hardwarového ovladače (A device ​to control Adobe Lightroom using a hardware driver)** (BP Macháček Vitězslav) 
 +    - Prozkoumejte existující řešení ​umožňující ovládání aplikace Adobe Lightroom s hardwarového ovladače. 
 +    - Pomocí metod softwarového inženýrství navrhněte vlastní řešení vyhovující níže uvedeným požadavkům. 
 +    - Navrhněte vlastní zařízení fungující jako samostatný ovladač splňující tyto požadavky:​ 
 +      - komunikace s aplikací ​bude realizována ​es USB Bluetooth, 
 +      - ovladač bude umožňovat čtení vstupů z encodérůtlačítek a Hallových senzorů, 
 +      - ovladač bude napájen z baterie. 
 +    - Navržený ovladač zrealizujte ​naprogramujte. 
 +    - Pro PC vytvořte vlastní aplikaci umožňující zpracování dat z ovladače a jejich ​enos do aplikace Adobe Lightroom Classic. 
 +    - Aplikace ​bude mít uživatelské rozhraníkteré bude umožňovat její nastavení a toto nastavení bude ukládat do lokální databáze. 
 +    ​Výsledné řešení řádně otestujte.
  
-  * **Jednoduchý překladač z jazyka c do automatového popisu ​ - Simple translator from C to automata description** - Navrhněte a zrealizujte překladač z programu popsaného podmnožinou příkazů jazyka c do mikroprogramu popsaného v jazyce VHDL. Prozkoumejte existující ​řešeníJazyk c bude podporovat vybrané celočíselné a binární typy proměnnýchPřekladač bude schopen přeložit následující prvky jazyka C: aritmetické ​logické operace, podmíněný výraz if (else ifelse), cyklus whilecyklus for příkaz gotoImplementace ​bude s ohledem ​na multiplatformnost provedena ​v jazyce ​Java(BP, DP) doba práce 2-4 semestry (volné) (90% SW, 10% HW)+  * **Přenosné zařízení pro odposlech NFC komunikace pomocí SDR založené na platformě Raspberry Pi (Portable device for sniffing NFC communication using SDR based on the Raspberry Pi platform)** (DP - Balko Martin) 
 +    ​- Prozkoumejte existující ​nástroje určené k analýze NFC komunikace. 
 +    - Analyzujte technologií SDR (softwarově definovaného rádia). 
 +    - Analyzujte technologii NFC, zejména princip komunikace mezi NFC čtečkou ​NFC kartou ​(MIFARE ClassicMIFARE DESFire, MIFARE Plus)
 +    - Analyzujte a navrhněte způsob pro odposlech NFC komunikace pomoci SDR. 
 +    - Navrhněte přenosné zařízeníkteré bude umožňovat odposlechzáznam ​prvotní analýzu NFC komunikace. 
 +    - Zařízení bude schopné odchytit UID karty a komunikaci směrem od čtečkyPokud bude signál dostatečně silný, zaznamená i komunikaci směrem od karty. 
 +    - Navržené řešení zrealizujte ​na platformě Raspberry Pi. 
 +    - Pro výsledné zařízení napište ​v jazyce ​Python obslužnou aplikaci. 
 +    ​Výsledné zařízení řádně otestujte.
  
-    ​* **Šifrování dat na pevném SATA disku připojeném přes ethernetové rozhraní** - Prostudujte ​existující ​hardwarová ​řešení ​šifrování dat na pevném diskuNavrhněte a zrealizujte ​vlastní řešení ​napsané v jazyce VHDLPro návrh použijte existující ethernetové jádro napsané v jazyce VHDL(DP) doba práce 2-4 semestry ​(volné(50% SW50% HW)+  ​* **Aplikace pro chytrou domácnost využívající rádiové spojení jednotek s Raspberry Pi (Smart home application using radio connection of units with Raspberry Pi)** (BP - Zoreník Pavel) 
 +    ​Prozkoumejte ​existující řešení. 
 +    - Pomocí metod softwarového inženýrství navrhněte vlastní řešení ​vyhovující níže uvedeným požadavkům. 
 +    - Navržené řešení naprogramujete,​ zdokumentujte a řádně otestujte. 
 +    ​Požadavky:​ 
 +      ​webová aplikace na platformě Raspberry Pi (konfigurace zařízení), 
 +      - připojení bude provedeno pomocí uživatelského jména a hesla, 
 +      - aplikace bude umožňovat více uživatelů s různým typem oprávnění,​ 
 +      - jednotlivá zařízení STM32, prostředí Arduino, 
 +      - komunikace zařízení přes rádiový modul RFM69, 
 +      - provoz zařízení na baterii, 
 +      - sledování teploty, ovládání zásuvek.
  
-  * **Sada nástrojů pro On-Line diagnostiku** (Set of tools for On-Line test) - Naprogramujte sadu nástrojů pro On-Line diagnostiku. Nástroje budou založeny na již existujícím nástroji pro práci s obvody. Tento nástroj zmodifikujte tak, aby umožňoval použít libovolnou techniku pro On-Line testování založenou na bezpečnostních kódech (sudá parita, zdvojení, Berger kód, Hamming kód, atp.). Výsledné řešení bude umožňovat načtení vstupního obvodu, jeho modifikaci na samočinně zabezpečený obvod a jeho konverzi do příslušných VHDL kódů. Aplikace bude podporovat i rozsáhlejší návrh složený z více částí. BP, DP - doba práce 2-4 semestry (volné) (100% SW) 
  
-  ​* **Rychlý osciloskop postavený s pomocí FPGA** (High speed scope based on FPGA) Navrhněte a zrealizujte levný 1 kanálový 50 Mhz osciloskop postavený s pomocí desky Starter board s obvodem Spartan3e. Jako základ použijte modul tvořený analogovým vstupem s A/D převodníkem. Tento modul upravte tak, aby splňoval požadavky kladené na vstupní části osciloskopu takovýchto parametrů. Pro desku Spartan 3E napište aplikaci pro zpracování dat získaných s A/D převodníku. Získaná data zobrazte. ​ BP, DP - doba práce 2-4 semestry (volné) (50% SW, 50% HW)+  ​ 
 +===== Available projects ​FIT =====
  
-  * **JTAG SPI USB programátor pro ATMEL** - Navrhněte programátor včetně programovatelné redukce pro programování mikrořadičů Atmel. BPDP - doba práce 2-4 semestry (volné) (50% SW50% HW)+  ​1. Arduino HW/SW 
 +    ​GPS přijímač a jeho aplikace 
 +    ​Meteo stanice 
 +    ​GSM modém a jeho aplikace 
 +    ​NFC a bezkontaktní karty 
 +    ​univerzální desky s různými periferiemi 
 +    * řízení modelu auta 
 +    * generator analogových průběhů 
 +    * přípravky pro desku digilent CMOD A7/S7 (displej, tlačítkaswitcheatd.) 
 +    * návrh hardware pro desku digilent CMOD A7/S7 
 +    * vlastní zadání 
 +    * Wifi a ESP32/​ESP2866 
 +    * zařízení pro ochranu baterie před vybitím
  
-  * **Vysoce spolehlivý systém železničního zabezpečovacího zařízení založeného na dvou FPGA obvodech** - Prostudujte stávající zrealizované ​HW zařízení. Prostudujte knihovnu prvků realizujících jednotlivé částí zabezpečovacího systému železnice. Pro toto zařízení napište firmware pro mikrořadič a spolehlivý řídicí systém popsaný ​jazyce VHDL a to tak, aby docházelo k vzájemné kontrole obou FPGA obvodů. Řídicí systém musí využívat samočinně testované obvody ​pro zajištění detekce poruch. Celý systém musí umožňovat vložení poruchy. Návrh ověřte na příkladu zabezpečení železniční stanice. Systém v ípadě detekce poruchy provede rekonfiguraci špatného FPGA obvodu. BP, DP doba práce 2-4 semestry (volné) (50% SW, 50% HW)+  ​2. Wolfram Mathematica 
 +    ​bezpečnostní kódy 
 +    ​kódy pro kryptografií 
 +    ​matematické funkce realizované v HW 
 +    * aritmetický procesor ​GF(2^2^n) 
 +    * efiktivita protokolů pro předmět BI-PSI 
 +    * vlastní zadání
  
-  * **Programovatelný stmívač světel ​pro domácí zvířata** - Navrhněte zařízení pro stmívání světel řízené mikrořadičem. Zařízení bude umožňovat stmívat 2 žárovky. Pro zadání ​průběhu stmívání napište aplikaci. Zařízení bude možné připojit k PC s pomocí USB rozhraní. Upřesňující pokyny zadavatele (kanárek domácí: pí píp - pí - píp pí pí píp) BP - doba práce 2 semestry (volné) (50% SW, 50% HW)+  ​3. Visual C++/C# 
 +    ​aplikace pro komunikaci s periferiemi v PC 
 +    ​aplikace pro komunikaci s procesorem Zynq 
 +    ​aplikace ​pro správu projektu ve VHDL 
 +    * překladače 
 +    ​grafické aplikace pro výuku 
 +    ​vlastní ​zadání
  
-  * **Univerzální řadič displejů** - Prozkoumejte existující řešeníNavrhněte a zrealizujte řadič displeje umožňující jednoduchou komunikaci se znakovým displejemKomunikace bude probíhat po sériové linceBP, - doba práce 2 semestry ​(volné) (60% HW, 40% SW )+  ​4. Jazyk VHDL / desky FPGA 
 +    ​návrh hardware pro bezpečnostní kódy 
 +    * generátor průběhů (sinusovka, obdelník, trojuhelník) 
 +    ​osciloskop 
 +    ​návrh hardware pro realizaci matematických funkcí 
 +    * implementace procesoru/​periferié procesoru (ARM, Z80, AVR, ...
 +    * HW podpora SoC (Zynq) 
 +    * aritmetický procesor v GF(2^2^n) 
 +    * Hry pro FPGA 
 +    * vlastní zadání
  
-  * **Zařízení ​pro přenos lokálních informací do internetu ​pomocí existujících wifi routeru** - Prostudujte existující řešení úpravy wifi routerů ​za účelem modifikace a vylepšení jejich funkcí. Upravte linuxové jádro wifi routeru tak, aby bylo možné nahrávat a ukládat vlastní přeložený kód. K wifi routeru připojte jednoduché zařízení (RFID čtečka, teploměr, apod). BP, DP - doba práce 2-4 semestry (volné) (90% SW, 10% HW)+  ​5. Plošné spoje 
 +    ​návrh zařízení s porcesorem atmel + drobné periferié 
 +    ​* zařízení s nízkou spotřebou 
 +    * vlastní zadání
  
-  * **Implementace USB rozhraní FPGA obvodem** - Seznamte se s problematikou USB rozhraní realizovaného FPGA obvody. Prostudujte stávající způsoby realizace tohoto USB rozhraní. Navrhněte ​realizujte funkční zařízení,​ které bude umožňovat přenos dat pomocí USB rozhraní realizované FPGA obvodem. Prostudujte existující řešení USB ovladačů. Na základě získaných informací vytvořte ​vlastní ​USB ovladač podporující navržené řešení. Na jednoduché aplikaci demonstrujte funkci vytvořeného řešení. Při návrhu se zaměřte na co možná nejjednodušší řešení, které bude umožňovat přenášet jen jednoduché informace. BP, DP - doba práce 2-4 semestry (volné) (50% HW, 50% SW )+  ​6. Raspberry PI / Raspberry PI Pico 
 +    ​ovládání jednoduchých periferií 
 +    ​chytré síť, ovládání periferií přes ethernet 
 +    ​vzdálená správa sítí 
 +    ​SDR(Software Defined Radio) aplikace ​sledování ​analýza provozu 
 +    * vlastní ​zadání
  
-  * **Síťový simulátor ​pro výukové účely na bázi prvků OS Linux a CISCO směrovačů ​(Network simulator based on Linux OS component and CISCO routers)** - Prostudujte existující řešení. Doplňte některé další síťové prvky do již existujícího simulátoru. BPDP - doba práce 2 semestry (volné) (100% SW)+  ​7. Android 
 +    ​aplikace ​pro práci s hardware ​(raspberry PIArduino a jiné)
  
-  * **Zařízení ​pro sledování objektu s nízkou spotřebou** - Prostudujte existující řešení. Navrhněte vlastní zařízení umožňující pořízení ​odeslání fotografie přes internet z okolí sledovaného objektu, který není připojen trvale k internetu ani k elektrické sítí. Důraz bude kladen na velmi nízkou spotřebu a co nejmenší pořizovací cenu. Sledovací zařízení bude umožňovat získání fotografie okolí s různou kvalitou. BP, DP - doba práce 2 semestry (volné) (10% HW, 90% SW)+  ​8. Python 
 +    ​aplikace ​pro zpracování ​generování dat podle šablon
  
-  * **Generátor samoopravných kódů: Hamming, RS, BCH, LDPC** - Prostudujte existující řešení. Navrhněte vlastní generátor samoopravných kódů. Zadávat bude možné libovolný generující polynom, popřípadě bude možné specifikovat vlastnosti kódu. Zvolte vhodný výstupní formát. BP, DP - doba práce 2-4 semestry (volné) (100% SW)+  ​9. Neuronové sítě 
 +    ​Model neuronové sítě ve Wolfram Mathematice 
 +    ​Model neuronové sítě v jazyce c++ 
 +    ​Implementace neuronu a neuronové sítě v hardware 
 +    ​Implementace neuronové sítě v SoC
  
-  * **Simulátor procesoru DOP** Prostudujte existující řešení. V programovacím jazyku Java implementujte simulátor výukového procesoru DOP-v3. Simulátor musí obsahovat editor a překladač zdrojových mikroprogramů (mikroassembler). Syntaxe zdrojového mikroprogramu musí být stejná jako u stávajícího simulátoru používaného pro výuku (SimDOP). Simulátor musí umožňovat krokování mikroprogramu po jednotlivých mikroinstrukcích i spouštění úseku k zadanému bodu zastavení. BP, DP - doba práce 2-4 semestry (volné) (100% SW)+===== Available projects HW external =====
  
-  ​* **Generátor obvodů pro edmět ČAO** - Prozkoumejte existující ​řešení pro kreslení elektrických obvodů. Vytvořte aplikacikterá bude umožňovat ​na základě zadaných parametrů vytvářet obvodyBPDP - doba práce 2-4 semestry (volné) (100% SW)+  ​1. Malý grafický displej do výšky 1U s rotačním enkodérem ovládaný ​es SPI 
 +    * Navrhněte a zrealizujte grafický TFT displej ovládaný pomocí sběrnice SPI. 
 +    ​Displej by měl obsahovat možnost zadávání příkazů (tlačítkarotační encoder,​…).  
 +    * Výška displeje musí splňovat ​normu 1U 
 +    * Pro vytvořený displej naprogramujte frameworkkterý usnadní práci s displejem.
  
-  ​* **Procesory pro FPGA obvody (Soft processors for FPGA circuits)** - Prostudujte existující řešení procesorů popsaných ​jazyce VHDLSrovnejte jejich parametry. Na základě srovnání implementujte jeden typ procesoru do FPGA obvodu. Vyberte vhodný procesor s ohledem ​na dostupnost překladačů jazyka C do ASM ​Zaměřte se zejména na hotové implementace procesoru AVR. Vytvořte knihovnu pro ovládání základních periferií. Pro přípravek firmy XILINX Spartan 3E vytvořte vzorovou aplikaci ​využívající ​všechny funkce vytvořené knihovnyBP, DP doba práce 2-4 semestry (volné) (80% SW, 20% HW)+  ​2. OSD displej v FPGA 
 +    ​Navrhněte a zrealizujte On-Screen displej ​obvodu FPGA pro video stream 
 +    * OSD displej by měl fungovat ​na formátech od 720p do 4K, jak progressive,​ tak interlaced 
 +    * Požadavkem je minimální ​využití zdrojů ​FPGA 
 +    * OSD se bude ovládat pomocí sběrnice AXI4-Lite.
  
-  * **Rychlé ethernetové jádro (High speed ethernet core)** - Prostudujte stávající řešení ethernetového jádra pracujícího na rychlostech 1G, 100M napsané v jazyce Verilog dostupné na stránce www.opencores.org a VHDL dostupné jako diplomová práce. ​Navrhněte a zrealizujte ​vlastní řešení 1G, 100M ethernetového ​jádra napsaného v jazyce VHDL a to takaby bylo možné využít pouze jednu hodinovou doménu. Pro jednotlivé ​částí i pro celé jádro proveďte verifikaci. Pro výsledné jádro napište testovací aplikaci demonstrující funkci jádra na všech realizovaných rychlostech. Pro realizaci ​použijte vývojovou desku Xilinx(BP, DP 2-4 semestry)+  ​3. Konfigurovatelný filtr ethernetoveho rámce v FPGA 
 +    ​* Navrhněte a zrealizujte ​konfigurovatelný filtr ethernetového ​rámce umožňující filtrovat pakety podle zadaných parametrů (MACIP…) do více streamů, nebo jednoho streamu označeného identifikátorem 
 +    * Pro vstupní a výstupní interface bude použit AXI4 Stream pro zajištění kompatibility.
  
-  * **Modul ​pro správu projektů s VHDL soubory** - Prostudujte stávající řešení vývojového nástroje pro správu VHDL projektů. Do již existujícího ​řešení implementujte modul, který bude umožňovat přidat do souboru libovolný signál ​přenést ho do vyšších úrovní zdrojových VHDL kódůVylepšete stávající řešení pro kontrolu konzistence VHDL souborů. V případě potřeby navrhněte nové vývojové prostředí. Otestujte generátor VHDL kódu na základě zadaných parametrů uživatele. Jako programovací jazyk zvolte Javu (BP, DP 2-4 semestry, možnost práce více studentů najednou jako tým)+  ​4. Zpracování I2S signálu s integraci do AXI Stream 
 +    ​Navrhněte a zrealizujte konverzní modul v FPGA ze standartního interface I2S na interface AXI4 Stream a opačně.  
 +    ​* Modul by měl zvládat konverzi různé datové ​šířky audio samplu ​multiplexování více audio streamu ​do jednoho I2S interfacu.
  
-  * **Portace operačního systému android ​na vývojovou desku procesorem ARM** - Prostudujte existující ​řešeníAnalyzujte ​možnosti portace operačního systému ​pro vývojovou desku Raspberry pi BeagleBone BlackNa jednu z chto desek proveďte portaci a vytvořte knihovny ​pro obsluhu periferiíPro vytvořenou knihovnu ​vytvořte demo aplikaci. (BPDP 2-4 semestry)+  ​5. Efektivní (de)interlacing 12G SDI videa 
 +    ​Navrhněte a zrealizujte (de)interlacer 6G a 12G SDI videa do progressive formátu.  
 +    ​Modul může pracovat jak nad SDI formátem, tak na Native video formátem. 
 + 
 +  6. Embedded audio konvertor na AXi4 Stream a zpět 
 +    ​Navrhněte a zrealizujte konverzní modul v FPGA z SDI Embedded audia na interface AXI4 Stream a opačně.  
 +    * Modul by měl zvládat konverzi různé datové šířky audio samplu. 
 + 
 +  7. Nízkolatenční komprese v FPGA využitím vlnové transformace 
 +    ​Navrhněte a zrealizujte nízkolatenční video kodek v FPGA založený na vlnkové transformaci.  
 +    ​Latence kodeku by se měla pohybovat v jednotkách řádků videa. 
 + 
 +===== Available projects SW external ===== 
 + 
 +  1. Optimalizace Java aplikací pro horizontální škálování v moderní mikroservisní architektuře - spolupráce s průmyslem 
 +    * využití AoT kompilace a minimalizace start-up času 
 +    * výběr vhodného JVM a analýza jeho výhod pro minimální náročnost na prostředky (napřGraalVM) 
 +    * využití vhodného frameworku a analýza jeho výhod (např. Quarkus) 
 +    * analýza ​možností využití ​pro serverless architekturu (např. Knative) 
 +    * využití komunikace přes gRPC 
 +    * podpora feature flagů pro release management 
 +    * vlastní zadání 
 + 
 +  2. Virtualizace ​izolace aplikačních prostředí - spolupráce s průmyslem 
 +    * využití OCI kontejnerů jako způsob doručování aplikací 
 +    * analýza bezpečnostních chyb využívané technologie docker a možnosti jejich eliminace 
 +    * porovnání s jinými přístupy (napřpodman, buildah apod.) 
 +    * lokální orchestrace kontejnerů (docker-compose vs podman-compose) 
 +    * vnořování kontejnerů (např. docker(-compose)-in-docker/​podman) 
 +    * vlastnosti container file systemů (např. OverlayFS) 
 +    * bezpečné (rootless) spušní více kontejnerů uvnitř kontejneru 
 + 
 +  3. Orchestrace kontejnerů v distribuovaném on-premise prostředí - spolupráce s průmyslem 
 +    * porovnání vlastností využívaných ​pro jako container runtime (containerd vs docker vs CRI-O) 
 +    * kubernetes vs jeho komerční distribuce (openshift, tanzu) 
 +    * helm vs yaml manifesty (+ možnosti jejich úprav, napřkustomize) 
 +    * realizace ingress load balancerů v lokálním on-premise prosředí 
 +    * vytvoření persistence v distribuovaném prostředí (např. Ceph, Rook, GlusterFS apod.) 
 +    * správa citlivých údajů (šifrování kubernetes secrets, PAM nástroje) 
 +    * vytvoření vlastního kubernetes operátora (vlastní zadání) 
 + 
 +  4Podpora vývoje a administrace prostředí prostřednictvím automatizace - spolupráce s průmyslem 
 +    * analýza praktik DevOps přístupu, GitOps, SecOps, ChatOps, AIOps 
 +    * analýza a představení SRE (Site reliability engineering) praktik 
 +    * vytvoření a nasazení prostředí pro kompletní podporu životního cyklu aplikace naplňující znaky GitOps a IaaC (infrastructure as a code) 
 +    * zabezpečení SVC repozitářů přes GPG klíče 
 +    * podpora IaaC nástrojů (ansiblechef+puppet,​ cloud vendor proprietární nástroje, terraform) 
 +    * využití CI nástroje s dynamickým vytěžováním zdrojů dle aktuální zátěže (návrh tzv. CI farmy) 
 +    * podpora deklarativního popisu činností (pipelines) 
 +    * porovnání známých CI nástrojů (jenkins, jenkins-x, gitlab, tekton, github actions) 
 +    * návrh procesů pro validaci aplikací před jejich nasazením prostřednictvím testů 
 + 
 +  5. Projekty zadané externím zadavatelem 
 +    * seznam zadavatelů níže 
 + 
 +**Pokud máte o téma zájem, napište mi email. Rezervace v systému bpm nemá žádnou váhu. Pokud se Vám nelíbí žádné z nabízených témat, koukněte do archívu dostupných zadání.** 
 + 
 + 
 +  *[[project:​2018:​proj_archiv|Návrhy zadání dostupných projektů]] 
 + 
 + 
 +===== Projekty zadané externím zadavatelem ===== 
 + 
 +  * [[project:​eaton:​proj_eaton|EATON HW/SW]]
  
-  * **FPGA deska řízená procesorem ARM** - Navrhněte zařízení obsahující FPGA obvod a procesor ARM. Mezi těmito obvody vytvořte komunikační linku vhodnou pro řízení FPGA obvodu s pomoci procesoru ARM. Zvolte vhodnou desku obsahující FPGA obvod. Pro řízení FPGA obvodu použijte vývojový kit Raspberry Pi osazený obvodem ARM. Vytvořte knihovnu funkcí pro procesor ARM umožňující komunikaci s FPGA obvodem. Pro ověření funkce celého spojení vytvořte testovací aplikaci. (BP, DP 2-4 semestry) 
  
-  * **Správa slovní zásoby pro os Android** - Vytvořte aplikaci pro správu slovní zásoby. Aplikace bude umožňovat import a export slovíček s pomocí textového souboru. Aplikace bude umožňovat zpracovávat velké objemy slov (10 - 20 tisíc). Důraz bude také kladen na rychlost zpracování slov, ovladatelnost a vhodné grafické prostředí. (BP, DP 2-4 semestry) 
  
-  * **Knihovna funkcí v jazyce C pro mikrořadič ARM 32 firmy ATMEL** (BP, DP 2-4 semestry) 
  
-  * **Jednoduchý TCP/IP stack pro malé procesory** (BP, DP 2-4 semestry) 
  
-  * **Sledování zařízení s nízkou spotřebou** - Navrhněte a zrealizujte zařízení umožňující sledování spotřeby objektu s nízkou spotřebou. Zařízení bude hlídat stav baterie a v případě poklesu pod určitou hranici celé zařízení odpojí a to včetně samo sebe. Zároveň bude umožňovat sledovat průběh změny stavu a následně upravit vlastní spotřebu až do stavu, kdy se odpojí od zdroje úplně. Baterií bude možné dobíjet ze solárního panelu s regulátorem. Pro vámi navržené zařízení navrhněte plošný spoj. (BP, DP 2-4 semestry) 
 ===== All defended works ===== ===== All defended works =====
  
-**BP a DP defended works on CTU in Prague FEL/FIT:** [[http://dip.felk.cvut.cz|BP a DP]]+**BP a DP defended works on CTU in Prague FEL/FIT:** [[https://dspace.cvut.cz|BP a DP]]
  
-===== All projects archives 2004 - 2014 =====+===== All projects archives 2004 - 2019 =====
  
 +  *[[project:​2022:​proj_2022|Realized projects 2022]]
 +  *[[project:​2021:​proj_2021|Realized projects 2021]]
 +  *[[project:​2020:​proj_2020|Realized projects 2020]]
 +  *[[project:​2019:​proj_2019|Realized projects 2019]]
 +  *[[project:​2018:​proj_2018|Realized projects 2018]]
 +  *[[project:​2017:​proj_2017|Realized projects 2017]]
 +  *[[project:​2016:​proj_2016|Realized projects 2016]]
 +  *[[project:​2015:​proj_2015|Realized projects 2015]]
   *[[project:​2014:​proj_2014|Realized projects 2014]]   *[[project:​2014:​proj_2014|Realized projects 2014]]
   *[[project:​2013:​proj_2013|Realized projects 2013]]   *[[project:​2013:​proj_2013|Realized projects 2013]]
project/proj_list.txt · Last modified: 2024/02/15 10:30 by xkubalik