1 /* Copyright 2018 The TensorFlow Authors. All Rights Reserved.
2 
3 Licensed under the Apache License, Version 2.0 (the "License");
4 you may not use this file except in compliance with the License.
5 You may obtain a copy of the License at
6 
7     http://www.apache.org/licenses/LICENSE-2.0
8 
9 Unless required by applicable law or agreed to in writing, software
10 distributed under the License is distributed on an "AS IS" BASIS,
11 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 See the License for the specific language governing permissions and
13 limitations under the License.
14 ==============================================================================*/
15 #ifndef TENSORFLOW_LITE_DELEGATES_FLEX_BUFFER_MAP_H_
16 #define TENSORFLOW_LITE_DELEGATES_FLEX_BUFFER_MAP_H_
17 
18 #include <map>
19 
20 #include "tensorflow/lite/c/c_api_internal.h"
21 #include "tensorflow/core/framework/tensor.h"
22 
23 namespace tflite {
24 namespace flex {
25 
26 // Maps a TF Lite tensor index into a TensorFlow tensor.
27 //
28 // The TF Lite interpreter assigns integer indices to each of its tensors, but
29 // the Flex delegate deals in terms of TensorFlow tensors. This class maps
30 // from indices to tensors and allows the creation of new tensors to be
31 // associated with a given index.
32 class BufferMap {
33  public:
34   BufferMap();
35   ~BufferMap();
36 
37   // Returns true if the given 'tensor_index' has a corresponding
38   // tensorflow::Tensor.
39   bool HasTensor(int tensor_index) const;
40 
41   // Returns true if the given 'tensor_index' has a corresponding
42   // tensorflow::Tensor *and* the content is owned by TensorFlow (that is, the
43   // mapping was added by SetFromTensorFlow()).
44   bool IsTensorFlowTensor(int tensor_index) const;
45 
46   // Returns the tensorflow::Tensor associated with the given 'tensor_index'.
47   // Precondition: HasTensor() is true.
48   tensorflow::Tensor GetTensor(int tensor_index) const;
49 
50   // Associates the given tensorflow::Tensor with the given 'tensor_index'.
51   // Note that TensorFlow Tensors share data buffers, so this method is only a
52   // shallow copy.
53   void SetFromTensorFlow(int tensor_index, tensorflow::Tensor tensor);
54 
55   // Same as above but creates a new tensorflow::Tensor with a copy of the
56   // given TfLiteTensor's data.
57   void SetFromTfLite(int tensor_index, const TfLiteTensor* tensor);
58 
59  private:
60   // Mapping from TL Lite tensor ID to TensorFlow's Tensor. All tensors that
61   // are inputs or outputs of a subgraph will be added here, irrespective of
62   // whether their data are managed by TF Lite or TensorFlow.
63   std::map<int, tensorflow::Tensor> id_to_tensor_;
64   // A list of tensors that are completely managed by TensorFlow. Most of the
65   // time, TF Lite will populate tensors that are inputs to subgraphs, while
66   // TensorFlow will populate output tensors. Occasionally, however, an input
67   // tensor is coming from a previous subgraph and could have been populated by
68   // TensorFlow. This set keeps track of all input or output tensors that have
69   // been populated by tensorflow.
70   std::set<int> owned_by_tf_;
71 };
72 
73 }  // namespace flex
74 }  // namespace tflite
75 
76 #endif  // TENSORFLOW_LITE_DELEGATES_FLEX_BUFFER_MAP_H_
77