Skip to content

Commit 1c22b62

Browse files
committed
feat: add fractional_max_pool3d_backward base
1 parent cfea02e commit 1c22b62

1 file changed

Lines changed: 70 additions & 0 deletions

File tree

Lines changed: 70 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,70 @@
1+
#ifndef INFINI_OPS_BASE_FRACTIONAL_MAX_POOL3D_BACKWARD_H_
2+
#define INFINI_OPS_BASE_FRACTIONAL_MAX_POOL3D_BACKWARD_H_
3+
4+
#include "operator.h"
5+
6+
namespace infini::ops {
7+
8+
class FractionalMaxPool3dBackward
9+
: public Operator<FractionalMaxPool3dBackward> {
10+
public:
11+
FractionalMaxPool3dBackward(const Tensor grad_output, const Tensor input,
12+
const std::vector<int64_t> kernel_size,
13+
const std::vector<int64_t> output_size,
14+
const Tensor indices, 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+
input_shape_{input.shape()},
19+
input_strides_{input.strides()},
20+
input_type_{input.dtype()},
21+
indices_shape_{indices.shape()},
22+
indices_strides_{indices.strides()},
23+
indices_type_{indices.dtype()},
24+
grad_input_shape_{grad_input.shape()},
25+
grad_input_strides_{grad_input.strides()},
26+
grad_input_type_{grad_input.dtype()},
27+
kernel_size_{kernel_size},
28+
output_size_{output_size},
29+
device_index_{grad_input.device().index()} {}
30+
31+
virtual void operator()(const Tensor grad_output, const Tensor input,
32+
const std::vector<int64_t> kernel_size,
33+
const std::vector<int64_t> output_size,
34+
const Tensor indices, Tensor grad_input) const = 0;
35+
36+
protected:
37+
Tensor::Shape grad_output_shape_;
38+
39+
Tensor::Strides grad_output_strides_;
40+
41+
DataType grad_output_type_;
42+
43+
Tensor::Shape input_shape_;
44+
45+
Tensor::Strides input_strides_;
46+
47+
DataType input_type_;
48+
49+
Tensor::Shape indices_shape_;
50+
51+
Tensor::Strides indices_strides_;
52+
53+
DataType indices_type_;
54+
55+
Tensor::Shape grad_input_shape_;
56+
57+
Tensor::Strides grad_input_strides_;
58+
59+
DataType grad_input_type_;
60+
61+
std::vector<int64_t> kernel_size_{};
62+
63+
std::vector<int64_t> output_size_{};
64+
65+
int device_index_{0};
66+
};
67+
68+
} // namespace infini::ops
69+
70+
#endif

0 commit comments

Comments
 (0)