#pragma once
#include "megdnn/oprs.h"
namespace megdnn {
namespace cuda {
class ConvPoolingForwardImpl final : public ConvPoolingForward {
public:
ConvPoolingForwardImpl(Handle* handle);
void exec(
const _megdnn_in TensorND src, const _megdnn_in TensorND filter,
const _megdnn_in TensorND bias, _megdnn_out TensorND dst,
_megdnn_out Workspace workspace) override;
void deduce_layout(
const TensorLayout& src, const TensorLayout& filter,
const TensorLayout& bias, TensorLayout& dst) override;
void check_layout(
const TensorLayout& src, const TensorLayout& filter,
const TensorLayout& bias, TensorLayout& dst,
size_t workspace_limit_in_bytes) override;
size_t get_workspace_in_bytes(
const TensorLayout& src, const TensorLayout& filter,
const TensorLayout& bias, const TensorLayout& dst) override;
};
} }