// clang-format off py::class_, OpDef> AdaptivePoolingInst(m, "AdaptivePooling"); py::enum_(AdaptivePoolingInst, "Mode") .value("MAX", AdaptivePooling::Mode::MAX) .value("AVERAGE", AdaptivePooling::Mode::AVERAGE) .value("AVERAGE_COUNT_EXCLUDE_PADDING", AdaptivePooling::Mode::AVERAGE_COUNT_EXCLUDE_PADDING) .def(py::init([](const std::string& in) { auto&& str = normalize_enum(in); if (str == "MAX") return AdaptivePooling::Mode::MAX; if (str == "AVERAGE") return AdaptivePooling::Mode::AVERAGE; if (str == "AVERAGE_COUNT_EXCLUDE_PADDING") return AdaptivePooling::Mode::AVERAGE_COUNT_EXCLUDE_PADDING; throw py::cast_error("invalid enum value " + in); })); py::implicitly_convertible(); py::enum_(AdaptivePoolingInst, "Format") .value("NCHW", AdaptivePooling::Format::NCHW) .value("NHWC", AdaptivePooling::Format::NHWC) .value("NHWCD4", AdaptivePooling::Format::NHWCD4) .value("NCHW4", AdaptivePooling::Format::NCHW4) .value("NCHW8", AdaptivePooling::Format::NCHW8) .value("NCHW32", AdaptivePooling::Format::NCHW32) .value("NCHW88", AdaptivePooling::Format::NCHW88) .value("NCHW44", AdaptivePooling::Format::NCHW44) .value("NCHW44_DOT", AdaptivePooling::Format::NCHW44_DOT) .value("NCHW4_NCHW32", AdaptivePooling::Format::NCHW4_NCHW32) .value("NCHW32_NCHW4", AdaptivePooling::Format::NCHW32_NCHW4) .value("NCHW4_NCHW", AdaptivePooling::Format::NCHW4_NCHW) .value("NHWC_NCHW", AdaptivePooling::Format::NHWC_NCHW) .value("NHWC_NCHW4_IC_SMALL", AdaptivePooling::Format::NHWC_NCHW4_IC_SMALL) .value("NCHW_NCHW4_IC_SMALL", AdaptivePooling::Format::NCHW_NCHW4_IC_SMALL) .value("CHWN4", AdaptivePooling::Format::CHWN4) .value("NCHW64", AdaptivePooling::Format::NCHW64) .value("NCHW4_NHWC", AdaptivePooling::Format::NCHW4_NHWC) .def(py::init([](const std::string& in) { auto&& str = normalize_enum(in); if (str == "NCHW") return AdaptivePooling::Format::NCHW; if (str == "NHWC") return AdaptivePooling::Format::NHWC; if (str == "NHWCD4") return AdaptivePooling::Format::NHWCD4; if (str == "NCHW4") return AdaptivePooling::Format::NCHW4; if (str == "NCHW8") return AdaptivePooling::Format::NCHW8; if (str == "NCHW32") return AdaptivePooling::Format::NCHW32; if (str == "NCHW88") return AdaptivePooling::Format::NCHW88; if (str == "NCHW44") return AdaptivePooling::Format::NCHW44; if (str == "NCHW44_DOT") return AdaptivePooling::Format::NCHW44_DOT; if (str == "NCHW4_NCHW32") return AdaptivePooling::Format::NCHW4_NCHW32; if (str == "NCHW32_NCHW4") return AdaptivePooling::Format::NCHW32_NCHW4; if (str == "NCHW4_NCHW") return AdaptivePooling::Format::NCHW4_NCHW; if (str == "NHWC_NCHW") return AdaptivePooling::Format::NHWC_NCHW; if (str == "NHWC_NCHW4_IC_SMALL") return AdaptivePooling::Format::NHWC_NCHW4_IC_SMALL; if (str == "NCHW_NCHW4_IC_SMALL") return AdaptivePooling::Format::NCHW_NCHW4_IC_SMALL; if (str == "CHWN4") return AdaptivePooling::Format::CHWN4; if (str == "NCHW64") return AdaptivePooling::Format::NCHW64; if (str == "NCHW4_NHWC") return AdaptivePooling::Format::NCHW4_NHWC; throw py::cast_error("invalid enum value " + in); })); py::implicitly_convertible(); AdaptivePoolingInst .def(py::init<::megdnn::param::AdaptivePooling::Mode, ::megdnn::param::AdaptivePooling::Format, std::vector, std::string>(), py::arg("mode") = ::megdnn::param::AdaptivePooling::Mode::MAX, py::arg("format") = ::megdnn::param::AdaptivePooling::Format::NCHW, py::arg("shape"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("mode", &AdaptivePooling::mode) .def_readwrite("format", &AdaptivePooling::format) .def_readwrite("shape", &AdaptivePooling::shape); py::class_, OpDef> AddAxisInst(m, "AddAxis"); AddAxisInst .def(py::init, std::string>(), py::arg("axis"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("axis", &AddAxis::axis); py::class_, OpDef> ArgmaxInst(m, "Argmax"); ArgmaxInst .def(py::init(), py::arg("axis") = 0, py::arg("scope") = {}) .def_readwrite("axis", &Argmax::axis); py::class_, OpDef> ArgminInst(m, "Argmin"); ArgminInst .def(py::init(), py::arg("axis") = 0, py::arg("scope") = {}) .def_readwrite("axis", &Argmin::axis); py::class_, OpDef> ArgsortInst(m, "Argsort"); py::enum_(ArgsortInst, "Order") .value("ASCENDING", Argsort::Order::ASCENDING) .value("DESCENDING", Argsort::Order::DESCENDING) .def(py::init([](const std::string& in) { auto&& str = normalize_enum(in); if (str == "ASCENDING") return Argsort::Order::ASCENDING; if (str == "DESCENDING") return Argsort::Order::DESCENDING; throw py::cast_error("invalid enum value " + in); })); py::implicitly_convertible(); ArgsortInst .def(py::init<::megdnn::param::Argsort::Order, std::string>(), py::arg("order") = ::megdnn::param::Argsort::Order::ASCENDING, py::arg("scope") = {}) .def_readwrite("order", &Argsort::order); py::class_, OpDef> AssertEqualInst(m, "AssertEqual"); AssertEqualInst .def(py::init(), py::arg("maxerr") = 0.0001, py::arg("verbose") = false, py::arg("scope") = {}) .def_readwrite("maxerr", &AssertEqual::maxerr) .def_readwrite("verbose", &AssertEqual::verbose); py::class_, OpDef> AtlasRuntimeInst(m, "AtlasRuntime"); AtlasRuntimeInst .def(py::init(), py::arg("buf"), py::arg("buf_size"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("buf", &AtlasRuntime::buf) .def_readwrite("buf_size", &AtlasRuntime::buf_size); py::class_, OpDef> BarrierInst(m, "Barrier"); BarrierInst .def(py::init<::mgb::CompNode, uint32_t, std::string>(), py::arg("comp_node"), py::arg("nr_outputs"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("comp_node", &Barrier::comp_node) .def_readwrite("nr_outputs", &Barrier::nr_outputs); py::class_, OpDef> BatchConvBiasInst(m, "BatchConvBias"); py::enum_(BatchConvBiasInst, "NonlineMode") .value("IDENTITY", BatchConvBias::NonlineMode::IDENTITY) .value("RELU", BatchConvBias::NonlineMode::RELU) .value("SIGMOID", BatchConvBias::NonlineMode::SIGMOID) .value("H_SWISH", BatchConvBias::NonlineMode::H_SWISH) .def(py::init([](const std::string& in) { auto&& str = normalize_enum(in); if (str == "IDENTITY") return BatchConvBias::NonlineMode::IDENTITY; if (str == "RELU") return BatchConvBias::NonlineMode::RELU; if (str == "SIGMOID") return BatchConvBias::NonlineMode::SIGMOID; if (str == "H_SWISH") return BatchConvBias::NonlineMode::H_SWISH; throw py::cast_error("invalid enum value " + in); })); py::implicitly_convertible(); py::enum_(BatchConvBiasInst, "Mode") .value("CROSS_CORRELATION", BatchConvBias::Mode::CROSS_CORRELATION) .value("CONVOLUTION", BatchConvBias::Mode::CONVOLUTION) .def(py::init([](const std::string& in) { auto&& str = normalize_enum(in); if (str == "CROSS_CORRELATION") return BatchConvBias::Mode::CROSS_CORRELATION; if (str == "CONVOLUTION") return BatchConvBias::Mode::CONVOLUTION; throw py::cast_error("invalid enum value " + in); })); py::implicitly_convertible(); py::enum_(BatchConvBiasInst, "Sparse") .value("DENSE", BatchConvBias::Sparse::DENSE) .value("GROUP", BatchConvBias::Sparse::GROUP) .def(py::init([](const std::string& in) { auto&& str = normalize_enum(in); if (str == "DENSE") return BatchConvBias::Sparse::DENSE; if (str == "GROUP") return BatchConvBias::Sparse::GROUP; throw py::cast_error("invalid enum value " + in); })); py::implicitly_convertible(); BatchConvBiasInst.attr("Format") = AdaptivePoolingInst.attr("Format"); py::enum_(BatchConvBiasInst, "ComputeMode") .value("DEFAULT", BatchConvBias::ComputeMode::DEFAULT) .value("FLOAT32", BatchConvBias::ComputeMode::FLOAT32) .def(py::init([](const std::string& in) { auto&& str = normalize_enum(in); if (str == "DEFAULT") return BatchConvBias::ComputeMode::DEFAULT; if (str == "FLOAT32") return BatchConvBias::ComputeMode::FLOAT32; throw py::cast_error("invalid enum value " + in); })); py::implicitly_convertible(); py::enum_(BatchConvBiasInst, "Strategy") .value("HEURISTIC", BatchConvBias::Strategy::HEURISTIC) .value("PROFILE", BatchConvBias::Strategy::PROFILE) .value("REPRODUCIBLE", BatchConvBias::Strategy::REPRODUCIBLE) .value("OPTIMIZED", BatchConvBias::Strategy::OPTIMIZED) .def("__or__", [](BatchConvBias::Strategy s0, BatchConvBias::Strategy s1) { return static_cast(uint32_t(s0) | uint32_t(s1)); }) .def("__and__", [](BatchConvBias::Strategy s0, BatchConvBias::Strategy s1) { return static_cast(uint32_t(s0) & uint32_t(s1)); }) .def(py::init([](const std::string& in) { auto&& str = normalize_enum(in); if (str == "HEURISTIC") return BatchConvBias::Strategy::HEURISTIC; if (str == "PROFILE") return BatchConvBias::Strategy::PROFILE; if (str == "REPRODUCIBLE") return BatchConvBias::Strategy::REPRODUCIBLE; if (str == "OPTIMIZED") return BatchConvBias::Strategy::OPTIMIZED; throw py::cast_error("invalid enum value " + in); })); py::implicitly_convertible(); BatchConvBiasInst .def(py::init<::megdnn::param::BatchConvBias::NonlineMode, ::megdnn::param::BatchConvBias::Mode, uint32_t, uint32_t, uint32_t, uint32_t, uint32_t, uint32_t, ::megdnn::param::BatchConvBias::Sparse, ::megdnn::param::BatchConvBias::Format, ::megdnn::param::BatchConvBias::ComputeMode, ::megdnn::param::ExecutionPolicy::Strategy, uint64_t, ::megdnn::DType, std::string>(), py::arg("nonlineMode") = ::megdnn::param::BatchConvBias::NonlineMode::IDENTITY, py::arg("mode") = ::megdnn::param::BatchConvBias::Mode::CROSS_CORRELATION, py::arg("pad_h") = 0, py::arg("pad_w") = 0, py::arg("stride_h") = 1, py::arg("stride_w") = 1, py::arg("dilate_h") = 1, py::arg("dilate_w") = 1, py::arg("sparse") = ::megdnn::param::BatchConvBias::Sparse::DENSE, py::arg("format") = ::megdnn::param::BatchConvBias::Format::NCHW, py::arg("compute_mode") = ::megdnn::param::BatchConvBias::ComputeMode::DEFAULT, py::arg("strategy") = static_cast<::megdnn::param::ExecutionPolicy::Strategy>(1), py::arg("workspace_limit") = 18446744073709551615ull, py::arg("dtype"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("nonlineMode", &BatchConvBias::nonlineMode) .def_readwrite("mode", &BatchConvBias::mode) .def_readwrite("pad_h", &BatchConvBias::pad_h) .def_readwrite("pad_w", &BatchConvBias::pad_w) .def_readwrite("stride_h", &BatchConvBias::stride_h) .def_readwrite("stride_w", &BatchConvBias::stride_w) .def_readwrite("dilate_h", &BatchConvBias::dilate_h) .def_readwrite("dilate_w", &BatchConvBias::dilate_w) .def_readwrite("sparse", &BatchConvBias::sparse) .def_readwrite("format", &BatchConvBias::format) .def_readwrite("compute_mode", &BatchConvBias::compute_mode) .def_readwrite("strategy", &BatchConvBias::strategy) .def_readwrite("workspace_limit", &BatchConvBias::workspace_limit) .def_readwrite("dtype", &BatchConvBias::dtype); py::class_, OpDef> BatchNormInst(m, "BatchNorm"); py::enum_(BatchNormInst, "ParamDim") .value("DIM_11HW", BatchNorm::ParamDim::DIM_11HW) .value("DIM_1CHW", BatchNorm::ParamDim::DIM_1CHW) .value("DIM_1C11", BatchNorm::ParamDim::DIM_1C11) .value("DIM_111C", BatchNorm::ParamDim::DIM_111C) .def(py::init([](const std::string& in) { auto&& str = normalize_enum(in); if (str == "DIM_11HW") return BatchNorm::ParamDim::DIM_11HW; if (str == "DIM_1CHW") return BatchNorm::ParamDim::DIM_1CHW; if (str == "DIM_1C11") return BatchNorm::ParamDim::DIM_1C11; if (str == "DIM_111C") return BatchNorm::ParamDim::DIM_111C; throw py::cast_error("invalid enum value " + in); })); py::implicitly_convertible(); py::enum_(BatchNormInst, "FwdMode") .value("TRAINING", BatchNorm::FwdMode::TRAINING) .value("INFERENCE", BatchNorm::FwdMode::INFERENCE) .def(py::init([](const std::string& in) { auto&& str = normalize_enum(in); if (str == "TRAINING") return BatchNorm::FwdMode::TRAINING; if (str == "INFERENCE") return BatchNorm::FwdMode::INFERENCE; throw py::cast_error("invalid enum value " + in); })); py::implicitly_convertible(); BatchNormInst .def(py::init<::megdnn::param::BN::ParamDim, ::megdnn::param::BN::FwdMode, double, double, float, float, std::string>(), py::arg("param_dim") = ::megdnn::param::BN::ParamDim::DIM_11HW, py::arg("fwd_mode") = ::megdnn::param::BN::FwdMode::TRAINING, py::arg("epsilon") = 1e-4f, py::arg("avg_factor") = 1.f, py::arg("scale") = 1.f, py::arg("bias") = 0.f, py::arg("scope") = {}) .def_readwrite("param_dim", &BatchNorm::param_dim) .def_readwrite("fwd_mode", &BatchNorm::fwd_mode) .def_readwrite("epsilon", &BatchNorm::epsilon) .def_readwrite("avg_factor", &BatchNorm::avg_factor) .def_readwrite("scale", &BatchNorm::scale) .def_readwrite("bias", &BatchNorm::bias); py::class_, OpDef> BatchNormBackwardInst(m, "BatchNormBackward"); BatchNormBackwardInst.attr("ParamDim") = BatchNormInst.attr("ParamDim"); BatchNormBackwardInst.attr("FwdMode") = BatchNormInst.attr("FwdMode"); BatchNormBackwardInst .def(py::init<::megdnn::param::BN::ParamDim, ::megdnn::param::BN::FwdMode, double, double, float, float, std::string>(), py::arg("param_dim") = ::megdnn::param::BN::ParamDim::DIM_11HW, py::arg("fwd_mode") = ::megdnn::param::BN::FwdMode::TRAINING, py::arg("epsilon") = 1e-4f, py::arg("avg_factor") = 1.f, py::arg("scale") = 1.f, py::arg("bias") = 0.f, py::arg("scope") = {}) .def_readwrite("param_dim", &BatchNormBackward::param_dim) .def_readwrite("fwd_mode", &BatchNormBackward::fwd_mode) .def_readwrite("epsilon", &BatchNormBackward::epsilon) .def_readwrite("avg_factor", &BatchNormBackward::avg_factor) .def_readwrite("scale", &BatchNormBackward::scale) .def_readwrite("bias", &BatchNormBackward::bias); py::class_, OpDef> BatchedIncrMeshIndexingInst(m, "BatchedIncrMeshIndexing"); BatchedIncrMeshIndexingInst .def(py::init>, std::string>(), py::arg("items"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("items", &BatchedIncrMeshIndexing::items); py::class_, OpDef> BatchedMatrixMulInst(m, "BatchedMatrixMul"); py::enum_(BatchedMatrixMulInst, "ComputeMode") .value("DEFAULT", BatchedMatrixMul::ComputeMode::DEFAULT) .value("FLOAT32", BatchedMatrixMul::ComputeMode::FLOAT32) .def(py::init([](const std::string& in) { auto&& str = normalize_enum(in); if (str == "DEFAULT") return BatchedMatrixMul::ComputeMode::DEFAULT; if (str == "FLOAT32") return BatchedMatrixMul::ComputeMode::FLOAT32; throw py::cast_error("invalid enum value " + in); })); py::implicitly_convertible(); py::enum_(BatchedMatrixMulInst, "Format") .value("DEFAULT", BatchedMatrixMul::Format::DEFAULT) .value("MK4", BatchedMatrixMul::Format::MK4) .value("MK8", BatchedMatrixMul::Format::MK8) .value("MK4_DOT", BatchedMatrixMul::Format::MK4_DOT) .value("N32K4_DOT", BatchedMatrixMul::Format::N32K4_DOT) .def(py::init([](const std::string& in) { auto&& str = normalize_enum(in); if (str == "DEFAULT") return BatchedMatrixMul::Format::DEFAULT; if (str == "MK4") return BatchedMatrixMul::Format::MK4; if (str == "MK8") return BatchedMatrixMul::Format::MK8; if (str == "MK4_DOT") return BatchedMatrixMul::Format::MK4_DOT; if (str == "N32K4_DOT") return BatchedMatrixMul::Format::N32K4_DOT; throw py::cast_error("invalid enum value " + in); })); py::implicitly_convertible(); BatchedMatrixMulInst.attr("Strategy") = BatchConvBiasInst.attr("Strategy"); BatchedMatrixMulInst .def(py::init(), py::arg("transposeA") = false, py::arg("transposeB") = false, py::arg("compute_mode") = ::megdnn::param::MatrixMul::ComputeMode::DEFAULT, py::arg("format") = ::megdnn::param::MatrixMul::Format::DEFAULT, py::arg("strategy") = static_cast<::megdnn::param::ExecutionPolicy::Strategy>(1), py::arg("workspace_limit") = 18446744073709551615ull, py::arg("dimA"), py::arg("dimB"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("transposeA", &BatchedMatrixMul::transposeA) .def_readwrite("transposeB", &BatchedMatrixMul::transposeB) .def_readwrite("compute_mode", &BatchedMatrixMul::compute_mode) .def_readwrite("format", &BatchedMatrixMul::format) .def_readwrite("strategy", &BatchedMatrixMul::strategy) .def_readwrite("workspace_limit", &BatchedMatrixMul::workspace_limit) .def_readwrite("dimA", &BatchedMatrixMul::dimA) .def_readwrite("dimB", &BatchedMatrixMul::dimB); py::class_, OpDef> BatchedMeshIndexingInst(m, "BatchedMeshIndexing"); BatchedMeshIndexingInst .def(py::init>, std::string>(), py::arg("items"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("items", &BatchedMeshIndexing::items); py::class_, OpDef> BatchedSetMeshIndexingInst(m, "BatchedSetMeshIndexing"); BatchedSetMeshIndexingInst .def(py::init>, std::string>(), py::arg("items"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("items", &BatchedSetMeshIndexing::items); py::class_, OpDef> BetaRNGInst(m, "BetaRNG"); BetaRNGInst .def(py::init(), py::arg("seed") = 0, py::arg("handle"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("seed", &BetaRNG::seed) .def_readwrite("handle", &BetaRNG::handle); py::class_, OpDef> BorrowInst(m, "Borrow"); BorrowInst .def(py::init<::mgb::CompNode, std::string>(), py::arg("comp_node"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("comp_node", &Borrow::comp_node); py::class_, OpDef> BroadcastInst(m, "Broadcast"); BroadcastInst .def(py::init, std::string>(), py::arg("shape"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("shape", &Broadcast::shape); py::class_, OpDef> CambriconRuntimeInst(m, "CambriconRuntime"); CambriconRuntimeInst .def(py::init(), py::arg("buf"), py::arg("buf_size"), py::arg("symbol"), py::arg("tensor_dim_mutable"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("buf", &CambriconRuntime::buf) .def_readwrite("buf_size", &CambriconRuntime::buf_size) .def_readwrite("symbol", &CambriconRuntime::symbol) .def_readwrite("tensor_dim_mutable", &CambriconRuntime::tensor_dim_mutable); py::class_, OpDef> CheckNonFiniteInst(m, "CheckNonFinite"); CheckNonFiniteInst .def(py::init(), py::arg("scale") = 1.0, py::arg("scope") = {}) .def_readwrite("scale", &CheckNonFinite::scale); py::class_, OpDef> CollectiveCommInst(m, "CollectiveComm"); py::enum_(CollectiveCommInst, "Mode") .value("REDUCE_SUM", CollectiveComm::Mode::REDUCE_SUM) .value("BROADCAST", CollectiveComm::Mode::BROADCAST) .value("ALL_GATHER", CollectiveComm::Mode::ALL_GATHER) .value("REDUCE_SCATTER_SUM", CollectiveComm::Mode::REDUCE_SCATTER_SUM) .value("ALL_REDUCE_SUM", CollectiveComm::Mode::ALL_REDUCE_SUM) .value("ALL_REDUCE_MAX", CollectiveComm::Mode::ALL_REDUCE_MAX) .value("ALL_REDUCE_MIN", CollectiveComm::Mode::ALL_REDUCE_MIN) .value("ALL_REDUCE_PROD", CollectiveComm::Mode::ALL_REDUCE_PROD) .value("GATHER", CollectiveComm::Mode::GATHER) .value("SCATTER", CollectiveComm::Mode::SCATTER) .value("ALL_TO_ALL", CollectiveComm::Mode::ALL_TO_ALL) .def(py::init([](const std::string& in) { auto&& str = normalize_enum(in); if (str == "REDUCE_SUM") return CollectiveComm::Mode::REDUCE_SUM; if (str == "BROADCAST") return CollectiveComm::Mode::BROADCAST; if (str == "ALL_GATHER") return CollectiveComm::Mode::ALL_GATHER; if (str == "REDUCE_SCATTER_SUM") return CollectiveComm::Mode::REDUCE_SCATTER_SUM; if (str == "ALL_REDUCE_SUM") return CollectiveComm::Mode::ALL_REDUCE_SUM; if (str == "ALL_REDUCE_MAX") return CollectiveComm::Mode::ALL_REDUCE_MAX; if (str == "ALL_REDUCE_MIN") return CollectiveComm::Mode::ALL_REDUCE_MIN; if (str == "ALL_REDUCE_PROD") return CollectiveComm::Mode::ALL_REDUCE_PROD; if (str == "GATHER") return CollectiveComm::Mode::GATHER; if (str == "SCATTER") return CollectiveComm::Mode::SCATTER; if (str == "ALL_TO_ALL") return CollectiveComm::Mode::ALL_TO_ALL; throw py::cast_error("invalid enum value " + in); })); py::implicitly_convertible(); CollectiveCommInst .def(py::init<::megdnn::param::CollectiveComm::Mode, std::string, uint32_t, uint32_t, bool, bool, std::string, uint32_t, ::megdnn::DType, std::string, std::string, std::string>(), py::arg("mode") = ::megdnn::param::CollectiveComm::Mode::REDUCE_SUM, py::arg("key"), py::arg("nr_devices"), py::arg("rank"), py::arg("is_root"), py::arg("local_grad"), py::arg("addr"), py::arg("port"), py::arg("dtype"), py::arg("backend"), py::arg("comp_node"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("mode", &CollectiveComm::mode) .def_readwrite("key", &CollectiveComm::key) .def_readwrite("nr_devices", &CollectiveComm::nr_devices) .def_readwrite("rank", &CollectiveComm::rank) .def_readwrite("is_root", &CollectiveComm::is_root) .def_readwrite("local_grad", &CollectiveComm::local_grad) .def_readwrite("addr", &CollectiveComm::addr) .def_readwrite("port", &CollectiveComm::port) .def_readwrite("dtype", &CollectiveComm::dtype) .def_readwrite("backend", &CollectiveComm::backend) .def_readwrite("comp_node", &CollectiveComm::comp_node); py::class_, OpDef> ConcatInst(m, "Concat"); ConcatInst .def(py::init(), py::arg("axis") = 0, py::arg("comp_node"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("axis", &Concat::axis) .def_readwrite("comp_node", &Concat::comp_node); py::class_, OpDef> CondTakeInst(m, "CondTake"); CondTakeInst .def(py::init<>()); py::class_, OpDef> ConvBiasInst(m, "ConvBias"); ConvBiasInst.attr("NonlineMode") = BatchConvBiasInst.attr("NonlineMode"); ConvBiasInst.attr("Mode") = BatchConvBiasInst.attr("Mode"); ConvBiasInst.attr("Sparse") = BatchConvBiasInst.attr("Sparse"); ConvBiasInst.attr("Format") = AdaptivePoolingInst.attr("Format"); ConvBiasInst.attr("ComputeMode") = BatchConvBiasInst.attr("ComputeMode"); ConvBiasInst.attr("Strategy") = BatchConvBiasInst.attr("Strategy"); ConvBiasInst .def(py::init<::megdnn::param::ConvBias::NonlineMode, ::megdnn::param::ConvBias::Mode, ::megdnn::param::ConvBias::Sparse, ::megdnn::param::ConvBias::Format, uint32_t, uint32_t, uint32_t, uint32_t, uint32_t, uint32_t, ::megdnn::param::ConvBias::ComputeMode, ::megdnn::param::ExecutionPolicy::Strategy, uint64_t, ::megdnn::DType, std::string>(), py::arg("nonlineMode") = ::megdnn::param::ConvBias::NonlineMode::IDENTITY, py::arg("mode") = ::megdnn::param::ConvBias::Mode::CROSS_CORRELATION, py::arg("sparse") = ::megdnn::param::ConvBias::Sparse::DENSE, py::arg("format") = ::megdnn::param::ConvBias::Format::NCHW, py::arg("pad_h") = 0, py::arg("pad_w") = 0, py::arg("stride_h") = 1, py::arg("stride_w") = 1, py::arg("dilate_h") = 1, py::arg("dilate_w") = 1, py::arg("compute_mode") = ::megdnn::param::ConvBias::ComputeMode::DEFAULT, py::arg("strategy") = static_cast<::megdnn::param::ExecutionPolicy::Strategy>(1), py::arg("workspace_limit") = 18446744073709551615ull, py::arg("dtype"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("nonlineMode", &ConvBias::nonlineMode) .def_readwrite("mode", &ConvBias::mode) .def_readwrite("sparse", &ConvBias::sparse) .def_readwrite("format", &ConvBias::format) .def_readwrite("pad_h", &ConvBias::pad_h) .def_readwrite("pad_w", &ConvBias::pad_w) .def_readwrite("stride_h", &ConvBias::stride_h) .def_readwrite("stride_w", &ConvBias::stride_w) .def_readwrite("dilate_h", &ConvBias::dilate_h) .def_readwrite("dilate_w", &ConvBias::dilate_w) .def_readwrite("compute_mode", &ConvBias::compute_mode) .def_readwrite("strategy", &ConvBias::strategy) .def_readwrite("workspace_limit", &ConvBias::workspace_limit) .def_readwrite("dtype", &ConvBias::dtype); py::class_, OpDef> ConvolutionInst(m, "Convolution"); ConvolutionInst.attr("Mode") = BatchConvBiasInst.attr("Mode"); ConvolutionInst.attr("Sparse") = BatchConvBiasInst.attr("Sparse"); ConvolutionInst.attr("Format") = AdaptivePoolingInst.attr("Format"); ConvolutionInst.attr("ComputeMode") = BatchConvBiasInst.attr("ComputeMode"); ConvolutionInst.attr("Strategy") = BatchConvBiasInst.attr("Strategy"); ConvolutionInst .def(py::init<::megdnn::param::Convolution::Mode, uint32_t, uint32_t, uint32_t, uint32_t, uint32_t, uint32_t, ::megdnn::param::Convolution::Sparse, ::megdnn::param::Convolution::Format, ::megdnn::param::Convolution::ComputeMode, ::megdnn::param::ExecutionPolicy::Strategy, uint64_t, std::string>(), py::arg("mode") = ::megdnn::param::Convolution::Mode::CROSS_CORRELATION, py::arg("pad_h") = 0, py::arg("pad_w") = 0, py::arg("stride_h") = 1, py::arg("stride_w") = 1, py::arg("dilate_h") = 1, py::arg("dilate_w") = 1, py::arg("sparse") = ::megdnn::param::Convolution::Sparse::DENSE, py::arg("format") = ::megdnn::param::Convolution::Format::NCHW, py::arg("compute_mode") = ::megdnn::param::Convolution::ComputeMode::DEFAULT, py::arg("strategy") = static_cast<::megdnn::param::ExecutionPolicy::Strategy>(1), py::arg("workspace_limit") = 18446744073709551615ull, py::arg("scope") = {}) .def_readwrite("mode", &Convolution::mode) .def_readwrite("pad_h", &Convolution::pad_h) .def_readwrite("pad_w", &Convolution::pad_w) .def_readwrite("stride_h", &Convolution::stride_h) .def_readwrite("stride_w", &Convolution::stride_w) .def_readwrite("dilate_h", &Convolution::dilate_h) .def_readwrite("dilate_w", &Convolution::dilate_w) .def_readwrite("sparse", &Convolution::sparse) .def_readwrite("format", &Convolution::format) .def_readwrite("compute_mode", &Convolution::compute_mode) .def_readwrite("strategy", &Convolution::strategy) .def_readwrite("workspace_limit", &Convolution::workspace_limit); py::class_, OpDef> Convolution3DInst(m, "Convolution3D"); py::enum_(Convolution3DInst, "Mode") .value("CROSS_CORRELATION", Convolution3D::Mode::CROSS_CORRELATION) .value("CONVOLUTION", Convolution3D::Mode::CONVOLUTION) .def(py::init([](const std::string& in) { auto&& str = normalize_enum(in); if (str == "CROSS_CORRELATION") return Convolution3D::Mode::CROSS_CORRELATION; if (str == "CONVOLUTION") return Convolution3D::Mode::CONVOLUTION; throw py::cast_error("invalid enum value " + in); })); py::implicitly_convertible(); py::enum_(Convolution3DInst, "Sparse") .value("DENSE", Convolution3D::Sparse::DENSE) .value("GROUP", Convolution3D::Sparse::GROUP) .def(py::init([](const std::string& in) { auto&& str = normalize_enum(in); if (str == "DENSE") return Convolution3D::Sparse::DENSE; if (str == "GROUP") return Convolution3D::Sparse::GROUP; throw py::cast_error("invalid enum value " + in); })); py::implicitly_convertible(); py::enum_(Convolution3DInst, "DataType") .value("FLOAT", Convolution3D::DataType::FLOAT) .value("FLOAT_IO16xC32", Convolution3D::DataType::FLOAT_IO16xC32) .def(py::init([](const std::string& in) { auto&& str = normalize_enum(in); if (str == "FLOAT") return Convolution3D::DataType::FLOAT; if (str == "FLOAT_IO16xC32") return Convolution3D::DataType::FLOAT_IO16xC32; throw py::cast_error("invalid enum value " + in); })); py::implicitly_convertible(); py::enum_(Convolution3DInst, "Format") .value("NCDHW", Convolution3D::Format::NCDHW) .value("NDHWC", Convolution3D::Format::NDHWC) .def(py::init([](const std::string& in) { auto&& str = normalize_enum(in); if (str == "NCDHW") return Convolution3D::Format::NCDHW; if (str == "NDHWC") return Convolution3D::Format::NDHWC; throw py::cast_error("invalid enum value " + in); })); py::implicitly_convertible(); Convolution3DInst.attr("Strategy") = BatchConvBiasInst.attr("Strategy"); Convolution3DInst .def(py::init<::megdnn::param::Convolution3D::Mode, uint32_t, uint32_t, uint32_t, uint32_t, uint32_t, uint32_t, uint32_t, uint32_t, uint32_t, ::megdnn::param::Convolution3D::Sparse, ::megdnn::param::Convolution3D::DataType, ::megdnn::param::Convolution3D::Format, ::megdnn::param::ExecutionPolicy::Strategy, uint64_t, std::string>(), py::arg("mode") = ::megdnn::param::Convolution3D::Mode::CROSS_CORRELATION, py::arg("pad_d") = 0, py::arg("pad_h") = 0, py::arg("pad_w") = 0, py::arg("stride_d") = 1, py::arg("stride_h") = 1, py::arg("stride_w") = 1, py::arg("dilate_d") = 1, py::arg("dilate_h") = 1, py::arg("dilate_w") = 1, py::arg("sparse") = ::megdnn::param::Convolution3D::Sparse::DENSE, py::arg("data_type") = ::megdnn::param::Convolution3D::DataType::FLOAT, py::arg("format") = ::megdnn::param::Convolution3D::Format::NCDHW, py::arg("strategy") = static_cast<::megdnn::param::ExecutionPolicy::Strategy>(1), py::arg("workspace_limit") = 18446744073709551615ull, py::arg("scope") = {}) .def_readwrite("mode", &Convolution3D::mode) .def_readwrite("pad_d", &Convolution3D::pad_d) .def_readwrite("pad_h", &Convolution3D::pad_h) .def_readwrite("pad_w", &Convolution3D::pad_w) .def_readwrite("stride_d", &Convolution3D::stride_d) .def_readwrite("stride_h", &Convolution3D::stride_h) .def_readwrite("stride_w", &Convolution3D::stride_w) .def_readwrite("dilate_d", &Convolution3D::dilate_d) .def_readwrite("dilate_h", &Convolution3D::dilate_h) .def_readwrite("dilate_w", &Convolution3D::dilate_w) .def_readwrite("sparse", &Convolution3D::sparse) .def_readwrite("data_type", &Convolution3D::data_type) .def_readwrite("format", &Convolution3D::format) .def_readwrite("strategy", &Convolution3D::strategy) .def_readwrite("workspace_limit", &Convolution3D::workspace_limit); py::class_, OpDef> Convolution3DBackwardDataInst(m, "Convolution3DBackwardData"); Convolution3DBackwardDataInst.attr("Mode") = Convolution3DInst.attr("Mode"); Convolution3DBackwardDataInst.attr("Sparse") = Convolution3DInst.attr("Sparse"); Convolution3DBackwardDataInst.attr("DataType") = Convolution3DInst.attr("DataType"); Convolution3DBackwardDataInst.attr("Format") = Convolution3DInst.attr("Format"); Convolution3DBackwardDataInst.attr("Strategy") = BatchConvBiasInst.attr("Strategy"); Convolution3DBackwardDataInst .def(py::init<::megdnn::param::Convolution3D::Mode, uint32_t, uint32_t, uint32_t, uint32_t, uint32_t, uint32_t, uint32_t, uint32_t, uint32_t, ::megdnn::param::Convolution3D::Sparse, ::megdnn::param::Convolution3D::DataType, ::megdnn::param::Convolution3D::Format, ::megdnn::param::ExecutionPolicy::Strategy, uint64_t, std::string>(), py::arg("mode") = ::megdnn::param::Convolution3D::Mode::CROSS_CORRELATION, py::arg("pad_d") = 0, py::arg("pad_h") = 0, py::arg("pad_w") = 0, py::arg("stride_d") = 1, py::arg("stride_h") = 1, py::arg("stride_w") = 1, py::arg("dilate_d") = 1, py::arg("dilate_h") = 1, py::arg("dilate_w") = 1, py::arg("sparse") = ::megdnn::param::Convolution3D::Sparse::DENSE, py::arg("data_type") = ::megdnn::param::Convolution3D::DataType::FLOAT, py::arg("format") = ::megdnn::param::Convolution3D::Format::NCDHW, py::arg("strategy") = static_cast<::megdnn::param::ExecutionPolicy::Strategy>(1), py::arg("workspace_limit") = 18446744073709551615ull, py::arg("scope") = {}) .def_readwrite("mode", &Convolution3DBackwardData::mode) .def_readwrite("pad_d", &Convolution3DBackwardData::pad_d) .def_readwrite("pad_h", &Convolution3DBackwardData::pad_h) .def_readwrite("pad_w", &Convolution3DBackwardData::pad_w) .def_readwrite("stride_d", &Convolution3DBackwardData::stride_d) .def_readwrite("stride_h", &Convolution3DBackwardData::stride_h) .def_readwrite("stride_w", &Convolution3DBackwardData::stride_w) .def_readwrite("dilate_d", &Convolution3DBackwardData::dilate_d) .def_readwrite("dilate_h", &Convolution3DBackwardData::dilate_h) .def_readwrite("dilate_w", &Convolution3DBackwardData::dilate_w) .def_readwrite("sparse", &Convolution3DBackwardData::sparse) .def_readwrite("data_type", &Convolution3DBackwardData::data_type) .def_readwrite("format", &Convolution3DBackwardData::format) .def_readwrite("strategy", &Convolution3DBackwardData::strategy) .def_readwrite("workspace_limit", &Convolution3DBackwardData::workspace_limit); py::class_, OpDef> ConvolutionBackwardDataInst(m, "ConvolutionBackwardData"); ConvolutionBackwardDataInst.attr("Mode") = BatchConvBiasInst.attr("Mode"); ConvolutionBackwardDataInst.attr("Sparse") = BatchConvBiasInst.attr("Sparse"); ConvolutionBackwardDataInst.attr("Format") = AdaptivePoolingInst.attr("Format"); ConvolutionBackwardDataInst.attr("ComputeMode") = BatchConvBiasInst.attr("ComputeMode"); ConvolutionBackwardDataInst.attr("Strategy") = BatchConvBiasInst.attr("Strategy"); ConvolutionBackwardDataInst .def(py::init<::megdnn::param::Convolution::Mode, uint32_t, uint32_t, uint32_t, uint32_t, uint32_t, uint32_t, ::megdnn::param::Convolution::Sparse, ::megdnn::param::Convolution::Format, ::megdnn::param::Convolution::ComputeMode, ::megdnn::param::ExecutionPolicy::Strategy, uint64_t, ::megdnn::DType, std::string>(), py::arg("mode") = ::megdnn::param::Convolution::Mode::CROSS_CORRELATION, py::arg("pad_h") = 0, py::arg("pad_w") = 0, py::arg("stride_h") = 1, py::arg("stride_w") = 1, py::arg("dilate_h") = 1, py::arg("dilate_w") = 1, py::arg("sparse") = ::megdnn::param::Convolution::Sparse::DENSE, py::arg("format") = ::megdnn::param::Convolution::Format::NCHW, py::arg("compute_mode") = ::megdnn::param::Convolution::ComputeMode::DEFAULT, py::arg("strategy") = static_cast<::megdnn::param::ExecutionPolicy::Strategy>(1), py::arg("workspace_limit") = 18446744073709551615ull, py::arg("dtype"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("mode", &ConvolutionBackwardData::mode) .def_readwrite("pad_h", &ConvolutionBackwardData::pad_h) .def_readwrite("pad_w", &ConvolutionBackwardData::pad_w) .def_readwrite("stride_h", &ConvolutionBackwardData::stride_h) .def_readwrite("stride_w", &ConvolutionBackwardData::stride_w) .def_readwrite("dilate_h", &ConvolutionBackwardData::dilate_h) .def_readwrite("dilate_w", &ConvolutionBackwardData::dilate_w) .def_readwrite("sparse", &ConvolutionBackwardData::sparse) .def_readwrite("format", &ConvolutionBackwardData::format) .def_readwrite("compute_mode", &ConvolutionBackwardData::compute_mode) .def_readwrite("strategy", &ConvolutionBackwardData::strategy) .def_readwrite("workspace_limit", &ConvolutionBackwardData::workspace_limit) .def_readwrite("dtype", &ConvolutionBackwardData::dtype); py::class_, OpDef> CopyInst(m, "Copy"); CopyInst .def(py::init<::mgb::CompNode, std::string>(), py::arg("comp_node"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("comp_node", &Copy::comp_node); py::class_, OpDef> CorrelationInst(m, "Correlation"); py::enum_(CorrelationInst, "Format") .value("NCHW", Correlation::Format::NCHW) .value("NHWC", Correlation::Format::NHWC) .value("NHWCD4", Correlation::Format::NHWCD4) .value("NCHW4", Correlation::Format::NCHW4) .value("NCHW8", Correlation::Format::NCHW8) .value("NCHW32", Correlation::Format::NCHW32) .value("NCHW88", Correlation::Format::NCHW88) .value("NCHW44", Correlation::Format::NCHW44) .value("NCHW44_DOT", Correlation::Format::NCHW44_DOT) .value("NCHW_WINOGRAD", Correlation::Format::NCHW_WINOGRAD) .value("NCHW88_WINOGRAD", Correlation::Format::NCHW88_WINOGRAD) .value("NCHW44_WINOGRAD", Correlation::Format::NCHW44_WINOGRAD) .value("NCHW4_NCHW32", Correlation::Format::NCHW4_NCHW32) .value("NCHW32_NCHW4", Correlation::Format::NCHW32_NCHW4) .value("NCHW4_NCHW", Correlation::Format::NCHW4_NCHW) .value("NHWC_NCHW", Correlation::Format::NHWC_NCHW) .value("NHWC_NCHW4_IC_SMALL", Correlation::Format::NHWC_NCHW4_IC_SMALL) .value("NCHW_NCHW4_IC_SMALL", Correlation::Format::NCHW_NCHW4_IC_SMALL) .value("CHWN4", Correlation::Format::CHWN4) .value("NCHW4_NHWC", Correlation::Format::NCHW4_NHWC) .def(py::init([](const std::string& in) { auto&& str = normalize_enum(in); if (str == "NCHW") return Correlation::Format::NCHW; if (str == "NHWC") return Correlation::Format::NHWC; if (str == "NHWCD4") return Correlation::Format::NHWCD4; if (str == "NCHW4") return Correlation::Format::NCHW4; if (str == "NCHW8") return Correlation::Format::NCHW8; if (str == "NCHW32") return Correlation::Format::NCHW32; if (str == "NCHW88") return Correlation::Format::NCHW88; if (str == "NCHW44") return Correlation::Format::NCHW44; if (str == "NCHW44_DOT") return Correlation::Format::NCHW44_DOT; if (str == "NCHW_WINOGRAD") return Correlation::Format::NCHW_WINOGRAD; if (str == "NCHW88_WINOGRAD") return Correlation::Format::NCHW88_WINOGRAD; if (str == "NCHW44_WINOGRAD") return Correlation::Format::NCHW44_WINOGRAD; if (str == "NCHW4_NCHW32") return Correlation::Format::NCHW4_NCHW32; if (str == "NCHW32_NCHW4") return Correlation::Format::NCHW32_NCHW4; if (str == "NCHW4_NCHW") return Correlation::Format::NCHW4_NCHW; if (str == "NHWC_NCHW") return Correlation::Format::NHWC_NCHW; if (str == "NHWC_NCHW4_IC_SMALL") return Correlation::Format::NHWC_NCHW4_IC_SMALL; if (str == "NCHW_NCHW4_IC_SMALL") return Correlation::Format::NCHW_NCHW4_IC_SMALL; if (str == "CHWN4") return Correlation::Format::CHWN4; if (str == "NCHW4_NHWC") return Correlation::Format::NCHW4_NHWC; throw py::cast_error("invalid enum value " + in); })); py::implicitly_convertible(); CorrelationInst .def(py::init<::megdnn::param::Correlation::Format, uint32_t, uint32_t, uint32_t, uint32_t, uint32_t, bool, std::string>(), py::arg("format") = ::megdnn::param::Correlation::Format::NCHW, py::arg("kernel_size") = 1, py::arg("max_displacement") = 1, py::arg("stride1") = 1, py::arg("stride2") = 1, py::arg("pad_size") = 0, py::arg("is_multiply") = true, py::arg("scope") = {}) .def_readwrite("format", &Correlation::format) .def_readwrite("kernel_size", &Correlation::kernel_size) .def_readwrite("max_displacement", &Correlation::max_displacement) .def_readwrite("stride1", &Correlation::stride1) .def_readwrite("stride2", &Correlation::stride2) .def_readwrite("pad_size", &Correlation::pad_size) .def_readwrite("is_multiply", &Correlation::is_multiply); py::class_, OpDef> CumsumInst(m, "Cumsum"); CumsumInst .def(py::init(), py::arg("axis") = 2147483647, py::arg("exclusive") = true, py::arg("reverse") = false, py::arg("scope") = {}) .def_readwrite("axis", &Cumsum::axis) .def_readwrite("exclusive", &Cumsum::exclusive) .def_readwrite("reverse", &Cumsum::reverse); py::class_, OpDef> CvtColorInst(m, "CvtColor"); py::enum_(CvtColorInst, "Mode") .value("RGB2GRAY", CvtColor::Mode::RGB2GRAY) .value("RGB2YUV", CvtColor::Mode::RGB2YUV) .value("YUV2RGB", CvtColor::Mode::YUV2RGB) .value("GRAY2RGB", CvtColor::Mode::GRAY2RGB) .value("RGBA2RGB", CvtColor::Mode::RGBA2RGB) .value("RGBA2BGR", CvtColor::Mode::RGBA2BGR) .value("RGBA2GRAY", CvtColor::Mode::RGBA2GRAY) .value("RGB2BGR", CvtColor::Mode::RGB2BGR) .value("BGR2GRAY", CvtColor::Mode::BGR2GRAY) .value("BGR2RGB", CvtColor::Mode::BGR2RGB) .value("YUV2GRAY_NV21", CvtColor::Mode::YUV2GRAY_NV21) .value("YUV2RGB_NV21", CvtColor::Mode::YUV2RGB_NV21) .value("YUV2BGR_NV21", CvtColor::Mode::YUV2BGR_NV21) .value("YUV2GRAY_NV12", CvtColor::Mode::YUV2GRAY_NV12) .value("YUV2RGB_NV12", CvtColor::Mode::YUV2RGB_NV12) .value("YUV2BGR_NV12", CvtColor::Mode::YUV2BGR_NV12) .value("YUV2GRAY_YV12", CvtColor::Mode::YUV2GRAY_YV12) .value("YUV2RGB_YV12", CvtColor::Mode::YUV2RGB_YV12) .value("YUV2BGR_YV12", CvtColor::Mode::YUV2BGR_YV12) .value("YUV2GRAY_YU12", CvtColor::Mode::YUV2GRAY_YU12) .value("YUV2RGB_YU12", CvtColor::Mode::YUV2RGB_YU12) .value("YUV2BGR_YU12", CvtColor::Mode::YUV2BGR_YU12) .value("YCrCb2RGB", CvtColor::Mode::YCrCb2RGB) .value("YCrCb2BGR", CvtColor::Mode::YCrCb2BGR) .value("BT601_YUV2RGB_NV21", CvtColor::Mode::BT601_YUV2RGB_NV21) .value("BT601_YUV2BGR_NV21", CvtColor::Mode::BT601_YUV2BGR_NV21) .value("BT601_YUV2RGB_NV12", CvtColor::Mode::BT601_YUV2RGB_NV12) .value("BT601_YUV2BGR_NV12", CvtColor::Mode::BT601_YUV2BGR_NV12) .value("BT601_YUV2RGB_YV12", CvtColor::Mode::BT601_YUV2RGB_YV12) .value("BT601_YUV2BGR_YV12", CvtColor::Mode::BT601_YUV2BGR_YV12) .value("BT601_YUV2RGB_YU12", CvtColor::Mode::BT601_YUV2RGB_YU12) .value("BT601_YUV2BGR_YU12", CvtColor::Mode::BT601_YUV2BGR_YU12) .def(py::init([](const std::string& in) { auto&& str = normalize_enum(in); if (str == "RGB2GRAY") return CvtColor::Mode::RGB2GRAY; if (str == "RGB2YUV") return CvtColor::Mode::RGB2YUV; if (str == "YUV2RGB") return CvtColor::Mode::YUV2RGB; if (str == "GRAY2RGB") return CvtColor::Mode::GRAY2RGB; if (str == "RGBA2RGB") return CvtColor::Mode::RGBA2RGB; if (str == "RGBA2BGR") return CvtColor::Mode::RGBA2BGR; if (str == "RGBA2GRAY") return CvtColor::Mode::RGBA2GRAY; if (str == "RGB2BGR") return CvtColor::Mode::RGB2BGR; if (str == "BGR2GRAY") return CvtColor::Mode::BGR2GRAY; if (str == "BGR2RGB") return CvtColor::Mode::BGR2RGB; if (str == "YUV2GRAY_NV21") return CvtColor::Mode::YUV2GRAY_NV21; if (str == "YUV2RGB_NV21") return CvtColor::Mode::YUV2RGB_NV21; if (str == "YUV2BGR_NV21") return CvtColor::Mode::YUV2BGR_NV21; if (str == "YUV2GRAY_NV12") return CvtColor::Mode::YUV2GRAY_NV12; if (str == "YUV2RGB_NV12") return CvtColor::Mode::YUV2RGB_NV12; if (str == "YUV2BGR_NV12") return CvtColor::Mode::YUV2BGR_NV12; if (str == "YUV2GRAY_YV12") return CvtColor::Mode::YUV2GRAY_YV12; if (str == "YUV2RGB_YV12") return CvtColor::Mode::YUV2RGB_YV12; if (str == "YUV2BGR_YV12") return CvtColor::Mode::YUV2BGR_YV12; if (str == "YUV2GRAY_YU12") return CvtColor::Mode::YUV2GRAY_YU12; if (str == "YUV2RGB_YU12") return CvtColor::Mode::YUV2RGB_YU12; if (str == "YUV2BGR_YU12") return CvtColor::Mode::YUV2BGR_YU12; if (str == "YCrCb2RGB") return CvtColor::Mode::YCrCb2RGB; if (str == "YCrCb2BGR") return CvtColor::Mode::YCrCb2BGR; if (str == "BT601_YUV2RGB_NV21") return CvtColor::Mode::BT601_YUV2RGB_NV21; if (str == "BT601_YUV2BGR_NV21") return CvtColor::Mode::BT601_YUV2BGR_NV21; if (str == "BT601_YUV2RGB_NV12") return CvtColor::Mode::BT601_YUV2RGB_NV12; if (str == "BT601_YUV2BGR_NV12") return CvtColor::Mode::BT601_YUV2BGR_NV12; if (str == "BT601_YUV2RGB_YV12") return CvtColor::Mode::BT601_YUV2RGB_YV12; if (str == "BT601_YUV2BGR_YV12") return CvtColor::Mode::BT601_YUV2BGR_YV12; if (str == "BT601_YUV2RGB_YU12") return CvtColor::Mode::BT601_YUV2RGB_YU12; if (str == "BT601_YUV2BGR_YU12") return CvtColor::Mode::BT601_YUV2BGR_YU12; throw py::cast_error("invalid enum value " + in); })); py::implicitly_convertible(); CvtColorInst .def(py::init<::megdnn::param::CvtColor::Mode, std::string>(), py::arg("mode") = ::megdnn::param::CvtColor::Mode::RGB2GRAY, py::arg("scope") = {}) .def_readwrite("mode", &CvtColor::mode); py::class_, OpDef> DeformableConvInst(m, "DeformableConv"); DeformableConvInst.attr("Mode") = BatchConvBiasInst.attr("Mode"); DeformableConvInst.attr("Sparse") = BatchConvBiasInst.attr("Sparse"); DeformableConvInst.attr("Format") = AdaptivePoolingInst.attr("Format"); DeformableConvInst.attr("ComputeMode") = BatchConvBiasInst.attr("ComputeMode"); DeformableConvInst.attr("Strategy") = BatchConvBiasInst.attr("Strategy"); DeformableConvInst .def(py::init<::megdnn::param::Convolution::Mode, uint32_t, uint32_t, uint32_t, uint32_t, uint32_t, uint32_t, ::megdnn::param::Convolution::Sparse, ::megdnn::param::Convolution::Format, ::megdnn::param::Convolution::ComputeMode, ::megdnn::param::ExecutionPolicy::Strategy, uint64_t, std::string>(), py::arg("mode") = ::megdnn::param::Convolution::Mode::CROSS_CORRELATION, py::arg("pad_h") = 0, py::arg("pad_w") = 0, py::arg("stride_h") = 1, py::arg("stride_w") = 1, py::arg("dilate_h") = 1, py::arg("dilate_w") = 1, py::arg("sparse") = ::megdnn::param::Convolution::Sparse::DENSE, py::arg("format") = ::megdnn::param::Convolution::Format::NCHW, py::arg("compute_mode") = ::megdnn::param::Convolution::ComputeMode::DEFAULT, py::arg("strategy") = static_cast<::megdnn::param::ExecutionPolicy::Strategy>(1), py::arg("workspace_limit") = 18446744073709551615ull, py::arg("scope") = {}) .def_readwrite("mode", &DeformableConv::mode) .def_readwrite("pad_h", &DeformableConv::pad_h) .def_readwrite("pad_w", &DeformableConv::pad_w) .def_readwrite("stride_h", &DeformableConv::stride_h) .def_readwrite("stride_w", &DeformableConv::stride_w) .def_readwrite("dilate_h", &DeformableConv::dilate_h) .def_readwrite("dilate_w", &DeformableConv::dilate_w) .def_readwrite("sparse", &DeformableConv::sparse) .def_readwrite("format", &DeformableConv::format) .def_readwrite("compute_mode", &DeformableConv::compute_mode) .def_readwrite("strategy", &DeformableConv::strategy) .def_readwrite("workspace_limit", &DeformableConv::workspace_limit); py::class_, OpDef> DeformablePSROIPoolingInst(m, "DeformablePSROIPooling"); DeformablePSROIPoolingInst .def(py::init(), py::arg("no_trans") = true, py::arg("spatial_scale") = 1, py::arg("trans_std") = 1, py::arg("pooled_h") = 1, py::arg("pooled_w") = 1, py::arg("part_size") = 1, py::arg("sample_per_part") = 1, py::arg("scope") = {}) .def_readwrite("no_trans", &DeformablePSROIPooling::no_trans) .def_readwrite("spatial_scale", &DeformablePSROIPooling::spatial_scale) .def_readwrite("trans_std", &DeformablePSROIPooling::trans_std) .def_readwrite("pooled_h", &DeformablePSROIPooling::pooled_h) .def_readwrite("pooled_w", &DeformablePSROIPooling::pooled_w) .def_readwrite("part_size", &DeformablePSROIPooling::part_size) .def_readwrite("sample_per_part", &DeformablePSROIPooling::sample_per_part); py::class_, OpDef> DiagInst(m, "Diag"); DiagInst .def(py::init(), py::arg("k") = 0, py::arg("scope") = {}) .def_readwrite("k", &Diag::k); py::class_, OpDef> DimshuffleInst(m, "Dimshuffle"); DimshuffleInst .def(py::init, std::string>(), py::arg("pattern"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("pattern", &Dimshuffle::pattern); py::class_, OpDef> DotInst(m, "Dot"); DotInst .def(py::init<>()); py::class_, OpDef> DropoutInst(m, "Dropout"); DropoutInst .def(py::init(), py::arg("drop_prob") = 0, py::arg("seed") = 0, py::arg("handle"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("drop_prob", &Dropout::drop_prob) .def_readwrite("seed", &Dropout::seed) .def_readwrite("handle", &Dropout::handle); py::class_, OpDef> ElemwiseInst(m, "Elemwise"); py::enum_(ElemwiseInst, "Mode") .value("RELU", Elemwise::Mode::RELU) .value("ABS", Elemwise::Mode::ABS) .value("ACOS", Elemwise::Mode::ACOS) .value("ASIN", Elemwise::Mode::ASIN) .value("CEIL", Elemwise::Mode::CEIL) .value("COS", Elemwise::Mode::COS) .value("EXP", Elemwise::Mode::EXP) .value("EXPM1", Elemwise::Mode::EXPM1) .value("FLOOR", Elemwise::Mode::FLOOR) .value("LOG", Elemwise::Mode::LOG) .value("LOG1P", Elemwise::Mode::LOG1P) .value("NEGATE", Elemwise::Mode::NEGATE) .value("SIGMOID", Elemwise::Mode::SIGMOID) .value("SIN", Elemwise::Mode::SIN) .value("TANH", Elemwise::Mode::TANH) .value("ABS_GRAD", Elemwise::Mode::ABS_GRAD) .value("ADD", Elemwise::Mode::ADD) .value("FLOOR_DIV", Elemwise::Mode::FLOOR_DIV) .value("MAX", Elemwise::Mode::MAX) .value("MIN", Elemwise::Mode::MIN) .value("MOD", Elemwise::Mode::MOD) .value("MUL", Elemwise::Mode::MUL) .value("POW", Elemwise::Mode::POW) .value("SIGMOID_GRAD", Elemwise::Mode::SIGMOID_GRAD) .value("SUB", Elemwise::Mode::SUB) .value("SWITCH_GT0", Elemwise::Mode::SWITCH_GT0) .value("TANH_GRAD", Elemwise::Mode::TANH_GRAD) .value("TRUE_DIV", Elemwise::Mode::TRUE_DIV) .value("LOG_SUM_EXP", Elemwise::Mode::LOG_SUM_EXP) .value("LT", Elemwise::Mode::LT) .value("LEQ", Elemwise::Mode::LEQ) .value("EQ", Elemwise::Mode::EQ) .value("SHL", Elemwise::Mode::SHL) .value("SHR", Elemwise::Mode::SHR) .value("COND_LEQ_MOV", Elemwise::Mode::COND_LEQ_MOV) .value("FUSE_MUL_ADD3", Elemwise::Mode::FUSE_MUL_ADD3) .value("FUSE_MUL_ADD4", Elemwise::Mode::FUSE_MUL_ADD4) .value("FUSE_ADD_RELU", Elemwise::Mode::FUSE_ADD_RELU) .value("FUSE_ADD_SIGMOID", Elemwise::Mode::FUSE_ADD_SIGMOID) .value("FUSE_ADD_TANH", Elemwise::Mode::FUSE_ADD_TANH) .value("FAST_TANH", Elemwise::Mode::FAST_TANH) .value("FAST_TANH_GRAD", Elemwise::Mode::FAST_TANH_GRAD) .value("ROUND", Elemwise::Mode::ROUND) .value("RMULH", Elemwise::Mode::RMULH) .value("ATAN2", Elemwise::Mode::ATAN2) .value("ERF", Elemwise::Mode::ERF) .value("ERFINV", Elemwise::Mode::ERFINV) .value("ERFC", Elemwise::Mode::ERFC) .value("ERFCINV", Elemwise::Mode::ERFCINV) .value("H_SWISH", Elemwise::Mode::H_SWISH) .value("H_SWISH_GRAD", Elemwise::Mode::H_SWISH_GRAD) .value("FUSE_ADD_H_SWISH", Elemwise::Mode::FUSE_ADD_H_SWISH) .value("NOT", Elemwise::Mode::NOT) .value("AND", Elemwise::Mode::AND) .value("OR", Elemwise::Mode::OR) .value("XOR", Elemwise::Mode::XOR) .value("SILU", Elemwise::Mode::SILU) .value("SILU_GRAD", Elemwise::Mode::SILU_GRAD) .value("GELU", Elemwise::Mode::GELU) .value("GELU_GRAD", Elemwise::Mode::GELU_GRAD) .value("COND_LT_MOV", Elemwise::Mode::COND_LT_MOV) .value("NEQ", Elemwise::Mode::NEQ) .value("ISNAN", Elemwise::Mode::ISNAN) .value("ISINF", Elemwise::Mode::ISINF) .def(py::init([](const std::string& in) { auto&& str = normalize_enum(in); if (str == "RELU") return Elemwise::Mode::RELU; if (str == "ABS") return Elemwise::Mode::ABS; if (str == "ACOS") return Elemwise::Mode::ACOS; if (str == "ASIN") return Elemwise::Mode::ASIN; if (str == "CEIL") return Elemwise::Mode::CEIL; if (str == "COS") return Elemwise::Mode::COS; if (str == "EXP") return Elemwise::Mode::EXP; if (str == "EXPM1") return Elemwise::Mode::EXPM1; if (str == "FLOOR") return Elemwise::Mode::FLOOR; if (str == "LOG") return Elemwise::Mode::LOG; if (str == "LOG1P") return Elemwise::Mode::LOG1P; if (str == "NEGATE") return Elemwise::Mode::NEGATE; if (str == "SIGMOID") return Elemwise::Mode::SIGMOID; if (str == "SIN") return Elemwise::Mode::SIN; if (str == "TANH") return Elemwise::Mode::TANH; if (str == "ABS_GRAD") return Elemwise::Mode::ABS_GRAD; if (str == "ADD") return Elemwise::Mode::ADD; if (str == "FLOOR_DIV") return Elemwise::Mode::FLOOR_DIV; if (str == "MAX") return Elemwise::Mode::MAX; if (str == "MIN") return Elemwise::Mode::MIN; if (str == "MOD") return Elemwise::Mode::MOD; if (str == "MUL") return Elemwise::Mode::MUL; if (str == "POW") return Elemwise::Mode::POW; if (str == "SIGMOID_GRAD") return Elemwise::Mode::SIGMOID_GRAD; if (str == "SUB") return Elemwise::Mode::SUB; if (str == "SWITCH_GT0") return Elemwise::Mode::SWITCH_GT0; if (str == "TANH_GRAD") return Elemwise::Mode::TANH_GRAD; if (str == "TRUE_DIV") return Elemwise::Mode::TRUE_DIV; if (str == "LOG_SUM_EXP") return Elemwise::Mode::LOG_SUM_EXP; if (str == "LT") return Elemwise::Mode::LT; if (str == "LEQ") return Elemwise::Mode::LEQ; if (str == "EQ") return Elemwise::Mode::EQ; if (str == "SHL") return Elemwise::Mode::SHL; if (str == "SHR") return Elemwise::Mode::SHR; if (str == "COND_LEQ_MOV") return Elemwise::Mode::COND_LEQ_MOV; if (str == "FUSE_MUL_ADD3") return Elemwise::Mode::FUSE_MUL_ADD3; if (str == "FUSE_MUL_ADD4") return Elemwise::Mode::FUSE_MUL_ADD4; if (str == "FUSE_ADD_RELU") return Elemwise::Mode::FUSE_ADD_RELU; if (str == "FUSE_ADD_SIGMOID") return Elemwise::Mode::FUSE_ADD_SIGMOID; if (str == "FUSE_ADD_TANH") return Elemwise::Mode::FUSE_ADD_TANH; if (str == "FAST_TANH") return Elemwise::Mode::FAST_TANH; if (str == "FAST_TANH_GRAD") return Elemwise::Mode::FAST_TANH_GRAD; if (str == "ROUND") return Elemwise::Mode::ROUND; if (str == "RMULH") return Elemwise::Mode::RMULH; if (str == "ATAN2") return Elemwise::Mode::ATAN2; if (str == "ERF") return Elemwise::Mode::ERF; if (str == "ERFINV") return Elemwise::Mode::ERFINV; if (str == "ERFC") return Elemwise::Mode::ERFC; if (str == "ERFCINV") return Elemwise::Mode::ERFCINV; if (str == "H_SWISH") return Elemwise::Mode::H_SWISH; if (str == "H_SWISH_GRAD") return Elemwise::Mode::H_SWISH_GRAD; if (str == "FUSE_ADD_H_SWISH") return Elemwise::Mode::FUSE_ADD_H_SWISH; if (str == "NOT") return Elemwise::Mode::NOT; if (str == "AND") return Elemwise::Mode::AND; if (str == "OR") return Elemwise::Mode::OR; if (str == "XOR") return Elemwise::Mode::XOR; if (str == "SILU") return Elemwise::Mode::SILU; if (str == "SILU_GRAD") return Elemwise::Mode::SILU_GRAD; if (str == "GELU") return Elemwise::Mode::GELU; if (str == "GELU_GRAD") return Elemwise::Mode::GELU_GRAD; if (str == "COND_LT_MOV") return Elemwise::Mode::COND_LT_MOV; if (str == "NEQ") return Elemwise::Mode::NEQ; if (str == "ISNAN") return Elemwise::Mode::ISNAN; if (str == "ISINF") return Elemwise::Mode::ISINF; throw py::cast_error("invalid enum value " + in); })); py::implicitly_convertible(); ElemwiseInst .def(py::init<::megdnn::param::Elemwise::Mode, std::string>(), py::arg("mode") = ::megdnn::param::Elemwise::Mode::RELU, py::arg("scope") = {}) .def_readwrite("mode", &Elemwise::mode); py::class_, OpDef> ElemwiseMultiTypeInst(m, "ElemwiseMultiType"); py::enum_(ElemwiseMultiTypeInst, "Mode") .value("FUSE_MUL_ADD3_INT16x32x32x32", ElemwiseMultiType::Mode::FUSE_MUL_ADD3_INT16x32x32x32) .value("FUSE_MUL_ADD3_IXxF32xF32xI8", ElemwiseMultiType::Mode::FUSE_MUL_ADD3_IXxF32xF32xI8) .value("ROUND_SHR_SATURATE_IXxI8xI8", ElemwiseMultiType::Mode::ROUND_SHR_SATURATE_IXxI8xI8) .value("FUSE_ADD_RMULH_ROUND_SHR_SATURATE_INT16x16x16x8", ElemwiseMultiType::Mode::FUSE_ADD_RMULH_ROUND_SHR_SATURATE_INT16x16x16x8) .value("FUSE_ADD_RMULH_ROUND_SHR_SATURATE_INT32x32x32x8", ElemwiseMultiType::Mode::FUSE_ADD_RMULH_ROUND_SHR_SATURATE_INT32x32x32x8) .value("ROUND_SHR_SATURATE_IXxI8xI16", ElemwiseMultiType::Mode::ROUND_SHR_SATURATE_IXxI8xI16) .value("QADD", ElemwiseMultiType::Mode::QADD) .value("QFUSE_ADD_RELU", ElemwiseMultiType::Mode::QFUSE_ADD_RELU) .value("QMUL", ElemwiseMultiType::Mode::QMUL) .value("QMIN", ElemwiseMultiType::Mode::QMIN) .value("QMAX", ElemwiseMultiType::Mode::QMAX) .value("QSUB", ElemwiseMultiType::Mode::QSUB) .value("QTRUE_DIV", ElemwiseMultiType::Mode::QTRUE_DIV) .value("QFUSE_ADD_SIGMOID", ElemwiseMultiType::Mode::QFUSE_ADD_SIGMOID) .value("QFUSE_ADD_TANH", ElemwiseMultiType::Mode::QFUSE_ADD_TANH) .value("QRELU", ElemwiseMultiType::Mode::QRELU) .value("QABS", ElemwiseMultiType::Mode::QABS) .value("QSIGMOID", ElemwiseMultiType::Mode::QSIGMOID) .value("QEXP", ElemwiseMultiType::Mode::QEXP) .value("QTANH", ElemwiseMultiType::Mode::QTANH) .value("QFUSE_MUL_ADD3", ElemwiseMultiType::Mode::QFUSE_MUL_ADD3) .value("QFAST_TANH", ElemwiseMultiType::Mode::QFAST_TANH) .value("QNEGATE", ElemwiseMultiType::Mode::QNEGATE) .value("QACOS", ElemwiseMultiType::Mode::QACOS) .value("QASIN", ElemwiseMultiType::Mode::QASIN) .value("QCEIL", ElemwiseMultiType::Mode::QCEIL) .value("QCOS", ElemwiseMultiType::Mode::QCOS) .value("QEXPM1", ElemwiseMultiType::Mode::QEXPM1) .value("QFLOOR", ElemwiseMultiType::Mode::QFLOOR) .value("QLOG", ElemwiseMultiType::Mode::QLOG) .value("QLOG1P", ElemwiseMultiType::Mode::QLOG1P) .value("QSIN", ElemwiseMultiType::Mode::QSIN) .value("QROUND", ElemwiseMultiType::Mode::QROUND) .value("QERF", ElemwiseMultiType::Mode::QERF) .value("QERFINV", ElemwiseMultiType::Mode::QERFINV) .value("QERFC", ElemwiseMultiType::Mode::QERFC) .value("QERFCINV", ElemwiseMultiType::Mode::QERFCINV) .value("QABS_GRAD", ElemwiseMultiType::Mode::QABS_GRAD) .value("QFLOOR_DIV", ElemwiseMultiType::Mode::QFLOOR_DIV) .value("QMOD", ElemwiseMultiType::Mode::QMOD) .value("QSIGMOID_GRAD", ElemwiseMultiType::Mode::QSIGMOID_GRAD) .value("QSWITCH_GT0", ElemwiseMultiType::Mode::QSWITCH_GT0) .value("QTANH_GRAD", ElemwiseMultiType::Mode::QTANH_GRAD) .value("QLT", ElemwiseMultiType::Mode::QLT) .value("QLEQ", ElemwiseMultiType::Mode::QLEQ) .value("QEQ", ElemwiseMultiType::Mode::QEQ) .value("QPOW", ElemwiseMultiType::Mode::QPOW) .value("QLOG_SUM_EXP", ElemwiseMultiType::Mode::QLOG_SUM_EXP) .value("QFAST_TANH_GRAD", ElemwiseMultiType::Mode::QFAST_TANH_GRAD) .value("QATAN2", ElemwiseMultiType::Mode::QATAN2) .value("QCOND_LEQ_MOV", ElemwiseMultiType::Mode::QCOND_LEQ_MOV) .value("QH_SWISH", ElemwiseMultiType::Mode::QH_SWISH) .value("QFUSE_ADD_H_SWISH", ElemwiseMultiType::Mode::QFUSE_ADD_H_SWISH) .value("QH_SWISH_GRAD", ElemwiseMultiType::Mode::QH_SWISH_GRAD) .value("FUSE_MUL_ADD3_INT16xF32xF32xF32", ElemwiseMultiType::Mode::FUSE_MUL_ADD3_INT16xF32xF32xF32) .value("MUL_INT16xF32xF32", ElemwiseMultiType::Mode::MUL_INT16xF32xF32) .value("FUSE_MUL_ADD3_UINT8xF32xF32xF32", ElemwiseMultiType::Mode::FUSE_MUL_ADD3_UINT8xF32xF32xF32) .value("QCOND_LT_MOV", ElemwiseMultiType::Mode::QCOND_LT_MOV) .value("EQ", ElemwiseMultiType::Mode::EQ) .value("NEQ", ElemwiseMultiType::Mode::NEQ) .value("LT", ElemwiseMultiType::Mode::LT) .value("LEQ", ElemwiseMultiType::Mode::LEQ) .value("ISNAN", ElemwiseMultiType::Mode::ISNAN) .value("ISINF", ElemwiseMultiType::Mode::ISINF) .def(py::init([](const std::string& in) { auto&& str = normalize_enum(in); if (str == "FUSE_MUL_ADD3_INT16x32x32x32") return ElemwiseMultiType::Mode::FUSE_MUL_ADD3_INT16x32x32x32; if (str == "FUSE_MUL_ADD3_IXxF32xF32xI8") return ElemwiseMultiType::Mode::FUSE_MUL_ADD3_IXxF32xF32xI8; if (str == "ROUND_SHR_SATURATE_IXxI8xI8") return ElemwiseMultiType::Mode::ROUND_SHR_SATURATE_IXxI8xI8; if (str == "FUSE_ADD_RMULH_ROUND_SHR_SATURATE_INT16x16x16x8") return ElemwiseMultiType::Mode::FUSE_ADD_RMULH_ROUND_SHR_SATURATE_INT16x16x16x8; if (str == "FUSE_ADD_RMULH_ROUND_SHR_SATURATE_INT32x32x32x8") return ElemwiseMultiType::Mode::FUSE_ADD_RMULH_ROUND_SHR_SATURATE_INT32x32x32x8; if (str == "ROUND_SHR_SATURATE_IXxI8xI16") return ElemwiseMultiType::Mode::ROUND_SHR_SATURATE_IXxI8xI16; if (str == "QADD") return ElemwiseMultiType::Mode::QADD; if (str == "QFUSE_ADD_RELU") return ElemwiseMultiType::Mode::QFUSE_ADD_RELU; if (str == "QMUL") return ElemwiseMultiType::Mode::QMUL; if (str == "QMIN") return ElemwiseMultiType::Mode::QMIN; if (str == "QMAX") return ElemwiseMultiType::Mode::QMAX; if (str == "QSUB") return ElemwiseMultiType::Mode::QSUB; if (str == "QTRUE_DIV") return ElemwiseMultiType::Mode::QTRUE_DIV; if (str == "QFUSE_ADD_SIGMOID") return ElemwiseMultiType::Mode::QFUSE_ADD_SIGMOID; if (str == "QFUSE_ADD_TANH") return ElemwiseMultiType::Mode::QFUSE_ADD_TANH; if (str == "QRELU") return ElemwiseMultiType::Mode::QRELU; if (str == "QABS") return ElemwiseMultiType::Mode::QABS; if (str == "QSIGMOID") return ElemwiseMultiType::Mode::QSIGMOID; if (str == "QEXP") return ElemwiseMultiType::Mode::QEXP; if (str == "QTANH") return ElemwiseMultiType::Mode::QTANH; if (str == "QFUSE_MUL_ADD3") return ElemwiseMultiType::Mode::QFUSE_MUL_ADD3; if (str == "QFAST_TANH") return ElemwiseMultiType::Mode::QFAST_TANH; if (str == "QNEGATE") return ElemwiseMultiType::Mode::QNEGATE; if (str == "QACOS") return ElemwiseMultiType::Mode::QACOS; if (str == "QASIN") return ElemwiseMultiType::Mode::QASIN; if (str == "QCEIL") return ElemwiseMultiType::Mode::QCEIL; if (str == "QCOS") return ElemwiseMultiType::Mode::QCOS; if (str == "QEXPM1") return ElemwiseMultiType::Mode::QEXPM1; if (str == "QFLOOR") return ElemwiseMultiType::Mode::QFLOOR; if (str == "QLOG") return ElemwiseMultiType::Mode::QLOG; if (str == "QLOG1P") return ElemwiseMultiType::Mode::QLOG1P; if (str == "QSIN") return ElemwiseMultiType::Mode::QSIN; if (str == "QROUND") return ElemwiseMultiType::Mode::QROUND; if (str == "QERF") return ElemwiseMultiType::Mode::QERF; if (str == "QERFINV") return ElemwiseMultiType::Mode::QERFINV; if (str == "QERFC") return ElemwiseMultiType::Mode::QERFC; if (str == "QERFCINV") return ElemwiseMultiType::Mode::QERFCINV; if (str == "QABS_GRAD") return ElemwiseMultiType::Mode::QABS_GRAD; if (str == "QFLOOR_DIV") return ElemwiseMultiType::Mode::QFLOOR_DIV; if (str == "QMOD") return ElemwiseMultiType::Mode::QMOD; if (str == "QSIGMOID_GRAD") return ElemwiseMultiType::Mode::QSIGMOID_GRAD; if (str == "QSWITCH_GT0") return ElemwiseMultiType::Mode::QSWITCH_GT0; if (str == "QTANH_GRAD") return ElemwiseMultiType::Mode::QTANH_GRAD; if (str == "QLT") return ElemwiseMultiType::Mode::QLT; if (str == "QLEQ") return ElemwiseMultiType::Mode::QLEQ; if (str == "QEQ") return ElemwiseMultiType::Mode::QEQ; if (str == "QPOW") return ElemwiseMultiType::Mode::QPOW; if (str == "QLOG_SUM_EXP") return ElemwiseMultiType::Mode::QLOG_SUM_EXP; if (str == "QFAST_TANH_GRAD") return ElemwiseMultiType::Mode::QFAST_TANH_GRAD; if (str == "QATAN2") return ElemwiseMultiType::Mode::QATAN2; if (str == "QCOND_LEQ_MOV") return ElemwiseMultiType::Mode::QCOND_LEQ_MOV; if (str == "QH_SWISH") return ElemwiseMultiType::Mode::QH_SWISH; if (str == "QFUSE_ADD_H_SWISH") return ElemwiseMultiType::Mode::QFUSE_ADD_H_SWISH; if (str == "QH_SWISH_GRAD") return ElemwiseMultiType::Mode::QH_SWISH_GRAD; if (str == "FUSE_MUL_ADD3_INT16xF32xF32xF32") return ElemwiseMultiType::Mode::FUSE_MUL_ADD3_INT16xF32xF32xF32; if (str == "MUL_INT16xF32xF32") return ElemwiseMultiType::Mode::MUL_INT16xF32xF32; if (str == "FUSE_MUL_ADD3_UINT8xF32xF32xF32") return ElemwiseMultiType::Mode::FUSE_MUL_ADD3_UINT8xF32xF32xF32; if (str == "QCOND_LT_MOV") return ElemwiseMultiType::Mode::QCOND_LT_MOV; if (str == "EQ") return ElemwiseMultiType::Mode::EQ; if (str == "NEQ") return ElemwiseMultiType::Mode::NEQ; if (str == "LT") return ElemwiseMultiType::Mode::LT; if (str == "LEQ") return ElemwiseMultiType::Mode::LEQ; if (str == "ISNAN") return ElemwiseMultiType::Mode::ISNAN; if (str == "ISINF") return ElemwiseMultiType::Mode::ISINF; throw py::cast_error("invalid enum value " + in); })); py::implicitly_convertible(); ElemwiseMultiTypeInst .def(py::init<::megdnn::param::ElemwiseMultiType::Mode, ::megdnn::DType, std::string>(), py::arg("mode") = ::megdnn::param::ElemwiseMultiType::Mode::FUSE_MUL_ADD3_INT16x32x32x32, py::arg("dtype"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("mode", &ElemwiseMultiType::mode) .def_readwrite("dtype", &ElemwiseMultiType::dtype); py::class_, OpDef> ExternOprInst(m, "ExternOpr"); ExternOprInst .def(py::init>, std::string, std::string, size_t, std::vector<::megdnn::DType>, std::string>(), py::arg("output_shapes"), py::arg("name"), py::arg("data"), py::arg("data_len"), py::arg("output_dtypes"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("output_shapes", &ExternOpr::output_shapes) .def_readwrite("name", &ExternOpr::name) .def_readwrite("data", &ExternOpr::data) .def_readwrite("data_len", &ExternOpr::data_len) .def_readwrite("output_dtypes", &ExternOpr::output_dtypes); py::class_, OpDef> EyeInst(m, "Eye"); EyeInst .def(py::init(), py::arg("k") = 0, py::arg("dtype") = megdnn::DType::from_enum(megdnn::DTypeEnum::Float32), py::arg("comp_node"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("k", &Eye::k) .def_readwrite("dtype", &Eye::dtype) .def_readwrite("comp_node", &Eye::comp_node); py::class_, OpDef> FakeQuantInst(m, "FakeQuant"); FakeQuantInst .def(py::init(), py::arg("qmin") = -2147483648, py::arg("qmax") = 2147483647, py::arg("scope") = {}) .def_readwrite("qmin", &FakeQuant::qmin) .def_readwrite("qmax", &FakeQuant::qmax); py::class_, OpDef> FastpathCopyInst(m, "FastpathCopy"); FastpathCopyInst .def(py::init<>()); py::class_, OpDef> GammaRNGInst(m, "GammaRNG"); GammaRNGInst .def(py::init(), py::arg("seed") = 0, py::arg("handle"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("seed", &GammaRNG::seed) .def_readwrite("handle", &GammaRNG::handle); py::class_, OpDef> GaussianRNGInst(m, "GaussianRNG"); GaussianRNGInst .def(py::init(), py::arg("seed") = 0, py::arg("mean") = 0, py::arg("std") = 1, py::arg("dtype") = megdnn::DType::from_enum(megdnn::DTypeEnum::Float32), py::arg("handle"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("seed", &GaussianRNG::seed) .def_readwrite("mean", &GaussianRNG::mean) .def_readwrite("std", &GaussianRNG::std) .def_readwrite("dtype", &GaussianRNG::dtype) .def_readwrite("handle", &GaussianRNG::handle); py::class_, OpDef> GetVarShapeInst(m, "GetVarShape"); GetVarShapeInst .def(py::init(), py::arg("axis") = ::megdnn::param::OptionalAxisV1::INVALID_AXIS, py::arg("scope") = {}) .def_readwrite("axis", &GetVarShape::axis); py::class_, OpDef> GroupLocalInst(m, "GroupLocal"); GroupLocalInst.attr("Mode") = BatchConvBiasInst.attr("Mode"); GroupLocalInst.attr("Sparse") = BatchConvBiasInst.attr("Sparse"); GroupLocalInst.attr("Format") = AdaptivePoolingInst.attr("Format"); GroupLocalInst.attr("ComputeMode") = BatchConvBiasInst.attr("ComputeMode"); GroupLocalInst .def(py::init<::megdnn::param::Convolution::Mode, uint32_t, uint32_t, uint32_t, uint32_t, uint32_t, uint32_t, ::megdnn::param::Convolution::Sparse, ::megdnn::param::Convolution::Format, ::megdnn::param::Convolution::ComputeMode, std::string>(), py::arg("mode") = ::megdnn::param::Convolution::Mode::CROSS_CORRELATION, py::arg("pad_h") = 0, py::arg("pad_w") = 0, py::arg("stride_h") = 1, py::arg("stride_w") = 1, py::arg("dilate_h") = 1, py::arg("dilate_w") = 1, py::arg("sparse") = ::megdnn::param::Convolution::Sparse::DENSE, py::arg("format") = ::megdnn::param::Convolution::Format::NCHW, py::arg("compute_mode") = ::megdnn::param::Convolution::ComputeMode::DEFAULT, py::arg("scope") = {}) .def_readwrite("mode", &GroupLocal::mode) .def_readwrite("pad_h", &GroupLocal::pad_h) .def_readwrite("pad_w", &GroupLocal::pad_w) .def_readwrite("stride_h", &GroupLocal::stride_h) .def_readwrite("stride_w", &GroupLocal::stride_w) .def_readwrite("dilate_h", &GroupLocal::dilate_h) .def_readwrite("dilate_w", &GroupLocal::dilate_w) .def_readwrite("sparse", &GroupLocal::sparse) .def_readwrite("format", &GroupLocal::format) .def_readwrite("compute_mode", &GroupLocal::compute_mode); py::class_, OpDef> IdentityInst(m, "Identity"); IdentityInst .def(py::init<>()); py::class_, OpDef> Images2NeibsInst(m, "Images2Neibs"); Images2NeibsInst .def(py::init(), py::arg("pad_h") = 0, py::arg("pad_w") = 0, py::arg("stride_h") = 1, py::arg("stride_w") = 1, py::arg("dilate_h") = 1, py::arg("dilate_w") = 1, py::arg("window_h") = 3, py::arg("window_w") = 3, py::arg("scope") = {}) .def_readwrite("pad_h", &Images2Neibs::pad_h) .def_readwrite("pad_w", &Images2Neibs::pad_w) .def_readwrite("stride_h", &Images2Neibs::stride_h) .def_readwrite("stride_w", &Images2Neibs::stride_w) .def_readwrite("dilate_h", &Images2Neibs::dilate_h) .def_readwrite("dilate_w", &Images2Neibs::dilate_w) .def_readwrite("window_h", &Images2Neibs::window_h) .def_readwrite("window_w", &Images2Neibs::window_w); py::class_, OpDef> IncrMeshIndexingInst(m, "IncrMeshIndexing"); IncrMeshIndexingInst .def(py::init>, std::string>(), py::arg("items"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("items", &IncrMeshIndexing::items); py::class_, OpDef> IncrSubtensorInst(m, "IncrSubtensor"); IncrSubtensorInst .def(py::init>, std::string>(), py::arg("items"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("items", &IncrSubtensor::items); py::class_, OpDef> IndexingIncrMultiAxisVecInst(m, "IndexingIncrMultiAxisVec"); IndexingIncrMultiAxisVecInst .def(py::init>, std::string>(), py::arg("items"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("items", &IndexingIncrMultiAxisVec::items); py::class_, OpDef> IndexingMultiAxisVecInst(m, "IndexingMultiAxisVec"); IndexingMultiAxisVecInst .def(py::init>, std::string>(), py::arg("items"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("items", &IndexingMultiAxisVec::items); py::class_, OpDef> IndexingOneHotInst(m, "IndexingOneHot"); IndexingOneHotInst .def(py::init(), py::arg("axis") = 0, py::arg("ndim"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("axis", &IndexingOneHot::axis) .def_readwrite("ndim", &IndexingOneHot::ndim); py::class_, OpDef> IndexingSetMultiAxisVecInst(m, "IndexingSetMultiAxisVec"); IndexingSetMultiAxisVecInst .def(py::init>, std::string>(), py::arg("items"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("items", &IndexingSetMultiAxisVec::items); py::class_, OpDef> IndexingSetOneHotInst(m, "IndexingSetOneHot"); IndexingSetOneHotInst .def(py::init(), py::arg("axis") = 0, py::arg("ndim"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("axis", &IndexingSetOneHot::axis) .def_readwrite("ndim", &IndexingSetOneHot::ndim); py::class_, OpDef> InplaceAddInst(m, "InplaceAdd"); InplaceAddInst .def(py::init<>()); py::class_, OpDef> LAMBUpdateInst(m, "LAMBUpdate"); LAMBUpdateInst .def(py::init(), py::arg("beta_1") = 1.f, py::arg("beta_2") = 1.f, py::arg("step") = 1.f, py::arg("lr") = 1.f, py::arg("weight_decay") = 1.f, py::arg("eps") = 1.f, py::arg("bias_correction") = true, py::arg("always_adapt") = false, py::arg("scope") = {}) .def_readwrite("beta_1", &LAMBUpdate::beta_1) .def_readwrite("beta_2", &LAMBUpdate::beta_2) .def_readwrite("step", &LAMBUpdate::step) .def_readwrite("lr", &LAMBUpdate::lr) .def_readwrite("weight_decay", &LAMBUpdate::weight_decay) .def_readwrite("eps", &LAMBUpdate::eps) .def_readwrite("bias_correction", &LAMBUpdate::bias_correction) .def_readwrite("always_adapt", &LAMBUpdate::always_adapt); py::class_, OpDef> LRNInst(m, "LRN"); LRNInst .def(py::init(), py::arg("n") = 5, py::arg("k") = 2.f, py::arg("alpha") = 1e-4f, py::arg("beta") = 0.75f, py::arg("scope") = {}) .def_readwrite("n", &LRN::n) .def_readwrite("k", &LRN::k) .def_readwrite("alpha", &LRN::alpha) .def_readwrite("beta", &LRN::beta); py::class_, OpDef> LSQInst(m, "LSQ"); LSQInst .def(py::init(), py::arg("qmin") = -2147483648, py::arg("qmax") = 2147483647, py::arg("scope") = {}) .def_readwrite("qmin", &LSQ::qmin) .def_readwrite("qmax", &LSQ::qmax); py::class_, OpDef> LSTMInst(m, "LSTM"); LSTMInst.attr("FwdMode") = BatchNormInst.attr("FwdMode"); LSTMInst .def(py::init(), py::arg("num_layers") = 1, py::arg("bidirectional") = false, py::arg("bias") = true, py::arg("hidden_size") = 128, py::arg("proj_size") = 0, py::arg("dropout") = 0.f, py::arg("fwd_mode") = ::megdnn::param::LSTM::FwdMode::TRAINING, py::arg("scope") = {}) .def_readwrite("num_layers", &LSTM::num_layers) .def_readwrite("bidirectional", &LSTM::bidirectional) .def_readwrite("bias", &LSTM::bias) .def_readwrite("hidden_size", &LSTM::hidden_size) .def_readwrite("proj_size", &LSTM::proj_size) .def_readwrite("dropout", &LSTM::dropout) .def_readwrite("fwd_mode", &LSTM::fwd_mode); py::class_, OpDef> LSTMCellInst(m, "LSTMCell"); LSTMCellInst .def(py::init<>()); py::class_, OpDef> LayerNormInst(m, "LayerNorm"); LayerNormInst .def(py::init(), py::arg("affine") = true, py::arg("eps") = 1e-5f, py::arg("normalized_dim") = 1, py::arg("normalized_size") = 1, py::arg("scope") = {}) .def_readwrite("affine", &LayerNorm::affine) .def_readwrite("eps", &LayerNorm::eps) .def_readwrite("normalized_dim", &LayerNorm::normalized_dim) .def_readwrite("normalized_size", &LayerNorm::normalized_size); py::class_, OpDef> LinspaceInst(m, "Linspace"); LinspaceInst .def(py::init(), py::arg("endpoint") = true, py::arg("comp_node"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("endpoint", &Linspace::endpoint) .def_readwrite("comp_node", &Linspace::comp_node); py::class_, OpDef> MagicMindRuntimeInst(m, "MagicMindRuntime"); MagicMindRuntimeInst .def(py::init(), py::arg("buf"), py::arg("buf_size"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("buf", &MagicMindRuntime::buf) .def_readwrite("buf_size", &MagicMindRuntime::buf_size); py::class_, OpDef> MatrixInverseInst(m, "MatrixInverse"); MatrixInverseInst .def(py::init<>()); py::class_, OpDef> MatrixMulInst(m, "MatrixMul"); MatrixMulInst.attr("ComputeMode") = BatchedMatrixMulInst.attr("ComputeMode"); MatrixMulInst.attr("Format") = BatchedMatrixMulInst.attr("Format"); MatrixMulInst.attr("Strategy") = BatchConvBiasInst.attr("Strategy"); MatrixMulInst .def(py::init(), py::arg("transposeA") = false, py::arg("transposeB") = false, py::arg("compute_mode") = ::megdnn::param::MatrixMul::ComputeMode::DEFAULT, py::arg("format") = ::megdnn::param::MatrixMul::Format::DEFAULT, py::arg("strategy") = static_cast<::megdnn::param::ExecutionPolicy::Strategy>(1), py::arg("workspace_limit") = 18446744073709551615ull, py::arg("dimA"), py::arg("dimB"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("transposeA", &MatrixMul::transposeA) .def_readwrite("transposeB", &MatrixMul::transposeB) .def_readwrite("compute_mode", &MatrixMul::compute_mode) .def_readwrite("format", &MatrixMul::format) .def_readwrite("strategy", &MatrixMul::strategy) .def_readwrite("workspace_limit", &MatrixMul::workspace_limit) .def_readwrite("dimA", &MatrixMul::dimA) .def_readwrite("dimB", &MatrixMul::dimB); py::class_, OpDef> MeshIndexingInst(m, "MeshIndexing"); MeshIndexingInst .def(py::init>, std::string>(), py::arg("items"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("items", &MeshIndexing::items); py::class_, OpDef> NMSKeepInst(m, "NMSKeep"); NMSKeepInst .def(py::init(), py::arg("iou_thresh"), py::arg("max_output"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("iou_thresh", &NMSKeep::iou_thresh) .def_readwrite("max_output", &NMSKeep::max_output); py::class_, OpDef> NvOfInst(m, "NvOf"); NvOfInst .def(py::init(), py::arg("precision") = 1, py::arg("scope") = {}) .def_readwrite("precision", &NvOf::precision); py::class_, OpDef> PaddingInst(m, "Padding"); py::enum_(PaddingInst, "PaddingMode") .value("REPLICATE", Padding::PaddingMode::REPLICATE) .value("REFLECT", Padding::PaddingMode::REFLECT) .value("CONSTANT", Padding::PaddingMode::CONSTANT) .def(py::init([](const std::string& in) { auto&& str = normalize_enum(in); if (str == "REPLICATE") return Padding::PaddingMode::REPLICATE; if (str == "REFLECT") return Padding::PaddingMode::REFLECT; if (str == "CONSTANT") return Padding::PaddingMode::CONSTANT; throw py::cast_error("invalid enum value " + in); })); py::implicitly_convertible(); PaddingInst .def(py::init(), py::arg("front_offset_dim0") = 0, py::arg("front_offset_dim1") = 0, py::arg("front_offset_dim2") = 0, py::arg("front_offset_dim3") = 0, py::arg("front_offset_dim4") = 0, py::arg("front_offset_dim5") = 0, py::arg("front_offset_dim6") = 0, py::arg("back_offset_dim0") = 0, py::arg("back_offset_dim1") = 0, py::arg("back_offset_dim2") = 0, py::arg("back_offset_dim3") = 0, py::arg("back_offset_dim4") = 0, py::arg("back_offset_dim5") = 0, py::arg("back_offset_dim6") = 0, py::arg("padding_val") = 0, py::arg("padding_mode") = ::megdnn::param::Padding::PaddingMode::CONSTANT, py::arg("scope") = {}) .def_readwrite("front_offset_dim0", &Padding::front_offset_dim0) .def_readwrite("front_offset_dim1", &Padding::front_offset_dim1) .def_readwrite("front_offset_dim2", &Padding::front_offset_dim2) .def_readwrite("front_offset_dim3", &Padding::front_offset_dim3) .def_readwrite("front_offset_dim4", &Padding::front_offset_dim4) .def_readwrite("front_offset_dim5", &Padding::front_offset_dim5) .def_readwrite("front_offset_dim6", &Padding::front_offset_dim6) .def_readwrite("back_offset_dim0", &Padding::back_offset_dim0) .def_readwrite("back_offset_dim1", &Padding::back_offset_dim1) .def_readwrite("back_offset_dim2", &Padding::back_offset_dim2) .def_readwrite("back_offset_dim3", &Padding::back_offset_dim3) .def_readwrite("back_offset_dim4", &Padding::back_offset_dim4) .def_readwrite("back_offset_dim5", &Padding::back_offset_dim5) .def_readwrite("back_offset_dim6", &Padding::back_offset_dim6) .def_readwrite("padding_val", &Padding::padding_val) .def_readwrite("padding_mode", &Padding::padding_mode); py::class_, OpDef> ParamPackConcatInst(m, "ParamPackConcat"); ParamPackConcatInst .def(py::init, std::string>(), py::arg("offsets"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("offsets", &ParamPackConcat::offsets); py::class_, OpDef> ParamPackSplitInst(m, "ParamPackSplit"); ParamPackSplitInst .def(py::init, std::vector>, std::string>(), py::arg("offsets"), py::arg("shapes"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("offsets", &ParamPackSplit::offsets) .def_readwrite("shapes", &ParamPackSplit::shapes); py::class_, OpDef> PermutationRNGInst(m, "PermutationRNG"); PermutationRNGInst .def(py::init(), py::arg("seed") = 0, py::arg("dtype") = megdnn::DType::from_enum(megdnn::DTypeEnum::Int32), py::arg("handle"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("seed", &PermutationRNG::seed) .def_readwrite("dtype", &PermutationRNG::dtype) .def_readwrite("handle", &PermutationRNG::handle); py::class_, OpDef> PixelShuffleInst(m, "PixelShuffle"); PixelShuffleInst .def(py::init(), py::arg("factor"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("factor", &PixelShuffle::factor); py::class_, OpDef> PixelShuffleBackwardInst(m, "PixelShuffleBackward"); PixelShuffleBackwardInst .def(py::init(), py::arg("factor"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("factor", &PixelShuffleBackward::factor); py::class_, OpDef> PoissonRNGInst(m, "PoissonRNG"); PoissonRNGInst .def(py::init(), py::arg("seed") = 0, py::arg("handle"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("seed", &PoissonRNG::seed) .def_readwrite("handle", &PoissonRNG::handle); py::class_, OpDef> PoolingInst(m, "Pooling"); PoolingInst.attr("Mode") = AdaptivePoolingInst.attr("Mode"); PoolingInst.attr("Format") = AdaptivePoolingInst.attr("Format"); PoolingInst.attr("Strategy") = BatchConvBiasInst.attr("Strategy"); PoolingInst .def(py::init<::megdnn::param::Pooling::Mode, uint32_t, uint32_t, uint32_t, uint32_t, uint32_t, uint32_t, ::megdnn::param::Pooling::Format, ::megdnn::param::ExecutionPolicy::Strategy, uint64_t, std::string>(), py::arg("mode") = ::megdnn::param::Pooling::Mode::MAX, py::arg("pad_h") = 0, py::arg("pad_w") = 0, py::arg("stride_h") = 2, py::arg("stride_w") = 2, py::arg("window_h") = 2, py::arg("window_w") = 2, py::arg("format") = ::megdnn::param::Pooling::Format::NCHW, py::arg("strategy") = static_cast<::megdnn::param::ExecutionPolicy::Strategy>(1), py::arg("workspace_limit") = 18446744073709551615ull, py::arg("scope") = {}) .def_readwrite("mode", &Pooling::mode) .def_readwrite("pad_h", &Pooling::pad_h) .def_readwrite("pad_w", &Pooling::pad_w) .def_readwrite("stride_h", &Pooling::stride_h) .def_readwrite("stride_w", &Pooling::stride_w) .def_readwrite("window_h", &Pooling::window_h) .def_readwrite("window_w", &Pooling::window_w) .def_readwrite("format", &Pooling::format) .def_readwrite("strategy", &Pooling::strategy) .def_readwrite("workspace_limit", &Pooling::workspace_limit); py::class_, OpDef> RNNInst(m, "RNN"); py::enum_(RNNInst, "NonlineMode") .value("IDENTITY", RNN::NonlineMode::IDENTITY) .value("RELU", RNN::NonlineMode::RELU) .value("TANH", RNN::NonlineMode::TANH) .def(py::init([](const std::string& in) { auto&& str = normalize_enum(in); if (str == "IDENTITY") return RNN::NonlineMode::IDENTITY; if (str == "RELU") return RNN::NonlineMode::RELU; if (str == "TANH") return RNN::NonlineMode::TANH; throw py::cast_error("invalid enum value " + in); })); py::implicitly_convertible(); RNNInst.attr("FwdMode") = BatchNormInst.attr("FwdMode"); RNNInst .def(py::init(), py::arg("num_layers") = 1, py::arg("bidirectional") = false, py::arg("bias") = true, py::arg("hidden_size") = 128, py::arg("dropout") = 0.f, py::arg("nonlineMode") = ::megdnn::param::RNN::NonlineMode::IDENTITY, py::arg("fwd_mode") = ::megdnn::param::RNN::FwdMode::TRAINING, py::arg("scope") = {}) .def_readwrite("num_layers", &RNN::num_layers) .def_readwrite("bidirectional", &RNN::bidirectional) .def_readwrite("bias", &RNN::bias) .def_readwrite("hidden_size", &RNN::hidden_size) .def_readwrite("dropout", &RNN::dropout) .def_readwrite("nonlineMode", &RNN::nonlineMode) .def_readwrite("fwd_mode", &RNN::fwd_mode); py::class_, OpDef> RNNCellInst(m, "RNNCell"); RNNCellInst.attr("NonlineMode") = RNNInst.attr("NonlineMode"); RNNCellInst .def(py::init<::megdnn::param::RNNCell::NonlineMode, std::string>(), py::arg("nonlineMode") = ::megdnn::param::RNNCell::NonlineMode::IDENTITY, py::arg("scope") = {}) .def_readwrite("nonlineMode", &RNNCell::nonlineMode); py::class_, OpDef> ROIAlignInst(m, "ROIAlign"); py::enum_(ROIAlignInst, "Mode") .value("MAX", ROIAlign::Mode::MAX) .value("AVERAGE", ROIAlign::Mode::AVERAGE) .def(py::init([](const std::string& in) { auto&& str = normalize_enum(in); if (str == "MAX") return ROIAlign::Mode::MAX; if (str == "AVERAGE") return ROIAlign::Mode::AVERAGE; throw py::cast_error("invalid enum value " + in); })); py::implicitly_convertible(); ROIAlignInst.attr("Format") = AdaptivePoolingInst.attr("Format"); ROIAlignInst .def(py::init<::megdnn::param::ROIAlign::Mode, ::megdnn::param::ROIAlign::Format, float, float, uint32_t, uint32_t, uint32_t, uint32_t, std::string>(), py::arg("mode") = ::megdnn::param::ROIAlign::Mode::MAX, py::arg("format") = ::megdnn::param::ROIAlign::Format::NCHW, py::arg("spatial_scale") = 1.0, py::arg("offset") = 0.0, py::arg("pooled_height") = 1, py::arg("pooled_width") = 1, py::arg("sample_height") = 2, py::arg("sample_width") = 2, py::arg("scope") = {}) .def_readwrite("mode", &ROIAlign::mode) .def_readwrite("format", &ROIAlign::format) .def_readwrite("spatial_scale", &ROIAlign::spatial_scale) .def_readwrite("offset", &ROIAlign::offset) .def_readwrite("pooled_height", &ROIAlign::pooled_height) .def_readwrite("pooled_width", &ROIAlign::pooled_width) .def_readwrite("sample_height", &ROIAlign::sample_height) .def_readwrite("sample_width", &ROIAlign::sample_width); py::class_, OpDef> ROIPoolingInst(m, "ROIPooling"); py::enum_(ROIPoolingInst, "Mode") .value("MAX", ROIPooling::Mode::MAX) .value("AVERAGE", ROIPooling::Mode::AVERAGE) .def(py::init([](const std::string& in) { auto&& str = normalize_enum(in); if (str == "MAX") return ROIPooling::Mode::MAX; if (str == "AVERAGE") return ROIPooling::Mode::AVERAGE; throw py::cast_error("invalid enum value " + in); })); py::implicitly_convertible(); ROIPoolingInst .def(py::init<::megdnn::param::ROIPooling::Mode, float, std::string>(), py::arg("mode") = ::megdnn::param::ROIPooling::Mode::MAX, py::arg("scale") = 1.f, py::arg("scope") = {}) .def_readwrite("mode", &ROIPooling::mode) .def_readwrite("scale", &ROIPooling::scale); py::class_, OpDef> ReduceInst(m, "Reduce"); py::enum_(ReduceInst, "Mode") .value("SUM", Reduce::Mode::SUM) .value("SUM_SQR", Reduce::Mode::SUM_SQR) .value("PRODUCT", Reduce::Mode::PRODUCT) .value("MIN", Reduce::Mode::MIN) .value("MAX", Reduce::Mode::MAX) .value("MEAN", Reduce::Mode::MEAN) .def(py::init([](const std::string& in) { auto&& str = normalize_enum(in); if (str == "SUM") return Reduce::Mode::SUM; if (str == "SUM_SQR") return Reduce::Mode::SUM_SQR; if (str == "PRODUCT") return Reduce::Mode::PRODUCT; if (str == "MIN") return Reduce::Mode::MIN; if (str == "MAX") return Reduce::Mode::MAX; if (str == "MEAN") return Reduce::Mode::MEAN; throw py::cast_error("invalid enum value " + in); })); py::implicitly_convertible(); py::enum_(ReduceInst, "DataType") .value("DEFAULT", Reduce::DataType::DEFAULT) .value("FLOAT_IO16xC32", Reduce::DataType::FLOAT_IO16xC32) .value("FLOAT_O32xC32", Reduce::DataType::FLOAT_O32xC32) .value("FLOAT_O16xC32", Reduce::DataType::FLOAT_O16xC32) .value("QUINT_I8xO32", Reduce::DataType::QUINT_I8xO32) .value("QINT_I8xO32", Reduce::DataType::QINT_I8xO32) .def(py::init([](const std::string& in) { auto&& str = normalize_enum(in); if (str == "DEFAULT") return Reduce::DataType::DEFAULT; if (str == "FLOAT_IO16xC32") return Reduce::DataType::FLOAT_IO16xC32; if (str == "FLOAT_O32xC32") return Reduce::DataType::FLOAT_O32xC32; if (str == "FLOAT_O16xC32") return Reduce::DataType::FLOAT_O16xC32; if (str == "QUINT_I8xO32") return Reduce::DataType::QUINT_I8xO32; if (str == "QINT_I8xO32") return Reduce::DataType::QINT_I8xO32; throw py::cast_error("invalid enum value " + in); })); py::implicitly_convertible(); ReduceInst .def(py::init<::megdnn::param::Reduce::Mode, int32_t, ::megdnn::param::Reduce::DataType, bool, std::string>(), py::arg("mode") = ::megdnn::param::Reduce::Mode::SUM, py::arg("axis") = 2147483647, py::arg("data_type") = ::megdnn::param::Reduce::DataType::DEFAULT, py::arg("keepdim") = true, py::arg("scope") = {}) .def_readwrite("mode", &Reduce::mode) .def_readwrite("axis", &Reduce::axis) .def_readwrite("data_type", &Reduce::data_type) .def_readwrite("keepdim", &Reduce::keepdim); py::class_, OpDef> RemapInst(m, "Remap"); py::enum_(RemapInst, "InterpolationMode") .value("NEAREST", Remap::InterpolationMode::NEAREST) .value("LINEAR", Remap::InterpolationMode::LINEAR) .value("AREA", Remap::InterpolationMode::AREA) .value("CUBIC", Remap::InterpolationMode::CUBIC) .value("LANCZOS4", Remap::InterpolationMode::LANCZOS4) .def(py::init([](const std::string& in) { auto&& str = normalize_enum(in); if (str == "NEAREST") return Remap::InterpolationMode::NEAREST; if (str == "LINEAR") return Remap::InterpolationMode::LINEAR; if (str == "AREA") return Remap::InterpolationMode::AREA; if (str == "CUBIC") return Remap::InterpolationMode::CUBIC; if (str == "LANCZOS4") return Remap::InterpolationMode::LANCZOS4; throw py::cast_error("invalid enum value " + in); })); py::implicitly_convertible(); py::enum_(RemapInst, "BorderMode") .value("REPLICATE", Remap::BorderMode::REPLICATE) .value("REFLECT", Remap::BorderMode::REFLECT) .value("REFLECT_101", Remap::BorderMode::REFLECT_101) .value("WRAP", Remap::BorderMode::WRAP) .value("CONSTANT", Remap::BorderMode::CONSTANT) .value("TRANSPARENT", Remap::BorderMode::TRANSPARENT) .value("ISOLATED", Remap::BorderMode::ISOLATED) .def(py::init([](const std::string& in) { auto&& str = normalize_enum(in); if (str == "REPLICATE") return Remap::BorderMode::REPLICATE; if (str == "REFLECT") return Remap::BorderMode::REFLECT; if (str == "REFLECT_101") return Remap::BorderMode::REFLECT_101; if (str == "WRAP") return Remap::BorderMode::WRAP; if (str == "CONSTANT") return Remap::BorderMode::CONSTANT; if (str == "TRANSPARENT") return Remap::BorderMode::TRANSPARENT; if (str == "ISOLATED") return Remap::BorderMode::ISOLATED; throw py::cast_error("invalid enum value " + in); })); py::implicitly_convertible(); RemapInst.attr("Format") = AdaptivePoolingInst.attr("Format"); RemapInst .def(py::init<::megdnn::param::Remap::InterpolationMode, ::megdnn::param::Remap::BorderMode, ::megdnn::param::Remap::Format, float, std::string>(), py::arg("imode") = ::megdnn::param::Remap::InterpolationMode::LINEAR, py::arg("border_type") = ::megdnn::param::Remap::BorderMode::REPLICATE, py::arg("format") = ::megdnn::param::Remap::Format::NHWC, py::arg("scalar") = 0.f, py::arg("scope") = {}) .def_readwrite("imode", &Remap::imode) .def_readwrite("border_type", &Remap::border_type) .def_readwrite("format", &Remap::format) .def_readwrite("scalar", &Remap::scalar); py::class_, OpDef> RemoteRecvInst(m, "RemoteRecv"); RemoteRecvInst .def(py::init, ::megdnn::DType, std::string, std::string>(), py::arg("key"), py::arg("addr"), py::arg("port"), py::arg("rank_from"), py::arg("cn"), py::arg("shape"), py::arg("dtype"), py::arg("backend"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("key", &RemoteRecv::key) .def_readwrite("addr", &RemoteRecv::addr) .def_readwrite("port", &RemoteRecv::port) .def_readwrite("rank_from", &RemoteRecv::rank_from) .def_readwrite("cn", &RemoteRecv::cn) .def_readwrite("shape", &RemoteRecv::shape) .def_readwrite("dtype", &RemoteRecv::dtype) .def_readwrite("backend", &RemoteRecv::backend); py::class_, OpDef> RemoteSendInst(m, "RemoteSend"); RemoteSendInst .def(py::init(), py::arg("key"), py::arg("addr"), py::arg("port"), py::arg("rank_to"), py::arg("backend"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("key", &RemoteSend::key) .def_readwrite("addr", &RemoteSend::addr) .def_readwrite("port", &RemoteSend::port) .def_readwrite("rank_to", &RemoteSend::rank_to) .def_readwrite("backend", &RemoteSend::backend); py::class_, OpDef> RemoveAxisInst(m, "RemoveAxis"); RemoveAxisInst .def(py::init, std::string>(), py::arg("axis"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("axis", &RemoveAxis::axis); py::class_, OpDef> ReshapeInst(m, "Reshape"); ReshapeInst .def(py::init, std::string>(), py::arg("axis") = ::megdnn::param::OptionalAxisV1::INVALID_AXIS, py::arg("shape"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("axis", &Reshape::axis) .def_readwrite("shape", &Reshape::shape); py::class_, OpDef> ResizeInst(m, "Resize"); ResizeInst.attr("InterpolationMode") = RemapInst.attr("InterpolationMode"); ResizeInst.attr("Format") = AdaptivePoolingInst.attr("Format"); ResizeInst .def(py::init<::megdnn::param::Resize::InterpolationMode, ::megdnn::param::Resize::Format, std::string>(), py::arg("imode") = ::megdnn::param::Resize::InterpolationMode::LINEAR, py::arg("format") = ::megdnn::param::Resize::Format::NHWC, py::arg("scope") = {}) .def_readwrite("imode", &Resize::imode) .def_readwrite("format", &Resize::format); py::class_, OpDef> SVDInst(m, "SVD"); SVDInst .def(py::init(), py::arg("full_matrices") = false, py::arg("compute_uv") = true, py::arg("scope") = {}) .def_readwrite("full_matrices", &SVD::full_matrices) .def_readwrite("compute_uv", &SVD::compute_uv); py::class_, OpDef> SetMeshIndexingInst(m, "SetMeshIndexing"); SetMeshIndexingInst .def(py::init>, std::string>(), py::arg("items"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("items", &SetMeshIndexing::items); py::class_, OpDef> SetSubtensorInst(m, "SetSubtensor"); SetSubtensorInst .def(py::init>, std::string>(), py::arg("items"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("items", &SetSubtensor::items); py::class_, OpDef> ShuffleRNGInst(m, "ShuffleRNG"); ShuffleRNGInst .def(py::init(), py::arg("seed") = 0, py::arg("handle"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("seed", &ShuffleRNG::seed) .def_readwrite("handle", &ShuffleRNG::handle); py::class_, OpDef> SlidingWindowTransposeInst(m, "SlidingWindowTranspose"); SlidingWindowTransposeInst .def(py::init(), py::arg("out_h") = 0, py::arg("out_w") = 0, py::arg("pad_h") = 0, py::arg("pad_w") = 0, py::arg("stride_h") = 1, py::arg("stride_w") = 1, py::arg("dilate_h") = 1, py::arg("dilate_w") = 1, py::arg("window_h") = 3, py::arg("window_w") = 3, py::arg("scope") = {}) .def_readwrite("out_h", &SlidingWindowTranspose::out_h) .def_readwrite("out_w", &SlidingWindowTranspose::out_w) .def_readwrite("pad_h", &SlidingWindowTranspose::pad_h) .def_readwrite("pad_w", &SlidingWindowTranspose::pad_w) .def_readwrite("stride_h", &SlidingWindowTranspose::stride_h) .def_readwrite("stride_w", &SlidingWindowTranspose::stride_w) .def_readwrite("dilate_h", &SlidingWindowTranspose::dilate_h) .def_readwrite("dilate_w", &SlidingWindowTranspose::dilate_w) .def_readwrite("window_h", &SlidingWindowTranspose::window_h) .def_readwrite("window_w", &SlidingWindowTranspose::window_w); py::class_, OpDef> SoftmaxInst(m, "Softmax"); SoftmaxInst .def(py::init(), py::arg("axis") = -1, py::arg("scope") = {}) .def_readwrite("axis", &Softmax::axis); py::class_, OpDef> SplitInst(m, "Split"); SplitInst .def(py::init(), py::arg("axis"), py::arg("nsections"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("axis", &Split::axis) .def_readwrite("nsections", &Split::nsections); py::class_, OpDef> SubtensorInst(m, "Subtensor"); SubtensorInst .def(py::init>, std::string>(), py::arg("items"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("items", &Subtensor::items); py::class_, OpDef> TQTInst(m, "TQT"); TQTInst .def(py::init(), py::arg("qmin") = -2147483648, py::arg("qmax") = 2147483647, py::arg("scope") = {}) .def_readwrite("qmin", &TQT::qmin) .def_readwrite("qmax", &TQT::qmax); py::class_, OpDef> TensorRTRuntimeInst(m, "TensorRTRuntime"); TensorRTRuntimeInst .def(py::init(), py::arg("buf"), py::arg("buf_size"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("buf", &TensorRTRuntime::buf) .def_readwrite("buf_size", &TensorRTRuntime::buf_size); py::class_, OpDef> TopKInst(m, "TopK"); py::enum_(TopKInst, "Mode") .value("KTH_ONLY", TopK::Mode::KTH_ONLY) .value("VALUE_IDX_NOSORT", TopK::Mode::VALUE_IDX_NOSORT) .value("VALUE_IDX_SORTED", TopK::Mode::VALUE_IDX_SORTED) .def(py::init([](const std::string& in) { auto&& str = normalize_enum(in); if (str == "KTH_ONLY") return TopK::Mode::KTH_ONLY; if (str == "VALUE_IDX_NOSORT") return TopK::Mode::VALUE_IDX_NOSORT; if (str == "VALUE_IDX_SORTED") return TopK::Mode::VALUE_IDX_SORTED; throw py::cast_error("invalid enum value " + in); })); py::implicitly_convertible(); TopKInst .def(py::init<::megdnn::param::TopK::Mode, std::string>(), py::arg("mode") = ::megdnn::param::TopK::Mode::KTH_ONLY, py::arg("scope") = {}) .def_readwrite("mode", &TopK::mode); py::class_, OpDef> TypeCvtInst(m, "TypeCvt"); TypeCvtInst .def(py::init<::megdnn::DType, std::string>(), py::arg("dtype"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("dtype", &TypeCvt::dtype); py::class_, OpDef> UniformRNGInst(m, "UniformRNG"); UniformRNGInst .def(py::init(), py::arg("seed") = 0, py::arg("dtype") = megdnn::DType::from_enum(megdnn::DTypeEnum::Float32), py::arg("handle"), py::arg("scope") = {}) .def(py::init<>()) .def_readwrite("seed", &UniformRNG::seed) .def_readwrite("dtype", &UniformRNG::dtype) .def_readwrite("handle", &UniformRNG::handle); py::class_, OpDef> WarpAffineInst(m, "WarpAffine"); WarpAffineInst.attr("InterpolationMode") = RemapInst.attr("InterpolationMode"); WarpAffineInst.attr("BorderMode") = RemapInst.attr("BorderMode"); WarpAffineInst.attr("Format") = AdaptivePoolingInst.attr("Format"); WarpAffineInst .def(py::init<::megdnn::param::WarpAffine::InterpolationMode, ::megdnn::param::WarpAffine::BorderMode, float, ::megdnn::param::WarpAffine::Format, std::string>(), py::arg("imode") = ::megdnn::param::WarpAffine::InterpolationMode::LINEAR, py::arg("border_mode") = ::megdnn::param::WarpAffine::BorderMode::REPLICATE, py::arg("border_val") = .0f, py::arg("format") = ::megdnn::param::WarpAffine::Format::NHWC, py::arg("scope") = {}) .def_readwrite("imode", &WarpAffine::imode) .def_readwrite("border_mode", &WarpAffine::border_mode) .def_readwrite("border_val", &WarpAffine::border_val) .def_readwrite("format", &WarpAffine::format); py::class_, OpDef> WarpPerspectiveInst(m, "WarpPerspective"); WarpPerspectiveInst.attr("InterpolationMode") = RemapInst.attr("InterpolationMode"); WarpPerspectiveInst.attr("BorderMode") = RemapInst.attr("BorderMode"); WarpPerspectiveInst.attr("Format") = AdaptivePoolingInst.attr("Format"); WarpPerspectiveInst .def(py::init<::megdnn::param::WarpPerspective::InterpolationMode, ::megdnn::param::WarpPerspective::BorderMode, ::megdnn::param::WarpPerspective::Format, float, std::string>(), py::arg("imode") = ::megdnn::param::WarpPerspective::InterpolationMode::LINEAR, py::arg("bmode") = ::megdnn::param::WarpPerspective::BorderMode::REPLICATE, py::arg("format") = ::megdnn::param::WarpPerspective::Format::NCHW, py::arg("border_val") = .0f, py::arg("scope") = {}) .def_readwrite("imode", &WarpPerspective::imode) .def_readwrite("bmode", &WarpPerspective::bmode) .def_readwrite("format", &WarpPerspective::format) .def_readwrite("border_val", &WarpPerspective::border_val); py::class_, OpDef> WarpPerspectiveBackwardDataInst(m, "WarpPerspectiveBackwardData"); WarpPerspectiveBackwardDataInst.attr("InterpolationMode") = RemapInst.attr("InterpolationMode"); WarpPerspectiveBackwardDataInst.attr("BorderMode") = RemapInst.attr("BorderMode"); WarpPerspectiveBackwardDataInst.attr("Format") = AdaptivePoolingInst.attr("Format"); WarpPerspectiveBackwardDataInst .def(py::init<::megdnn::param::WarpPerspective::InterpolationMode, ::megdnn::param::WarpPerspective::BorderMode, ::megdnn::param::WarpPerspective::Format, float, std::string>(), py::arg("imode") = ::megdnn::param::WarpPerspective::InterpolationMode::LINEAR, py::arg("bmode") = ::megdnn::param::WarpPerspective::BorderMode::REPLICATE, py::arg("format") = ::megdnn::param::WarpPerspective::Format::NCHW, py::arg("border_val") = .0f, py::arg("scope") = {}) .def_readwrite("imode", &WarpPerspectiveBackwardData::imode) .def_readwrite("bmode", &WarpPerspectiveBackwardData::bmode) .def_readwrite("format", &WarpPerspectiveBackwardData::format) .def_readwrite("border_val", &WarpPerspectiveBackwardData::border_val); py::class_, OpDef> WarpPerspectiveBackwardMatInst(m, "WarpPerspectiveBackwardMat"); WarpPerspectiveBackwardMatInst.attr("InterpolationMode") = RemapInst.attr("InterpolationMode"); WarpPerspectiveBackwardMatInst.attr("BorderMode") = RemapInst.attr("BorderMode"); WarpPerspectiveBackwardMatInst.attr("Format") = AdaptivePoolingInst.attr("Format"); WarpPerspectiveBackwardMatInst .def(py::init<::megdnn::param::WarpPerspective::InterpolationMode, ::megdnn::param::WarpPerspective::BorderMode, ::megdnn::param::WarpPerspective::Format, float, std::string>(), py::arg("imode") = ::megdnn::param::WarpPerspective::InterpolationMode::LINEAR, py::arg("bmode") = ::megdnn::param::WarpPerspective::BorderMode::REPLICATE, py::arg("format") = ::megdnn::param::WarpPerspective::Format::NCHW, py::arg("border_val") = .0f, py::arg("scope") = {}) .def_readwrite("imode", &WarpPerspectiveBackwardMat::imode) .def_readwrite("bmode", &WarpPerspectiveBackwardMat::bmode) .def_readwrite("format", &WarpPerspectiveBackwardMat::format) .def_readwrite("border_val", &WarpPerspectiveBackwardMat::border_val); // clang-format on