2022-05-29 13:05:23 +00:00
# Hypergraph drawing using Graphviz and Asymptote
## Usage
2022-08-23 14:43:08 +00:00
Requires Python 3 (tested with 3.9.13), [pydot ](https://pypi.org/project/pydot/ ) (tested with 1.4.2), [Asymptote ](https://asymptote.sourceforge.io/ ) (tested with 2.67) and LaTeX (tested with TeX Live 2021).
2022-05-29 13:05:23 +00:00
To render a hypergraph specified in `graph.dot` , execute the following:
```bash
cat graph.dot | dot -Tdot | python3 ./dot_hypergraph_to_asymptote.py /dev/stdin > graph.asy
asy -f png graph.asy
```
You may adjust the font size, width/height of the output and more by editing the values at the beginning of the script.
2022-08-23 14:43:08 +00:00
To embed the graph in a LaTeX document, set `output_latex` to true.
```latex
\usepackage[inline]{asymptote}
% ...
\begin{figure}
\centering
\input{output.asy}
\caption{...}
\label{fig:...}
\end{figure}
```
2022-05-29 13:05:23 +00:00
## Example
| Original graph | Asymptote rendering |
| -------------- | ------------------- |
| ![dot rendering ](./graph_dot.png ) | ![asymptote rendering ](./graph.png ) |
`graph.dot` :
```
digraph {
edge [dir="back"];
"Node 1" -> "Node 2" [label="Edge 1"]
"Node 1" -> "Node 3" [label="Edge 1"]
"Node 3" -> "Node 4" [label="Edge 2"]
"Node 3" -> "Node 5" [label="Edge 2"]
"Node 5" -> "Node 6" [label="Edge 3"]
"Node 4" -> "Node 6" [label="Edge 3"]
"Node 2" -> "Node 7" [label="Edge 4"]
"Node 6" -> "Node 7" [label="Edge 4"]
"Node 2" -> "Node 8" [label="Edge 5"]
"Node 7" -> "Node 8" [label="Edge 5"]
}
```
## Credits
The generated code is based on https://tex.stackexchange.com/a/108099/185782 by g.kov.
## License
[CC BY-SA 4.0 ](https://creativecommons.org/licenses/by-sa/4.0/ )
2022-08-23 14:43:08 +00:00
(open an issue if you'd prefer a different license)