⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 atan2.c

📁 一个C源代码分析器
💻 C
字号:
/* Copyright (C) 1991, 1992, 1994 Free Software Foundation, Inc.This file is part of the GNU C Library.The GNU C Library is free software; you can redistribute it and/ormodify it under the terms of the GNU Library General Public License aspublished by the Free Software Foundation; either version 2 of theLicense, or (at your option) any later version.The GNU C Library is distributed in the hope that it will be useful,but WITHOUT ANY WARRANTY; without even the implied warranty ofMERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNULibrary General Public License for more details.You should have received a copy of the GNU Library General PublicLicense along with the GNU C Library; see the file COPYING.LIB.  Ifnot, write to the Free Software Foundation, Inc., 675 Mass Ave,Cambridge, MA 02139, USA.  */#include <ansidecl.h>#include <math.h>#ifdef	__GNUC____CONSTVALUE doubleDEFUN(atan2, (y, x), double y AND double x){  static CONST double one = 1.0, zero = 0.0;  double signx, signy;  double pi, PIo4, PIo2;  if (__isnan(x))    return x;  if (__isnan(y))    return y;  signy = __copysign(one, y);  signx = __copysign(one, x);  asm("fmovecr%.x %1, %0" : "=f" (pi) : "i" (0));  PIo2 = pi / 2;  PIo4 = pi / 4;  if (y == zero)    return signx == one ? y : __copysign(pi, signy);  if (x == zero)    return __copysign(PIo2, signy);  if (__isinf(x))    {      if (__isinf(y))	return __copysign(signx == one ? PIo4 : 3 * PIo4, signy);      else	return __copysign(signx == one ? zero : pi, signy);    }  if (__isinf(y))    return __copysign(PIo2, signy);  y = fabs(y);  if (x < 0.0)    /* X is negative.  */    return __copysign(pi - atan(y / -x), signy);  return __copysign(atan(y / x), signy);}#else#include <sysdeps/generic/atan2.c>#endif

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -