numpy.ldexp#
- numpy.ldexp(x1, x2, /, out=None, *, where=True, casting='same_kind', order='K', dtype=None, subok=True[, signature]) = <ufunc 'ldexp'>#
返回 x1 * 2x2,逐个元素.
尾数 x1 和二的指数 x2 用于构造浮点数
x1 * 2x2.- 参数:
- x1array_like
乘数数组.
- x2类数组,int
二的指数数组.如果
x1.shape != x2.shape,则它们必须可广播到公共形状(这将成为输出的形状).- outndarray, None, or tuple of ndarray and None, optional
结果存储到的位置.如果提供,它必须具有输入的广播到的形状. 如果未提供或为 None,则返回一个新分配的数组.一个元组(可能只能作为关键字参数)必须具有等于输出数量的长度.
- wherearray_like, optional
此条件在输入上进行广播.在条件为 True 的位置, out 数组将设置为 ufunc 结果.否则, out 数组将保留其原始值.请注意,如果通过默认值
out=None创建一个未初始化的 out 数组,则其中条件为 False 的位置将保持未初始化.- \kwargs
对于其他仅限关键字的参数,请参阅 ufunc docs .
- 返回:
- yndarray 或标量
x1 * 2x2的结果.如果 x1 和 x2 都是标量,则这是一个标量.
注释
不支持复数 dtypes,它们将引发 TypeError.
ldexp可以作为frexp的逆运算使用,如果单独使用,则更清楚地使用表达式x1 * 2x2.示例
>>> import numpy as np >>> np.ldexp(5, np.arange(4)) array([ 5., 10., 20., 40.], dtype=float16)
>>> x = np.arange(6) >>> np.ldexp(*np.frexp(x)) array([ 0., 1., 2., 3., 4., 5.])