mirror of
https://github.com/ROCm/composable_kernel.git
synced 2026-05-16 10:59:55 +00:00
Batchnorm inference instances, external API, client examples and gtests (#531)
* File renaming and class renaming for device element-wise operation
* Add batchnorm-infer instances, external API and client example
* Add batchnorm-infer profiler module and gtests
* Remove file device_elementwise_extension.hpp and move NormalizeInInfer operation to element_wise_operation.hpp
* Remove the using of class aliasing for DeviceElementwiseForBatchNormInfer
* Rename class and file due to conflict from device_elementwise_2d.hpp
* Fix namespace in batcnnorm_infer_nhwc client example
[ROCm/composable_kernel commit: a1b2441f8d]
This commit is contained in:
@@ -0,0 +1,117 @@
|
||||
// SPDX-License-Identifier: MIT
|
||||
// Copyright (c) 2018-2022, Advanced Micro Devices, Inc. All rights reserved.
|
||||
|
||||
#pragma once
|
||||
|
||||
#include <cstdlib>
|
||||
|
||||
#include "ck/ck.hpp"
|
||||
#include "ck/tensor_operation/gpu/element/element_wise_operation.hpp"
|
||||
#include "ck/tensor_operation/gpu/device/device_elementwise.hpp"
|
||||
|
||||
#include "ck/library/tensor_operation_instance/device_operation_instance_factory.hpp"
|
||||
|
||||
namespace ck {
|
||||
namespace tensor_operation {
|
||||
namespace device {
|
||||
namespace instance {
|
||||
|
||||
// FP16
|
||||
void add_device_batchnorm_infer_rank_4_f16_instances(
|
||||
std::vector<std::unique_ptr<ck::tensor_operation::device::DeviceElementwise<
|
||||
ck::Tuple<F16, F32, F32, F16, F16>,
|
||||
ck::Tuple<F16>,
|
||||
ck::tensor_operation::element_wise::NormalizeInInfer,
|
||||
4>>>&);
|
||||
|
||||
// FP32
|
||||
void add_device_batchnorm_infer_rank_4_f32_instances(
|
||||
std::vector<std::unique_ptr<ck::tensor_operation::device::DeviceElementwise<
|
||||
ck::Tuple<F32, F32, F32, F32, F32>,
|
||||
ck::Tuple<F32>,
|
||||
ck::tensor_operation::element_wise::NormalizeInInfer,
|
||||
4>>>&);
|
||||
|
||||
// BF16
|
||||
void add_device_batchnorm_infer_rank_4_bf16_instances(
|
||||
std::vector<std::unique_ptr<ck::tensor_operation::device::DeviceElementwise<
|
||||
ck::Tuple<BF16, F32, F32, BF16, BF16>,
|
||||
ck::Tuple<BF16>,
|
||||
ck::tensor_operation::element_wise::NormalizeInInfer,
|
||||
4>>>&);
|
||||
|
||||
// FP64
|
||||
void add_device_batchnorm_infer_rank_4_f64_instances(
|
||||
std::vector<std::unique_ptr<ck::tensor_operation::device::DeviceElementwise<
|
||||
ck::Tuple<F64, F64, F64, F64, F64>,
|
||||
ck::Tuple<F64>,
|
||||
ck::tensor_operation::element_wise::NormalizeInInfer,
|
||||
4>>>&);
|
||||
|
||||
template <typename XDataType,
|
||||
typename YDataType,
|
||||
typename ScaleDataType,
|
||||
typename BiasDataType,
|
||||
typename MeanVarDataType,
|
||||
index_t Rank>
|
||||
struct DeviceOperationInstanceFactory<ck::tensor_operation::device::DeviceElementwise<
|
||||
ck::Tuple<XDataType, MeanVarDataType, MeanVarDataType, ScaleDataType, BiasDataType>,
|
||||
ck::Tuple<YDataType>,
|
||||
ck::tensor_operation::element_wise::NormalizeInInfer,
|
||||
Rank>>
|
||||
{
|
||||
using DeviceOp = ck::tensor_operation::device::DeviceElementwise<
|
||||
ck::Tuple<XDataType, MeanVarDataType, MeanVarDataType, ScaleDataType, BiasDataType>,
|
||||
ck::Tuple<YDataType>,
|
||||
ck::tensor_operation::element_wise::NormalizeInInfer,
|
||||
Rank>;
|
||||
|
||||
static auto GetInstances()
|
||||
{
|
||||
std::vector<std::unique_ptr<DeviceOp>> op_ptrs;
|
||||
|
||||
if constexpr(is_same_v<XDataType, F16> && is_same_v<YDataType, F16> &&
|
||||
is_same_v<ScaleDataType, F16> && is_same_v<BiasDataType, F16> &&
|
||||
is_same_v<MeanVarDataType, F32>)
|
||||
{
|
||||
if constexpr(Rank == 4)
|
||||
{
|
||||
add_device_batchnorm_infer_rank_4_f16_instances(op_ptrs);
|
||||
}
|
||||
}
|
||||
else if constexpr(is_same_v<XDataType, F32> && is_same_v<YDataType, F32> &&
|
||||
is_same_v<ScaleDataType, F32> && is_same_v<BiasDataType, F32> &&
|
||||
is_same_v<MeanVarDataType, F32>)
|
||||
{
|
||||
if constexpr(Rank == 4)
|
||||
{
|
||||
add_device_batchnorm_infer_rank_4_f32_instances(op_ptrs);
|
||||
}
|
||||
}
|
||||
else if constexpr(is_same_v<XDataType, BF16> && is_same_v<YDataType, BF16> &&
|
||||
is_same_v<ScaleDataType, BF16> && is_same_v<BiasDataType, BF16> &&
|
||||
is_same_v<MeanVarDataType, F32>)
|
||||
{
|
||||
if constexpr(Rank == 4)
|
||||
{
|
||||
add_device_batchnorm_infer_rank_4_bf16_instances(op_ptrs);
|
||||
}
|
||||
}
|
||||
else if constexpr(is_same_v<XDataType, F64> && is_same_v<YDataType, F64> &&
|
||||
is_same_v<ScaleDataType, F64> && is_same_v<BiasDataType, F64> &&
|
||||
is_same_v<MeanVarDataType, F64>)
|
||||
{
|
||||
if constexpr(Rank == 4)
|
||||
{
|
||||
add_device_batchnorm_infer_rank_4_f64_instances(op_ptrs);
|
||||
}
|
||||
}
|
||||
|
||||
return op_ptrs;
|
||||
}
|
||||
};
|
||||
|
||||
} // namespace instance
|
||||
} // namespace device
|
||||
} // namespace tensor_operation
|
||||
} // namespace ck
|
||||
@@ -7,7 +7,7 @@
|
||||
|
||||
#include "ck/ck.hpp"
|
||||
#include "ck/tensor_operation/gpu/device/tensor_layout.hpp"
|
||||
#include "ck/tensor_operation/gpu/device/impl/device_elementwise.hpp"
|
||||
#include "ck/tensor_operation/gpu/device/impl/device_elementwise_impl.hpp"
|
||||
#include "ck/tensor_operation/gpu/element/element_wise_operation.hpp"
|
||||
|
||||
#include "ck/library/tensor_operation_instance/add_device_operation_instance.hpp"
|
||||
@@ -18,11 +18,8 @@ namespace device {
|
||||
namespace instance {
|
||||
|
||||
using Normalize = ck::tensor_operation::element_wise::Normalize;
|
||||
using DeviceNormalizeFromMeanMeanSquarePtr = ck::tensor_operation::device::DeviceElementwiseBasePtr<
|
||||
Tuple<half_t, float, float, half_t, half_t>,
|
||||
Tuple<half_t>,
|
||||
Normalize,
|
||||
2>;
|
||||
using DeviceNormalizeFromMeanMeanSquarePtr = ck::tensor_operation::device::
|
||||
DeviceElementwisePtr<Tuple<half_t, float, float, half_t, half_t>, Tuple<half_t>, Normalize, 2>;
|
||||
|
||||
void add_device_normalize_from_mean_squaremean_f16_f32_f32_f16_f16_instances(
|
||||
std::vector<DeviceNormalizeFromMeanMeanSquarePtr>& instances);
|
||||
|
||||
Reference in New Issue
Block a user