Skip to content

Commit b4e4343

Browse files
committed
feat: add BinaryCrossEntropyBackwardGradInput base
1 parent 57ec7e3 commit b4e4343

1 file changed

Lines changed: 49 additions & 0 deletions

File tree

Lines changed: 49 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,49 @@
1+
#ifndef INFINI_OPS_BASE_BINARY_CROSS_ENTROPY_BACKWARD_GRAD_INPUT_H_
2+
#define INFINI_OPS_BASE_BINARY_CROSS_ENTROPY_BACKWARD_GRAD_INPUT_H_
3+
4+
#include "operator.h"
5+
6+
namespace infini::ops {
7+
8+
class BinaryCrossEntropyBackwardGradInput
9+
: public Operator<BinaryCrossEntropyBackwardGradInput> {
10+
public:
11+
BinaryCrossEntropyBackwardGradInput(const Tensor grad_output,
12+
const Tensor self, const Tensor target,
13+
Tensor grad_input)
14+
: grad_output_shape_{grad_output.shape()},
15+
grad_output_strides_{grad_output.strides()},
16+
grad_output_type_{grad_output.dtype()},
17+
self_shape_{self.shape()},
18+
self_strides_{self.strides()},
19+
self_type_{self.dtype()},
20+
target_shape_{target.shape()},
21+
target_strides_{target.strides()},
22+
target_type_{target.dtype()},
23+
grad_input_shape_{grad_input.shape()},
24+
grad_input_strides_{grad_input.strides()},
25+
grad_input_type_{grad_input.dtype()},
26+
device_index_{grad_input.device().index()} {}
27+
28+
virtual void operator()(const Tensor grad_output, const Tensor self,
29+
const Tensor target, Tensor grad_input) const = 0;
30+
31+
protected:
32+
Tensor::Shape grad_output_shape_;
33+
Tensor::Strides grad_output_strides_;
34+
DataType grad_output_type_;
35+
Tensor::Shape self_shape_;
36+
Tensor::Strides self_strides_;
37+
DataType self_type_;
38+
Tensor::Shape target_shape_;
39+
Tensor::Strides target_strides_;
40+
DataType target_type_;
41+
Tensor::Shape grad_input_shape_;
42+
Tensor::Strides grad_input_strides_;
43+
DataType grad_input_type_;
44+
int device_index_{0};
45+
};
46+
47+
} // namespace infini::ops
48+
49+
#endif

0 commit comments

Comments
 (0)