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

📄 math.h

📁 C8051F300 & Si57x ANSI C Reference Design
💻 H
字号:
/*  math.h: Floating point math function declarations    Copyright (C) 2001  Jesus Calvino-Fraga, jesusc@ieee.org    This library is free software; you can redistribute it and/or    modify it under the terms of the GNU Lesser General Public    License as published by the Free Software Foundation; either    version 2.1 of the License, or (at your option) any later version.    This library 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    Lesser General Public License for more details.    You should have received a copy of the GNU Lesser General Public    License along with this library; if not, write to the Free Software    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA *//* Version 1.0 - Initial release */#ifndef _INC_MATH#define _INC_MATH#define HUGE_VALF   3.402823466e+38#define PI          3.1415926536#define TWO_PI      6.2831853071#define HALF_PI     1.5707963268#define QUART_PI    0.7853981634#define iPI         0.3183098862#define iTWO_PI     0.1591549431#define TWO_O_PI    0.6366197724// EPS=B**(-t/2), where B is the radix of the floating-point representation// and there are t base-B digits in the significand.  Therefore, for floats// EPS=2**(-12).  Also define EPS2=EPS*EPS.#define EPS 244.14062E-6#define EPS2 59.6046E-9union float_long{    float f;    long l;};#if defined(SDCC_MATH_LIB) && defined(SDCC_mcs51) && !defined(SDCC_USE_XSTACK) && !defined(SDCC_STACK_AUTO) && !defined(_SDCC_NO_ASM_LIB_FUNCS)// Compile the mcs51 assembly version only when all these// conditions are met.  Since not all the functions are// reentrant, do not compile with --stack-auto is used.#define MATH_ASM_MCS51#endif/* Functions on the z80 & gbz80 are always reentrant and so the "reentrant" *//* keyword is not defined. */#if defined(SDCC_z80) || defined(SDCC_gbz80)#define _FLOAT_FUNC_REENTRANT#else#define _FLOAT_FUNC_REENTRANT __reentrant#endif/********************************************** * Prototypes for float ANSI C math functions * **********************************************//* Trigonometric functions */float sinf(const float x) _FLOAT_FUNC_REENTRANT;float cosf(const float x) _FLOAT_FUNC_REENTRANT;float tanf(const float x) _FLOAT_FUNC_REENTRANT;float cotf(const float x) _FLOAT_FUNC_REENTRANT;float asinf(const float x) _FLOAT_FUNC_REENTRANT;float acosf(const float x) _FLOAT_FUNC_REENTRANT;float atanf(const float x) _FLOAT_FUNC_REENTRANT;float atan2f(const float x, const float y);/* Hyperbolic functions */float sinhf(const float x) _FLOAT_FUNC_REENTRANT;float coshf(const float x) _FLOAT_FUNC_REENTRANT;float tanhf(const float x) _FLOAT_FUNC_REENTRANT;/* Exponential, logarithmic and power functions */float expf(const float x);float logf(const float x) _FLOAT_FUNC_REENTRANT;float log10f(const float x) _FLOAT_FUNC_REENTRANT;float powf(const float x, const float y);float sqrtf(const float a) _FLOAT_FUNC_REENTRANT;/* Nearest integer, absolute value, and remainder functions */float fabsf(const float x) _FLOAT_FUNC_REENTRANT;float frexpf(const float x, int *pw2);float ldexpf(const float x, const int pw2);float ceilf(float x) _FLOAT_FUNC_REENTRANT;float floorf(float x) _FLOAT_FUNC_REENTRANT;float modff(float x, float * y);#endif  /* _INC_MATH */

⌨️ 快捷键说明

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