#include "cdflib/chndtr.cuh"
#include "kernels.cuh"

#ifndef _USE_MATH_DEFINES
#define _USE_MATH_DEFINES
#endif
#include <math.h>
#include <cmath>

#include <ATen/ATen.h>
#include <ATen/Dispatch.h>
#include <ATen/cuda/CUDAApplyUtils.cuh>
#include <ATen/native/cuda/Loops.cuh>
#include <ATen/native/cuda/Math.cuh>


namespace cdf_ops {
namespace cuda {

void chndtr_scalar_double_kernel_cuda(at::TensorIterator& iter, double df) {
    const at::cuda::OptionalCUDAGuard device_guard(iter.device());
    AT_ASSERT (df > cdflib::cuda::chndtr_double_thresh);
    // double
    AT_DISPATCH_FLOATING_TYPES(iter.dtype(), "chndtr_scalar_cuda", [&]() {
        at::native::gpu_kernel(iter, [=]GPU_LAMBDA(scalar_t x, scalar_t pnonc) -> scalar_t {
            return static_cast<scalar_t>(cdflib::cuda::chndtr<double>(x, df, pnonc));
        });
    });
}

} // namespace cuda
} // namespace cdf_ops
