Cordisk algoritm med VHDL: 4 steg
Cordisk algoritm med VHDL: 4 steg
Anonim

Av AmCoderhttps://www.linkedin.com/in/mituFölj mer av författaren:

Designa en synkron FIFO, LIFO/Stack i Verilog
Designa en synkron FIFO, LIFO/Stack i Verilog
Designa en synkron FIFO, LIFO/Stack i Verilog
Designa en synkron FIFO, LIFO/Stack i Verilog
Videogränssnitt med FPGA med VGA
Videogränssnitt med FPGA med VGA
Videogränssnitt med FPGA med VGA
Videogränssnitt med FPGA med VGA
Synkronisatorer, Clock Domain Crossing, Clock Generators, Edge Detectors, mycket mer - Viktiga tweak -kretsar
Synkronisatorer, Clock Domain Crossing, Clock Generators, Edge Detectors, mycket mer - Viktiga tweak -kretsar
Synkronisatorer, Clock Domain Crossing, Clock Generators, Edge Detectors, mycket mer - Viktiga tweak -kretsar
Synkronisatorer, Clock Domain Crossing, Clock Generators, Edge Detectors, mycket mer - Viktiga tweak -kretsar

Om: Mitu Raj - Just a Hobbyst and Learner - Chip Designer - Software Developer - Physics and Mathematics Entusiast Mer om AmCoder »

## Detta är den mest klickade, populära länken i Google för VHDL -implementering av CORDIC ALGORITHM för att generera sinus- och cosinusvåg ## För närvarande finns det många hårdvarueffektiva algoritmer, men dessa är inte välkända på grund av dominans av programvarusystem över de många åren. CORDIC är en sådan algoritm som inte är annat än en uppsättning skift- och tilläggslogiker som används för att beräkna ett brett spektrum av funktioner, inklusive vissa trigonometriska, hyperboliska, linjära och logaritmiska funktioner. Detta är algoritmen som används i miniräknare etc. Således kan vi genom att bara använda enkla shifters och adders designa en hårdvara med mindre komplexitet men kraft för DSP med hjälp av cordic algoritm. Därför kan den utformas som ren RTL -design i VHDL eller Verilog utan att använda några dedikerade flytpunktsenheter eller komplexa matematiska IP -adresser.

Steg 1: VHDL och Modelsim

Här implementeras den cordiska algoritmen med VHDL för att generera en sinusvåg och en cose -våg. Den kan mata ut sinus och cosinus för inmatningsvinkel med stor precision. Koden är syntetiserbar på FPGA. Modelsim används för att simulera designen och testbänken.

Steg 2: VHDL -kod för design och testbänk

VHDL -kod för design och testbänk
VHDL -kod för design och testbänk

Binär skalningsteknik används för att representera flyttal.

Gå igenom de bifogade dokumenten innan du kodar.

Gå igenomSimulera cordic_v4.vhd - Designen -Ingången är vinkel i 32 bitar + teckenbit; den kan bearbeta vilken vinkel som helst från 0 till +/- 360 grader med ingångsprecision på 0.000000000233 grader. Vid inmatning -> MSB är teckenbiten och resten 32 bitar representerar storleken. -Designens utsignal är dess sinus och cos -värde i 16 bitar + teckenbit.ie; med precision 0.00001526. Observera att utsignalen visas i 2: s komplimentsform om respektive sinus- eller cos -värde är negativt. Simulering av testb.vhd - Testbänk för konstruktionen (1) Mata in vinklar och dragåterställning = '0'. Efter två steg av simulering, återställ till "1" och "kör alla". (2) I simuleringsfönstret ställer du in radixen för sin- och cosignaler som decimal och format> Analog (automatisk). (3) Zooma ut för att se vågformen ordentligt.

Steg 3: Bifogade filer

(1) cordic_v4.vhd - Design. (2) testb.vhd - Testbänk för konstruktionen.

(3) Dokumentera hur man tvingar in vinkelinmatningar och konverterar de binära resultaten.

Uppdatering: DENNA FILER ÄR OBSELETERADE OCH GÖRES INTE MER. Vänligen använd filer från nästa steg

Steg 4: Mini -Cordic IP -kärna - 16 bitar

Begränsning av ovanstående implementering är- långsam, lägre klockfrekvens för drift på grund av beräkningar i en enda klockcykel. Mini-Cordic IP Core- 16 Bit

- Kritiska vägar fördelade på flera cykler för att förbättra prestanda.- Snabbare- FPGA beprövad design syntetiseras upp till 100 Mhz klocka.- Mer yta optimerat i HDL, Mindre hårdvara.- Belastnings- och klara statussignaler tillagda.- Endast nackdelen är lägre upplösning jämfört med föregående. Testbänk:

helt automatiserad från 0 till 360 graders vinkelingångar

Bifogade filer: 1) mini cordic main vhdl file2) mini cordic test bench3) Mini Cordic IP Core manual4) Doc om hur man tvingar vinklar och konverterar resultat

För frågor, kontakta mig gärna:

Mitu Raj

följ mig:

mail: [email protected]

### Totalt antal nedladdningar: 325 från och med 01-05-2021 ###

### Koden redigerades senast: 07-07-2020 ###

Rekommenderad: