You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

mindspore.dataset.GeneratorDataset.rst 5.9 kB

4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. mindspore.dataset.GeneratorDataset
  2. ===================================
  3. .. py:class:: mindspore.dataset.GeneratorDataset(source, column_names=None, column_types=None, schema=None, num_samples=None, num_parallel_workers=1, shuffle=None, sampler=None, num_shards=None, shard_id=None, python_multiprocessing=True, max_rowsize=6)
  4. 自定义Python数据源,通过迭代该数据源构造数据集。生成的数据集的列名和列类型取决于用户定义的Python数据源。
  5. **参数:**
  6. - **source** (Union[Callable, Iterable, Random Accessible]) - 一个Python的可调用对象,可以是可迭代的Python对象,或支持随机访问的Python对象。
  7. - 如果 `source` 是可调用对象,要求 `source` 对象可以通过 `source().next()` 的方式返回一个由NumPy数组构成的元组。
  8. - 如果 `source` 是可迭代对象,要求 `source` 对象通过 `iter(source).next()` 的方式返回一个由NumPy数组构成的元组。
  9. - 如果 `source` 是支持随机访问的对象,要求 `source` 对象通过 `source[idx]` 的方式返回一个由NumPy数组构成的元组。
  10. - **column_names** (Union[str, list[str]],可选) - 指定数据集生成的列名,默认值:None,不指定。用户可以通过此参数或 `schema` 参数指定列名。
  11. - **column_types** (list[mindspore.dtype],可选) - 指定生成数据集各个数据列的数据类型,默认值:None,不指定。
  12. 如果未指定该参数,则自动推断类型;如果指定了该参数,将在数据输出时做类型匹配检查。
  13. - **schema** (Union[Schema, str],可选) - 读取模式策略,用于指定读取数据列的数据类型、数据维度等信息。
  14. 支持传入JSON文件路径或 mindspore.dataset.Schema 构造的对象。默认值:None,不指定。
  15. 用户可以通过提供 `column_names` 或 `schema` 指定数据集的列名,但如果同时指定两者,则将优先从 `schema` 中获取列名信息。
  16. - **num_samples** (int,可选) - 指定从数据集中读取的样本数,默认值:None,读取全部样本。
  17. - **num_parallel_workers** (int,可选) - 指定读取数据的工作进程数/线程数(由参数 `python_multiprocessing` 决定当前为多进程模式或多线程模式),默认值:1。
  18. - **shuffle** (bool,可选) - 是否混洗数据集。只有输入的 `source` 参数带有可随机访问属性(`__getitem__`)时,才可以指定该参数。默认值:None,下表中会展示不同配置的预期行为。
  19. - **sampler** (Union[Sampler, Iterable],可选) - 指定从数据集中选取样本的采样器。只有输入的 `source` 参数带有可随机访问属性(`__getitem__`)时,才可以指定该参数。默认值:None,下表中会展示不同配置的预期行为。
  20. - **num_shards** (int, 可选) - 指定分布式训练时将数据集进行划分的分片数,默认值:None。指定此参数后, `num_samples` 表示每个分片的最大样本数。
  21. - **shard_id** (int, 可选) - 指定分布式训练时使用的分片ID号,默认值:None。只有当指定了 `num_shards` 时才能指定此参数。
  22. - **python_multiprocessing** (bool,可选) - 启用Python多进程模式加速运算,默认值:True。当传入 `source` 的Python对象的计算量很大时,开启此选项可能会有较好效果。
  23. - **max_rowsize** (int,可选) - 指定在多进程之间复制数据时,共享内存分配的最大空间,默认值:6,单位为MB。仅当参数 `python_multiprocessing` 设为True时,此参数才会生效。
  24. **异常:**
  25. - **RuntimeError** - Python对象 `source` 在执行期间引发异常。
  26. - **RuntimeError** - `column_names` 参数指定的列名数量与 `source` 参数输出的数据数量不匹配。
  27. - **ValueError** - `num_parallel_workers` 参数超过最大线程数。
  28. - **ValueError** - 同时指定了 `sampler` 和 `shuffle` 参数。
  29. - **ValueError** - 同时指定了 `sampler` 和 `num_shards` 参数或同时指定了 `sampler` 和 `shard_id` 参数。
  30. - **ValueError** - 指定了 `num_shards` 参数,但是未指定 `shard_id` 参数。
  31. - **ValueError** - 指定了 `shard_id` 参数,但是未指定 `num_shards` 参数。
  32. - **ValueError** - `shard_id` 参数值错误(小于0或者大于等于 `num_shards` )。
  33. .. note::
  34. - `source` 参数接收用户自定义的Python函数(PyFuncs),不要将 `mindspore.nn` 和 `mindspore.ops` 目录下或其他的网络计算算子添加
  35. 到 `source` 中。
  36. - 此数据集可以指定参数 `sampler` ,但参数 `sampler` 和参数 `shuffle` 的行为是互斥的。下表展示了几种合法的输入参数组合及预期的行为。
  37. .. list-table:: 配置 `sampler` 和 `shuffle` 的不同组合得到的预期排序结果
  38. :widths: 25 25 50
  39. :header-rows: 1
  40. * - 参数 `sampler`
  41. - 参数 `shuffle`
  42. - 预期数据顺序
  43. * - None
  44. - None
  45. - 随机排列
  46. * - None
  47. - True
  48. - 随机排列
  49. * - None
  50. - False
  51. - 顺序排列
  52. * - `sampler` 实例
  53. - None
  54. - 由 `sampler` 行为定义的顺序
  55. * - `sampler` 实例
  56. - True
  57. - 不允许
  58. * - `sampler` 实例
  59. - False
  60. - 不允许
  61. .. include:: mindspore.dataset.Dataset.add_sampler.rst
  62. .. include:: mindspore.dataset.Dataset.rst
  63. .. include:: mindspore.dataset.Dataset.b.rst
  64. .. include:: mindspore.dataset.Dataset.c.rst
  65. .. include:: mindspore.dataset.Dataset.d.rst
  66. .. include:: mindspore.dataset.Dataset.use_sampler.rst
  67. .. include:: mindspore.dataset.Dataset.zip.rst