Comment réparer : runtimewarning : valeur non valide rencontrée dans double_scalars



Une erreur que vous pouvez rencontrer en Python est :

runtimewarning: invalid value encountered in double_scalars

Cette erreur se produit lorsque vous tentez d’effectuer une opération mathématique impliquant des nombres extrêmement petits ou extrêmement grands et que Python génère simplement une valeur NaN comme résultat.

L’exemple suivant montre comment corriger cette erreur dans la pratique.

Comment reproduire l’erreur

Supposons que nous essayions d’effectuer l’opération mathématique suivante avec deux tableaux NumPy :

import numpy as np

#define two NumPy arrays
array1 = np.array([[1100, 1050]])
array2 = np.array([[1200, 4000]])

#perform complex mathematical operation
np.exp(-3*array1).sum() / np.exp(-3*array2).sum()

RuntimeWarning: invalid value encountered in double_scalars

Nous recevons un RuntimeWarning car le résultat au dénominateur est extrêmement proche de zéro.

Cela signifie que la réponse au problème de division sera extrêmement grande et que Python est incapable de gérer une valeur aussi grande.

Comment réparer l’erreur

Généralement, le moyen de corriger ce type d’erreur consiste à utiliser une fonction spéciale d’une autre bibliothèque Python, capable de gérer des valeurs extrêmement petites ou extrêmement grandes dans les calculs.

Dans ce cas, nous pouvons utiliser la fonction logsumexp() de la bibliothèque SciPy :

import numpy as np
from scipy.special import logsumexp

#define two NumPy arrays
array1 = np.array([[1100, 1050]])
array2 = np.array([[1200, 4000]])

#perform complex mathematical operation
np.exp(logsumexp(-3*array1) - logsumexp(-3*array2))

2.7071782767869983e+195

Notez que le résultat est extrêmement volumineux mais nous ne recevons aucune erreur car nous avons utilisé une fonction mathématique spéciale de la bibliothèque SciPy conçue pour gérer ces types de nombres.

Dans de nombreux cas, il vaut la peine de rechercher des fonctions spéciales de la bibliothèque SciPy capables de gérer des opérations mathématiques extrêmes, car ces fonctions sont spécifiquement conçues pour le calcul scientifique.

Remarque : Vous pouvez trouver la documentation complète en ligne de la fonction logsumexp() ici .

Ressources additionnelles

Les didacticiels suivants expliquent comment corriger d’autres erreurs courantes en Python :

Comment réparer KeyError dans Pandas
Comment réparer : ValueError : impossible de convertir le float NaN en entier
Comment réparer : ValueError : les opérandes n’ont pas pu être diffusés avec les formes

Ajouter un commentaire

Votre adresse e-mail ne sera pas publiée. Les champs obligatoires sont indiqués avec *