NUsight: Building an
effective debugging tool

Josephus Paye II

Co-Team Leader, NUbots

NUsight

A collection of tools that provide realtime visualisation of debug data from one or more robots

🌐 web-based

many 🤖 to many 💻

The Elements of a Visual Debugging Tool

The Elements of a Visual Debugging Tool

Data

Rendering

Networking

the values and images to visualise

getting data from a robot into the debugging tool

displaying the data in a user interface, with interactive controls

Five Key Principles

Five Key Principles

Keep it simple

Use UDP with stateless messages

Use declarative, data-driven rendering

Go beyond numbers and graphs

Give users control over what is visualised

1. Keep It Simple

1. Keep It Simple

The system

is wrong

The debugger

is wrong

1. Keep It Simple

Minimise the number of settings and configuration options in the tool

Adopt design patterns and principles
that exclude certain classes of bugs

Keep the tool strictly as a viewer, responsible for displaying data only

2. Use UDP with Stateless Messages

2. Use UDP with Stateless Messages

TCP vs UDP

2. Use UDP with Stateless Messages

message Image {
    message Lens {
        enum Projection {
            UNKNOWN     = 0;
            RECTILINEAR = 1;
            EQUIDISTANT = 2;
            EQUISOLID   = 3;
        }

        Projection projection   = 1;
        float      focal_length = 2;
        float      fov          = 3;
        fvec2      centre       = 4;
        fvec2      k            = 5;
    }

    uint32                    format     = 1;
    uvec2                     dimensions = 2;
    bytes                     data       = 3;
    uint32                    camera_id  = 4;
    string                    name       = 5;
    google.protobuf.Timestamp timestamp  = 6;
    mat4                      Hcw        = 7;
    Lens                      lens       = 8;
}

Stateless messaging

3. Use Declarative,
Data-driven Rendering

3. Use Declarative,
Data-driven Rendering

Declarative vs Imperative Rendering

<!-- Declarative: SVG -->
<svg width="200" height="200">
    <rect width="100" height="100" fill="green" />
</svg>

<!-- Imperative: Canvas 2D -->
<canvas id="canvas" width="200" height="200" />
<script>
    let canvas = document.getElementById('canvas');
    let ctx = canvas.getContext('2d');
    ctx.fillStyle = 'green';
    ctx.fillRect(0, 0, 100, 100);
</script>

3. Use Declarative,
Data-driven Rendering

Data-driven Rendering

React.js

MobX

4. Go Beyond Numbers and Graphs

4. Go Beyond Numbers and Graphs

Make it look real where possible

Localisation

Vision

4. Go Beyond Numbers and Graphs

Visualise with context and system info

5. Give Users Control Over What is Visualised

5. Give Users Control Over What is Visualised

Give control where the data goes in (input)

# NUsight.yaml

# Select which data to send
reaction_handles:
  # Overview information for the dashboard, designed for minimum bandwidth
  overview: true
  # Motor positions, orientation, etc.
  sensor_data: false
  # Raw image
  image: false
  # compressed image
  compressed_image: false
  # Classified image
  classified_image: false
  # Vision objects including goals, balls and debugging lines
  vision_object: false
  # Visual mesh data
  visual_mesh: false
  # Green horizon data
  green_horizon: false
  # Localisation state estimates and uncertainties
  localisation: false
  # Data for chart tool in NUsight
  data_point: false

5. Give Users Control Over What is Visualised

Give control where the data comes out

Conclusion

Keep it simple

Use UDP with stateless networking

Use declarative, data-driven rendering

Go beyond numbers and graphs

Give users control over what is visualised

A realtime visual debugging tool is very useful and improves development efficiency when building complex systems like soccer playing robots.

Acknowledgement

Thanks to Brendan Annable, creator of NUsight, and Trent Houliston, contributor to NUsight, as well as the rest of the NUbots team for their help in preparing this presentation.

Links

NUsight is open source and available on GitHub (github.com/NUbots/NUsight2) and can be referred to when building your own debugging tool.

We are also happy to answer any questions you may have - email nubots@newcastle.edu.au

Thanks!

NUsight: Building an effective debugging tool for soccer playing robots

By josephuspaye

NUsight: Building an effective debugging tool for soccer playing robots

This talk was given remotely at the Humanoid Virtual Workshops held for RoboCup 2020. More information about NUsight and NUbots can be found at https://nubook.nubots.net

  • 1,155