Positive definite solution

i need to solved for different values of gama until its lowest value, which gives a positive definite solution for P is found, so i am using all(eig(P)>0) like the equation below:
is this right?
gama=100000;
for i=1:2000;
P = inv(inv(P)+M'*inv(R)*M-gama^(-2)*eye(4));
E=eig(P_cov);
if all(eig(P))>0) %%(all eigenvalues must be positive)
gama=gama/2;
else
break;
end
end
P = inv(inv(P)+M'*inv(R)*M-gama^(-2)*eye(4));
is this correct?

 Respuesta aceptada

Walter Roberson
Walter Roberson el 23 de Nov. de 2011

1 voto

If the eigenvalues are all positive, you change gama, exiting the loop when they are not all positive. That means that at the end the gama you get out will be such that the eigenvalues are not all positive. This does not satisfy the stated conditions.

3 comentarios

dab483
dab483 el 23 de Nov. de 2011
yes. that's what i am facing right now. any idea how do i correct them.
Walter Roberson
Walter Roberson el 23 de Nov. de 2011
gama=100000;
oldgama = gama;
...
if all(eig(P))>0) %%(all eigenvalues must be positive)
oldgama = gama;
gama=gama/2;
else
break;
end
Then right after the end of the "for" loop,
gama = oldgama;
dab483
dab483 el 24 de Nov. de 2011
Thank you. It satisfy the stated conditions.

Iniciar sesión para comentar.

Más respuestas (1)

Sean de Wolski
Sean de Wolski el 23 de Nov. de 2011

1 voto

Use a second variable and only update it if the eigenvalues are all positive. When you exit the loop it will be the last set of all positive eigenvalues.

1 comentario

dab483
dab483 el 23 de Nov. de 2011
Can you show it a litle bit.. i'm blank right now.

Iniciar sesión para comentar.

Categorías

Más información sobre Linear Algebra en Centro de ayuda y File Exchange.

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by