sdr-psk-fpga icon indicating copy to clipboard operation
sdr-psk-fpga copied to clipboard

Dual-Mode PSK Transceiver on SDR With FPGA

Dual-Mode PSK Transceiver on SDR With FPGA

[!NOTE] This is a course project of Southeast University (2023 Fall).

Features

  • [x] BPSK/QPSK Modulation
  • [x] Coherent BPSK/QPSK Demodulation
  • [x] Carrier Synchronization (with Costas Loop)
  • [x] Symbol (Timing) Synchronization (with Gardner Loop)
  • [x] Packet-Based Communication
  • [x] Dynamic BPSK and QPSK Switching
  • [x] Pseudorandom (PN) Sequence Generator
  • [x] Block Diagram (with IP + Verilog RTL)
  • [x] Verified with Testbench
  • [x] Tested on SDR
  • [ ] Pulse Shaping

You can explore details of implementations in the report.

[!TIP] The current design is resource-efficient. You have plenty of room to implement the remaining features to further enhance the platform.

Platforms

  • SDR: eNodeX 30B
    • FPGA: Xilinx Zynq 7020 (xc7z020clg484-1)
    • 1Tx-1Rx with GSM Antenna (Max 2Tx-2Rx on SDR but we only use 1Tx-1Rx)
    • 4 GPIO as Output Signals (Max 8 GPIO Pins on SDR)
  • Software
    • Vivado 2022.2 (To directly open the project, you need version >= 2022.2)
    • Matlab Filter Designer Toolbox (You can use alternatives to generate Xilinx .coe files)
    • LaTeX (My Version: TeX Live 2023 Latest)
    • Python >= 3.9 (For Data Processing in Report)

Directories

License

This project is distributed under the MIT License. The report is open access under the CC BY-SA 4.0.