:summary: Le groupe Calcul propose un atelier d'une journée sur la différenciation automatique et ses usages courants.

.. contents::

.. section:: Description

.. section:: Description

:class: description

Calculating a derivative can sometimes be more delicate than one might think, specially when the function to be derived is itself the result of a numerical calculation.

In practice, this poses numerical and algorithmic problems: on the one hand, it is difficult to control the truncation error of a finite difference computation and on the other hand the symbolic computation can lead to an explosion of the complexity of the expressions.

Calculating a derivative can sometimes be more delicate than one might think, specially when the function to be derived is itself the result of a numerical calculation.

In practice, this poses numerical and algorithmic problems: on the one hand, it is difficult to control the truncation error of a finite difference computation and on the other hand the symbolic computation can lead to an explosion of the complexity of the expressions.

This need is encountered in problems where one seeks to optimize a quantity resulting itself from an approximate calculation.

This is formalized through the optimization of a criterion under constraint.

For example:

This need is encountered in problems where one seeks to optimize a quantity resulting itself from an approximate calculation.

This is formalized through the optimization of a criterion under constraint.

For example:

- the optimal control (aerodynamic stability analysis, ...),

- data assimilation (meteorology, risk analysis, ...),

- the inverse problems (geophysics, medical imaging, design, ...),

- sensitivity analysis (quantification of uncertainties, ...),

- deep learning (neural networks, ...).

- the optimal control (aerodynamic stability analysis, ...),

- data assimilation (meteorology, risk analysis, ...),

- the inverse problems (geophysics, medical imaging, design, ...),

- sensitivity analysis (quantification of uncertainties, ...),

- deep learning (neural networks, ...).

The algorithmic differentiation (AD) allows to get rid of a part of the calculations.

The AD takes a calculation code, as well as a description of the input and output variables, and produces a new code that calculates the derivatives of the outputs with respect to the inputs.

This uses concepts from compilation and program analysis (not computer algebra).

There are two modes of AD, which differ in the way of applying the rule of derivation of a compound function:

The algorithmic differentiation (AD) allows to get rid of a part of the calculations.

The AD takes a calculation code, as well as a description of the input and output variables, and produces a new code that calculates the derivatives of the outputs with respect to the inputs.

This uses concepts from compilation and program analysis (not computer algebra).

There are two modes of AD, which differ in the way of applying the rule of derivation of a compound function:

- the direct mode, which is used when the number of inputs is smaller than the number of outputs;

- the reverse mode, which is used when the number of inputs is greater than the number of outputs, in particular to calculate the gradient of a functional with respect to a large vector.

- the direct mode, which is used when the number of inputs is smaller than the number of outputs;

- the reverse mode, which is used when the number of inputs is greater than the number of outputs, in particular to calculate the gradient of a functional with respect to a large vector.

The inverse mode is equivalent to the adjoint state calculation (used in optimal control) and is close to retro-propagation in neural networks.

These results, well known to specialists in each discipline, are not new, however they deserve to be presented from a broader perspective.

The inverse mode is equivalent to the adjoint state calculation (used in optimal control) and is close to retro-propagation in neural networks.

These results, well known to specialists in each discipline, are not new, however they deserve to be presented from a broader perspective.

The purpose of this day is to bring together specialists in these different technologies to highlight the common needs, the different use cases and the limits of the different methods.

Another goal of this day is to meet different communities, who share these techniques.

The purpose of this day is to bring together specialists in these different technologies to highlight the common needs, the different use cases and the limits of the different methods.

Another goal of this day is to meet different communities, who share these techniques.

The workshop will include educational presentations presenting the principles of the methods, feedback on different applications and presentations recent or more original extensions.

The workshop will include educational presentations presenting the principles of the methods, feedback on different applications and presentations recent or more original extensions.

<pclass="font-weight-light text-center pt-4">Le groupe Calcul propose un atelier de trois jours pour vous sensibiliser aux outils utilisés pour faire de l'intégration continue.</p>

<buttontype="button"class="btn btn-outline-dark detail"id="header-btn">L'événement en détail</button>