GSoCIdeas: Difference between revisions
|  (Add another 2025 project - easy and small-medium) | |||
| (12 intermediate revisions by 4 users not shown) | |||
| Line 2: | Line 2: | ||
| == Summer of Code  | == Summer of Code 2025: Project ideas list == | ||
| This is the list of project ideas for the summer of code  | This is the list of project ideas for the summer of code 2025 within GNU Radio.<br /> | ||
| Remember that these are '''ideas''' and are merely meant as an inspiration for you to write your own proposal. | Remember that these are '''ideas''' and are merely meant as an inspiration for you to write your own proposal. | ||
| Line 22: | Line 22: | ||
| * Both OOTs and in-tree improvements are welcome | * Both OOTs and in-tree improvements are welcome | ||
| === FM Broadcast Radio application === | |||
| GNU Radio has built-in capabilities to receive, decode and play FM broadcast radio stations. With additional projects https://github.com/bastibl/gr-rds we are able to decode RDS data alongside.  | |||
| The project does not (yet) have a fully fledged demo application which would allow potential users and beginners to see how to build a production-grade application (almost). The goal for this project  | |||
| is to build an application which works plug&play with many SDRs and automatically scans (all) potential FM broadcast frequencies, gives a channel list and allows users to tune/select a radio station they would like to listen to. | |||
| Therefore one part of the project is to focus on a polished user experience in the frontend application. Since this should be a good demo the other part of the project should focus on developing a well-functioning flowgraph with  | |||
| the existing signal processing blocks and potentially also porting gr-rds to a newer GNU Radio and/or integrating it in the GNU Radio source tree. This flowgraph should then be started/halted on demand of the frontend application. | |||
| Potentially multiple streams could be recorded at the same time or decoded and some of the signal processing signals can be shown in a debug view so potential beginners and users can perform introspection on the application. | |||
| '''Prerequisites''' | |||
| * Programming skills in Python | |||
| * Interest in designing a functional and polished graphical user interface | |||
| * Preferred: Familiarity with basic signal processing libraries in Python (e.g., SciPy). | |||
| * Interest working with real radio signals | |||
| '''Expected Outcome''' | |||
| * Fully fledged FM broadcast receiver application with integrated RDS and spectrum scanning | |||
| * A clean example application which shows how the signal processing can be combined well with a GUI | |||
| '''Project Length''' | |||
| * Small (100 hours) – Medium (200 hours) | |||
| '''Difficulty'''' | |||
| * Easy | |||
| '''Mentor(s)''' | |||
| * Andrej Rode | |||
| === 5G Cell Scanner === | |||
| Cell scanning by passively observing the RF environment using an SDR and decoding received signals based on the waveforms defined in the 2G/3G/4G/5G standards is a well-established approach for assessing cellular connectivity in the surrounding environment. While multiple cell scanners are publicly available, they often employ opaque signal processing methods and frequently cease analysis prematurely, failing to provide detailed information about the cells. This includes not decoding the Master Information Block (MIB) and the System Information Block (SIB1) to extract cell properties and signal quality metrics. | |||
| Our objective is to develop a high-quality cell scanner using GNU Radio in a transparent way that delivers the most information possible (depending on the cells’ signal levels) in a trustable manner. The general procedure will be based on the initial synchronization and cell identification process on the user-equipment side of 5G (see further reads). | |||
| Depending on the student’s experience, we can also go a step further and parallelize the cell scanning process by observing multiple frequency bands simultaneously by applying channelization and parallel processing techniques to the signal. | |||
| '''Prerequisites''' | |||
| * Proficiency with GNU Radio. | |||
| * Basic programming skills in Python. | |||
| * Preferred: Familiarity with basic signal processing libraries in Python (e.g., SciPy). | |||
| * Preferred: General understanding of the 5G waveform and experience with 5G processing libraries in Python. | |||
| '''Expected Outcome''' | |||
| * Development of an Out-Of-Tree (OOT) module or flowgraphs capable of interacting with SDR input streams and automatically generating detailed visualizations of cell search results. | |||
| * Capability to export results as a function of time and SDR location to enable the creation of coverage maps. | |||
| '''Further Reads''' | |||
| * https://de.mathworks.com/help/5g/ug/nr-cell-search-and-mib-and-sib1-recovery.html  | |||
| * https://de.mathworks.com/help/5g/gs/synchronization-signal-blocks-and-bursts.html | |||
| '''Project Length''' | |||
| * Small (100 hours) – Medium (200 hours) | |||
| '''Difficulty'''' | |||
| * Medium | |||
| '''Mentor(s)''' | |||
| * Michael Petry | |||
| * Andrej Rode | |||
| === Expanding the GNU Radio 4.0 Block Set === | |||
| GNU Radio 4.0 has reached a stage where real signal processing applications can achieve performance improvements over GNU Radio 3.x. To maximize its adoption, we aim to expand the set of available blocks, making it easier for the community to build applications with readily available components.  The goal of this project is to migrate existing GR 3.x blocks (e.g. gr-digital, gr-analog, gr-audio ...) into GR 4.0.  A good list of blocks in GR3 that should be ports has been maintained here:  [https://github.com/fair-acc/gnuradio4/issues/161] | |||
| '''Prerequisites''' | |||
| * Knowledge of modern C++ | |||
| * Signal processing understanding | |||
| '''Outcome''' | |||
| * GR4 OOT module with a substantial number of blocks | |||
| * Each block should have CI tests and an example flowgraph | |||
| * Document the process so that other block developers can be guided | |||
| '''Project length''' | |||
| Long (350 hours) | |||
| '''Difficulty''' | |||
| Medium | |||
| '''Mentor(s)''' | |||
| John Sallay, Josh Morman | |||
| === Graphical interoperability between CyberEther and GNU Radio === | === Graphical interoperability between CyberEther and GNU Radio === | ||
| The [https://github.com/luigifcruz/CyberEther CyberEther] project comes with some neat graphical sinks that would be great to have access to in GNU Radio. This project entails creating a new CyberEther GUI workflow much like the [https://github.com/gnuradio/gr-bokehgui gr-bokehgui] project, such that users can create flowgraphs with CyberEther sinks. | The [https://github.com/luigifcruz/CyberEther CyberEther] project comes with some neat graphical sinks that would be great to have access to in GNU Radio. This project entails creating a new CyberEther GUI workflow much like the [https://github.com/gnuradio/gr-bokehgui gr-bokehgui] project, such that users can create flowgraphs with CyberEther sinks. This would allow the user to visualize GNU Radio data streams in one of the high-performance CyberEther plots (lineplot, waterfall, spectrogram, etc). | ||
| '''Prerequisites''' | '''Prerequisites''' | ||
| * Knowledge of C++ and some Python | * Knowledge of C++ and some Python | ||
| * Familiarity with graphical APIs ( | * Familiarity with graphical APIs (OpenGL, Vulkan, Metal) | ||
| * Basic Qt understanding | * Basic Qt understanding | ||
| '''Outcome''' | |||
| * OOT module with CyberEther sinks | |||
| * Support for both GNU Radio main branch and 3.10? | |||
| '''Project length''' | '''Project length''' | ||
| Line 82: | Line 175: | ||
| * Knowledge of C++ and Python. | * Knowledge of C++ and Python. | ||
| * Familiarity with CUDA programming | * Familiarity with CUDA programming | ||
| '''Outcome''' | |||
| Depends on chosen subprojects (see above). | |||
| '''Project length''' | '''Project length''' | ||
| Line 93: | Line 191: | ||
| '''Mentor(s)''' | '''Mentor(s)''' | ||
| Josh Morman | Josh Morman, Andrej Rode | ||
| === GRC and GR 4.0 === | |||
| Development of GR 4.0 is progressing quickly. In the current runtime prototype a plugin architecture is used to properly register blocks with the runtime.  | |||
| This allows a more dynamic construction of flowgraphs and introspection into the blocks. But this means the current way of assembling a flowgraph by generating a Python or C++  | |||
| file needs updates.  | |||
| The idea is to port and change necessary parts of GRC (Qt development version) to use the block registry in the new GNU Radio runtime https://github.com/gnuradio/gnuradio4/ and assemble some of the example flowgraphs defined in GRC files and make them run.   | |||
| The design for this is not finalized and therefore you will have freedom to propose your ideas. | |||
| '''Prerequisites''' | |||
| * Good Knowledge of C++ and Python | |||
| * Experience with inter-language bindings (not necessarily C++ & Python) is useful | |||
| * Basic Qt understanding | |||
| '''Outcome''' | |||
| '' | |||
| *  | * Prototype integration of GRC with the new plugin architecture of GR 4.0 | ||
| '''Project length''' | '''Project length''' | ||
| 350 hours | Long (350 hours) | ||
| '''Difficulty''' | '''Difficulty''' | ||
| Challenging | |||
| '''Mentor(s)''' | '''Mentor(s)''' | ||
| Josh Morman | Andrej Rode, Josh Morman | ||
| Line 192: | Line 253: | ||
| '''Mentor(s)''' | '''Mentor(s)''' | ||
| Håkon Vågsether | Andrej Rode, Håkon Vågsether | ||
| === CI for maintenance branches and select OOT modules === | === CI for maintenance branches and select OOT modules === | ||
Latest revision as of 20:31, 27 February 2025
Note- also check out Grant Ideas for additional ideas that are more suited towards grant money than GSoC.
Summer of Code 2025: Project ideas list
This is the list of project ideas for the summer of code 2025 within GNU Radio.
Remember that these are ideas and are merely meant as an inspiration for you to write your own proposal.
Students who do not find a fit among these projects are encouraged to engage with us and suggest new ones. The GNU Radio discussion mailing list is the best place to contact all of us. Please do not contact us off-list for the sake of discussing the summer of code, unless you're contacting a mentor listed here to get feedback on a proposal.
Reviewing the Google GSoC FAQ page for a broader understanding of project, mentor, and student responsibilities is recommended.
If you need a USRP or other radio hardware to complete the project, we will be able to arrange something.
Please add ideas to this list (you may cannibalize old ideas, of course!).
Guidelines for good projects (when suggesting projects, please consider these):
- Clearly defined scope, with a main target that can be done in 3 months
- Clear benefits for the GNU Radio project
- Not specific to a certain hardware. No specific embedded devices, either, please.
- Both OOTs and in-tree improvements are welcome
FM Broadcast Radio application
GNU Radio has built-in capabilities to receive, decode and play FM broadcast radio stations. With additional projects https://github.com/bastibl/gr-rds we are able to decode RDS data alongside. The project does not (yet) have a fully fledged demo application which would allow potential users and beginners to see how to build a production-grade application (almost). The goal for this project is to build an application which works plug&play with many SDRs and automatically scans (all) potential FM broadcast frequencies, gives a channel list and allows users to tune/select a radio station they would like to listen to.
Therefore one part of the project is to focus on a polished user experience in the frontend application. Since this should be a good demo the other part of the project should focus on developing a well-functioning flowgraph with the existing signal processing blocks and potentially also porting gr-rds to a newer GNU Radio and/or integrating it in the GNU Radio source tree. This flowgraph should then be started/halted on demand of the frontend application. Potentially multiple streams could be recorded at the same time or decoded and some of the signal processing signals can be shown in a debug view so potential beginners and users can perform introspection on the application.
Prerequisites
- Programming skills in Python
- Interest in designing a functional and polished graphical user interface
- Preferred: Familiarity with basic signal processing libraries in Python (e.g., SciPy).
- Interest working with real radio signals
Expected Outcome
- Fully fledged FM broadcast receiver application with integrated RDS and spectrum scanning
- A clean example application which shows how the signal processing can be combined well with a GUI
Project Length
- Small (100 hours) – Medium (200 hours)
Difficulty'
- Easy
Mentor(s)
- Andrej Rode
5G Cell Scanner
Cell scanning by passively observing the RF environment using an SDR and decoding received signals based on the waveforms defined in the 2G/3G/4G/5G standards is a well-established approach for assessing cellular connectivity in the surrounding environment. While multiple cell scanners are publicly available, they often employ opaque signal processing methods and frequently cease analysis prematurely, failing to provide detailed information about the cells. This includes not decoding the Master Information Block (MIB) and the System Information Block (SIB1) to extract cell properties and signal quality metrics. Our objective is to develop a high-quality cell scanner using GNU Radio in a transparent way that delivers the most information possible (depending on the cells’ signal levels) in a trustable manner. The general procedure will be based on the initial synchronization and cell identification process on the user-equipment side of 5G (see further reads). Depending on the student’s experience, we can also go a step further and parallelize the cell scanning process by observing multiple frequency bands simultaneously by applying channelization and parallel processing techniques to the signal.
Prerequisites
- Proficiency with GNU Radio.
- Basic programming skills in Python.
- Preferred: Familiarity with basic signal processing libraries in Python (e.g., SciPy).
- Preferred: General understanding of the 5G waveform and experience with 5G processing libraries in Python.
Expected Outcome
- Development of an Out-Of-Tree (OOT) module or flowgraphs capable of interacting with SDR input streams and automatically generating detailed visualizations of cell search results.
- Capability to export results as a function of time and SDR location to enable the creation of coverage maps.
Further Reads
- https://de.mathworks.com/help/5g/ug/nr-cell-search-and-mib-and-sib1-recovery.html
- https://de.mathworks.com/help/5g/gs/synchronization-signal-blocks-and-bursts.html
Project Length
- Small (100 hours) – Medium (200 hours)
Difficulty'
- Medium
Mentor(s)
- Michael Petry
- Andrej Rode
Expanding the GNU Radio 4.0 Block Set
GNU Radio 4.0 has reached a stage where real signal processing applications can achieve performance improvements over GNU Radio 3.x. To maximize its adoption, we aim to expand the set of available blocks, making it easier for the community to build applications with readily available components. The goal of this project is to migrate existing GR 3.x blocks (e.g. gr-digital, gr-analog, gr-audio ...) into GR 4.0. A good list of blocks in GR3 that should be ports has been maintained here: [1]
Prerequisites
- Knowledge of modern C++
- Signal processing understanding
Outcome
- GR4 OOT module with a substantial number of blocks
- Each block should have CI tests and an example flowgraph
- Document the process so that other block developers can be guided
Project length
Long (350 hours)
Difficulty
Medium
Mentor(s)
John Sallay, Josh Morman
Graphical interoperability between CyberEther and GNU Radio
The CyberEther project comes with some neat graphical sinks that would be great to have access to in GNU Radio. This project entails creating a new CyberEther GUI workflow much like the gr-bokehgui project, such that users can create flowgraphs with CyberEther sinks. This would allow the user to visualize GNU Radio data streams in one of the high-performance CyberEther plots (lineplot, waterfall, spectrogram, etc).
Prerequisites
- Knowledge of C++ and some Python
- Familiarity with graphical APIs (OpenGL, Vulkan, Metal)
- Basic Qt understanding
Outcome
- OOT module with CyberEther sinks
- Support for both GNU Radio main branch and 3.10?
Project length
Long (350 hours)
Difficulty
Medium
Mentor(s)
Luigi Cruz, Håkon Vågsether
GPU Accelerated Signal Processing Blocks
GPUs offer incredible capability for accelerating a number of signal processing routines when the calculations can be done in parallel. Also, GNU Radio 3.10 brought in a "custom buffers" feature which provides support generally for accelerator devices by allowing blocks to have direct access to device memory, finally making accelerator processing feasible through a flowgraph (see FOSDEM 2022 Presentation.
One piece that is missing for GNU Radio is a library of blocks that accelerate common DSP routines. There are several interesting libraries of GPU accelerated signal processing - primarily using CUDA because of its accessible programming paradigm and the ubiquity of NVIDIA hardware:
Integration of any of this functionality, along with additional kernels for signal processing would need to be predicated on using gr-cuda custom buffers, and expanding this module as needed
This project can be broken into several subprojects:
- Create gr-matx OOT
- Add Matx Custom Buffer Type (after gr-cuda)
- Create blocks wrapping Matx operations
 
- Expand gr-cuda
- Additional custom buffer types - pinned, unified
- Create python custom buffers allowing zero copy into python blocks
 
- Create gr-cuSignal
- Wrap cuSignal functionality (dependent on python zero copy)
 
- Replicate existing GR blocks as CUDA accelerated (things not in cuSignal or Matx)
- Target for extensions to Matx, cuSignal, or CUSP (within our control)
- FIR Filters
- Polyphase Resampler
- Signal Source
- Moving Average
- Polyphase Clock Sync
- Stream Operators
- ...
 
Prerequisites
- Knowledge of C++ and Python.
- Familiarity with CUDA programming
Outcome
Depends on chosen subprojects (see above).
Project length
350 hours
Difficulty
Medium
Mentor(s)
Josh Morman, Andrej Rode
GRC and GR 4.0
Development of GR 4.0 is progressing quickly. In the current runtime prototype a plugin architecture is used to properly register blocks with the runtime. This allows a more dynamic construction of flowgraphs and introspection into the blocks. But this means the current way of assembling a flowgraph by generating a Python or C++ file needs updates.
The idea is to port and change necessary parts of GRC (Qt development version) to use the block registry in the new GNU Radio runtime https://github.com/gnuradio/gnuradio4/ and assemble some of the example flowgraphs defined in GRC files and make them run. The design for this is not finalized and therefore you will have freedom to propose your ideas.
Prerequisites
- Good Knowledge of C++ and Python
- Experience with inter-language bindings (not necessarily C++ & Python) is useful
- Basic Qt understanding
Outcome
- Prototype integration of GRC with the new plugin architecture of GR 4.0
Project length
Long (350 hours)
Difficulty
Challenging
Mentor(s)
Andrej Rode, Josh Morman
Revitalize in-tree and out-of-tree (OOT) modules
A lot has changed since version 3.7, and GNU Radio has made great technical strides the last few years. However, some OOT modules haven't been updated to support the latest versions of GNU Radio, and these modules currently require the user to install an older version of the framework. This is unfortunate, and lowers the useability of GNU Radio as a whole. Some of these modules have been superseded by others, but might still have some blocks or flowgraphs that are useful, and these could be updated and moved in-tree. Some in-tree modules are also in need of attention, like gr-wavelet, which does not have any examples.
Prerequisites
- Knowledge of C++, Python and DSP.
Outcome
- More example code, tests and flowgraphs for various in-tree modules
- Porting various OOT modules to support recent versions of GNU Radio
- Possibly blocks/flowgraphs from old OOT modules moved in-tree
Project length
Small (90 hours) - Medium (175 hours)
Difficulty
Easy - Medium
Mentor(s)
Andrej Rode, Håkon Vågsether
CI for maintenance branches and select OOT modules
It would be useful to have nightly builds for GNU Radio's maintenance branches (3.8, 3.9, 3.10) and some select OOTs.
Prerequisites
- Experience with Docker?
- ?
Outcome
- Automated PPAs, Snaps, Flatpak apps
Project length
175 hours
Difficulty
Easy
Mentor(s)
Håkon Vågsether, ?
Old Ideas
Feel free to browse old ideas from previous years for inspiration.