NormalizeDouble

Rundet Matrix-/Vektorelemente auf eine festgelegte Genauigkeit. Bei komplexen Zahlen werden reeller und imaginäre Teil separat normalisiert. Es wird eine Matrix/ein Vektor mit normalisierten Elementen zurückgegeben.

vector vector::NormalizeDouble(
  int            digits      // Anzahl der Dezimalstellen nach dem Komma
   );
 
vectorf vectorf::NormalizeDouble(
  int            digits      // Anzahl der Dezimalstellen nach dem Komma
   );
 
vectorc vectorc::NormalizeDouble(
  int            digits      // Anzahl der Dezimalstellen nach dem Komma
   );
 
vectorcf vectorcf::NormalizeDouble(
  int            digits      // Anzahl der Dezimalstellen nach dem Komma
   );
 
matrix matrix::NormalizeDouble(
  int            digits      // Anzahl der Dezimalstellen nach dem Komma
   );
 
matrixf matrixf::NormalizeDouble(
  int            digits      // Anzahl der Dezimalstellen nach dem Komma
   );
 
matrixc matrixc::NormalizeDouble(
  int            digits      // Anzahl der Dezimalstellen nach dem Komma
   );
 
matrixcf matrixcf::NormalizeDouble(
  int            digits      // Anzahl der Dezimalstellen nach dem Komma
   );

Parameter

digits

[in]  Genauigkeitsformat, Anzahl der Dezimalstellen nach dem Komma (0-11).

Rückgabewert

Matrix/Vektor mit normalisierten Werten.

Beispiel

   matrixf a={{ 11234},
              { 12567},
              { 2539,10},
              { 36945},
              { 47,1055}};
   matrixf ai=a.Inv();
//--- Die Ergebnismatrix sollte eine Einheitsmatrix sein.
   matrixf aai=a@ai;
   Print(aai);
//--- kleine Werte ersetzen
   matrixf aain=aai.NormalizeDouble(5);
//--- genaue Identitätsmatrix
   Print("identity matrix\n",aain);
 
/*
[[0.99999976,0,0,-2.3841858e-07,0]
 [-4.1723251e-07,1,1.8626451e-09,-5.9604645e-08,2.3841858e-07]
 [-1.0728836e-06,-1.1920929e-07,0.99999994,-8.3446503e-07,4.7683716e-07]
 [-2.9802322e-07,5.9604645e-08,-3.9115548e-08,0.99999958,0]
 [-5.9604645e-08,-5.9604645e-08,4.2840838e-08,-6.5565109e-07,1.0000002]]
identity matrix
[[1,0,0,0,0]
 [0,1,0,0,0]
 [0,0,1,0,0]
 [0,0,0,1,0]
 [0,0,0,0,1]]
*/