#pragma once
#include "megdnn/oprs.h"
#include "src/cuda/utils.h"
namespace megdnn {
namespace cuda {
class TQTForwardImpl final : public TQTForward {
public:
using TQTForward::TQTForward;
void exec(
_megdnn_tensor_in input, _megdnn_tensor_in scale, _megdnn_tensor_out output,
_megdnn_workspace workspace) override;
size_t get_workspace_in_bytes(
const TensorLayout&,
const TensorLayout&,
const TensorLayout& ) override {
return 0;
}
private:
void exec_noncontig(
_megdnn_tensor_in input, _megdnn_tensor_in scale,
_megdnn_tensor_out output);
};
class TQTBackwardImpl final : public TQTBackward {
public:
using TQTBackward::TQTBackward;
void exec(
_megdnn_tensor_in diff, _megdnn_tensor_in input, _megdnn_tensor_in scale,
_megdnn_tensor_out grad_x, _megdnn_tensor_out grad_s,
_megdnn_workspace workspace) override;
size_t get_workspace_in_bytes(
const TensorLayout& , const TensorLayout& ,
const TensorLayout& , const TensorLayout& ,
const TensorLayout& ) override {
return 0;
}
private:
void exec_noncontig(
_megdnn_tensor_in diff, _megdnn_tensor_in input, _megdnn_tensor_in scale,
_megdnn_tensor_out grad_x, _megdnn_tensor_out grad_s);
};
} }