94{
95 std::vector<flatbuffers::Offset<circle::SubGraph>> subgprahs_vec;
96
97 int32_t subgraph_index = 0;
98
99 for (auto it_sg : *tflite_flatbuffer_vec)
100 {
101
102 std::vector<flatbuffers::Offset<circle::Tensor>> tensor_vec;
103
104 auto tflite_tensors = it_sg->tensors();
105 for (auto it : *tflite_tensors)
106 {
107
109 if (it->shape())
110 {
111 auto shape_vec = std::vector<int32_t>({it->shape()->
begin(), it->shape()->end()});
112 shape = _fb->CreateVector(shape_vec);
113 }
114
116 if (it->name())
117 name = _fb->CreateString(it->name()->str());
118
120 if (it->quantization())
121 {
122 std::vector<float> tfmin;
123 std::vector<float> tfmax;
124 std::vector<float> tfscale;
125 std::vector<int64_t> tfzerop;
130 int32_t quantized_dimension = it->quantization()->quantized_dimension();
131
132 if (it->quantization()->min() && it->quantization()->max())
133 {
134 auto rmin = it->quantization()->min();
135 auto rmax = it->quantization()->max();
136 tfmin = std::vector<float>{rmin->begin(), rmin->end()};
137 tfmax = std::vector<float>{rmax->begin(), rmax->end()};
138 min = _fb->CreateVector(tfmin);
139 max = _fb->CreateVector(tfmax);
140 }
141
142 if (it->quantization()->scale() && it->quantization()->zero_point())
143 {
144 auto rs = it->quantization()->scale();
145 auto rz = it->quantization()->zero_point();
146 tfscale = std::vector<float>{rs->begin(), rs->end()};
147 tfzerop = std::vector<int64_t>{rz->begin(), rz->end()};
148 scale = _fb->CreateVector(tfscale);
149 zero_point = _fb->CreateVector(tfzerop);
150 }
151
152 quantization = circle::CreateQuantizationParameters(*_fb, min, max, scale, zero_point,
153 circle::QuantizationDetails_NONE, 0,
154 quantized_dimension);
155 }
156
157 bool is_variable = it->is_variable();
158
160
161 if (it->sparsity())
162 {
166 dim_metadata;
167
168
169 if (it->sparsity()->traversal_order())
170 {
171 auto traversal_order_vec = std::vector<int32_t>{
172 it->sparsity()->traversal_order()->begin(), it->sparsity()->traversal_order()->end()};
173 traversal_order = _fb->CreateVector(traversal_order_vec);
174 }
175
176
177 if (it->sparsity()->block_map())
178 {
179 auto block_map_vec = std::vector<int32_t>{it->sparsity()->block_map()->begin(),
180 it->sparsity()->block_map()->end()};
181 block_map = _fb->CreateVector(block_map_vec);
182 }
183
184
185 std::vector<flatbuffers::Offset<circle::DimensionMetadata>> dim_metadata_vec;
186 auto tflite_dim_metadata = it->sparsity()->dim_metadata();
187 for (auto it : *tflite_dim_metadata)
188 {
189
190 auto tflite_array_segments_type = it->array_segments_type();
191 auto circle_array_segments =
193 auto circle_array_segments_type =
195
196
197 auto tflite_array_indices_type = it->array_indices_type();
198 auto circle_array_indices =
200 auto circle_array_indices_type =
202
203 auto circle_dim_metadata_builder = circle::DimensionMetadataBuilder{*_fb};
204
206 circle_dim_metadata_builder.add_dense_size(it->dense_size());
207 circle_dim_metadata_builder.add_array_segments(circle_array_segments);
208 circle_dim_metadata_builder.add_array_segments_type(circle_array_segments_type);
209 circle_dim_metadata_builder.add_array_indices(circle_array_indices);
210 circle_dim_metadata_builder.add_array_indices_type(circle_array_indices_type);
211 auto dim_metadata = circle_dim_metadata_builder.Finish();
212 dim_metadata_vec.emplace_back(dim_metadata);
213 }
214 dim_metadata = _fb->CreateVector(dim_metadata_vec);
215
216 sparsity = circle::CreateSparsityParameters(*_fb, traversal_order, block_map, dim_metadata);
217 }
218
219
221 if (it->shape_signature())
222 {
223 auto shape_signature_vec =
224 std::vector<int32_t>({it->shape_signature()->
begin(), it->shape_signature()->end()});
225 shape_signature = _fb->CreateVector(shape_signature_vec);
226 }
227
228 circle::TensorBuilder tensor_builder{*_fb};
229 tensor_builder.add_shape(shape);
231 tensor_builder.add_buffer(it->buffer());
232 tensor_builder.add_name(name);
233 tensor_builder.add_quantization(quantization);
234 tensor_builder.add_is_variable(is_variable);
235 tensor_builder.add_sparsity(
sparsity);
236 tensor_builder.add_shape_signature(shape_signature);
237 auto tensor = tensor_builder.Finish();
238 tensor_vec.emplace_back(tensor);
239 }
240 auto circle_tensors = _fb->CreateVector(tensor_vec);
241
242
243 auto tflite_inputs = it_sg->inputs();
244 std::vector<int32_t> input_vec{tflite_inputs->begin(), tflite_inputs->end()};
245
246
247
248
249 if (_tfl_signature_def_offsets != nullptr)
250 {
251 for (auto it_signdef : *_tfl_signature_def_offsets)
252 {
253 if (it_signdef->subgraph_index() == subgraph_index)
254 {
255 auto inputs = it_signdef->inputs();
256 assert(
inputs->size() == input_vec.size());
257
258 std::map<std::string, uint32_t> map_name_index;
259 for (
auto it_tm : *
inputs)
260 {
261 map_name_index[it_tm->name()->str()] = it_tm->tensor_index();
262 }
263 uint32_t input_vec_idx = 0;
264 for (auto &item : map_name_index)
265 {
266 input_vec[input_vec_idx++] = item.second;
267 }
268 }
269 }
270 }
271
272 auto circle_inputs = _fb->CreateVector(input_vec);
273
274
275 auto tflite_outputs = it_sg->outputs();
276 std::vector<int32_t> output_vec{tflite_outputs->begin(), tflite_outputs->end()};
277
278 if (_tfl_signature_def_offsets != nullptr)
279 {
280
281 for (auto it_signdef : *_tfl_signature_def_offsets)
282 {
283 if (it_signdef->subgraph_index() == subgraph_index)
284 {
285 auto outputs = it_signdef->outputs();
286 assert(outputs->size() == output_vec.size());
287
288 std::map<std::string, uint32_t> map_name_index;
289 for (auto it_tm : *outputs)
290 {
291 map_name_index[it_tm->name()->str()] = it_tm->tensor_index();
292 }
293 uint32_t output_vec_idx = 0;
294 for (auto &item : map_name_index)
295 {
296 output_vec[output_vec_idx++] = item.second;
297 }
298 }
299 }
300 }
301
302 auto circle_outputs = _fb->CreateVector(output_vec);
303
304
305 std::vector<flatbuffers::Offset<circle::Operator>> operator_vec;
306
307 auto tflite_operators = it_sg->operators();
308 if (tflite_operators != nullptr)
309 {
310 for (auto it : *tflite_operators)
311 {
312
313 std::vector<int32_t> input_vec{it->inputs()->begin(), it->inputs()->end()};
314 auto circle_inputs = _fb->CreateVector(input_vec);
315
316 std::vector<int32_t> output_vec{it->outputs()->begin(), it->outputs()->end()};
317 auto circle_outputs = _fb->CreateVector(output_vec);
318
321
323 if (it->custom_options())
324 {
325 std::vector<uint8_t> custom_options_vec{it->custom_options()->begin(),
326 it->custom_options()->end()};
328 }
329
330
331 assert(it->custom_options_format() == tflite::CustomOptionsFormat_FLEXBUFFERS);
332 auto circle_custom_options_format = circle::CustomOptionsFormat_FLEXBUFFERS;
333
334 circle::OperatorBuilder operator_builder{*_fb};
335 operator_builder.add_opcode_index(it->opcode_index());
336 operator_builder.add_inputs(circle_inputs);
337 operator_builder.add_outputs(circle_outputs);
338 operator_builder.add_builtin_options(circle_builtin_options);
339 operator_builder.add_builtin_options_type(circle_builtin_options_type);
340 operator_builder.add_custom_options(circle_custom_options);
341 operator_builder.add_custom_options_format(circle_custom_options_format);
342
343 auto opeartor = operator_builder.Finish();
344 operator_vec.emplace_back(opeartor);
345 }
346 }
347 auto circle_operators = _fb->CreateVector(operator_vec);
348
349
350 auto subgraphs_name = _fb->CreateString(it_sg->name());
351
352
353 auto circle_subgraph_builder = circle::SubGraphBuilder{*_fb};
354
355 circle_subgraph_builder.add_tensors(circle_tensors);
356 circle_subgraph_builder.add_inputs(circle_inputs);
357 circle_subgraph_builder.add_outputs(circle_outputs);
358 circle_subgraph_builder.add_operators(circle_operators);
359 circle_subgraph_builder.add_name(subgraphs_name);
360
361 auto circle_subgraph = circle_subgraph_builder.Finish();
362 subgprahs_vec.emplace_back(circle_subgraph);
363
364
365 subgraph_index = subgraph_index + 1;
366 }
367 _circle_flatbuffer_vec_offset = _fb->CreateVector(subgprahs_vec);
368}
circle::BuiltinOptions circle_builtin_options(const luci::CircleNode *node)
flatbuffers::Offset< flatbuffers::Vector< uint8_t > > circle_custom_options(flatbuffers::FlatBufferBuilder &fb, const luci::CircleNode *node)
circle::SparseIndexVector get_circle_sparse_index_vector_type(const tflite::SparseIndexVector &tfl_sparse_index_vector_type)
Returns circle SparseIndexVector type according to tflite.
circle::BuiltinOptions get_circle_builtin_options_type(const tflite::Operator *op)
Returns circle builtin_options_type according to tflite.
circle::DimensionType get_circle_dimension_type(tflite::DimensionType tfl_dim_type)
Returns circle DimensionType according to tflite.
flatbuffers::Offset< void > get_circle_builtin_options(flatbuffers::FlatBufferBuilder &fb, const tflite::Operator *op)
Returns circle builtin_options according to tflite.
circle::TensorType get_circle_tensortype(tflite::TensorType tfl_tt)
Returns circle TensorType according to tflite.
flatbuffers::Offset< void > get_circle_sparse_index_vector(flatbuffers::FlatBufferBuilder &fb, const void *v_array, const tflite::SparseIndexVector &tfl_sparse_index_vector_type)
Returns circle SparseIndexVector according to tflite.