hiperwalk.plot_probability_distribution#
- hiperwalk.plot_probability_distribution(probabilities, plot=None, animate=False, show=True, filename=None, interval=250, figsize=(12, 10), dpi=100, **kwargs)[source]#
Plot the probability distributions of quantum walk states.
This function allows plotting the probability distributions for multiple steps of a quantum walk evolution. The generated figures can be displayed step-by-step, saved as individual files, or used to create and save animations.
- Parameters:
- probabilities
numpy.ndarray
An array representing the probabilities of the walker being found at each vertex during the quantum walk evolution. Each column corresponds to a vertex, while each row represents a step in the walk.
- plotstr, default=None
The plot type. The valid options are
{'bar', 'line', 'graph', 'histogram', 'plane'}
. IfNone
, uses default plotting. Usuallybar
, but default plotting changes according tograph
.- showbool, default=True
Whether or not to show plots or animation. With
show=True
we have: Using Terminal: After shown, press q to quit. Ifanimate==False
, the quantum walk will be shown step-by-step; Ifanimate==True
, the entire animation is shown in a new window. Using Jupyter Notebook: Ifanimate==False
, all the quantum walk steps are shown at once. Ifanimate==True
, the entire animation is shown as a html video.- filenamestr, default=None
The filename path (with no format) where the plot(s) will be saved. If
None
no file is saved. Otherwise, ifanimate==False
, the j-step is saved in thefilename-j.png
file; ifanimate==True
, the entire walk is saved in thefilename.fig
file.- graphoptional
The structure of the graph on which the walk takes place. The graph labels are used as plotting labels. Important: check Graph Plots subsection in other parameters.
The following types are acceptable.
hiperwalk.Graph
Hiperwalk Graph. It is used to generate default plotting for specific graphs. User-specified values are not overridden.
networkx.classes.graph
,NetworkX Graph
scipy.sparse.csr_matrix
Adjacency matrix.
- rescalebool, optional
If
False
or omitted, the reference maximum probability is the global one. IfTrue
, the reference maximum probability depends on the current step, changing every image or frame. For example, if the global maximum probability is 1,min_node_size, max_node_size = (300, 3000)
, and the maximum probability of a given step is 0.5; then forrescale=False
, the step maximum node size shown is 1650 (halfway betweeen 300 and 3000), while forrescale=True
, the step maximum node size shown is 3000.- animatebool, default=False
Whether or not to animate multiple plots. If
False
, each quantum walk step generates an image. IfTrue
, each quantum walk step is used as an animation frame.- intervalint, default=250
Time in milliseconds that each frame is shown if
animate==True
.- figsizetuple, default=(12, 10)
Figure size in inches. Must be a tuple in the format (WIDTH, HEIGHT).
- dpifloat, default=100
Figure resolution in dots-per-inch.
- **kwargsdict, optional
Extra arguments to further customize plotting. Valid arguments depend on
plot
. Check Other Parameters Section for details.
- probabilities
- Other Parameters:
- Bar Plots
See
matplotlib.pyplot.bar
for more optional keywords.- Graph Plots
See
networkx.draw
for more optional keywords.- graph :
Graph structure.
- min_node_size, max_node_sizescalar, default=(300, 3000)
By default, nodes sizes depend on the probability.
min_node_size
andmax_node_size
describe the inferior and superior limits for the node sizes, respectively.- node_sizescalar or list of scalars, optional
If
node_size
is a scalar, all nodes will have the same size. Ifnode_size
is a list of scalars, vertices may have different sizes and the length ofnode_size
must matchprobabilities
. Thenode_size
argument is ignored if bothmin_node_size
andmax_node_size
are set.- cmapstr, optional
A colormap for representing vertices probabilities. if
cmap='default'
, uses the'viridis'
colormap. For more colormap options, check Matplolib’s Colormap reference.
- Histogram Plots
See
matplotlib.pyplot.bar
for more optional keywords. Thewidth
keyword is always overriden.- Line Plots
See
matplotlib.pyplot.plot
for more optional keywords.- Plane Plots
- dimensions: 2-tuple of int
plane dimensions in
(x_dim, y_dim)
format.
- Raises:
- ValueError
If
plot
has an invalid value.- KeyError
If
plot == 'graph' `` and keyword ``graph
is not set.
Warning
For showing animations, the current version only supports Jupyter and GTK 3.0. It must be updated to support GTK 4.0 for Ubuntu 22.04.
Notes
The core logic of the main implementation loop is more or less like follows.
>>> preconfigure() >>> for prob in probabilities: >>> configure() >>> plot(prob)
preconfigure()
executes configurations that do not change between plots, e.g. nodes positions in graph plots.configure()
executes configurates that must be (re)done for each iteration, e.g. setting figure size.plot()
calls the appropriated plotting method with customization parameters, i.e. bar, line or graph plot with the respective valid kwargs.Todo
Accept the
probabilities
parameter as a list.- Use Graphviz instead of NetworkX to draw graphs.
As noted by networkx’s documentation: Proper graph visualization is hard, and we highly recommend that people visualize their graphs with tools dedicated to that task. https://networkx.org/documentation/stable/reference/drawing.html
- Implement
repeat_delay
parameter: An extra time to wait before the animation is repeated. Pull requests to the Matplotlib animation writers are needed.
- Implement
- Implement
transparency
parameter: change nodes transparency depending on probability.
- Implement
Implement GTK 4.0 support.
Examples
Todo
probabilities expects numpy array or matrix