Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
机器未来
Paddle
提交
7973d3a0
P
Paddle
项目概览
机器未来
/
Paddle
与 Fork 源项目一致
Fork自
PaddlePaddle / Paddle
通知
1
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
P
Paddle
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1
Issue
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
7973d3a0
编写于
10月 10, 2017
作者:
Y
Yu Yang
提交者:
GitHub
10月 10, 2017
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #4641 from reyoung/feature/add_persistable_in_var_desc
Init Python API
上级
cec1f598
77150f1f
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
165 addition
and
0 deletion
+165
-0
python/paddle/v2/framework/graph.py
python/paddle/v2/framework/graph.py
+129
-0
python/paddle/v2/framework/tests/test_program.py
python/paddle/v2/framework/tests/test_program.py
+36
-0
未找到文件。
python/paddle/v2/framework/graph.py
0 → 100644
浏览文件 @
7973d3a0
import
paddle.v2.framework.core
as
core
import
collections
__all__
=
[
'Block'
,
'Variable'
,
'Program'
,
'Operator'
]
class
Variable
(
object
):
def
__init__
(
self
,
block
,
name
=
None
,
shape
=
None
,
dtype
=
None
,
lod_level
=
None
):
self
.
block
=
block
if
name
is
None
:
name
=
Variable
.
_unique_var_name_
()
self
.
proto
=
self
.
block
.
proto
.
new_var
(
name
)
if
shape
is
not
None
:
self
.
proto
.
set_shape
(
shape
)
if
dtype
is
not
None
:
# TODO(yuyang18): Convert dtype from numpy.dtype
self
.
proto
.
set_data_type
(
dtype
)
if
lod_level
is
not
None
:
# TODO(yuyang18): set_lod_level is not defined.
self
.
proto
.
set_lod_level
(
lod_level
)
self
.
block
.
vars
[
name
]
=
self
self
.
op
=
None
# TODO(yuyang18): Get methods
@
staticmethod
def
_unique_var_name_
():
uid
=
core
.
unique_integer
()
# unique during whole process.
return
"_generated_var_%d"
%
uid
class
Operator
(
object
):
def
__init__
(
self
,
block
,
proto
,
type
=
None
,
inputs
=
None
,
outputs
=
None
,
attrs
=
None
):
self
.
block
=
block
self
.
proto
=
proto
if
type
is
not
None
:
# TODO.
pass
if
inputs
is
not
None
:
# TODO
pass
if
outputs
is
not
None
:
# TODO
pass
if
attrs
is
not
None
:
# TODO
pass
# TODO: Getters
class
Block
(
object
):
def
__init__
(
self
,
program
,
idx
):
self
.
proto
=
program
.
proto
.
block
(
idx
)
self
.
vars
=
dict
()
# var_name --> var
self
.
ops
=
collections
.
deque
()
# operator list
self
.
program
=
program
@
property
def
parent_idx
(
self
):
return
self
.
proto
.
parent
@
property
def
idx
(
self
):
return
self
.
proto
.
id
def
create_var
(
self
,
*
args
,
**
kwargs
):
return
Variable
(
self
,
*
args
,
**
kwargs
)
def
append_op
(
self
,
*
args
,
**
kwargs
):
op_proto
=
self
.
proto
.
append_op
()
op
=
Operator
(
self
,
op_proto
,
*
args
,
**
kwargs
)
self
.
ops
.
append
(
op
)
return
op
def
prepend_op
(
self
,
*
args
,
**
kwargs
):
op_proto
=
self
.
proto
.
prepend_op
()
op
=
Operator
(
self
,
op_proto
,
*
args
,
**
kwargs
)
self
.
ops
.
appendleft
(
op
)
return
op
class
Program
(
object
):
@
classmethod
def
instance
(
cls
):
# From https://stackoverflow.com/questions/8212053
# Making Program as a Singleton class.
if
not
hasattr
(
cls
,
'_instance'
):
cls
.
_instance
=
cls
()
return
cls
.
_instance
def
__init__
(
self
):
assert
not
hasattr
(
self
.
__class__
,
'_instance'
),
'Do not call constructor directly!'
self
.
proto
=
core
.
ProgramDesc
.
instance
()
self
.
blocks
=
[
Block
(
self
,
0
)]
self
.
current_block_idx
=
0
def
global_block
(
self
):
return
self
.
blocks
[
0
]
def
current_block
(
self
):
return
self
.
blocks
[
self
.
current_block_idx
]
def
create_block
(
self
):
new_block_idx
=
len
(
self
.
blocks
)
self
.
proto
.
append_block
(
self
.
current_block
().
proto
)
self
.
current_block_idx
=
new_block_idx
self
.
blocks
.
append
(
Block
(
self
,
self
.
current_block_idx
))
return
self
.
current_block
()
def
rollback
(
self
):
self
.
current_block_idx
=
self
.
current_block
().
parent_idx
# program is a global instance.
g_program
=
Program
.
instance
()
python/paddle/v2/framework/tests/test_program.py
0 → 100644
浏览文件 @
7973d3a0
import
unittest
from
paddle.v2.framework.graph
import
g_program
class
TestProgram
(
unittest
.
TestCase
):
def
test_program
(
self
):
b
=
g_program
.
current_block
()
self
.
assertEqual
(
-
1
,
b
.
parent_idx
)
self
.
assertEqual
(
0
,
b
.
idx
)
b
=
g_program
.
create_block
()
self
.
assertEqual
(
1
,
b
.
idx
)
self
.
assertEqual
(
0
,
b
.
parent_idx
)
b
=
g_program
.
create_block
()
self
.
assertEqual
(
2
,
b
.
idx
)
self
.
assertEqual
(
1
,
b
.
parent_idx
)
g_program
.
rollback
()
b
=
g_program
.
current_block
()
self
.
assertEqual
(
1
,
b
.
idx
)
self
.
assertEqual
(
0
,
b
.
parent_idx
)
b
=
g_program
.
create_block
()
self
.
assertEqual
(
3
,
b
.
idx
)
self
.
assertEqual
(
1
,
b
.
parent_idx
)
g_program
.
rollback
()
b
=
g_program
.
current_block
()
self
.
assertEqual
(
1
,
b
.
idx
)
self
.
assertEqual
(
0
,
b
.
parent_idx
)
if
__name__
==
'__main__'
:
unittest
.
main
()
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录