Files
openvino/inference-engine/include/ie_parameter.hpp
2019-10-04 19:26:43 +03:00

280 lines
6.9 KiB
C++

// Copyright (C) 2018-2019 Intel Corporation
// SPDX-License-Identifier: Apache-2.0
//
/**
* @brief A header file for the CNNNetworkIterator class
* @file ie_cnn_network_iterator.hpp
*/
#pragma once
#include <details/ie_exception.hpp>
#include <algorithm>
#include <typeinfo>
#include <iterator>
#include <utility>
#include <vector>
#include <cctype>
#include <string>
#include <tuple>
#include <map>
namespace InferenceEngine {
/**
* @brief This class represents an object to work with different parameters
*/
class Parameter {
public:
/**
* @brief Default constructor
*/
Parameter() = default;
/**
* @brief Move constructor
* @param parameter Parameter object
*/
Parameter(Parameter &&parameter) noexcept {
std::swap(ptr, parameter.ptr);
}
/**
* @brief Copy constructor
* @param parameter Parameter object
*/
Parameter(const Parameter &parameter) {
*this = parameter;
}
/**
* @brief Constructor creates parameter with object
* @tparam T Parameter type
* @tparam U Identity type-transformation
* @param parameter object
*/
template<class T, typename = typename std::enable_if<!std::is_same<typename std::decay<T>::type, Parameter>::value>::type >
Parameter(T&& parameter) { // NOLINT
static_assert(!std::is_same<typename std::decay<T>::type, Parameter>::value, "To prevent recursion");
ptr = new RealData<typename std::decay<T>::type>(std::forward<T>(parameter));
}
/**
* @brief Constructor creates string parameter from char *
* @param str char array
*/
Parameter(const char *str): Parameter(std::string(str)) {} // NOLINT
/**
* @brief Destructor
*/
virtual ~Parameter() {
clear();
}
/**
* Copy operator for Parameter
* @param parameter Parameter object
* @return Parameter
*/
Parameter& operator=(const Parameter& parameter) {
if (this == &parameter) {
return *this;
}
clear();
if (!parameter.empty())
ptr = parameter.ptr->copy();
return *this;
}
/**
* Remove a value from parameter
*/
void clear() {
delete ptr;
ptr = nullptr;
}
/**
* Checks that parameter contains a value
* @return false if parameter contains a value else false
*/
bool empty() const noexcept {
return nullptr == ptr;
}
/**
* Checks the type of value
* @tparam T Type of value
* @return true if type of value is correct
*/
template<class T>
bool is() const {
return empty() ? false : ptr->is(typeid(T));
}
/**
* Dynamic cast to specified type
* @tparam T type
* @return casted object
*/
template<typename T>
T &&as() && {
return std::move(dyn_cast<T>(ptr));
}
/**
* Dynamic cast to specified type
* @tparam T type
* @return casted object
*/
template<class T>
T& as() & {
return dyn_cast<T>(ptr);
}
/**
* Dynamic cast to specified type
* @tparam T type
* @return casted object
*/
template<class T>
const T& as() const & {
return dyn_cast<T>(ptr);
}
/**
* Dynamic cast to specified type
* @tparam T type
* @return casted object
*/
template<class T>
operator T&&() && {
return std::move(dyn_cast<typename std::remove_cv<T>::type>(ptr));
}
/**
* Dynamic cast to specified type
* @tparam T type
* @return casted object
*/
template<class T>
operator T&() & {
return dyn_cast<typename std::remove_cv<T>::type>(ptr);
}
/**
* Dynamic cast to specified type
* @tparam T type
* @return casted object
*/
template<class T> operator const T&() const & {
return dyn_cast<typename std::remove_cv<T>::type>(ptr);
}
/**
* Dynamic cast to specified type
* @tparam T type
* @return casted object
*/
template<class T> operator T&() const & {
return dyn_cast<typename std::remove_cv<T>::type>(ptr);
}
/**
* @brief The comparison operator for the Parameter
* @param rhs object to compare
* @return true if objects are equal
*/
bool operator == (const Parameter& rhs) const {
return *ptr == *(rhs.ptr);
}
/**
* @brief The comparison operator for the Parameter
* @param rhs object to compare
* @return true if objects aren't equal
*/
bool operator != (const Parameter& rhs) const {
return !(*this == rhs);
}
private:
template<class T, class EqualTo>
struct CheckOperatorEqual {
template<class U, class V>
static auto test(U*) -> decltype(std::declval<U>() == std::declval<V>()) {
return false;
}
template<typename, typename>
static auto test(...) -> std::false_type {
return {};
}
using type = typename std::is_same<bool, decltype(test<T, EqualTo>(nullptr))>::type;
};
template<class T, class EqualTo = T>
struct HasOperatorEqual : CheckOperatorEqual<T, EqualTo>::type {};
struct Any {
virtual ~Any() = default;
virtual bool is(const std::type_info&) const = 0;
virtual Any *copy() const = 0;
virtual bool operator==(const Any& rhs) const = 0;
};
template<class T>
struct RealData: Any, std::tuple<T> {
using std::tuple<T>::tuple;
bool is(const std::type_info& id) const override {
return id == typeid(T);
}
Any *copy() const override {
return new RealData{get()};
}
T& get() & {
return std::get<0>(*static_cast<std::tuple<T>*>(this));
}
const T& get() const & {
return std::get<0>(*static_cast<const std::tuple<T>*>(this));
}
template <class U>
typename std::enable_if<!HasOperatorEqual<U>::value, bool>::type
equal(const Any& left, const Any& rhs) const {
THROW_IE_EXCEPTION << "Parameter doesn't contain equal operator";
}
template <class U>
typename std::enable_if<HasOperatorEqual<U>::value, bool>::type
equal(const Any& left, const Any& rhs) const {
return dyn_cast<U>(&left) == dyn_cast<U>(&rhs);
}
bool operator==(const Any& rhs) const override {
return rhs.is(typeid(T)) && equal<T>(*this, rhs);
}
};
template<typename T>
static T &dyn_cast(Any* obj) {
if (obj == nullptr)
THROW_IE_EXCEPTION << "Parameter is empty!";
return dynamic_cast<RealData<T>&>(*obj).get();
}
template<typename T>
static const T &dyn_cast(const Any* obj) {
if (obj == nullptr)
THROW_IE_EXCEPTION << "Parameter is empty!";
return dynamic_cast<const RealData<T> &>(*obj).get();
}
Any *ptr = nullptr;
};
} // namespace InferenceEngine