Skip to content

Mission Elevation Plot and Terrain Analysis

Jonathan Hudson edited this page Jun 4, 2021 · 21 revisions

Mission Elevations

Overview

Prior to inav 3.0, mission altitudes are relative to the HOME (arming) location, which is not part of a mission definition. As a result, the pilot has to be ensure by some other means that the mission will clear any raised elevations on the mission path. For inav 3.0, missions may be either relative to home or absolute (AMSL).

mwp includes a mwp-plot-elevations tool that performs mission and terrain analysis. Prior to 2021-05-03, this was provided by a ruby script in mwptools/samples; since 2021-05-03 there is a Go program (in mwptools/mwp-plot-elevations) which is an enhanced version, and supports inav 3.0 absolute altitude missions. If you're running an older version of mwp, or you haven't installed the Go compiler, you can use the older, less functional ruby version, but the Go version is recommended as:

  • It supports inav 3.0 absolute altitude waypoints
  • It can update LAND waypoints to offset the difference between the home ground elevation and the LAND WP ground elevation.
  • It's much faster
  • Its usage is compatible with the deprecated ruby version.

Both the ruby application and the Go application are platform independent and can be used without WP for mission terrain analysis.

Note that prior to 2021-05, the ruby version was installed as mwp-plot-elevations.rb; now it's installed as plain mwp-plot-elevations in order that the superior Go version is a drop in replacement.

mwp-plot-elevations can rewrite the mission file with new elevations to provide a specified ground clearance.

Video Tutorial & UI integration

From of 2018-12-06, mwp-plot-elevations is integrated into the mwp application. There is a video tutorial. Note this uses the older ruby application, but that doesn't really affect basic functionality.

mwp integration

Sample output

Given the mission shown below: Test Mission and knowing that the land rises to the north and west, we can check that we do indeed have adequate clearance with the planned route and elevations:

# for decimal '.' locales
$ mwp-plot-elevations -- home 50.9104826,-1.5350745 --plotfile profile.svg  west_field.mission
# for decimal ',' locales
$ mwp-plot-elevations --home "50,9104826 -1,5350745" --plotfile profile.svg  west_field.mission

where:

  • west_field.mission is the MW-XML mission file (via mwp, ezgui, mission planner for inav or impload)
  • the --home lat,lon option defines the home position (which may also be set by the environment variable MWP_HOME), the command line having preference.
  • The graphical output is profile.svg, via the --plotfile option.

The result from this command is an SVG file, which can be displayed with common image tools (eog, ImageMagick display et al). It can also be converted to a raster image using e.g. rsvg-convert); a sample is shown below:

Mission Elevation

The red line represents the planned mission altitudes (which are defined relative to the estimated home location), and the green area represents the terrain. As we can see, we clear the hill (and other terrain), but cannot guarantee that we have LOS to lowest point of the mission, or that we're clear of the trees.

We can also specify a "clearance" option, in the image below this was set to 16m. Where the blue line is above the red line, one should review that the mission elevations are adequate.

Mission Clearance

Creating a new mission file

It is also possible (see command line options below) to write out a new mission that takes into account the clearance (margin parameter). If we then plot this new mission file, we can see that we are at least margin (in this example 16m) distance clear of the terrain.

Mission Clearance

Note that the original mission elevations are still taken into account. We can also ignore these, so we end up the absolute clearance distance above the terrain.

$ mwp-plot-elevations nm_west_field.mission --output /tmp/p1.mission --no-mission-alts

Absolute Clearance

Dependencies

The mwp-plot-elevations has NO dependency on mwp or Linux/FreeBSD, it can just as easily be run on MacOS or even MS Windows. It does however has some dependencies:

Go version

  • Go compiler (1.13 or later)

Ruby version

  • ruby (2.0 or later)
  • ruby 'gems' (libraries)
    • nokogiri
  • gnuplot

gnuplot is easily provided (by your distro or from a binary download), and the nokogiri dependency is also easily satisfied by either the distro or Ruby's gem command:

$ apt install ruby-nokogiri
### or ###
> gem install nokogiri
## mwp Windows / Cygwin
$ cyg-apt install ruby-nokogiri

Using the package manager is recommended for non-proprietary operating systems.

