Vector Network Analyzer using Pluto SDR
Go to file
Brendan Haines 086f348084
All checks were successful
Publish Python 🐍 distribution 📦 to PyPI and TestPyPI / Build distribution 📦 (push) Successful in 16s
Publish Python 🐍 distribution 📦 to PyPI and TestPyPI / Publish Python 🐍 distribution 📦 to PyPI (push) Has been skipped
add pypi link
2025-01-17 00:37:30 -07:00
.github/workflows use an old release of pypa/gh-action-pypi-publish that actually works 2024-12-08 13:48:24 -07:00
.vscode add lots of boilerplate python packaging code 2024-11-10 11:33:37 -07:00
charon_vna fix vswr plots for S11 > 0dB 2025-01-17 00:34:29 -07:00
.gitignore add lots of boilerplate python packaging code 2024-11-10 11:33:37 -07:00
Pipfile auto-formatting tools 2024-12-19 00:04:51 -07:00
Pipfile.lock auto-formatting tools 2024-12-19 00:04:51 -07:00
pyproject.toml urls 2024-12-19 00:55:27 -07:00
README.md add pypi link 2025-01-17 00:37:30 -07:00
setup.cfg add lots of boilerplate python packaging code 2024-11-10 11:33:37 -07:00

Charon VNA

Named after Pluto's moon, Charon uses the ADI Pluto SDR as a vector network analyzer. The basic usage is as a 1 port VNA but this can be extended to arbitrarily many ports with the addition of a couple RF switches.

Installation

  1. Install LibIIO. This is a dependency of PyADI-IIO. On Ubuntu 22.04 just run sudo apt-get install -y libiio-dev

  2. Charon releases are published on PyPi. Install using pip: pip install charon-vna

Hardware Setup

You need a few things:

  • Analog Devices Pluto SDR
    • Any variant of the Pluto should work too such as the Pluto+ however I have only tested with the basic flavor
    • Note that you must have two receive ports which means revision C or later of the basic Pluto
  • Directional couplers (1 per port up to 4 ports)
  • Charon switch board - coming soon.
    • Optional. Without this you'll be limited to S11 and uncalibrated S21 measurements (with required re-cabling)
    • There's nothing special about this particular board, if you want more than 4 ports you can make your own pretty easily. You just need 3 SPxT switches. Note that these switches will see tons of cycles so avoid mechanical switches
  • SMA cables
  • Calibration standard
    • Ideally something with s-parameters measured on a better VNA
    • I have used a basic SMA load and two modified SMA jacks with decent results

Pluto Configuration

Most of my testing is with Pluto firmware v0.39 though this may work with other firmware versions. I had issues with the Pluto sometimes seeing no signal which resolved when I upgraded from v0.35. Instructions for upgrading firmware are on the Analog Devices wiki.

We need two receive channels on the SDR. If you have a Pluto+ that should already be configured and you can skip this step.

Analog devices has a guide for enabling the second channel. Ideally this should be set as ad9361 to enable a wider band of operation in addition to the second channel, however the critical setting is enabling 2r2t. SSH into the Pluto and run the following:

fw_setenv attr_name compatible
fw_setenv attr_val ad9361
fw_setenv mode 2r2t

Usage

There will be some sort of GUI because that sounds useful. It will also be accessible over a socket to enable test automation with external (including non-python) code.

Calibration

TBD

Power Calibration

I include a default output power lookup table. This is derived from two TX channels of two Pluto SDRs and does not include any of the loss of a coupler or Charon switch board.

Absolute output power is generally not well calibrated for VNAs anyway and has negligible impact on most measurements so this is probably sufficient for most users. If you're trying to run a power sweep this may be insufficient.

If you have an RF power meter you can generate your own power calibration.

Note that unlike the main calibration, power calibration frequencies do not need to match the measurement frequencies. Values are interpolated.

References

Pluto Default Connection Settings

user: root password: analog ip: 192.168.2.1