2020-06-06 01:49:27 +02:00
|
|
|
---
|
2023-02-24 02:20:59 +01:00
|
|
|
layout: forward
|
|
|
|
target: https://developers.google.com/mediapipe/framework/tools/visualizer
|
2020-06-06 01:49:27 +02:00
|
|
|
title: Visualizer
|
|
|
|
parent: Tools
|
|
|
|
nav_order: 1
|
|
|
|
---
|
2019-06-17 01:03:25 +02:00
|
|
|
|
2020-06-06 01:49:27 +02:00
|
|
|
# Visualizer
|
|
|
|
{: .no_toc }
|
|
|
|
|
|
|
|
1. TOC
|
|
|
|
{:toc}
|
|
|
|
---
|
2019-06-17 01:03:25 +02:00
|
|
|
|
2023-04-04 00:12:06 +02:00
|
|
|
**Attention:** *Thanks for your interest in MediaPipe! We have moved to
|
|
|
|
[https://developers.google.com/mediapipe](https://developers.google.com/mediapipe)
|
|
|
|
as the primary developer documentation site for MediaPipe as of April 3, 2023.*
|
|
|
|
|
|
|
|
---
|
|
|
|
|
2019-06-17 01:03:25 +02:00
|
|
|
To help users understand the structure of their calculator graphs and to
|
|
|
|
understand the overall behavior of their machine learning inference pipelines,
|
2019-06-29 05:48:42 +02:00
|
|
|
we have built the [MediaPipe Visualizer](https://viz.mediapipe.dev/)
|
|
|
|
that is available online.
|
2019-06-17 01:03:25 +02:00
|
|
|
|
|
|
|
* 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.
|
|
|
|
|
2022-09-06 23:29:51 +02:00
|
|
|
data:image/s3,"s3://crabby-images/ffccd/ffccd44b4c4a936f35dca2c897c4954d34860807" alt="Startup screen"
|
2019-06-17 01:03:25 +02:00
|
|
|
|
2020-06-06 01:49:27 +02:00
|
|
|
## Working within the Editor
|
2019-06-17 01:03:25 +02:00
|
|
|
|
|
|
|
Getting Started:
|
|
|
|
|
|
|
|
The graph can be modified by adding and editing code in the Editor view.
|
|
|
|
|
2022-09-06 23:29:51 +02:00
|
|
|
data:image/s3,"s3://crabby-images/3423c/3423c5261be66ef6e485bc285f3f36d834ba8ed6" alt="Editor UI"
|
2019-06-17 01:03:25 +02:00
|
|
|
|
|
|
|
* Pressing the "New" button in the upper right corner will clear any existing
|
|
|
|
code in the Editor window.
|
|
|
|
|
2022-09-06 23:29:51 +02:00
|
|
|
data:image/s3,"s3://crabby-images/1b248/1b248b6e26d052d372d9bc431a3ac21fabb689e4" alt="New Button"
|
2019-06-17 01:03:25 +02:00
|
|
|
|
|
|
|
* Pressing the "Upload" button will prompt the user to select a local PBTXT
|
2021-02-27 09:21:16 +01:00
|
|
|
file, which will overwrite the current code within the editor.
|
2019-06-17 01:03:25 +02:00
|
|
|
|
|
|
|
* Alternatively, code can be pasted directly into the editor window.
|
|
|
|
|
|
|
|
* Errors and informational messages will appear in the Feedback window.
|
|
|
|
|
2022-09-06 23:29:51 +02:00
|
|
|
data:image/s3,"s3://crabby-images/c4776/c477648fda7370e28dfab5ba13c6881621d95860" alt="Error Msg"
|
2019-06-17 01:03:25 +02:00
|
|
|
|
2020-06-06 01:49:27 +02:00
|
|
|
## Understanding the Graph
|
2019-06-17 01:03:25 +02:00
|
|
|
|
|
|
|
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").
|
|
|
|
|
2022-09-06 23:29:51 +02:00
|
|
|
data:image/s3,"s3://crabby-images/7f875/7f875a64ca8772721eff56f259ab462b0f8a24fd" alt="Stream UI"
|
2019-08-19 04:54:50 +02:00
|
|
|
|
2022-09-06 23:29:51 +02:00
|
|
|
data:image/s3,"s3://crabby-images/5da13/5da13496ca0de9c0d247c7d521e551aac2fc6a37" alt="Stream_code"
|
2019-06-17 01:03:25 +02:00
|
|
|
|
|
|
|
* 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").
|
|
|
|
|
2022-09-06 23:29:51 +02:00
|
|
|
data:image/s3,"s3://crabby-images/feb74/feb746713500d64dcd38d44081ca4996237a4a51" alt="Sidepacket UI"
|
2019-08-19 04:54:50 +02:00
|
|
|
|
2022-09-06 23:29:51 +02:00
|
|
|
data:image/s3,"s3://crabby-images/86d45/86d456d91ae3da5651f66362d109c7879cbf58a8" alt="Sidepacket_code"
|
2019-06-17 01:03:25 +02:00
|
|
|
|
|
|
|
* There are special nodes that represent inputs and outputs to the graph and
|
|
|
|
can supply either side packets or streams.
|
|
|
|
|
2022-09-06 23:29:51 +02:00
|
|
|
data:image/s3,"s3://crabby-images/dce9f/dce9ff208c7c2fc5ff04d2c43fce65ad97c9ad89" alt="Special nodes"
|
2020-05-21 18:46:31 +02:00
|
|
|
|
2022-09-06 23:29:51 +02:00
|
|
|
data:image/s3,"s3://crabby-images/5eeff/5eeff9e2aa8dce791e3d507561fa1157fbceeb78" alt="Special nodes"
|
2020-05-21 18:46:31 +02:00
|
|
|
|
2020-06-06 01:49:27 +02:00
|
|
|
## Visualizing Subgraphs
|
2019-08-19 04:54:50 +02:00
|
|
|
|
|
|
|
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.
|
|
|
|
|
2020-06-06 01:49:27 +02:00
|
|
|
For instance, there are two graphs involved in
|
2020-06-11 06:10:39 +02:00
|
|
|
[MediaPipe Hands](../solutions/hands.md): the main graph
|
2020-05-21 18:46:31 +02:00
|
|
|
([source pbtxt file](https://github.com/google/mediapipe/blob/master/mediapipe/graphs/hand_tracking/hand_detection_mobile.pbtxt))
|
2019-08-19 04:54:50 +02:00
|
|
|
and its associated subgraph
|
2020-05-21 18:46:31 +02:00
|
|
|
([source pbtxt file](https://github.com/google/mediapipe/blob/master/mediapipe/graphs/hand_tracking/subgraphs/hand_detection_gpu.pbtxt)).
|
2019-08-19 04:54:50 +02:00
|
|
|
To visualize them:
|
2019-08-17 03:49:25 +02:00
|
|
|
|
2019-08-19 04:54:50 +02:00
|
|
|
* In the MediaPipe visualizer, click on the upload graph button and select the
|
|
|
|
2 pbtxt files to visualize (main graph and its associated subgraph).
|
2019-08-17 03:49:25 +02:00
|
|
|
|
2022-09-06 23:29:51 +02:00
|
|
|
data:image/s3,"s3://crabby-images/1b248/1b248b6e26d052d372d9bc431a3ac21fabb689e4" alt="Upload graph button"
|
2019-08-17 03:49:25 +02:00
|
|
|
|
2022-09-06 23:29:51 +02:00
|
|
|
data:image/s3,"s3://crabby-images/f66b1/f66b19a3e8785b952392cf9efbb3ba87433c87a4" alt="Choose the 2 files"
|
2019-08-17 03:49:25 +02:00
|
|
|
|
2019-08-19 04:54:50 +02:00
|
|
|
* There will be 2 additional tabs. The main graph tab is
|
|
|
|
`hand_detection_mobile.pbtxt`.
|
2019-08-17 03:49:25 +02:00
|
|
|
|
2022-09-06 23:29:51 +02:00
|
|
|
data:image/s3,"s3://crabby-images/3fe95/3fe950004719dc41eaef332d2f8baf813191c859" alt="hand_detection_mobile_gpu.pbtxt"
|
2019-08-17 03:49:25 +02:00
|
|
|
|
2019-08-19 04:54:50 +02:00
|
|
|
* Clicking on the `HandDetection` node in purple redirects the view to the
|
|
|
|
`hand_detection_gpu.pbtxt` tab.
|
2019-08-17 03:49:25 +02:00
|
|
|
|
2022-09-06 23:29:51 +02:00
|
|
|
data:image/s3,"s3://crabby-images/52dd1/52dd15c82746e6a95417b7d96f5c3615790b34e9" alt="Hand detection subgraph"
|