See also
This notebook can be downloaded here
UML class diagram generator#
This notebook generates UML diagrams of class hierarchies
Dependencies:
pylint
,ipykernel
(install these two in a python env), graphviz
from IPython.display import Image, display
from quantify_scheduler.helpers.inspect import make_uml_diagram
General notes#
Yellow labels indicate addition as a submodule
Different colors indicate different packages
Generated figures are saved in png format
Options must be given in
list[str]
formatFor more information, visit the Wikipedia page on relationships in class diagrams
Plotting all classes in a module#
Be aware that this option will only plot classes that are contained within
module_to_plot
, and not related classes defined outside the module.Extra options:
Show ancestors (aka parent classes):
-A
Ignore specific submodules:
--ignore <file[,file...]>
(e.g.["--ignore", "circuit_to_device.py,corrections.py,zhinst"]
)
from quantify_scheduler.backends import qblox
module_to_plot = qblox
options = ["-A"]
diagram_name = make_uml_diagram(module_to_plot, options)
if diagram_name:
display(Image(diagram_name))
data:image/s3,"s3://crabby-images/df4cc/df4cca8edf3474a6a5a5993e32a6684e89191e83" alt="../_images/e830a4532c41abb37758f5fa1214be037cd4e58a7a7998700c1f8df66b9f7816.png"
Plotting ancestors and submodules of a class#
Remove
--only-classnames
option to show all class attributes
from quantify_scheduler.device_under_test.transmon_element import BasicTransmonElement
class_to_plot = BasicTransmonElement
options = ["--only-classnames"]
diagram_name = make_uml_diagram(class_to_plot, options)
if diagram_name:
display(Image(diagram_name))
data:image/s3,"s3://crabby-images/2be46/2be46428e6c44b7f5a06d44377df910621fa4dd1" alt="../_images/3d1c178a8fd12a028ea5089d1fd7f5b7c442099a201b9a761ae0a1dfc0b964e8.png"