/*
Segment Operations (mean, max, min)
Written by Li Jiang
All Rights Reserved 2020.
*/

#include "sec_mean.h"

void sec_mean(at::Tensor inp_tensor, at::Tensor offsets_tensor, at::Tensor out_tensor, int nProposal, int C){
    int *offsets = offsets_tensor.data_ptr<int>();
    float *inp = inp_tensor.data_ptr<float>();
    float *out = out_tensor.data_ptr<float>();

    sec_mean_cuda(nProposal, C, inp, offsets, out);
}

void sec_min(at::Tensor inp_tensor, at::Tensor offsets_tensor, at::Tensor out_tensor, int nProposal, int C){
    int *offsets = offsets_tensor.data_ptr<int>();
    float *inp = inp_tensor.data_ptr<float>();
    float *out = out_tensor.data_ptr<float>();

    sec_min_cuda(nProposal, C, inp, offsets, out);
}

void sec_max(at::Tensor inp_tensor, at::Tensor offsets_tensor, at::Tensor out_tensor, int nProposal, int C){
    int *offsets = offsets_tensor.data_ptr<int>();
    float *inp = inp_tensor.data_ptr<float>();
    float *out = out_tensor.data_ptr<float>();

    sec_max_cuda(nProposal, C, inp, offsets, out);
}