var_type.h 2.6 KB
Newer Older
1
/* Copyright (c) 2016 PaddlePaddle Authors. All Rights Reserved.
2

L
Luo Tao 已提交
3 4 5
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
6

L
Luo Tao 已提交
7
    http://www.apache.org/licenses/LICENSE-2.0
8

L
Luo Tao 已提交
9 10 11 12 13
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. */
14 15

#pragma once
16
#include "paddle/fluid/framework/channel.h"
Y
Yi Wang 已提交
17 18 19 20 21 22 23
#include "paddle/fluid/framework/framework.pb.h"
#include "paddle/fluid/framework/lod_rank_table.h"
#include "paddle/fluid/framework/lod_tensor.h"
#include "paddle/fluid/framework/lod_tensor_array.h"
#include "paddle/fluid/framework/reader.h"
#include "paddle/fluid/framework/selected_rows.h"
#include "paddle/fluid/framework/variable.h"
24 25 26

namespace paddle {
namespace framework {
S
sneaxiy 已提交
27 28

template <typename T>
Y
Yu Yang 已提交
29
inline bool IsType(const std::type_index& type_index) {
S
sneaxiy 已提交
30 31 32
  return type_index == std::type_index(typeid(T));
}

33
inline proto::VarType::Type ToVarType(std::type_index type) {
S
sneaxiy 已提交
34
  if (IsType<LoDTensor>(type)) {
35
    return proto::VarType_Type_LOD_TENSOR;
S
sneaxiy 已提交
36
  } else if (IsType<LoDRankTable>(type)) {
37
    return proto::VarType_Type_LOD_RANK_TABLE;
S
sneaxiy 已提交
38
  } else if (IsType<LoDTensorArray>(type)) {
39
    return proto::VarType_Type_LOD_TENSOR_ARRAY;
S
sneaxiy 已提交
40
  } else if (IsType<SelectedRows>(type)) {
41
    return proto::VarType_Type_SELECTED_ROWS;
S
sneaxiy 已提交
42
  } else if (IsType<ReaderHolder>(type)) {
43
    return proto::VarType_Type_READER;
S
sneaxiy 已提交
44
  } else if (IsType<ChannelHolder>(type)) {
45
    return proto::VarType_Type_CHANNEL;
46 47 48 49 50
  } else {
    PADDLE_THROW("ToVarType:Unsupported type %s", type.name());
  }
}

Y
Yu Yang 已提交
51
template <typename Visitor>
Y
Yancey 已提交
52
inline void VisitVarType(const framework::Variable& var, Visitor visitor) {
Y
Yu Yang 已提交
53
  switch (ToVarType(var.Type())) {
54
    case proto::VarType_Type_LOD_TENSOR:
F
fengjiayi 已提交
55
      visitor(var.Get<LoDTensor>());
Y
Yu Yang 已提交
56
      return;
57
    case proto::VarType_Type_LOD_RANK_TABLE:
Y
Yu Yang 已提交
58 59
      visitor(var.Get<LoDRankTable>());
      return;
60
    case proto::VarType_Type_LOD_TENSOR_ARRAY:
Y
Yu Yang 已提交
61 62
      visitor(var.Get<LoDTensorArray>());
      return;
63
    case proto::VarType_Type_SELECTED_ROWS:
Y
Yu Yang 已提交
64 65
      visitor(var.Get<SelectedRows>());
      return;
66
    case proto::VarType_Type_READER:
F
fengjiayi 已提交
67 68
      visitor(var.Get<ReaderHolder>());
      return;
69 70 71
    case proto::VarType_Type_CHANNEL:
      visitor(var.Get<ChannelHolder>());
      return;
Y
Yu Yang 已提交
72 73 74 75 76
    default:
      PADDLE_THROW("Not supported visit type, %d", ToVarType(var.Type()));
  }
}

77 78
}  // namespace framework
}  // namespace paddle