Table des matières:
- Étape 1: Étape 1: Comment ça marche
- Étape 2: Étape 2: Programmation de la carte Basys 3
- Étape 3: Étape 3: Comment l'utiliser
Vidéo: Integer_Matrix_Solver_UART_SERIAL_VHDL : 3 étapes
2024 Auteur: John Day | [email protected]. Dernière modifié: 2024-01-30 09:09
Ce didacticiel instructable vous montre comment créer un solveur matriciel 2 par 2 en implémentant le module terminal série UART ainsi qu'un module solveur matriciel. L'utilisateur pourra entrer une matrice 2 par 2, puis la conception mise en œuvre crachera la solution au système linéaire.
Pour utiliser ce code, vous aurez besoin de:
- Une carte FPGA Digilent Basys 3
- Ordinateur avec le logiciel Xilinx Vivado (Webpack Edition fonctionnera). Pour ce module, nous avons utilisé la version 2017.2.
- Un cordon micro USB (capable de transférer des données)
Auteurs: Drew Miller, EE Major, Cal Poly SLO, Sukhdeep Singh, EE Major, Cal Poly SLO Classe: Digital Design
- Instructeur EE/CPE 133: Joseph Callenes
Sources:
- UART_TX, UART_RX de:
- Rebondir de:
Fonction de division de deux nombres non signés:
Étape 1: Étape 1: Comment ça marche
Entrées: l'utilisateur entre un système linéaire dans le terminal de l'ordinateur, puis un module UART les convertit en un tableau que le module de résolution matricielle doit manipuler. Le module UART s'interface avec l'utilisateur et lui permet de saisir la matrice appropriée ainsi que de le guider pour saisir correctement les données. Le système dispose également d'un commutateur de réinitialisation/activation mappé sur le commutateur le plus à gauche de la carte Basys3.
Sorties: les résultats du solveur matriciel sont transmis via l'interface du module UART, puis affichés sur le terminal informatique avec les solutions répertoriées à l'écran. Le solveur matriciel génère des vecteurs logiques standard non signés vers le module UART qui les convertit en sorties plus conviviales que l'utilisateur peut apprécier. Le solveur matriciel actuel ne peut avoir que des nombres jusqu'à 15 entrés et le résultat de sortie doit être un entier propre ou le programme de solveur matriciel est incapable de sortir la solution correcte.
Module "Serial Control" de niveau supérieur: l'utilisateur entre le système linéaire souhaité dans ce module via les modules UART_TX et UART_RX et convertit les entrées du terminal informatique en un tableau de vecteurs logiques standard qui sont traités par le module de résolution matricielle. Le module de résolution matricielle renvoie ensuite un tableau de vecteurs logiques standard qui sont ensuite affichés à l'écran par l'interface série UART. La transmission et la réception de données via les modules UART s'effectuent grâce à l'utilisation d'un FSM très long dans ce module.
Module UART_TX: L'utilisateur entre un vecteur logique standard de 8 bits et un signal d'envoi afin d'envoyer des données via l'interface USB. Pendant qu'il envoie des données, le signal TX_Active est haut. Après avoir envoyé les données, le signal TX_Done émet des impulsions.
Module UART_RX: L'utilisateur reçoit 8 bits de données à la fois de l'interface USB. Une impulsion de RX_DV est une indication que des données ont été reçues et que la logique vectorielle RX_Byte peut être lue.
Module solveur matriciel: le solveur matriciel reçoit un tableau imputé du module UART qui représente la matrice. Le solveur matriciel convertit ensuite chaque nombre du système linéaire en nombres entiers pour faciliter leur utilisation. À l'intérieur du module de résolution matricielle, il existe plusieurs sous-modules. Le premier sous-module est l'inverse_matrix_1 qui prend la matrice et donne ensuite l'inverse de la matrice donnée. Le sous-module suivant est le multiplicateur qui multiplie le total_matrix par la matrice inverse à l'aide d'opérations matricielles standard. Enfin, le module maître les mappe ensemble pour produire une seule réponse.
Étape 2: Étape 2: Programmation de la carte Basys 3
Une fois que vous avez acquis le code source ci-dessous, téléchargez-le sur la carte basys 3 pour utiliser l'interface.
reference.digilentinc.com/basys3/refmanual
Étape 3: Étape 3: Comment l'utiliser
Utilisez une interface série à 9600 bauds afin de communiquer avec l'UART Basys3. J'ai utilisé screen sur Linux avec la commande suivante:
écran /dev/ttyUSB1 9600
Pour ce faire sous Linux, j'ai dû ajouter mon utilisateur au groupe "dialout". Sous Windows, putty devrait fonctionner et sous MacOSX, le processus devrait être similaire à celui de Linux.
Basculer le commutateur le plus à gauche sur la position active démarre le solveur matriciel. Le désactiver réinitialise le solveur matriciel.
Conseillé:
Comment fabriquer une antenne double biquade 4G LTE en quelques étapes faciles : 3 étapes
Comment créer une antenne double biquade 4G LTE Étapes faciles : La plupart du temps, je n'ai pas une bonne force de signal pour mes travaux quotidiens. Donc. Je recherche et essaye différents types d'antenne mais ne fonctionne pas. Après une perte de temps, j'ai trouvé une antenne que j'espère fabriquer et tester, car ce n'est pas un principe de construction
Game Design dans Flick en 5 étapes : 5 étapes
Game Design dans Flick en 5 étapes : Flick est un moyen très simple de créer un jeu, en particulier quelque chose comme un puzzle, un roman visuel ou un jeu d'aventure
Système d'alerte de stationnement en marche arrière Arduino - Étapes par étape : 4 étapes
Système d'alerte de stationnement en marche arrière Arduino | Étapes par étape : dans ce projet, je vais concevoir un circuit de capteur de stationnement inversé pour voiture Arduino simple à l'aide d'un capteur à ultrasons Arduino UNO et HC-SR04. Ce système d'alerte de marche arrière basé sur Arduino peut être utilisé pour une navigation autonome, une télémétrie de robot et d'autres r
Détection de visage sur Raspberry Pi 4B en 3 étapes : 3 étapes
Détection de visage sur Raspberry Pi 4B en 3 étapes : dans ce Instructable, nous allons effectuer une détection de visage sur Raspberry Pi 4 avec Shunya O/S en utilisant la bibliothèque Shunyaface. Shunyaface est une bibliothèque de reconnaissance/détection de visage. Le projet vise à atteindre la vitesse de détection et de reconnaissance la plus rapide avec
Miroir de vanité de bricolage en étapes faciles (à l'aide de bandes lumineuses à LED): 4 étapes
Miroir de vanité DIY en étapes faciles (à l'aide de bandes lumineuses à LED) : Dans cet article, j'ai fabriqué un miroir de vanité DIY à l'aide des bandes LED. C'est vraiment cool et vous devez les essayer aussi