Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
MegEngine 天元
MegEngine
提交
05c739b8
MegEngine
项目概览
MegEngine 天元
/
MegEngine
1 年多 前同步成功
通知
404
Star
4705
Fork
582
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
MegEngine
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
05c739b8
编写于
12月 31, 2020
作者:
M
Megvii Engine Team
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
refactor(mge/data): rename `MapDataset` to `Dataset`
GitOrigin-RevId: 6262561355995679ff51a80c0187d204405d376b
上级
a892e5d0
变更
5
显示空白变更内容
内联
并排
Showing
5 changed file
with
26 addition
and
34 deletion
+26
-34
imperative/python/megengine/data/dataloader.py
imperative/python/megengine/data/dataloader.py
+14
-16
imperative/python/megengine/data/dataset/__init__.py
imperative/python/megengine/data/dataset/__init__.py
+1
-1
imperative/python/megengine/data/dataset/meta_dataset.py
imperative/python/megengine/data/dataset/meta_dataset.py
+8
-12
imperative/python/megengine/data/dataset/vision/meta_vision.py
...ative/python/megengine/data/dataset/vision/meta_vision.py
+2
-2
imperative/python/test/unit/data/test_dataset.py
imperative/python/test/unit/data/test_dataset.py
+1
-3
未找到文件。
imperative/python/megengine/data/dataloader.py
浏览文件 @
05c739b8
...
...
@@ -19,7 +19,7 @@ import numpy as np
from
..logger
import
get_logger
from
..random.rng
import
_random_seed_generator
from
.collator
import
Collator
from
.dataset
import
Dataset
,
MapDataset
,
StreamDataset
from
.dataset
import
Dataset
,
StreamDataset
from
.sampler
import
MapSampler
,
Sampler
,
SequentialSampler
,
StreamSampler
from
.transform
import
PseudoTransform
,
Transform
...
...
@@ -88,7 +88,15 @@ class DataLoader:
self
.
divide
=
divide
if
isinstance
(
dataset
,
MapDataset
):
if
isinstance
(
dataset
,
StreamDataset
):
self
.
sampler
=
sampler
if
sampler
else
StreamSampler
(
batch_size
=
1
)
assert
isinstance
(
self
.
sampler
,
StreamSampler
),
"types of dataset and sampler do not match"
else
:
assert
isinstance
(
dataset
,
Dataset
),
"Can not recognize this kind of dataset: %s"
%
type
(
dataset
)
self
.
sampler
=
(
sampler
if
sampler
...
...
@@ -97,15 +105,6 @@ class DataLoader:
assert
isinstance
(
self
.
sampler
,
MapSampler
),
"types of dataset and sampler do not match"
elif
isinstance
(
dataset
,
StreamDataset
):
self
.
sampler
=
sampler
if
sampler
else
StreamSampler
(
batch_size
=
1
)
assert
isinstance
(
self
.
sampler
,
StreamSampler
),
"types of dataset and sampler do not match"
else
:
raise
TypeError
(
"can not recognize this kind of dataset: %s"
%
type
(
dataset
)
)
if
divide
:
if
self
.
sampler
.
batch_size
<=
self
.
num_workers
:
...
...
@@ -140,15 +139,14 @@ class DataLoader:
return
_SerialStreamDataLoaderIter
(
self
)
else
:
return
_ParallelStreamDataLoaderIter
(
self
)
elif
isinstance
(
self
.
dataset
,
MapDataset
):
else
:
assert
isinstance
(
self
.
dataset
,
Dataset
),
"Can not recognize this kind of dataset: %s"
%
type
(
self
.
dataset
)
if
not
self
.
num_workers
:
return
_SerialMapDataLoaderIter
(
self
)
else
:
return
_ParallelMapDataLoaderIter
(
self
)
else
:
raise
TypeError
(
"can not recognize this kind of dataset: %s"
%
type
(
self
.
dataset
)
)
def
__len__
(
self
):
return
len
(
self
.
sampler
)
...
...
imperative/python/megengine/data/dataset/__init__.py
浏览文件 @
05c739b8
...
...
@@ -6,5 +6,5 @@
# Unless required by applicable law or agreed to in writing,
# software distributed under the License is distributed on an
# "AS IS" BASIS, WITHOUT ARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
from
.meta_dataset
import
ArrayDataset
,
Dataset
,
MapDataset
,
StreamDataset
from
.meta_dataset
import
ArrayDataset
,
Dataset
,
StreamDataset
from
.vision
import
*
imperative/python/megengine/data/dataset/meta_dataset.py
浏览文件 @
05c739b8
...
...
@@ -12,17 +12,7 @@ from typing import Tuple
class
Dataset
(
ABC
):
r
"""
An abstract class for all Datasets.
"""
@
abstractmethod
def
__init__
(
self
):
pass
class
MapDataset
(
Dataset
):
r
"""
An abstract class for map data.
An abstract class for all datasets.
__getitem__ and __len__ method are aditionally needed.
"""
...
...
@@ -53,8 +43,14 @@ class StreamDataset(Dataset):
def
__iter__
(
self
):
pass
def
__getitem__
(
self
):
raise
AssertionError
(
"can not get item from StreamDataset by index"
)
def
__len__
(
self
):
raise
AssertionError
(
"StreamDataset does not have length"
)
class
ArrayDataset
(
Map
Dataset
):
class
ArrayDataset
(
Dataset
):
def
__init__
(
self
,
*
arrays
):
r
"""
ArrayDataset is a dataset for numpy array data, one or more numpy arrays
...
...
imperative/python/megengine/data/dataset/vision/meta_vision.py
浏览文件 @
05c739b8
...
...
@@ -9,10 +9,10 @@
import
collections.abc
import
os
from
..meta_dataset
import
Map
Dataset
from
..meta_dataset
import
Dataset
class
VisionDataset
(
Map
Dataset
):
class
VisionDataset
(
Dataset
):
_repr_indent
=
4
def
__init__
(
self
,
root
,
*
,
order
=
None
,
supported_order
=
None
):
...
...
imperative/python/test/unit/data/test_dataset.py
浏览文件 @
05c739b8
...
...
@@ -12,14 +12,12 @@ import sys
import
numpy
as
np
import
pytest
from
megengine.data.dataset
import
ArrayDataset
,
Dataset
,
MapDataset
,
StreamDataset
from
megengine.data.dataset
import
ArrayDataset
,
Dataset
,
StreamDataset
def
test_abstract_cls
():
with
pytest
.
raises
(
TypeError
):
Dataset
()
with
pytest
.
raises
(
TypeError
):
MapDataset
()
with
pytest
.
raises
(
TypeError
):
StreamDataset
()
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录