vision_cpu.h 3.1 KB
Newer Older
1
2
#pragma once
#include <torch/extension.h>
3
#include "../macros.h"
4
5

VISION_API std::tuple<at::Tensor, at::Tensor> ROIPool_forward_cpu(
6
7
8
9
10
11
    const at::Tensor& input,
    const at::Tensor& rois,
    const float spatial_scale,
    const int pooled_height,
    const int pooled_width);

12
VISION_API at::Tensor ROIPool_backward_cpu(
13
14
15
16
17
18
19
20
21
22
23
    const at::Tensor& grad,
    const at::Tensor& rois,
    const at::Tensor& argmax,
    const float spatial_scale,
    const int pooled_height,
    const int pooled_width,
    const int batch_size,
    const int channels,
    const int height,
    const int width);

24
VISION_API at::Tensor ROIAlign_forward_cpu(
25
26
    const at::Tensor& input,
    const at::Tensor& rois,
27
28
29
30
    const double spatial_scale,
    const int64_t pooled_height,
    const int64_t pooled_width,
    const int64_t sampling_ratio,
AhnDW's avatar
AhnDW committed
31
    const bool aligned);
32

33
VISION_API at::Tensor ROIAlign_backward_cpu(
34
35
    const at::Tensor& grad,
    const at::Tensor& rois,
36
37
38
39
40
41
42
43
    const double spatial_scale,
    const int64_t pooled_height,
    const int64_t pooled_width,
    const int64_t batch_size,
    const int64_t channels,
    const int64_t height,
    const int64_t width,
    const int64_t sampling_ratio,
AhnDW's avatar
AhnDW committed
44
    const bool aligned);
45

46
VISION_API std::tuple<at::Tensor, at::Tensor> PSROIPool_forward_cpu(
47
48
49
50
51
52
    const at::Tensor& input,
    const at::Tensor& rois,
    const float spatial_scale,
    const int pooled_height,
    const int pooled_width);

53
VISION_API at::Tensor PSROIPool_backward_cpu(
54
55
56
57
58
59
60
61
62
63
64
    const at::Tensor& grad,
    const at::Tensor& rois,
    const at::Tensor& mapping_channel,
    const float spatial_scale,
    const int pooled_height,
    const int pooled_width,
    const int batch_size,
    const int channels,
    const int height,
    const int width);

65
VISION_API std::tuple<at::Tensor, at::Tensor> PSROIAlign_forward_cpu(
66
67
68
69
70
71
72
    const at::Tensor& input,
    const at::Tensor& rois,
    const float spatial_scale,
    const int pooled_height,
    const int pooled_width,
    const int sampling_ratio);

73
VISION_API at::Tensor PSROIAlign_backward_cpu(
74
75
76
77
78
79
80
81
82
83
84
85
    const at::Tensor& grad,
    const at::Tensor& rois,
    const at::Tensor& mapping_channel,
    const float spatial_scale,
    const int pooled_height,
    const int pooled_width,
    const int sampling_ratio,
    const int batch_size,
    const int channels,
    const int height,
    const int width);

86
VISION_API at::Tensor nms_cpu(
87
88
    const at::Tensor& dets,
    const at::Tensor& scores,
89
    const double iou_threshold);
90

91
VISION_API at::Tensor DeformConv2d_forward_cpu(
92
93
94
95
96
97
98
99
100
101
    const at::Tensor& input,
    const at::Tensor& weight,
    const at::Tensor& offset,
    const at::Tensor& bias,
    std::pair<int, int> stride,
    std::pair<int, int> pad,
    std::pair<int, int> dilation,
    int groups,
    int deformable_groups);

102
VISION_API std::tuple<at::Tensor, at::Tensor, at::Tensor, at::Tensor>
103
104
105
106
107
108
109
110
111
112
113
DeformConv2d_backward_cpu(
    const at::Tensor& grad_out,
    const at::Tensor& input,
    const at::Tensor& weight,
    const at::Tensor& offset,
    const at::Tensor& bias,
    std::pair<int, int> stride,
    std::pair<int, int> pad,
    std::pair<int, int> dilation,
    int groups,
    int deformable_groups);