numpy.empty_like#

numpy.empty_like(prototype, dtype=None, order='K', subok=True, shape=None, *, device=None)#

返回一个与给定数组具有相同形状和类型的新数组.

参数:
prototypearray_like

prototype 的形状和数据类型定义了返回数组的相同属性.

dtypedata-type,可选

覆盖结果的数据类型.

order{‘C’, ‘F’, ‘A’, or ‘K’}, optional

覆盖结果的内存布局. ‘C’ 表示 C 顺序,’F’ 表示 F 顺序,如果 prototype 是 Fortran 连续的,则 ‘A’ 表示 ‘F’,否则表示 ‘C’. ‘K’ 表示尽可能匹配 prototype 的布局.

subokbool, optional.

如果为 True,则新创建的数组将使用 prototype 的子类类型,否则它将是一个基类数组.默认为 True.

shapeint or sequence of ints, optional.

覆盖结果的形状.如果 order=’K’ 并且维度数量未更改,将尝试保持顺序,否则,将暗示 order=’C’.

devicestr, optional

在其上放置创建的数组的设备.默认值:None.仅用于 Array-API 互操作性,因此如果传递则必须为 "cpu" .

在 2.0.0 版本加入.

返回:
outndarray

具有与 prototype 相同形状和类型的未初始化(任意)数据的数组.

参见

ones_like

返回一个具有输入形状和类型的 1 数组.

zeros_like

返回一个具有输入形状和类型的 0 数组.

full_like

返回一个用值填充的具有输入形状的新数组.

empty

返回一个新的未初始化数组.

注释

与其他数组创建函数(例如 zeros_like , ones_like , full_like )不同, empty_like 不初始化数组的值,因此可能会稍微快一些.但是,存储在新分配的数组中的值是任意的.为了获得可重现的行为,请务必在读取之前设置数组的每个元素.

示例

>>> import numpy as np
>>> a = ([1,2,3], [4,5,6])                         # a is array-like
>>> np.empty_like(a)
array([[-1073741821, -1073741821,           3],    # uninitialized
       [          0,           0, -1073741821]])
>>> a = np.array([[1., 2., 3.],[4.,5.,6.]])
>>> np.empty_like(a)
array([[ -2.00000715e+000,   1.48219694e-323,  -2.00000572e+000], # uninitialized
       [  4.38791518e-305,  -2.00000715e+000,   4.17269252e-309]])