Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
PaddlePaddle
X2Paddle
提交
c5b22aca
X
X2Paddle
项目概览
PaddlePaddle
/
X2Paddle
1 年多 前同步成功
通知
328
Star
698
Fork
167
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
26
列表
看板
标记
里程碑
合并请求
4
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
X
X2Paddle
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
26
Issue
26
列表
看板
标记
里程碑
合并请求
4
合并请求
4
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
c5b22aca
编写于
3月 14, 2019
作者:
J
jiangjiajun
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
change src dir to tf2fluid
上级
e4babb02
变更
10
展开全部
隐藏空白更改
内联
并排
Showing
10 changed file
with
435 addition
and
335 deletion
+435
-335
requirements.txt
requirements.txt
+0
-3
tensorflow2fluid/tf2fluid/__init__.py
tensorflow2fluid/tf2fluid/__init__.py
+0
-0
tensorflow2fluid/tf2fluid/convert.py
tensorflow2fluid/tf2fluid/convert.py
+71
-27
tensorflow2fluid/tf2fluid/framework_pb2.py
tensorflow2fluid/tf2fluid/framework_pb2.py
+0
-0
tensorflow2fluid/tf2fluid/graph.py
tensorflow2fluid/tf2fluid/graph.py
+0
-0
tensorflow2fluid/tf2fluid/model_loader.py
tensorflow2fluid/tf2fluid/model_loader.py
+52
-0
tensorflow2fluid/tf2fluid/paddle_emitter.py
tensorflow2fluid/tf2fluid/paddle_emitter.py
+260
-259
tensorflow2fluid/tf2fluid/tensorflow_graph.py
tensorflow2fluid/tf2fluid/tensorflow_graph.py
+11
-14
tensorflow2fluid/tf2fluid/tensorflow_parser.py
tensorflow2fluid/tf2fluid/tensorflow_parser.py
+36
-27
tensorflow2fluid/tf2fluid/utils.py
tensorflow2fluid/tf2fluid/utils.py
+5
-5
未找到文件。
requirements.txt
已删除
100644 → 0
浏览文件 @
e4babb02
paddlepaddle
tensorflow
flake8
tensorflow2fluid/
src
/__init__.py
→
tensorflow2fluid/
tf2fluid
/__init__.py
浏览文件 @
c5b22aca
文件已移动
tensorflow2fluid/
src
/convert.py
→
tensorflow2fluid/
tf2fluid
/convert.py
浏览文件 @
c5b22aca
...
...
@@ -18,33 +18,74 @@ from tensorflow_parser import TensorflowPbParser
from
six
import
text_type
as
_text_type
from
utils
import
*
import
argparse
import
logging
import
logging
import
os
logging
.
basicConfig
(
level
=
logging
.
DEBUG
)
def
_get_parser
():
parser
=
argparse
.
ArgumentParser
()
parser
.
add_argument
(
"--meta_file"
,
"-m"
,
type
=
_text_type
,
default
=
None
,
help
=
"meta file path for checkpoint format"
)
parser
.
add_argument
(
"--ckpt_dir"
,
"-c"
,
type
=
_text_type
,
default
=
None
,
help
=
"checkpoint directory"
)
parser
.
add_argument
(
"--pb_file"
,
"-p"
,
type
=
_text_type
,
default
=
None
,
help
=
"pb model file path"
)
parser
.
add_argument
(
"--in_nodes"
,
"-i"
,
type
=
_text_type
,
nargs
=
"+"
,
default
=
None
,
help
=
"input nodes name"
)
parser
.
add_argument
(
"--input_shape"
,
"-is"
,
type
=
_text_type
,
nargs
=
"+"
,
default
=
None
,
help
=
"input tensor shape"
)
parser
.
add_argument
(
"--output_nodes"
,
"-o"
,
type
=
_text_type
,
nargs
=
"+"
,
default
=
None
,
help
=
"output nodes name"
)
parser
.
add_argument
(
"--save_dir"
,
"-s"
,
type
=
_text_type
,
default
=
None
,
help
=
"path to save transformed paddle model"
)
parser
.
add_argument
(
"--input_format"
,
"-sf"
,
type
=
_text_type
,
default
=
None
,
help
=
"input data format(NHWC/NCHW or OTHER)"
)
parser
.
add_argument
(
"--use_cuda"
,
"-u"
,
type
=
_text_type
,
default
=
"True"
,
help
=
"True for use gpu"
)
parser
.
add_argument
(
"--meta_file"
,
"-m"
,
type
=
_text_type
,
default
=
None
,
help
=
"meta file path for checkpoint format"
)
parser
.
add_argument
(
"--ckpt_dir"
,
"-c"
,
type
=
_text_type
,
default
=
None
,
help
=
"checkpoint directory"
)
parser
.
add_argument
(
"--pb_file"
,
"-p"
,
type
=
_text_type
,
default
=
None
,
help
=
"pb model file path"
)
parser
.
add_argument
(
"--in_nodes"
,
"-i"
,
type
=
_text_type
,
nargs
=
"+"
,
default
=
None
,
help
=
"input nodes name"
)
parser
.
add_argument
(
"--input_shape"
,
"-is"
,
type
=
_text_type
,
nargs
=
"+"
,
default
=
None
,
help
=
"input tensor shape"
)
parser
.
add_argument
(
"--output_nodes"
,
"-o"
,
type
=
_text_type
,
nargs
=
"+"
,
default
=
None
,
help
=
"output nodes name"
)
parser
.
add_argument
(
"--save_dir"
,
"-s"
,
type
=
_text_type
,
default
=
None
,
help
=
"path to save transformed paddle model"
)
parser
.
add_argument
(
"--input_format"
,
"-sf"
,
type
=
_text_type
,
default
=
None
,
help
=
"input data format(NHWC/NCHW or OTHER)"
)
parser
.
add_argument
(
"--use_cuda"
,
"-u"
,
type
=
_text_type
,
default
=
"True"
,
help
=
"True for use gpu"
)
return
parser
def
_convert
(
args
):
def
run
(
args
):
if
args
.
meta_file
is
None
and
args
.
pb_file
is
None
:
raise
Exception
(
"Need to define --meta_file or --pb_file"
)
if
args
.
input_format
is
None
:
...
...
@@ -78,27 +119,30 @@ def _convert(args):
items
[
i
]
=
int
(
items
[
i
])
else
:
items
[
i
]
=
None
input_shape
.
append
(
items
)
logging
.
info
(
"Loading tensorflow model..."
)
if
args
.
meta_file
is
not
None
:
parser
=
TensorflowCkptParser
(
args
.
meta_file
,
args
.
ckpt_dir
,
args
.
output_nodes
,
input_shape
,
args
.
in_nodes
,
input_format
)
parser
=
TensorflowCkptParser
(
args
.
meta_file
,
args
.
ckpt_dir
,
args
.
output_nodes
,
input_shape
,
args
.
in_nodes
,
input_format
)
else
:
parser
=
TensorflowPbParser
(
args
.
pb_file
,
args
.
output_nodes
,
input_shape
,
args
.
in_nodes
,
input_format
)
parser
=
TensorflowPbParser
(
args
.
pb_file
,
args
.
output_nodes
,
input_shape
,
args
.
in_nodes
,
input_format
)
logging
.
info
(
"Tensorflow model loaded!"
)
emitter
=
PaddleEmitter
(
parser
,
args
.
save_dir
)
emitter
.
run
()
open
(
args
.
save_dir
+
"/__init__.py"
,
"w"
).
close
()
open
(
args
.
save_dir
+
"/__init__.py"
,
"w"
).
close
()
def
_main
():
parser
=
_get_parser
()
args
=
parser
.
parse_args
()
_convert
(
args
)
run
(
args
)
if
__name__
==
"__main__"
:
_main
()
tensorflow2fluid/
src
/framework_pb2.py
→
tensorflow2fluid/
tf2fluid
/framework_pb2.py
浏览文件 @
c5b22aca
文件已移动
tensorflow2fluid/
src
/graph.py
→
tensorflow2fluid/
tf2fluid
/graph.py
浏览文件 @
c5b22aca
文件已移动
tensorflow2fluid/
src/name_generato
r.py
→
tensorflow2fluid/
tf2fluid/model_loade
r.py
浏览文件 @
c5b22aca
...
...
@@ -12,35 +12,41 @@
# See the License for the specific language governing permissions and
# limitations under the License.
import
paddle.fluid
as
fluid
import
sys
class
NameGenerator
(
object
):
def
__init__
(
self
):
self
.
param_index
=
0
self
.
input_index
=
0
self
.
net_index
=
0
self
.
const_index
=
0
self
.
names
=
dict
()
def
get_name
(
self
,
node
):
ref_name
=
None
op_name
=
node
.
layer_type
class
ModelLoader
(
object
):
def
__init__
(
self
,
model_dir
,
use_cuda
=
False
):
sys
.
path
.
append
(
model_dir
)
mymodel
=
__import__
(
"mymodel"
)
self
.
model
=
mymodel
.
Model
()
self
.
model
.
build
()
self
.
inputs
=
self
.
model
.
inputs
self
.
outputs
=
self
.
model
.
outputs
if
use_cuda
:
self
.
exe
=
fluid
.
Executor
(
fluid
.
CUDAPlace
(
0
))
else
:
self
.
exe
=
fluid
.
Executor
(
fluid
.
CPUPlace
())
self
.
exe
.
run
(
fluid
.
default_startup_program
())
if
node
.
layer
.
name
in
self
.
names
:
return
self
.
names
[
node
.
layer
.
name
]
var_list
=
list
()
global_block
=
fluid
.
default_main_program
().
global_block
()
with
open
(
model_dir
+
"/save_var.list"
)
as
f
:
for
line
in
f
:
try
:
var
=
global_block
.
var
(
line
.
strip
())
var_list
.
append
(
var
)
except
:
pass
fluid
.
io
.
load_vars
(
self
.
exe
,
model_dir
,
vars
=
var_list
)
self
.
program
=
fluid
.
default_main_program
()
if
op_name
==
"variablev2"
:
ref_name
=
"param_"
+
str
(
self
.
param_index
)
self
.
param_index
+=
1
elif
op_name
==
"placeholder"
:
ref_name
=
"input_"
+
str
(
self
.
input_index
)
self
.
input_index
+=
1
elif
op_name
==
"const"
:
ref_name
=
"const_"
+
str
(
self
.
const_index
)
self
.
const_index
+=
1
elif
op_name
.
lower
()
==
"identity"
:
ref_name
=
self
.
names
[
node
.
layer
.
input
[
0
]]
else
:
ref_name
=
"net_"
+
str
(
self
.
net_index
)
self
.
net_index
+=
1
self
.
names
[
node
.
layer
.
name
]
=
ref_name
return
ref_name
def
save_inference_model
(
self
,
save_dir
):
fluid
.
io
.
save_inference_model
(
save_dir
,
self
.
model
.
inputs
,
self
.
model
.
outputs
,
self
.
exe
)
def
inference
(
self
,
feed_dict
):
result
=
self
.
exe
.
run
(
self
.
program
,
feed
=
feed_dict
,
fetch_list
=
self
.
model
.
outputs
)
return
result
tensorflow2fluid/
src
/paddle_emitter.py
→
tensorflow2fluid/
tf2fluid
/paddle_emitter.py
浏览文件 @
c5b22aca
此差异已折叠。
点击以展开。
tensorflow2fluid/
src
/tensorflow_graph.py
→
tensorflow2fluid/
tf2fluid
/tensorflow_graph.py
浏览文件 @
c5b22aca
...
...
@@ -16,6 +16,7 @@ from graph import GraphNode, Graph
from
tensorflow.core.framework
import
attr_value_pb2
from
utils
import
*
class
TensorflowGraphNode
(
GraphNode
):
dtype_map
=
{
1
:
"float32"
,
3
:
"int32"
,
9
:
"int64"
}
...
...
@@ -64,18 +65,13 @@ class TensorflowGraphNode(GraphNode):
return
val
if
isinstance
(
val
,
bytes
)
else
val
else
:
return
default_value
def
clear_code
(
self
):
self
.
code
.
clear
()
class
TensorflowGraph
(
Graph
):
useless_type
=
[
'identity'
,
'placeholderwithdefault'
,
'switch'
,
'merge'
]
useless_type
=
[
'identity'
,
'placeholderwithdefault'
,
'switch'
,
'merge'
]
def
__init__
(
self
,
tf_graph
):
super
(
TensorflowGraph
,
self
).
__init__
(
tf_graph
)
...
...
@@ -84,7 +80,8 @@ class TensorflowGraph(Graph):
def
build
(
self
,
input_format
):
skip_node
=
set
([
'const'
])
for
i
,
layer
in
enumerate
(
self
.
tf_graph
.
node
):
self
.
node_map
[
layer
.
name
]
=
TensorflowGraphNode
(
layer
,
input_format
)
self
.
node_map
[
layer
.
name
]
=
TensorflowGraphNode
(
layer
,
input_format
)
for
i
,
layer
in
enumerate
(
self
.
tf_graph
.
node
):
if
layer
.
op
.
lower
()
in
skip_node
:
...
...
@@ -94,22 +91,22 @@ class TensorflowGraph(Graph):
':'
)[
0
]
in
self
.
node_map
:
pred_node
=
self
.
node_map
[
pred
.
split
(
':'
)[
0
]]
if
pred_node
.
layer_type
==
"switch"
:
self
.
_make_connection
(
pred_node
,
self
.
node_map
[
layer
.
name
])
self
.
_make_connection
(
pred_node
,
self
.
node_map
[
layer
.
name
])
elif
pred_node
.
layer_type
==
"split"
or
\
pred_node
.
layer_type
==
"splitv"
:
self
.
node_map
[
pred
]
=
TensorflowGraphNode
(
pred_node
.
layer
,
input_format
,
pred
)
self
.
_make_connection
(
self
.
node_map
[
pred
],
self
.
node_map
[
layer
.
name
])
self
.
_make_connection
(
self
.
node_map
[
pred
],
self
.
node_map
[
layer
.
name
])
self
.
_make_connection
(
pred_node
,
self
.
node_map
[
pred
])
else
:
raise
Exception
(
"Unsupported situation(name:[{}],
\
OP[{}])"
.
format
(
node
.
layer_name
,
node
.
layer_type
))
elif
pred
in
self
.
node_map
:
self
.
_make_connection
(
self
.
node_map
[
pred
],
self
.
node_map
[
layer
.
name
])
self
.
_make_connection
(
self
.
node_map
[
pred
],
self
.
node_map
[
layer
.
name
])
else
:
raise
Exception
(
"input: {} not in node_map"
.
format
(
pred
))
...
...
tensorflow2fluid/
src
/tensorflow_parser.py
→
tensorflow2fluid/
tf2fluid
/tensorflow_parser.py
浏览文件 @
c5b22aca
...
...
@@ -19,6 +19,7 @@ from tensorflow.python.tools import strip_unused_lib
from
tensorflow.python.framework
import
dtypes
import
numpy
class
TensorflowCkptParser
(
object
):
def
__init__
(
self
,
meta_file
,
...
...
@@ -29,21 +30,22 @@ class TensorflowCkptParser(object):
input_format
=
"NCHW"
.
encode
()):
graph_def
=
None
self
.
weights
=
None
self
.
inputs
=
in_nodes
self
.
outputs
=
dest_nodes
sess
=
tf
.
Session
()
if
meta_file
is
None
:
raise
Exception
(
"meta_file must be provided"
)
new_saver
=
tf
.
train
.
import_meta_graph
(
meta_file
)
if
checkpoint_file
is
not
None
:
self
.
weights
=
dict
()
new_saver
.
restore
(
sess
,
tf
.
train
.
latest_checkpoint
(
checkpoint_file
))
new_saver
.
restore
(
sess
,
tf
.
train
.
latest_checkpoint
(
checkpoint_file
))
for
var
in
tf
.
global_variables
():
value
=
var
.
eval
(
sess
)
self
.
weights
[
var
.
name
.
split
(
':'
)[
0
]]
=
value
self
.
infer
=
ModelInfer
(
sess
)
graph_def
,
ver
=
tf
.
get_default_graph
().
_as_graph_def
(
add_shapes
=
True
)
graph_def
,
ver
=
tf
.
get_default_graph
().
_as_graph_def
(
add_shapes
=
True
)
if
in_nodes
is
not
None
and
input_shape
is
not
None
:
graph_def
=
strip_unused_lib
.
strip_unused
(
...
...
@@ -58,7 +60,8 @@ class TensorflowCkptParser(object):
shape
=
[
tf
.
Dimension
(
x
)
for
x
in
input_shape
[
index
]]
shape_proto
=
tf
.
TensorShape
(
shape
).
as_proto
()
node
.
attr
[
'_output_shapes'
].
list
.
shape
.
pop
()
node
.
attr
[
'_output_shapes'
].
list
.
shape
.
extend
([
shape_proto
])
node
.
attr
[
'_output_shapes'
].
list
.
shape
.
extend
(
[
shape_proto
])
self
.
infer
.
gen_sample_data
(
node
.
name
,
input_shape
[
index
])
self
.
tf_graph
=
TensorflowGraph
(
graph_def
)
...
...
@@ -69,14 +72,20 @@ class TensorflowCkptParser(object):
class
TensorflowPbParser
(
object
):
def
__init__
(
self
,
pb_file
,
dest_nodes
,
input_shape
=
None
,
in_nodes
=
None
,
input_format
=
"NCHW"
.
encode
()):
def
__init__
(
self
,
pb_file
,
dest_nodes
,
input_shape
=
None
,
in_nodes
=
None
,
input_format
=
"NCHW"
.
encode
()):
with
open
(
pb_file
,
'rb'
)
as
f
:
serialized
=
f
.
read
()
tf
.
reset_default_graph
()
original_graph_def
=
tf
.
GraphDef
()
original_graph_def
.
ParseFromString
(
serialized
)
self
.
inputs
=
list
()
self
.
outputs
=
dest_nodes
sess
=
tf
.
Session
(
graph
=
tf
.
get_default_graph
())
sess
.
run
(
tf
.
global_variables_initializer
())
self
.
infer
=
ModelInfer
(
sess
)
...
...
@@ -111,11 +120,11 @@ class TensorflowPbParser(object):
raise
Exception
(
"Unexpected dtype for input, only support "
\
"float32 and int32 now"
)
input_map
[
in_nodes
[
i
]
+
":0"
]
=
x
self
.
inputs
.
append
(
x
.
name
.
split
(
':'
)[
0
])
self
.
infer
.
gen_sample_data
(
x
.
name
,
input_shape
[
i
])
tf
.
import_graph_def
(
graph_def
,
name
=
""
,
input_map
=
input_map
)
graph_def
=
tf
.
get_default_graph
().
_as_graph_def
(
add_shapes
=
True
)[
0
]
graph_def
=
tf
.
get_default_graph
().
_as_graph_def
(
add_shapes
=
True
)[
0
]
self
.
tf_graph
=
TensorflowGraph
(
graph_def
)
self
.
tf_graph
.
build
(
input_format
)
...
...
@@ -164,7 +173,7 @@ class ModelInfer(object):
if
len
(
tensor_name
.
split
(
':'
))
<
2
:
tensor_name
=
tensor_name
+
':0'
output_tensor
=
self
.
sess
.
graph
.
get_tensor_by_name
(
tensor_name
)
tensor_values
=
[]
for
i
in
range
(
0
,
3
):
inputs_tensors
=
dict
()
...
...
@@ -175,19 +184,19 @@ class ModelInfer(object):
inputs_tensors
[
tensor
]
=
values
[
i
]
r
,
=
self
.
sess
.
run
([
output_tensor
],
inputs_tensors
)
tensor_values
.
append
(
r
.
flatten
())
compare01
=
(
tensor_values
[
0
]
==
tensor_values
[
1
])
compare12
=
(
tensor_values
[
1
]
==
tensor_values
[
2
])
if
compare01
.
all
()
and
compare12
.
all
():
return
tensor_values
[
0
]
if
(
compare01
==
compare12
).
all
():
index
=
numpy
.
argwhere
(
compare01
==
False
).
flatten
()
index
=
numpy
.
argwhere
(
compare01
==
False
).
flatten
()
if
index
.
shape
[
0
]
!=
1
:
raise
Exception
(
"There's not only one unstable dimension"
)
tensor_values
[
0
][
index
[
0
]]
=
-
1
index
=
numpy
.
argwhere
(
tensor_values
[
0
]
<
0
).
flatten
()
if
index
.
shape
[
0
]
>
2
:
raise
Exception
(
"There's more than two values less than zero"
)
...
...
@@ -199,17 +208,17 @@ class ModelInfer(object):
return
tensor_values
[
0
]
else
:
raise
Exception
(
"Can not infer a stable shape tensor value"
)
def
get_tensor_shape
(
self
,
layer
):
shape
=
layer
.
attr
[
'_output_shapes'
].
list
.
shape
[
0
]
shape
=
numpy
.
array
([
dim
.
size
for
dim
in
shape
.
dim
])
if
numpy
.
argwhere
(
shape
<
0
).
shape
[
0
]
<=
1
:
if
numpy
.
argwhere
(
shape
<
0
).
shape
[
0
]
<=
1
:
return
shape
tensor_name
=
layer
.
name
if
len
(
tensor_name
.
split
(
':'
))
<
2
:
tensor_name
=
tensor_name
+
':0'
output_tensor
=
self
.
sess
.
graph
.
get_tensor_by_name
(
tensor_name
)
shapes
=
[]
for
i
in
range
(
0
,
3
):
inputs_tensors
=
dict
()
...
...
@@ -220,15 +229,15 @@ class ModelInfer(object):
inputs_tensors
[
tensor
]
=
values
[
i
]
r
,
=
self
.
sess
.
run
([
output_tensor
],
inputs_tensors
)
shapes
.
append
(
numpy
.
array
(
r
.
shape
))
compare01
=
(
shapes
[
0
]
==
shapes
[
1
])
compare12
=
(
shapes
[
1
]
==
shapes
[
2
])
if
compare01
.
all
()
and
compare12
.
all
():
return
shapes
[
0
]
if
(
compare01
==
compare12
).
all
():
index
=
numpy
.
argwhere
(
compare01
==
False
).
flatten
()
index
=
numpy
.
argwhere
(
compare01
==
False
).
flatten
()
if
index
.
shape
[
0
]
!=
1
:
raise
Exception
(
"There's not only one unstable dimension"
)
if
index
[
0
]
!=
0
:
...
...
@@ -237,13 +246,13 @@ class ModelInfer(object):
return
shapes
[
0
]
else
:
raise
Exception
(
"Can not infer a stable tensor shape, failed!"
)
def
get_const_tensor_value
(
self
,
layer
):
tensor_name
=
layer
.
name
if
len
(
tensor_name
.
split
(
':'
))
<
2
:
tensor_name
=
tensor_name
+
':0'
output_tensor
=
self
.
sess
.
graph
.
get_tensor_by_name
(
tensor_name
)
result
=
[]
for
i
in
range
(
0
,
3
):
inputs_tensors
=
dict
()
...
...
@@ -254,10 +263,10 @@ class ModelInfer(object):
inputs_tensors
[
tensor
]
=
values
[
i
]
r
,
=
self
.
sess
.
run
([
output_tensor
],
inputs_tensors
)
result
.
append
(
r
)
compare01
=
(
result
[
0
]
==
result
[
1
])
compare12
=
(
result
[
1
]
==
result
[
2
])
if
compare01
.
all
()
and
compare12
.
all
():
return
result
[
0
]
else
:
...
...
tensorflow2fluid/
src
/utils.py
→
tensorflow2fluid/
tf2fluid
/utils.py
浏览文件 @
c5b22aca
...
...
@@ -22,7 +22,6 @@ VALID = 'VALID'.encode()
class
NameGenerator
(
object
):
def
__init__
(
self
):
self
.
param_index
=
0
self
.
input_index
=
0
self
.
net_index
=
0
self
.
const_index
=
0
self
.
names
=
dict
()
...
...
@@ -38,8 +37,7 @@ class NameGenerator(object):
ref_name
=
"param_"
+
str
(
self
.
param_index
)
self
.
param_index
+=
1
elif
op_name
==
"placeholder"
:
ref_name
=
"input_"
+
str
(
self
.
input_index
)
self
.
input_index
+=
1
ref_name
=
node
.
layer
.
name
elif
op_name
==
"const"
:
ref_name
=
"const_"
+
str
(
self
.
const_index
)
self
.
const_index
+=
1
...
...
@@ -76,11 +74,13 @@ class LayerCode(object):
layer_code2
=
""
for
k
,
v
in
self
.
param_attr
.
items
():
layer_code2
=
layer_code2
+
k
+
"="
+
"{}"
.
format
(
v
)
+
", "
layer_code2
=
layer_code2
.
strip
(
", "
)
layer_code2
=
layer_code2
.
strip
(
", "
)
layer_code
=
(
layer_code0
+
layer_code1
+
layer_code2
).
strip
(
", "
)
+
")"
layer_code
=
(
layer_code0
+
layer_code1
+
layer_code2
).
strip
(
", "
)
+
")"
return
layer_code
class
FluidCode
(
object
):
def
__init__
(
self
):
self
.
codes
=
list
()
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录