/**
 * @file registry.cpp
 * @brief Soft Hamming Operator Schema Registration
 *
 * Registers operator schemas for the d2p::soft_hamming family of functions.
 * CPU and CUDA implementations are registered in their respective files.
 */

#include <torch/extension.h>

#ifdef USE_TORCH_LIBRARY

TORCH_LIBRARY_FRAGMENT(d2p, m) {
    // Main autograd function with tensor parameters
    // Returns (distance, posteriors) tuple
    m.def("soft_hamming(Tensor costs, Tensor temperature, Tensor lengths) -> Tensor[]");

    // Convenience function with float parameters (no param gradient)
    m.def("soft_hamming_float(Tensor costs, float temperature, Tensor? lengths) -> Tensor[]");

    // Forward + backward with explicit outputs for debugging
    // Returns (distance, posteriors, grad_T)
    m.def("soft_hamming_with_grads(Tensor costs, float temperature, Tensor? lengths) -> (Tensor, Tensor, Tensor)");

    // Hessian-vector product (always zero for Hamming - linear function)
    m.def("soft_hamming_hvp(Tensor costs, Tensor tangent, float temperature, Tensor? lengths) -> Tensor");

    // Complete backward given grad_output
    // Returns (grad_costs, grad_temperature)
    m.def("soft_hamming_backward_full(Tensor costs, Tensor grad_output, float temperature, Tensor? lengths) -> (Tensor, Tensor)");
}

#endif // USE_TORCH_LIBRARY
