modify the format of API
This commit is contained in:
parent
c9937a553f
commit
bddd31dd5b
|
@ -18,43 +18,37 @@ mindspore.COOTensor
|
|||
.. note::
|
||||
这是一个实验特性,在未来可能会发生API的变化。目前COOTensor中相同索引的值不会进行合并。
|
||||
|
||||
**参数:**
|
||||
|
||||
参数:
|
||||
- **indices** (Tensor) - 形状为 `[N, ndims]` 的二维整数张量,其中N和ndims分别表示稀疏张量中 `values` 的数量和COOTensor维度的数量。目前 `ndims` 只能为2。请确保indices的值在所给shape范围内。
|
||||
- **values** (Tensor) - 形状为 `[N]` 的一维张量,用来给 `indices` 中的每个元素提供数值。
|
||||
- **shape** (tuple(int)) - 形状为ndims的整数元组,用来指定稀疏矩阵的稠密形状。
|
||||
- **coo_tensor** (COOTensor) - COOTensor对象,用来初始化新的COOTensor。
|
||||
|
||||
**返回:**
|
||||
|
||||
返回:
|
||||
COOTensor,由 `indices` 、 `values` 和 `shape` 组成。
|
||||
|
||||
.. py:method:: abs()
|
||||
|
||||
对所有非零元素取绝对值,并返回新的COOTensor。
|
||||
|
||||
**返回:**
|
||||
|
||||
返回:
|
||||
COOTensor。
|
||||
|
||||
.. py:method:: astype(dtype)
|
||||
|
||||
返回指定数据类型的COOTensor。
|
||||
|
||||
**参数:**
|
||||
|
||||
参数:
|
||||
- **dtype** (Union[`mindspore.dtype` , `numpy.dtype` , str]) - 指定数据类型。
|
||||
|
||||
**返回:**
|
||||
|
||||
返回:
|
||||
COOTensor。
|
||||
|
||||
.. py:method:: coalesce()
|
||||
|
||||
合并COOTensor中相同索引的值。
|
||||
|
||||
**返回:**
|
||||
|
||||
返回:
|
||||
COOTensor。
|
||||
|
||||
.. py:method:: dtype
|
||||
|
@ -94,25 +88,22 @@ mindspore.COOTensor
|
|||
.. note::
|
||||
如果运行后端是CPU,那么仅支持在安装了LLVM12.0.1的机器运行。
|
||||
|
||||
**返回:**
|
||||
|
||||
返回:
|
||||
CSRTensor。
|
||||
|
||||
.. py:method:: to_dense()
|
||||
|
||||
将COOTensor转换为稠密Tensor。
|
||||
|
||||
**返回:**
|
||||
|
||||
返回:
|
||||
Tensor。
|
||||
|
||||
.. py:method:: to_tuple()
|
||||
|
||||
将COOTensor的索引,非零元素,以及形状信息作为tuple返回。
|
||||
|
||||
**返回:**
|
||||
|
||||
tuple(Tensor, Tensor, tuple(int))
|
||||
返回:
|
||||
tuple(Tensor, Tensor, tuple(int))。
|
||||
|
||||
.. py:method:: values
|
||||
:property:
|
||||
|
|
|
@ -18,36 +18,31 @@ mindspore.CSRTensor
|
|||
这是一个实验特性,在未来可能会发生API的变化。
|
||||
如果values或indices的长度超出了indptr所指定的取值范围,超出部分的行为将没有定义。
|
||||
|
||||
**参数:**
|
||||
|
||||
参数:
|
||||
- **indptr** (Tensor) - 形状为 `[M]` 的一维整数张量,其中M等于 `shape[0] + 1` , 表示每行非零元素的在 `values` 中存储的起止位置。默认值:None。支持的数据类型为 `int16` , `int32` 和 `int64` 。
|
||||
- **indices** (Tensor) - 形状为 `[N]` 的一维整数张量,其中N等于非零元素数量,表示每个元素的列索引值。默认值:None。支持的数据类型为 `int16` , `int32` 和 `int64` 。
|
||||
- **values** (Tensor) - 张量,values的0维长度必须与indices的0维长度相等(values.shape[0] == indices.shape[0])。values用来表示索引对应的数值。默认值:None。
|
||||
- **shape** (tuple(int)) - 形状为ndims的整数元组,用来指定稀疏矩阵的稠密形状。`shape[0]` 表示行数,因此必须和 `M - 1` 值相等。默认值:None。
|
||||
- **csr_tensor** (CSRTensor) - CSRTensor对象,用来初始化新的CSRTensor。values的特征维度需要和csr_tensor的特征维度匹配(values.shape[1:] == csr_tensor.shape[2:])。默认值:None。
|
||||
|
||||
**输出:**
|
||||
|
||||
输出:
|
||||
CSRTensor,稠密形状取决于传入的 `shape` ,数据类型由 `values` 决定。
|
||||
|
||||
.. py:method:: abs()
|
||||
|
||||
对所有非零元素取绝对值,并返回新的CSRTensor。
|
||||
|
||||
**返回:**
|
||||
|
||||
返回:
|
||||
CSRTensor。
|
||||
|
||||
.. py:method:: astype(dtype)
|
||||
|
||||
返回指定数据类型的CSRTensor。
|
||||
|
||||
**参数:**
|
||||
|
||||
参数:
|
||||
- **dtype** (Union[`mindspore.dtype` , `numpy.dtype` , str]) - 指定数据类型。
|
||||
|
||||
**返回:**
|
||||
|
||||
返回:
|
||||
CSRTensor。
|
||||
|
||||
.. py:method:: dtype
|
||||
|
@ -78,12 +73,10 @@ mindspore.CSRTensor
|
|||
.. note::
|
||||
如果运行后端是CPU,那么仅支持在安装了LLVM12.0.1的机器运行。
|
||||
|
||||
**参数:**
|
||||
|
||||
参数:
|
||||
- **dense_vector** (Tensor) - 形状为 `[N,1]` 的二维张量,其中N等于CSRTensor的列数。
|
||||
|
||||
**返回:**
|
||||
|
||||
返回:
|
||||
Tensor。
|
||||
|
||||
.. py:method:: mm(dense_matrix)
|
||||
|
@ -94,12 +87,10 @@ mindspore.CSRTensor
|
|||
.. note::
|
||||
如果运行后端是CPU,那么仅支持在安装了LLVM12.0.1的机器运行。
|
||||
|
||||
**参数:**
|
||||
|
||||
参数:
|
||||
- **dense_matrix** (Tensor) - 形状为 `[N,K]` 的二维矩阵,其中N等于CSRTensor的列数。
|
||||
|
||||
**返回:**
|
||||
|
||||
返回:
|
||||
Tensor。
|
||||
|
||||
.. py:method:: ndim
|
||||
|
@ -124,12 +115,10 @@ mindspore.CSRTensor
|
|||
.. note::
|
||||
如果运行后端是CPU,那么仅支持在安装了LLVM12.0.1的机器运行。
|
||||
|
||||
**参数:**
|
||||
|
||||
参数:
|
||||
- **axis** (int) - 求和轴。
|
||||
|
||||
**返回:**
|
||||
|
||||
返回:
|
||||
Tensor。
|
||||
|
||||
.. py:method:: to_coo()
|
||||
|
@ -139,25 +128,22 @@ mindspore.CSRTensor
|
|||
.. note::
|
||||
如果运行后端是CPU,那么仅支持在安装了LLVM12.0.1的机器运行。
|
||||
|
||||
**返回:**
|
||||
|
||||
返回:
|
||||
COOTensor。
|
||||
|
||||
.. py:method:: to_dense()
|
||||
|
||||
将CSRTensor转换为稠密Tensor。
|
||||
|
||||
**返回:**
|
||||
|
||||
返回:
|
||||
Tensor。
|
||||
|
||||
.. py:method:: to_tuple()
|
||||
|
||||
将CSRTensor的行偏移量,列索引,非零元素,以及形状信息作为tuple返回。
|
||||
|
||||
**返回:**
|
||||
|
||||
tuple(Tensor,Tensor, Tensor, tuple(int))
|
||||
返回:
|
||||
tuple(Tensor,Tensor, Tensor, tuple(int))。
|
||||
|
||||
.. py:method:: values
|
||||
:property:
|
||||
|
|
|
@ -6,7 +6,7 @@ mindspore.Callback
|
|||
用于构建Callback函数的基类。Callback函数是一个上下文管理器,在运行模型时被调用。
|
||||
可以使用此机制进行一些自定义操作。
|
||||
|
||||
Callback类的每个方法对应了训练或推理过程的不同阶段,这些方法有相同的入参 `run_context`,用于保存训练或推理过程中模型的相关信息。定义Callback子类或自定义Callback时,请根据需要重写名称前缀为“on_train”或“on_eval”的方法,否则自定义的Callback在 `model.fit` 中使用时会产生错误。
|
||||
Callback类的每个方法对应了训练或推理过程的不同阶段,这些方法有相同的入参 `run_context`,用于保存训练或推理过程中模型的相关信息。定义Callback子类或自定义Callback时,请根据需要重写名称前缀为"on_train"或"on_eval"的方法,否则自定义的Callback在 `model.fit` 中使用时会产生错误。
|
||||
|
||||
自定义Callback场景下,在类方法中通过 `RunContext.original_args()` 方法可以获取模型训练或推理过程中已有
|
||||
的上下文信息,此信息为一个存储了已有属性的字典型变量;用户也可以在此信息中添加其他的自定义属性;此外,
|
||||
|
@ -17,142 +17,124 @@ mindspore.Callback
|
|||
|
||||
在网络执行之前被调用一次。与 `on_train_begin` 和 `on_eval_begin` 方法具有兼容性。
|
||||
|
||||
**参数:**
|
||||
|
||||
参数:
|
||||
- **run_context** (RunContext) - 包含模型的一些基本信息。
|
||||
|
||||
.. py:method:: end(run_context)
|
||||
|
||||
网络执行后被调用一次。与 `on_train_end` 和 `on_eval_end` 方法具有兼容性。
|
||||
|
||||
**参数:**
|
||||
|
||||
参数:
|
||||
- **run_context** (RunContext) - 包含模型的一些基本信息。
|
||||
|
||||
.. py:method:: epoch_begin(run_context)
|
||||
|
||||
在每个epoch开始之前被调用。与 `on_train_epoch_begin` 和 `on_eval_epoch_begin` 方法具有兼容性。
|
||||
|
||||
**参数:**
|
||||
|
||||
参数:
|
||||
- **run_context** (RunContext) - 包含模型的一些基本信息。
|
||||
|
||||
.. py:method:: epoch_end(run_context)
|
||||
|
||||
在每个epoch结束后被调用。与 `on_train_epoch_end` 和 `on_eval_epoch_end` 方法具有兼容性。
|
||||
|
||||
**参数:**
|
||||
|
||||
参数:
|
||||
- **run_context** (RunContext) - 包含模型的一些基本信息。
|
||||
|
||||
.. py:method:: step_begin(run_context)
|
||||
|
||||
在每个step开始之前被调用。与 `on_train_step_begin` 和 `on_eval_step_begin` 方法具有兼容性。
|
||||
|
||||
**参数:**
|
||||
|
||||
参数:
|
||||
- **run_context** (RunContext) - 包含模型的一些基本信息。
|
||||
|
||||
.. py:method:: step_end(run_context)
|
||||
|
||||
在每个step完成后被调用。与 `on_train_step_end` 和 `on_eval_step_end` 方法具有兼容性。
|
||||
|
||||
**参数:**
|
||||
|
||||
参数:
|
||||
- **run_context** (RunContext) - 包含模型的一些基本信息。
|
||||
|
||||
.. py:method:: on_train_begin(run_context)
|
||||
|
||||
在网络执行训练之前调用。
|
||||
|
||||
**参数:**
|
||||
|
||||
参数:
|
||||
- **run_context** (RunContext) - 包含模型的一些基本信息。
|
||||
|
||||
.. py:method:: on_train_end(run_context)
|
||||
|
||||
网络训练执行结束时调用。
|
||||
|
||||
**参数:**
|
||||
|
||||
参数:
|
||||
- **run_context** (RunContext) - 包含模型的一些基本信息。
|
||||
|
||||
.. py:method:: on_train_epoch_begin(run_context)
|
||||
|
||||
在训练的每个epoch开始之前被调用。
|
||||
|
||||
**参数:**
|
||||
|
||||
参数:
|
||||
- **run_context** (RunContext) - 包含模型的一些基本信息。
|
||||
|
||||
.. py:method:: on_train_epoch_end(run_context)
|
||||
|
||||
在训练的每个epoch结束后被调用。
|
||||
|
||||
**参数:**
|
||||
|
||||
参数:
|
||||
- **run_context** (RunContext) - 包含模型的一些基本信息。
|
||||
|
||||
.. py:method:: on_train_step_begin(run_context)
|
||||
|
||||
在训练的每个step开始之前被调用。
|
||||
|
||||
**参数:**
|
||||
|
||||
参数:
|
||||
- **run_context** (RunContext) - 包含模型的一些基本信息。
|
||||
|
||||
.. py:method:: on_train_step_end(run_context)
|
||||
|
||||
在训练的每个step完成后被调用。
|
||||
|
||||
**参数:**
|
||||
|
||||
参数:
|
||||
- **run_context** (RunContext) - 包含模型的一些基本信息。
|
||||
|
||||
.. py:method:: on_eval_begin(run_context)
|
||||
|
||||
在网络执行推理之前调用。
|
||||
|
||||
**参数:**
|
||||
|
||||
参数:
|
||||
- **run_context** (RunContext) - 包含模型的一些基本信息。
|
||||
|
||||
.. py:method:: on_eval_end(run_context)
|
||||
|
||||
网络执行推理之后调用。
|
||||
|
||||
**参数:**
|
||||
|
||||
参数:
|
||||
- **run_context** (RunContext) - 包含模型的一些基本信息。
|
||||
|
||||
.. py:method:: on_eval_epoch_begin(run_context)
|
||||
|
||||
在推理的epoch开始之前被调用。
|
||||
|
||||
**参数:**
|
||||
|
||||
参数:
|
||||
- **run_context** (RunContext) - 包含模型的一些基本信息。
|
||||
|
||||
.. py:method:: on_eval_epoch_end(run_context)
|
||||
|
||||
在推理的epoch结束后被调用。
|
||||
|
||||
**参数:**
|
||||
|
||||
参数:
|
||||
- **run_context** (RunContext) - 包含模型的一些基本信息。
|
||||
|
||||
.. py:method:: on_eval_step_begin(run_context)
|
||||
|
||||
在推理的每个step开始之前被调用。
|
||||
|
||||
**参数:**
|
||||
|
||||
参数:
|
||||
- **run_context** (RunContext) - 包含模型的一些基本信息。
|
||||
|
||||
.. py:method:: on_eval_step_end(run_context)
|
||||
|
||||
在推理的每个step完成后被调用。
|
||||
|
||||
**参数:**
|
||||
|
||||
参数:
|
||||
- **run_context** (RunContext) - 包含模型的一些基本信息。
|
||||
|
|
|
@ -8,8 +8,7 @@ mindspore.CheckpointConfig
|
|||
.. note::
|
||||
在训练过程中,如果数据集是通过数据通道传输的,建议将 `save_checkpoint_steps` 设为循环下沉step数量的整数倍数,否则,保存checkpoint的时机可能会有偏差。建议同时只设置一种触发保存checkpoint策略和一种保留checkpoint文件总数策略。如果同时设置了 `save_checkpoint_steps` 和 `save_checkpoint_seconds` ,则 `save_checkpoint_seconds` 无效。如果同时设置了 `keep_checkpoint_max` 和 `keep_checkpoint_per_n_minutes` ,则 `keep_checkpoint_per_n_minutes` 无效。
|
||||
|
||||
**参数:**
|
||||
|
||||
参数:
|
||||
- **save_checkpoint_steps** (int) - 每隔多少个step保存一次checkpoint。默认值:1。
|
||||
- **save_checkpoint_seconds** (int) - 每隔多少秒保存一次checkpoint。不能同时与 `save_checkpoint_steps` 一起使用。默认值:0。
|
||||
- **keep_checkpoint_max** (int) - 最多保存多少个checkpoint文件。默认值:5。
|
||||
|
@ -22,18 +21,15 @@ mindspore.CheckpointConfig
|
|||
- **enc_mode** (str) - 仅当 `enc_key` 不设为None时,该参数有效。指定了加密模式,目前支持AES-GCM和AES-CBC。默认值:AES-GCM。
|
||||
- **exception_save** (bool) - 当有异常发生时,是否保存当前checkpoint文件。默认值:False。
|
||||
|
||||
**异常:**
|
||||
|
||||
异常:
|
||||
- **ValueError** - 输入参数的类型不正确。
|
||||
|
||||
|
||||
.. py:method:: append_dict
|
||||
:property:
|
||||
|
||||
获取需要额外保存到checkpoint中的字典的值。
|
||||
|
||||
**返回:**
|
||||
|
||||
返回:
|
||||
Dict: 字典中的值。
|
||||
|
||||
.. py:method:: async_save
|
||||
|
@ -41,8 +37,7 @@ mindspore.CheckpointConfig
|
|||
|
||||
获取是否异步保存checkpoint。
|
||||
|
||||
**返回:**
|
||||
|
||||
返回:
|
||||
Bool: 是否异步保存checkpoint。
|
||||
|
||||
.. py:method:: enc_key
|
||||
|
@ -50,8 +45,7 @@ mindspore.CheckpointConfig
|
|||
|
||||
获取加密的key值。
|
||||
|
||||
**返回:**
|
||||
|
||||
返回:
|
||||
(None, bytes): 加密的key值。
|
||||
|
||||
.. py:method:: enc_mode
|
||||
|
@ -59,16 +53,14 @@ mindspore.CheckpointConfig
|
|||
|
||||
获取加密模式。
|
||||
|
||||
**返回:**
|
||||
|
||||
返回:
|
||||
str: 加密模式。
|
||||
|
||||
.. py:method:: get_checkpoint_policy()
|
||||
|
||||
获取checkpoint的保存策略。
|
||||
|
||||
**返回:**
|
||||
|
||||
返回:
|
||||
Dict: checkpoint的保存策略。
|
||||
|
||||
.. py:method:: integrated_save
|
||||
|
@ -76,8 +68,7 @@ mindspore.CheckpointConfig
|
|||
|
||||
获取是否合并保存拆分后的Tensor。
|
||||
|
||||
**返回:**
|
||||
|
||||
返回:
|
||||
Bool: 获取是否合并保存拆分后的Tensor。
|
||||
|
||||
.. py:method:: keep_checkpoint_max
|
||||
|
@ -85,8 +76,7 @@ mindspore.CheckpointConfig
|
|||
|
||||
获取最多保存checkpoint文件的数量。
|
||||
|
||||
**返回:**
|
||||
|
||||
返回:
|
||||
Int: 最多保存checkpoint文件的数量。
|
||||
|
||||
.. py:method:: keep_checkpoint_per_n_minutes
|
||||
|
@ -94,8 +84,7 @@ mindspore.CheckpointConfig
|
|||
|
||||
获取每隔多少分钟保存一个checkpoint文件。
|
||||
|
||||
**返回:**
|
||||
|
||||
返回:
|
||||
Int: 每隔多少分钟保存一个checkpoint文件。
|
||||
|
||||
.. py:method:: save_checkpoint_seconds
|
||||
|
@ -103,8 +92,7 @@ mindspore.CheckpointConfig
|
|||
|
||||
获取每隔多少秒保存一次checkpoint文件。
|
||||
|
||||
**返回:**
|
||||
|
||||
返回:
|
||||
Int: 每隔多少秒保存一次checkpoint文件。
|
||||
|
||||
.. py:method:: save_checkpoint_steps
|
||||
|
@ -112,8 +100,7 @@ mindspore.CheckpointConfig
|
|||
|
||||
获取每隔多少个step保存一次checkpoint文件。
|
||||
|
||||
**返回:**
|
||||
|
||||
返回:
|
||||
Int: 每隔多少个step保存一次checkpoint文件。
|
||||
|
||||
.. py:method:: saved_network
|
||||
|
@ -121,6 +108,5 @@ mindspore.CheckpointConfig
|
|||
|
||||
获取需要保存的网络。
|
||||
|
||||
**返回:**
|
||||
|
||||
返回:
|
||||
Cell: 需要保存的网络。
|
||||
|
|
|
@ -10,8 +10,7 @@ mindspore.ConvertModelUtils
|
|||
|
||||
该接口用于增加计算图,提升二阶算法THOR运行时的性能。
|
||||
|
||||
**参数:**
|
||||
|
||||
参数:
|
||||
- **model** (Object) - 用于训练的高级API。
|
||||
- **network** (Cell) - 训练网络。
|
||||
- **loss_fn** (Cell) - 目标函数。默认值:None。
|
||||
|
@ -27,6 +26,5 @@ mindspore.ConvertModelUtils
|
|||
- **loss_scale_manager** (Union[None, LossScaleManager]) - 如果为None,则不会按比例缩放loss。否则,需设置LossScaleManager,且优化器的入参loss_scale不为None。这是一个关键参数。例如,使用 `loss_scale_manager=None` 设置值。
|
||||
- **keep_batchnorm_fp32** (bool) - 保持BN在 `float32` 中运行。如果为True,则将覆盖之前的级别设置。默认值:False。
|
||||
|
||||
**返回:**
|
||||
|
||||
model (Object) - 用于训练的高级API。
|
||||
返回:
|
||||
model (Object),用于训练的高级API。
|
||||
|
|
|
@ -12,6 +12,5 @@ mindspore.ConvertNetUtils
|
|||
.. note::
|
||||
此接口由二阶优化器thor自动调用。
|
||||
|
||||
**参数:**
|
||||
|
||||
**net** (Cell) - 由二阶优化器thor训练的网络。
|
||||
参数:
|
||||
- **net** (Cell) - 由二阶优化器thor训练的网络。
|
||||
|
|
|
@ -10,8 +10,7 @@ mindspore.DatasetHelper
|
|||
.. note::
|
||||
DatasetHelper的迭代将提供一个epoch的数据。
|
||||
|
||||
**参数:**
|
||||
|
||||
参数:
|
||||
- **dataset** (Dataset) - 训练数据集迭代器。数据集可以由数据集生成器API在 :class:`mindspore.dataset` 中生成,例如 :class:`mindspore.dataset.ImageFolderDataset` 。
|
||||
- **dataset_sink_mode** (bool) - 如果值为True,使用 :class:`mindspore.ops.GetNext` 在设备(Device)上通过数据通道中获取数据,否则在主机(Host)直接遍历数据集获取数据。默认值:True。
|
||||
- **sink_size** (int) - 控制每个下沉中的数据量。如果 `sink_size` 为-1,则下沉每个epoch的完整数据集。如果 `sink_size` 大于0,则下沉每个epoch的 `sink_size` 数据。默认值:-1。
|
||||
|
|
|
@ -5,8 +5,7 @@ mindspore.DynamicLossScaleManager
|
|||
|
||||
动态调整损失缩放系数的管理器,继承自 :class:`mindspore.LossScaleManager` 。
|
||||
|
||||
**参数:**
|
||||
|
||||
参数:
|
||||
- **init_loss_scale** (float) - 初始梯度放大系数。默认值:2**24。
|
||||
- **scale_factor** (int) - 放大/缩小倍数。默认值:2。
|
||||
- **scale_window** (int) - 无溢出时的连续正常step的最大数量。默认值:2000。
|
||||
|
@ -15,30 +14,26 @@ mindspore.DynamicLossScaleManager
|
|||
|
||||
该值表示是否在发生溢出时放弃本轮参数更新。
|
||||
|
||||
**返回:**
|
||||
|
||||
返回:
|
||||
bool,始终为True。
|
||||
|
||||
.. py:method:: get_loss_scale()
|
||||
|
||||
返回当前梯度放大系数。
|
||||
|
||||
**返回:**
|
||||
|
||||
返回:
|
||||
float,梯度放大系数。
|
||||
|
||||
.. py:method:: get_update_cell()
|
||||
|
||||
返回用于更新梯度放大系数的 `Cell` 实例,:class:`mindspore.nn.TrainOneStepWithLossScaleCell` 会调用该实例。
|
||||
|
||||
**返回:**
|
||||
|
||||
返回:
|
||||
:class:`mindspore.nn.DynamicLossScaleUpdateCell` 实例,用于更新梯度放大系数。
|
||||
|
||||
.. py:method:: update_loss_scale(overflow)
|
||||
|
||||
根据溢出状态更新梯度放大系数。如果发生溢出,减小梯度放大系数,否则增大梯度放大系数。
|
||||
|
||||
**参数:**
|
||||
|
||||
**overflow** (bool) - 表示是否溢出。
|
||||
参数:
|
||||
- **overflow** (bool) - 表示是否溢出。
|
|
@ -7,8 +7,7 @@ mindspore.EarlyStopping
|
|||
|
||||
假设 `monitor` 是"accuracy",那么,`mode` 将为"max",因为训练的目标是准确率的提高,`model.fit()` 边训练边验证场景下,将记录 `monitor` 的变化,当在 `patience` 个epoch范围内指标效果变好的程度没有超过 `min_delta` 时,将调用 `run_context.request_stop()` 方法来终止训练。
|
||||
|
||||
**参数:**
|
||||
|
||||
参数:
|
||||
- **monitor** (str) - 监控指标。如果是边训练边推理场景,合法的monitor配置值可以为"loss", "eval_loss"以及实例化 `Model` 时传入的metric名称;如果在训练时不做推理,合法的monitor配置值为"loss"。当monitor为"loss"时,如果训练网络有多个输出,默认取第一个值为训练损失值。默认值:"eval_loss"。
|
||||
- **min_delta** (float) - `monitor` 指标变化的最小阈值,超过此阈值才视为 `monitor` 的变化。默认值:0。
|
||||
- **patience** (int) - `moniter` 相对历史最优值变好超过 `min_delta` 视为当前epoch的模型效果有所改善,`patience` 为等待的无改善epoch的数量,当内部等待的epoch数 `self.wait` 大于等于 `patience` 时,训练停止。默认值:0。
|
||||
|
@ -17,8 +16,7 @@ mindspore.EarlyStopping
|
|||
- **baseline** (float) - 模型效果的基线,当前 `moniter` 相对历史最优值变好且好于 `baseline` 时,内部的等待epoch计数器被清零。默认值:0。
|
||||
- **restore_best_weights** (bool) - 是否自动保存最优模型的权重。默认值:False。
|
||||
|
||||
**异常:**
|
||||
|
||||
异常:
|
||||
- **ValueError** - 当 `mode` 不在 `{'auto', 'min', 'max'}` 中。
|
||||
- **ValueError** - 当传入的 `monitor` 返回值不是标量。
|
||||
|
||||
|
@ -26,22 +24,19 @@ mindspore.EarlyStopping
|
|||
|
||||
训练开始时初始化相关的变量。
|
||||
|
||||
**参数:**
|
||||
|
||||
参数:
|
||||
- **run_context** (RunContext) - 包含模型的相关信息。详情请参考 :class:`mindspore.RunContext`。
|
||||
|
||||
.. py:method:: on_train_epoch_end(run_context)
|
||||
|
||||
训练过程中,若监控指标在等待 `patience` 个epoch后仍没有改善,则停止训练。
|
||||
|
||||
**参数:**
|
||||
|
||||
参数:
|
||||
- **run_context** (RunContext) - 包含模型的相关信息。详情请参考 :class:`mindspore.RunContext`。
|
||||
|
||||
.. py:method:: on_train_end(run_context)
|
||||
|
||||
打印是第几个epoch执行早停。
|
||||
|
||||
**参数:**
|
||||
|
||||
参数:
|
||||
- **run_context** (RunContext) - 包含模型的相关信息。详情请参考 :class:`mindspore.RunContext`。
|
||||
|
|
|
@ -7,6 +7,5 @@ mindspore.async_ckpt_thread_status
|
|||
|
||||
在执行异步保存checkpoint时,判断异步线程是否执行完毕。
|
||||
|
||||
**返回:**
|
||||
|
||||
返回:
|
||||
Bool: True,异步保存checkpoint线程正在运行。False,异步保存checkpoint线程未运行。
|
|
@ -5,15 +5,12 @@ mindspore.build_searched_strategy
|
|||
|
||||
构建网络中每个参数的策略,用于分布式推理。关于它的使用细节,请参考: `保存和加载模型(HyBrid Parallel模式) <https://www.mindspore.cn/tutorials/experts/zh-CN/master/parallel/save_load.html>`_。
|
||||
|
||||
**参数:**
|
||||
|
||||
**strategy_filename** (str) - 策略文件的名称。
|
||||
|
||||
**返回:**
|
||||
参数:
|
||||
- **strategy_filename** (str) - 策略文件的名称。
|
||||
|
||||
返回:
|
||||
Dict,key为参数名,value为该参数的切片策略。
|
||||
|
||||
**异常:**
|
||||
|
||||
异常:
|
||||
- **ValueError** - 策略文件不正确。
|
||||
- **TypeError** - `strategy_filename` 不是str。
|
||||
|
|
|
@ -5,28 +5,26 @@ mindspore.build_train_network
|
|||
|
||||
构建混合精度训练网络。
|
||||
|
||||
**参数:**
|
||||
|
||||
- **network** (Cell) – 定义网络结构。
|
||||
- **optimizer** (Optimizer) – 定义优化器,用于更新权重参数。
|
||||
- **loss_fn** (Union[None, Cell]) – 定义损失函数。如果为None, `network` 中应该包含损失函数。默认值:None。
|
||||
- **level** (str) – 支持["O0", "O2", "O3", "auto"]。默认值:"O0"。
|
||||
参数:
|
||||
- **network** (Cell) - 定义网络结构。
|
||||
- **optimizer** (Optimizer) - 定义优化器,用于更新权重参数。
|
||||
- **loss_fn** (Union[None, Cell]) - 定义损失函数。如果为None, `network` 中应该包含损失函数。默认值:None。
|
||||
- **level** (str) - 支持["O0", "O2", "O3", "auto"]。默认值:"O0"。
|
||||
|
||||
- **"O0"** - 不变化。
|
||||
- **"O2"** - 将网络精度转为float16, `BatchNorm` 和 `loss_fn` 保持float32精度,使用动态调整损失缩放系数(loss scale)的策略。
|
||||
- **"O3"** - 将网络精度转为float16,不使用损失缩放策略,并设置 `keep_batchnorm_fp32` 为False。
|
||||
- **auto** - 为不同处理器设置专家推荐的混合精度等级,如在GPU上设为"O2",在Ascend上设为"O3"。该设置方式可能在部分场景下不适用,建议用户根据具体的网络模型自定义设置 `amp_level` 。 `keep_batchnorm_fp32` , `cast_model_type` 和 `loss_scale_manager` 属性由level自动决定。
|
||||
|
||||
- **boost_level** (str) – `mindspore.boost` 中参数 `level` 的选项,设置boost的训练模式级别。支持["O0", "O1", "O2"]。默认值: "O0"。
|
||||
- **boost_level** (str) - `mindspore.boost` 中参数 `level` 的选项,设置boost的训练模式级别。支持["O0", "O1", "O2"]。默认值: "O0"。
|
||||
|
||||
- **"O0"** - 不变化。
|
||||
- **"O1"** - 开启boost模式,性能提升20%左右,准确率与原始准确率相同。
|
||||
- **"O2"** - 开启boost模式,性能提升30%左右,准确率降低小于3%。如果设置了"O1"或"O2"模式,boost相关库将自动生效。
|
||||
|
||||
- **cast_model_type** (mindspore.dtype) – 支持float16,float32。如果设置了该参数,网络将被转化为设置的数据类型,而不会根据设置的level进行转换。
|
||||
- **keep_batchnorm_fp32** (bool) – 当网络被设置为float16时,配置为True,则BatchNorm将保持在float32下运行。设置level不会影响该属性。
|
||||
- **loss_scale_manager** (Union[None, LossScaleManager]) – 如果不为None,必须是 :class:`mindspore.LossScaleManager` 的子类,用于缩放损失系数(loss scale)。设置level不会影响该属性。
|
||||
|
||||
**异常:**
|
||||
- **cast_model_type** (mindspore.dtype) - 支持float16,float32。如果设置了该参数,网络将被转化为设置的数据类型,而不会根据设置的level进行转换。
|
||||
- **keep_batchnorm_fp32** (bool) - 当网络被设置为float16时,配置为True,则BatchNorm将保持在float32下运行。设置level不会影响该属性。
|
||||
- **loss_scale_manager** (Union[None, LossScaleManager]) - 如果不为None,必须是 :class:`mindspore.LossScaleManager` 的子类,用于缩放损失系数(loss scale)。设置level不会影响该属性。
|
||||
|
||||
异常:
|
||||
- **ValueError** - 在CPU上,属性 `loss_scale_manager` 不是 `None` 或 `FixedLossScaleManager` (其属性 `drop_overflow_update=False` )。
|
||||
|
|
|
@ -10,15 +10,12 @@ mindspore.connect_network_with_dataset
|
|||
.. note::
|
||||
如果以图模式在Ascend/GPU上运行网络,此函数将使用 :class:`mindspore.ops.GetNext` 包装输入网络。在其他情况下,输入网络将在没有改动的情况下返回。仅在下沉模式下获取数据需要使用 :class:`mindspore.ops.GetNext` ,因此此函数不适用于非下沉模式。
|
||||
|
||||
**参数:**
|
||||
|
||||
参数:
|
||||
- **network** (Cell) - 数据集的训练网络。
|
||||
- **dataset_helper** (DatasetHelper) - 一个处理MindData数据集的类,提供了数据集的类型、形状(shape)和队列名称,以包装 :class:`mindspore.ops.GetNext` 。
|
||||
|
||||
**返回:**
|
||||
|
||||
返回:
|
||||
Cell,在Ascend上以图模式运行任务的情况下,一个由 :class:`mindspore.ops.GetNext` 包装的新网络。在其他情况下是输入网络。
|
||||
|
||||
**异常:**
|
||||
|
||||
异常:
|
||||
- **RuntimeError** - 如果该接口在非数据下沉模式调用。
|
||||
|
|
|
@ -8,14 +8,12 @@ mindspore.conver_model
|
|||
.. note::
|
||||
这是一个实验特性,未来API可能会发生的变化。
|
||||
|
||||
**参数:**
|
||||
|
||||
参数:
|
||||
- **mindir_file** (str) - MindIR模型文件名称。
|
||||
- **convert_file** (str) - 转化后的模型文件名称。
|
||||
- **file_format** (str) - 需要转化的文件格式,当前版本仅支持"ONNX"。
|
||||
|
||||
**异常:**
|
||||
|
||||
异常:
|
||||
- **TypeError** - `mindir_file` 参数不是str类型。
|
||||
- **TypeError** - `convert_file` 参数不是str类型。
|
||||
- **ValueError** - `file_format` 参数的值不是"ONNX"。
|
||||
|
|
|
@ -46,10 +46,10 @@ mindspore.dtype
|
|||
``uint`` 无符号整数标量。
|
||||
``float_`` 浮点标量。
|
||||
``complex`` 复数标量。
|
||||
``number`` 数值型, 包括 ``int_`` , ``uint`` , ``float_`` , ``complex`` 和 ``bool_``。
|
||||
``number`` 数值型,包括 ``int_``、``uint``、``float_``、``complex`` 和 ``bool_``。
|
||||
``list_`` 由 ``tensor`` 构造的列表,例如 ``List[T0,T1,...,Tn]`` ,其中元素 ``Ti`` 可以是不同的类型。
|
||||
``tuple_`` 由 ``tensor`` 构造的元组,例如 ``Tuple[T0,T1,...,Tn]`` ,其中元素 ``Ti`` 可以是不同的类型。
|
||||
``function`` 函数类型。 两种返回方式,当function不是None时,直接返回function,另一种当function为None时返回function(参数: List[T0,T1,...,Tn], 返回值: T)。
|
||||
``function`` 函数类型。两种返回方式,当function不是None时,直接返回function,另一种当function为None时返回function(参数: List[T0,T1,...,Tn],返回值: T)。
|
||||
``type_type`` 类型的类型定义。
|
||||
``type_none`` 没有匹配的返回类型,对应 Python 中的 ``type(None)``。
|
||||
``symbolic_key`` 在 ``env_type`` 中用作变量的键的变量的值。
|
||||
|
|
|
@ -5,10 +5,8 @@ mindspore.dtype_to_nptype
|
|||
|
||||
将MindSpore 数据类型转换成NumPy数据类型。
|
||||
|
||||
**参数:**
|
||||
|
||||
- **type_** (mindspore.dtype) – MindSpore中的dtype。
|
||||
|
||||
**返回:**
|
||||
参数:
|
||||
- **type_** (mindspore.dtype) - MindSpore中的dtype。
|
||||
|
||||
返回:
|
||||
NumPy的数据类型。
|
|
@ -5,10 +5,8 @@ mindspore.dtype_to_pytype
|
|||
|
||||
将MindSpore数据类型转换为Python数据类型。
|
||||
|
||||
**参数:**
|
||||
|
||||
- **type_** (mindspore.dtype) – MindSpore中的dtype。
|
||||
|
||||
**返回:**
|
||||
参数:
|
||||
- **type_** (mindspore.dtype) - MindSpore中的dtype。
|
||||
|
||||
返回:
|
||||
Python的数据类型。
|
|
@ -9,18 +9,17 @@ mindspore.export
|
|||
- 当导出文件格式为AIR、ONNX时,单个Tensor的大小不能超过2GB。
|
||||
- 当 `file_name` 没有后缀时,系统会根据 `file_format` 自动添加后缀。
|
||||
|
||||
**参数:**
|
||||
|
||||
- **net** (Cell) – MindSpore网络结构。
|
||||
- **inputs** (Union[Tensor, Dasaset, List, Tuple, Number, Bool) – 网络的输入,如果网络有多个输入,需要一同传入。当传入的类型为 `Dataset` 时,将会把数据预处理行为同步保存起来。需要手动调整batch的大小,当前仅支持获取 `Dataset` 的 `image` 列。
|
||||
- **file_name** (str) – 导出模型的文件名称。
|
||||
- **file_format** (str) – MindSpore目前支持导出"AIR","ONNX"和"MINDIR"格式的模型。
|
||||
参数:
|
||||
- **net** (Cell) - MindSpore网络结构。
|
||||
- **inputs** (Union[Tensor, Dasaset, List, Tuple, Number, Bool) - 网络的输入,如果网络有多个输入,需要一同传入。当传入的类型为 `Dataset` 时,将会把数据预处理行为同步保存起来。需要手动调整batch的大小,当前仅支持获取 `Dataset` 的 `image` 列。
|
||||
- **file_name** (str) - 导出模型的文件名称。
|
||||
- **file_format** (str) - MindSpore目前支持导出"AIR","ONNX"和"MINDIR"格式的模型。
|
||||
|
||||
- **AIR** - Ascend Intermediate Representation。一种Ascend模型的中间表示格式。推荐的输出文件后缀是".air"。
|
||||
- **ONNX** - Open Neural Network eXchange。一种针对机器学习所设计的开放式的文件格式。推荐的输出文件后缀是“.onnx”。
|
||||
- **ONNX** - Open Neural Network eXchange。一种针对机器学习所设计的开放式的文件格式。推荐的输出文件后缀是".onnx"。
|
||||
- **MINDIR** - MindSpore Native Intermediate Representation for Anf。一种MindSpore模型的中间表示格式。推荐的输出文件后缀是".mindir"。
|
||||
|
||||
- **kwargs** (dict) – 配置选项字典。
|
||||
- **kwargs** (dict) - 配置选项字典。
|
||||
|
||||
- **quant_mode** (str) - 如果网络是量化感知训练网络,那么 `quant_mode` 需要设置为"QUANT",否则 `quant_mode` 需要设置为"NONQUANT"。
|
||||
- **mean** (float) - 预处理后输入数据的平均值,用于量化网络的第一层。默认值:127.5。
|
||||
|
@ -29,5 +28,5 @@ mindspore.export
|
|||
- **enc_mode** (Union[str, function]) - 指定加密模式,当设置 `enc_key` 时启用。
|
||||
- 对于'AIR'和'ONNX'格式的模型,当前仅支持自定义加密导出。
|
||||
- 对于'MINDIR'格式的模型,支持的加密选项有:'AES-GCM','AES-CBC'和用户自定义加密算法。默认值:"AES-GCM"。
|
||||
- 关于使用自定义加密导出的详情, 请查看 `教程 <https://www.mindspore.cn/mindarmour/docs/zh-CN/master/model_encrypt_protection.html>`_。
|
||||
- 关于使用自定义加密导出的详情,请查看 `教程 <https://www.mindspore.cn/mindarmour/docs/zh-CN/master/model_encrypt_protection.html>`_。
|
||||
- **dataset** (Dataset) - 指定数据集的预处理方法,用于将数据集的预处理导入MindIR。
|
||||
|
|
|
@ -539,9 +539,6 @@ class SeLU(Cell):
|
|||
Supported Platforms:
|
||||
``Ascend`` ``GPU`` ``CPU``
|
||||
|
||||
Raises:
|
||||
TypeError: If dtype of `input_x` is neither float16 nor float32.
|
||||
|
||||
Examples:
|
||||
>>> input_x = Tensor(np.array([[-1.0, 4.0, -8.0], [2.0, -5.0, 9.0]]), mindspore.float32)
|
||||
>>> selu = nn.SeLU()
|
||||
|
@ -1407,9 +1404,6 @@ class Mish(Cell):
|
|||
Supported Platforms:
|
||||
``Ascend`` ``CPU``
|
||||
|
||||
Raises:
|
||||
TypeError: If dtype of `x` is neither float16 nor float32.
|
||||
|
||||
Examples:
|
||||
>>> x = Tensor(np.array([[-1.0, 4.0, -8.0], [2.0, -5.0, 9.0]]), mindspore.float32)
|
||||
>>> mish = ops.Mish()
|
||||
|
|
Loading…
Reference in New Issue