Spectrum analyzer for multiple SDR platforms (PyQtGraph based GUI for soapy_power, hackrf_sweep, rtl_power, rx_power and other backends)
Go to file
Michal Krenek (Mikos) 0af92b3d16 Fix typo
2015-12-10 01:42:04 +01:00
qspectrumanalyzer Add support for rtl_power_fftw backend 2015-12-07 03:36:43 +01:00
.gitignore Code refactoring before publishing on PyPI 2015-04-24 16:26:42 +02:00
LICENSE Initial commit 2015-03-03 00:50:46 +01:00
MANIFEST.in Switch from distutils to setuptools 2015-04-26 22:16:21 +02:00
PKGBUILD Add support for rtl_power_fftw backend 2015-12-07 03:36:43 +01:00
qspectrumanalyzer.desktop Add support for rtl_power_fftw backend 2015-12-07 03:36:43 +01:00
qspectrumanalyzer.png Initial commit 2015-03-03 00:50:46 +01:00
qspectrumanalyzer.svg Initial commit 2015-03-03 00:50:46 +01:00
README.rst Fix typo 2015-12-10 01:42:04 +01:00
setup-qt.py Update setup-qt.py script 2015-04-24 16:30:48 +02:00
setup.py Switch from distutils to setuptools 2015-04-26 22:16:21 +02:00

QSpectrumAnalyzer
=================

Spectrum analyzer for RTL-SDR (GUI for rtl_power based on PyQtGraph)

Screenshot
----------

.. image:: https://xmikos.github.io/qspectrumanalyzer/qspectrumanalyzer_screenshot.png

Requirements
------------

- Python >= 3.3
- PyQt >= 4.5
- PyQtGraph (http://www.pyqtgraph.org)
- rtl-sdr (https://github.com/keenerd/rtl-sdr)
- Optional: rtl_power_fftw (https://github.com/AD-Vega/rtl-power-fftw)

You should use `Keenerds fork of rtl-sdr <https://github.com/keenerd/rtl-sdr>`_
(latest Git revision), because ``rtl_power`` in original rtl-sdr (from osmocom.org)
is broken (especially when used with cropping).

Another alternative is
`rtl_power_fftw <https://github.com/AD-Vega/rtl-power-fftw>`_ which has various
benefits over ``rtl_power``. E.g. better FFT performance (thanks to
use of ``fftw`` library) and possibility to use much shorter acquisition time
for more real-time continuous measurement (minimum interval in original
``rtl_power`` is 1 second, but in ``rtl_power_fftw`` you are only limited
by number of frequency hops).

Usage
-----

Start QSpectrumAnalyzer by running ``qspectrumanalyzer``.

You can choose if you want to use ``rtl_power`` or ``rtl_power_fftw`` backend in
*File* -> *Settings* (default is ``rtl_power``). Path to ``rtl_power``
(or ``rtl_power_fftw``) executable can be also manually specified there. You can also
set waterfall plot history size in there. Default is 100 lines, be aware that
really large sweeps (with a lot of bins) would require a lot of system memory, so
don't make this number too big.

Controls should be intuitive, but if you want consistent results, you should
turn off automatic gain control (set it to some fixed number) and also set
crop to 20% or more. For finding out ppm correction factor for your rtl-sdr
stick, use `kalibrate-rtl <https://github.com/steve-m/kalibrate-rtl>`_.

You can move and zoom plot with mouse, change plot settings or export plots
from right-click menu. Waterfall plot black/white levels and color lookup
table can be changed in mini-histogram widget.

Installation
------------

**Arch Linux:**
::

    git clone https://aur.archlinux.org/qspectrumanalyzer.git
    cd qspectrumanalyzer
    makepkg -sri

Or simply use `pacaur <https://aur.archlinux.org/packages/pacaur>`_ (or any other AUR helper):
::

    pacaur -S qspectrumanalyzer

**Debian / Ubuntu:**
::

    sudo apt-get install python3-pip python3-pyqt4 python3-numpy
    sudo pip3 install qspectrumanalyzer

Warning! ``pip`` will install packages system-wide by default, but you
should always use your distribution package manager for this.

You can install it locally only for your current user by running this (without ``sudo``):
::

    pip3 install --user qspectrumanalyzer

Executables will be then placed in ``~/.local/bin`` directory, you can add it to your
PATH in ``~/.bashrc``.

Todo:
-----

- peak hold (maybe even with gradual fading, RTSA-like spectrum visualization similar to
  `gr-fosphor <http://www.cgran.org/pages/gr-fosphor.html>`_)
- automatic peak detection / highlighting
- frequency markers / bookmarks with notes (even importing / exporting .csv file with
  predefined channels, etc.)