/* GCC Quad-Precision Math Library Copyright (C) 2010, 2011 Free Software Foundation, Inc. Written by Francois-Xavier Coudert 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 #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); }