[[TOC]]
This project aims to bring an affordable heads up display system into ANY cockpit.
The focus is to improve traffic awareness and to reduce the amount of time pilots reference tablets or an EFB.
NOTE: This project relies on having a Stratux build with AHRS and GPS. A suitable build can be done for less than $150 (USD).
There are two versions that can be built:
There are two main ways to configure the StratuxHud.
The first is as a stand-alone unit. For the standalone configuration, the HUD code runs on its own Raspberry Pi.
The second is in an "All-In-One" (AIO) configuration. With an AIO setup, the HUD code runs on the Stratux.
Feature | Stand Alone | AIO |
---|---|---|
Keypad Control | Yes | No |
Dynon D180 Support | Yes | No |
Aithre CO Monitor | Yes | Experimental |
Illyrian SPO/Pulse Monitor | Yes | Experimental |
Raspberry Pi 3b+ | Yes | No |
Raspberry Pi 4 | Yes | No |
Using the "Kivic HUD 2nd Gen" projector and a Raspberry Pi 3.
Estimated cost is $240
- $45 for RaspberryPi 3b+
- $195 for Kivic 2nd Gen projector
- Fans, case, cables
Uses 5V USB power.
NOTE: This project initially used and recommended the "HUDLY Classic" projector which is no longer available.
To get the most out of the StratuxHud, the following configuration for the Stratux is suggested:
- V3 receiver for 978 (UAT)
- V2 receiver for 1090
- Stratux GPYes u-blox 7
Picking the correct GPS solution for your HUD can be difficult.
The Vk-162, while less tidy due to the cable, has FAR superior GPS reception. GPS reception with the GP-Yes unit can be a problem.
I have two two Vk-162 units fail. With each failure the AHRS reports from the Stratux have been VERY slow.
This behavior has not been observed with a GPYes unit.
If you are running the HUD as a standalone unit AND using the optional Dynon interface, then this is not a problem.
For the StratuxHud to work correctly, you MUST have the AHRS chip and a GPS solution installed on the Stratux
NOTE: To have full functionality with a Stratux based unit, please use Stratux Version 1.6r1 or higher.
New with v1.7 is integration with Dynon D10/D100 Series Products.
This is achieved using the serial output.
At this time, integration with a Dynon D180 has only been tested.
The DynonToHud service is included with the Stand Alone image of the StratuxHud.
While the DynonToHud service does decode and make available both the EFIS and EMS data, at this time only the EFIS/AHRS data is presented by any of the HUD views.
For more information on the setup, and installation of the DynonToHud service, please visit the project page.
(DynonToHud)[/~https://github.com/JohnMarzulli/DynonToHud]
You may use a number pad as an input device. I used velcro to secure the number pad to my dashboard.
Key | Action |
---|---|
Backspace | Tell the Stratux that you are in a level position. Resets the AHRS to level. |
+ | Next view |
- | Previous view |
= | Toggle rendering debug information |
Esc | Send shutdown commands to both the HUD controller and the Stratux |
q | (Full keyboard only) Quit to the command line. |
0/Ins | Force a connection reset between the HUD and the Stratux |
- AHRS + ADS-B
- Traffic
- Traffic List
- Universal Time
- Diagnostics
- (Blank)
- AHRS Only
This view shows attitude information along with targeting bugs that show the relative position and distance of traffic.
In this example:
- There is one (1) potential target. The traffic is at a higher altitude, and somewhat distant.
- The traffic is within our field of view and has a targeting reticle.
- With are rolled to the left slightly, less than 10 degrees.
- We are at 649 feet MSL.
- We have an indicated AIRSPEED of 75MPG, but are hovering with a groundspeed of 0MPH
- We have a heading of 76, but our GPS track is 303. If the AHRS or GPS is unable to obtain a reliable heading then
---
is shown for that portion of the heading.
NOTE: This example was using EFIS/AHRS data obtained from a Dynon D-180 FlightDek. As a result, Indicated Air Speed (IAS) is displayed. The heading of 76, G-Force of 1.0, and altitude of 649' are also sourced from the Dynon.
NOTE: This is the default view on startup. If you would like to switch to the AHRS Only
You may press -
on the keypad.
This view shows a heading strip, target bugs, targeting reticles, and "information cards" about our potential traffic.
In this example, N4768B
is almost directly in front of us. The plane is 11.3 statute miles away, with a bearing of 105 degrees, and 1,100 feet above us.
Note that the bearing is calculated using the direction we are pointing (left side heading), NOT the ground track heading which is the right portion.
This shows us at most, the eight closest planes.
The _IDENT_ifier will be the tail number when available, otherwise, the ICAO identifier or callsign may be used. The _BEAR_ing is the heading to take to fly to that target. The _DIST_ance is the distance to the target. The _ALT_itude is given in relative terms, with two digits dropped.
In this example, the closest target is N4768B. The plane is only 4.4 statue mile away, and 1,500 feet above us.
The diagnostics view is designed to help give some troubleshooting ability. If a value is set for "OWNSHIP" (See the configuration file section), then any report from that tailnumber is ignored. The IP address is provided so you may use the configuration webpage if you set it up.
This view also tells you how hot the HUD processor is with the HUD CPU
row (temperature is in Celsius). The Aithre row tells you information about any Aithre or Illyrian sensors attached. The Traffic row tells you the address that the HUD is using to contact the TrafficManager service. If you see a "TRAFFIC UNAVAILABLE" warning, this address is critical to resolving your issue.
Shows the current time in UTC at the bottom of the screen.
A blank screen so no information is displayed.
This is a similar view to AHRS + ADS-B
, but removes any AHRS information.
Here you can see that only the Stratux is being used for flight data. As a result only the Ground Speed is available.
The unit was not moving at the time, so the heading was not available, but the ground track was 343.
This view element appears when the HUD software is unable to communicate with the "TrafficManager" service.
This sub-service handles the communication of traffic data with the Stratux receiver.
If you see this warning, the service has stopped, was not installed correctly, or the HUD is looking for it in the wrong place.
If this warning appears sometime during the flight, and is not always on, then a HUD restart may resolve the issue.
Please note that the warning DOES not appear on the "AHRS Only" view.
If you are using the DynonToHud service, then it is possible to run the StratuxHud without a Stratux.
When you do this, traffic and GPS based data will not be available.
Here you can see the Ground Speed (GND) read "---" and is colored red to indicate the data is not available. The ground track also reads "---"
NOTE: If you are using the DynonToHud service AND the Stratux is unable to gain or keep GPS lock, then this is what will appear. The ground speed and ground track will re-appear when GPS lock is re-obtained. NOTE: Positioning of your GPS antenna, or flight maneuvers that cause the antenna to no longer have a view to the sky may cause GPS lock to be lost.
NOTE: This does not include a power source. You will need to supply ship power from a 5V USB port or from a battery. NOTE: This is for a build that uses a separate Raspberry Pi to drive the display. If you wish to have an "All-In-One" solution where the HUD software runs on the Stratux, you will not need an additional Pi.
- Aviator Systems Display Choose "HUD Standalone"
- OPTIONAL 3/4" Wire Braiding
- Raspberry Pi 3B+
- Case For Raspberry Pi
- Cooling Fan for Raspberry Pi
- Micro USB Cable
- Micro SD Card
- Rottay Mechanical Keypad
Please use one of the provided images from the "Release" page on GitHub.
- Download the image for your scenario from the GitHub (Releases Page)[/~https://github.com/JohnMarzulli/StratuxHud/releases]
- Use (Etcher)[https://www.balena.io/etcher/] to flash the image onto a Micro SD card.
- Plug in your Projector to the Raspberry Pi
- It is recommended that you SSH into the HUD and use
raspi-config
to ("expand the filesystem")[https://geek-university.com/raspberry-pi/expand-raspbian-filesystem/].
- Flash the latest Raspbian to an SD card
- Plug in a keyboard and a monitor
- Plug in the power to the Pi.
- Press ctrl+alt+f1 to quit from the GUI to the desktop
sudo raspi-config
Boot Options
->Desktop / CLI
->Console Autologin
Advanced Options
->Expand Filesystem
Advanced Options
->Memory Split
-> "128"- "OK"
- "Finish"
- "Yes"
- Wait for the reboot
sudo raspi-config
- "Network options" -> "WiFi"
- Choose your country. Pressing "u" will take you to USA.
- Enter your network name and password.
- "Interfacing Options" -> "Enable SSH"
- "Localization" -> "Change Keyboard Layout" -> "Generic 104"
- "Other" -> "English US" -> "Default" -> "No compose" -> "Yes"
- "Finish"
If you are using a 3B+, and are experiencing under-voltage warnings, these may be relieved by the following command to update your Linux install to the latest:
sudo apt-get update && sudo apt-get dist-upgrade -y
Other causes of under-voltage warnings are low-quality USB cables, lose power port on the Pi, or a low quality power supply.
Make sure you are using a high-quality power cable if you are using a Pi 3B+
- Enter
ping google.com
. Press ctrl+c after a while. This will confirm that you have internet access. If you do not, then use rasp-config to re-enter your wi-fi cd ~
git clone /~https://github.com/JohnMarzulli/StratuxHud.git
cd StratuxHud
sudo apt-get install libgtk2.0-dev
a. ChooseY
if promptedcd tools; ./install_splash.sh
python --version
. Verify that your version is 2.7.14sudo python3 setup.py develop
For Linux systems where you wish to develop or debug:sudo setcap 'cap_net_raw,cap_net_admin+eip' ~/.local/lib/python2.7/site-packages/bluepy/bluepy-helper
sudo raspi-config
- Choose "WiFi" again, and enter
stratux
as the SSID. No password. sudo vim /etc/wpa_supplicant/wpa_supplicant.conf
- Delete the section that contains your WiFi network, leaving the section that contains the Stratux network.
- More info on configuring Linux WiFi: https://www.raspberrypi.org/forums/viewtopic.php?t=160620
- Save and quit.
- Type "crontab -e"
- Select "Nano" (Option 1)
- Enter the following text at the bottom of the file:
@reboot sudo python3 /home/pi/AithreToHud/aithre_manager.py &
@reboot nodejs /home/pi/TrafficToHud/build/traffic_manager.js &
@reboot python3 /home/pi/DynonToHud/dynon_to_hud.py &
@reboot sudo python3 /home/pi/StratuxHud/stratux_hud.py &
@reboot nodejs /home/pi/HudConfig/build/index.js &
- Save and quit.
Use LXDE autostart:
https://www.raspberrypi.org/forums/viewtopic.php?t=275703
To ensure proper operation, if you are a developer the order services are brought online is important.
The following order is suggested:
- Stratux
- AithreManager
- DynonToHud
- TrafficManager
- StratuxHud
- HudConfig
The AithreManager has no external dependencies.
The DynonToHud service has no external dependencies.
The TrafficManager uses the Stratux ADS-B services and received.
The StratuxHud depends on the AithreManager and the TrafficManager. It can optionally use DynonToHud.
The HudConfig depends on the StratuxHud
If you are compiling from source code and upgrading from V1.7, some additional steps will need to be taken.
First, you will need to delete all .pyc files.
It is also reccomended that you delete the __pycache__
directory.
The traffic manager
, node_modules
, lib
, and aithre_manager
directories are no longer used and should be removed.
You may have the HUD ignore your own aircraft using a "OWNSHIP" functionality. The OWNSHIP value is set using the Stratux. The HUD retrieves the Mode S code set as the OWNSHIP and then filters out all reports so they are ignored.
Please refer to the Stratux documentation on how to set the OWNSHIP value.
Support for Aithre was added in V1.5
Values for the CO PPM are shown in the default AHRS Only
, AHRS + ADS-B
, and System Information
views.
No additional setup is required, just simply turn on your Aithre and place it within range of the StratuxHud processing unit.
NOTE: Aithre support will only work on Raspberry Pi units that have a Bluetooth chip, such as the 3, and 3B+. The RPi2 and earlier will not work.
NOTE: The Aithre hardware supports only a single device at a time. If you wish to use the phone app to display your CO PPM values:
- Use the HudConfig tool to disable Aithre support
Alternatively:
- Open
/root/hud_config.json
- Set the "aithre" line to:
"aithre": false,
- Save and close.
EXPERIMENTAL
For All In One (Stratux + HUD on the same machine) setups, additional steps need to be taken.
Due to the needs of the GPS, the normal BlueTooth functions are disabled. Edit the /boot/config.txt to include the following line beneath the line that sets the overlay to value of dtoverlay
to "miniuart".
enable_uart=1
Edit the line towards the bottom to have core_freq=250
More details on Pi3 Bluetooth can be found here: https://www.cnet.com/how-to/how-to-setup-bluetooth-on-a-raspberry-pi-3/
Warning
It has been found that enabling BlueTooth and the GPS simultaneously can cause hardware instability. This needs to be considered an experimental feature and only used if you are willing to potentially lose the Stratux during flight.
- Install the Kivic projector per the Kivic directions. Please note that there is a release clip and the unit is removable. Also note that the combiner glass can be adjusted fore and aft.
- Plug in the 3.5mm TRS cable between the Raspberry Pi and the Kivic. This is the same hole as the audio adapter for the Pi.
- Plug the number pad into the Raspberry Pi.
- You will need to run two Micro USB (5v) power cables. One to the HUD and one to the Raspberry Pi processing unit. These may be run from a battery bank, or from the ship's power if you have 5V USB outlets.
- You may use the optional sleeving to help keep the install tidy.
If you would like to update from an earlier version to V1.5
- Connect to a network using the ethernet cable.
- Connect your Pi to a monitor using an HDMI cable. Connect a keyboard.
- Reboot.
- Press "Q" while the HUD is running to quit to a command line.
- cd /home/pi/StratuxHud
git fetch
- If you are currently running a version earlier than 1.5 only:
sudo cp *.json /root/
git stash
git checkout master
git pull
- If you have any errors, please report them immediately. Otherwise you are updated.
sudo shutdown -h now
You may consider using a barrel jack connector to supply power to your Pi unit.
These connectors are more durable than the Micro USB connector on the board, or are a good repair if your connector becomes damaged.
You will find the solder pads on the bottom of the Raspberry Pi 3, near the Micro USB power Jack.
- Solder +5V (Red) to PP2
- Solder GND (White) to PP3
Date | Version | Major Changes |
---|---|---|
2020-10-31 | 2.0 | Migration to Python V3, with major refactoring of underlying code. New TopDownScope element and view. |
2020-04-20 | 1.7 | Now able to cycle through views using the HudConfig page. Support for Illyrian by Aithre. Split Aithre data collection into a micro-service. Improve warning on some elements when GPS lock is lost. Fix user configuration files not always being used or saved. Support new V3 radio and Stratux 1.6. Experimental support for Aithre in Stratux + HUD AIO configurations. Updates to distance conversion. Use the same naming strategy for aircraft as popular EFBs. Support data collected from Dynon serial output using the DynonToHud project. Indicate which speeds are IAS and groundspeed when GPS and Avionics data are both available. Update element positions. Added new indication when the Traffic service is not available. |
2019-09-04 | 1.6 | Traffic manager moved to a stand-alone service in NodeJs/TypeScript. |
2019-06-30 | 1.5 | Support for the Aithre CO detector. New roll indicator. Various performance improvements. Visual warning if GPS is not plugged in. Use the OWNSHIP config from the receiver instead of the local config. |
2019-03-31 | 1.4 | Add connection reset button. Fixes issues with the Diagnostic view running out of space. Initial port to Python 3.7 |
2019-01-31 | 1.3 | Improvements to the communication with the Stratux. Update directions for Kivic install. |
2018-10-13 | 1.2 | Major performance increases |
2018-09-07 | 1.1 | New system to allow views to be configurable |
2018-07-17 | 1.0 | Initial release |
Please note that performance characteristics are only shown for displays that are currently available for purchase. The Hudly Classic is intentionally not listed.
Board | Screen | Frames Per Second (AHRS View Only) | Notes |
---|---|---|---|
Rasp Pi 2 (stand-alone) | Sun Founder 5" | ~25FPS to ~30FPS | Not recommended |
Rasp Pi 3 (stand-alone) | Kivic | 50FPS - 60FPS | Recommended |
Rasp Pi 3 (stand-alone) | Hudly Wireless | 30FPS - 50FPS | Recommended |
Rasp Pi 3 (Running on Stratux) | Kivic | 30FPS | Highly Recommended |
Rasp Pi 3 (Running on Stratux) | Hudly Wireless | 25FPS | Highly Recommended |
Rasp Pi 3B+ (stand-alone) | Kivic | 55FPS - 60FPS | Recommended |
Rasp Pi 3B+ (stand-alone) | Hudly Wireless | 40FPS - 60FPS | Recommended |
Rasp Pi 4 (stand-alone) | Kivic | 60FPS | Highly Recommended |
Rasp Pi 4 (stand-alone) | Hudly Wireless | 60FPS | Highly Recommended |
Please note that the frame rate is capped at 60FPS. Drawing any faster will not be detectable using the recommended output systems. Reducing the framerate will reduce the powerdraw.
This project uses the Liberation family of fonts. They can be found at https://pagure.io/liberation-fonts/
The initial project was inspired by Kris Knigga's PyAhrs project /~https://github.com/kdknigga/pyahrs
Many thanks to the Aithre team for providing the unit used to develop the plugin, and for their support in understanding the Aithre interface.
The following components are used:
- Python
- PyGame
... and of course Stratux
This project is covered by the GPL v3 license.
- Python 3.9 introduces issues with
isAlive
- PyGame 1.9.6 is the last known working version. v2.0 instroduces issues with window creation.
cd ~
wget https://www.openssl.org/source/openssl-1.1.1g.tar.gz
tar zxvf openssl-1.1.1g.tar.gz
cd openssl-1.1.1g
./config --prefix=/home/pi/openssl --openssldir=/home/pi/openssl no-ssl2
make
make install
cd~
wget https://www.python.org/ftp/python/3.8.8/Python-3.8.8.tgz
sudo tar zxf Python-3.8.8.tgz
cd Python-3.8.8
export LD_LIBRARY_PATH=${LD_LIBRARY_PATH}:/home/pi/openssl/lib/
sudo ./configure --enable-optimizations --with-openssl=/home/pi/openssl/
sudo make
sudo make install
sudo apt install libsdl-mixer1.2-dev
sudo apt install libsdl2-ttf-dev libsdl2-mixer-dev libsdl2-image-dev libsdl-sound1.2-dev python3-pygame
pip3 install setuptools
sudo python3 setup.py develop
pip4 install pygame==1.9.6
sudo apt install freeglut3 freeglut3-dev
pip3 install PyOpenGL PyOpenGL_accelerate
https://www.raspberrypi.org/forums/viewtopic.php?t=223592 https://www.raspberrypi.org/forums/viewtopic.php?t=243892 https://www.raspberrypi.org/forums/viewtopic.php?t=266277
- Dynon Skyview support
- Airball support
- Engine instruments and displays
- Weather
- Audio alerts
- Turn "projection" on the radar map.
- Nearby airports
- View improvements