This provides adds a new callback-based op registration C API. This new function would be required in order to implement the TF Tasks Library, or any other C++ API that uses OpResolver parameters, using the TF Lite C API. PiperOrigin-RevId: 333154110 Change-Id: I6e53edc91ff1271f41c355bb9ad1a48d32bf3e41
134 lines
5.4 KiB
C++
134 lines
5.4 KiB
C++
/* Copyright 2018 The TensorFlow 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.
|
|
==============================================================================*/
|
|
#ifndef TENSORFLOW_LITE_C_C_API_INTERNAL_H_
|
|
#define TENSORFLOW_LITE_C_C_API_INTERNAL_H_
|
|
|
|
#include <stdarg.h>
|
|
|
|
#include <memory>
|
|
#include <vector>
|
|
|
|
#include "tensorflow/lite/builtin_ops.h"
|
|
#include "tensorflow/lite/core/api/error_reporter.h"
|
|
#include "tensorflow/lite/core/api/op_resolver.h"
|
|
#include "tensorflow/lite/interpreter.h"
|
|
#include "tensorflow/lite/model.h"
|
|
#include "tensorflow/lite/mutable_op_resolver.h"
|
|
|
|
// Internal structures and subroutines used by the C API. These are likely to
|
|
// change and should not be depended on directly by any C API clients.
|
|
//
|
|
// NOTE: This header does not follow C conventions and does not define a C API.
|
|
// It is effectively an (internal) implementation detail of the C API.
|
|
|
|
struct TfLiteModel {
|
|
// Sharing is safe as FlatBufferModel is const.
|
|
std::shared_ptr<const tflite::FlatBufferModel> impl;
|
|
};
|
|
|
|
// The `TfLiteOpResolver` struct is an abstract callback interface that
|
|
// contains function pointers for callbacks that return a
|
|
// `TfLiteRegistration` given an op code or custom op name. This mechanism is
|
|
// used to map ops referenced in the flatbuffer model to executable function
|
|
// pointers (`TfLiteRegistration`s).
|
|
// This struct mirrors the tflite::OpResolver C++ abstract base class.
|
|
struct TfLiteOpResolverCallbacks {
|
|
// Opaque data that gets passed down to the callback functions.
|
|
void* user_data = nullptr;
|
|
|
|
// Callback that finds the op registration for a builtin operator by enum
|
|
// code. The `user_data` parameter will be set to the
|
|
// `op_resolver_user_data` value that was passed to
|
|
// `TfLiteInterpreterOptionsSetOpResolver`.
|
|
const TfLiteRegistration* (*find_builtin_op)(void* user_data,
|
|
TfLiteBuiltinOperator op,
|
|
int version);
|
|
// Callback that finds the op registration of a custom operator by op name.
|
|
// The `user_data` parameter will be set to the `op_resolver_user_data` value
|
|
// that was passed to `TfLiteInterpreterOptionsSetOpResolver`.
|
|
const TfLiteRegistration* (*find_custom_op)(void* user_data, const char* op,
|
|
int version);
|
|
};
|
|
|
|
// This struct mirrors the tflite::ErrorResolver C++ abstract base class.
|
|
struct TfLiteErrorReporterCallback {
|
|
// Opaque data that gets passed down to the callback function.
|
|
void* user_data = nullptr;
|
|
|
|
// Callback function that reports an error.
|
|
void (*error_reporter)(void* user_data, const char* format,
|
|
va_list args) = nullptr;
|
|
};
|
|
|
|
struct TfLiteInterpreterOptions {
|
|
enum {
|
|
kDefaultNumThreads = -1,
|
|
};
|
|
int num_threads = kDefaultNumThreads;
|
|
|
|
tflite::MutableOpResolver mutable_op_resolver;
|
|
|
|
TfLiteOpResolverCallbacks op_resolver_callbacks = {};
|
|
|
|
std::vector<TfLiteDelegate*> delegates;
|
|
|
|
TfLiteErrorReporterCallback error_reporter_callback;
|
|
|
|
bool use_nnapi = false;
|
|
};
|
|
|
|
struct TfLiteInterpreter {
|
|
// Taking a reference to the (const) model data avoids lifetime-related issues
|
|
// and complexity with the TfLiteModel's existence.
|
|
std::shared_ptr<const tflite::FlatBufferModel> model;
|
|
|
|
// The interpreter does not take ownership of the provided ErrorReporter
|
|
// instance, so we ensure its validity here. Note that the interpreter may use
|
|
// the reporter in its destructor, so the reporter should be declared first.
|
|
std::unique_ptr<tflite::ErrorReporter> optional_error_reporter;
|
|
|
|
std::unique_ptr<tflite::Interpreter> impl;
|
|
};
|
|
|
|
namespace tflite {
|
|
namespace internal {
|
|
|
|
// This adds the builtin and/or custom operators specified in options in
|
|
// `optional_options` (if any) to `mutable_resolver`, and then returns a newly
|
|
// created TfLiteInterpreter using `mutable_op_resolver` as the default
|
|
// OpResolver, and using any other options in `optional_options`, and using
|
|
// the provided `model`.
|
|
//
|
|
// * `model` must be a valid model instance. The caller retains ownership of the
|
|
// object, and can destroy it immediately after creating the interpreter; the
|
|
// interpreter will maintain its own reference to the underlying model data.
|
|
// * `optional_options` may be null. The caller retains ownership of the object,
|
|
// and can safely destroy it immediately after creating the interpreter.
|
|
// * `mutable_resolver` must not be null. The caller retains ownership of the
|
|
// MutableOpResolver object, and can safely destroy it immediately after
|
|
// creating the interpreter.
|
|
//
|
|
// NOTE: The client *must* explicitly allocate tensors before attempting to
|
|
// access input tensor data or invoke the interpreter.
|
|
|
|
TfLiteInterpreter* InterpreterCreateWithOpResolver(
|
|
const TfLiteModel* model, const TfLiteInterpreterOptions* optional_options,
|
|
tflite::MutableOpResolver* mutable_resolver);
|
|
|
|
} // namespace internal
|
|
} // namespace tflite
|
|
|
|
#endif // TENSORFLOW_LITE_C_C_API_INTERNAL_H_
|