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/3cefa/3cefaae3fca05d63eb41fabf31f85e39c6de5a80" alt="../_images/1f2d0dee1c4badb2d690666458882abc9619ca92c88ea5061eee264b0928461a.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/c981f/c981f840e55115c05ff80a77a62f83b0ea34b859" alt="../_images/593154af00bae6fb3c515e4073e8a11813da5978b76cb97b0ae60713dcace2e1.png"