#include "op_plugin/OpApiInterface.h"
#include "op_plugin/utils/op_api_common.h"
namespace op_api {
using npu_preparation = at_npu::native::OpPreparation;
at::Tensor &upsample_nearest_exact2d_backward_out_slow(const at::Tensor &grad_output, at::IntArrayRef output_size,
at::IntArrayRef input_size, c10::optional<double> scales_h, c10::optional<double> scales_w, at::Tensor &grad_input)
{
at::Tensor grad_input_slow =
at::_upsample_nearest_exact2d_backward(grad_output.cpu(), output_size, input_size, scales_h, scales_w);
grad_input.copy_(grad_input_slow);
return grad_input;
}
at::Tensor upsample_nearest_exact2d_backward_slow(const at::Tensor &grad_output, at::IntArrayRef output_size,
at::IntArrayRef input_size, c10::optional<double> scales_h, c10::optional<double> scales_w)
{
at::Tensor grad_input = npu_preparation::apply_tensor_without_format(grad_output, input_size);
at::Tensor grad_input_slow =
at::_upsample_nearest_exact2d_backward(grad_output.cpu(), output_size, input_size, scales_h, scales_w);
grad_input.copy_(grad_input_slow);
return grad_input;
}
at::Tensor &_upsample_nearest_exact2d_backward_out(const at::Tensor &grad_output, at::IntArrayRef output_size,
at::IntArrayRef input_size, c10::optional<double> scales_h, c10::optional<double> scales_w, at::Tensor &grad_input)
{
DO_COMPATIBILITY(aclnnUpsampleNearestExact2dBackward,
upsample_nearest_exact2d_backward_out_slow(
grad_output, output_size, input_size, scales_h, scales_w, grad_input));
npu_preparation::check_tensor({grad_output}, grad_input, grad_output, input_size);
at::Tensor self = grad_output;
double scales_h_attr = scales_h.value_or(0);
double scales_w_attr = scales_w.value_or(0);
EXEC_NPU_CMD(aclnnUpsampleNearestExact2dBackward, grad_output, output_size, input_size, scales_h_attr, scales_w_attr, grad_input);
return grad_input;
}
at::Tensor _upsample_nearest_exact2d_backward(const at::Tensor &grad_output, at::IntArrayRef output_size,
at::IntArrayRef input_size, c10::optional<double> scales_h, c10::optional<double> scales_w)
{
DO_COMPATIBILITY(aclnnUpsampleNearestExact2dBackward,
upsample_nearest_exact2d_backward_slow(grad_output, output_size, input_size, scales_h, scales_w));
at::Tensor self = grad_output;
double scales_h_attr = scales_h.value_or(0);
double scales_w_attr = scales_w.value_or(0);
at::Tensor grad_input = npu_preparation::apply_tensor_without_format(grad_output, input_size);
EXEC_NPU_CMD(aclnnUpsampleNearestExact2dBackward, grad_output, output_size, input_size, scales_h_attr, scales_w_attr, grad_input);
return grad_input;
}
}