Ruby Digital FPV System (2024)

Hardware Setup

Here you find all the information on how to connect all the hardware components to create a Ruby system:

  • Hardware Components
    • Supported SBC boards
    • Supported radio modules
    • Supported cameras
  • Wiring and connections
  • Buttons
  • Serial Ports
  • Ruby Addons

Hardware Components:

Ruby supports a variety of hardware components in terms of cameras, radio modules, SBCs.Below is the minimum list of required components to create a fully working system.

Note: You can mix and match hardware as needed. That is, you can use different Pi boards for vehicles and controllers and use different radio modules on the same link (assuming they do support the frequency you will be using).

Ruby Digital FPV System (1)

Controller

Here is the list of components required to make a working controller:

  • 1 SBC (Single Board Computer, ie Raspberry, Radxa; see below);
  • 1 BEC/UBEC or any good 5V power supply;
  • 1+ radio card(s) in 433/868/915Mhz, 2.4Ghz or 5.8Ghz bands(multiple can be used for Rx diversity or multiple radio links); see the list below of all supported radio cards.
  • 1 HDMI display; Or any device that can display HDMI;
  • 4 (+3 additional optional) Push buttons. This is for the menu navigation on the controller. If you choose to use a rotary encoder for menu navigation, or a USB keyboard, then you don't need these push buttons.

Ruby Digital FPV System (2)

Vehicles

Here is the list of components required to make a working vehicle (drone, plane, car, UAV):

  • 1 SBC (Single Board Computer, ie Raspberry, Radxa; OpenIPC hardware camera, see below);
  • 1 camera (see below the full list of supported camera types);
  • 1 BEC/UBEC or any good 5V power supply (for providing a solid, high current capable, 5V supply to the PI board and network cards);
  • 1+ radio card(s) in 433/868/915Mhz, 2.4Ghz or 5.8Ghz bands(multiple can be used for Rx diversity or multiple radio links); see the list below of all supported radio cards.

Here is the full list of supported hardware components:

Ruby Digital FPV System (3)

Supported computer boards

  • Pi Zero, Pi Zero W, Pi Zero 2 (W);
  • Pi 2,3,4 and variants;
  • Radxa 3W/3E;
  • OpenIPC cameras as SBC (AIO air units, Goke7205, Sigmastar SSC338Q). Can be used only for vehicles, not for controller. Read more about it and how to setup your openIPC camera here;

Note: Pi Zero is not recomended if you need high video bitrate due to single core CPU;

Relative performance of SBC/AIO units:

Ruby Digital FPV System (4)

SBC/AIO Units Relative Performance


Advantages of using OpenIPC hardware as air unit on vehicles:

  • Better video quality than most Raspberry Pi cameras. OpenIPC hardware is using Sony IMX sensors which have great video quality and great low light handling; Same as Raspberry Pi HQ cameras and Veye cameras;
  • Lower video feed glass-to-glass latency; As low as 40ms;
  • More compact. You don't need a SBC on your vehicle as the OpenIPC hardware is a SBC;

Tip:

Ruby detects automatically, at boot time, if it's running on a vehicle/relay or on a controller.

If one of the following conditions below is true, Ruby will assume that it's running on a vehicle/relay and will automatically configure everything accordingly. Otherways it will assume it's running on a controller.

  • A CSI or HDMI camera is present in the system;
  • GPIO pin 19 is pulled-up (to 3.3V, only for Raspberry Pi boards);
  • A file called forcevehicle or forcevehicle.txt is present to the SD card;

Ruby Digital FPV System (5)

Supported radio modules

433 Mhz bandSiK, ELRS radio modules
868/915 Mhz bandSiK, ELRS radio modules
2.3/2.5 Ghz bandAtheros chipsets AR9271 cards: TPLink WN722N V1
2.4 Ghz bandAtheros chipsets AR9271 cards: TPLink WN722N V1, Alfa AWS036NHA
Ralink chipsets cards: Alfa AWUS036NH
5.8 Ghz bandRealtek chipsets RTL8812AU, RTL8811AU cards:
  • Alfa AWUS036ACH
  • Alfa AWUS036ACS
  • ASUS USB-AC56
  • TP-Link Archer T2U Plus
  • NetGear A6100 (not on OpenIPC hardware)
  • Tenda U12
  • Examples this or this or this one)

