Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
PaddlePaddle
Paddle-Lite
提交
5a5927ac
P
Paddle-Lite
项目概览
PaddlePaddle
/
Paddle-Lite
通知
332
Star
4
Fork
1
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
271
列表
看板
标记
里程碑
合并请求
78
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
P
Paddle-Lite
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
271
Issue
271
列表
看板
标记
里程碑
合并请求
78
合并请求
78
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
5a5927ac
编写于
6月 27, 2018
作者:
R
Ruilong Liu
提交者:
GitHub
6月 27, 2018
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #467 from codeWorm2015/metal
complete Skeleton Code
上级
888877ff
a2fe77b1
变更
15
隐藏空白更改
内联
并排
Showing
15 changed file
with
349 addition
and
207 deletion
+349
-207
metal/paddle-mobile/paddle-mobile.xcodeproj/project.pbxproj
metal/paddle-mobile/paddle-mobile.xcodeproj/project.pbxproj
+4
-0
metal/paddle-mobile/paddle-mobile/Common/Types.swift
metal/paddle-mobile/paddle-mobile/Common/Types.swift
+4
-54
metal/paddle-mobile/paddle-mobile/Executor.swift
metal/paddle-mobile/paddle-mobile/Executor.swift
+34
-2
metal/paddle-mobile/paddle-mobile/Loader.swift
metal/paddle-mobile/paddle-mobile/Loader.swift
+38
-101
metal/paddle-mobile/paddle-mobile/Operators/Base/OpCreator.swift
...addle-mobile/paddle-mobile/Operators/Base/OpCreator.swift
+51
-0
metal/paddle-mobile/paddle-mobile/Operators/Base/OpParam.swift
.../paddle-mobile/paddle-mobile/Operators/Base/OpParam.swift
+8
-0
metal/paddle-mobile/paddle-mobile/Operators/Base/Operator.swift
...paddle-mobile/paddle-mobile/Operators/Base/Operator.swift
+18
-1
metal/paddle-mobile/paddle-mobile/Operators/ConvOp.swift
metal/paddle-mobile/paddle-mobile/Operators/ConvOp.swift
+19
-18
metal/paddle-mobile/paddle-mobile/Operators/FeedOp.swift
metal/paddle-mobile/paddle-mobile/Operators/FeedOp.swift
+0
-1
metal/paddle-mobile/paddle-mobile/Operators/FetchOp.swift
metal/paddle-mobile/paddle-mobile/Operators/FetchOp.swift
+4
-4
metal/paddle-mobile/paddle-mobile/Program/BlockDesc.swift
metal/paddle-mobile/paddle-mobile/Program/BlockDesc.swift
+0
-3
metal/paddle-mobile/paddle-mobile/Program/TensorDesc.swift
metal/paddle-mobile/paddle-mobile/Program/TensorDesc.swift
+36
-1
metal/paddle-mobile/paddle-mobile/framework/Dim.swift
metal/paddle-mobile/paddle-mobile/framework/Dim.swift
+6
-0
metal/paddle-mobile/paddle-mobile/framework/Tensor.swift
metal/paddle-mobile/paddle-mobile/framework/Tensor.swift
+101
-15
metal/paddle-mobile/paddle-mobile/framework/Texture.swift
metal/paddle-mobile/paddle-mobile/framework/Texture.swift
+26
-7
未找到文件。
metal/paddle-mobile/paddle-mobile.xcodeproj/project.pbxproj
浏览文件 @
5a5927ac
...
...
@@ -30,6 +30,7 @@
FC039BBE20E11CC20081E9F8
/* OpDesc.swift in Sources */
=
{
isa
=
PBXBuildFile
;
fileRef
=
FC039BB520E11CC20081E9F8
/* OpDesc.swift */
;
};
FC039BBF20E11CC20081E9F8
/* Attribute.swift in Sources */
=
{
isa
=
PBXBuildFile
;
fileRef
=
FC039BB620E11CC20081E9F8
/* Attribute.swift */
;
};
FC039BC020E11CC20081E9F8
/* BlockDesc.swift in Sources */
=
{
isa
=
PBXBuildFile
;
fileRef
=
FC039BB720E11CC20081E9F8
/* BlockDesc.swift */
;
};
FC82735920E3C04200BE430A
/* OpCreator.swift in Sources */
=
{
isa
=
PBXBuildFile
;
fileRef
=
FC82735820E3C04200BE430A
/* OpCreator.swift */
;
};
FC9D037920E229E4000F735A
/* OpParam.swift in Sources */
=
{
isa
=
PBXBuildFile
;
fileRef
=
FC9D037820E229E4000F735A
/* OpParam.swift */
;
};
FC9D038020E22FBB000F735A
/* FeedOp.swift in Sources */
=
{
isa
=
PBXBuildFile
;
fileRef
=
FC9D037F20E22FBB000F735A
/* FeedOp.swift */
;
};
FC9D038220E2312E000F735A
/* FetchOp.swift in Sources */
=
{
isa
=
PBXBuildFile
;
fileRef
=
FC9D038120E2312E000F735A
/* FetchOp.swift */
;
};
...
...
@@ -64,6 +65,7 @@
FC039BB520E11CC20081E9F8
/* OpDesc.swift */
=
{
isa
=
PBXFileReference
;
fileEncoding
=
4
;
lastKnownFileType
=
sourcecode.swift
;
path
=
OpDesc.swift
;
sourceTree
=
"<group>"
;
};
FC039BB620E11CC20081E9F8
/* Attribute.swift */
=
{
isa
=
PBXFileReference
;
fileEncoding
=
4
;
lastKnownFileType
=
sourcecode.swift
;
path
=
Attribute.swift
;
sourceTree
=
"<group>"
;
};
FC039BB720E11CC20081E9F8
/* BlockDesc.swift */
=
{
isa
=
PBXFileReference
;
fileEncoding
=
4
;
lastKnownFileType
=
sourcecode.swift
;
path
=
BlockDesc.swift
;
sourceTree
=
"<group>"
;
};
FC82735820E3C04200BE430A
/* OpCreator.swift */
=
{
isa
=
PBXFileReference
;
lastKnownFileType
=
sourcecode.swift
;
path
=
OpCreator.swift
;
sourceTree
=
"<group>"
;
};
FC9D037820E229E4000F735A
/* OpParam.swift */
=
{
isa
=
PBXFileReference
;
lastKnownFileType
=
sourcecode.swift
;
path
=
OpParam.swift
;
sourceTree
=
"<group>"
;
};
FC9D037F20E22FBB000F735A
/* FeedOp.swift */
=
{
isa
=
PBXFileReference
;
lastKnownFileType
=
sourcecode.swift
;
path
=
FeedOp.swift
;
sourceTree
=
"<group>"
;
};
FC9D038120E2312E000F735A
/* FetchOp.swift */
=
{
isa
=
PBXFileReference
;
lastKnownFileType
=
sourcecode.swift
;
path
=
FetchOp.swift
;
sourceTree
=
"<group>"
;
};
...
...
@@ -195,6 +197,7 @@
children
=
(
FC9D037820E229E4000F735A
/* OpParam.swift */
,
FC039BA620E11CBC0081E9F8
/* Operator.swift */
,
FC82735820E3C04200BE430A
/* OpCreator.swift */
,
);
path
=
Base
;
sourceTree
=
"<group>"
;
...
...
@@ -316,6 +319,7 @@
FC039BB920E11CC20081E9F8
/* Scope.swift in Sources */
,
FC039BAC20E11CBC0081E9F8
/* BatchNormOp.swift in Sources */
,
FC039BBC20E11CC20081E9F8
/* VarDesc.swift in Sources */
,
FC82735920E3C04200BE430A
/* OpCreator.swift in Sources */
,
FC039BAB20E11CBC0081E9F8
/* Operator.swift in Sources */
,
FC9D038220E2312E000F735A
/* FetchOp.swift in Sources */
,
FC039BBD20E11CC20081E9F8
/* Program.swift in Sources */
,
...
...
metal/paddle-mobile/paddle-mobile/Common/Types.swift
浏览文件 @
5a5927ac
...
...
@@ -24,69 +24,19 @@ public protocol PrecisionType {
extension
Float32
:
PrecisionType
{
}
enum
DataLayout
{
public
enum
DataLayout
{
case
NCHW
case
NHWC
}
protocol
Variant
{
protocol
Variant
:
CustomStringConvertible
,
CustomDebugStringConvertible
{
}
extension
Tensor
:
Variant
{
}
extension
Texture
:
Variant
{
}
let
gFetchType
=
"fetch"
let
gFeedType
=
"feed"
let
gConvType
=
"conv2d"
let
gBatchNormType
=
"batch_norm"
let
gReluType
=
"relu"
let
gElementwiseAdd
=
"elementwise_add"
fileprivate
var
singletons
:
[
String
:
Any
]
=
[:]
class
OpCreator
<
P
:
PrecisionType
>
{
static
var
shared
:
OpCreator
<
P
>
{
let
key
=
String
(
describing
:
P
.
self
)
if
let
singleton
=
singletons
[
key
]
{
return
singleton
as!
OpCreator
<
P
>
}
else
{
let
newSingleton
=
OpCreator
<
P
>
()
singletons
[
key
]
=
newSingleton
return
newSingleton
}
}
func
creat
(
opDesc
:
OpDesc
,
scope
:
Scope
)
throws
->
Runable
&
InferShaperable
{
guard
let
opCreator
=
opCreators
[
opDesc
.
type
]
else
{
throw
PaddleMobileError
.
opError
(
message
:
"there is no "
+
opDesc
.
type
+
" yet"
)
}
do
{
return
try
opCreator
(
opDesc
,
scope
)
}
catch
let
error
{
throw
error
}
}
let
opCreators
:
[
String
:
(
OpDesc
,
Scope
)
throws
->
Runable
&
InferShaperable
]
=
[
gConvType
:
ConvOp
<
P
>.
creat
,
gBatchNormType
:
BatchNormOp
<
P
>.
creat
,
gReluType
:
ReluOp
<
P
>.
creat
,
gElementwiseAdd
:
ElementwiseAddOp
<
P
>.
creat
,
gFeedType
:
FeedOp
<
P
>.
creat
,
gFetchType
:
FetchOp
<
P
>.
creat
]
private
init
(){}
extension
ResultHolder
:
Variant
{
}
let
opInfos
=
[
gConvType
:
(
inputs
:
[
"Input"
],
outputs
:
[
"Output"
]),
gBatchNormType
:
(
inputs
:
[
"X"
],
outputs
:
[
"Y"
]),
gReluType
:
(
inputs
:
[
"X"
],
outputs
:
[
"Out"
]),
gElementwiseAdd
:
(
inputs
:
[
"X"
,
"Y"
],
outputs
:
[
"Out"
]),
gFeedType
:
(
inputs
:
[
"X"
],
outputs
:
[
"Out"
]),
gFetchType
:
(
inputs
:
[
"X"
],
outputs
:
[
"Out"
])]
metal/paddle-mobile/paddle-mobile/Executor.swift
浏览文件 @
5a5927ac
...
...
@@ -14,9 +14,41 @@
import
Foundation
public
class
ResultHolder
<
P
:
PrecisionType
>
{
public
let
dim
:
[
Int
]
public
let
resultArr
:
[
P
]
public
init
(
inDim
:
[
Int
],
inResult
:
[
P
])
{
dim
=
inDim
resultArr
=
inResult
}
}
extension
ResultHolder
:
CustomDebugStringConvertible
,
CustomStringConvertible
{
public
var
debugDescription
:
String
{
var
str
=
""
str
+=
"Dim:
\(
dim
)
\n
value:[ "
if
resultArr
.
count
<
20
{
for
d
in
resultArr
{
str
+=
"
\(
d
)
"
}
}
else
{
for
d
in
stride
(
from
:
0
,
to
:
resultArr
.
count
,
by
:
resultArr
.
count
/
20
)
{
str
+=
"
\(
resultArr
[
d
]
)
"
}
}
str
+=
" ]"
return
str
}
public
var
description
:
String
{
return
debugDescription
}
}
public
class
Executor
<
P
:
PrecisionType
>
{
var
ops
:
[
Runable
&
InferShaperable
]
=
[]
let
program
:
Program
public
init
(
inProgram
:
Program
)
throws
{
program
=
inProgram
for
block
in
inProgram
.
programDesc
.
blocks
{
...
...
@@ -32,13 +64,13 @@ public class Executor<P: PrecisionType> {
}
}
public
func
predict
(
input
:
Texture
)
throws
->
Texture
{
public
func
predict
(
input
:
Texture
)
throws
->
ResultHolder
<
P
>
{
program
.
scope
[
program
.
feedKey
]
=
input
for
op
in
ops
{
op
.
run
()
}
let
outputVar
=
program
.
scope
[
program
.
fetchKey
]
guard
let
output
=
outputVar
as?
Texture
else
{
guard
let
output
=
outputVar
as?
ResultHolder
<
P
>
else
{
throw
PaddleMobileError
.
netError
(
message
:
"output var type error"
)
}
return
output
...
...
metal/paddle-mobile/paddle-mobile/Loader.swift
浏览文件 @
5a5927ac
...
...
@@ -15,72 +15,6 @@
import
Foundation
import
SwiftProtobuf
class
ParamData
<
P
:
PrecisionType
>
{
let
size
:
Int
var
dim
:
Dim
private(set)
var
layout
:
DataLayout
var
pointer
:
UnsafeMutablePointer
<
P
>
init
(
inDim
:
Dim
,
inLayout
:
DataLayout
=
.
NCHW
)
{
dim
=
inDim
size
=
inDim
.
numel
()
*
MemoryLayout
<
P
>.
size
pointer
=
UnsafeMutablePointer
<
P
>.
allocate
(
capacity
:
size
)
layout
=
inLayout
}
func
convert
(
to
:
DataLayout
)
{
guard
to
!=
layout
else
{
return
}
guard
dim
.
cout
()
==
4
else
{
return
}
guard
layout
==
.
NCHW
&&
to
==
.
NHWC
else
{
// other not support
return
}
let
newPointer
=
UnsafeMutablePointer
<
P
>.
allocate
(
capacity
:
size
)
if
layout
==
.
NCHW
{
NCHW2NHWC
(
newPtr
:
newPointer
)
}
pointer
.
deinitialize
(
count
:
size
)
pointer
.
deallocate
()
pointer
=
newPointer
layout
=
to
}
func
NCHW2NHWC
(
newPtr
:
UnsafeMutablePointer
<
P
>
)
{
let
N
=
dim
[
0
]
let
C
=
dim
[
1
]
let
H
=
dim
[
2
]
let
W
=
dim
[
3
]
let
HXW
=
H
*
W
let
CXHXW
=
C
*
H
*
W
var
index
:
Int
=
0
for
n
in
0
..<
N
{
for
h
in
0
..<
H
{
for
w
in
0
..<
W
{
for
c
in
0
..<
C
{
newPtr
[
index
]
=
pointer
[
n
*
CXHXW
+
c
*
HXW
+
h
*
w
+
w
]
index
+=
1
}
}
}
}
dim
.
swapeDimAt
(
index1
:
1
,
index2
:
3
)
}
deinit
{
pointer
.
deinitialize
(
count
:
size
)
pointer
.
deallocate
()
}
}
public
class
Loader
<
P
:
PrecisionType
>
{
class
ParaLoader
{
...
...
@@ -101,7 +35,7 @@ public class Loader<P: PrecisionType> {
nowIndex
=
0
}
func
read
(
data
:
ParamData
<
P
>
)
throws
{
func
read
(
tensor
:
Tensor
<
P
>
)
throws
{
guard
nowIndex
<=
fileSize
else
{
throw
PaddleMobileError
.
loaderError
(
message
:
"out of the file range"
)
}
...
...
@@ -135,8 +69,8 @@ public class Loader<P: PrecisionType> {
这里没有根据 Data Type 去判断, 而是从外部泛型直接指定了精度
*/
let
bytesRead
=
fread
(
data
.
pointer
,
1
,
data
.
size
,
file
)
guard
bytesRead
==
data
.
size
else
{
let
bytesRead
=
fread
(
tensor
.
data
.
pointer
,
1
,
tensor
.
data
.
size
,
file
)
guard
bytesRead
==
tensor
.
data
.
size
else
{
throw
PaddleMobileError
.
loaderError
(
message
:
"param read size error"
)
}
nowIndex
+=
bytesRead
...
...
@@ -166,63 +100,66 @@ public class Loader<P: PrecisionType> {
throw
PaddleMobileError
.
loaderError
(
message
:
"count of blocks must greater than 0"
)
}
// to get feed key and fetch key
let
block
=
programDesc
.
blocks
[
0
]
guard
let
firstOp
=
block
.
ops
.
first
,
let
lastOp
=
block
.
ops
.
last
else
{
throw
PaddleMobileError
.
loaderError
(
message
:
"at least two operator"
)
}
guard
firstOp
.
type
==
gFeedType
,
lastOp
.
type
==
gFetchType
else
{
throw
PaddleMobileError
.
loaderError
(
message
:
"the first op is not feed or the last op is not fetch"
)
}
guard
let
inputKey
=
opInfos
[
gFeedType
]?
.
inputs
.
first
,
let
outKey
=
opInfos
[
gFetchType
]?
.
outputs
.
first
else
{
throw
PaddleMobileError
.
loaderError
(
message
:
"the feed input key or fetch output key not found"
)
}
guard
let
feedKey
=
firstOp
.
inputs
[
inputKey
]?
.
first
,
let
fetchKey
=
lastOp
.
outputs
[
outKey
]?
.
first
else
{
throw
PaddleMobileError
.
loaderError
(
message
:
"feed key or fetch key not found"
)
}
// to load memory
for
block
in
programDesc
.
blocks
{
for
varDesc
in
block
.
vars
{
print
(
varDesc
.
name
+
"
\(
varDesc
.
persistable
)
"
)
if
(
varDesc
.
type
==
.
LodTensor
)
{
guard
let
tensorDesc
=
varDesc
.
tensorDesc
else
{
throw
PaddleMobileError
.
loaderError
(
message
:
"get tensor desc failed"
)
}
guard
(
try
?
tensorDesc
.
dataType
.
dataTypeSize
())
==
MemoryLayout
<
P
>.
size
else
{
throw
PaddleMobileError
.
memoryError
(
message
:
"PrecisionType not support"
)
}
if
(
varDesc
.
persistable
&&
varDesc
.
type
!=
.
FeedMiniBatch
&&
varDesc
.
type
!=
.
FetchList
)
{
guard
let
tensorDesc
=
varDesc
.
tensorDesc
else
{
throw
PaddleMobileError
.
loaderError
(
message
:
"get tensor desc failed"
)
}
guard
(
try
?
tensorDesc
.
dataType
.
dataTypeSize
())
==
MemoryLayout
<
P
>.
size
else
{
throw
PaddleMobileError
.
memoryError
(
message
:
"PrecisionType not support"
)
}
let
dimArr
=
tensorDesc
.
dims
guard
dimArr
.
count
>
0
else
{
throw
PaddleMobileError
.
loaderError
(
message
:
"tensor desc dim size error"
)
}
let
dim
=
Dim
.
init
(
inDim
:
dimArr
)
let
paraData
=
ParamData
<
P
>.
init
(
inDim
:
dim
)
let
tensor
=
Tensor
<
P
>.
init
(
inDim
:
dim
,
inLayout
:
tensorDesc
.
dataLayout
)
do
{
try
paraLoader
.
read
(
data
:
paraData
)
try
paraLoader
.
read
(
tensor
:
tensor
)
}
catch
let
error
{
throw
error
}
paraData
.
convert
(
to
:
.
NHWC
)
let
tensor
=
Tensor
<
P
>.
init
(
inData
:
paraData
)
tensor
.
convert
(
to
:
.
NHWC
)
scope
[
varDesc
.
name
]
=
tensor
}
else
{
scope
[
varDesc
.
name
]
=
Texture
.
init
()
let
dim
=
Dim
.
init
(
inDim
:
tensorDesc
.
NHWCDim
)
scope
[
varDesc
.
name
]
=
Texture
.
init
(
inDim
:
dim
,
inLayout
:
.
NHWC
)
}
}
else
{
scope
[
varDesc
.
name
]
=
Texture
.
init
()
if
varDesc
.
name
==
fetchKey
{
scope
[
varDesc
.
name
]
=
ResultHolder
<
P
>.
init
(
inDim
:
[],
inResult
:
[])
}
else
if
varDesc
.
name
==
feedKey
{
scope
[
varDesc
.
name
]
=
Texture
.
init
()
}
}
}
}
let
block
=
programDesc
.
blocks
[
0
]
guard
let
firstOp
=
block
.
ops
.
first
,
let
lastOp
=
block
.
ops
.
last
else
{
throw
PaddleMobileError
.
loaderError
(
message
:
"at least two operator"
)
}
guard
firstOp
.
type
==
gFeedType
,
lastOp
.
type
==
gFetchType
else
{
throw
PaddleMobileError
.
loaderError
(
message
:
"the first op is not feed or the last op is not fetch"
)
}
guard
let
inputKey
=
opInfos
[
gFeedType
]?
.
inputs
.
first
,
let
outKey
=
opInfos
[
gFetchType
]?
.
outputs
.
first
else
{
throw
PaddleMobileError
.
loaderError
(
message
:
"the feed input key or fetch output key not found"
)
}
guard
let
feedKey
=
firstOp
.
inputs
[
inputKey
]?
.
first
,
let
fetchKey
=
lastOp
.
outputs
[
outKey
]?
.
first
else
{
throw
PaddleMobileError
.
loaderError
(
message
:
"feed key or fetch key not found"
)
}
let
program
=
Program
.
init
(
protoProgramDesc
:
protoProgram
,
inParamPath
:
paraPath
,
inScope
:
scope
,
inFeedKey
:
feedKey
,
inFetchKey
:
fetchKey
)
return
program
...
...
metal/paddle-mobile/paddle-mobile/Operators/Base/OpCreator.swift
0 → 100644
浏览文件 @
5a5927ac
/* Copyright (c) 2018 PaddlePaddle Authors. All Rights Reserved.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License. */
import
Foundation
fileprivate
var
singletons
:
[
String
:
Any
]
=
[:]
class
OpCreator
<
P
:
PrecisionType
>
{
static
var
shared
:
OpCreator
<
P
>
{
let
key
=
String
(
describing
:
P
.
self
)
if
let
singleton
=
singletons
[
key
]
{
return
singleton
as!
OpCreator
<
P
>
}
else
{
let
newSingleton
=
OpCreator
<
P
>
()
singletons
[
key
]
=
newSingleton
return
newSingleton
}
}
func
creat
(
opDesc
:
OpDesc
,
scope
:
Scope
)
throws
->
Runable
&
InferShaperable
{
guard
let
opCreator
=
opCreators
[
opDesc
.
type
]
else
{
throw
PaddleMobileError
.
opError
(
message
:
"there is no "
+
opDesc
.
type
+
" yet"
)
}
do
{
return
try
opCreator
(
opDesc
,
scope
)
}
catch
let
error
{
throw
error
}
}
let
opCreators
:
[
String
:
(
OpDesc
,
Scope
)
throws
->
Runable
&
InferShaperable
]
=
[
gConvType
:
ConvOp
<
P
>.
creat
,
gBatchNormType
:
BatchNormOp
<
P
>.
creat
,
gReluType
:
ReluOp
<
P
>.
creat
,
gElementwiseAdd
:
ElementwiseAddOp
<
P
>.
creat
,
gFeedType
:
FeedOp
<
P
>.
creat
,
gFetchType
:
FetchOp
<
P
>.
creat
]
private
init
(){}
}
metal/paddle-mobile/paddle-mobile/Operators/Base/OpParam.swift
浏览文件 @
5a5927ac
...
...
@@ -22,6 +22,10 @@ import Foundation
*/
protocol
OpParam
{
associatedtype
OutputType
:
Variant
var
output
:
OutputType
{
get
}
func
outputDesc
()
->
String
associatedtype
ParamPrecisionType
:
PrecisionType
init
(
opDesc
:
OpDesc
,
scope
:
Scope
)
throws
static
func
getFirstTensor
<
VarType
:
Variant
>
(
key
:
String
,
map
:
[
String
:
[
String
]],
from
:
Scope
)
throws
->
VarType
...
...
@@ -40,6 +44,10 @@ protocol OpParam {
}
extension
OpParam
{
func
outputDesc
()
->
String
{
return
output
.
debugDescription
}
static
func
getFirstTensor
<
VarType
:
Variant
>
(
key
:
String
,
map
:
[
String
:
[
String
]],
from
:
Scope
)
throws
->
VarType
{
guard
let
mapKeys
=
map
[
key
],
mapKeys
.
count
>
0
else
{
throw
PaddleMobileError
.
paramError
(
message
:
key
+
" not found in
\(
map
)
or maped values is empty"
)
...
...
metal/paddle-mobile/paddle-mobile/Operators/Base/Operator.swift
浏览文件 @
5a5927ac
...
...
@@ -22,6 +22,7 @@ protocol Runable {
extension
Runable
where
Self
:
OperatorProtocol
{
func
run
()
{
runImpl
()
print
(
type
+
": "
+
para
.
outputDesc
())
}
}
...
...
@@ -44,7 +45,6 @@ protocol InferShaperable {
func
inferShape
()
}
protocol
OperatorProtocol
{
associatedtype
ParamType
:
OpParam
var
type
:
String
{
get
}
...
...
@@ -66,6 +66,7 @@ extension OperatorProtocol {
}
}
class
Operator
<
ParameterType
:
OpParam
>
:
OperatorProtocol
{
typealias
ParamType
=
ParameterType
let
type
:
String
...
...
@@ -87,3 +88,19 @@ class Operator <ParameterType: OpParam>: OperatorProtocol{
}
}
}
// op infos
let
gFetchType
=
"fetch"
let
gFeedType
=
"feed"
let
gConvType
=
"conv2d"
let
gBatchNormType
=
"batch_norm"
let
gReluType
=
"relu"
let
gElementwiseAdd
=
"elementwise_add"
let
opInfos
=
[
gConvType
:
(
inputs
:
[
"Input"
],
outputs
:
[
"Output"
]),
gBatchNormType
:
(
inputs
:
[
"X"
],
outputs
:
[
"Y"
]),
gReluType
:
(
inputs
:
[
"X"
],
outputs
:
[
"Out"
]),
gElementwiseAdd
:
(
inputs
:
[
"X"
,
"Y"
],
outputs
:
[
"Out"
]),
gFeedType
:
(
inputs
:
[
"X"
],
outputs
:
[
"Out"
]),
gFetchType
:
(
inputs
:
[
"X"
],
outputs
:
[
"Out"
])]
metal/paddle-mobile/paddle-mobile/Operators/ConvOp.swift
浏览文件 @
5a5927ac
...
...
@@ -41,24 +41,25 @@ struct ConvParam<P: PrecisionType>: OpParam {
class
ConvOp
<
P
:
PrecisionType
>
:
Operator
<
ConvParam
<
P
>>
,
Runable
,
Creator
,
InferShaperable
{
func
inferShape
()
{
// let inDims = para.input.dim
// let filterDim = para.filter.dim
// let strides = para.stride
// let paddings = para.paddings
// let dilations = para.dilations
//
// var outDim = [inDims[0]]
// for i in 0..<strides.count {
// let dilation: Int = Int(dilations[i])
// let filterSize: Int = filterDim[i + 1]
// let inputSize: Int = inDims[i + 1]
// let padding: Int = Int(paddings[i])
// let stride: Int = Int(strides[i])
// let dKernel = dilation * (filterSize - 1) + 1
// let outputSize = (inputSize + 2 * padding - dKernel) / stride + 1
// outDim.append(outputSize)
// }
// outDim.append(filterDim[0])
let
inDims
=
para
.
input
.
dim
let
filterDim
=
para
.
filter
.
dim
let
strides
=
para
.
stride
let
paddings
=
para
.
paddings
let
dilations
=
para
.
dilations
var
outDim
=
[
inDims
[
0
]]
for
i
in
0
..<
strides
.
count
{
let
dilation
:
Int
=
Int
(
dilations
[
i
])
let
filterSize
:
Int
=
filterDim
[
i
+
1
]
let
inputSize
:
Int
=
inDims
[
i
+
1
]
let
padding
:
Int
=
Int
(
paddings
[
i
])
let
stride
:
Int
=
Int
(
strides
[
i
])
let
dKernel
=
dilation
*
(
filterSize
-
1
)
+
1
let
outputSize
=
(
inputSize
+
2
*
padding
-
dKernel
)
/
stride
+
1
outDim
.
append
(
outputSize
)
}
outDim
.
append
(
filterDim
[
0
])
para
.
output
.
dim
=
Dim
.
init
(
inDim
:
outDim
)
}
typealias
OpType
=
ConvOp
<
P
>
...
...
metal/paddle-mobile/paddle-mobile/Operators/FeedOp.swift
浏览文件 @
5a5927ac
...
...
@@ -34,7 +34,6 @@ class FeedOp<P: PrecisionType>: Operator<FeedParam<P>>, Runable, Creator, InferS
typealias
OpType
=
FeedOp
<
P
>
func
inferShape
()
{
para
.
output
.
dim
=
para
.
input
.
dim
}
func
runImpl
()
{
...
...
metal/paddle-mobile/paddle-mobile/Operators/FetchOp.swift
浏览文件 @
5a5927ac
...
...
@@ -15,9 +15,9 @@
import
Foundation
struct
FetchParam
<
P
:
PrecisionType
>
:
OpParam
{
var
input
:
Texture
var
out
put
:
Texture
let
output
:
ResultHolder
<
P
>
let
in
put
:
Texture
init
(
opDesc
:
OpDesc
,
scope
:
Scope
)
throws
{
do
{
input
=
try
FetchParam
.
inputX
(
inputs
:
opDesc
.
inputs
,
from
:
scope
)
...
...
@@ -32,7 +32,7 @@ struct FetchParam<P: PrecisionType>: OpParam{
class
FetchOp
<
P
:
PrecisionType
>
:
Operator
<
FetchParam
<
P
>>
,
Runable
,
Creator
,
InferShaperable
{
func
inferShape
()
{
p
ara
.
output
.
dim
=
para
.
input
.
dim
p
rint
(
para
.
input
.
dim
)
}
typealias
OpType
=
FetchOp
<
P
>
...
...
metal/paddle-mobile/paddle-mobile/Program/BlockDesc.swift
浏览文件 @
5a5927ac
...
...
@@ -35,7 +35,4 @@ struct BlockDesc {
self
.
ops
=
ops
}
}
metal/paddle-mobile/paddle-mobile/Program/TensorDesc.swift
浏览文件 @
5a5927ac
...
...
@@ -17,8 +17,43 @@ import Foundation
struct
TensorDesc
{
let
dims
:
[
Int
]
let
dataType
:
VarTypeType
let
dataLayout
:
DataLayout
=
.
NCHW
var
NCHWDim
:
[
Int
]
{
get
{
if
dims
.
count
!=
4
{
return
dims
}
if
dataLayout
==
.
NCHW
{
return
dims
}
else
if
dataLayout
==
.
NHWC
{
var
resultDims
=
dims
resultDims
.
swapAt
(
1
,
3
)
return
resultDims
}
else
{
fatalError
(
" not support other layout"
)
}
}
}
var
NHWCDim
:
[
Int
]
{
get
{
if
dims
.
count
!=
4
{
return
dims
}
if
dataLayout
==
.
NHWC
{
return
dims
}
else
if
dataLayout
==
.
NCHW
{
var
resultDims
=
dims
resultDims
.
swapAt
(
1
,
3
)
return
resultDims
}
else
{
fatalError
(
" not support other layout"
)
}
}
}
init
(
protoTensorDesc
:
PaddleMobile_Framework_Proto_VarType
.
TensorDesc
)
{
dims
=
protoTensorDesc
.
dims
.
map
{
Int
(
$0
)}
dims
=
protoTensorDesc
.
dims
.
map
{
Int
(
$0
)
>
0
?
Int
(
$0
)
:
1
}
dataType
=
VarTypeType
.
init
(
rawValue
:
protoTensorDesc
.
dataType
.
rawValue
)
??
.
ErrorType
}
...
...
metal/paddle-mobile/paddle-mobile/framework/Dim.swift
浏览文件 @
5a5927ac
...
...
@@ -44,3 +44,9 @@ public struct Dim {
fatalError
()
}
}
extension
Dim
:
CustomStringConvertible
{
public
var
description
:
String
{
return
"
\(
dims
)
"
}
}
metal/paddle-mobile/paddle-mobile/framework/Tensor.swift
浏览文件 @
5a5927ac
...
...
@@ -14,38 +14,124 @@
import
Foundation
protocol
Tensorial
{
protocol
Tensorial
:
CustomStringConvertible
,
CustomDebugStringConvertible
{
var
dim
:
Dim
{
get
set
}
func
numel
()
->
Int
func
dataLayout
()
->
DataLayout
var
layout
:
DataLayout
{
get
}
init
(
inDim
:
Dim
,
inLayout
:
DataLayout
)
}
extension
Tensorial
{
func
numel
()
->
Int
{
return
dim
.
numel
()
}
}
class
Tensor
<
P
:
PrecisionType
>
:
Tensorial
{
var
dim
:
Dim
{
get
{
return
paraData
.
dim
class
Tensor
<
P
:
PrecisionType
>
:
Tensorial
{
var
data
:
Data
var
dim
:
Dim
private(set)
var
layout
:
DataLayout
class
Data
{
init
(
inSize
:
Int
,
inPointer
:
UnsafeMutablePointer
<
P
>
)
{
size
=
inSize
pointer
=
inPointer
}
let
size
:
Int
var
pointer
:
UnsafeMutablePointer
<
P
>
subscript
(
index
:
Int
)
->
P
{
get
{
return
pointer
[
index
]
}
set
{
pointer
[
index
]
=
newValue
}
}
set
{
paraData
.
dim
=
newValue
func
release
()
{
pointer
.
deinitialize
(
count
:
size
)
pointer
.
deallocate
()
}
deinit
{
release
()
}
}
required
init
(
inDim
:
Dim
,
inLayout
:
DataLayout
=
.
NCHW
)
{
dim
=
inDim
let
size
=
inDim
.
numel
()
*
MemoryLayout
<
P
>.
size
let
pointer
=
UnsafeMutablePointer
<
P
>.
allocate
(
capacity
:
size
)
data
=
Data
.
init
(
inSize
:
size
,
inPointer
:
pointer
)
layout
=
inLayout
}
let
paraData
:
ParamData
<
P
>
init
(
inDimArray
:
[
Int
],
inData
:
ParamData
<
P
>
)
{
paraData
=
inData
func
convert
(
to
:
DataLayout
)
{
guard
to
!=
layout
else
{
return
}
guard
dim
.
cout
()
==
4
else
{
return
}
guard
layout
==
.
NCHW
&&
to
==
.
NHWC
else
{
// other not support
return
}
let
newPointer
=
UnsafeMutablePointer
<
P
>.
allocate
(
capacity
:
data
.
size
)
if
layout
==
.
NCHW
{
NCHW2NHWC
(
newPtr
:
newPointer
)
}
data
.
release
()
data
.
pointer
=
newPointer
layout
=
to
}
func
NCHW2NHWC
(
newPtr
:
UnsafeMutablePointer
<
P
>
)
{
let
N
=
dim
[
0
]
let
C
=
dim
[
1
]
let
H
=
dim
[
2
]
let
W
=
dim
[
3
]
let
HXW
=
H
*
W
let
CXHXW
=
C
*
H
*
W
var
index
:
Int
=
0
for
n
in
0
..<
N
{
for
h
in
0
..<
H
{
for
w
in
0
..<
W
{
for
c
in
0
..<
C
{
newPtr
[
index
]
=
data
.
pointer
[
n
*
CXHXW
+
c
*
HXW
+
h
*
w
+
w
]
index
+=
1
}
}
}
}
dim
.
swapeDimAt
(
index1
:
1
,
index2
:
3
)
}
init
(
inData
:
ParamData
<
P
>
)
{
paraData
=
inData
}
extension
Tensor
{
var
debugDescription
:
String
{
var
str
=
""
str
+=
"Dim:
\(
dim
)
\n
value:[ "
if
data
.
size
<
20
{
for
d
in
0
..<
data
.
size
{
str
+=
"
\(
data
[
d
]
)
"
}
}
else
{
for
d
in
stride
(
from
:
0
,
to
:
data
.
size
,
by
:
data
.
size
/
20
)
{
str
+=
"
\(
data
[
d
]
)
"
}
}
str
+=
" ]"
return
str
}
func
dataLayout
()
->
DataLayout
{
return
paraData
.
layout
var
description
:
String
{
return
debugDescription
}
}
metal/paddle-mobile/paddle-mobile/framework/Texture.swift
浏览文件 @
5a5927ac
...
...
@@ -17,20 +17,39 @@ import Foundation
public
class
Texture
:
Tensorial
{
var
dim
:
Dim
// let texture: MTLTexture
func
dataLayout
()
->
DataLayout
{
return
.
NHWC
required
public
init
(
inDim
:
Dim
,
inLayout
:
DataLayout
=
.
NHWC
)
{
dim
=
inDim
layout
=
inLayout
}
private(set)
var
layout
:
DataLayout
// let texture: MTLTexture
public
init
(
inTexture
:
MTLTexture
,
inDim
:
Dim
)
{
// texture = inTexture
// texture = inTexture
dim
=
inDim
layout
=
.
NHWC
}
public
init
()
{
public
init
(
inLayout
:
DataLayout
=
.
NHWC
)
{
dim
=
Dim
.
init
(
inDim
:
[])
// fatalError()
layout
=
inLayout
}
}
extension
Texture
{
public
var
description
:
String
{
return
debugDescription
}
public
var
debugDescription
:
String
{
var
str
=
""
str
+=
"Dim:
\(
dim
)
\n
value:[ "
str
+=
" ]"
return
str
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录