From 4416d1f084acc383913bcf9949f578df697ae47e Mon Sep 17 00:00:00 2001 From: Abhiram Iyer Date: Mon, 8 Jun 2020 18:22:48 -0700 Subject: [PATCH] feat(//core/conversion/converters/impl): added support for linear1d and bilinear2d ops Signed-off-by: Abhiram Iyer Signed-off-by: Abhiram Iyer --- .../converters/impl/interpolate.cpp | 66 +++++++++++++++++++ 1 file changed, 66 insertions(+) diff --git a/core/conversion/converters/impl/interpolate.cpp b/core/conversion/converters/impl/interpolate.cpp index 1a3d676b12..34b3c5fa6a 100755 --- a/core/conversion/converters/impl/interpolate.cpp +++ b/core/conversion/converters/impl/interpolate.cpp @@ -100,6 +100,72 @@ auto interpolate_registrations TRTORCH_UNUSED = RegisterNodeConversionPatterns() TRTORCH_THROW_ERROR("Unable to convert node: " << util::node_info(n) << "\nScale factor parameter for upsample_nearest3d not supported yet."); } + return true; + } + }).pattern({ + "aten::upsample_linear1d(Tensor self, int[1] output_size, bool align_corners, float? scales=None) -> (Tensor)", + [](ConversionCtx* ctx, const torch::jit::Node* n, args& args) -> bool { + auto in = args[0].ITensor(); + auto in_shape = util::toVec(in->getDimensions()); + + bool align_corners = args[2].IValue()->to(); + + // Case 1: user uses output size and not scales + if (!args[1].IValue()->isNone() && args[3].IValue()->isNone()) { + auto out_size = util::toVec(util::toDims(args[1].unwrapToIntList())); + + TRTORCH_ASSERT(out_size.size() == 1, "aten::upsample_linear1d input Tensor and output size dimension mismatch"); + + auto out_shape = in_shape; + std::copy(out_size.begin(), out_size.end(), out_shape.begin() + (in_shape.size() - out_size.size())); + + auto resize_layer = ctx->net->addResize(*in); + TRTORCH_CHECK(resize_layer, "Unable to create interpolation (resizing) layer from node" << *n); + + resize_layer->setOutputDimensions(util::toDims(out_shape)); + resize_layer->setResizeMode(nvinfer1::ResizeMode::kLINEAR); + resize_layer->setAlignCorners(align_corners); + resize_layer->setName(util::node_info(n).c_str()); + + auto layer_output = ctx->AssociateValueAndTensor(n->outputs()[0], resize_layer->getOutput(0)); + LOG_DEBUG("Output tensor shape: " << layer_output->getDimensions()); + } else { + TRTORCH_THROW_ERROR("Unable to convert node: " << util::node_info(n) << "\nScale factor parameter for upsample_linear1d not supported yet."); + } + + return true; + } + }).pattern({ + "aten::upsample_bilinear2d(Tensor self, int[2] output_size, bool align_corners, float? scales_h=None, float? scales_w=None) -> (Tensor)", + [](ConversionCtx* ctx, const torch::jit::Node* n, args& args) -> bool { + auto in = args[0].ITensor(); + auto in_shape = util::toVec(in->getDimensions()); + + bool align_corners = args[2].IValue()->to(); + + // Case 1: user uses output size and not scales_h, scales_w + if (!args[1].IValue()->isNone() && args[3].IValue()->isNone() && args[4].IValue()->isNone()) { + auto out_size = util::toVec(util::toDims(args[1].unwrapToIntList())); + + TRTORCH_ASSERT(out_size.size() == 2, "aten::upsample_bilinear2d input Tensor and output size dimension mismatch"); + + auto out_shape = in_shape; + std::copy(out_size.begin(), out_size.end(), out_shape.begin() + (in_shape.size() - out_size.size())); + + auto resize_layer = ctx->net->addResize(*in); + TRTORCH_CHECK(resize_layer, "Unable to create interpolation (resizing) layer from node" << *n); + + resize_layer->setOutputDimensions(util::toDims(out_shape)); + resize_layer->setResizeMode(nvinfer1::ResizeMode::kLINEAR); + resize_layer->setAlignCorners(align_corners); + resize_layer->setName(util::node_info(n).c_str()); + + auto layer_output = ctx->AssociateValueAndTensor(n->outputs()[0], resize_layer->getOutput(0)); + LOG_DEBUG("Output tensor shape: " << layer_output->getDimensions()); + } else { + TRTORCH_THROW_ERROR("Unable to convert node: " << util::node_info(n) << "\nScale factor parameter for upsample_linear1d not supported yet."); + } + return true; } });