Scilab Website | Contribute with GitLab | Mailing list archives | ATOMS toolboxes
Scilab Online Help
2024.1.0 - Français


clean

nettoie une matrice (arrondi à zéro des termes très petits)

Séquence d'appel

B = clean(A)
B = clean(A, epsa)
B = clean(A, epsa, epsr)

Arguments

A

scalaire, vecteur, matrice ou hypermatrice de nombres décimaux ou de nombres complexes (en encodage dense ou creux), ou de polynômes ou fractions rationnelles à coefficients réels ou complexes.

epsa,epsr

nombres réels positifs : tolérances. Par défaut = 10-10 pour les deux.

Description

Cette fonction met à 0 les termes de A de valeur absolue <=epsa, ou de valeur relative <=epsr (par rapport à max(abs(A)), %inf et %nan exclus)

Pour des polynômes ou fractions rationnelles, clean() est appliquée de la même façon à l'ensemble des coefficients de tous les éléments de A.

Exemples

m = grand(3,5,"uin",1,9) .* 10.^grand(3,5,"uin",-16,1)
clean(m)
clean(m, 1e-7)
--> m = grand(3,5,"uin",1,9) .* 10.^grand(3,5,"uin",-16,1)
 m  =
   5.000D-08   5.          0.8         7.000D-08   4.000D-11
   0.00007     7.          4.000D-09   6.000D-13   2.000D-16
   2.000D-08   1.000D-14   1.          8.          0.7

--> clean(m)
 ans  =
   5.000D-08   5.   0.8         7.000D-08   0.
   0.00007     7.   4.000D-09   0.          0.
   2.000D-08   0.   1.          8.          0.7

--> clean(m, 1e-7)
 ans  =
   0.        5.   0.8   0.   0.
   0.00007   7.   0.    0.   0.
   0.        0.   1.    8.   0.7

Pour des fractions rationnelles :

x = poly(0,'x');
w = [3+2*x, 2+x; 3+x, 2-x]/5
r = w * inv(w)
clean(r)
--> w = [3+2*x, 2+x; 3+x, 2-x]/5
 w  =
   0.6 +0.4x   0.4 +0.2x
   0.6 +0.2x   0.4 -0.2x

--> r = w * inv(w)
 r  =
                                                                2
   -3.140D-16 + x                        -1.110D-15 + 3.331D-16x
   ---------------                       ------------------------
                                                           2
         x                                   1.3333333x + x
                                      2                             2
   1.110D-15 - 2.220D-16x - 5.551D-17x   -1.110D-15 + 1.3333333x + x
   ------------------------------------  ----------------------------
                           2                                 2
             1.3333333x + x                    1.3333333x + x

--> clean(r)
 ans  =
   1   0
   --  --
   1   1

   0   1
   --  --
   1   1

Voir aussi

  • %eps — epsilon (floating-point relative accuracy)
  • cond — conditionnement
  • nearfloat — get previous or next floating-point number
  • number_properties — determine floating-point parameters
Report an issue
<< ceil Virgule flottante double >>

Copyright (c) 2022-2024 (Dassault Systèmes)
Copyright (c) 2017-2022 (ESI Group)
Copyright (c) 2011-2017 (Scilab Enterprises)
Copyright (c) 1989-2012 (INRIA)
Copyright (c) 1989-2007 (ENPC)
with contributors
Last updated:
Mon Jun 17 17:52:26 CEST 2024