Open source, multi-user SDR receiver software with a web interface
Go to file
2014-11-29 13:56:56 +01:00
htdocs logo fix 2014-11-29 01:36:15 +01:00
plugins added ddc_transition_bw() 2014-11-29 13:56:56 +01:00
config_rtl.py initial commit 2014-11-29 01:07:10 +01:00
config_webrx.py added ddc_transition_bw() 2014-11-29 13:56:56 +01:00
openwebrx.py thread id error fixed 2000-01-01 19:35:00 +01:00
README.md added ddc_transition_bw() 2014-11-29 13:56:56 +01:00
rtl_mus.py initial commit 2014-11-29 01:07:10 +01:00
rxws.py initial commit 2014-11-29 01:07:10 +01:00
screenshot.jpg jpg extension 2014-11-29 01:09:26 +01:00

OpenWebRX

OpenWebRX is a multi-user SDR receiver software with a web interface.

OpenWebRX

It has the following features:

  • libcsdr based demodulators (AM/FM/SSB),
  • filter passband can be set from GUI,
  • waterfall display can be shifted back in time,
  • it extensively uses HTML5 features like WebSocket, Web Audio API, and <canvas>.
  • it works in Google Chrome, Chromium (above version 37) and Mozilla Firefox (above version 28),
  • currently only supports RTL-SDR, but other SDR hardware may be easily added.

Setup

OpenWebRX currently requires a Linux machine to run.

First you will need to install the dependencies:

After cloning this repository and connecting an RTL-SDR dongle to your computer, you can run the server:

python openwebrx.py

You can now open the GUI at http://localhost:8073.

Please note that the server is also listening on the following ports (on localhost only):

  • port 8888 for the I/Q source,
  • port 4951 for the multi-user I/Q server.

Now the next step is to customize the parameters of your server in config_webrx.py.

Actually, if you do something cool with OpenWebRX (or just have a problem), please drop me a mail:
Andras Retzler, HA7ILM <randras@sdr.hu>

I would like to maintain a list of online amateur radio receivers on sdr.hu.

Usage tips

The filter envelope can be dragged at its ends and moved around to set the passband.

However, if you hold the shift key, you can drag the center line (BFO) or the whole passband (PBS).

Configuration tips

If you want to run OpenWebRX on a remote server instead of localhost, do not forget to set server_hostname in config_webrx.py, or you may get a WebSocket error.

DSP CPU usage can be fine-tuned in plugins/dsp/csdr/plugin.py: you can set transition bandwidths higher (thus degrade filter performance by decreasing the length of the kernel, but also decrease CPU usage).

Todo

Currently, clients use up a lot of bandwidth. This will be improved later.