Skip to content

Commit f4ef8a1

Browse files
committed
feat: add upsample_linear1d_backward_grad_input base
1 parent 57ec7e3 commit f4ef8a1

1 file changed

Lines changed: 41 additions & 0 deletions

File tree

Lines changed: 41 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,41 @@
1+
#ifndef INFINI_OPS_BASE_UPSAMPLE_LINEAR1D_BACKWARD_GRAD_INPUT_H_
2+
#define INFINI_OPS_BASE_UPSAMPLE_LINEAR1D_BACKWARD_GRAD_INPUT_H_
3+
4+
#include "operator.h"
5+
6+
namespace infini::ops {
7+
8+
class UpsampleLinear1dBackwardGradInput
9+
: public Operator<UpsampleLinear1dBackwardGradInput> {
10+
public:
11+
UpsampleLinear1dBackwardGradInput(const Tensor grad_output,
12+
const std::vector<int64_t> output_size,
13+
const std::vector<int64_t> input_size,
14+
const bool align_corners, Tensor grad_input)
15+
: grad_output_shape_{grad_output.shape()},
16+
grad_output_strides_{grad_output.strides()},
17+
grad_output_type_{grad_output.dtype()},
18+
grad_input_shape_{grad_input.shape()},
19+
grad_input_strides_{grad_input.strides()},
20+
grad_input_type_{grad_input.dtype()},
21+
device_index_{grad_input.device().index()} {}
22+
23+
virtual void operator()(const Tensor grad_output,
24+
const std::vector<int64_t> output_size,
25+
const std::vector<int64_t> input_size,
26+
const bool align_corners,
27+
Tensor grad_input) const = 0;
28+
29+
protected:
30+
Tensor::Shape grad_output_shape_;
31+
Tensor::Strides grad_output_strides_;
32+
DataType grad_output_type_;
33+
Tensor::Shape grad_input_shape_;
34+
Tensor::Strides grad_input_strides_;
35+
DataType grad_input_type_;
36+
int device_index_{0};
37+
};
38+
39+
} // namespace infini::ops
40+
41+
#endif

0 commit comments

Comments
 (0)