Skip to main content

ezmsg namespace package containing tools for working with ezmsg graphs.

Project description

ezmsg-tools

A namespace package for ezmsg to visualize running graphs and data.

Key features:

  • Graph visualization - Visualize ezmsg graph topologies
  • Data visualization - Real-time data plotting and monitoring
  • Debug tools - Tools for debugging ezmsg pipelines

The data visualization is highly fragile. Expect bugs.

Installation

Pre-requisites

On Mac, you should use brew:

  • brew install graphviz
  • export CFLAGS="-I $(brew --prefix graphviz)/include"
  • export LDFLAGS="-L $(brew --prefix graphviz)/lib"

On Windows, follow the instructions here. Short version:

  • Download and install Visual C/C++
  • Download and install graphviz. Get the most recent Windows x64 CMake releases.
  • Install pygraphviz in your environment:
python -m pip install --config-settings="--global-option=build_ext"
    --config-settings="--global-option=-IC:\Program Files\Graphviz\include"
    --config-settings="--global-option=-LC:\Program Files\Graphviz\lib"
    pygraphviz

Release

Install the latest release from pypi with: pip install ezmsg-tools (or uv add ... or poetry add ...).

More than likely, you will want to include at least one of the extras when installing:

pip install "ezmsg-tools[all]"

Or install the latest development version:

pip install "ezmsg-tools[all] @ git+https://github.com/ezmsg-org/ezmsg-tools.git@dev"

Getting Started

This package includes some entrypoints with useful tools.

ezmsg-signal-monitor

The pipeline must be running on a graph service exposed on the network. For example, first, run the GraphService on an open port:

ezmsg --address 127.0.0.1:25978 start

Then run your usual pipeline but make sure it attaches to the graph address by passing graph_address=("127.0.0.1", 25978) as a kwarg to ez.run.

While the pipeline is running, you can run the signal-monitor tool with (uv run) ezmsg-signal-monitor --graph-addr 127.0.0.1:25978.

This launches a window with graph visualized on the left. Click on a node's output box to get a live visualization on the right side of the screen plotting the data as it leaves that node. Use a to toggle auto-scaling. With auto-scaling off, use -, and = to zoom out and in, respectively. See the phosphor docs for the full list of keyboard shortcuts.

Currently only 2-D outputs are supported!

Don't forget to shutdown your graph service when you are done, e.g.: ezmsg --address 127.0.0.1:25978 shutdown

ezmsg-performance-monitor

DEPRECATED

ezmsg will soon includes a built-in performance monitor that can be used instead of this tool.

This tool operates on logfiles created by ezmsg. Logfiles will automatically be created when running a pipeline containing nodes decorated with ezmsg.sigproc.util.profile.profile_subpub, and if the EZMSG_LOGLEVEL environment variable is set to DEBUG. The logfiles will be created in ~/.ezmsg/profile/ezprofiler.log by default but this can be changed with the EZMSG_PROFILE environment variable.

Most of the nodes provided by ezmsg.sigproc are already decorated to enable profiling, as is any custom nodes that inherit from ezmsg.sigproc.base.GenAxisArray. You can decorate other nodes with ezmsg.sigproc.util.profile.profile_subpub to enable profiling.

During a run with profiling enabled, the logfiles will be created in the specified location. You may wish to additionally create a graph file: (uv run) EZMSG_LOGLEVEL=WARN ezmsg mermaid > ~/.ezmsg/profile/ezprofiler.mermaid

During or after a pipeline run with profiling enabled, you can run (uv run ) ezmsg-performance-monitor to visualize the performance of the nodes in the pipeline.

Unlike signal-monitor, this tool does not require the pipeline to attach to an existing graph service because it relies exclusively on the logfile.

This performance monitor is soon to be deprecated in favor of monitoring tools built-in to ezmsg.

Developers

We use uv for development. It is not strictly required, but if you intend to contribute to ezmsg-tools then using uv will lead to the smoothest collaboration.

  1. Install uv if not already installed.
  2. Fork ezmsg-tools and clone your fork to your local computer.
  3. Open a terminal and cd to the cloned folder.
  4. Make sure pygraphviz pre-requisites are installed.
  5. uv sync --all-extras to create a .venv and install ezmsg-tools including dev and test dependencies.
  6. (Optional) Install pre-commit hooks: uv run pre-commit install
  7. After editing code and making commits, Run the test suite before making a PR: uv run pytest

Troubleshooting

Graphviz can be difficult to install on some systems. The simplest may be to use conda/mamba: conda install graphviz. If that fails, see here.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ezmsg_tools-0.3.0.tar.gz (159.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

ezmsg_tools-0.3.0-py3-none-any.whl (26.2 kB view details)

Uploaded Python 3

File details

Details for the file ezmsg_tools-0.3.0.tar.gz.

File metadata

  • Download URL: ezmsg_tools-0.3.0.tar.gz
  • Upload date:
  • Size: 159.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.11.0 {"installer":{"name":"uv","version":"0.11.0","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for ezmsg_tools-0.3.0.tar.gz
Algorithm Hash digest
SHA256 5ad436fecd1ad18b134187a6ec406bb04992e29f0c5811837d45c7d9389fb48c
MD5 b9c00e39e441087e90447a578f8647e8
BLAKE2b-256 db40f693a352f1f541672860ce9906c914e629266dd674d2bc920bf1f084ec60

See more details on using hashes here.

File details

Details for the file ezmsg_tools-0.3.0-py3-none-any.whl.

File metadata

  • Download URL: ezmsg_tools-0.3.0-py3-none-any.whl
  • Upload date:
  • Size: 26.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.11.0 {"installer":{"name":"uv","version":"0.11.0","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for ezmsg_tools-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 1074f78afa5afb70b23df1ffcc35e0033437132ffc33e9505a82816bef414209
MD5 ed81e7d80c88702692b8ef1aa20ddd83
BLAKE2b-256 ee3aa8c2b702babe788ade8c2b10d1c3c141d9f6108d7e3a21e1c516e12a84d4

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page