mirror of
https://github.com/clearml/clearml-docs
synced 2025-03-03 18:53:37 +00:00
Rewrite Matplotlib integration page (#628)
This commit is contained in:
parent
8ae6f38903
commit
47444aae0a
@ -1,6 +1,5 @@
|
|||||||
---
|
---
|
||||||
title: Matplotlib
|
title: Matplotlib
|
||||||
displayed_sidebar: mainSidebar
|
|
||||||
---
|
---
|
||||||
|
|
||||||
The example below demonstrates integrating ClearML into code that uses `matplotlib` to plot scatter diagrams, and
|
The example below demonstrates integrating ClearML into code that uses `matplotlib` to plot scatter diagrams, and
|
||||||
@ -23,18 +22,18 @@ which is associated with the `examples` project (in script) or the `Colab notebo
|
|||||||
|
|
||||||
The scatter plots appear in the **ClearML Web UI**, in **PLOTS**.
|
The scatter plots appear in the **ClearML Web UI**, in **PLOTS**.
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/49487/49487ae5482147e1f44b015f3780c9715094ae4e" alt="image"
|
data:image/s3,"s3://crabby-images/49487/49487ae5482147e1f44b015f3780c9715094ae4e" alt="Matplotlib plot 1"
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/413f9/413f9cc123e7e72171eb581269185958a3804265" alt="image"
|
data:image/s3,"s3://crabby-images/413f9/413f9cc123e7e72171eb581269185958a3804265" alt="Matplotlib plot 2"
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/0cdfe/0cdfed4703fbdaed9dee6ee7c2880a63ae6a8078" alt="image"
|
data:image/s3,"s3://crabby-images/0cdfe/0cdfed4703fbdaed9dee6ee7c2880a63ae6a8078" alt="Matplotlib plot 3"
|
||||||
|
|
||||||
## Debug Samples
|
## Debug Samples
|
||||||
|
|
||||||
The images appear in **DEBUG SAMPLES**. Each debug sample image is associated with a metric.
|
The images appear in **DEBUG SAMPLES**. Each debug sample image is associated with a metric.
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/02c92/02c92378714a34518fd6cb4620984294cf583099" alt="image"
|
data:image/s3,"s3://crabby-images/02c92/02c92378714a34518fd6cb4620984294cf583099" alt="Matplotlib image plot"
|
||||||
|
|
||||||
View the debug sample in the image viewer.
|
View the debug sample in the image viewer.
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/64850/64850094afe19339edd4782a0bdb36610c556a55" alt="image"
|
data:image/s3,"s3://crabby-images/64850/64850094afe19339edd4782a0bdb36610c556a55" alt="Image viewer"
|
72
docs/integrations/matplotlib.md
Normal file
72
docs/integrations/matplotlib.md
Normal file
@ -0,0 +1,72 @@
|
|||||||
|
---
|
||||||
|
title: Matplotlib
|
||||||
|
---
|
||||||
|
|
||||||
|
:::tip
|
||||||
|
If you are not already using ClearML, see [Getting Started](../getting_started/ds/ds_first_steps.md) for setup
|
||||||
|
instructions.
|
||||||
|
:::
|
||||||
|
|
||||||
|
[Matplotlib](https://matplotlib.org/) is a Python library for data visualization. ClearML automatically captures plots
|
||||||
|
and images created with `matplotlib`.
|
||||||
|
|
||||||
|
All you have to do is add two lines of code to your script:
|
||||||
|
|
||||||
|
```python
|
||||||
|
from clearml import Task
|
||||||
|
|
||||||
|
task = Task.init(task_name="<task_name>", project_name="<project_name>")
|
||||||
|
```
|
||||||
|
|
||||||
|
This will create a ClearML Task that captures your script's information, including Git details, uncommitted code, python
|
||||||
|
environment, your matplotlib visualizations, and more. View these matplotlib plots and images in the [WebApp](../webapp/webapp_exp_track_visual.md),
|
||||||
|
in the experiment's **Plots** and **Debug Samples** tabs respectively.
|
||||||
|
|
||||||
|
data:image/s3,"s3://crabby-images/0bed0/0bed01fe0085cc8b1092d466450bd2afbe84205e" alt="image"
|
||||||
|
|
||||||
|
## Automatic Logging Control
|
||||||
|
By default, when ClearML is integrated into your script, it captures all of your matplotlib visualizations.
|
||||||
|
But, you may want to have more control over what your experiment logs.
|
||||||
|
|
||||||
|
To control a task's framework logging, use the `auto_connect_frameworks` parameter of [`Task.init()`](../references/sdk/task.md#taskinit).
|
||||||
|
Completely disable all automatic logging by setting the parameter to `False`. For finer grained control of logged
|
||||||
|
frameworks, input a dictionary, with framework-boolean pairs.
|
||||||
|
|
||||||
|
For example:
|
||||||
|
|
||||||
|
```python
|
||||||
|
auto_connect_frameworks={
|
||||||
|
'matplotlib': False, 'tensorflow': False, 'tensorboard': False, 'pytorch': True,
|
||||||
|
'xgboost': False, 'scikit': True, 'fastai': True, 'lightgbm': False,
|
||||||
|
'hydra': True, 'detect_repository': True, 'tfdefines': True, 'joblib': True,
|
||||||
|
'megengine': True, 'jsonargparse': True, 'catboost': True
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
## Manual Logging
|
||||||
|
To augment its automatic logging, ClearML also provides an explicit logging interface.
|
||||||
|
|
||||||
|
Use [`Logger.report_matplotlib_figure()`](../references/sdk/logger.md#report_matplotlib_figure) to explicitly log
|
||||||
|
a matplotlib figure, and specify its title and series names, and iteration number:
|
||||||
|
|
||||||
|
|
||||||
|
```
|
||||||
|
logger = task.get_logger()
|
||||||
|
|
||||||
|
area = (40 * np.random.rand(N))**2
|
||||||
|
plt.scatter(x, y, s=area, c=colors, alpha=0.5)
|
||||||
|
logger.report_matplotlib_figure(title="My Plot Title", series="My Plot Series", iteration=10, figure=plt)
|
||||||
|
plt.show()
|
||||||
|
```
|
||||||
|
|
||||||
|
The logged figure is displayed in the experiment's **Plots** tab.
|
||||||
|
|
||||||
|
data:image/s3,"s3://crabby-images/dd1b6/dd1b631b9c006bd62fa2bf1565b4f92a7e6570ed" alt="Experiment Matplotlib plots"
|
||||||
|
|
||||||
|
Matplotlib figures can be logged as images by passing `report_image=True` to `Logger.report_matplotlib_figure()`.
|
||||||
|
View the images in the experiment's **DEBUG SAMPLES** tab.
|
||||||
|
|
||||||
|
data:image/s3,"s3://crabby-images/e08f4/e08f479b575e7f37da1243c1000cdfe45ecc241a" alt="Experiment debug sample"
|
||||||
|
|
||||||
|
See [Manual Matplotlib Reporting](../guides/reporting/manual_matplotlib_reporting.md) example.
|
||||||
|
|
@ -63,7 +63,7 @@ module.exports = {
|
|||||||
'integrations/catboost', 'integrations/click', 'guides/frameworks/fastai/fastai_with_tensorboard',
|
'integrations/catboost', 'integrations/click', 'guides/frameworks/fastai/fastai_with_tensorboard',
|
||||||
'integrations/hydra',
|
'integrations/hydra',
|
||||||
'guides/frameworks/keras/keras_tensorboard', 'guides/frameworks/tensorflow/integration_keras_tuner',
|
'guides/frameworks/keras/keras_tensorboard', 'guides/frameworks/tensorflow/integration_keras_tuner',
|
||||||
'guides/frameworks/lightgbm/lightgbm_example', 'guides/frameworks/matplotlib/matplotlib_example',
|
'guides/frameworks/lightgbm/lightgbm_example', 'integrations/matplotlib',
|
||||||
'guides/frameworks/megengine/megengine_mnist', 'integrations/openmmv', 'integrations/optuna',
|
'guides/frameworks/megengine/megengine_mnist', 'integrations/openmmv', 'integrations/optuna',
|
||||||
'integrations/python_fire', 'guides/frameworks/pytorch/pytorch_mnist',
|
'integrations/python_fire', 'guides/frameworks/pytorch/pytorch_mnist',
|
||||||
'integrations/ignite',
|
'integrations/ignite',
|
||||||
|
Loading…
Reference in New Issue
Block a user