Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
BaiXuePrincess
Paddle
提交
11f31d1e
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看板
提交
11f31d1e
编写于
6月 15, 2018
作者:
X
Xin Pan
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
follow comments
上级
bc46c527
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
10 addition
and
41 deletion
+10
-41
python/paddle/fluid/layers/control_flow.py
python/paddle/fluid/layers/control_flow.py
+10
-41
未找到文件。
python/paddle/fluid/layers/control_flow.py
浏览文件 @
11f31d1e
...
...
@@ -617,48 +617,17 @@ class While(object):
Examples:
.. code-block:: python
# The value these d0, d1 and d2 can be fed from python.
d0 = fluid.layers.data(
"d0", shape=[10], append_batch_size=False, dtype='float32')
d1 = fluid.layers.data(
"d1", shape=[10], append_batch_size=False, dtype='float32')
d2 = fluid.layers.data(
"d2", shape=[10], append_batch_size=False, dtype='float32')
i = fluid.layers.zeros(shape=[1], dtype='int64')
i.stop_gradient = True
init = fluid.layers.zeros(shape=[10], dtype='float32')
# Initialize mem_array from init
mem_array = fluid.layers.array_write(x=init, i=i)
# Initialize data_array from d0
data_array = fluid.layers.array_write(x=d0, i=i)
# Set a value to data_array using d1[i].
i = fluid.layers.increment(i)
fluid.layers.array_write(d1, i, array=data_array)
# Set a value to data_array using d2[i].
i = fluid.layers.increment(i)
fluid.layers.array_write(d2, i, array=data_array)
# Create a idx to start the while loop.
i = fluid.layers.zeros(shape=[1], dtype='int64')
i.stop_gradient = True
array_len = fluid.layers.fill_constant(
shape=[1], dtype='int64', value=3)
array_len.stop_gradient = True
# Create the while loop condition.
cond = fluid.layers.less_than(x=i, y=array_len)
# Within the loop, perform sums.
while_op = fluid.layers.While(cond=cond)
with while_op.block():
d = fluid.layers.array_read(array=data_array, i=i)
prev = fluid.layers.array_read(array=mem_array, i=i)
result = fluid.layers.sums(input=[d, prev])
i = fluid.layers.increment(x=i, in_place=True)
fluid.layers.array_write(result, i=i, array=mem_array)
fluid.layers.less_than(x=i, y=array_len, cond=cond)
d0 = layers.data("d0", shape=[10], dtype='float32')
data_array = layers.array_write(x=d0, i=i)
array_len = layers.fill_constant(shape=[1],dtype='int64', value=3)
sum_result = fluid.layers.array_read(array=mem_array, i=i)
cond = layers.less_than(x=i, y=array_len)
while_op = layers.While(cond=cond)
with while_op.block():
d = layers.array_read(array=data_array, i=i)
i = layers.increment(x=i, in_place=True)
layers.array_write(result, i=i, array=d)
layers.less_than(x=i, y=array_len, cond=cond)
"""
BEFORE_WHILE_BLOCK
=
0
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录