数值库
出自 cppreference.cn
< cpp
C++ 数值库包含常用数学函数和类型,以及优化的数值数组和随机数生成支持。
目录 |
[编辑] 数学函数和类型
[编辑] 常用数学函数
头文件 <cmath> 提供了 标准 C 库数学函数,例如 std::fabs、 std::sqrt 和 std::sin。
[编辑] 数学特殊函数 (自 C++17 起)
头文件 <cmath> 也提供了几个数学特殊函数,例如 std::beta、 std::hermite 和 std::cyl_bessel_i。
[编辑] 数学常数 (自 C++20 起)
头文件 <numbers> 提供了几个数学常数,例如 std::numbers::pi 或 std::numbers::sqrt2
[编辑] 基本线性代数算法 (自 C++26 起)
头文件 <linalg> 提供了基于 BLAS 的基本线性代数算法。
[编辑] 数据并行类型 (自 C++26 起)
头文件 <simd> 提供了可移植的类型,用于显式声明数据并行性并构建数据以实现更高效的 SIMD 访问。
[编辑] 复数算术
定义于头文件
<complex> | |
复数类型 (类模板) |
[编辑] 数值数组
定义于头文件
<valarray> | |
数值数组、数组掩码和数组切片 (类模板) |
[编辑] 数值算法
头文件 <numeric> 提供了以下数值算法
[编辑] 因子运算 (自 C++17 起)
定义于头文件
<numeric> | |
(C++17) |
计算两个整数的最大公约数 (函数模板) |
(C++17) |
计算两个整数的最小公倍数 (函数模板) |
[编辑] 插值运算 (C++20)
定义于头文件
<numeric> | |
(C++20) |
两个数字或指针之间的中点 (函数模板) |
定义于头文件
<cmath> | |
(C++20) |
线性插值函数 (函数) |
[编辑] 饱和算术 (自 C++26 起)
定义于头文件
<numeric> | |
(C++26) |
对两个整数执行饱和加法运算 (函数模板) |
(C++26) |
对两个整数执行饱和减法运算 (函数模板) |
(C++26) |
对两个整数执行饱和乘法运算 (函数模板) |
(C++26) |
对两个整数执行饱和除法运算 (函数模板) |
(C++26) |
返回一个整数值,该值被钳制到另一个整数类型的范围内 (函数模板) |
[编辑] 数值运算
定义于头文件
<numeric> | |
(C++11) |
用起始值的连续增量填充一个范围 (函数模板) |
(C++23) |
用起始值的连续增量填充一个范围 (算法函数对象) |
对元素范围求和或折叠 (函数模板) | |
(C++17) |
类似于 std::accumulate,但无序 (函数模板) |
(C++17) |
应用一个可调用对象,然后无序地归约 (函数模板) |
计算两个元素范围的内积 (函数模板) | |
计算范围内相邻元素之间的差值 (函数模板) | |
计算元素范围的部分和 (函数模板) | |
(C++17) |
类似于 std::partial_sum,在第 ith 个和中包含第 ith 个输入元素 (函数模板) |
(C++17) |
类似于 std::partial_sum,从第 ith 个和中排除第 ith 个输入元素 (函数模板) |
(C++17) |
应用一个可调用对象,然后计算包含扫描 (函数模板) |
(C++17) |
应用一个可调用对象,然后计算排除扫描 (函数模板) |
[编辑] 杂项
[编辑] 伪随机数生成
头文件 <random> 定义了 伪随机数生成器和数值分布。头文件 <cstdlib> 也通过 std::srand 和 std::rand 包含了 C 风格的随机数生成。
[编辑] 浮点环境 (自 C++11 起)
头文件 <cfenv> 定义了与异常浮点状态相关的 标志和函数,例如溢出和除以零。
[编辑] 位操作 (自 C++20 起)
头文件 <bit> 提供了几个函数模板,用于访问、操作和处理单个位和位序列。标量类型的字节顺序 (字节序) 可以通过 std::endian 工具进行检查。
[编辑] 参见
C 文档 关于 数值
|