107 lines
3.6 KiB
Markdown
107 lines
3.6 KiB
Markdown
---
|
|
layout: default
|
|
title: Visualizer
|
|
parent: Tools
|
|
nav_order: 1
|
|
---
|
|
|
|
# Visualizer
|
|
{: .no_toc }
|
|
|
|
1. TOC
|
|
{:toc}
|
|
---
|
|
|
|
To help users understand the structure of their calculator graphs and to
|
|
understand the overall behavior of their machine learning inference pipelines,
|
|
we have built the [MediaPipe Visualizer](https://viz.mediapipe.dev/)
|
|
that is available online.
|
|
|
|
* A graph view allows users to see a connected calculator graph as expressed
|
|
through a graph configuration that is pasted into the graph editor or
|
|
uploaded. The user can visualize and troubleshoot a graph they have created.
|
|
|
|
data:image/s3,"s3://crabby-images/8c764/8c764f8ee22c9174bf3e589485315fc2ca4823b2" alt="Startup screen"
|
|
|
|
## Working within the Editor
|
|
|
|
Getting Started:
|
|
|
|
The graph can be modified by adding and editing code in the Editor view.
|
|
|
|
data:image/s3,"s3://crabby-images/22da6/22da6652048e4d0a3daaf81253c96ea8f68d0568" alt="Editor UI"
|
|
|
|
* Pressing the "New" button in the upper right corner will clear any existing
|
|
code in the Editor window.
|
|
|
|
data:image/s3,"s3://crabby-images/0b7c5/0b7c57c308e4724e0843a74e1ac60731d2124343" alt="New Button"
|
|
|
|
* Pressing the "Upload" button will prompt the user to select a local PBTXT
|
|
file, which will overwrite the current code within the editor.
|
|
|
|
* Alternatively, code can be pasted directly into the editor window.
|
|
|
|
* Errors and informational messages will appear in the Feedback window.
|
|
|
|
data:image/s3,"s3://crabby-images/6879f/6879fc5373f4125c6656fb1ea4b9af3052eaa5ee" alt="Error Msg"
|
|
|
|
## Understanding the Graph
|
|
|
|
The visualizer graph shows the connections between calculator nodes.
|
|
|
|
* Streams exit from the bottom of the calculator producing the stream and
|
|
enter the top of any calculator receiving the stream. (Notice the use of the
|
|
key, "input_stream" and "output_stream").
|
|
|
|
data:image/s3,"s3://crabby-images/2c1e5/2c1e5fa479f296996497a2d19b3b2c99ee6f5708" alt="Stream UI"
|
|
|
|
data:image/s3,"s3://crabby-images/a25d2/a25d2c4dbd472cd83e619c64e183497cd868e70e" alt="Stream_code"
|
|
|
|
* Sidepackets work the same, except that they exit a node on the right and
|
|
enter on the left. (Notice the use of the key, "input_side_packet" and
|
|
"output_side_packet").
|
|
|
|
data:image/s3,"s3://crabby-images/5cf1d/5cf1d5e92e057ae5a6a3dbdfbdbe8f998846b771" alt="Sidepacket UI"
|
|
|
|
data:image/s3,"s3://crabby-images/04e3d/04e3d62b91e00db4685f149a5b3448e015c6f7ac" alt="Sidepacket_code"
|
|
|
|
* There are special nodes that represent inputs and outputs to the graph and
|
|
can supply either side packets or streams.
|
|
|
|
data:image/s3,"s3://crabby-images/eb050/eb050610fc2c3a1e24d51fe48de909ff640d6b6c" alt="Special nodes"
|
|
|
|
data:image/s3,"s3://crabby-images/a366b/a366ba5990bb169b03314f795eacc9389befbd8b" alt="Special nodes"
|
|
|
|
## Visualizing Subgraphs
|
|
|
|
The MediaPipe visualizer can display multiple graphs in separate tabs. If a
|
|
graph has a `type` field in the top level of the graph's text proto definition,
|
|
and that value of graph `type` is used as a calculator name in another graph, it
|
|
is considered a subgraph by the visualizer and colored appropriately where it is
|
|
used. Clicking on a subgraph will navigate to the corresponding tab which holds
|
|
the subgraph's definition.
|
|
|
|
For instance, there are two graphs involved in
|
|
[MediaPipe Hands](../solutions/hands.md): the main graph
|
|
([source pbtxt file](https://github.com/google/mediapipe/blob/master/mediapipe/graphs/hand_tracking/hand_detection_mobile.pbtxt))
|
|
and its associated subgraph
|
|
([source pbtxt file](https://github.com/google/mediapipe/blob/master/mediapipe/graphs/hand_tracking/subgraphs/hand_detection_gpu.pbtxt)).
|
|
To visualize them:
|
|
|
|
* In the MediaPipe visualizer, click on the upload graph button and select the
|
|
2 pbtxt files to visualize (main graph and its associated subgraph).
|
|
|
|
data:image/s3,"s3://crabby-images/0b7c5/0b7c57c308e4724e0843a74e1ac60731d2124343" alt="Upload graph button"
|
|
|
|
data:image/s3,"s3://crabby-images/539ac/539ac8ddcf01b189a36e62c3a10eda0d5654d08f" alt="Choose the 2 files"
|
|
|
|
* There will be 2 additional tabs. The main graph tab is
|
|
`hand_detection_mobile.pbtxt`.
|
|
|
|
data:image/s3,"s3://crabby-images/c215d/c215df3edb2d36d79a3543bcba50839a9dc0e792" alt="hand_detection_mobile_gpu.pbtxt"
|
|
|
|
* Clicking on the `HandDetection` node in purple redirects the view to the
|
|
`hand_detection_gpu.pbtxt` tab.
|
|
|
|
data:image/s3,"s3://crabby-images/dd4a9/dd4a97cabbd4202bf8c776ccfcc10a14ea259f93" alt="Hand detection subgraph"
|