GNU Radio stable release 3.1.0 is now available for download:
http://gnuradio.org/releases/gnuradio/gnuradio-3.1.0.tar.gz
http://gnuradio.org/releases/gnuradio/gr-howto-write-a-block-3.1.0.tar.gz
Binary installation packages for Ubuntu 32-bit and 64-bit systems are
documented at:
http://gnuradio.org/trac/wiki/DebianPackages
Release 3.1.0 is based on a snapshot of the current development trunk,
with a few incomplete or buggy portions removed. Changes on this stable
branch are documented at:
http://gnuradio.org/trac/wiki/Release3.1Branch
If you want to check out a Subversion branch that only includes updates
along this series, use:
$ svn co http://gnuradio.org/svn/gnuradio/branches/releases/3.1
While 3.1.0 is based on the current development trunk that many are
familiar with, it has been a full year since the last stable branch was
cleaved from the trunk. The changes between then and now are many and
varied; here are some highlights:
-
New hierarchical flow graph code, allowing arbitrarily nested
flow graphs and runtime flow graph reconfiguration (gr.top_block,
gr.hier_block2). All the gnuradio-examples programs have been ported to
this new way of doing things, to illustrate the differences in syntax.
(The stable branch, however, also maintains the existing gr.flow_graph()
based API.) -
New top-level components
- gr-atsc (ATSC TV receiver, not real-time)
- gr-comedi (drivers for Linux Control and Measurement Interfaces)
- gr-pager (Wideband multi-channel FLEX pager receiver/decoder)
- gr-radar-mono (Monostatic Active Radar with up to 32 MHz LFM chirps)
- gr-sounder (Channel sounder for up to 32 MHz wide passband channels)
- gr-utils (Commonly used USRP and other scripts moved from examples)
-
Streamlined build and installation
- Binary packaging for Debian/Ubuntu and similar systems
- Reduced memory footprint for compilation
-
Many, many bug fixes and updates all over the tree (documentation
volunteers welcomed…)
This new stable branch will be maintained such that existing Python and
C++ code based upon it will not break due to updates in the series. New
releases in this series will have backported bug fixes and new features
added. However, no changes will be made that (intentionally!) result in
existing user code not functioning.
If it sounds like this means we will be making such changes on the
trunk, you are absolutely right. Several features targeted for the 3.2
stable branch will require deep surgery and will break user code that
doesn’t keep up:
- Removal of gr.flow_graph(), leaving only gr.top_block() added in 3.1
- Removal of gr.hier_block(), leaving only gr.hier_block2() added in 3.1
- In-band signaling for USRP communications
- M-blocks, a new message/packet-oriented hierarchical flow model
- Pure C++ GNU Radio applications, with no Python involved
- Scheduler changes to better scale to multi-core CPUs
Install and develop for the 3.1 stable branch if you want to avoid any
issues, or work off the trunk and enjoy the ride.
–
Johnathan C.
Corgan Enterprises LLC
http://corganenterprises.com