Interpreter
public final class Interpreter
A TensorFlow Lite interpreter that performs inference from a given model.
-
The configuration options for the
Interpreter
.Declaration
Swift
public let options: Options?
-
The total number of input
Tensor
s associated with the model.Declaration
Swift
public var inputTensorCount: Int { get }
-
The total number of output
Tensor
s associated with the model.Declaration
Swift
public var outputTensorCount: Int { get }
-
Creates a new instance with the given values.
Throws
An error if the model could not be loaded or the interpreter could not be created.Declaration
Parameters
modelPath
The local file path to a TensorFlow Lite model.
options
Configurations for the
Interpreter
. The default isnil
indicating that theInterpreter
will determine the configuration options.delegate
Array
ofDelegate
s for theInterpreter
to use to perform graph operations. The default isnil
. -
Invokes the interpreter to perform inference from the loaded graph.
Throws
An error if the model was not ready because the tensors were not allocated.Declaration
Swift
public func invoke() throws
-
Returns the output
Tensor
at the given index.Throws
An error if the index is invalid, tensors haven’t been allocated, or interpreter has not been invoked for models that dynamically compute output tensors based on the values of its input tensors.Declaration
Swift
public func output(at index: Int) throws -> Tensor
Parameters
index
The index for the output
Tensor
.Return Value
The output
Tensor
at the given index. -
Resizes the input
Tensor
at the given index to the specifiedTensor.Shape
.Note
After resizing an input tensor, the client must explicitly callallocateTensors()
before attempting to access the resized tensor data or invoking the interpreter to perform inference.Throws
An error if the input tensor at the given index could not be resized.Declaration
Swift
public func resizeInput(at index: Int, to shape: Tensor.Shape) throws
-
Copies the given data to the input
Tensor
at the given index.Throws
An error if thedata.count
does not match the input tensor’sdata.count
or if the given index is invalid.Declaration
Swift
@discardableResult public func copy(_ data: Data, toInputAt index: Int) throws -> Tensor
Parameters
data
The data to be copied to the input
Tensor
‘s data buffer.index
The index for the input
Tensor
.Return Value
The input
Tensor
with the copied data. -
Allocates memory for all input
Tensor
s based on theirTensor.Shape
s.Note
This is a relatively expensive operation and should only be called after creating the interpreter and resizing any input tensors.