GithubHelp home page GithubHelp logo

rob0tsunny / fpga_ip Goto Github PK

View Code? Open in Web Editor NEW

This project forked from oscimp/fpga_ip

0.0 1.0 0.0 579 KB

OscillatorIMP ecosystem FPGA IP sources

Shell 0.08% Tcl 11.27% Verilog 0.39% VHDL 84.73% Makefile 1.59% C 0.91% MATLAB 0.31% Vim Script 0.04% Python 0.36% Coq 0.31%

fpga_ip's Introduction

fpga_ip

In order to allow for pipelined processing of datastreams with no latency introduced by FIFOs or glue between blocks, dedicated custom interfaces have been introduced: real and complex numbers and associated control signals. These interfaces are of varying, user defined, bit width. A complex number is two real numbers processed in parallel.

Data structure

OscillatorIMP ecosystem FPGA IP sources

Block name Function Input(s) Output(s) Parameter(s) Driver Library function(s) (liboscimp)
ad9767 Redpitaya DAC (obsolete: see redpitaya_converters) dataA_in,dataB_in none none none
add_constComplex Add a constant to complex value stream data_in data_out DATA_IN_SIZE(16), DATA_OUT_SIZE(18) add_const add_const_set_offset, add_const_get_offset, add_constMulti_set_offset
add_constReal Add a constant to real value stream data_in data_out DATA_IN_SIZE(16), DATA_OUT_SIZE(18) add_const add_const_set_offset, add_const_get_offset, add_constMulti_set_offset
adder_substracter_complex Sum or difference of complex values data1_i, data2_i data_o DATA_SIZE(16) none none
adder_substracter_real Sum or difference of real values data1_i, data2_i data_o DATA_SIZE(16) none none
axiStreamToComplex Xilinx AXI Stream to complex stream TODO TODO TODO TODO TODO
axiStreamToReal Xilinx AXI Stream to real stream TODO TODO TODO TODO TODO
axi_deltaSigma Slow DAC output (Sigma-Delta) TODO TODO TODO TODO TODO
axi_to_dac AXI value to DAC none dataA_out, dataB_out DATA_SIZE(14) axi_to_dac axi_to_dac_full_conf
cacode GPS Gold Code generator TODO TODO TODO TODO TODO
convertComplexToReal Complex -> real values data_in dataI_out,dataQ_out DATA_SIZE(8) none none
convertRealToComplex Real -> complex values dataI_in,dataQ_in data_out DATA_SIZE(8) none
dataComplex_to_ram PL to PS transfer (complex values) dataN_in none DATA_SIZE(32), NB_INPUT(12), NB_SAMPLE(1024) data_to_ram
dataReal_to_ram PL to PS transfer (real values) dataN_in none DATA_SIZE(32), NB_INPUT(12), NB_SAMPLE(1024) data_to_ram
dupplReal_1_to_2 Splits a real value stream data_in data1_out,data2_out DATA_SIZE(8) none
dupplComplex_1_to_2 Splits a complex value stream data_in data1_out,data2_out DATA_SIZE(8) none
expanderComplex Add Most Significant Bits (complex) data_in data_out DATA_IN_SIZE(16), DATA_OUT_SIZE(16) none
expanderReal Add Most Significant Bits (real value) data_in data_out DATA_IN_SIZE(16), DATA_OUT_SIZE(16) none
firReal Finite Impulse Response (FIR) filter with real coefficients provided from the processor, applied to real input stream data_in data_out DATA_SIZE(16), NB_COEFF(128), DECIMATE_FACTOR(32), DATA_OUT_SIZE(32), COEFF_SIZE(16) fir
ltc2145 Redpitaya ADC (obsolete: see redpitaya_converters) none dataA_out,dataB_out none none
meanComplex outputs the mean value of the complex valued input stream data_in data_out INPUT_DATA_SIZE(16), OUTPUT_DATA_SIZE(18), nb_accum(8), shift(3) none none
meanReal outputs the mean value of the real valued input stream data_in data_out INPUT_DATA_SIZE(16), OUTPUT_DATA_SIZE(18), nb_accum(8), shift(3) none none
mean_vector_axi Average complex input stream (ADDR_SIZE=burst length) data_in data_out DATA_SIZE(14),MAX_NB_ACCUM(1024),ADDR_SIZE(10)
mixer_sin mixer data_in,nco_in data_out DATA_SIZE(16), NCO_SIZE(16) none
nco_counter NCO (sine & square = complex values) none sine_out, square_out COUNTER_SIZE(28), DATA_SIZE(16) nco_counter nco_counter_send_conf
prn20b 20-bit pseudo random number sequence (LFSR) none data_out none none none
redpitaya_adc_dac_clk Repitaya clock distribution (ADC & DAC) none none none none
redpitaya_converters Redpitaya ADC/DAC converters dataA_in, dataB_in dataA_out, dataB_out ADC_EN(true), DAC_EN(true), ADC_SIZE(14) none none
shifterReal Bit shift (real values) data_in data_out DATA_IN_SIZE(32), DATA_OUT_SIZE(16) none
shifterComplex Bit shift (complex values) data_in data_out DATA_IN_SIZE(32), DATA_OUT_SIZE(16) none
switchComplex Complex stream multiplexer data1_in,data2_in data_out DATA_SIZE(16),DEFAULT_INPUT(0) switch switch_conf
switchReal Real stream multiplexer data1_in,data2_in data_out DATA_SIZE(16),DEFAULT_INPUT(0) switch switch_conf

For the pulse RADAR application:

Block name Function Input(s) Output(s) Parameter(s) Driver Library function(s) (liboscimp)
check_valid_burst
extract_data_from_burst
gen_radar_prog

For the pulse PlutoSDR demonstration and audio output/sigma-delta DAC with DC component output in general:

Block name Function Input(s) Output(s) Parameter(s) Driver Library function(s) (liboscimp)
axi_deltaSigma

fpga_ip's People

Contributors

jmfriedt avatar trabucayre avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.