[Numpy-discussion] One question about the numpy.linalg.eig() routine
Mon Apr 2 22:19:55 CDT 2012
BTW this extra degree of freedom can be used to "rotate" the eigenvectors
along the unit circle (multiplication by exp(j*phi)). To those of physical
it should remind of gauge fixing (vector potential in EM/QM).
These "rotations" can be used to make one (any) non-zero component of each
eigenvector be positive real number.
Finally to the point: it seems that numpy.linalg.eig uses these "rotations"
to turn the
diagonal elements in the eigenvector matrix to real positive numbers,
that's why the numpy solutions looks neat.
PS Probably nobody cares to know, but the phase factor I gave in my 1st
email should be negated:
On Mon, Apr 2, 2012 at 8:53 PM, Matthew Brett <firstname.lastname@example.org>wrote:
> On Mon, Apr 2, 2012 at 5:38 PM, Val Kalatsky <email@example.com> wrote:
> > Both results are correct.
> > There are 2 factors that make the results look different:
> > 1) The order: the 2nd eigenvector of the numpy solution corresponds to
> > 1st eigenvector of your solution,
> > note that the vectors are written in columns.
> > 2) The phase: an eigenvector can be multiplied by an arbitrary phase
> > with absolute value = 1.
> > As you can see this factor is -1 for the 2nd eigenvector
> > and -0.99887305445887753-0.047461785427773337j for the other one.
> Thanks for this answer; for my own benefit:
> Definition: A . v = L . v where A is the input matrix, L is an
> eigenvalue of A and v is an eigenvector of A.
> In : A = [[0.6+0.0j,
> -1.97537668-0.09386068j],[-1.97537668+0.09386068j, -0.6+0.0j]]
> In : L, v = np.linalg.eig(A)
> In : np.allclose(np.dot(A, v), L * v)
> Out: True
> NumPy-Discussion mailing list
-------------- next part --------------
An HTML attachment was scrubbed...
More information about the NumPy-Discussion