Namespaces
Variants
Views
Actions

Difference between revisions of "cpp/numeric/complex/tan"

From cppreference.com
< cpp‎ | numeric‎ | complex
m (langlinks)
m (fmt, headers sorted)
Line 1: Line 1:
 
{{cpp/title|tan{{small|(std::complex)}}}}
 
{{cpp/title|tan{{small|(std::complex)}}}}
 
{{cpp/numeric/complex/navbar}}
 
{{cpp/numeric/complex/navbar}}
{{ddcl | header=complex | 1=
+
{{ddcl|header=complex|1=
 
template< class T >  
 
template< class T >  
 
complex<T> tan( const complex<T>& z );
 
complex<T> tan( const complex<T>& z );
 
}}
 
}}
  
Computes complex tangent of a complex value {{tt|z}}.
+
Computes complex tangent of a complex value {{c|z}}.
  
 
===Parameters===
 
===Parameters===
 
{{par begin}}
 
{{par begin}}
{{par | z | complex value}}
+
{{par|z|complex value}}
 
{{par end}}
 
{{par end}}
  
 
===Return value===
 
===Return value===
 +
If no errors occur, the complex tangent of {{c|z}} is returned.
  
If no errors occur, the complex tangent of {{tt|z}} is returned.
+
Errors and special cases are handled as if the operation is implemented by {{tt|-i * [[cpp/numeric/complex/tanh|std::tanh]](i * z)}}, where {{tt|i}} is the imaginary unit.
 
+
Errors and special cases are handled as if the operation is implemented by {{tt|-i * [[cpp/numeric/complex/tanh|std::tanh]](i*z)}}, where {{tt|i}} is the imaginary unit.
+
  
 
===Notes===
 
===Notes===
 
Tangent is an analytical function on the complex plain and has no branch cuts. It is periodic with respect to the real component, with period &pi;i, and has poles of the first order along the real line, at coordinates {{math|(π(1/2 + n), 0)}}. However no common floating-point representation is able to represent π/2 exactly, thus there is no value of the argument for which a pole error occurs.
 
Tangent is an analytical function on the complex plain and has no branch cuts. It is periodic with respect to the real component, with period &pi;i, and has poles of the first order along the real line, at coordinates {{math|(π(1/2 + n), 0)}}. However no common floating-point representation is able to represent π/2 exactly, thus there is no value of the argument for which a pole error occurs.
  
Mathematical definition of the tangent is {{math|tan z {{=}} {{mfrac|i(e{{su|p=-iz}}-e{{su|p=iz}})|e{{su|p=-iz}}+e{{su|p=iz}}}}}}
+
Mathematical definition of the tangent is {{math|tan z {{=}} {{mfrac|i(e{{su|p=-iz}}-e{{su|p=iz}})|e{{su|p=-iz}}+e{{su|p=iz}}}}}}.
  
 
===Example===
 
===Example===
 
{{example|
 
{{example|
 
|code=
 
|code=
#include <iostream>
 
 
#include <cmath>
 
#include <cmath>
 
#include <complex>
 
#include <complex>
 +
#include <iostream>
  
 
int main()
 
int main()
 
{
 
{
 
     std::cout << std::fixed;
 
     std::cout << std::fixed;
     std::complex<double> z(1, 0); // behaves like real tangent along the real line
+
     std::complex<double> z(1.0, 0.0); // behaves like real tangent along the real line
 
     std::cout << "tan" << z << " = " << std::tan(z)
 
     std::cout << "tan" << z << " = " << std::tan(z)
 
               << " ( tan(1) = " << std::tan(1) << ")\n";
 
               << " ( tan(1) = " << std::tan(1) << ")\n";
  
     std::complex<double> z2(0, 1); // behaves like tanh along the imaginary line
+
     std::complex<double> z2(0.0, 1.0); // behaves like tanh along the imaginary line
 
     std::cout << "tan" << z2 << " = " << std::tan(z2)
 
     std::cout << "tan" << z2 << " = " << std::tan(z2)
 
               << " (tanh(1) = " << std::tanh(1) << ")\n";
 
               << " (tanh(1) = " << std::tanh(1) << ")\n";
Line 49: Line 48:
 
===See also===
 
===See also===
 
{{dsc begin}}
 
{{dsc begin}}
{{dsc inc | cpp/numeric/complex/dsc sin}}
+
{{dsc inc|cpp/numeric/complex/dsc sin}}
{{dsc inc | cpp/numeric/complex/dsc cos}}
+
{{dsc inc|cpp/numeric/complex/dsc cos}}
{{dsc inc | cpp/numeric/complex/dsc atan}}
+
{{dsc inc|cpp/numeric/complex/dsc atan}}
{{dsc inc | cpp/numeric/math/dsc tan}}
+
{{dsc inc|cpp/numeric/math/dsc tan}}
{{dsc inc | cpp/numeric/valarray/dsc tan}}
+
{{dsc inc|cpp/numeric/valarray/dsc tan}}
{{dsc see c | c/numeric/complex/ctan}}
+
{{dsc see c|c/numeric/complex/ctan}}
 
{{dsc end}}
 
{{dsc end}}
  
 
{{langlinks|de|es|fr|it|ja|pt|ru|zh}}
 
{{langlinks|de|es|fr|it|ja|pt|ru|zh}}

Revision as of 07:30, 22 April 2023

 
 
 
 
Defined in header <complex>
template< class T >
complex<T> tan( const complex<T>& z );

Computes complex tangent of a complex value z.

Contents

Parameters

z - complex value

Return value

If no errors occur, the complex tangent of z is returned.

Errors and special cases are handled as if the operation is implemented by -i * std::tanh(i * z), where i is the imaginary unit.

Notes

Tangent is an analytical function on the complex plain and has no branch cuts. It is periodic with respect to the real component, with period πi, and has poles of the first order along the real line, at coordinates (π(1/2 + n), 0). However no common floating-point representation is able to represent π/2 exactly, thus there is no value of the argument for which a pole error occurs.

Mathematical definition of the tangent is tan z =
i(e-iz-eiz)
e-iz+eiz
.

Example

#include <cmath>
#include <complex>
#include <iostream>
 
int main()
{
    std::cout << std::fixed;
    std::complex<double> z(1.0, 0.0); // behaves like real tangent along the real line
    std::cout << "tan" << z << " = " << std::tan(z)
              << " ( tan(1) = " << std::tan(1) << ")\n";
 
    std::complex<double> z2(0.0, 1.0); // behaves like tanh along the imaginary line
    std::cout << "tan" << z2 << " = " << std::tan(z2)
              << " (tanh(1) = " << std::tanh(1) << ")\n";
}

Output:

tan(1.000000,0.000000) = (1.557408,0.000000) ( tan(1) = 1.557408)
tan(0.000000,1.000000) = (0.000000,0.761594) (tanh(1) = 0.761594)

See also

computes sine of a complex number (sin(z))
(function template) [edit]
computes cosine of a complex number (cos(z))
(function template) [edit]
computes arc tangent of a complex number (arctan(z))
(function template) [edit]
(C++11)(C++11)
computes tangent (tan(x))
(function) [edit]
applies the function std::tan to each element of valarray
(function template) [edit]