var_type.h 2.4 KB
Newer Older
L
Luo Tao 已提交
1
/* Copyright (c) 2016 PaddlePaddle Authors. All Rights Reserve.
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 16 17 18 19

#pragma once
#include "paddle/framework/framework.pb.h"
#include "paddle/framework/lod_rank_table.h"
#include "paddle/framework/lod_tensor.h"
#include "paddle/framework/lod_tensor_array.h"
F
fengjiayi 已提交
20
#include "paddle/framework/reader.h"
Y
Yancey 已提交
21 22
#include "paddle/framework/selected_rows.h"
#include "paddle/framework/variable.h"
23 24 25

namespace paddle {
namespace framework {
26
inline proto::VarDesc::VarType ToVarType(std::type_index type) {
27
  if (type.hash_code() == typeid(LoDTensor).hash_code()) {
28
    return proto::VarDesc_VarType_LOD_TENSOR;
29
  } else if (type.hash_code() == typeid(LoDRankTable).hash_code()) {
30
    return proto::VarDesc_VarType_LOD_RANK_TABLE;
31
  } else if (type.hash_code() == typeid(LoDTensorArray).hash_code()) {
32
    return proto::VarDesc_VarType_LOD_TENSOR_ARRAY;
Y
Yu Yang 已提交
33
  } else if (type.hash_code() == typeid(SelectedRows).hash_code()) {
34
    return proto::VarDesc_VarType_SELECTED_ROWS;
F
fengjiayi 已提交
35 36
  } else if (type.hash_code() == typeid(ReaderHolder).hash_code()) {
    return proto::VarDesc_VarType_READER;
37 38 39 40 41
  } else {
    PADDLE_THROW("ToVarType:Unsupported type %s", type.name());
  }
}

Y
Yu Yang 已提交
42
template <typename Visitor>
Y
Yancey 已提交
43
inline void VisitVarType(const framework::Variable& var, Visitor visitor) {
Y
Yu Yang 已提交
44
  switch (ToVarType(var.Type())) {
45
    case proto::VarDesc_VarType_LOD_TENSOR:
F
fengjiayi 已提交
46
      visitor(var.Get<LoDTensor>());
Y
Yu Yang 已提交
47
      return;
48
    case proto::VarDesc_VarType_LOD_RANK_TABLE:
Y
Yu Yang 已提交
49 50
      visitor(var.Get<LoDRankTable>());
      return;
51
    case proto::VarDesc_VarType_LOD_TENSOR_ARRAY:
Y
Yu Yang 已提交
52 53
      visitor(var.Get<LoDTensorArray>());
      return;
54
    case proto::VarDesc_VarType_SELECTED_ROWS:
Y
Yu Yang 已提交
55 56
      visitor(var.Get<SelectedRows>());
      return;
F
fengjiayi 已提交
57 58 59
    case proto::VarDesc_VarType_READER:
      visitor(var.Get<ReaderHolder>());
      return;
Y
Yu Yang 已提交
60 61 62 63 64
    default:
      PADDLE_THROW("Not supported visit type, %d", ToVarType(var.Type()));
  }
}

65 66
}  // namespace framework
}  // namespace paddle