Eigenvectors are not orthogonal for some skew-symmetric matrices, why?
    26 visualizaciones (últimos 30 días)
  
       Mostrar comentarios más antiguos
    
    Rahul Singh
 el 1 de Mayo de 2015
  
    
    
    
    
    Comentada: Paul
      
      
 el 16 de Sept. de 2025
                         0   -0.5000         0         0         0    0.5000
        0.5000         0   -0.5000         0         0         0
             0    0.5000         0   -0.5000         0         0
A =          0         0    0.5000         0   -0.5000         0
             0         0         0    0.5000         0   -0.5000
       -0.5000         0         0         0    0.5000         0
The above matrix is skew-symmetric. When I use [U E] = eig(A), to find the eigenvectors of the matrix. These eigenvectors must be orthogonal, i.e., U*U' matix must be Identity matrix. However, I am getting U*U' as
    0.9855   -0.0000    0.0410   -0.0000   -0.0265    0.0000
   -0.0000    0.9590    0.0000    0.0265   -0.0000    0.0145
    0.0410    0.0000    0.9735   -0.0000   -0.0145    0.0000
   -0.0000    0.0265   -0.0000    1.0145    0.0000   -0.0410
   -0.0265   -0.0000   -0.0145    0.0000    1.0410   -0.0000
    0.0000    0.0145    0.0000   -0.0410   -0.0000    1.0265
Here we can observe a substantial error. This happens for some other skew-symmetric matrices also. Why this large error is being observed and how do I get correct eigen-decomposition for all skew-symmetric matrices?
0 comentarios
Respuesta aceptada
  Roger Stafford
      
      
 el 1 de Mayo de 2015
        
      Editada: Walter Roberson
      
      
 el 20 de Sept. de 2018
  
      Your matrix A is "defective" , meaning that its eigenvalues are not all distinct. In fact, it has only three distinct eigenvalues. Consequently the space of eigenvectors does not fully span six-dimensional vector space. See the Wikipedia article:
What you are seeing is not an error on Matlab's part. It is a mathematical property of such matrices. You cannot achieve what you call "correct eigen-decomposition" for such matrices.
8 comentarios
  Lorenzo
 el 20 de Sept. de 2018
				
      Editada: Lorenzo
 el 20 de Sept. de 2018
  
			That matrix is not defective (1i times the matrix is hermitian and so it has a complete set of eigenvectors), it has however degenerate eigenvalues and this is the reason why U fails to be unitary. You should use schur in this case, which always return a unitary matrix
Más respuestas (2)
  Rahul Singh
 el 2 de Mayo de 2015
        4 comentarios
  Roger Stafford
      
      
 el 3 de Mayo de 2015
				Yes, all the eigenvectors come out orthogonal after that adjustment I described. The fact that U'*U gives the identity matrix implies that. You should be able to check that for yourself.
  Christine Tobler
    
 el 20 de Sept. de 2018
        Since, as Lorenzo points out in a comment above, 1i*A is hermitian, you could apply eig to that matrix:
>> [U, D] = eig(1i*A);
>> D = D/1i;
>> norm(U'*U - eye(6))
ans =
   1.4373e-15
>> norm(A*U - U*D)
ans =
   7.8098e-16
1 comentario
  Paul
      
      
 el 16 de Sept. de 2025
				"As of R2021a, eig will now detect if a matrix is skew-symmetric or skew-hermitian, and will return purely imaginary eigenvalues and orthogonal eigenvectors in that case. See the Release Notes. This does require the input to be exactly skew-hermitian, not just up to round-off (you can use ishermitian(A, 'skew') to check this)."  Source
A = [        0   -0.5000         0         0         0    0.5000
        0.5000         0   -0.5000         0         0         0
             0    0.5000         0   -0.5000         0         0
             0         0    0.5000         0   -0.5000         0
             0         0         0    0.5000         0   -0.5000
       -0.5000         0         0         0    0.5000         0];
[U,D] = eig(A,'vector');
any(real(D))
norm(U'*U - eye(6))
norm(U*U' - eye(6))
Ver también
Categorías
				Más información sobre Linear Algebra en Help Center y File Exchange.
			
	Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!





