| /* GCC Quad-Precision Math Library | 
 |    Copyright (C) 2010, 2011 Free Software Foundation, Inc. | 
 |    Written by Francois-Xavier Coudert  <fxcoudert@gcc.gnu.org> | 
 |  | 
 | This file is part of the libquadmath library. | 
 | Libquadmath is free software; you can redistribute it and/or | 
 | modify it under the terms of the GNU Library General Public | 
 | License as published by the Free Software Foundation; either | 
 | version 2 of the License, or (at your option) any later version. | 
 |  | 
 | Libquadmath is distributed in the hope that it will be useful, | 
 | but WITHOUT ANY WARRANTY; without even the implied warranty of | 
 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU | 
 | Library General Public License for more details. | 
 |  | 
 | You should have received a copy of the GNU Library General Public | 
 | License along with libquadmath; see the file COPYING.LIB.  If | 
 | not, write to the Free Software Foundation, Inc., 51 Franklin Street - Fifth Floor, | 
 | Boston, MA 02110-1301, USA.  */ | 
 |  | 
 | #include "quadmath-imp.h" | 
 |  | 
 | #ifdef HAVE_FENV_H | 
 | # include <fenv.h> | 
 | #endif | 
 |  | 
 |  | 
 | #define REALPART(z) (__real__(z))  | 
 | #define IMAGPART(z) (__imag__(z))  | 
 | #define COMPLEX_ASSIGN(z_, r_, i_) {__real__(z_) = (r_); __imag__(z_) = (i_);}  | 
 |  | 
 |  | 
 | __float128 | 
 | cabsq (__complex128 z) | 
 | { | 
 |   return hypotq (REALPART (z), IMAGPART (z)); | 
 | } | 
 |  | 
 |  | 
 | __complex128 | 
 | cexpiq (__float128 x) | 
 | { | 
 |   __float128 sinix, cosix; | 
 |   __complex128 v; | 
 |   sincosq (x, &sinix, &cosix); | 
 |   COMPLEX_ASSIGN (v, cosix, sinix); | 
 |   return v; | 
 | } | 
 |  | 
 |  | 
 | __float128 | 
 | cargq (__complex128 z) | 
 | { | 
 |   return atan2q (IMAGPART (z), REALPART (z)); | 
 | } | 
 |  | 
 |  | 
 | __complex128 | 
 | cpowq (__complex128 base, __complex128 power) | 
 | { | 
 |   return cexpq (power * clogq (base)); | 
 | } | 
 |  | 
 |  | 
 | __complex128 | 
 | ccosq (__complex128 x) | 
 | { | 
 |   __complex128 y; | 
 |  | 
 |   COMPLEX_ASSIGN (y, -IMAGPART (x), REALPART (x)); | 
 |   return ccoshq (y); | 
 | } |