Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ml2grow/graph-flow-vis
Web applicaton to visualize complex pipelines.
https://github.com/ml2grow/graph-flow-vis
Last synced: 3 months ago
JSON representation
Web applicaton to visualize complex pipelines.
- Host: GitHub
- URL: https://github.com/ml2grow/graph-flow-vis
- Owner: ml2grow
- License: apache-2.0
- Created: 2019-10-21T13:22:16.000Z (about 5 years ago)
- Default Branch: master
- Last Pushed: 2023-05-02T09:48:43.000Z (over 1 year ago)
- Last Synced: 2024-08-01T12:30:24.602Z (6 months ago)
- Language: JavaScript
- Size: 246 KB
- Stars: 4
- Watchers: 3
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
- Code of conduct: code-of-conduct.md
Awesome Lists containing this project
- awesome-starred - ml2grow/graph-flow-vis - Web applicaton to visualize complex pipelines. (others)
README
# graph-flow-vis (WIP)
Web applicaton to visualize complex pipelines, made with [dagre-d3](https://github.com/dagrejs/dagre-d3).
The core focus is to visualize [flowpipe](https://github.com/PaulSchweizer/flowpipe) graphs.![example graph](example_graph_vis1.png)
## features
- easy inspection of graph and objects/values passed between nodes
- capable of handling large datasets
- also works with complex nested graphs## getting started
install:
```
virtualenv myenv
source myenv/bin/activate
pip install -r web_app/requirements.txt
```run:
- `cd` to the `web_app` folder and run:
```
FLASK_APP=app.py FLASK_ENV=development flask run --port 8889
```Open localhost:8889 in your browser and click on the name of the graph you want to visualize.
## graph format
The web app expects graphs represented in the following json format:
```
{
"graph": {
"name": "MainGraph",
"nodes": [
{
"id": "some_node"
},
...
],
"edges": [
{
"source": "some_node",
"target": "other_node",
"label": "obj | type | info",
"debug_file": "[PATH IS OPTIONAL]graph_data/MainGraph/some_node-[UUID]_obj.md"
},
...
],
"sub_graphs": [
{
"name": "MainGraph",
"nodes_in_graph": [
"some_node",
"other_node",
],
"parent": ""
},
{
"name": "SubGraph",
"nodes_in_graph": [
"sub_node_1",
"sub_node_2",
],
"parent": "MainGraph"
},
...
]
}
}
```All graph json files should be placed in `web_app/static/json`.
Optionally; in `web_app/graph_data` you can place markdown string representations of objects
that are passed between nodes. This can allow you to easily debug your pipeline.
These files should be markdown files with the following path:
```
graph_data/name_of_graph/source_node_id-[UUID]_edge_object_name.md
```
for example:
```
graph_data/DataGraph/QueryRecords-3503ceda-e8bb-4d34-98b6-1ea26c170c41_record_rows.md
```
Markdown tables are automatically rendered with custom css to make them easier on the eyes.## Contributions
All contributions such as bugs, feature requests, additional examples or code improvements are welcome.
You are free to create an issue or pull request as long as you adhere to our [code of conduct](code-of-conduct.md).