Algoritmo cordico con VHDL: 4 passaggi
Algoritmo cordico con VHDL: 4 passaggi
Anonim

Di AmCoderhttps://www.linkedin.com/in/mituFollow Altro dall'autore:

Progettare un FIFO sincrono, LIFO/Stack in Verilog
Progettare un FIFO sincrono, LIFO/Stack in Verilog
Progettare un FIFO sincrono, LIFO/Stack in Verilog
Progettare un FIFO sincrono, LIFO/Stack in Verilog
Interfacciamento video con FPGA tramite VGA
Interfacciamento video con FPGA tramite VGA
Interfacciamento video con FPGA tramite VGA
Interfacciamento video con FPGA tramite VGA
Sincronizzatori, attraversamento del dominio di clock, generatori di clock, rilevatori di bordi e molto altro ancora: circuiti di ritocco essenziali
Sincronizzatori, attraversamento del dominio di clock, generatori di clock, rilevatori di bordi e molto altro ancora: circuiti di ritocco essenziali
Sincronizzatori, attraversamento del dominio di clock, generatori di clock, rilevatori di bordi e molto altro - Circuiti di ritocco essenziali
Sincronizzatori, attraversamento del dominio di clock, generatori di clock, rilevatori di bordi e molto altro - Circuiti di ritocco essenziali

Informazioni su: Mitu Raj -- Solo un hobbysta e uno studente -- Progettista di chip -- Sviluppatore di software -- Appassionato di fisica e matematica Maggiori informazioni su AmCoder »

##Questo è il link più cliccato e popolare in Google per l'implementazione VHDL di CORDIC ALGORITHM per generare onde seno e coseno## Al momento, esistono molti algoritmi hardware efficienti, ma questi non sono ben noti a causa del predominio dei sistemi software su i molti anni. CORDIC è un algoritmo di questo tipo che non è altro che un insieme di logiche di spostamento e aggiunta utilizzate per calcolare un'ampia gamma di funzioni tra cui alcune funzioni trigonometriche, iperboliche, lineari e logaritmiche. Questo è l'algoritmo utilizzato nelle calcolatrici, ecc. Quindi, semplicemente usando semplici shifter e sommatori, possiamo progettare un hardware con meno complessità ma potenza del DSP utilizzando un algoritmo cordic. Quindi può essere progettato come design RTL nudo in VHDL o Verilog senza utilizzare unità in virgola mobile dedicate o IP matematici complessi.

Passaggio 1: VHDL e Modelsim

Qui l'algoritmo cordic è implementato usando VHDL per generare un'onda sinusoidale e un'onda cose. Può produrre seno e coseno dell'angolo di input con grande precisione. Il codice è sintetizzabile su FPGA. Modelsim viene utilizzato per simulare il progetto e il banco prova.

Passaggio 2: codice VHDL per la progettazione e il banco di prova

Codice VHDL per la Progettazione e il Banco Prova
Codice VHDL per la Progettazione e il Banco Prova

La tecnica di ridimensionamento binario viene utilizzata per rappresentare i numeri in virgola mobile.

Si prega di leggere i documenti allegati prima di codificare.

Vai alla simulazione cordic_v4.vhd - Il design - L'input è l'angolo in 32 bit + bit di segno; può elaborare qualsiasi angolo da 0 a +/- 360 gradi con una precisione di input di 0.000000000233 gradi. Quando si fornisce l'input -> MSB è il bit di segno e gli altri 32 bit rappresentano la grandezza.-L'output del progetto è il suo valore seno e cos in 16 bit + bit di segno.ie; con precisione 0.000001526. Si prega di notare che l'uscita viene visualizzata sotto forma di complimento a 2 se il rispettivo valore seno o cos è negativo. Simulazione di testb.vhd - Banco di prova per il progetto (1) Input angoli e pull reset ='0'. Dopo due passaggi di simulazione, resetta su '1' e "esegui tutto". (2) Nella finestra di simulazione imposta la radice dei segnali sin e cos come decimale e formato > Analogico (automatico). (3) Rimpicciolisci per vedere la forma d'onda propriamente.

Passaggio 3: file allegati

(1) cordic_v4.vhd - Progettazione.(2) testb.vhd - Banco prova per la progettazione.

(3) Documento su come forzare gli input angolari e convertire i risultati binari.

Aggiornamento: QUESTI FILE SONO OBSELETE E NON PIU' FORNITI. SI PREGA DI UTILIZZARE I FILE DEL PASSO SUCCESSIVO

Passaggio 4: Mini-Cordic IP Core - 16 Bit

La limitazione dell'implementazione di cui sopra è la frequenza di funzionamento lenta e di clock inferiore a causa dell'esecuzione di calcoli in un singolo ciclo di clock. Mini-Cordic IP Core - 16 Bit

- Percorsi critici distribuiti su più cicli per migliorare le prestazioni.- Più veloce - Design collaudato FPGA sintetizzato fino a 100 Mhz di clock.- Più area ottimizzata in HDL, hardware minore.- Aggiunti segnali di stato di carico e di fine.- L'unico aspetto negativo è la risoluzione inferiore rispetto al precedente. Banco di prova:

completamente automatizzato da 0 a 360 gradi ingressi angolari

File allegati: 1) mini cordic main vhdl file2) mini cordic test bench3) mini cordic IP Core manuale4) documento su come forzare gli angoli e convertire i risultati

Per qualsiasi domanda non esitare a contattarmi:

Mitu Raj

seguimi:

mail: [email protected]

###Download totali: 325 fino al 01-05-2021###

### Ultima modifica del codice: 07-luglio-2020 ###

Consigliato: