[clang] Fix crashes when passing VLA to va_arg (#119563)
[llvm-project.git] / libcxx / include / __cxx03 / complex
blobc68bce75bb9befd6f664a406a947f454b94c8a53
1 // -*- C++ -*-
2 //===----------------------------------------------------------------------===//
3 //
4 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
5 // See https://llvm.org/LICENSE.txt for license information.
6 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
7 //
8 //===----------------------------------------------------------------------===//
10 #ifndef _LIBCPP___CXX03_COMPLEX
11 #define _LIBCPP___CXX03_COMPLEX
14     complex synopsis
16 namespace std
19 template<class T>
20 class complex
22 public:
23     typedef T value_type;
25     complex(const T& re = T(), const T& im = T()); // constexpr in C++14
26     complex(const complex&);  // constexpr in C++14
27     template<class X> complex(const complex<X>&);  // constexpr in C++14
29     T real() const; // constexpr in C++14
30     T imag() const; // constexpr in C++14
32     void real(T); // constexpr in C++20
33     void imag(T); // constexpr in C++20
35     complex<T>& operator= (const T&); // constexpr in C++20
36     complex<T>& operator+=(const T&); // constexpr in C++20
37     complex<T>& operator-=(const T&); // constexpr in C++20
38     complex<T>& operator*=(const T&); // constexpr in C++20
39     complex<T>& operator/=(const T&); // constexpr in C++20
41     complex& operator=(const complex&); // constexpr in C++20
42     template<class X> complex<T>& operator= (const complex<X>&); // constexpr in C++20
43     template<class X> complex<T>& operator+=(const complex<X>&); // constexpr in C++20
44     template<class X> complex<T>& operator-=(const complex<X>&); // constexpr in C++20
45     template<class X> complex<T>& operator*=(const complex<X>&); // constexpr in C++20
46     template<class X> complex<T>& operator/=(const complex<X>&); // constexpr in C++20
49 template<>
50 class complex<float>
52 public:
53     typedef float value_type;
55     constexpr complex(float re = 0.0f, float im = 0.0f);
56     explicit constexpr complex(const complex<double>&);
57     explicit constexpr complex(const complex<long double>&);
59     constexpr float real() const;
60     void real(float); // constexpr in C++20
61     constexpr float imag() const;
62     void imag(float); // constexpr in C++20
64     complex<float>& operator= (float); // constexpr in C++20
65     complex<float>& operator+=(float); // constexpr in C++20
66     complex<float>& operator-=(float); // constexpr in C++20
67     complex<float>& operator*=(float); // constexpr in C++20
68     complex<float>& operator/=(float); // constexpr in C++20
70     complex<float>& operator=(const complex<float>&); // constexpr in C++20
71     template<class X> complex<float>& operator= (const complex<X>&); // constexpr in C++20
72     template<class X> complex<float>& operator+=(const complex<X>&); // constexpr in C++20
73     template<class X> complex<float>& operator-=(const complex<X>&); // constexpr in C++20
74     template<class X> complex<float>& operator*=(const complex<X>&); // constexpr in C++20
75     template<class X> complex<float>& operator/=(const complex<X>&); // constexpr in C++20
78 template<>
79 class complex<double>
81 public:
82     typedef double value_type;
84     constexpr complex(double re = 0.0, double im = 0.0);
85     constexpr complex(const complex<float>&);
86     explicit constexpr complex(const complex<long double>&);
88     constexpr double real() const;
89     void real(double); // constexpr in C++20
90     constexpr double imag() const;
91     void imag(double); // constexpr in C++20
93     complex<double>& operator= (double); // constexpr in C++20
94     complex<double>& operator+=(double); // constexpr in C++20
95     complex<double>& operator-=(double); // constexpr in C++20
96     complex<double>& operator*=(double); // constexpr in C++20
97     complex<double>& operator/=(double); // constexpr in C++20
98     complex<double>& operator=(const complex<double>&); // constexpr in C++20
100     template<class X> complex<double>& operator= (const complex<X>&); // constexpr in C++20
101     template<class X> complex<double>& operator+=(const complex<X>&); // constexpr in C++20
102     template<class X> complex<double>& operator-=(const complex<X>&); // constexpr in C++20
103     template<class X> complex<double>& operator*=(const complex<X>&); // constexpr in C++20
104     template<class X> complex<double>& operator/=(const complex<X>&); // constexpr in C++20
107 template<>
108 class complex<long double>
110 public:
111     typedef long double value_type;
113     constexpr complex(long double re = 0.0L, long double im = 0.0L);
114     constexpr complex(const complex<float>&);
115     constexpr complex(const complex<double>&);
117     constexpr long double real() const;
118     void real(long double); // constexpr in C++20
119     constexpr long double imag() const;
120     void imag(long double); // constexpr in C++20
122     complex<long double>& operator=(const complex<long double>&); // constexpr in C++20
123     complex<long double>& operator= (long double); // constexpr in C++20
124     complex<long double>& operator+=(long double); // constexpr in C++20
125     complex<long double>& operator-=(long double); // constexpr in C++20
126     complex<long double>& operator*=(long double); // constexpr in C++20
127     complex<long double>& operator/=(long double); // constexpr in C++20
129     template<class X> complex<long double>& operator= (const complex<X>&); // constexpr in C++20
130     template<class X> complex<long double>& operator+=(const complex<X>&); // constexpr in C++20
131     template<class X> complex<long double>& operator-=(const complex<X>&); // constexpr in C++20
132     template<class X> complex<long double>& operator*=(const complex<X>&); // constexpr in C++20
133     template<class X> complex<long double>& operator/=(const complex<X>&); // constexpr in C++20
136 // 26.3.6 operators:
137 template<class T> complex<T> operator+(const complex<T>&, const complex<T>&); // constexpr in C++20
138 template<class T> complex<T> operator+(const complex<T>&, const T&);          // constexpr in C++20
139 template<class T> complex<T> operator+(const T&, const complex<T>&);          // constexpr in C++20
140 template<class T> complex<T> operator-(const complex<T>&, const complex<T>&); // constexpr in C++20
141 template<class T> complex<T> operator-(const complex<T>&, const T&);          // constexpr in C++20
142 template<class T> complex<T> operator-(const T&, const complex<T>&);          // constexpr in C++20
143 template<class T> complex<T> operator*(const complex<T>&, const complex<T>&); // constexpr in C++20
144 template<class T> complex<T> operator*(const complex<T>&, const T&);          // constexpr in C++20
145 template<class T> complex<T> operator*(const T&, const complex<T>&);          // constexpr in C++20
146 template<class T> complex<T> operator/(const complex<T>&, const complex<T>&); // constexpr in C++20
147 template<class T> complex<T> operator/(const complex<T>&, const T&);          // constexpr in C++20
148 template<class T> complex<T> operator/(const T&, const complex<T>&);          // constexpr in C++20
149 template<class T> complex<T> operator+(const complex<T>&);                    // constexpr in C++20
150 template<class T> complex<T> operator-(const complex<T>&);                    // constexpr in C++20
151 template<class T> bool operator==(const complex<T>&, const complex<T>&);      // constexpr in C++14
152 template<class T> bool operator==(const complex<T>&, const T&);               // constexpr in C++14
153 template<class T> bool operator==(const T&, const complex<T>&);               // constexpr in C++14, removed in C++20
154 template<class T> bool operator!=(const complex<T>&, const complex<T>&);      // constexpr in C++14, removed in C++20
155 template<class T> bool operator!=(const complex<T>&, const T&);               // constexpr in C++14, removed in C++20
156 template<class T> bool operator!=(const T&, const complex<T>&);               // constexpr in C++14, removed in C++20
158 template<class T, class charT, class traits>
159   basic_istream<charT, traits>&
160   operator>>(basic_istream<charT, traits>&, complex<T>&);
161 template<class T, class charT, class traits>
162   basic_ostream<charT, traits>&
163   operator<<(basic_ostream<charT, traits>&, const complex<T>&);
165 // 26.3.7 values:
167 template<class T>              T real(const complex<T>&); // constexpr in C++14
168                      long double real(long double);       // constexpr in C++14
169                           double real(double);            // constexpr in C++14
170 template<Integral T>      double real(T);                 // constexpr in C++14
171                           float  real(float);             // constexpr in C++14
173 template<class T>              T imag(const complex<T>&); // constexpr in C++14
174                      long double imag(long double);       // constexpr in C++14
175                           double imag(double);            // constexpr in C++14
176 template<Integral T>      double imag(T);                 // constexpr in C++14
177                           float  imag(float);             // constexpr in C++14
179 template<class T> T abs(const complex<T>&);
181 template<class T>              T arg(const complex<T>&);
182                      long double arg(long double);
183                           double arg(double);
184 template<Integral T>      double arg(T);
185                           float  arg(float);
187 template<class T>              T norm(const complex<T>&); // constexpr in C++20
188                      long double norm(long double);       // constexpr in C++20
189                           double norm(double);            // constexpr in C++20
190 template<Integral T>      double norm(T);                 // constexpr in C++20
191                           float  norm(float);             // constexpr in C++20
193 template<class T>      complex<T>           conj(const complex<T>&); // constexpr in C++20
194                        complex<long double> conj(long double);       // constexpr in C++20
195                        complex<double>      conj(double);            // constexpr in C++20
196 template<Integral T>   complex<double>      conj(T);                 // constexpr in C++20
197                        complex<float>       conj(float);             // constexpr in C++20
199 template<class T>    complex<T>           proj(const complex<T>&);
200                      complex<long double> proj(long double);
201                      complex<double>      proj(double);
202 template<Integral T> complex<double>      proj(T);
203                      complex<float>       proj(float);
205 template<class T> complex<T> polar(const T&, const T& = T());
207 // 26.3.8 transcendentals:
208 template<class T> complex<T> acos(const complex<T>&);
209 template<class T> complex<T> asin(const complex<T>&);
210 template<class T> complex<T> atan(const complex<T>&);
211 template<class T> complex<T> acosh(const complex<T>&);
212 template<class T> complex<T> asinh(const complex<T>&);
213 template<class T> complex<T> atanh(const complex<T>&);
214 template<class T> complex<T> cos (const complex<T>&);
215 template<class T> complex<T> cosh (const complex<T>&);
216 template<class T> complex<T> exp (const complex<T>&);
217 template<class T> complex<T> log (const complex<T>&);
218 template<class T> complex<T> log10(const complex<T>&);
220 template<class T> complex<T> pow(const complex<T>&, const T&);
221 template<class T> complex<T> pow(const complex<T>&, const complex<T>&);
222 template<class T> complex<T> pow(const T&, const complex<T>&);
224 template<class T> complex<T> sin (const complex<T>&);
225 template<class T> complex<T> sinh (const complex<T>&);
226 template<class T> complex<T> sqrt (const complex<T>&);
227 template<class T> complex<T> tan (const complex<T>&);
228 template<class T> complex<T> tanh (const complex<T>&);
230   // [complex.tuple], tuple interface
231   template<class T> struct tuple_size;                               // Since C++26
232   template<size_t I, class T> struct tuple_element;                  // Since C++26
233   template<class T> struct tuple_size<complex<T>>;                   // Since C++26
234   template<size_t I, class T> struct tuple_element<I, complex<T>>;   // Since C++26
235   template<size_t I, class T>
236     constexpr T& get(complex<T>&) noexcept;                          // Since C++26
237   template<size_t I, class T>
238     constexpr T&& get(complex<T>&&) noexcept;                        // Since C++26
239   template<size_t I, class T>
240     constexpr const T& get(const complex<T>&) noexcept;              // Since C++26
241   template<size_t I, class T>
242     constexpr const T&& get(const complex<T>&&) noexcept;            // Since C++26
244   // [complex.literals], complex literals
245   inline namespace literals {
246   inline namespace complex_literals {
247     constexpr complex<long double> operator""il(long double);        // Since C++14
248     constexpr complex<long double> operator""il(unsigned long long); // Since C++14
249     constexpr complex<double> operator""i(long double);              // Since C++14
250     constexpr complex<double> operator""i(unsigned long long);       // Since C++14
251     constexpr complex<float> operator""if(long double);              // Since C++14
252     constexpr complex<float> operator""if(unsigned long long);       // Since C++14
253   }
254   }
255 }  // std
259 #include <__cxx03/__config>
260 #include <__cxx03/__fwd/complex.h>
261 #include <__cxx03/__fwd/tuple.h>
262 #include <__cxx03/__tuple/tuple_element.h>
263 #include <__cxx03/__tuple/tuple_size.h>
264 #include <__cxx03/__type_traits/conditional.h>
265 #include <__cxx03/__utility/move.h>
266 #include <__cxx03/cmath>
267 #include <__cxx03/version>
269 #if !defined(_LIBCPP_HAS_NO_LOCALIZATION)
270 #  include <__cxx03/sstream> // for std::basic_ostringstream
271 #endif
273 #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
274 #  pragma GCC system_header
275 #endif
277 _LIBCPP_PUSH_MACROS
278 #include <__cxx03/__undef_macros>
280 _LIBCPP_BEGIN_NAMESPACE_STD
282 template <class _Tp>
283 class _LIBCPP_TEMPLATE_VIS complex;
285 template <class _Tp, __enable_if_t<is_floating_point<_Tp>::value, int> = 0>
286 _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex<_Tp>
287 operator*(const complex<_Tp>& __z, const complex<_Tp>& __w);
289 template <class _Tp, __enable_if_t<!is_floating_point<_Tp>::value, int> = 0>
290 _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex<_Tp>
291 operator*(const complex<_Tp>& __z, const complex<_Tp>& __w);
293 template <class _Tp, __enable_if_t<is_floating_point<_Tp>::value, int> = 0>
294 _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex<_Tp>
295 operator/(const complex<_Tp>& __x, const complex<_Tp>& __y);
297 template <class _Tp, __enable_if_t<!is_floating_point<_Tp>::value, int> = 0>
298 _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex<_Tp>
299 operator/(const complex<_Tp>& __x, const complex<_Tp>& __y);
301 template <class _Tp>
302 class _LIBCPP_TEMPLATE_VIS complex {
303 public:
304   typedef _Tp value_type;
306 private:
307   value_type __re_;
308   value_type __im_;
310 public:
311   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX14
312   complex(const value_type& __re = value_type(), const value_type& __im = value_type())
313       : __re_(__re), __im_(__im) {}
314   template <class _Xp>
315   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX14 complex(const complex<_Xp>& __c)
316       : __re_(__c.real()), __im_(__c.imag()) {}
318   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX14 value_type real() const { return __re_; }
319   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX14 value_type imag() const { return __im_; }
321   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 void real(value_type __re) { __re_ = __re; }
322   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 void imag(value_type __im) { __im_ = __im; }
324   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex& operator=(const value_type& __re) {
325     __re_ = __re;
326     __im_ = value_type();
327     return *this;
328   }
329   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex& operator+=(const value_type& __re) {
330     __re_ += __re;
331     return *this;
332   }
333   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex& operator-=(const value_type& __re) {
334     __re_ -= __re;
335     return *this;
336   }
337   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex& operator*=(const value_type& __re) {
338     __re_ *= __re;
339     __im_ *= __re;
340     return *this;
341   }
342   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex& operator/=(const value_type& __re) {
343     __re_ /= __re;
344     __im_ /= __re;
345     return *this;
346   }
348   template <class _Xp>
349   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex& operator=(const complex<_Xp>& __c) {
350     __re_ = __c.real();
351     __im_ = __c.imag();
352     return *this;
353   }
354   template <class _Xp>
355   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex& operator+=(const complex<_Xp>& __c) {
356     __re_ += __c.real();
357     __im_ += __c.imag();
358     return *this;
359   }
360   template <class _Xp>
361   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex& operator-=(const complex<_Xp>& __c) {
362     __re_ -= __c.real();
363     __im_ -= __c.imag();
364     return *this;
365   }
366   template <class _Xp>
367   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex& operator*=(const complex<_Xp>& __c) {
368     *this = *this * complex(__c.real(), __c.imag());
369     return *this;
370   }
371   template <class _Xp>
372   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex& operator/=(const complex<_Xp>& __c) {
373     *this = *this / complex(__c.real(), __c.imag());
374     return *this;
375   }
377 #if _LIBCPP_STD_VER >= 26
378   template <size_t _Ip, class _Xp>
379   friend _LIBCPP_HIDE_FROM_ABI constexpr _Xp& get(complex<_Xp>&) noexcept;
381   template <size_t _Ip, class _Xp>
382   friend _LIBCPP_HIDE_FROM_ABI constexpr _Xp&& get(complex<_Xp>&&) noexcept;
384   template <size_t _Ip, class _Xp>
385   friend _LIBCPP_HIDE_FROM_ABI constexpr const _Xp& get(const complex<_Xp>&) noexcept;
387   template <size_t _Ip, class _Xp>
388   friend _LIBCPP_HIDE_FROM_ABI constexpr const _Xp&& get(const complex<_Xp>&&) noexcept;
389 #endif
392 template <>
393 class _LIBCPP_TEMPLATE_VIS complex<double>;
394 template <>
395 class _LIBCPP_TEMPLATE_VIS complex<long double>;
397 struct __from_builtin_tag {};
399 template <class _Tp>
400 using __complex_t =
401     __conditional_t<is_same<_Tp, float>::value,
402                     _Complex float,
403                     __conditional_t<is_same<_Tp, double>::value, _Complex double, _Complex long double> >;
405 template <class _Tp>
406 _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR __complex_t<_Tp> __make_complex(_Tp __re, _Tp __im) {
407 #if __has_builtin(__builtin_complex)
408   return __builtin_complex(__re, __im);
409 #else
410   return __complex_t<_Tp>{__re, __im};
411 #endif
414 template <>
415 class _LIBCPP_TEMPLATE_VIS complex<float> {
416   float __re_;
417   float __im_;
419 public:
420   typedef float value_type;
422   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR complex(float __re = 0.0f, float __im = 0.0f) : __re_(__re), __im_(__im) {}
424   template <class _Tag, __enable_if_t<_IsSame<_Tag, __from_builtin_tag>::value, int> = 0>
425   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR explicit complex(_Tag, _Complex float __v)
426       : __re_(__real__ __v), __im_(__imag__ __v) {}
428   _LIBCPP_HIDE_FROM_ABI explicit _LIBCPP_CONSTEXPR complex(const complex<double>& __c);
429   _LIBCPP_HIDE_FROM_ABI explicit _LIBCPP_CONSTEXPR complex(const complex<long double>& __c);
431   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR float real() const { return __re_; }
432   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR float imag() const { return __im_; }
434   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 void real(value_type __re) { __re_ = __re; }
435   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 void imag(value_type __im) { __im_ = __im; }
437   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR _Complex float __builtin() const { return std::__make_complex(__re_, __im_); }
438   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX14 void __builtin(_Complex float __f) {
439     __re_ = __real__ __f;
440     __im_ = __imag__ __f;
441   }
443   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex& operator=(float __re) {
444     __re_ = __re;
445     __im_ = value_type();
446     return *this;
447   }
448   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex& operator+=(float __re) {
449     __re_ += __re;
450     return *this;
451   }
452   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex& operator-=(float __re) {
453     __re_ -= __re;
454     return *this;
455   }
456   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex& operator*=(float __re) {
457     __re_ *= __re;
458     __im_ *= __re;
459     return *this;
460   }
461   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex& operator/=(float __re) {
462     __re_ /= __re;
463     __im_ /= __re;
464     return *this;
465   }
467   template <class _Xp>
468   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex& operator=(const complex<_Xp>& __c) {
469     __re_ = __c.real();
470     __im_ = __c.imag();
471     return *this;
472   }
473   template <class _Xp>
474   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex& operator+=(const complex<_Xp>& __c) {
475     __re_ += __c.real();
476     __im_ += __c.imag();
477     return *this;
478   }
479   template <class _Xp>
480   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex& operator-=(const complex<_Xp>& __c) {
481     __re_ -= __c.real();
482     __im_ -= __c.imag();
483     return *this;
484   }
485   template <class _Xp>
486   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex& operator*=(const complex<_Xp>& __c) {
487     *this = *this * complex(__c.real(), __c.imag());
488     return *this;
489   }
490   template <class _Xp>
491   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex& operator/=(const complex<_Xp>& __c) {
492     *this = *this / complex(__c.real(), __c.imag());
493     return *this;
494   }
496 #if _LIBCPP_STD_VER >= 26
497   template <size_t _Ip, class _Xp>
498   friend _LIBCPP_HIDE_FROM_ABI constexpr _Xp& get(complex<_Xp>&) noexcept;
500   template <size_t _Ip, class _Xp>
501   friend _LIBCPP_HIDE_FROM_ABI constexpr _Xp&& get(complex<_Xp>&&) noexcept;
503   template <size_t _Ip, class _Xp>
504   friend _LIBCPP_HIDE_FROM_ABI constexpr const _Xp& get(const complex<_Xp>&) noexcept;
506   template <size_t _Ip, class _Xp>
507   friend _LIBCPP_HIDE_FROM_ABI constexpr const _Xp&& get(const complex<_Xp>&&) noexcept;
508 #endif
511 template <>
512 class _LIBCPP_TEMPLATE_VIS complex<double> {
513   double __re_;
514   double __im_;
516 public:
517   typedef double value_type;
519   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR complex(double __re = 0.0, double __im = 0.0) : __re_(__re), __im_(__im) {}
521   template <class _Tag, __enable_if_t<_IsSame<_Tag, __from_builtin_tag>::value, int> = 0>
522   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR explicit complex(_Tag, _Complex double __v)
523       : __re_(__real__ __v), __im_(__imag__ __v) {}
525   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR complex(const complex<float>& __c);
526   _LIBCPP_HIDE_FROM_ABI explicit _LIBCPP_CONSTEXPR complex(const complex<long double>& __c);
528   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR double real() const { return __re_; }
529   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR double imag() const { return __im_; }
531   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 void real(value_type __re) { __re_ = __re; }
532   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 void imag(value_type __im) { __im_ = __im; }
534   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR _Complex double __builtin() const {
535     return std::__make_complex(__re_, __im_);
536   }
538   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX14 void __builtin(_Complex double __f) {
539     __re_ = __real__ __f;
540     __im_ = __imag__ __f;
541   }
543   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex& operator=(double __re) {
544     __re_ = __re;
545     __im_ = value_type();
546     return *this;
547   }
548   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex& operator+=(double __re) {
549     __re_ += __re;
550     return *this;
551   }
552   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex& operator-=(double __re) {
553     __re_ -= __re;
554     return *this;
555   }
556   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex& operator*=(double __re) {
557     __re_ *= __re;
558     __im_ *= __re;
559     return *this;
560   }
561   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex& operator/=(double __re) {
562     __re_ /= __re;
563     __im_ /= __re;
564     return *this;
565   }
567   template <class _Xp>
568   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex& operator=(const complex<_Xp>& __c) {
569     __re_ = __c.real();
570     __im_ = __c.imag();
571     return *this;
572   }
573   template <class _Xp>
574   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex& operator+=(const complex<_Xp>& __c) {
575     __re_ += __c.real();
576     __im_ += __c.imag();
577     return *this;
578   }
579   template <class _Xp>
580   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex& operator-=(const complex<_Xp>& __c) {
581     __re_ -= __c.real();
582     __im_ -= __c.imag();
583     return *this;
584   }
585   template <class _Xp>
586   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex& operator*=(const complex<_Xp>& __c) {
587     *this = *this * complex(__c.real(), __c.imag());
588     return *this;
589   }
590   template <class _Xp>
591   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex& operator/=(const complex<_Xp>& __c) {
592     *this = *this / complex(__c.real(), __c.imag());
593     return *this;
594   }
596 #if _LIBCPP_STD_VER >= 26
597   template <size_t _Ip, class _Xp>
598   friend _LIBCPP_HIDE_FROM_ABI constexpr _Xp& get(complex<_Xp>&) noexcept;
600   template <size_t _Ip, class _Xp>
601   friend _LIBCPP_HIDE_FROM_ABI constexpr _Xp&& get(complex<_Xp>&&) noexcept;
603   template <size_t _Ip, class _Xp>
604   friend _LIBCPP_HIDE_FROM_ABI constexpr const _Xp& get(const complex<_Xp>&) noexcept;
606   template <size_t _Ip, class _Xp>
607   friend _LIBCPP_HIDE_FROM_ABI constexpr const _Xp&& get(const complex<_Xp>&&) noexcept;
608 #endif
611 template <>
612 class _LIBCPP_TEMPLATE_VIS complex<long double> {
613   long double __re_;
614   long double __im_;
616 public:
617   typedef long double value_type;
619   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR complex(long double __re = 0.0L, long double __im = 0.0L)
620       : __re_(__re), __im_(__im) {}
622   template <class _Tag, __enable_if_t<_IsSame<_Tag, __from_builtin_tag>::value, int> = 0>
623   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR explicit complex(_Tag, _Complex long double __v)
624       : __re_(__real__ __v), __im_(__imag__ __v) {}
626   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR complex(const complex<float>& __c);
627   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR complex(const complex<double>& __c);
629   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR long double real() const { return __re_; }
630   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR long double imag() const { return __im_; }
632   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 void real(value_type __re) { __re_ = __re; }
633   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 void imag(value_type __im) { __im_ = __im; }
635   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR _Complex long double __builtin() const {
636     return std::__make_complex(__re_, __im_);
637   }
639   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX14 void __builtin(_Complex long double __f) {
640     __re_ = __real__ __f;
641     __im_ = __imag__ __f;
642   }
644   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex& operator=(long double __re) {
645     __re_ = __re;
646     __im_ = value_type();
647     return *this;
648   }
649   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex& operator+=(long double __re) {
650     __re_ += __re;
651     return *this;
652   }
653   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex& operator-=(long double __re) {
654     __re_ -= __re;
655     return *this;
656   }
657   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex& operator*=(long double __re) {
658     __re_ *= __re;
659     __im_ *= __re;
660     return *this;
661   }
662   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex& operator/=(long double __re) {
663     __re_ /= __re;
664     __im_ /= __re;
665     return *this;
666   }
668   template <class _Xp>
669   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex& operator=(const complex<_Xp>& __c) {
670     __re_ = __c.real();
671     __im_ = __c.imag();
672     return *this;
673   }
674   template <class _Xp>
675   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex& operator+=(const complex<_Xp>& __c) {
676     __re_ += __c.real();
677     __im_ += __c.imag();
678     return *this;
679   }
680   template <class _Xp>
681   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex& operator-=(const complex<_Xp>& __c) {
682     __re_ -= __c.real();
683     __im_ -= __c.imag();
684     return *this;
685   }
686   template <class _Xp>
687   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex& operator*=(const complex<_Xp>& __c) {
688     *this = *this * complex(__c.real(), __c.imag());
689     return *this;
690   }
691   template <class _Xp>
692   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex& operator/=(const complex<_Xp>& __c) {
693     *this = *this / complex(__c.real(), __c.imag());
694     return *this;
695   }
697 #if _LIBCPP_STD_VER >= 26
698   template <size_t _Ip, class _Xp>
699   friend _LIBCPP_HIDE_FROM_ABI constexpr _Xp& get(complex<_Xp>&) noexcept;
701   template <size_t _Ip, class _Xp>
702   friend _LIBCPP_HIDE_FROM_ABI constexpr _Xp&& get(complex<_Xp>&&) noexcept;
704   template <size_t _Ip, class _Xp>
705   friend _LIBCPP_HIDE_FROM_ABI constexpr const _Xp& get(const complex<_Xp>&) noexcept;
707   template <size_t _Ip, class _Xp>
708   friend _LIBCPP_HIDE_FROM_ABI constexpr const _Xp&& get(const complex<_Xp>&&) noexcept;
709 #endif
712 inline _LIBCPP_CONSTEXPR complex<float>::complex(const complex<double>& __c) : __re_(__c.real()), __im_(__c.imag()) {}
714 inline _LIBCPP_CONSTEXPR complex<float>::complex(const complex<long double>& __c)
715     : __re_(__c.real()), __im_(__c.imag()) {}
717 inline _LIBCPP_CONSTEXPR complex<double>::complex(const complex<float>& __c) : __re_(__c.real()), __im_(__c.imag()) {}
719 inline _LIBCPP_CONSTEXPR complex<double>::complex(const complex<long double>& __c)
720     : __re_(__c.real()), __im_(__c.imag()) {}
722 inline _LIBCPP_CONSTEXPR complex<long double>::complex(const complex<float>& __c)
723     : __re_(__c.real()), __im_(__c.imag()) {}
725 inline _LIBCPP_CONSTEXPR complex<long double>::complex(const complex<double>& __c)
726     : __re_(__c.real()), __im_(__c.imag()) {}
728 // 26.3.6 operators:
730 template <class _Tp>
731 inline _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex<_Tp>
732 operator+(const complex<_Tp>& __x, const complex<_Tp>& __y) {
733   complex<_Tp> __t(__x);
734   __t += __y;
735   return __t;
738 template <class _Tp>
739 inline _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex<_Tp>
740 operator+(const complex<_Tp>& __x, const _Tp& __y) {
741   complex<_Tp> __t(__x);
742   __t += __y;
743   return __t;
746 template <class _Tp>
747 inline _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex<_Tp>
748 operator+(const _Tp& __x, const complex<_Tp>& __y) {
749   complex<_Tp> __t(__y);
750   __t += __x;
751   return __t;
754 template <class _Tp>
755 inline _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex<_Tp>
756 operator-(const complex<_Tp>& __x, const complex<_Tp>& __y) {
757   complex<_Tp> __t(__x);
758   __t -= __y;
759   return __t;
762 template <class _Tp>
763 inline _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex<_Tp>
764 operator-(const complex<_Tp>& __x, const _Tp& __y) {
765   complex<_Tp> __t(__x);
766   __t -= __y;
767   return __t;
770 template <class _Tp>
771 inline _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex<_Tp>
772 operator-(const _Tp& __x, const complex<_Tp>& __y) {
773   complex<_Tp> __t(-__y);
774   __t += __x;
775   return __t;
778 template <class _Tp, __enable_if_t<is_floating_point<_Tp>::value, int> >
779 _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex<_Tp>
780 operator*(const complex<_Tp>& __lhs, const complex<_Tp>& __rhs) {
781   return complex<_Tp>(__from_builtin_tag(), __lhs.__builtin() * __rhs.__builtin());
784 template <class _Tp, __enable_if_t<!is_floating_point<_Tp>::value, int> >
785 _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex<_Tp>
786 operator*(const complex<_Tp>& __z, const complex<_Tp>& __w) {
787   _Tp __a = __z.real();
788   _Tp __b = __z.imag();
789   _Tp __c = __w.real();
790   _Tp __d = __w.imag();
792   return complex<_Tp>((__a * __c) - (__b * __d), (__a * __d) + (__b * __c));
795 template <class _Tp>
796 inline _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex<_Tp>
797 operator*(const complex<_Tp>& __x, const _Tp& __y) {
798   complex<_Tp> __t(__x);
799   __t *= __y;
800   return __t;
803 template <class _Tp>
804 inline _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex<_Tp>
805 operator*(const _Tp& __x, const complex<_Tp>& __y) {
806   complex<_Tp> __t(__y);
807   __t *= __x;
808   return __t;
811 template <class _Tp, __enable_if_t<is_floating_point<_Tp>::value, int> >
812 _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex<_Tp>
813 operator/(const complex<_Tp>& __lhs, const complex<_Tp>& __rhs) {
814   return complex<_Tp>(__from_builtin_tag(), __lhs.__builtin() / __rhs.__builtin());
817 template <class _Tp, __enable_if_t<!is_floating_point<_Tp>::value, int> >
818 _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex<_Tp>
819 operator/(const complex<_Tp>& __z, const complex<_Tp>& __w) {
820   _Tp __a = __z.real();
821   _Tp __b = __z.imag();
822   _Tp __c = __w.real();
823   _Tp __d = __w.imag();
825   _Tp __denom = __c * __c + __d * __d;
826   return complex<_Tp>((__a * __c + __b * __d) / __denom, (__b * __c - __a * __d) / __denom);
829 template <class _Tp>
830 inline _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex<_Tp>
831 operator/(const complex<_Tp>& __x, const _Tp& __y) {
832   return complex<_Tp>(__x.real() / __y, __x.imag() / __y);
835 template <class _Tp>
836 inline _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex<_Tp>
837 operator/(const _Tp& __x, const complex<_Tp>& __y) {
838   complex<_Tp> __t(__x);
839   __t /= __y;
840   return __t;
843 template <class _Tp>
844 inline _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex<_Tp> operator+(const complex<_Tp>& __x) {
845   return __x;
848 template <class _Tp>
849 inline _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex<_Tp> operator-(const complex<_Tp>& __x) {
850   return complex<_Tp>(-__x.real(), -__x.imag());
853 template <class _Tp>
854 inline _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX14 bool
855 operator==(const complex<_Tp>& __x, const complex<_Tp>& __y) {
856   return __x.real() == __y.real() && __x.imag() == __y.imag();
859 template <class _Tp>
860 inline _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX14 bool operator==(const complex<_Tp>& __x, const _Tp& __y) {
861   return __x.real() == __y && __x.imag() == 0;
864 #if _LIBCPP_STD_VER <= 17
866 template <class _Tp>
867 inline _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX14 bool operator==(const _Tp& __x, const complex<_Tp>& __y) {
868   return __x == __y.real() && 0 == __y.imag();
871 template <class _Tp>
872 inline _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX14 bool
873 operator!=(const complex<_Tp>& __x, const complex<_Tp>& __y) {
874   return !(__x == __y);
877 template <class _Tp>
878 inline _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX14 bool operator!=(const complex<_Tp>& __x, const _Tp& __y) {
879   return !(__x == __y);
882 template <class _Tp>
883 inline _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX14 bool operator!=(const _Tp& __x, const complex<_Tp>& __y) {
884   return !(__x == __y);
887 #endif
889 // 26.3.7 values:
891 template <class _Tp, bool = is_integral<_Tp>::value, bool = is_floating_point<_Tp>::value >
892 struct __libcpp_complex_overload_traits {};
894 // Integral Types
895 template <class _Tp>
896 struct __libcpp_complex_overload_traits<_Tp, true, false> {
897   typedef double _ValueType;
898   typedef complex<double> _ComplexType;
901 // Floating point types
902 template <class _Tp>
903 struct __libcpp_complex_overload_traits<_Tp, false, true> {
904   typedef _Tp _ValueType;
905   typedef complex<_Tp> _ComplexType;
908 // real
910 template <class _Tp>
911 inline _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX14 _Tp real(const complex<_Tp>& __c) {
912   return __c.real();
915 template <class _Tp>
916 inline _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX14 typename __libcpp_complex_overload_traits<_Tp>::_ValueType
917 real(_Tp __re) {
918   return __re;
921 // imag
923 template <class _Tp>
924 inline _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX14 _Tp imag(const complex<_Tp>& __c) {
925   return __c.imag();
928 template <class _Tp>
929 inline _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX14 typename __libcpp_complex_overload_traits<_Tp>::_ValueType
930 imag(_Tp) {
931   return 0;
934 // abs
936 template <class _Tp>
937 inline _LIBCPP_HIDE_FROM_ABI _Tp abs(const complex<_Tp>& __c) {
938   return std::hypot(__c.real(), __c.imag());
941 // arg
943 template <class _Tp>
944 inline _LIBCPP_HIDE_FROM_ABI _Tp arg(const complex<_Tp>& __c) {
945   return std::atan2(__c.imag(), __c.real());
948 template <class _Tp, __enable_if_t<is_same<_Tp, long double>::value, int> = 0>
949 inline _LIBCPP_HIDE_FROM_ABI long double arg(_Tp __re) {
950   return std::atan2l(0.L, __re);
953 template <class _Tp, __enable_if_t<is_integral<_Tp>::value || is_same<_Tp, double>::value, int> = 0>
954 inline _LIBCPP_HIDE_FROM_ABI double arg(_Tp __re) {
955   return std::atan2(0., __re);
958 template <class _Tp, __enable_if_t<is_same<_Tp, float>::value, int> = 0>
959 inline _LIBCPP_HIDE_FROM_ABI float arg(_Tp __re) {
960   return std::atan2f(0.F, __re);
963 // norm
965 template <class _Tp>
966 inline _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 _Tp norm(const complex<_Tp>& __c) {
967   if (std::__constexpr_isinf(__c.real()))
968     return std::abs(__c.real());
969   if (std::__constexpr_isinf(__c.imag()))
970     return std::abs(__c.imag());
971   return __c.real() * __c.real() + __c.imag() * __c.imag();
974 template <class _Tp>
975 inline _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 typename __libcpp_complex_overload_traits<_Tp>::_ValueType
976 norm(_Tp __re) {
977   typedef typename __libcpp_complex_overload_traits<_Tp>::_ValueType _ValueType;
978   return static_cast<_ValueType>(__re) * __re;
981 // conj
983 template <class _Tp>
984 inline _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 complex<_Tp> conj(const complex<_Tp>& __c) {
985   return complex<_Tp>(__c.real(), -__c.imag());
988 template <class _Tp>
989 inline _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 typename __libcpp_complex_overload_traits<_Tp>::_ComplexType
990 conj(_Tp __re) {
991   typedef typename __libcpp_complex_overload_traits<_Tp>::_ComplexType _ComplexType;
992   return _ComplexType(__re);
995 // proj
997 template <class _Tp>
998 inline _LIBCPP_HIDE_FROM_ABI complex<_Tp> proj(const complex<_Tp>& __c) {
999   complex<_Tp> __r = __c;
1000   if (std::__constexpr_isinf(__c.real()) || std::__constexpr_isinf(__c.imag()))
1001     __r = complex<_Tp>(INFINITY, std::copysign(_Tp(0), __c.imag()));
1002   return __r;
1005 template <class _Tp, __enable_if_t<is_floating_point<_Tp>::value, int> = 0>
1006 inline _LIBCPP_HIDE_FROM_ABI typename __libcpp_complex_overload_traits<_Tp>::_ComplexType proj(_Tp __re) {
1007   if (std::__constexpr_isinf(__re))
1008     __re = std::abs(__re);
1009   return complex<_Tp>(__re);
1012 template <class _Tp, __enable_if_t<is_integral<_Tp>::value, int> = 0>
1013 inline _LIBCPP_HIDE_FROM_ABI typename __libcpp_complex_overload_traits<_Tp>::_ComplexType proj(_Tp __re) {
1014   typedef typename __libcpp_complex_overload_traits<_Tp>::_ComplexType _ComplexType;
1015   return _ComplexType(__re);
1018 // polar
1020 template <class _Tp>
1021 _LIBCPP_HIDE_FROM_ABI complex<_Tp> polar(const _Tp& __rho, const _Tp& __theta = _Tp()) {
1022   if (std::__constexpr_isnan(__rho) || std::signbit(__rho))
1023     return complex<_Tp>(_Tp(NAN), _Tp(NAN));
1024   if (std::__constexpr_isnan(__theta)) {
1025     if (std::__constexpr_isinf(__rho))
1026       return complex<_Tp>(__rho, __theta);
1027     return complex<_Tp>(__theta, __theta);
1028   }
1029   if (std::__constexpr_isinf(__theta)) {
1030     if (std::__constexpr_isinf(__rho))
1031       return complex<_Tp>(__rho, _Tp(NAN));
1032     return complex<_Tp>(_Tp(NAN), _Tp(NAN));
1033   }
1034   _Tp __x = __rho * std::cos(__theta);
1035   if (std::__constexpr_isnan(__x))
1036     __x = 0;
1037   _Tp __y = __rho * std::sin(__theta);
1038   if (std::__constexpr_isnan(__y))
1039     __y = 0;
1040   return complex<_Tp>(__x, __y);
1043 // log
1045 template <class _Tp>
1046 inline _LIBCPP_HIDE_FROM_ABI complex<_Tp> log(const complex<_Tp>& __x) {
1047   return complex<_Tp>(std::log(std::abs(__x)), std::arg(__x));
1050 // log10
1052 template <class _Tp>
1053 inline _LIBCPP_HIDE_FROM_ABI complex<_Tp> log10(const complex<_Tp>& __x) {
1054   return std::log(__x) / std::log(_Tp(10));
1057 // sqrt
1059 template <class _Tp>
1060 _LIBCPP_HIDE_FROM_ABI complex<_Tp> sqrt(const complex<_Tp>& __x) {
1061   if (std::__constexpr_isinf(__x.imag()))
1062     return complex<_Tp>(_Tp(INFINITY), __x.imag());
1063   if (std::__constexpr_isinf(__x.real())) {
1064     if (__x.real() > _Tp(0))
1065       return complex<_Tp>(
1066           __x.real(), std::__constexpr_isnan(__x.imag()) ? __x.imag() : std::copysign(_Tp(0), __x.imag()));
1067     return complex<_Tp>(
1068         std::__constexpr_isnan(__x.imag()) ? __x.imag() : _Tp(0), std::copysign(__x.real(), __x.imag()));
1069   }
1070   return std::polar(std::sqrt(std::abs(__x)), std::arg(__x) / _Tp(2));
1073 // exp
1075 template <class _Tp>
1076 _LIBCPP_HIDE_FROM_ABI complex<_Tp> exp(const complex<_Tp>& __x) {
1077   _Tp __i = __x.imag();
1078   if (__i == 0) {
1079     return complex<_Tp>(std::exp(__x.real()), std::copysign(_Tp(0), __x.imag()));
1080   }
1081   if (std::__constexpr_isinf(__x.real())) {
1082     if (__x.real() < _Tp(0)) {
1083       if (!std::__constexpr_isfinite(__i))
1084         __i = _Tp(1);
1085     } else if (__i == 0 || !std::__constexpr_isfinite(__i)) {
1086       if (std::__constexpr_isinf(__i))
1087         __i = _Tp(NAN);
1088       return complex<_Tp>(__x.real(), __i);
1089     }
1090   }
1091   _Tp __e = std::exp(__x.real());
1092   return complex<_Tp>(__e * std::cos(__i), __e * std::sin(__i));
1095 // pow
1097 template <class _Tp>
1098 inline _LIBCPP_HIDE_FROM_ABI complex<_Tp> pow(const complex<_Tp>& __x, const complex<_Tp>& __y) {
1099   return std::exp(__y * std::log(__x));
1102 template <class _Tp, class _Up>
1103 inline _LIBCPP_HIDE_FROM_ABI complex<typename __promote<_Tp, _Up>::type>
1104 pow(const complex<_Tp>& __x, const complex<_Up>& __y) {
1105   typedef complex<typename __promote<_Tp, _Up>::type> result_type;
1106   return std::pow(result_type(__x), result_type(__y));
1109 template <class _Tp, class _Up, __enable_if_t<is_arithmetic<_Up>::value, int> = 0>
1110 inline _LIBCPP_HIDE_FROM_ABI complex<typename __promote<_Tp, _Up>::type> pow(const complex<_Tp>& __x, const _Up& __y) {
1111   typedef complex<typename __promote<_Tp, _Up>::type> result_type;
1112   return std::pow(result_type(__x), result_type(__y));
1115 template <class _Tp, class _Up, __enable_if_t<is_arithmetic<_Tp>::value, int> = 0>
1116 inline _LIBCPP_HIDE_FROM_ABI complex<typename __promote<_Tp, _Up>::type> pow(const _Tp& __x, const complex<_Up>& __y) {
1117   typedef complex<typename __promote<_Tp, _Up>::type> result_type;
1118   return std::pow(result_type(__x), result_type(__y));
1121 // __sqr, computes pow(x, 2)
1123 template <class _Tp>
1124 inline _LIBCPP_HIDE_FROM_ABI complex<_Tp> __sqr(const complex<_Tp>& __x) {
1125   return complex<_Tp>((__x.real() - __x.imag()) * (__x.real() + __x.imag()), _Tp(2) * __x.real() * __x.imag());
1128 // asinh
1130 template <class _Tp>
1131 _LIBCPP_HIDE_FROM_ABI complex<_Tp> asinh(const complex<_Tp>& __x) {
1132   const _Tp __pi(atan2(+0., -0.));
1133   if (std::__constexpr_isinf(__x.real())) {
1134     if (std::__constexpr_isnan(__x.imag()))
1135       return __x;
1136     if (std::__constexpr_isinf(__x.imag()))
1137       return complex<_Tp>(__x.real(), std::copysign(__pi * _Tp(0.25), __x.imag()));
1138     return complex<_Tp>(__x.real(), std::copysign(_Tp(0), __x.imag()));
1139   }
1140   if (std::__constexpr_isnan(__x.real())) {
1141     if (std::__constexpr_isinf(__x.imag()))
1142       return complex<_Tp>(__x.imag(), __x.real());
1143     if (__x.imag() == 0)
1144       return __x;
1145     return complex<_Tp>(__x.real(), __x.real());
1146   }
1147   if (std::__constexpr_isinf(__x.imag()))
1148     return complex<_Tp>(std::copysign(__x.imag(), __x.real()), std::copysign(__pi / _Tp(2), __x.imag()));
1149   complex<_Tp> __z = std::log(__x + std::sqrt(std::__sqr(__x) + _Tp(1)));
1150   return complex<_Tp>(std::copysign(__z.real(), __x.real()), std::copysign(__z.imag(), __x.imag()));
1153 // acosh
1155 template <class _Tp>
1156 _LIBCPP_HIDE_FROM_ABI complex<_Tp> acosh(const complex<_Tp>& __x) {
1157   const _Tp __pi(atan2(+0., -0.));
1158   if (std::__constexpr_isinf(__x.real())) {
1159     if (std::__constexpr_isnan(__x.imag()))
1160       return complex<_Tp>(std::abs(__x.real()), __x.imag());
1161     if (std::__constexpr_isinf(__x.imag())) {
1162       if (__x.real() > 0)
1163         return complex<_Tp>(__x.real(), std::copysign(__pi * _Tp(0.25), __x.imag()));
1164       else
1165         return complex<_Tp>(-__x.real(), std::copysign(__pi * _Tp(0.75), __x.imag()));
1166     }
1167     if (__x.real() < 0)
1168       return complex<_Tp>(-__x.real(), std::copysign(__pi, __x.imag()));
1169     return complex<_Tp>(__x.real(), std::copysign(_Tp(0), __x.imag()));
1170   }
1171   if (std::__constexpr_isnan(__x.real())) {
1172     if (std::__constexpr_isinf(__x.imag()))
1173       return complex<_Tp>(std::abs(__x.imag()), __x.real());
1174     return complex<_Tp>(__x.real(), __x.real());
1175   }
1176   if (std::__constexpr_isinf(__x.imag()))
1177     return complex<_Tp>(std::abs(__x.imag()), std::copysign(__pi / _Tp(2), __x.imag()));
1178   complex<_Tp> __z = std::log(__x + std::sqrt(std::__sqr(__x) - _Tp(1)));
1179   return complex<_Tp>(std::copysign(__z.real(), _Tp(0)), std::copysign(__z.imag(), __x.imag()));
1182 // atanh
1184 template <class _Tp>
1185 _LIBCPP_HIDE_FROM_ABI complex<_Tp> atanh(const complex<_Tp>& __x) {
1186   const _Tp __pi(atan2(+0., -0.));
1187   if (std::__constexpr_isinf(__x.imag())) {
1188     return complex<_Tp>(std::copysign(_Tp(0), __x.real()), std::copysign(__pi / _Tp(2), __x.imag()));
1189   }
1190   if (std::__constexpr_isnan(__x.imag())) {
1191     if (std::__constexpr_isinf(__x.real()) || __x.real() == 0)
1192       return complex<_Tp>(std::copysign(_Tp(0), __x.real()), __x.imag());
1193     return complex<_Tp>(__x.imag(), __x.imag());
1194   }
1195   if (std::__constexpr_isnan(__x.real())) {
1196     return complex<_Tp>(__x.real(), __x.real());
1197   }
1198   if (std::__constexpr_isinf(__x.real())) {
1199     return complex<_Tp>(std::copysign(_Tp(0), __x.real()), std::copysign(__pi / _Tp(2), __x.imag()));
1200   }
1201   if (std::abs(__x.real()) == _Tp(1) && __x.imag() == _Tp(0)) {
1202     return complex<_Tp>(std::copysign(_Tp(INFINITY), __x.real()), std::copysign(_Tp(0), __x.imag()));
1203   }
1204   complex<_Tp> __z = std::log((_Tp(1) + __x) / (_Tp(1) - __x)) / _Tp(2);
1205   return complex<_Tp>(std::copysign(__z.real(), __x.real()), std::copysign(__z.imag(), __x.imag()));
1208 // sinh
1210 template <class _Tp>
1211 _LIBCPP_HIDE_FROM_ABI complex<_Tp> sinh(const complex<_Tp>& __x) {
1212   if (std::__constexpr_isinf(__x.real()) && !std::__constexpr_isfinite(__x.imag()))
1213     return complex<_Tp>(__x.real(), _Tp(NAN));
1214   if (__x.real() == 0 && !std::__constexpr_isfinite(__x.imag()))
1215     return complex<_Tp>(__x.real(), _Tp(NAN));
1216   if (__x.imag() == 0 && !std::__constexpr_isfinite(__x.real()))
1217     return __x;
1218   return complex<_Tp>(std::sinh(__x.real()) * std::cos(__x.imag()), std::cosh(__x.real()) * std::sin(__x.imag()));
1221 // cosh
1223 template <class _Tp>
1224 _LIBCPP_HIDE_FROM_ABI complex<_Tp> cosh(const complex<_Tp>& __x) {
1225   if (std::__constexpr_isinf(__x.real()) && !std::__constexpr_isfinite(__x.imag()))
1226     return complex<_Tp>(std::abs(__x.real()), _Tp(NAN));
1227   if (__x.real() == 0 && !std::__constexpr_isfinite(__x.imag()))
1228     return complex<_Tp>(_Tp(NAN), __x.real());
1229   if (__x.real() == 0 && __x.imag() == 0)
1230     return complex<_Tp>(_Tp(1), __x.imag());
1231   if (__x.imag() == 0 && !std::__constexpr_isfinite(__x.real()))
1232     return complex<_Tp>(std::abs(__x.real()), __x.imag());
1233   return complex<_Tp>(std::cosh(__x.real()) * std::cos(__x.imag()), std::sinh(__x.real()) * std::sin(__x.imag()));
1236 // tanh
1238 template <class _Tp>
1239 _LIBCPP_HIDE_FROM_ABI complex<_Tp> tanh(const complex<_Tp>& __x) {
1240   if (std::__constexpr_isinf(__x.real())) {
1241     if (!std::__constexpr_isfinite(__x.imag()))
1242       return complex<_Tp>(std::copysign(_Tp(1), __x.real()), _Tp(0));
1243     return complex<_Tp>(std::copysign(_Tp(1), __x.real()), std::copysign(_Tp(0), std::sin(_Tp(2) * __x.imag())));
1244   }
1245   if (std::__constexpr_isnan(__x.real()) && __x.imag() == 0)
1246     return __x;
1247   _Tp __2r(_Tp(2) * __x.real());
1248   _Tp __2i(_Tp(2) * __x.imag());
1249   _Tp __d(std::cosh(__2r) + std::cos(__2i));
1250   _Tp __2rsh(std::sinh(__2r));
1251   if (std::__constexpr_isinf(__2rsh) && std::__constexpr_isinf(__d))
1252     return complex<_Tp>(__2rsh > _Tp(0) ? _Tp(1) : _Tp(-1), __2i > _Tp(0) ? _Tp(0) : _Tp(-0.));
1253   return complex<_Tp>(__2rsh / __d, std::sin(__2i) / __d);
1256 // asin
1258 template <class _Tp>
1259 _LIBCPP_HIDE_FROM_ABI complex<_Tp> asin(const complex<_Tp>& __x) {
1260   complex<_Tp> __z = std::asinh(complex<_Tp>(-__x.imag(), __x.real()));
1261   return complex<_Tp>(__z.imag(), -__z.real());
1264 // acos
1266 template <class _Tp>
1267 _LIBCPP_HIDE_FROM_ABI complex<_Tp> acos(const complex<_Tp>& __x) {
1268   const _Tp __pi(atan2(+0., -0.));
1269   if (std::__constexpr_isinf(__x.real())) {
1270     if (std::__constexpr_isnan(__x.imag()))
1271       return complex<_Tp>(__x.imag(), __x.real());
1272     if (std::__constexpr_isinf(__x.imag())) {
1273       if (__x.real() < _Tp(0))
1274         return complex<_Tp>(_Tp(0.75) * __pi, -__x.imag());
1275       return complex<_Tp>(_Tp(0.25) * __pi, -__x.imag());
1276     }
1277     if (__x.real() < _Tp(0))
1278       return complex<_Tp>(__pi, std::signbit(__x.imag()) ? -__x.real() : __x.real());
1279     return complex<_Tp>(_Tp(0), std::signbit(__x.imag()) ? __x.real() : -__x.real());
1280   }
1281   if (std::__constexpr_isnan(__x.real())) {
1282     if (std::__constexpr_isinf(__x.imag()))
1283       return complex<_Tp>(__x.real(), -__x.imag());
1284     return complex<_Tp>(__x.real(), __x.real());
1285   }
1286   if (std::__constexpr_isinf(__x.imag()))
1287     return complex<_Tp>(__pi / _Tp(2), -__x.imag());
1288   if (__x.real() == 0 && (__x.imag() == 0 || std::isnan(__x.imag())))
1289     return complex<_Tp>(__pi / _Tp(2), -__x.imag());
1290   complex<_Tp> __z = std::log(__x + std::sqrt(std::__sqr(__x) - _Tp(1)));
1291   if (std::signbit(__x.imag()))
1292     return complex<_Tp>(std::abs(__z.imag()), std::abs(__z.real()));
1293   return complex<_Tp>(std::abs(__z.imag()), -std::abs(__z.real()));
1296 // atan
1298 template <class _Tp>
1299 _LIBCPP_HIDE_FROM_ABI complex<_Tp> atan(const complex<_Tp>& __x) {
1300   complex<_Tp> __z = std::atanh(complex<_Tp>(-__x.imag(), __x.real()));
1301   return complex<_Tp>(__z.imag(), -__z.real());
1304 // sin
1306 template <class _Tp>
1307 _LIBCPP_HIDE_FROM_ABI complex<_Tp> sin(const complex<_Tp>& __x) {
1308   complex<_Tp> __z = std::sinh(complex<_Tp>(-__x.imag(), __x.real()));
1309   return complex<_Tp>(__z.imag(), -__z.real());
1312 // cos
1314 template <class _Tp>
1315 inline _LIBCPP_HIDE_FROM_ABI complex<_Tp> cos(const complex<_Tp>& __x) {
1316   return std::cosh(complex<_Tp>(-__x.imag(), __x.real()));
1319 // tan
1321 template <class _Tp>
1322 _LIBCPP_HIDE_FROM_ABI complex<_Tp> tan(const complex<_Tp>& __x) {
1323   complex<_Tp> __z = std::tanh(complex<_Tp>(-__x.imag(), __x.real()));
1324   return complex<_Tp>(__z.imag(), -__z.real());
1327 #if !defined(_LIBCPP_HAS_NO_LOCALIZATION)
1328 template <class _Tp, class _CharT, class _Traits>
1329 _LIBCPP_HIDE_FROM_ABI basic_istream<_CharT, _Traits>&
1330 operator>>(basic_istream<_CharT, _Traits>& __is, complex<_Tp>& __x) {
1331   if (__is.good()) {
1332     std::ws(__is);
1333     if (__is.peek() == _CharT('(')) {
1334       __is.get();
1335       _Tp __r;
1336       __is >> __r;
1337       if (!__is.fail()) {
1338         std::ws(__is);
1339         _CharT __c = __is.peek();
1340         if (__c == _CharT(',')) {
1341           __is.get();
1342           _Tp __i;
1343           __is >> __i;
1344           if (!__is.fail()) {
1345             std::ws(__is);
1346             __c = __is.peek();
1347             if (__c == _CharT(')')) {
1348               __is.get();
1349               __x = complex<_Tp>(__r, __i);
1350             } else
1351               __is.setstate(__is.failbit);
1352           } else
1353             __is.setstate(__is.failbit);
1354         } else if (__c == _CharT(')')) {
1355           __is.get();
1356           __x = complex<_Tp>(__r, _Tp(0));
1357         } else
1358           __is.setstate(__is.failbit);
1359       } else
1360         __is.setstate(__is.failbit);
1361     } else {
1362       _Tp __r;
1363       __is >> __r;
1364       if (!__is.fail())
1365         __x = complex<_Tp>(__r, _Tp(0));
1366       else
1367         __is.setstate(__is.failbit);
1368     }
1369   } else
1370     __is.setstate(__is.failbit);
1371   return __is;
1374 template <class _Tp, class _CharT, class _Traits>
1375 _LIBCPP_HIDE_FROM_ABI basic_ostream<_CharT, _Traits>&
1376 operator<<(basic_ostream<_CharT, _Traits>& __os, const complex<_Tp>& __x) {
1377   basic_ostringstream<_CharT, _Traits> __s;
1378   __s.flags(__os.flags());
1379   __s.imbue(__os.getloc());
1380   __s.precision(__os.precision());
1381   __s << '(' << __x.real() << ',' << __x.imag() << ')';
1382   return __os << __s.str();
1384 #endif // !_LIBCPP_HAS_NO_LOCALIZATION
1386 #if _LIBCPP_STD_VER >= 26
1388 // [complex.tuple], tuple interface
1390 template <class _Tp>
1391 struct tuple_size<complex<_Tp>> : integral_constant<size_t, 2> {};
1393 template <size_t _Ip, class _Tp>
1394 struct tuple_element<_Ip, complex<_Tp>> {
1395   static_assert(_Ip < 2, "Index value is out of range.");
1396   using type = _Tp;
1399 template <size_t _Ip, class _Xp>
1400 _LIBCPP_HIDE_FROM_ABI constexpr _Xp& get(complex<_Xp>& __z) noexcept {
1401   static_assert(_Ip < 2, "Index value is out of range.");
1402   if constexpr (_Ip == 0) {
1403     return __z.__re_;
1404   } else {
1405     return __z.__im_;
1406   }
1409 template <size_t _Ip, class _Xp>
1410 _LIBCPP_HIDE_FROM_ABI constexpr _Xp&& get(complex<_Xp>&& __z) noexcept {
1411   static_assert(_Ip < 2, "Index value is out of range.");
1412   if constexpr (_Ip == 0) {
1413     return std::move(__z.__re_);
1414   } else {
1415     return std::move(__z.__im_);
1416   }
1419 template <size_t _Ip, class _Xp>
1420 _LIBCPP_HIDE_FROM_ABI constexpr const _Xp& get(const complex<_Xp>& __z) noexcept {
1421   static_assert(_Ip < 2, "Index value is out of range.");
1422   if constexpr (_Ip == 0) {
1423     return __z.__re_;
1424   } else {
1425     return __z.__im_;
1426   }
1429 template <size_t _Ip, class _Xp>
1430 _LIBCPP_HIDE_FROM_ABI constexpr const _Xp&& get(const complex<_Xp>&& __z) noexcept {
1431   static_assert(_Ip < 2, "Index value is out of range.");
1432   if constexpr (_Ip == 0) {
1433     return std::move(__z.__re_);
1434   } else {
1435     return std::move(__z.__im_);
1436   }
1439 #endif // _LIBCPP_STD_VER >= 26
1441 #if _LIBCPP_STD_VER >= 14
1442 // Literal suffix for complex number literals [complex.literals]
1443 inline namespace literals {
1444 inline namespace complex_literals {
1445 _LIBCPP_HIDE_FROM_ABI inline constexpr complex<long double> operator""il(long double __im) { return {0.0l, __im}; }
1447 _LIBCPP_HIDE_FROM_ABI inline constexpr complex<long double> operator""il(unsigned long long __im) {
1448   return {0.0l, static_cast<long double>(__im)};
1451 _LIBCPP_HIDE_FROM_ABI inline constexpr complex<double> operator""i(long double __im) {
1452   return {0.0, static_cast<double>(__im)};
1455 _LIBCPP_HIDE_FROM_ABI inline constexpr complex<double> operator""i(unsigned long long __im) {
1456   return {0.0, static_cast<double>(__im)};
1459 _LIBCPP_HIDE_FROM_ABI inline constexpr complex<float> operator""if(long double __im) {
1460   return {0.0f, static_cast<float>(__im)};
1463 _LIBCPP_HIDE_FROM_ABI inline constexpr complex<float> operator""if(unsigned long long __im) {
1464   return {0.0f, static_cast<float>(__im)};
1466 } // namespace complex_literals
1467 } // namespace literals
1468 #endif
1470 _LIBCPP_END_NAMESPACE_STD
1472 _LIBCPP_POP_MACROS
1474 #if !defined(_LIBCPP_REMOVE_TRANSITIVE_INCLUDES) && _LIBCPP_STD_VER <= 20
1475 #  include <__cxx03/iosfwd>
1476 #  include <__cxx03/stdexcept>
1477 #  include <__cxx03/type_traits>
1478 #endif
1480 #endif // _LIBCPP___CXX03_COMPLEX