1 /* Copyright 2019 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 16 package org.tensorflow.lite.support.common; 17 18 import org.tensorflow.lite.support.tensorbuffer.TensorBuffer; 19 20 /** 21 * TensorProcessor is a helper class for preprocessing and postprocessing tensors. It could 22 * transform a {@link TensorBuffer} to another by executing a chain of {@link TensorOperator}. 23 * 24 * <p>Example Usage: 25 * 26 * <pre> 27 * TensorProcessor processor = new TensorProcessor.Builder().add(new NormalizeOp(1, 2)).build(); 28 * TensorBuffer anotherTensorBuffer = processor.process(tensorBuffer); 29 * </pre> 30 * 31 * @see TensorProcessor.Builder to build a {@link TensorProcessor} instance. 32 * @see TensorProcessor#process(TensorBuffer) to apply the processor on a {@link TensorBuffer}. 33 */ 34 public class TensorProcessor extends SequentialProcessor<TensorBuffer> { TensorProcessor(Builder builder)35 private TensorProcessor(Builder builder) { 36 super(builder); 37 } 38 39 /** The Builder to create an {@link TensorProcessor}, which could be executed later. */ 40 public static class Builder extends SequentialProcessor.Builder<TensorBuffer> { 41 42 /** 43 * Creates a Builder to build {@link TensorProcessor}. 44 * 45 * @see #add(TensorOperator) to add an Op. 46 * @see #build() to complete the building process and get a built Processor. 47 */ Builder()48 public Builder() { 49 super(); 50 } 51 52 /** 53 * Adds an {@link TensorOperator} into the Operator chain. 54 * 55 * @param op the Operator instance to be executed then. 56 */ add(TensorOperator op)57 public TensorProcessor.Builder add(TensorOperator op) { 58 super.add(op); 59 return this; 60 } 61 62 /** Completes the building process and gets the {@link TensorProcessor} instance. */ 63 @Override build()64 public TensorProcessor build() { 65 return new TensorProcessor(this); 66 } 67 } 68 } 69