Note: These radio modules have been tested as working, but any radio modules with those chipsets will work just fine. Relative performance of radio modules:

Ruby Digital FPV System (7)

Supported cameras

  • Raspberry Pi v1,v2, HQ cameras *

    * Most ArduCam cameras are not compatible. They are not supported on all Pi versions, have performance issues and/or lack control capabilities.

  • Veye cameras 290/309/327 variants (http://www.veye.cc/en/);
  • Any digital camera that has a HDMI output (720p or 1080p), using a HDMI-CSI adapter board;
  • OpenIPC cameras; OpenIPC hardware (AIO air units, Goke7205, Sigmastar SSC338Q);

Recommended cameras:
Raspberry HQ;
Veye cameras;
OpenIPC AIO unit, OpenIPC Sigmastar SSC338Q;

Raspberry Pi v1 and OpenIPC Goke cameras are supported by not recommended due low image quality and single core CPU;

Note: Raspberry Pi v3 cameras (or any camera that reqires libcamera support) are not supported. Check with your camera vendor/manufacturer to see if it requires libcamera support for it to work on Raspberry.


Tip:

All hardware components in Ruby are plug and play.

Ruby, at boot time, automatically detects all the hardware components present on the system and does configure automatically everything so that all the hardware components work right from the start, without the user having to do any configuration.
So, when you add or remove hardware components, Ruby automatically configures them and the system to match the new hardware configuration. You can still configure the settings of each hardware component as needed.

Wiring and connections:

If you are new to electronics and DYI projects, it's recommended you start with the basic wiring and connections as in the pictures below as it's easier and faster to do and have a system up and running:

Ruby Digital FPV System (8)

Basic vehicle wiring

Ruby Digital FPV System (9)

Basic controller wiring

Note! If you have critical usage scenarios or you plan to use Ruby in environments with vibrations, it is recommended to replace all USB cables and connectors with wires that are soldered to the boards at each end. This gives a more robust system in terms of reliability and resilience to vibrations:

Direct wiring of USB connections:

It is recommended that you wire directly the USB connections, from Pi/Radxa to the radio cards, to not use USB cables and connectors, to avoid vibration issues, using the points on the Pi board that give you direct access to the USB data lanes, as in the pictures below:

Ruby Digital FPV System (10)

USB connection points for Pi Zero/Zero W/Zero 2

Ruby Digital FPV System (11)

USB connection points for Pi 2,3 and variants


Ruby Digital FPV System (13)

Different USB type connectors pinout

Note: On Raspberry Pi 4, the video output is generated on the HDMI Output Port 0. So you should connect a display to that port. The HDMI Output Port 1 is not used.

Buttons:

The user interface in Ruby can be accessed and navigated using a USB keyboard, a rotary encoder or push buttons.The more convenient way, long term, is to use push buttons for menu navigation.To do so, on the controller you need to add the 4 navigation buttons.
No buttons, rotary encoders or USB keyboard are needed on vehicles.

Buttons Wiring:

The user interface on the controller can be accessed in Ruby (besides keyboard and rotary encoders) using 4 push buttons for: Menu, Cancel, Up and Down.There are also some optional buttons, that enable auxiliary functions in Ruby like starting a video recording, taking a picture, changing OSD layouts, changing camera settings on the fly and more. They are not mandatory, but make life easier and the user experience more enjoyable.

Please see the Peripherals section to see how to setup a rotary encoder.

If you choose to use buttons for interface navigation, you need to wire the buttons as in the pictures below. There is a common rail to all buttons, connected to 3.3v, and one individual connection from each button to a GPIO pin on the Raspberry Pi/Radxa boards:

Ruby Digital FPV System (14)

Menu Navigation Buttons Wiring for Raspberry Pi Boards

Ruby Digital FPV System (15)

Optional Buttons Wiring for Raspberry Pi Boards


Ruby Digital FPV System (16)

Menu and Optional Navigation Buttons Wiring for Radxa Zero 3 Boards

You can then assign what actions to do when pressing the Quick Actions buttons from the Preferences menu:

Ruby Digital FPV System (17)

Quick Actions buttons

Other hardware connections:

There are few other hardware connections you can make to Ruby, that are optional, but can be used if needed.
They are as follows (only for Raspberry Pi boards):
* A LED that will blink when video recording is turned on (on the controller side);
* A LED that will blink when there are major hardware or software issues (on the controller side);
* A GPIO pin (GPIO 19) that you can use to force a Pi to boot as a vehicle/relay, even if it has no camera (on the vehicle side);
* A GPIO pin (GPIO 26) that you can use to force a Pi to boot as a controller, even if a camera is detected (on the controller itself);

The wiring for those is as in the picture below:

Ruby Digital FPV System (18)

Optional LEDs and buttons

Serial Ports:

Ruby can communicate with external devices using serial interfaces (UART).
The serial interfaces can be used to communicate with a flight controller, with a camera gimbal, a receiver or other devices based on each individual application.
If you need more than one serial interface, to connect to multiple devices, you can add any number of USB to serial adapters and connect them to the USB ports on the Pi, as in the picture below:

Ruby Digital FPV System (19)

Accessing serial ports on a Raspberry Pi

Note: Use only brand name USB to serial adapters or ones with CP2109 or CP2102 chipsets. The USB serial adapters with CH340 chipset are not supported.
Note: The CP2102 chipsets are the most reliable ones and work in all conditions. The CP2109 might be incompatible with some Pi boards, depending on the manufacturer.

All available serial ports will be shown in the Ruby UI interface and you can change the parameters and usage for each individual port.

Most of the times, on the vehicle, you want to connect your flight controller to the Raspberry Pi so that Ruby can receive telemtry info from the flight controller and to send data and commands to the flight controller.
You need to connect the serial interface as in the picture below:

Ruby Digital FPV System (20)

Wiring of flight controller for telemetry data

Note: Keep in mind that Raspberry Pi uses 3.3 volts logic levels. Most modern flight controllers (Pixhawk, Cube, STM32, etc) also use 3.3 volts so nothing special needs to be done. If you have an old or special flight controller that used 5 volts logic levels, you need to insert a level shifter.

Ruby Hardware Peripherals:

You can add optional hardware components to Ruby controller that will extend the functionality with new features.

Ruby Digital FPV System (21)

Optional peripherals that can be attached to the controller

Raspberry Pi Pico Add-on:

To expand the I/O capabilities of Raspberry Pi, to add more UART interfaces, analog inputs, SBUS/IBUS/PPM RC input and other future extensions, a small Raspberry Pi Pico is connected to the Pi controller using the I2C interface.
The add-on Pico is powered directly from the main Pi:

Ruby Digital FPV System (22)

Connecting a Pico Pi to the controller Pi

To add peripherals to the Pico Pi, use the following diagram:

Ruby Digital FPV System (23)

Connecting I/O peripherals to Pico Pi

Note: Raspberry Pi Pico is using 3.3v levels on the GPIO pins, but from the tests done, it can handle just fine 5V IBUS/SBUS input. You should add a 5v -> 3.3v level shifter on the IBUS/SBUS input if your source signal is using 5v levels.

You need to flash the Ruby software on your Pico. See the Downloads section for instructions on how to flash a Raspberry Pi Pico and to get the latest software for the Pico.

I2C Interface:

Ruby can use I2C interface and communicate with external devices.
You can add multiple devices on the same I2C interface and all I2C devices that are detected at boot will show up in Ruby UI interface and you can change parameters for each individual I2C device.

Note: Raspberry Pi uses 3.3 volts logic levels. If you need to connect I2C devices that use 5 volts logic levels, use a level shifter as in the picture above.

Ruby Digital FPV System (24)

Using the I2C bus on the Raspberry Pi

Ruby Digital FPV System (2024)

References

Top Articles
Latest Posts
Article information

Author: Dr. Pierre Goyette

Last Updated:

Views: 6370

Rating: 5 / 5 (50 voted)

Reviews: 81% of readers found this page helpful

Author information

Name: Dr. Pierre Goyette

Birthday: 1998-01-29

Address: Apt. 611 3357 Yong Plain, West Audra, IL 70053

Phone: +5819954278378

Job: Construction Director

Hobby: Embroidery, Creative writing, Shopping, Driving, Stand-up comedy, Coffee roasting, Scrapbooking

Introduction: My name is Dr. Pierre Goyette, I am a enchanting, powerful, jolly, rich, graceful, colorful, zany person who loves writing and wants to share my knowledge and understanding with you.