Jump to content

Hypot: Difference between revisions

From Wikipedia, the free encyclopedia
Content deleted Content added
Implementation: mention corner case of hypot(0,0) failing
Tags: Mobile edit Mobile web edit
Add Scala
Line 51: Line 51:
*JavaScript<ref>https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Math/hypot</ref>
*JavaScript<ref>https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Math/hypot</ref>
*Some C90 and C++ libraries have provided a hypot function.<ref>Single Unix Specification, Open Group, http://www.opengroup.org/onlinepubs/007908799/xsh/hypot.html</ref><ref>IBM, ILE C/C++ Run-Time Library Functions, http://publib.boulder.ibm.com/infocenter/iadthelp/v7r0/index.jsp?topic=/com.ibm.etools.iseries.langref.doc/rzan5mst144.htm</ref><ref>The GNU C Library, Mathematics, http://www.cs.utah.edu/dept/old/texinfo/glibc-manual-0.02/library_17.html {{Webarchive|url=https://web.archive.org/web/20090305023614/http://www.cs.utah.edu/dept/old/texinfo/glibc-manual-0.02/library_17.html |date=2009-03-05 }}</ref>
*Some C90 and C++ libraries have provided a hypot function.<ref>Single Unix Specification, Open Group, http://www.opengroup.org/onlinepubs/007908799/xsh/hypot.html</ref><ref>IBM, ILE C/C++ Run-Time Library Functions, http://publib.boulder.ibm.com/infocenter/iadthelp/v7r0/index.jsp?topic=/com.ibm.etools.iseries.langref.doc/rzan5mst144.htm</ref><ref>The GNU C Library, Mathematics, http://www.cs.utah.edu/dept/old/texinfo/glibc-manual-0.02/library_17.html {{Webarchive|url=https://web.archive.org/web/20090305023614/http://www.cs.utah.edu/dept/old/texinfo/glibc-manual-0.02/library_17.html |date=2009-03-05 }}</ref>
*[[Scala]]<ref>https://www.scala-lang.org/enwiki/api/current/scala/math/index.html#hypot(x:Double,y:Double):Double</ref>


==See also==
==See also==

Revision as of 19:05, 11 July 2020

Hypot is a mathematical function defined to calculate the length of the hypotenuse of a right-angle triangle. It was designed to avoid errors arising due to limited-precision calculations performed on computers.

Motivation and usage

Calculating the length of the hypotenuse of a triangle is possible using the square-root function on the sum of two squares, but hypot(xy) avoids problems that occur when squaring very large or very small numbers.

The magnitude of the hypotenuse from (0, 0) to (xy) can be calculated using

This operation is also known as Pythagorean addition.

However, the squares of very large or small values of x and y may exceed the range of machine precision when calculated on a computer, leading to an inaccurate result caused by arithmetic underflow and/or arithmetic overflow. The hypot function was designed to calculate the result without causing this problem.

The hypot function is often used together with the atan2 function to convert from Cartesian coordinates to polar coordinates:

r = hypot(xy),
θ = atan2(yx).

Implementation

The difficulty with the naive implementation is that x2 or y2 may overflow or underflow, unless the intermediate result is computed with extended precision. A common implementation technique is to exchange the values, if necessary, so that |x| ≥ |y|, and then use the equivalent form[1]

The computation of y/x cannot overflow unless both x and y are 0. If y/x underflows, the final result is equal to |x|, which is correct within the precision of the calculation. The square root is computed of a value between 1 and 2. Finally, the multiplication by |x| cannot underflow, and overflows only when the result is too large to represent.

Programming language support

The function is present in several programming languages:

See also

References

  1. ^ In some situations, last form reduces calcuration errors (in ULPs).
  2. ^ Cimpanu, Catalin. "CSS to get support for trigonometry functions". ZDNet. Retrieved 2019-11-01.
  3. ^ http://www.cplusplus.com/reference/cmath/hypot/
  4. ^ https://dlang.org/phobos/std_math.html#.hypot
  5. ^ https://docs.julialang.org/en/v1/base/math/#Base.Math.hypot
  6. ^ https://docs.python.org/3/library/math.html#math.hypot
  7. ^ https://developer.apple.com/DOCUMENTATION/mac/PPCNumerics/PPCNumerics-141.html
  8. ^ http://nl.mathworks.com/help/matlab/ref/hypot.html
  9. ^ http://www.frameworkpascal.com/helphtml/hypot_func.htm
  10. ^ http://www.php.net/hypot
  11. ^ http://java.sun.com/j2se/1.5.0/docs/enwiki/api/java/lang/Math.html#hypot(double,%20double)
  12. ^ "hypot - Kotlin Programming Language". Kotlin. Retrieved 2018-03-19.
  13. ^ http://ruby-doc.org/core/Math.html#method-c-hypot
  14. ^ http://golang.org/pkg/math/#Hypot
  15. ^ https://doc.rust-lang.org/std/primitive.f64.html#method.hypot
  16. ^ https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Math/hypot
  17. ^ Single Unix Specification, Open Group, http://www.opengroup.org/onlinepubs/007908799/xsh/hypot.html
  18. ^ IBM, ILE C/C++ Run-Time Library Functions, http://publib.boulder.ibm.com/infocenter/iadthelp/v7r0/index.jsp?topic=/com.ibm.etools.iseries.langref.doc/rzan5mst144.htm
  19. ^ The GNU C Library, Mathematics, http://www.cs.utah.edu/dept/old/texinfo/glibc-manual-0.02/library_17.html Archived 2009-03-05 at the Wayback Machine
  20. ^ https://www.scala-lang.org/enwiki/api/current/scala/math/index.html#hypot(x:Double,y:Double):Double