fill_constant_compute.cc 3.9 KB
Newer Older
Y
Yan Chunwei 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31
// Copyright (c) 2019 PaddlePaddle Authors. All Rights Reserved.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
//     http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.

#include "lite/core/kernel.h"
#include "lite/core/op_registry.h"

namespace paddle {
namespace lite {
namespace kernels {
namespace arm {

template <typename T>
class FillConstantCompute : public KernelLite<TARGET(kARM), PRECISION(kFloat)> {
 public:
  using param_t = operators::FillConstantParam;

  void Run() override {
    auto& param = *param_.get_mutable<param_t>();
    auto& context = ctx_->As<ARMContext>();

32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50
    if (param.dtype == static_cast<int32_t>(lite::core::FluidType::FP32)) {
      auto data = param.Out->template mutable_data<float>();
      for (int i = 0; i < param.Out->numel(); i++) {
        data[i] = param.value;
      }
    } else if (param.dtype ==
               static_cast<int32_t>(lite::core::FluidType::INT32)) {
      auto data = param.Out->template mutable_data<int32_t>();
      for (int i = 0; i < param.Out->numel(); i++) {
        data[i] = param.value;
      }
    } else if (param.dtype ==
               static_cast<int32_t>(lite::core::FluidType::INT8)) {
      auto data = param.Out->template mutable_data<int8_t>();
      for (int i = 0; i < param.Out->numel(); i++) {
        data[i] = param.value;
      }
    } else {
      LOG(FATAL) << "not supported dtype " << param.dtype;
Y
Yan Chunwei 已提交
51 52 53 54 55 56
    }
  }

  virtual ~FillConstantCompute() = default;
};

T
TianXiaogang 已提交
57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72
template <typename T>
class FillConstantBatchLikeCompute
    : public KernelLite<TARGET(kARM), PRECISION(kFloat)> {
 public:
  using param_t = operators::FillConstantBatchLikeParam;

  void Run() override {
    auto& param = *param_.get_mutable<param_t>();
    auto& context = ctx_->As<ARMContext>();

    if (param.input->lod().size() && param.input_dim_idx == 0) {
      auto odims = param.out->dims();
      odims[param.output_dim_idx] = param.input->lod().back().size() - 1;
      param.out->Resize(odims);
    }

73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91
    if (param.dtype == static_cast<int32_t>(lite::core::FluidType::FP32)) {
      auto data = param.out->template mutable_data<float>();
      for (int i = 0; i < param.out->numel(); i++) {
        data[i] = param.value;
      }
    } else if (param.dtype ==
               static_cast<int32_t>(lite::core::FluidType::INT32)) {
      auto data = param.out->template mutable_data<int32_t>();
      for (int i = 0; i < param.out->numel(); i++) {
        data[i] = param.value;
      }
    } else if (param.dtype ==
               static_cast<int32_t>(lite::core::FluidType::INT8)) {
      auto data = param.out->template mutable_data<int8_t>();
      for (int i = 0; i < param.out->numel(); i++) {
        data[i] = param.value;
      }
    } else {
      LOG(FATAL) << "not supported dtype " << param.dtype;
T
TianXiaogang 已提交
92 93 94 95 96 97
    }
  }

  virtual ~FillConstantBatchLikeCompute() = default;
};

Y
Yan Chunwei 已提交
98 99 100 101 102 103 104 105 106 107 108 109 110 111
}  // namespace arm
}  // namespace kernels
}  // namespace lite
}  // namespace paddle

// float
REGISTER_LITE_KERNEL(fill_constant,
                     kARM,
                     kFloat,
                     kNCHW,
                     paddle::lite::kernels::arm::FillConstantCompute<float>,
                     def)
    .BindOutput("Out", {LiteType::GetTensorTy(TARGET(kARM))})
    .Finalize();
T
TianXiaogang 已提交
112 113 114 115 116 117 118 119 120 121
REGISTER_LITE_KERNEL(
    fill_constant_batch_size_like,
    kARM,
    kFloat,
    kNCHW,
    paddle::lite::kernels::arm::FillConstantBatchLikeCompute<float>,
    def)
    .BindInput("Input", {LiteType::GetTensorTy(TARGET(kARM))})
    .BindOutput("Out", {LiteType::GetTensorTy(TARGET(kARM))})
    .Finalize();