On all operating systems, the terrain graph is also plotted interactively, regardless of whether the -p (save SVG plot) option has been specified. The following shows the UI on Windows (it's pretty much the same on other OS).

Interactive UI

Caveats

  • 3rd party terrain data is not guaranteed, either as to its absolute accuracy, nor to its coverage.
  • Terrain data does not take into account other obstacles (trees, buildings, power lines etc).
  • The tool does not faithfully model the vehicle motion. As multi-rotor and fixed-wing have different climb behaviours, this would be quite complex.
  • RTH altitude has to specificed if you wish to model it, and assumes 'AT LEAST' behaviour.

Command line help and options

$ mwp-plot-elevations --help
Usage of mwp-plot-elevations [options] missionfile
  -dump
    	Dump  internal data,exit
  -home string
    	home as DD.dddd,DDD.dddd (default "50.910476,-1.535038")
  -margin int
    	Clearance margin (m) (default 16)
  -no-mission-alts
    	Ignore extant mission altitudes
  -no-plot
    	No interactive plot
  -output string
    	Revised mission file
  -plotfile string
    	SVG graph file
  -rth-alt int
    	RTH altitude (m) (default 25)
  -upland
    	Update landing elevation offset

Note that Go considers -foo and --foo to the equivalent. The ruby script requires the -- notation.

Configuration File

As well as specifying options such as home location, clearance margin and RTH altitude on the command line (or as an environment variable), some or all of these options may be set in a configuration file.

mwp-plot-elevations looks for options in one of the following (in order) ./.elev-plot.rc (i.e. current directory), $HOME/.config/mwp/elev-plot, and $HOME/.elev-plot.rc. The configuration file is a simple text file containing key=value pairs. Blank lines and lines beginning with # are ignored; the following example illustrates the recognised keys. Note that $HOME/.config/mwp/elev-plot is the preferred location, as this is also used by mwp to populate its graphical dialogue to launch the analysis tool.

# settings for mwp-plot-elevations
margin = 16
home = 50.910476,-1.535038
# for ',' locales
# home = 50,910476 -1,535038
rth-alt=25
# 'sanity' is the home -> WP1 distance check; default if not set here is 100m
sanity = 200

Usage Examples

# Interactive plot, using the above configuration file:
$ mwp-plot-elevations nm_west_field.mission

# Interactive plot. save SVG file
$ mwp-plot-elevations --plotfile /tmp/mission.svg nm_west_field.mission

# Interactive plot. save SVG file, rewrite mission file
$ mwp-plot-elevations --plotfile /tmp/mission.svg --output new_west_field.mission nm_west_field.mission

# Interactive plot. save SVG file, rewrite mission file, override clearance margin (20m)
$ mwp-plot-elevationsb --plotfile /tmp/mission.svg --outout new_west_field.mission --margin 20 nm_west_field.mission

# Interactive plot. save SVG file, rewrite mission file,
# override clearance margin (20m), reduce RTH altitude (22m)
$ mwp-plot-elevations --plotfile /tmp/mission.svg --output new_west_field.mission --margin 20 --rth-alt 22 nm_west_field.mission

Another contrived example ... create a mission in Google Earth (tied to ground), save as KMZ, convert to MWXML mission file with impload (0 altitude). Use mwp-plot-elevations.rb to calculate a safe mission.

KMZ planned in Google Earth

Google Earth Mission Plan

Conversion tools

# convert the saved KMZ file to a MWXML mission file
$ impload convert  /tmp/IOM.kmz /tmp/perwick.mission

# Verify the elevations and clearance with plot-elevations.rb
$ mwp-plot-elevations.rb -h  54.068826,-4.735472   -m 40 /tmp/perwick.mission

Elevations verified

Looks OK (well, apart from the flying through the hill, due to impload's default altitude of 20m).

If we specify that a new mission file be generated (--output), the updated mission is also plotted, and we can see that this clears the hill.

mwp-plot-elevations --home  54.068826,-4.735472 --margin 40 --output /tmp/perwick-ok.mission /tmp/perwick.mission

Elevations verified

It's not yet perfect, we could be more aggressive in reaching just the clearance altitude, but we clear the hill!.

Climb and Dive Angle Report

As of 2021-06, it's also possible to get climb and dive angles for the calculated mission. Before I added the WP12 => WP7 jump in the mission shown below, it was almost OK; below the desired clearance in a couple of places and just failing to clear the hill at WP15. After adding the JUMP, it hits the terrain pretty conclusively between WP12 and WP7. The modified mission is interesting, as it has to adjust the WPs within the JUMP for the worst case (so the WP7, the second pass is definitive).

The final result:

jump mission

We also get a climb / dive report, currently to STDOUT and $TMP/mwpmission-angles.txt (tab separated for easy analysis).

$ mwp-plot-elevations --margin 25 -no-mission-alts --output /tmp/n.mission \
 --home 54.125205,-4.730322 -rth-alt 40 mwp/missions/IoM/barrule-jump.mission
HOME -  WP1	 21.3°	(climb)
 WP1 -  WP2	-13.9°	(dive)
 WP2 -  WP3	 16.2°	(climb)
 WP3 -  WP4	 -8.1°	(dive)
 WP4 -  WP5	 11.4°	(climb)
 WP5 -  WP6	  4.9°	(climb)
 WP6 -  WP7	 -6.6°	(dive)
 WP7 -  WP8	 -8.9°	(dive)
 WP8 -  WP9	  1.3°	(climb)
 WP9 - WP10	  7.0°	(climb)
WP10 - WP11	  4.4°	(climb)
WP11 - WP12	-11.9°	(dive)
WP12 -  WP7	  0.3°	(climb)
 WP7 -  WP8	 -8.9°	(dive)
 WP8 -  WP9	  1.3°	(climb)
 WP9 - WP10	  7.0°	(climb)
WP10 - WP11	  4.4°	(climb)
WP11 - WP12	-11.9°	(dive)
WP12 - WP14	  2.5°	(climb)
WP14 - WP15	 -5.2°	(dive)
WP15 -  RTH	 -3.6°	(dive)

If you run mwp-plot-elevations via mwp, the information is presented in a separate window.

cd-analysist

Finally ....

win10 plot

Probably need to have the Windows gnuplot, vice cygwin version.

Clone this wiki locally