concat_and_split.h 2.2 KB
Newer Older
C
chengduoZH 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
/* Copyright (c) 2018 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. */

#pragma once
16
#include <vector>
Y
Yu Yang 已提交
17
#include "paddle/fluid/framework/data_type.h"
18
#include "paddle/fluid/framework/lod_tensor.h"
C
chengduoZH 已提交
19 20 21 22 23 24

namespace paddle {
namespace operators {
namespace math {

/*
C
chengduoZH 已提交
25 26 27 28 29 30
 * \brief Concatenate the input tensors along the dimension axis.
 *  TODO(zcd): maybe it needs to be more detailed.
 *  Examples:
 *     Input[0] = [[1,2],[3,4]]
 *     Input[1] = [[5,6]]
 *     axis = 0
C
chengduoZH 已提交
31
 *
C
chengduoZH 已提交
32 33 34
 *     Output = [[1,2],
 *               [3,4],
 *               [5,6]]
C
chengduoZH 已提交
35 36 37 38 39
 */
template <typename DeviceContext, typename T>
class ConcatFunctor {
 public:
  void operator()(const DeviceContext& context,
C
chengduoZH 已提交
40
                  const std::vector<framework::Tensor>& input, int axis,
C
chengduoZH 已提交
41 42 43
                  framework::Tensor* output);
};

C
chengduoZH 已提交
44 45 46 47 48 49 50 51 52 53 54 55
/*
 * \brief Split the input tensors along the dimension axis into outputs.
 *  TODO(zcd): maybe it needs to be more detailed.
 *  Examples:
 *     Input = [[1,2],
 *              [3,4],
 *              [5,6]]
 *     axis = 0
 *
 *     Output[0] = [[1,2],[3,4]]
 *     Output[1] = [[5,6]]
 */
C
chengduoZH 已提交
56
template <typename DeviceContext, typename T>
C
chengduo 已提交
57
class SplitFunctor {
C
chengduoZH 已提交
58 59
 public:
  void operator()(const DeviceContext& context, const framework::Tensor& input,
C
chengduoZH 已提交
60 61
                  const std::vector<const framework::Tensor*>& ref_inputs,
                  int axis, std::vector<framework::Tensor*>* outputs);
C
chengduoZH 已提交
62 63
};

C
chengduoZH 已提交
64 65 66
}  // namespace math
}  // namespace operators
}  // namespace paddle
C
chengduoZH 已提交
67 68 69 70 71 72 73 74 75 76 77

#define FOR_ALL_TYPES(macro) \
  macro(int);                \
  macro(float);              \
  macro(double);             \
  macro(bool);               \
  macro(int64_t);            \
  macro(int16_t);            \
  macro(uint8_t);            \
  macro(int8_t);             \
  macro(::paddle::platform::float16)