GetSwishTmpSize
Function Usage
Obtains Swish tiling parameters, that is, the maximum and minimum temporary space sizes required to complete Swish computation.
Prototype
1 | inline void GetSwishTmpSize(const ge::Shape& srcShape, const uint32_t typeSize, const bool isReuseSource, uint32_t& max, uint32_t& min) |
Parameters
Parameter |
Input/Output |
Description |
|---|---|---|
srcShape |
Input |
Input shape. |
typeSize |
Input |
Data type size of operator inputs. The unit is byte. For example, if the data type of operator inputs is half, set this parameter to 2, that is, sizeof(half). |
isReuseSource |
Input |
Whether to reuse the space of the source operand input, which must be the same as that of the API in the kernel. |
max |
Output |
Maximum size of the temporary space required by Swish computation. Any space exceeding this value will not be utilized by the API. Within the range between the minimum and maximum, as the temporary space increases, the API computing performance in the kernel can be optimized to some extent. To achieve better performance, reserve or allocate the space based on the actual buffer usage. If the maximum space size is 0, no temporary space is required. NOTE:
max is for reference only and may be larger than the remaining space of the Unified Buffer. In this case, select a proper temporary space size based on the remaining space of the Unified Buffer. |
min |
Output |
Minimum size of the temporary space required by Swish computation. To ensure correct functions, the size of the temporary space to be reserved or allocated during API computation cannot be less than the value of this parameter. If the minimum space size is 0, no temporary space is required. |
Returns
None
Example
1 2 3 4 5 6 | // The input shape is 1024. The operator input data is of the half type. The source operand cannot be modified. std::vector<int64_t> shape_vec = {1024}; ge::Shape shape(shape_vec); uint32_t max; uint32_t min; AscendC::GetSwishTmpSize(shape, 2, false, max, min); |