1# StridedSlice
2
3
4## 概述
5
6根据步长和索引对输入张量进行切片提取。
7
8该算子对应的[NodeType](_n_n_rt_v10.md#nodetype)为NODE_TYPE_STRIDED_SLICE。
9
10输入:
11
12- x,n维tensor。
13
14- begin,1维tensor,begin的长度等于n,begin[i]指定第i维上截取的起点。
15
16- end,1维tensor,end的长度等于n,end[i]指定第i维上截取的终点。
17
18- strides,1维张量,strides的长度等于n,strides[i]指定第i维上截取的步长,允许存在负值。
19
20> ![icon-note.gif](public_sys-resources/icon-note.gif) **说明:**
21> 输入的张量有如下情况:begin, end 和 strides 的shape必须相同。 begin,end 是从0开始进行索引。 strides 的元素必须非零。
22
23输出:
24
25- output,堆叠运算后的tensor,数据类型与x相同。输出维度rank(x[0])+1维。
26
27**起始版本:** 3.2
28
29**相关模块:**[NNRt](_n_n_rt_v10.md)
30
31
32## 汇总
33
34
35### Public 属性
36
37| 名称 | 描述 |
38| -------- | -------- |
39| long [beginMask](#beginmask) | 表示切片的起始索引。 |
40| long [endMask](#endmask) | 表示切片的结束索引。 |
41| long [ellipsisMask](#ellipsismask) | 一个整数,用于解除begin和end的限制。 |
42| long [newAxisMask](#newaxismask) | 用于新增维度。 |
43| long [shrinkAxisMask](#shrinkaxismask) | 用于压缩指定维度。 |
44
45
46## 类成员变量说明
47
48
49### beginMask
50
51```
52long StridedSlice::beginMask
53```
54
55**描述**
56
57
58表示切片的起始索引。
59
60beginMask使用二进制编码方式对输入x的不同维度进行标志,beginMask的第i位设置为1则begin[i]参数对应的第i维度设置无效,表示该维度的起始索引从0开始。默认值为0。
61
62
63### ellipsisMask
64
65```
66long StridedSlice::ellipsisMask
67```
68
69**描述**
70
71
72一个整数,用于解除begin和end的限制。
73
74不为0的维度不需要进行切片操作。 将ellipsisMask转成二进制表示,如果ellipsisMask的第i位为1,则对于第i维,从第一个元素开始,以strides[i]为步长,截取元素直到tensor边界。
75
76
77### endMask
78
79```
80long StridedSlice::endMask
81```
82
83**描述**
84
85
86表示切片的结束索引。功能类似begin_mask。
87
88endMask使用二进制编码方式对输入x的不同维度进行标志,第i位设置为1则end参数对应的该维度设置无效,表示该维度切分的结束索引到列表最后,即切分到尽可能大的维度。默认值为0。
89
90
91### newAxisMask
92
93```
94long StridedSlice::newAxisMask
95```
96
97**描述**
98
99
100用于新增维度。
101
102newAxisMask使用二进制编码方式对输入x的不同维度进行标志,如果第i位出现1,则begin、end、stride对所有维度参数无效,并在第i位上增加一个大小为1的维度。
103
104
105### shrinkAxisMask
106
107```
108long StridedSlice::shrinkAxisMask
109```
110
111**描述**
112
113
114用于压缩指定维度。
115
116将shrinkAxisMask转成二进制表示,如果shrinkAxisMask的第i位位1,则舍去第i维所有元素,第i维长度压缩至1。
117