vector_view.h 4.8 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20
// Copyright (c) 2020 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

#include <string>
#include <type_traits>
#include <vector>
#include "flatbuffers/flatbuffers.h"
21
#include "lite/utils/cp_logging.h"
22 23 24 25 26 27 28 29 30 31 32 33 34 35

namespace paddle {
namespace lite {
namespace fbs {

struct Flatbuffers {};
struct Standand {};

template <typename T, typename U = void>
struct ElementTraits {
  typedef T element_type;
};

template <typename T>
36
struct ElementTraits<T*,
37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79
                     typename std::enable_if<std::is_class<T>::value>::type> {
  typedef flatbuffers::Offset<T> element_type;
};

template <>
struct ElementTraits<std::string, void> {
  typedef flatbuffers::Offset<flatbuffers::String> element_type;
};

template <typename T, typename U>
struct VectorTraits;

template <typename T>
struct VectorTraits<T, Flatbuffers> {
  typedef flatbuffers::Vector<typename ElementTraits<T>::element_type>
      vector_type;
  typedef typename vector_type::const_iterator const_iterator;
  typedef typename const_iterator::value_type value_type;
  typedef const typename const_iterator::reference const_reference;
  typedef value_type subscript_return_type;
};

template <typename T>
struct VectorTraits<T, Standand> {
  typedef std::vector<T> vector_type;
  typedef typename vector_type::const_iterator const_iterator;
  typedef typename vector_type::const_reference const_reference;
  typedef const_reference subscript_return_type;
};

template <typename T, typename U = Flatbuffers>
class VectorView {
 public:
  typedef VectorTraits<T, U> Traits;
  explicit VectorView(typename Traits::vector_type const* cvec) {
    cvec_ = cvec;
  }
  typename Traits::subscript_return_type operator[](size_t i) const {
    return cvec_->operator[](i);
  }
  typename Traits::const_iterator begin() const { return cvec_->begin(); }
  typename Traits::const_iterator end() const { return cvec_->end(); }
  size_t size() const { return cvec_->size(); }
80 81 82 83 84 85 86 87 88
  operator std::vector<T>() {
    VLOG(10) << "Copying elements out of VectorView will damage performance.";
    std::vector<T> tmp;
    tmp.reserve(cvec_->size());
    for (auto val : *cvec_) {
      tmp.push_back(val);
    }
    return tmp;
  }
89 90 91 92 93 94 95 96 97 98 99 100 101 102
  ~VectorView() = default;

 private:
  typename Traits::vector_type const* cvec_;
};

struct FBSStrIterator {
  typedef flatbuffers::VectorIterator<
      flatbuffers::Offset<flatbuffers::String>,
      typename flatbuffers::IndirectHelper<
          flatbuffers::Offset<flatbuffers::String>>::return_type>
      VI;

  explicit FBSStrIterator(const VI& iter) { iter_ = iter; }
103
  const VI& raw_iter() const { return iter_; }
104 105

  bool operator==(const FBSStrIterator& other) const {
106
    return iter_ == other.raw_iter();
107 108 109
  }

  bool operator<(const FBSStrIterator& other) const {
110
    return iter_ < other.raw_iter();
111 112 113
  }

  bool operator!=(const FBSStrIterator& other) const {
114
    return iter_ != other.raw_iter();
115 116 117
  }

  ptrdiff_t operator-(const FBSStrIterator& other) const {
118
    return iter_ - other.raw_iter();
119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156
  }

  std::string operator*() const { return iter_.operator*()->str(); }
  std::string operator->() const { return iter_.operator->()->str(); }

  FBSStrIterator& operator++() {
    iter_++;
    return *this;
  }

  FBSStrIterator& operator--() {
    iter_--;
    return *this;
  }

  FBSStrIterator operator+(const size_t& offset) {
    return FBSStrIterator(iter_ + offset);
  }

  FBSStrIterator operator-(const size_t& offset) {
    return FBSStrIterator(iter_ - offset);
  }

 private:
  VI iter_;
};

template <>
class VectorView<std::string, Flatbuffers> {
 public:
  typedef VectorTraits<std::string, Flatbuffers> Traits;
  explicit VectorView(typename Traits::vector_type const* cvec) {
    cvec_ = cvec;
  }
  std::string operator[](size_t i) const { return cvec_->operator[](i)->str(); }
  FBSStrIterator begin() const { return FBSStrIterator(cvec_->begin()); }
  FBSStrIterator end() const { return FBSStrIterator(cvec_->end()); }
  size_t size() const { return cvec_->size(); }
157 158 159 160 161 162 163 164 165
  operator std::vector<std::string>() {
    VLOG(10) << "Copying elements out of VectorView will damage performance.";
    std::vector<std::string> tmp;
    tmp.reserve(cvec_->size());
    for (auto val : *cvec_) {
      tmp.push_back(val->str());
    }
    return tmp;
  }
166 167 168 169 170 171 172 173 174
  ~VectorView() = default;

 private:
  typename Traits::vector_type const* cvec_;
};

}  // namespace fbs
}  // namespace lite
}  // namespace paddle