Histogram: draw the amount of samples in ranges of values
=========================================================
A histogram is a visual representation of the distribution of quantitative data. In other words, it allows to represent the amount of samples for which a chosen attribute is contained in a range of values.
How to draw a Histogram ?
-------------------------
1. **Import the required packages**
.. code-block:: python
# Required packages
import random
import plot_data as pld
from plot_data.colors import BLUE, GREEN
2. **Create data**
In order to draw a Histogram of a variable sampled randomly, build a random vector of samples (stored as Python `dict`) with one attribute. Here we chose to build a vector of length sampled within a Gaussian distribution.
.. code-block:: python
# Vector construction
elements = [{'length': random.gauss(0, 3)} for _ in range(500)]
3. **Set styles for bars and axes**
Styles for bars and axes can be customized with the user’s preferences:
.. code-block:: python
# Surface Style
surface_style = pld.SurfaceStyle(color_fill=BLUE)
# Edge Style
edge_style = pld.EdgeStyle(line_width=1, color_stroke=GREEN, dashline=[5, 3])
4. **Build the Histogram object and draw it in a web browser**
When building the histogram, ticks number on x axis can be specified with the `graduation_nb` attribute.
.. code-block:: python
histogram = pld.Histogram(x_variable='length',
elements=elements,
graduation_nb=20,
surface_style=surface_style,
edge_style=edge_style)
Once done, the figure can be displayed with the following command line:
.. code-block:: python
pld.plot_canvas(plot_data_object=histogram, canvas_id='my_histogram')
.. raw:: html
Histogram Features
------------------
- **Rubberbands can be drawn on axes by clicking and dragging on it with mouse. Rubberbands allow to select range of values on each axis,**
- Bars tooltips give information on how samples are distributed within a clicked bar,
- The view can be adjusted with mouse interactions (click, drag and wheel),
- One can select several bars with several mouse click by keeping pressed `Ctrl` key,
- One can reset the view by pressing `Ctrl + Space`,
- One can reset the whole figure by pressing `Ctrl + Shift + Left Click`.
How to write a method to draw a Histogram in a DessiaObject ?
-------------------------------------------------------------
For the previously designed PendulumDOE ([section 2.2.2](https://www.notion.so/Using-data-display-with-PlotData-30f86e58db6240788cf4f3b543b0ae51?pvs=21)), an interesting plot may be to draw the distribution of pendulums speeds within the previously designed PendulumDOE class.
To do it, add a method to draw a Histogram to the PendulumDOE class:
.. code-block:: python
class PendulumDOE(Dataset):
:
:
:
@plot_data_view("histogram")
def histogram(self, reference_path: str = "#"):
elements = [{"speed": pendulum.max_speed} for pendulum in self.dessia_objects]
return pld.Histogram(x_variable="speed", elements=elements, graduation_nb=20)
And draw the Histogram with the function `plot_canvas`:
.. code-block:: python
# Parameters sampling definition
planet_sampling = BoundedAttributeValue('g', 1, 11, 10)
length_sampling = BoundedAttributeValue('length', 0.1, 3, 10)
# DOE instantiation
pendulum_doe = PendulumDOE.from_boundaries(planet_sampling, length_sampling, 10, 0.01, method = 'fullfact')
# Parallel Plot construction
histogram = pendulum_doe.histogram()
# Draw the figure in a web browser
pld.plot_canvas(plot_data_object=histogram, filepath="section_2_5_2_histogram")
.. raw:: html