mindspore.device_context.gpu.op_tuning 源代码

# Copyright 2024 Huawei Technologies Co., Ltd
#
# 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.
# ============================================================================

"""Op tuning interfaces."""

try:
    from mindspore._c_expression import GPUOpTuningConf
except ImportError:
    pass
from  .device import _is_supported

function_status = {'conv_fprop_algo': False, 'conv_wgrad_algo': False, 'conv_dgrad_algo': False}

[文档]def conv_fprop_algo(mode): """ Specifies convolution forward algorithm. For detailed information, please refer to `NVIDA cuDNN about cudnnConvolutionForward <https://docs.nvidia.com/deeplearning/cudnn/latest/api/cudnn-cnn-library.html>`_. Args: mode (str): convolution forward algorithm. If not configured, the framework defaults to 'normal'. The value range is as follows: - normal: Use the cuDNN's heuristic search algorithm, the appropriate convolution algorithm will be quickly selected based on the convolution shape and type. This parameter does not guarantee optimal performance. - performance: Use the cuDNN's trial search algorithm, all convolution algorithms will be trial run based on the convolution shape and type, and the optimal algorithm will be selected. This parameter ensures optimal performance. - implicit_gemm: This algorithm expresses the convolution as a matrix product without actually explicitly forming the matrix that holds the input tensor data. - precomp_gemm: This algorithm expresses convolution as a matrix product without actually explicitly forming the matrix that holds the input tensor data, but still needs some memory workspace to precompute some indices in order to facilitate the implicit construction of the matrix that holds the input tensor data. - gemm: This algorithm expresses the convolution as an explicit matrix product. A significant memory workspace is needed to store the matrix that holds the input tensor data. - direct: This algorithm expresses the convolution as a direct convolution, without implicitly or explicitly doing a matrix multiplication. - fft: This algorithm uses the Fast-Fourier Transform approach to compute the convolution. A significant memory workspace is needed to store intermediate results. - fft_tiling: This algorithm uses the Fast-Fourier Transform approach but splits the inputs into tiles. A significant memory workspace is needed to store intermediate results but less than fft algorithm for large size images. - winograd: This algorithm uses the Winograd Transform approach to compute the convolution. A reasonably sized workspace is needed to store intermediate results. - winograd_nonfused: This algorithm uses the Winograd Transform approach to compute the convolution. A significant workspace may be needed to store intermediate results. Examples: >>> import mindspore as ms >>> ms.device_context.gpu.op_tuning.conv_fprop_algo("performance") """ if not function_status['conv_fprop_algo']: function_status['conv_fprop_algo'] = True if not _is_supported(): return conv_fprop_algo_mode = ["normal", "performance", "implicit_gemm", "precomp_gemm", "gemm", "direct", "fft", "fft_tiling", "winograd", "winograd_nonfused"] if mode in conv_fprop_algo_mode: GPUOpTuningConf.get_instance().set_conv_fprop_algo(mode) else: raise ValueError( f"For 'mindspore.device_context.gpu.op_tuning.conv_fprop_algo', the argument must be in " f"{conv_fprop_algo_mode} but got {mode}." )
[文档]def conv_wgrad_algo(mode): """ Specifies convolution filter grad algorithm. For detailed information, please refer to `NVIDA cuDNN <https://docs.nvidia.com/deeplearning/cudnn/latest/api/cudnn-cnn-library.html>`_. Args: mode (str): convolution filter grad algorithm. If not configured, the framework defaults to 'normal'. The value range is as follows: - normal: Use the cuDNN's heuristic search algorithm, the appropriate convolution algorithm will be quickly selected based on the convolution shape and type. This parameter does not guarantee optimal performance. - performance: Use the cuDNN's trial search algorithm, all convolution algorithms will be trial run based on the convolution shape and type, and the optimal algorithm will be selected. This parameter ensures optimal performance. - algo_0: This algorithm expresses the convolution as a sum of matrix products without actually explicitly forming the matrix that holds the input tensor data. The sum is done using the atomic add operation, thus the results are non-deterministic. - algo_1: This algorithm expresses the convolution as a matrix product without actually explicitly forming the matrix that holds the input tensor data. The results are deterministic. - algo_3: This algorithm is similar to algo_0 but uses some small workspace to precompute some indices. The results are also non-deterministic. - fft: This algorithm uses a Fast-Fourier Transform approach to compute the convolution. A significant memory workspace is needed to store intermediate results. The results are deterministic. - fft_tiling: This algorithm uses the Fast-Fourier Transform approach but splits the inputs into tiles. A significant memory workspace is needed to store intermediate results but less than fft for large size images. The results are deterministic. - winograd_nonfused: This algorithm uses the Winograd Transform approach to compute the convolution. A significant workspace may be needed to store intermediate results. The results are deterministic. Examples: >>> import mindspore as ms >>> ms.device_context.gpu.op_tuning.conv_wgrad_algo("performance") """ if not function_status['conv_wgrad_algo']: function_status['conv_wgrad_algo'] = True if not _is_supported(): return conv_wgrad_algo_mode = ["normal", "performance", "algo_0", "algo_1", "fft", "algo_3", "fft_tiling", "winograd_nonfused"] if mode in conv_wgrad_algo_mode: GPUOpTuningConf.get_instance().set_conv_wgrad_algo(mode) else: raise ValueError( f"For 'mindspore.device_context.gpu.op_tuning.conv_wgrad_algo', the argument must be in " f"{conv_wgrad_algo_mode} but got {mode}." )
[文档]def conv_dgrad_algo(mode): """ Specifies convolution data grad algorithm. For detailed information, please refer to `NVIDA cuDNN <https://docs.nvidia.com/deeplearning/cudnn/latest/api/cudnn-cnn-library.html>`_. Args: mode (str): convolution data grad algorithm. If not configured, the framework defaults to 'normal'. The value range is as follows: - normal: Use the cuDNN's heuristic search algorithm, the appropriate convolution algorithm will be quickly selected based on the convolution shape and type. This parameter does not guarantee optimal performance. - performance: Use the cuDNN's trial search algorithm, all convolution algorithms will be trial run based on the convolution shape and type, and the optimal algorithm will be selected. This parameter ensures optimal performance. - algo_0: This algorithm expresses the convolution as a sum of matrix products without actually explicitly forming the matrix that holds the input tensor data. The sum is done using the atomic add operation, thus the results are non-deterministic. - algo_1: This algorithm expresses the convolution as a matrix product without actually explicitly forming the matrix that holds the input tensor data. The results are deterministic. - fft: This algorithm uses a Fast-Fourier Transform approach to compute the convolution. A significant memory workspace is needed to store intermediate results. The results are deterministic. - fft_tiling: This algorithm uses the Fast-Fourier Transform approach but splits the inputs into tiles. A significant memory workspace is needed to store intermediate results but less than fft for large size images. The results are deterministic. - winograd: This algorithm uses the Winograd Transform approach to compute the convolution. A reasonably sized workspace is needed to store intermediate results. The results are deterministic. - winograd_nonfused: This algorithm uses the Winograd Transform approach to compute the convolution. A significant workspace may be needed to store intermediate results. The results are deterministic. Examples: >>> import mindspore as ms >>> ms.device_context.gpu.op_tuning.conv_dgrad_algo("performance") """ if not function_status['conv_dgrad_algo']: function_status['conv_dgrad_algo'] = True if not _is_supported(): return conv_dgrad_algo_mode = ["normal", "performance", "algo_0", "algo_1", "fft", "fft_tiling", "winograd", "winograd_nonfused"] if mode in conv_dgrad_algo_mode: GPUOpTuningConf.get_instance().set_conv_dgrad_algo(mode) else: raise ValueError( f"For 'mindspore.device_context.gpu.op_tuning.conv_dgrad_algo', the argument must be in " f"{conv_dgrad_algo_mode} but got {mode}." )