QR

Calcula a fatoração qr de uma matriz.

bool  QR(
  matrix&  Q,     // matriz com colunas ortonormal
  matrix&  R      // matriz triangular superior
   );

Parâmetros

Q

[out]  Matriz com colunas ortonormais. Quando o modo complete estiver habilitado, o resultado será uma matriz ortogonal/unitária, dependendo se a é real/complexa. Nesse caso, o determinante pode ser +/- 1. Caso a matriz de entrada possua mais de duas dimensões, será retornado uma pilha de matrizes com as propriedades mencionadas.

R

[out]  Matriz triangular superior.

Valor retornado

Retorna true se bem-sucedido, caso contrário, false.

Exemplo:

//---  A*x = b
  matrix A = {{01}, {11}, {11}, {21}};
  Print("A \n"A);
  vector b = {1223};
  Print("b \n"b);
//--- A = Q*R
  matrix qr;
  A.QR(qr);
  Print("q \n"q);
  Print("r \n"r);
  matrix qr=q.MatMul(r);
  Print("qr \n"qr);
  /* 
  A
  [[0,1]
  [1,1]
  [1,1]
  [2,1]]
  b
  [1,2,2,3]
  q
  [[0.4082482904638631,-0.8164965809277259,-1.110223024625157e-16,-0.4082482904638631]
  [0.4625425214347352,-0.03745747856526496,0.7041241452319315,0.5374574785652647]
  [-0.5374574785652648,-0.03745747856526496,0.7041241452319316,-0.4625425214347352]
  [-0.5749149571305296,-0.5749149571305299,-0.09175170953613698,0.5749149571305296]]
  r
  [[-1.224744871391589,-0.2415816237971962]
  [-1.22474487139159,-1.466326495188786]
  [1.224744871391589,1.316496580927726]
  [1.224744871391589,0.2415816237971961]]
  qr
  [[-1.110223024625157e-16,1]
  [1,0.9999999999999999]
  [1,1]
  [2,1]]
  */