普通文本  |  83行  |  2.76 KB

/*
 * Copyright (C) 2018 The Android Open Source Project
 *
 * 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.
 */

#include "utils/tflite/dist_diversification.h"
#include "gmock/gmock.h"
#include "gtest/gtest.h"
#include "tensorflow/lite/interpreter.h"
#include "tensorflow/lite/kernels/register.h"
#include "tensorflow/lite/kernels/test_util.h"
#include "tensorflow/lite/model.h"

namespace libtextclassifier3 {
namespace {

class DistanceDiversificationOpModel : public tflite::SingleOpModel {
 public:
  explicit DistanceDiversificationOpModel(int matrix_rows);
  void SetDistanceMatrix(const std::initializer_list<float>& values) {
    PopulateTensor(distance_matrix_, values);
  }
  void SetNumOutput(int length) { PopulateTensor(num_results_, {length}); }
  void SetMinDistance(float min_distance) {
    PopulateTensor(min_distance_, {min_distance});
  }
  int GetOutputLen() { return ExtractVector<int>(output_len_).front(); }
  std::vector<int> GetOutputIndexes(int output_length) {
    auto res = ExtractVector<int>(output_indexes_);
    res.resize(output_length);
    return res;
  }

 private:
  int distance_matrix_;
  int num_results_;
  int min_distance_;

  int output_len_;
  int output_indexes_;
};

DistanceDiversificationOpModel::DistanceDiversificationOpModel(
    int matrix_rows) {
  distance_matrix_ = AddInput(tflite::TensorType_FLOAT32);
  min_distance_ = AddInput(tflite::TensorType_FLOAT32);
  num_results_ = AddInput(tflite::TensorType_INT32);

  output_indexes_ = AddOutput(tflite::TensorType_INT32);
  output_len_ = AddOutput(tflite::TensorType_INT32);
  SetCustomOp("DistanceDiversification", {},
              tflite::ops::custom::Register_DISTANCE_DIVERSIFICATION);
  BuildInterpreter({{matrix_rows, matrix_rows}, {1}, {1}});
}

// Tests
TEST(DistanceDiversificationOp, Simple) {
  DistanceDiversificationOpModel m(5);
  m.SetDistanceMatrix({0.0, 0.1, 0.2, 0.3, 0.4, 0.1, 0.0, 0.1, 0.2,
                       0.3, 0.2, 0.1, 0.0, 0.1, 0.2, 0.3, 0.2, 0.1,
                       0.0, 0.1, 0.4, 0.3, 0.2, 0.1, 0.0});
  m.SetMinDistance(0.21);
  m.SetNumOutput(3);
  m.Invoke();
  const int output_length = m.GetOutputLen();
  EXPECT_EQ(output_length, 2);
  EXPECT_THAT(m.GetOutputIndexes(output_length), testing::ElementsAre(0, 3));
}

}  // namespace
}  // namespace libtextclassifier3