On 4/30/07, David Goldsmith <David.L.Goldsmith@noaa.gov> wrote:
lorenzo bolla wrote:
> me!
> I have two cases.
>
>    1. I need that arctan2(1+0.00000001j,1-0.000001j) gives something
>       close to arctan2(1,1): any decent analytic prolungation will do!
>
This is the foreseeable use case described by Anne.

In any event, I stand not only corrected, but embarrassed (for numpy):

    Python 2.5 (r25:51918, Sep 19 2006, 08:49:13)
    [GCC 4.0.1 (Apple Computer, Inc. build 5341)] on darwin
    Type "help", "copyright", "credits" or "license" for more information.
     >>> import numpy as N
     >>> complex(0,1)
    1j
     >>> N.arctan(1)
    0.78539816339744828
     >>> N.arctan(complex(0,1))
    Warning: invalid value encountered in arctan
    (nannanj)

I agree that arctan should be implemented for _at least_ *one* complex
argument...

It is, you should look at that error a bit more carefully...

-tim

(hint what is arctan(0+1j)?)
 

DG
>
>    1. if someone of you is familiar with electromagnetic problems, in
>       particular with Snell's law, will recognize that in case of
>       total internal reflection
>       < http://en.wikipedia.org/wiki/Total_internal_reflection> the
>       wavevector tangential to the interface is real, while the normal
>       one is purely imaginary: hence the angle of diffraction is still
>       given by arctan2(k_tangent, k_normal), that, as in Matlab or
>       Octave, should give pi/2 (that physically means no propagation
>       -- total internal reflection, as said).
>
> L.
>
> On 4/30/07, *Anne Archibald* <peridot.faceted@gmail.com
> <mailto:peridot.faceted@gmail.com>> wrote:
>
>     On 29/04/07, David Goldsmith <David.L.Goldsmith@noaa.gov
>     <mailto:David.L.Goldsmith@noaa.gov >> wrote:
>     > Far be it from me to challenge the mighty Wolfram, but I'm not
>     sure that
>     > using the *formula* for calculating the arctan of a *single*
>     complex
>     > argument from its real and imaginary parts makes any sense if x
>     and/or y
>     > are themselves complex (in particular, does Lim(formula), as the
>     > imaginary part of complex x and/or y approaches zero, approach
>     > arctan2(realpart(x), realpart(y)?) - without going to the trouble to
>     > determine it one way or another, I'd be surprised if "their"
>     > continuation of the arctan2 function from RxR to CxC is (a. e.)
>     > continuous (not that I know for sure that "mine" is...).
>
>     Well, yes, in fact, theirs is continuous, and in fact analytic, except
>     along the branch cuts (which they describe). Formulas almost always
>     yield continuous functions apart from easy-to-recognize cases. (This
>     can be made into a specific theorem if you're determined.)
>
>     Their formula is a pretty reasonable choice, given that it's not at
>     all clear what arctan2 should mean for complex arguments. But for
>     numpy it's tempting to simply throw an exception (which would catch
>     quite a few programmer errors that would otherwise manifest as
>     nonsense numbers). Still, I suppose defining it on the complex
>     numbers
>     in a way that is continuous close to the real plane allows people to
>     put in almost-real complex numbers and get out pretty much the answer
>     they expect. Does anyone have an application for which they need
>     arctan2 of, say, (1+i,1-i)?
>
>     Anne
>     _______________________________________________
>     Numpy-discussion mailing list
>     Numpy-discussion@scipy.org <mailto:Numpy-discussion@scipy.org>
>     http://projects.scipy.org/mailman/listinfo/numpy-discussion
>
>
> ------------------------------------------------------------------------
>
> _______________________________________________
> Numpy-discussion mailing list
> Numpy-discussion@scipy.org
> http://projects.scipy.org/mailman/listinfo/numpy-discussion
>

_______________________________________________
Numpy-discussion mailing list
Numpy-discussion@scipy.org
http://projects.scipy.org/mailman/listinfo/numpy-discussion



--

//=][=\\

tim.hochberg@ieee.org