Algorithme Cordic utilisant VHDL : 4 étapes
Algorithme Cordic utilisant VHDL : 4 étapes
Anonim

Par AmCoderhttps://www.linkedin.com/in/mituFollow Plus par l'auteur:

Concevoir une FIFO synchrone, LIFO/Stack dans Verilog
Concevoir une FIFO synchrone, LIFO/Stack dans Verilog
Concevoir une FIFO synchrone, LIFO/Stack dans Verilog
Concevoir une FIFO synchrone, LIFO/Stack dans Verilog
Interfaçage vidéo avec FPGA en utilisant VGA
Interfaçage vidéo avec FPGA en utilisant VGA
Interfaçage vidéo avec FPGA en utilisant VGA
Interfaçage vidéo avec FPGA en utilisant VGA
Synchroniseurs, croisement de domaines d'horloge, générateurs d'horloge, détecteurs de bord, bien plus encore - Circuits de réglage essentiels
Synchroniseurs, croisement de domaines d'horloge, générateurs d'horloge, détecteurs de bord, bien plus encore - Circuits de réglage essentiels
Synchroniseurs, croisement de domaine d'horloge, générateurs d'horloge, détecteurs de bord, bien plus encore - Circuits de réglage essentiels
Synchroniseurs, croisement de domaine d'horloge, générateurs d'horloge, détecteurs de bord, bien plus encore - Circuits de réglage essentiels

À propos de: Mitu Raj -- Juste un amateur et un apprenant -- Concepteur de puces -- Développeur de logiciels -- Passionné de physique et de mathématiques En savoir plus sur AmCoder »

## Ceci est le lien le plus cliqué et le plus populaire de Google pour l'implémentation VHDL de l'ALGORITHME CORDIC pour générer des ondes sinus et cosinus## À l'heure actuelle, il existe de nombreux algorithmes efficaces pour le matériel, mais ceux-ci ne sont pas bien connus en raison de la prédominance des systèmes logiciels sur les nombreuses années. CORDIC est un tel algorithme qui n'est rien d'autre qu'un ensemble de logiques de décalage et d'addition utilisées pour calculer un large éventail de fonctions, y compris certaines fonctions trigonométriques, hyperboliques, linéaires et logarithmiques. C'est l'algorithme utilisé dans les calculatrices, etc. Ainsi, en utilisant simplement de simples décalages et additionneurs, nous pouvons concevoir un matériel avec moins de complexité mais la puissance du DSP en utilisant l'algorithme cordic. Par conséquent, il peut être conçu comme une conception RTL nue en VHDL ou Verilog sans utiliser d'unités à virgule flottante dédiées ou d'adresses IP mathématiques complexes.

Étape 1: VHDL et Modelsim

Ici, l'algorithme cordic est implémenté en utilisant VHDL pour générer une onde sinusoïdale et une onde cose. Il peut produire le sinus et le cosinus de l'angle d'entrée avec une grande précision. Le code est synthétisable sur FPGA. Modelsim est utilisé pour simuler la conception et le banc d'essai.

Étape 2: Code VHDL pour la conception et le banc de test

Code VHDL pour la conception et le banc d'essai
Code VHDL pour la conception et le banc d'essai

La technique de mise à l'échelle binaire est utilisée pour représenter les nombres à virgule flottante.

Veuillez consulter les documents joints avant de coder.

Passez en revueSimulation cordic_v4.vhd - La conception -L'entrée est l'angle en 32 bits + bit de signe; il peut traiter n'importe quel angle de 0 à +/-360 degrés avec une précision d'entrée de 0,000000000233 degrés. Lorsque vous donnez l'entrée -> MSB est le bit de signe et les 32 bits restants représentent la magnitude.-La sortie de la conception est sa valeur sinus et cos en 16 bits + bit de signe. avec une précision de 0,00001526. Veuillez noter que la sortie est affichée sous forme de complément 2 si la valeur sinus ou cos respective est négative. Simulation de testb.vhd - Banc d'essai pour la conception (1) Angles d'entrée et réinitialisation de traction = '0'. Après deux étapes de simulation, réinitialisez à '1' et "exécutez tout".(2) Dans la fenêtre de simulation, définissez la base des signaux sin et cos comme décimal et format > Analogique (automatique).(3) Effectuez un zoom arrière pour voir la forme d'onde correctement.

Étape 3: Fichiers joints

(1) cordic_v4.vhd - Conception.(2) testb.vhd - Banc d'essai pour la conception.

(3) Documenter sur la façon de forcer les entrées d'angle et de convertir les résultats binaires.

Mise à jour: CES FICHIERS SONT OBSÉLÉTÉS ET NE FOURNISSENT PLUS. VEUILLEZ UTILISER LES FICHIERS DE L'ÉTAPE SUIVANTE

Étape 4: Mini-Cordic IP Core - 16 bits

La limitation de la mise en œuvre ci-dessus est lente, fréquence d'horloge inférieure en raison des calculs effectués en un seul cycle d'horloge. Mini-Cordic IP Core - 16 bits

- Chemins critiques répartis sur plusieurs cycles pour améliorer les performances.- Plus rapide - Conception éprouvée FPGA synthétisée jusqu'à une horloge de 100 Mhz.- Plus de zone optimisée en HDL, matériel moindre.- Signaux Load et Done Status ajoutés.- Seul inconvénient est une résolution inférieure par rapport au précédent. Banc d'essai:

complètement automatisé des entrées d'angle de 0 à 360 degrés

Fichiers joints: 1) fichier vhdl principal mini cordic2) banc d'essai mini cordic3) manuel Mini Cordic IP Core4) Doc sur la façon de forcer les angles et de convertir les résultats

Pour toute question, n'hésitez pas à me contacter:

Mitu Raj

suivez-moi:

courrier: [email protected]

###Téléchargements totaux: 325 au 01-05-2021###

### Dernière modification du code: 2020-07-07 ###

Conseillé: