/* Copyright 2022 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_KERNELS_INTERNAL_OPTIMIZED_OPTIMIZED_OPS_UTILS_H_ #define TENSORFLOW_LITE_KERNELS_INTERNAL_OPTIMIZED_OPTIMIZED_OPS_UTILS_H_ #include "Eigen/Core" // from @eigen_archive #include "unsupported/Eigen/CXX11/Tensor" // from @eigen_archive #include "tensorflow/lite/kernels/internal/runtime_shape.h" #include "tensorflow/lite/kernels/internal/types.h" namespace tflite { namespace optimized_ops { // Make a local VectorMap typedef allowing to map a float array // as a Eigen vector expression. The std::conditional here is to // construct the suitable Eigen type for the constness of the // data. Indeed, for const data, we need to produce // Eigen::Map<const Eigen::Matrix<float, ...>> // and not the more straightforward // Eigen::Map<Eigen::Matrix<const float, ...>> VectorMap; template <typename Scalar> VectorMap<Scalar> MapAsVector(Scalar* data, const RuntimeShape& shape) { … } // Make a local VectorMap typedef allowing to map a float array // as a Eigen matrix expression. The same explanation as for VectorMap // above also applies here. MatrixMap; template <typename Scalar> MatrixMap<Scalar> MapAsMatrixWithLastDimAsRows(Scalar* data, const RuntimeShape& shape) { … } template <typename Scalar> MatrixMap<Scalar> MapAsMatrixWithFirstDimAsCols(Scalar* data, const RuntimeShape& shape) { … } ArrayMap; template <typename Scalar> ArrayMap<Scalar> MapAsArrayWithLastDimAsRows(Scalar* data, const RuntimeShape& shape) { … } } // namespace optimized_ops } // namespace tflite #endif // TENSORFLOW_LITE_KERNELS_INTERNAL_OPTIMIZED_OPTIMIZED_OPS_UTILS_H_