Inverse cosine of complex numbers
Mostrar comentarios más antiguos
I'm trying to get the inverse cosine of a complex number. Using the definition given in the help of acos(z) produces a different result than directly using acos. See below for the code snippet. Can someone help me out?
format LONGENG
z = 0.625820036622262+1.576125391478034E-055i;
res1 = acos(z)
d = z + i*sqrt(1-(z*z))
res2 = -i*log(d)
Respuestas (1)
Andrew Reibold
el 9 de Oct. de 2014
Editada: Andrew Reibold
el 9 de Oct. de 2014
I know why!
You were close, but you didn't quite replicate the definition in the documentation correctly.

This is how you would write it.
d = z + i*sqrt(1-z*z)
res2 = -i*log(d)
Using this corrected definition, I get approximately 0.894613863 + ~0i for both answers.
First Method Solution: 0.894613863926113 - 2.02075780910344e-55i
Second Method Solution: 0.894613863926114 + 1.11022302462516e-16i
Bother of the i values are near negligible in magnitude relative to the real part.
Hope this helped!
-Andrew
4 comentarios
Sriram
el 9 de Oct. de 2014
Titus Edelhofer
el 9 de Oct. de 2014
You can't expect them to be exactly equal: since the computation of the imaginary part involves the real part, you can expect the result only be precise up to the numerical roundoff (which is in fact what Andrew got as result, namely
eps(0.89)
ans =
1.1102e-16
Titus
Sriram
el 9 de Oct. de 2014
Andrew Reibold
el 10 de Oct. de 2014
Editada: Andrew Reibold
el 10 de Oct. de 2014
For some reason I thought your square root function was only taking the square root of z^2. Unless you edited the question, I just made an honest mistake saying you typed it wrong I guess.
Categorías
Más información sobre Data Type Identification 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!