Jump to content

atan2

From Wikipedia, the free encyclopedia

This is an old revision of this page, as edited by SciKal (talk | contribs) at 15:30, 12 January 2017 (Definition and computation). The present address (URL) is a permanent link to this revision, which may differ significantly from the current revision.

Graph of the tangent function from −π to +π with the corresponding signs of x and y for atan2(y, x). The green arrows show two results of the atan2 function dependent on the sign of the arguments.

In a variety of computer languages, the function atan2 is the arctangent function with two arguments. The purpose of using two arguments instead of one is to gather information on the signs of the inputs in order to return the appropriate quadrant of the computed angle, which is not possible for the single-argument arctangent function. It also avoids the problems of division by zero.

For any real number (e.g., floating point) arguments x and y not both equal to zero, atan2(y, x) is the angle in radians between the positive x-axis of a plane and the point given by the coordinates (x, y) on it. The angle is positive for counter-clockwise angles (upper half-plane, y > 0), and negative for clockwise angles (lower half-plane, y < 0).

History and motivation

The atan2 function was first introduced in computer programming languages, but now it is also common in other fields of science and engineering. It dates back at least as far as the FORTRAN programming language[1] and is currently found in many modern programming languages. Among these languages are: C's math.h standard library, the Java Math library, .NET's System.Math (usable from C#, VB.NET, etc.), the Python math module, the Ruby Math module, and elsewhere. In addition, many scripting languages, such as Perl, include the C-style atan2(y,x) function.

The one-argument arctangent function cannot distinguish between diametrically opposite directions. For example, the anticlockwise angle from the x-axis to the vector (1, 1), calculated in the usual way as arctan(1/1), is π/4 (radians), or 45°. However, the angle between the x-axis and the vector (−1, −1) appears, by the same method, to be arctan(−1/−1), again π/4, even though the answer clearly should be −3π/4, or −135°. In addition, an attempt to find the angle between the x-axis and the vector (0, 1) requires evaluation of arctan(1/0), which fails on division by zero.

The atan2 function calculates the arc tangent of the two variables y and x. It is similar to calculating the arc tangent of y/x, except that the signs of both arguments are used to determine the quadrant of the result. Thus, the atan2 function takes into account the signs of both vector components, and places the angle in the correct quadrant, e.g., atan2 (1, 1) = π/4 and atan2 (−1, −1) = −3π/4. In addition, atan2 can produce an angle of ±π/2 (or ±90°) while the ordinary arctangent method breaks down, e.g., atan2 (1, 0 )= π/2.

When calculations are performed manually, the necessary quadrant corrections and exception handling can be done by inspection, but it is extremely useful to have a single function that always gives an unambiguous correct result. The atan2 function is useful in many applications involving vectors in Euclidean space, such as finding the direction from one point to another. A principal use is in computer graphics rotations, for converting rotation matrix representations into Euler angles.

Definition and computation

The function atan2 computes the principal value of the argument function applied to the complex number x+iy. That is, atan2(y, x) = Pr arg(x+iy) = Arg(x+iy). The argument can be changed by (corresponding to a complete turn around the origin) without making any difference to the angle, but to define atan2 uniquely one uses the principal value in the range (−π, π]. That is, π < atan2(y, x) ≤ π.

In terms of the standard arctan function, whose range is (−π/2, π/2), it can be expressed as follows:

A more compact expression with four overlapping half-planes is

A variant of the last formula which avoids rounding errors being blown up is sometimes used in high precision computation:

Notes:

  • This produces results in the range (−π, π], which can be mapped to [0, 2π) by adding to negative results.

The relation between atan2(y, x) and arctan(y/x)

The derivation of the principal value of the argument refers to this figure

The derivation of the principal value of the argument atan2(y, x) goes as follows: If (x,y) = (r cos θ, r sin θ) then tan θ/2 = y/r + x. It follows that:

Note that x2 + y2 + x ≠ 0 in the domain in question. Computation gives

Illustrations

atan2 at selected points.

The figure alongside shows values of atan2 at selected points on the unit circle. The values, in radians, are shown inside the circle. The diagram uses the standard mathematical convention that angles increase counterclockwise, and zero is to the right. Note that the order of arguments is reversed; the function atan2(y, x) computes the angle corresponding to the point (x, y).

The figure below shows values of atan2 for points on the unit circle. On the x-axis is the angle of the points, starting from 0 (point (1, 0)) and going counterclockwise, through points:

  • (0, 1) with angle π/2 (in radians);
  • (−1, 0) with angle π;
  • (0, −1) with angle /2;

to (1, 0) with angle 0 = (2πn mod 2π). One can clearly see the branch cut of the atan2 function.[2]

atan2 on the unit circle.

The two figures below show 3D view of respectively atan2(y, x) and arctan(y/x) over a region of the plane. Note that for atan2(y, x), rays emanating from the origin have constant values, but for arctan(y/x) lines passing through the origin have constant values. For x > 0, the two diagrams give identical values.


Identities

Addition sum and difference identity

Sums of may be collapsed into a single operation according to the following identity

...provided that .

The proof involves considering two cases, one where or and one where and .

We only consider the case where or . To start, we make the following observations:

  1. provided that or .
  2. , where is the complex argument function.
  3. whenever , a consequence of Euler's formula.
  4. .

To see (4), we have the identity where , hence . Furthermore, since for any positive real value , then if we let and then we have .

From these observations have following equivalences:

Derivative

As the function atan2 is a function of two variables, it has two partial derivatives. At points where these derivatives exist, atan2 is, except for a constant, equal to arctan(y/x). Hence for x > 0 or y ≠ 0,

Informally representing the function atan2 as the angle function θ(x, y) = atan2(y, x) (which is only defined up to a constant) yields the following formula for the total differential:

While the function atan2 is discontinuous along the negative y-axis, reflecting the fact that angle cannot be continuously defined, this derivative is continuously defined except at the origin, reflecting the fact that infinitesimal (and indeed local) changes in angle can be defined everywhere except the origin. Integrating this derivative along a path gives the total change in angle over the path, and integrating over a closed loop gives the winding number.

In the language of differential geometry, this derivative is a one-form, and it is closed (its derivative is zero) but not exact (it is not the derivative of a 0-form, i.e., a function), and in fact it generates the first de Rham cohomology of the punctured plane. This is the most basic example of such a form, and it is fundamental in differential geometry.

The partial derivatives of atan2 do not contain trigonometric functions, making it particularly useful in many applications (e.g. embedded systems) where trigonometric functions can be expensive to evaluate.


Realizations of the function in common computer languages

The realization of the function differs from one computer languages to another:

  • In Common Lisp, where optional arguments exist, the atan function allows one to optionally supply the x coordinate: (atan y x).[3]
  • In Mathematica, the form ArcTan[x, y] is used where the one parameter form supplies the normal arctangent. Mathematica classifies ArcTan[0, 0] as an indeterminate expression.
  • In Microsoft Excel,[4] OpenOffice.org Calc, LibreOffice Calc,[5] Google Spreadsheets,[6] iWork Numbers,[7] and ANSI SQL:2008 standard,[8] the atan2 function has the two arguments reversed.
  • In the Intel Architecture assembler code, atan2 is known as the FPATAN (floating-point partial arctangent) instruction.[9] It can deal with infinities and results lie in the closed interval [−π, π], e.g. atan2(∞, x) = +π/2 for finite x. Particularly, FPATAN is defined when both arguments are zero:
    atan2(+0, +0) = +0;
    atan2(+0, −0) = +π;
    atan2(−0, +0) = −0;
    atan2(−0, −0) = −π.
This definition is related to the concept of signed zero.
  • On most TI graphing calculators (excluding the TI-85 and TI-86), the equivalent function is called R►Pθ and has the arguments reversed.
  • On TI-85 the arg function is called angle(x,y) and although it appears to take two arguments, it really only has one complex argument which is denoted by a pair of numbers: x + yi = (x, y).
  • In mathematical writings other than source code, such as in books and articles, the notations Arctan[10] and Tan−1[11] have been utilized; these are uppercase variants of the regular arctan and tan−1. This usage is consistent with the complex argument notation, such that Atan(y, x) = Arg(x + yi).
  • On HP calculators, treat the coordinates as a complex number and then take the ARG. Or << C->R ARG >> 'ATAN2' STO.
  • On scientific calculators the function can often be calculated as the angle given when (x, y) is converted from rectangular coordinates to polar coordinates.

See also

References

  1. ^ Organick, Elliott I. (1966). A FORTRAN IV Primer. Addison-Wesley. p. 42. Some processors also offer the library function called ATAN2, a function of two arguments (opposite and adjacent). {{cite book}}: Cite has empty unknown parameter: |coauthors= (help)
  2. ^ Computation of the external argument by Wolf Jung
  3. ^ "CLHS: Function ASIN, ACOS, ATAN". LispWorks.
  4. ^ "Microsoft Excel Atan2 Method". Microsoft.
  5. ^ "LibreOffice Calc ATAN2". Libreoffice.org.
  6. ^ "Google Spreadsheets' Function List". Google.
  7. ^ "Numbers' Trigonometric Function List". Apple.
  8. ^ "ANSI SQL:2008 standard". Teradata. Archived from the original on 2015-08-20. {{cite web}}: Unknown parameter |deadurl= ignored (|url-status= suggested) (help)
  9. ^ IA-32 Intel Architecture Software Developer’s Manual. Volume 2A: Instruction Set Reference, A-M, 2004.
  10. ^ https://books.google.com/books?id=2LIMMD9FVXkC&pg=PA234&dq=four+quadrant+inverse+tangent+mathematical+notation&hl=en&sa=X&ei=Q2Y4UaGTAcmzyAHsooCoBw&ved=0CDgQ6AEwAg#v=onepage&q=four%20quadrant%20inverse%20tangent%20mathematical%20notation&f=false
  11. ^ https://books.google.com/books?id=7nNjaH9B0_0C&pg=PA345&dq=four+quadrant+inverse+tangent+mathematical+notation&hl=en&sa=X&ei=Q2Y4UaGTAcmzyAHsooCoBw&ved=0CDIQ6AEwAQ#v=onepage&q=four%20quadrant%20inverse%20tangent%20mathematical%20notation&f=false

Other implementations/code for atan2