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 {
27
inline proto::VarType::Type ToVarType(std::type_index type) {
28
  if (type.hash_code() == typeid(LoDTensor).hash_code()) {
29
    return proto::VarType_Type_LOD_TENSOR;
30
  } else if (type.hash_code() == typeid(LoDRankTable).hash_code()) {
31
    return proto::VarType_Type_LOD_RANK_TABLE;
32
  } else if (type.hash_code() == typeid(LoDTensorArray).hash_code()) {
33
    return proto::VarType_Type_LOD_TENSOR_ARRAY;
Y
Yu Yang 已提交
34
  } else if (type.hash_code() == typeid(SelectedRows).hash_code()) {
35
    return proto::VarType_Type_SELECTED_ROWS;
F
fengjiayi 已提交
36
  } else if (type.hash_code() == typeid(ReaderHolder).hash_code()) {
37
    return proto::VarType_Type_READER;
38 39
  } else if (type.hash_code() == typeid(ChannelHolder).hash_code()) {
    return proto::VarType_Type_CHANNEL;
40 41 42 43 44
  } else {
    PADDLE_THROW("ToVarType:Unsupported type %s", type.name());
  }
}

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

71 72
}  // namespace framework
}  // namespace paddle