From 04952a64019689ad1a688587f09298048422a2a5 Mon Sep 17 00:00:00 2001 From: Popov Dmitriy Ivanovich Date: Wed, 29 Nov 2023 19:27:08 +0300 Subject: [PATCH] Check if option set before returning option to python --- src/core/algorithms/algorithm.h | 8 ++-- src/core/config/ioption.h | 2 +- src/core/config/option.h | 3 +- src/python_bindings/opt_to_str.cpp | 75 +++++++++++++----------------- src/python_bindings/opt_to_str.h | 10 ++-- src/python_bindings/py_algorithm.h | 4 +- 6 files changed, 48 insertions(+), 54 deletions(-) diff --git a/src/core/algorithms/algorithm.h b/src/core/algorithms/algorithm.h index e6da6e93e3..6e30f8b4ff 100644 --- a/src/core/algorithms/algorithm.h +++ b/src/core/algorithms/algorithm.h @@ -106,10 +106,12 @@ class Algorithm { [[nodiscard]] std::unordered_set GetPossibleOptions() const; [[nodiscard]] std::string_view GetDescription(std::string_view option_name) const; - std::unordered_map > GetOptValues() { - std::unordered_map > opt_values; + std::unordered_map> GetOptValues() { + std::unordered_map> opt_values; for (auto& i : possible_options_) { - opt_values[i.second->GetName()] = i.second->GetOptValue(); + if (i.second->IsSet()) { + opt_values[i.second->GetName()] = i.second->GetOptValue(); + } } return opt_values; } diff --git a/src/core/config/ioption.h b/src/core/config/ioption.h index b303571613..5b5de0fee5 100644 --- a/src/core/config/ioption.h +++ b/src/core/config/ioption.h @@ -7,7 +7,7 @@ #include "boost/any.hpp" namespace config { -struct OptValue{ +struct OptValue { std::type_index type; boost::any value; }; diff --git a/src/core/config/option.h b/src/core/config/option.h index e0fdefd26b..8c93d0f4e0 100644 --- a/src/core/config/option.h +++ b/src/core/config/option.h @@ -91,7 +91,8 @@ class Option : public IOption { } std::unique_ptr GetOptValue() override { - return std::make_unique(OptValue{std::type_index(typeid(T)),boost::any(*value_ptr_)}); + return std::make_unique( + OptValue{std::type_index(typeid(T)), boost::any(*value_ptr_)}); } private: diff --git a/src/python_bindings/opt_to_str.cpp b/src/python_bindings/opt_to_str.cpp index f3d88ff287..b408dc342c 100644 --- a/src/python_bindings/opt_to_str.cpp +++ b/src/python_bindings/opt_to_str.cpp @@ -5,57 +5,48 @@ using ConvFunction = std::function; template std::pair normal_conv_pair{ - std::type_index(typeid(T)), - [](boost::any value) { return py::cast(boost::any_cast(value)); } -}; + std::type_index(typeid(T)), + [](boost::any value) { return py::cast(boost::any_cast(value)); }}; template <> std::pair normal_conv_pair{ - std::type_index(typeid(bool)), - [](boost::any value) { return py::cast(boost::any_cast(value)); } -}; + std::type_index(typeid(bool)), + [](boost::any value) { return py::cast(boost::any_cast(value)); }}; template <> std::pair normal_conv_pair{ - std::type_index(typeid(config::IndicesType)), - [](boost::any value) { - auto opt_value = (boost::any_cast(value)); - return py::cast(opt_value); - } -}; + std::type_index(typeid(config::IndicesType)), [](boost::any value) { + auto opt_value = (boost::any_cast(value)); + return py::cast(opt_value); + }}; template <> std::pair normal_conv_pair{ - std::type_index(typeid(algos::metric::MetricAlgo)), - [](boost::any value){ - auto opt_value = boost::any_cast(value); - return py::cast(opt_value._to_string()); - } -}; + std::type_index(typeid(algos::metric::MetricAlgo)), [](boost::any value) { + auto opt_value = boost::any_cast(value); + return py::cast(opt_value._to_string()); + }}; template <> std::pair normal_conv_pair{ - std::type_index(typeid(algos::metric::Metric)), - [](boost::any value){ - auto opt_value = boost::any_cast(value); - return py::cast(opt_value._to_string()); - } -}; + std::type_index(typeid(algos::metric::Metric)), [](boost::any value) { + auto opt_value = boost::any_cast(value); + return py::cast(opt_value._to_string()); + }}; const std::unordered_map converters{ - normal_conv_pair, - normal_conv_pair, - normal_conv_pair, - normal_conv_pair, - normal_conv_pair, - normal_conv_pair, - normal_conv_pair, - normal_conv_pair, - normal_conv_pair, - normal_conv_pair, - normal_conv_pair -}; -} // namespace + normal_conv_pair, + normal_conv_pair, + normal_conv_pair, + normal_conv_pair, + normal_conv_pair, + normal_conv_pair, + normal_conv_pair, + normal_conv_pair, + normal_conv_pair, + normal_conv_pair, + normal_conv_pair}; +} // namespace -namespace python_bindings{ - py::object opt_to_str(std::type_index type, boost::any val) { - return converters.at(type)(val); - } -} // namespace python_bindings \ No newline at end of file +namespace python_bindings { +py::object opt_to_str(std::type_index type, boost::any val) { + return converters.at(type)(val); +} +} // namespace python_bindings diff --git a/src/python_bindings/opt_to_str.h b/src/python_bindings/opt_to_str.h index 5e200d2137..b76a6282d4 100644 --- a/src/python_bindings/opt_to_str.h +++ b/src/python_bindings/opt_to_str.h @@ -14,12 +14,12 @@ #include "config/error/type.h" #include "config/indices/type.h" #include "config/max_lhs/type.h" +#include "config/names.h" #include "config/tabular_data/input_table_type.h" #include "config/thread_number/type.h" -#include "config/names.h" #include "model/types/types.h" -namespace python_bindings{ - namespace py = pybind11; - py::object opt_to_str(std::type_index type, boost::any val); -} // namespace python_bindings \ No newline at end of file +namespace python_bindings { +namespace py = pybind11; +py::object opt_to_str(std::type_index type, boost::any val); +} // namespace python_bindings diff --git a/src/python_bindings/py_algorithm.h b/src/python_bindings/py_algorithm.h index dc96b2b626..6a16b4477a 100644 --- a/src/python_bindings/py_algorithm.h +++ b/src/python_bindings/py_algorithm.h @@ -14,9 +14,9 @@ #include "config/error/type.h" #include "config/indices/type.h" #include "config/max_lhs/type.h" +#include "config/names.h" #include "config/tabular_data/input_table_type.h" #include "config/thread_number/type.h" -#include "config/names.h" #include "model/types/types.h" #include "opt_to_str.h" @@ -61,7 +61,7 @@ class PyAlgorithmBase { std::unordered_map GetOpts() { auto opt_ = algorithm_->GetOptValues(); std::unordered_map res; - for (const auto& [name,value] : opt_) { + for (const auto& [name, value] : opt_) { if (name == config::names::kTable || name == config::names::kInputFormat) { continue; }