Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
BaiXuePrincess
Paddle
提交
096b2f5a
P
Paddle
项目概览
BaiXuePrincess
/
Paddle
与 Fork 源项目一致
Fork自
PaddlePaddle / Paddle
通知
1
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
P
Paddle
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
未验证
提交
096b2f5a
编写于
5月 14, 2021
作者:
L
liym27
提交者:
GitHub
5月 14, 2021
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Polish code for _getitem_impl_ (#32868)
上级
a8625aaf
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
40 addition
and
104 deletion
+40
-104
python/paddle/fluid/framework.py
python/paddle/fluid/framework.py
+40
-104
未找到文件。
python/paddle/fluid/framework.py
浏览文件 @
096b2f5a
...
...
@@ -792,29 +792,16 @@ def _getitem_impl_(var, item):
if
not
isinstance
(
item
,
tuple
):
item
=
[
item
]
decrease_axis
=
[]
slice_axis
=
[]
slice_start
=
[]
slice_end
=
[]
slice_step
=
[]
decrease_axes
=
[]
axes
=
[]
starts
=
[]
ends
=
[]
steps
=
[]
use_strided_slice
=
False
reverse_axis
=
[]
target_block
=
default_main_program
().
current_block
()
def
fill_constant
(
shape
,
value
,
force_cpu
=
False
,
out
=
None
):
var
.
block
.
append_op
(
type
=
'fill_constant'
,
inputs
=
{},
outputs
=
{
'Out'
:
[
out
]},
attrs
=
{
'shape'
:
shape
,
'dtype'
:
out
.
dtype
,
'value'
:
float
(
value
),
'force_cpu'
:
force_cpu
})
out
.
stop_gradient
=
True
return
out
max_integer
=
2
**
31
-
1
for
dim
,
slice_item
in
enumerate
(
item
):
if
isinstance
(
slice_item
,
slice
):
start
=
slice_item
.
start
...
...
@@ -824,8 +811,7 @@ def _getitem_impl_(var, item):
if
start
is
None
and
end
is
None
and
step
is
None
:
continue
if
step
is
None
:
step
=
1
step
=
1
if
step
is
None
else
step
if
start
is
None
and
end
is
None
:
assert
(
step
==
-
1
)
...
...
@@ -836,106 +822,56 @@ def _getitem_impl_(var, item):
start
=
0
if
end
is
None
:
end
=
10000000
if
step
!=
1
:
use_strided_slice
=
True
end
=
max_integer
slice_axis
.
append
(
dim
)
slice_start
.
append
(
start
)
slice_end
.
append
(
end
)
slice_step
.
append
(
step
)
else
:
decrease_axis
.
append
(
dim
)
slice_axis
.
append
(
dim
)
slice_start
.
append
(
slice_item
)
slice_step
.
append
(
1
)
if
isinstance
(
slice_item
,
Variable
):
temp_1
=
var
.
block
.
create_var
(
dtype
=
slice_item
.
dtype
)
fill_constant
([
1
],
1
,
force_cpu
=
True
,
out
=
temp_1
)
temp_end
=
target_block
.
create_var
(
dtype
=
slice_item
.
dtype
)
target_block
.
append_op
(
type
=
'elementwise_add'
,
inputs
=
{
'X'
:
slice_item
,
'Y'
:
temp_1
},
outputs
=
{
'Out'
:
temp_end
},
attrs
=
{
'axis'
:
-
1
})
slice_end
.
append
(
temp_end
)
else
:
slice_end
.
append
(
slice_item
+
1
if
slice_item
!=
-
1
else
10000000
)
decrease_axes
.
append
(
dim
)
start
=
slice_item
step
=
1
end
=
slice_item
+
1
if
slice_item
!=
-
1
else
max_integer
def
contain_var
(
one_list
):
for
ele
in
one_list
:
if
isinstance
(
ele
,
Variable
):
return
True
return
False
def
get_new_list_tensor
(
old_list
):
new_list_tensor
=
[]
for
dim
in
old_list
:
if
isinstance
(
dim
,
Variable
):
dim
.
stop_gradient
=
True
new_list_tensor
.
append
(
dim
)
else
:
assert
(
isinstance
(
dim
,
int
))
temp_out
=
var
.
block
.
create_var
(
dtype
=
'int64'
)
fill_constant
([
1
],
dim
,
force_cpu
=
True
,
out
=
temp_out
)
new_list_tensor
.
append
(
temp_out
)
return
new_list_tensor
axes
.
append
(
dim
)
starts
.
append
(
start
)
ends
.
append
(
end
)
steps
.
append
(
step
)
use_strided_slice
=
True
if
step
!=
1
else
use_strided_slice
inputs
=
{
'Input'
:
[
var
]}
attrs
=
{
'axes'
:
slice_axi
s
,
'axes'
:
axe
s
,
'starts'
:
[],
'ends'
:
[],
'decrease_axis'
:
decrease_ax
i
s
'decrease_axis'
:
decrease_ax
e
s
}
if
(
use_strided_slice
==
True
)
:
if
use_strided_slice
==
True
:
attrs
[
'strides'
]
=
[]
infer_flags
=
list
(
1
for
i
in
range
(
len
(
slice_axis
)))
# starts
if
contain_var
(
slice_start
):
inputs
[
'StartsTensorList'
]
=
get_new_list_tensor
(
slice_start
)
for
i
,
dim
in
enumerate
(
slice_start
):
if
isinstance
(
dim
,
Variable
):
attrs
[
'starts'
].
append
(
-
1
)
infer_flags
[
i
]
=
-
1
else
:
attrs
[
'starts'
].
append
(
dim
)
else
:
attrs
[
'starts'
]
=
slice_start
# ends
if
contain_var
(
slice_end
):
inputs
[
'EndsTensorList'
]
=
get_new_list_tensor
(
slice_end
)
for
i
,
dim
in
enumerate
(
slice_end
):
if
isinstance
(
dim
,
Variable
):
attrs
[
'ends'
].
append
(
-
1
)
infer_flags
[
i
]
=
-
1
else
:
attrs
[
'ends'
].
append
(
dim
)
else
:
attrs
[
'ends'
]
=
slice_end
# strides
if
use_strided_slice
==
True
:
if
contain_var
(
slice_step
):
inputs
[
'StridesTensorList'
]
=
get_new_list_tensor
(
slice_step
)
for
i
,
dim
in
enumerate
(
slice_step
):
infer_flags
=
list
(
1
for
i
in
range
(
len
(
axes
)))
from
.layers
import
utils
def
deal_attrs
(
attr
,
attr_name
,
tensor_attr_name
,
inputs
,
infer_flags
):
if
utils
.
_contain_var
(
attr
):
inputs
[
tensor_attr_name
]
=
utils
.
_convert_to_tensor_list
(
attr
,
dtype
=
"int64"
)
for
i
,
dim
in
enumerate
(
attr
):
if
isinstance
(
dim
,
Variable
):
attrs
[
'strides'
].
append
(
-
1
)
attrs
[
attr_name
].
append
(
-
1
)
infer_flags
[
i
]
=
-
1
else
:
attrs
[
'strides'
].
append
(
dim
)
attrs
[
attr_name
].
append
(
dim
)
else
:
attrs
[
'strides'
]
=
slice_step
attrs
[
attr_name
]
=
attr
deal_attrs
(
starts
,
"starts"
,
"StartsTensorList"
,
inputs
,
infer_flags
)
deal_attrs
(
ends
,
"ends"
,
"EndsTensorList"
,
inputs
,
infer_flags
)
deal_attrs
(
steps
,
"strides"
,
"StridesTensorList"
,
inputs
,
infer_flags
)
# infer_flags
attrs
[
'infer_flags'
]
=
infer_flags
out
=
var
if
use_strided_slice
==
False
and
len
(
slice_axis
)
>
0
:
target_block
=
default_main_program
().
current_block
()
if
use_strided_slice
==
False
and
len
(
axes
)
>
0
:
# append slice_op here
slice_out_var
=
target_block
.
create_var
(
name
=
unique_name
.
generate_with_ignorable_key
(
var
.
name
+
"_slice"
),
...
...
@@ -948,7 +884,7 @@ def _getitem_impl_(var, item):
attrs
=
attrs
)
out
=
slice_out_var
elif
use_strided_slice
==
True
and
len
(
slice_axi
s
)
>
0
:
elif
use_strided_slice
==
True
and
len
(
axe
s
)
>
0
:
strided_slice_out_var
=
target_block
.
create_var
(
name
=
unique_name
.
generate_with_ignorable_key
(
var
.
name
+
"_strided_slice"
),
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录