STT-tensorflow/tensorflow/lite/tools/logging.h
Chao Mei 020d0f0a49 1. Rename BenchmarkParam and BenchmarkParams to ToolParam and ToolParams respectively, and branch them to the upper-level directory.
2. Also branch the benchmark/logging.h to the upper level directory.

Note we still keep those in benchmark directory for backward compatibility but by reusing the new definitions here. These utility classes are helpful to and going to be used in other tflite-related tools.

PiperOrigin-RevId: 305834516
Change-Id: Id809398b060698b641cad0c8ac5fe9ca22b9ab40
2020-04-09 23:58:21 -07:00

88 lines
2.5 KiB
C++

/* Copyright 2020 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_TOOLS_LOGGING_H_
#define TENSORFLOW_LITE_TOOLS_LOGGING_H_
// LOG and CHECK macros for tflite tooling.
#include <cstdlib>
#include <iostream>
#include <sstream>
#ifdef _WIN32
#undef ERROR
#endif
namespace tflite {
namespace logging {
// A wrapper that logs to stderr.
//
// Used for TFLITE_LOG and TFLITE_BENCHMARK_CHECK macros.
class LoggingWrapper {
public:
enum class LogSeverity : int {
INFO = 0,
WARN = 1,
ERROR = 2,
FATAL = 3,
};
LoggingWrapper(LogSeverity severity)
: severity_(severity), should_log_(true) {}
LoggingWrapper(LogSeverity severity, bool log)
: severity_(severity), should_log_(log) {}
std::stringstream& Stream() { return stream_; }
~LoggingWrapper() {
if (should_log_) {
switch (severity_) {
case LogSeverity::INFO:
case LogSeverity::WARN:
std::cout << stream_.str() << std::endl;
break;
case LogSeverity::ERROR:
std::cerr << stream_.str() << std::endl;
break;
case LogSeverity::FATAL:
std::cerr << stream_.str() << std::endl;
std::flush(std::cerr);
std::abort();
break;
}
}
}
private:
std::stringstream stream_;
LogSeverity severity_;
bool should_log_;
};
} // namespace logging
} // namespace tflite
#define TFLITE_LOG(severity) \
tflite::logging::LoggingWrapper( \
tflite::logging::LoggingWrapper::LogSeverity::severity) \
.Stream()
#define TFLITE_TOOLS_CHECK(condition) \
tflite::logging::LoggingWrapper( \
tflite::logging::LoggingWrapper::LogSeverity::FATAL, \
(condition) ? false : true) \
.Stream()
#define TFLITE_TOOLS_CHECK_EQ(a, b) TFLITE_TOOLS_CHECK((a) == (b))
#endif // TENSORFLOW_LITE_TOOLS_LOGGING_H_