Skip to content
New issue

Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? # to your account

Create a "flow" view on the website? #98

Open
mithro opened this issue Feb 2, 2021 · 13 comments
Open

Create a "flow" view on the website? #98

mithro opened this issue Feb 2, 2021 · 13 comments
Labels
enhancement New feature or request help wanted Extra attention is needed theme

Comments

@mithro
Copy link
Member

mithro commented Feb 2, 2021

It would be really nice if the site had a "flow" view.

See the diagram at http://j.mp/openfpga-diagram and https://symbiflow.readthedocs.io/en/latest/toolchain-desc/design-flow.html and https://symbiflow.readthedocs.io/en/latest/introduction.html

@mithro
Copy link
Member Author

mithro commented Feb 2, 2021

@umarcor
Copy link
Member

umarcor commented Feb 3, 2021

Absolutely agree. As we have discussed before, I've also been drawing some diagrams, feeding forth and back to yours. This is the one for synthesis and PnR:

umarcorPhD

And this is WIP for HDL-centric simulation and verification (from umarcor.github.io/osvb):

osvb

My main concern is that, if we added such flow views to the site, I believe they must be interactive:

  1. Have the name of each tool be a link to the corresponding "details" page.
  2. Allow to zoom in/out and drag the diagram.
  3. Allow selecting specific keywords for having some nodes/edges of the diagram highlighted (or changing the transparency of all other elements).

Therefore, the limitation is technical on my side. I know how to do 1 using SVG "manually". I believe I can easily find some example about how to do 2. Yet, 3. requires expertise on web frontend design.


Ideally, I'd like to generate the diagrams programmatically, as I find so frustrating to spend time routing the signals or setting styles. I'm quite comfortable with TikZ (see https://texample.net/tikz/examples/). Unfortunately, AFAIAA, TikZ/LaTeX is for generating PS/DVI/PDF, not easily usable for SVG (or other web-friendly formats). I've tried SVG generation libraries (I did a golang version of wavedrom), but none of them provides the relative positioning and edge routing features available in TikZ. You need to first build your own utility library.

We are experimenting with Graphviz/dot in https://hdl.github.io/containers/#_graph. At the moment *.dot files are written manually. It would not be difficult to generate them automatically. The limitation for doing so is that extracting the logic of the graphs from repo sources is not machine-friendly. It's rather intuitive for humans, but there's lots of parsing involved for computers. A similar constraint would apply here. Therefore, there is no much value in maintaining a description of the graphs which is agnostic to the drawing engine. We'd better use a "graph" language directly. Yet, I'm not convinced about Graphviz because, unlike TikZ, positioning nodes is not trivial.

Any reference/suggestion/proposal is very welcome.


@umarcor umarcor added enhancement New feature or request help wanted Extra attention is needed theme labels Feb 3, 2021
@Paebbels
Copy link
Member

Paebbels commented Feb 3, 2021

I patched once a Sphinx plugin to utilize https://github.com/ariutta/svg-pan-zoom for a SVG (was it Wavedrom classdiagrams, I don't remember ...).

@Paebbels
Copy link
Member

Paebbels commented Feb 3, 2021

I don't recommend GraphViz / dot. I'ts good for masses of data and connections, but not for stractured layout / good looking. I use yEd for this, here nodes have sizes and coordinates. I can generate svg, png, pdf, ... (@umarcor the diagram I showed you in our last meeting was done in yEd) See Galery for what people did with yEd.

@umarcor
Copy link
Member

umarcor commented Feb 3, 2021

@Paebbels, thanks for the refs. the diagrams above were done with draw.io, which is a natural competitor of yEd. In fact, draw.io was formerly named jgraph/mxgraph, and it was not open source. Then, they open sourced it and creatred daw.io. However, I don't think that yEd or draw.io can help much generating diagrams programmatically. I found the APIs to be quite low-level, for you to write your app on top of them. So, doable, but not straightforward. In practice, we use them graphically, just as gdocs's drawings.

@Paebbels
Copy link
Member

Paebbels commented Feb 3, 2021

@umarcor I create graphml files directly via Python script an xml template snippets. So I have templates for nodes and edges and they are written to a file. We can have a meeting on how I do it.

I also found:

but never used either tool.

@mithro
Copy link
Member Author

mithro commented Feb 3, 2021

@umarcor Can you fix the black background on your verification image?

@umarcor
Copy link
Member

umarcor commented Feb 4, 2021

@mithro done.

@rodrigomelo9
Copy link
Contributor

Hi. I really love this idea :-) I am not precisely an expert with frontend things XD, but if we found the right tool I can try :P

@umarcor umarcor pinned this issue Feb 9, 2021
@cmarqu
Copy link
Contributor

cmarqu commented Feb 23, 2021

@drom might have input here.

umarcor pushed a commit that referenced this issue Feb 24, 2021
hide email button if the field is unset in the config
@umarcor
Copy link
Member

umarcor commented Apr 19, 2021

Based on the first diagram in #98 (comment), I created a dot graph. See https://github.com/hdl/awesome/tree/develop/todo/map. The output is awful. However, the information (nodes, edges, and clusters) is there, in case someone wants to experiment with automatic layouts. There are some references in https://hdl.github.io/containers/#_graph_generationparsing.

@umarcor
Copy link
Member

umarcor commented Feb 6, 2022

An updated diagram of "GHDL as a VHDL toolkit" for simulation, synthesis, LSP, documentation...

umarcor.github.io/SIEAV/VHDL.

# for free to join this conversation on GitHub. Already have an account? # to comment
Labels
enhancement New feature or request help wanted Extra attention is needed theme
Projects
None yet
Development

No branches or pull requests

5 participants