You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

mindspore.Tensor.txt 34 kB

4 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917
  1. argmax(axis=None)
  2. 返回指定轴上最大值的索引。
  3. 参数:
  4. axis (int, optional):默认情况下,返回扁平化Tensor的最大值序号,否则返回指定轴方向上。
  5. 返回:
  6. Tensor,最大值的索引。它具有与此Tensor相同的shape,但移除了轴方向上的维度。
  7. 异常:
  8. ValueError:轴超出了范围。
  9. 支持平台:
  10. ``Ascend`` ``GPU`` ``CPU``
  11. 样例:
  12. >>> import numpy as np
  13. >>> from mindspore import Tensor
  14. >>> a = Tensor(np.arange(10, 16).reshape(2, 3).astype("float32"))
  15. >>> print(a.argmax())
  16. 5
  17. argmin(axis=None)
  18. 返回指定轴上最小值的索引。
  19. 参数:
  20. axis (int, optional):返回扁平化Tensor的最小值序号,否则返回指定轴方向上的最小值序号。默认值: None。
  21. 返回:
  22. Tensor,最小Tensor的索引。它与Tensor的shape相同,但移除了轴方向上的维度。
  23. 异常:
  24. ValueError:轴超出了范围。
  25. 支持平台:
  26. ``Ascend`` ``GPU`` ``CPU``
  27. 样例:
  28. >>> import numpy as np
  29. >>> from mindspore import Tensor
  30. >>> a = Tensor(np.arange(10, 16).reshape(2, 3).astype("float32"))
  31. >>> print(a.argmin())
  32. 0
  33. astype(dtype, copy=True)
  34. 返回Tensor的副本,并将其转换为指定类型。
  35. 参数:
  36. dtype (Union[`mindspore.dtype`, str]):指定的Tensor数据类型,可以是:`mindspore.dtype.float32`或`float32`的格式。
  37. 默认值::`mindspore.dtype.float32`。
  38. copy (bool, optional):默认情况下,astype返回新拷贝的Tensor。如果该参数设为false,则返回输入Tensor而不是副本。默认值:True。
  39. 返回:
  40. Tensor,指定数据类型的Tensor。
  41. 异常:
  42. TypeError:指定了无法解析的类型。
  43. 支持平台:
  44. ``Ascend`` ``GPU`` ``CPU``
  45. 样例:
  46. >>> import numpy as np
  47. >>> from mindspore import Tensor
  48. >>> x = Tensor(np.ones((1,2,2,1), dtype=np.float32))
  49. >>> x = x.astype("int32")
  50. >>> print(x.dtype)
  51. Int32
  52. choose(choices, mode='clip')
  53. 通过索引数组和Tensor数组中构造一个Tensor。
  54. 参数:
  55. choices (Union[tuple, list, Tensor]):选择数组。输入的索引数组和`choose`广播维度必须相同。如果`choices`本身是一个数组,则其最外层的维度(即,对应于`choices.shape[0]`的维度)被用来定义长度。
  56. mode ('raise', 'wrap', 'clip', optional):指定如何处理`[0, n-1]`外部的索引:
  57. 'raise' – 引发异常(默认);
  58. 'wrap' – 绕接;
  59. 'clip' – 裁剪到范围。'clip'模式意味着所有过大的索引都将替换为在轴方向上寻址最后一个元素的索引。注:这将禁用具有负数的索引。
  60. 返回:
  61. Tensor,合并后的结果。
  62. 支持平台:
  63. ``Ascend`` ``GPU`` ``CPU``
  64. 异常:
  65. ValueError:输入Tensor和任一`choices`无法广播。
  66. 样例:
  67. >>> import numpy as np
  68. >>> from mindspore import Tensor
  69. >>> choices = [[0, 1, 2, 3], [10, 11, 12, 13], [20, 21, 22, 23], [30, 31, 32, 33]]
  70. >>> x = Tensor(np.array([2, 3, 1, 0]))
  71. >>> print(x.choose(choices))
  72. [20 31 12 3]
  73. clip(xmin, xmax, dtype=None)
  74. 裁剪Tensor中的值。
  75. 给定一个区间,区间外的值将被裁剪到区间边缘。
  76. 例如,如果指定的间隔为:math:`[0, 1]`,则小于0的值将变为0,大于1的值将变为1。
  77. 注:
  78. 目前不支持裁剪`xmin=nan`或`xmax=nan`。
  79. 参数:
  80. xmin (Tensor, scalar, None):最小值。如果值为None,则不在间隔的下边缘执行裁剪操作。
  81. `xmin`或`xmax`只能有一个为None。
  82. xmax (Tensor, scalar, None):最大值。如果值为None,则不在间隔的上边缘执行裁剪操作。
  83. `xmin`或`xmax`只能有一个为None。
  84. 如果`xmin`或`xmax`是Tensor,则三个Tensor将被广播进行shape匹配。
  85. dtype (`mindspore.dtype`, optional):覆盖输出Tensor的dtype。默认值为None。
  86. 返回:
  87. Tensor,含有输入Tensor的元素,其中values < `xmin`被替换为`xmin`,values > `xmax`被替换为`xmax`。
  88. 异常:
  89. TypeError:输入的类型与Tensor不一致。
  90. ValueError:输入与Tensor的shape不能广播,或者`xmin`和`xmax`都是`None`。
  91. 支持平台:
  92. ``Ascend`` ``GPU`` ``CPU``
  93. 样例:
  94. >>> from mindspore import Tensor
  95. >>> x = Tensor([1, 2, 3, -4, 0, 3, 2, 0]).astype("float32")
  96. >>> output = x.clip(0, 2)
  97. >>> print(output)
  98. [1.2.2.0.0.2.2.0.]
  99. copy()
  100. 返回复制的Tensor。
  101. 注:
  102. 当前实现不支持类似NumPy的`order`参数。
  103. 返回:
  104. 复制的Tensor。
  105. 支持平台:
  106. ``Ascend`` ``GPU`` ``CPU``
  107. 样例:
  108. >>> import numpy as np
  109. >>> from mindspore import Tensor
  110. >>> a = Tensor(np.ones((3,3)).astype("float32"))
  111. >>> output = a.copy()
  112. >>> print(output)
  113. [[1.1.1.]
  114. [1.1.1.]
  115. [1.1.1.]]
  116. cumsum(axis=None, dtype=None)
  117. 返回指定轴方向上元素的累加值。
  118. 注:
  119. 如果`dtype`为`int8`, `int16`或`bool`,则结果`dtype`将提升为`int32`,不支持`int64`。
  120. 参数:
  121. axis (int, optional):轴,在该轴方向上的累积和。其默认值(None)用来计算扁平轴上的累加和。
  122. dtype (`mindspore.dtype`, optional):如果未指定参数值,则保持与原始Tensor相同,除非参数值是一个精度小于:class:`float32`的整数。
  123. 在这种情况下,使用`float32`。默认值:None。
  124. 异常:
  125. ValueError:轴超出范围。
  126. 返回:
  127. Tensor。
  128. 支持平台:
  129. ``Ascend`` ``GPU`` ``CPU``
  130. 样例:
  131. >>> import numpy as np
  132. >>> from mindspore import Tensor
  133. >>> a = Tensor(np.ones((3,3)).astype("float32"))
  134. >>> output = a.cumsum(axis=0)
  135. >>> print(output)
  136. [[1.1.1.]
  137. [2.2.2.]
  138. [3.3.3.]]
  139. diagonal(offset=0, axis1=0, axis2=1)
  140. 返回指定的对角线。
  141. 参数:
  142. offset (int, optional):对角线与主对角线的偏移。可以是正值或负值。默认为主对角线。
  143. axis1 (int, optional):二维子数组的第一轴,对角线应该从这里开始。默认为第一轴(0)。
  144. axis2 (int, optional):二维子数组的第二轴,对角线应该从这里开始。默认为第二轴。
  145. 返回:
  146. Tensor,如果Tensor是二维,则返回值是一维数组。
  147. 异常:
  148. ValueError:输入Tensor的维度少于2。
  149. 支持平台:
  150. ``Ascend`` ``GPU`` ``CPU``
  151. 样例:
  152. >>> import numpy as np
  153. >>> from mindspore import Tensor
  154. >>> a = Tensor(np.arange(4).reshape(2, 2))
  155. >>> print(a)
  156. [[0 1]
  157. [2 3]]
  158. >>> output = a.diagonal()
  159. >>> print(output)
  160. [0 3]
  161. fill(value)
  162. 用标量值填充数组。
  163. 注:
  164. 与NumPy不同,Tensor.fill()将始终返回一个新的Tensor,而不是填充原来的Tensor。
  165. 参数:
  166. value (Union[None, int, float, bool]):所有元素都被赋予这个值。
  167. 返回:
  168. Tensor,与原来的dtype和shape相同的Tensor。
  169. 异常:
  170. TypeError:输入参数具有前面未指定的类型。
  171. 支持平台:
  172. ``Ascend`` ``GPU`` ``CPU``
  173. 样例:
  174. >>> import numpy as np
  175. >>> from mindspore import Tensor
  176. >>> a = Tensor(np.arange(4).reshape((2,2)).astype('float32'))
  177. >>> print(a.fill(1.0))
  178. [[1.1.]
  179. [1.1.]]
  180. flatten(order='C')
  181. 返回展开成一维的Tensor的副本。
  182. 参数:
  183. order (str, optional):可以在'C'和'F'之间进行选择。'C'表示按行优先(C风格)顺序展开。'F'表示按列优先顺序(Fortran风格)进行扁平化。
  184. 仅支持'C'和'F'。默认值:C。
  185. 返回:
  186. Tensor,具有与输入相同的数据类型。
  187. 支持平台:
  188. ``Ascend`` ``GPU`` ``CPU``
  189. 异常:
  190. TypeError:`order`不是字符串类型。
  191. ValueError:`order`是字符串类型,但不是'C'或'F'。
  192. 样例:
  193. >>> import numpy as np
  194. >>> from mindspore import Tensor
  195. >>> x = Tensor(np.ones((2,3,4), dtype=np.float32))
  196. >>> output = x.flatten()
  197. >>> print(output.shape)
  198. (24,)
  199. flush_from_cache()
  200. 如果Tensor开启缓存作用,则将缓存数据刷新到host侧。
  201. has_init
  202. Tensor是否已经初始化。
  203. init_data(slice_index=None, shape=None, opt_shard_group=None)
  204. 获取此Tensor的数据。
  205. 对于同一个Tensor,只可以调用一次init_data函数。
  206. 参数:
  207. slice_index (int):参数切片的索引。
  208. 在初始化参数切片的时候使用,保证使用相同切片的设备可以生成相同的Tensor。默认值:None。
  209. shape (list[int]):切片的shape,在初始化参数切片时使用。默认值:None。
  210. opt_shard_group(str):优化器分片组,在自动或半自动并行模式下用于获取参数的切片。默认值:None。
  211. 返回:
  212. 初始化的Tensor。
  213. 支持平台:
  214. ``Ascend`` ``GPU`` ``CPU``
  215. 样例:
  216. >>> import mindspore as ms
  217. >>> import mindspore.common.initializer as init
  218. >>> x = init.initializer(init.Constant(1), [2, 2], ms.float32)
  219. >>> out = x.init_data()
  220. >>> print(out)
  221. [[1.1.]
  222. [1.1.]]
  223. item(index=None)
  224. 使用索引从Tensor中获取值。
  225. 注:
  226. Tensor.item返回的是Tensor标量,而不是Python标量。
  227. 参数:
  228. index (Union[None, int, tuple(int)]):Tensor的索引。默认值:None。
  229. 返回:
  230. Tensor标量,dtype与原始Tensor的相同。
  231. 异常:
  232. ValueError:`index`的长度不等于Tensor的ndim。
  233. 支持平台:
  234. ``Ascend`` ``GPU``
  235. 样例:
  236. >>> import numpy as np
  237. >>> from mindspore import Tensor
  238. >>> x = Tensor(np.array([[1,2,3],[4,5,6]], dtype=np.float32))
  239. >>> x = x.item((0,1))
  240. >>> print(x)
  241. 2.0
  242. itemset(*args)
  243. 将标量插入到Tensor(并将标量转换为Tensor的数据类型)。
  244. 必须至少有1个参数,并且最后一个参数被定义为项。
  245. Tensor.itemset(\*args)等同于:math:`Tensor[args] = item`。
  246. 参数:
  247. args (Union[(numbers.Number), (int/tuple(int), numbers.Number)]):指定索引和值的参数。如果`args`包含一个参数(标量),则其仅在Tensor大小为1的情况下使用。如果`args`包含两个参数,则最后一个参数是要设置的值且必须是标量,而第一个参数指定单个Tensor元素的位置。
  248. 参数值是整数或者元组。
  249. 返回:
  250. 一个新的Tensor,其值为:math:`Tensor[args] = item`。
  251. 异常:
  252. ValueError:第一个参数的长度不等于Tensor的ndim。
  253. IndexError:只提供了一个参数,并且原来的Tensor不是标量。
  254. 支持平台:
  255. ``Ascend`` ``GPU``
  256. 样例:
  257. >>> import numpy as np
  258. >>> from mindspore import Tensor
  259. >>> x = Tensor(np.array([[1,2,3],[4,5,6]], dtype=np.float32))
  260. >>> x = x.itemset((0,1), 4)
  261. >>> print(x)
  262. [[1.4.3.]
  263. [4.5.6.]]
  264. itemsize
  265. 返回一个Tensor元素的长度(以字节为单位)。
  266. max(axis=None, keepdims=False, initial=None, where=True)
  267. 返回Tensor的最大值或轴方向上的最大值。
  268. 参数:
  269. axis (Union[None, int, tuple of ints], optional):轴,在该轴方向上进行操作。默认情况下,使用扁平输入。如果该参数为整数元组,则在多个轴上选择最大值,而不是在单个轴或所有轴上进行选择。默认值:None。
  270. keepdims (bool, optional):
  271. 如果这个参数为True,被删去的维度保留在结果中,且维度大小设为1。有了这个选项,结果就可以与输入数组进行正确的广播运算。默认值:False。
  272. initial (scalar, optional):
  273. 输出元素的最小值。该参数必须设置,才能对空切片进行计算。默认值:None。
  274. where (bool Tensor, optional):
  275. 一个bool数组,被广播以匹配数组维度和选择包含在降维中的元素。如果传递了一个非默认值,则还必须提供初始值。默认值:True。
  276. 返回:
  277. Tensor或标量,输入Tensor的最大值。如果`axis`为None,则结果是一个标量值。如果提供了`axis`,则结果是Tensor ndim - 1维度的一个数组。
  278. 异常:
  279. TypeError:参数具有前面未指定的类型。
  280. 支持平台:
  281. ``Ascend`` ``GPU`` ``CPU``
  282. 样例:
  283. >>> import numpy as np
  284. >>> from mindspore import Tensor
  285. >>> a = Tensor(np.arange(4).reshape((2, 2)).astype('float32'))
  286. >>> output = a.max()
  287. >>> print(output)
  288. 3.0
  289. min(axis=None, keepdims=False, initial=None, where=True)
  290. 返回Tensor的最小值或轴方向上的最小值。
  291. 参数:
  292. axis (Union[None, int, tuple of ints], optional):轴,在该轴方向上进行操作。默认情况下,使用扁平输入。如果该参数为整数元组,则在多个轴上选择最小值,而不是在单个轴或所有轴上进行选择。默认值:None。
  293. keepdims (bool, optional):
  294. 如果这个参数为True,被删去的维度保留在结果中,且维度大小设为1。有了这个选项,结果就可以与输入数组进行正确的广播运算。默认值:False。
  295. initial (scalar, optional):
  296. 输出元素的最大值。该参数必须设置,才能对空切片进行计算。默认值:None。
  297. where (bool Tensor, optional):
  298. 一个布尔数组,被广播以匹配数组维度和选择包含在降维中的元素。如果传递了一个非默认值,则还必须提供初始值。默认值:True。
  299. 返回:
  300. Tensor或标量,输入Tensor的最小值。如果轴为None,则结果为一个标量值。如果提供了`axis`,则结果是Tensor.ndim - 1维度的一个数组。
  301. 异常:
  302. TypeError:参数具有前面未指定的类型。
  303. 支持平台:
  304. ``Ascend`` ``GPU`` ``CPU``
  305. 样例:
  306. >>> import numpy as np
  307. >>> from mindspore import Tensor
  308. >>> import mindspore.numpy as np
  309. >>> a = Tensor(np.arange(4).reshape((2,2)).astype('float32'))
  310. >>> output = a.min()
  311. >>> print(output)
  312. 0.0
  313. nbytes
  314. 返回Tensor占用的总字节数。
  315. ndim
  316. 返回Tensor维度的数量。
  317. ptp(axis=None, keepdims=False)
  318. 该函数名称是"peak to peak"的缩写。
  319. 注:
  320. 不支持NumPy参数`dtype`和`out`。
  321. 参数:
  322. axis (Union[None, int, tuple(int)]):轴,在轴方向上可以计算范围。
  323. 默认计算扁平数组的方差。默认值:None。
  324. keepdims (bool):如果设为True,被删去的维度保留在结果中,且维度大小设为1。有了这个选项,结果将针对输入数组正确传递。
  325. 默认值为False。
  326. 返回:
  327. Tensor。
  328. 异常:
  329. TypeError:`self`不是Tensor,或者`axis`和`keepdims`具有前面未指定的类型。
  330. 支持平台:
  331. ``Ascend`` ``GPU`` ``CPU``
  332. 样例:
  333. >>> from mindspore import Tensor
  334. >>> x = Tensor([[4.0, 9.0, 2.0, 10.0], [6.0, 9.0, 7.0, 12.0]]).astype("float32")
  335. >>> print(x.ptp(axis=1))
  336. [8.6.]
  337. >>> print(x.ptp(axis=0))
  338. [2.0.5.2.]
  339. ravel()
  340. 返回一个展开的一维Tensor。
  341. 返回:
  342. 一维Tensor,含有与输入相同的元素。
  343. 支持平台:
  344. ``Ascend`` ``GPU`` ``CPU``
  345. 样例:
  346. >>> import numpy as np
  347. >>> from mindspore import Tensor
  348. >>> x = Tensor(np.ones((2,3,4), dtype=np.float32))
  349. >>> output = x.ravel()
  350. >>> print(output.shape)
  351. (24,)
  352. repeat(repeats, axis=None)
  353. 对数组中的元素进行重复复制。
  354. 参数:
  355. repeats (Union[int, tuple, list]):每个元素的重复次数,`repeats`被广播以适应指定轴的shape。
  356. axis (int, optional):轴方向上的重复值。默认情况下,使用展开的输入Tensor,并返回一个展开的输出Tensor。
  357. 返回:
  358. Tensor,除了维度外,与输入Tensor具有相同的shape。
  359. 异常:
  360. ValueError:维度超出范围。
  361. TypeError:参数类型不匹配。
  362. 支持平台:
  363. ``Ascend`` ``GPU`` ``CPU``
  364. 样例:
  365. >>> import numpy as np
  366. >>> from mindspore import Tensor
  367. >>> x = Tensor(np.array(3))
  368. >>> print(x.repeat(4))
  369. [3 3 3 3]
  370. >>> x = Tensor(np.array([[1, 2],[3, 4]]))
  371. >>> print(x.repeat(2))
  372. [1 1 2 2 3 3 4 4]
  373. >>> print(x.repeat(3, axis=1))
  374. [[1 1 1 2 2 2]
  375. [3 3 3 4 4 4]]
  376. >>> print(x.repeat([1,2], axis=0))
  377. [[1 2]
  378. [3 4]
  379. [3 4]]
  380. reshape(*shape)
  381. 不改变数据的情况下,为Tensor提供新的shape。
  382. 参数:
  383. shape(Union[int, tuple(int), list(int)]):新的shape应与原来的shape兼容。如果参数值为整数,则结果是该长度的一维数组。shape的维度可以为-1。在这种情况下,将根据数组的长度和剩下的维度计算出该值。
  384. 返回:
  385. Tensor,具有新shape的Tensor。
  386. 异常:
  387. TypeError:新shape不是整数、列表或元组。
  388. ValueError:新shape与原来Tensor的shape不兼容。
  389. 支持平台:
  390. ``Ascend`` ``GPU`` ``CPU``
  391. 样例:
  392. >>> from mindspore import Tensor
  393. >>> from mindspore import dtype as mstype
  394. >>> x = Tensor([[-0.1, 0.3, 3.6], [0.4, 0.5, -3.2]], dtype=mstype.float32)
  395. >>> output = x.reshape((3, 2))
  396. >>> print(output)
  397. [[-0.1 0.3]
  398. [ 3.6 0.4]
  399. [ 0.5 -3.2]]
  400. resize(*new_shape)
  401. 更改Tensor的shape。
  402. 注:
  403. 此方法不更改输入数组的大小,也不返回NumPy中的任何内容,而是返回一个具有输入大小的新Tensor。
  404. 不支持Numpy参数`refcheck`。
  405. 参数:
  406. new_shape (Union[ints, tuple of ints]):指定Tensor的新shape。
  407. 返回:
  408. Tensor。
  409. 支持平台:
  410. ``Ascend`` ``GPU`` ``CPU``
  411. 样例:
  412. >>> import numpy as np
  413. >>> from mindspore import Tensor
  414. >>> x = Tensor(np.array([[0, 1], [2, 3]]))
  415. >>> x = x.resize(2, 3)
  416. >>> print(x)
  417. [[0 1 2]
  418. [3 0 0]]
  419. searchsorted(v, side='left', sorter=None)
  420. 查找应插入元素以保存顺序的位置索引。
  421. 参数:
  422. v (Union[int, float, bool, list, tuple, Tensor]):要插入元素的值。
  423. side ('left', 'right', optional):如果参数值为'left',则给出找到的第一个合适位置的索引。如果参数值为'right',则返回最后一个这样的索引。如果没有合适的索引,则返回0或N(其中N是Tensor的长度)。
  424. 默认值:`left`。
  425. sorter (Union[int, float, bool, list, tuple, Tensor]):整数索引的可选一维数组,将Tensor按升序排序。它们通常是NumPy argsort方法的结果。
  426. 返回:
  427. Tensor,shape与`v`相同的插入点数组。
  428. 异常:
  429. ValueError:`side`或`sorter`的参数无效。
  430. 支持平台:
  431. ``Ascend`` ``GPU`` ``CPU``
  432. 样例:
  433. >>> import numpy as np
  434. >>> from mindspore import Tensor
  435. >>> x = Tensor(np.array([1, 2, 3, 4, 5]))
  436. >>> print(x.searchsorted(3))
  437. 2
  438. shape
  439. 返回Tensor的shape。
  440. size
  441. 返回Tensor中的元素总数。
  442. squeeze(axis=None)
  443. 从Tensor中删除shape为1的维度。
  444. 参数:
  445. axis (Union[None, int, list(int), tuple(int)], optional):选择shape中长度为1的条目的子集。如果选择shape条目长度大于1的轴,则报错。默认值为None。
  446. 返回:
  447. Tensor,删除了长度为1的维度的全部子集或一个子集。
  448. 异常:
  449. TypeError:输入的参数类型有误。
  450. ValueError:指定维度的shape大于1。
  451. 支持平台:
  452. ``Ascend`` ``GPU`` ``CPU``
  453. 样例:
  454. >>> import numpy as np
  455. >>> from mindspore import Tensor
  456. >>> x = Tensor(np.ones((1,2,2,1), dtype=np.float32))
  457. >>> x = x.squeeze()
  458. >>> print(x.shape)
  459. (2, 2)
  460. std(axis=None, ddof=0, keepdims=False)
  461. 计算指定维度的标准差。
  462. 标准差是方差的算术平方根,如::math:`std = sqrt(mean(abs(x - x.mean())**2))`。
  463. 返回标准差。默认情况下计算展开数组的标准差,否则在指定维度上计算。
  464. 注:
  465. 不支持NumPy参数`dtype`、`out`和`where`。
  466. 参数:
  467. axis (Union[None, int, tuple(int)]):在该维度上计算标准差。默认值:`None`。
  468. 如果为`None`,则计算展开数组的标准偏差。
  469. ddof (int):δ自由度。计算中使用的除数是:math:`N - ddof`,其中:math:`N`表示元素的数量。默认值:0。
  470. keepdims:默认值:`False`。
  471. 返回:
  472. 含有标准差数值的Tensor。
  473. 支持平台:
  474. ``Ascend`` ``GPU`` ``CPU``
  475. 样例:
  476. >>> import numpy as np
  477. >>> from mindspore import Tensor
  478. >>> input_x = Tensor(np.array([1, 2, 3, 4], dtype=np.float32))
  479. >>> output = input_x.std()
  480. >>> print(output)
  481. 1.118034
  482. strides
  483. Tensor上每个维度跨度的字节元组。
  484. sum(axis=None, dtype=None, keepdims=False, initial=None)
  485. 返回指定维度上数组元素的总和。
  486. 注:
  487. 不支持NumPy参数`out`、`where`、`casting`、`order`、`subok`、`signature`和`extobj`。
  488. 参数:
  489. axis (Union[None, int, tuple(int)]):指定维度,在该维度方向上进行求和运算。默认值:None。
  490. 如果参数值为None,会计算输入数组中所有元素的和。
  491. 如果axis为负数,则从最后一维开始往第一维计算。
  492. 如果axis为整数元组,会对该元组指定的所有轴方向上的元素进行求和。
  493. dtype (`mindspore.dtype`, optional):默认值为None。会覆盖输出Tensor的dtype。
  494. keepdims (bool):如果这个参数为True,被删去的维度保留在结果中,且维度大小设为1。有了这个选项,结果就可以与输入数组进行正确的广播运算。
  495. 如果设为默认值,那么keepdims不会被传递给ndarray子类的sum方法。但是任何非默认值都会被传递。如果子类的方法未实现keepdims,则引发异常。默认值:`False`。
  496. initial (scalar):初始化的起始值。默认值:`None`。
  497. 返回:
  498. Tensor。具有与输入相同shape的Tensor,删除了指定的轴。
  499. 如果输入Tensor是0维数组,或axis为None时,返回一个标量。
  500. 异常:
  501. TypeError:input不是Tensor,`axis`不是整数或整数元组,`keepdims`不是整数,或者`initial`不是标量。
  502. ValueError:任意轴超出范围或存在重复的轴。
  503. 支持平台:
  504. ``Ascend`` ``GPU`` ``CPU``
  505. 样例:
  506. >>> import numpy as np
  507. >>> from mindspore import Tensor
  508. >>> input_x = Tensor(np.array([-1, 0, 1]).astype(np.float32))
  509. >>> print(input_x.sum())
  510. 0.0
  511. >>> input_x = Tensor(np.arange(10).reshape(2, 5).astype(np.float32))
  512. >>> print(input_x.sum(axis=1))
  513. [10.35.]
  514. swapaxes(axis1, axis2)
  515. 交换Tensor的两个维度。
  516. 参数:
  517. axis1 (int):第一个维度。
  518. axis2 (int):第二个维度。
  519. 返回:
  520. 转化后的Tensor,与输入具有相同的数据类型。
  521. 异常:
  522. TypeError:`axis1`或`axis2`不是整数。
  523. ValueError:`axis1`或`axis2`不在`[-ndim, ndim-1]`范围内。
  524. 支持平台:
  525. ``Ascend`` ``GPU`` ``CPU``
  526. 样例:
  527. >>> import numpy as np
  528. >>> from mindspore import Tensor
  529. >>> x = Tensor(np.ones((2,3,4), dtype=np.float32))
  530. >>> output = x.swapaxes(0, 2)
  531. >>> print(output.shape)
  532. (4,3,2)
  533. T
  534. 返回被转置后的Tensor。
  535. take(indices, axis=None, mode='clip')
  536. 在指定维度上获取Tensor中的元素。
  537. 参数:
  538. indices (Tensor):待提取的值的shape为`(Nj...)`的索引。
  539. axis (int, optional):在指定维度上选择值。默认情况下,使用展开的输入数组。默认值:`None`。
  540. mode ('raise', 'wrap', 'clip', optional):
  541. - edge:填充Tensor的边缘值。
  542. - raise:引发错误。
  543. - wrap:绕接。
  544. - clip:裁剪到范围。`clip`模式意味着所有过大的索引都会被在指定轴方向上指向最后一个元素的索引替换。注:这将禁用具有负数的索引。
  545. 默认值:`clip`。
  546. 返回:
  547. Tensor,索引的结果。
  548. 异常:
  549. ValueError:`axis`超出范围,或`mode`被设置为'raise'、'wrap'和'clip'以外的值。
  550. 支持平台:
  551. ``Ascend`` ``GPU`` ``CPU``
  552. 样例:
  553. >>> import numpy as np
  554. >>> from mindspore import Tensor
  555. >>> a = Tensor(np.array([4, 3, 5, 7, 6, 8]))
  556. >>> indices = Tensor(np.array([0, 1, 4]))
  557. >>> output = a.take(indices)
  558. >>> print(output)
  559. [4 3 6]
  560. to_tensor(slice_index=None, shape=None, opt_shard_group=None)
  561. 返回init_data()的结果,并获取此Tensor的数据。
  562. 注:
  563. 不建议使用`to_tensor`。请使用`init_data`。
  564. 参数:
  565. slice_index (int):参数切片的索引。
  566. 在初始化参数切片的时候使用,保证使用相同切片的设备可以生成相同的Tensor。默认值:None。
  567. shape (list[int]):切片的shape,在初始化参数切片时使用。默认值:None。
  568. opt_shard_group(str):优化器分片组,在自动或半自动并行模式下用于获取参数切片的分片。默认值:None。
  569. 返回:
  570. 初始化的Tensor。
  571. 支持平台:
  572. ``Ascend`` ``GPU`` ``CPU``
  573. 样例:
  574. >>> import mindspore as ms
  575. >>> import mindspore.common.initializer as init
  576. >>> x = init.initializer(init.Constant(1), [2, 2], ms.float32)
  577. >>> out = x.to_tensor()
  578. >>> print(out)
  579. [[1.1.]
  580. [1.1.]]
  581. trace(offset=0, axis1=0, axis2=1, dtype=None)
  582. 在Tensor的对角线方向上的总和。
  583. 参数:
  584. offset (int, optional):对角线与主对角线的偏移。
  585. 可以是正值或负值。默认为主对角线。
  586. axis1 (int, optional):二维子数组的第一轴,对角线应该从这里开始。默认为第一轴(0)。
  587. axis2 (int, optional):二维子数组的第二轴,对角线应该从这里开始。默认为第二轴。
  588. dtype (`mindspore.dtype`, optional):默认值为None。覆盖输出Tensor的dtype。
  589. 返回:
  590. Tensor,对角线方向上的总和。
  591. 异常:
  592. ValueError:输入Tensor的维度少于2。
  593. 支持平台:
  594. ``Ascend`` ``GPU`` ``CPU``
  595. 样例:
  596. >>> import numpy as np
  597. >>> from mindspore import Tensor
  598. >>> x = Tensor(np.eye(3, dtype=np.float32))
  599. >>> print(x.trace())
  600. 3.0
  601. transpose(*axes)
  602. 返回被转置后的Tensor。
  603. - 对于一维Tensor,这没有影响,因为转置后的向量是相同的。
  604. - 对于二维Tensor,是标准的矩阵转置。
  605. - 对于n维Tensor,如果提供了维度,则它们的顺序代表维度的置换方式。
  606. 如果未提供轴,且Tensor.shape等于(i[0], i[1],...i[n-2], i[n-1]),则Tensor.transpose().shape等于(i[n-1], i[n-2], ... i[1], i[0])。
  607. 参数:
  608. axes(Union[None, tuple(int), list(int), int], optional):如果axes为None或未设置,则该方法将反转维度。如果axes为tuple(int)或list(int),则Tensor.transpose()把Tensor转置为新的维度。
  609. 如果axes为整数,则此表单仅作为元组/列表表单的备选。
  610. 返回:
  611. Tensor,具有与输入Tensor相同的维度,其中维度被准确的排列。
  612. 异常:
  613. TypeError:输入参数类型有误。
  614. ValueError:`axes`的数量不等于Tensor.ndim。
  615. 支持平台:
  616. ``Ascend`` ``GPU`` ``CPU``
  617. 样例:
  618. >>> import numpy as np
  619. >>> from mindspore import Tensor
  620. >>> x = Tensor(np.ones((1,2,3), dtype=np.float32))
  621. >>> x = x.transpose()
  622. >>> print(x.shape)
  623. (3, 2, 1)
  624. var(axis=None, ddof=0, keepdims=False)
  625. 在指定维度上的方差。
  626. 方差是平均值的平方偏差的平均值,即::math:`var = mean(abs(x - x.mean())**2)`。
  627. 返回方差值。默认情况下计算展开Tensor的方差,否则在指定维度上计算。
  628. 注:
  629. 不支持NumPy参数`dtype`、`out`和`where`。
  630. 参数:
  631. axis (Union[None, int, tuple(int)]):维度,在指定维度上计算方差。
  632. 其默认值是展开Tensor的方差。默认值:`None`。
  633. ddof (int):δ自由度。默认值:0。
  634. 计算中使用的除数是:math:`N - ddof`,其中:math:`N`表示元素的数量。
  635. keepdims (bool):默认值:`False`。
  636. 支持平台:
  637. ``Ascend`` ``GPU`` ``CPU``
  638. 返回:
  639. 含有方差值的Tensor。
  640. 样例:
  641. >>> import numpy as np
  642. >>> from mindspore import Tensor
  643. >>> input_x = Tensor(np.array([1., 2., 3., 4.], np.float32))
  644. >>> output = input_x.var()
  645. >>> print(output)
  646. 1.25
  647. view(*shape)
  648. 根据输入shape重新创建一个Tensor,与原Tensor数据相同。
  649. 参数:
  650. shape (Union[tuple(int), int]):输出Tensor的维度。
  651. 返回:
  652. Tensor,具有与输入shape相同的维度。