diff --git a/README.md b/README.md index e814925..c7d6417 100644 --- a/README.md +++ b/README.md @@ -4,6 +4,7 @@ Oh-My-LOAM is a ROS-free implementation of LOAM (J. Zhang and S. Singh. LOAM: Li Comparing with A-LOAM, this implementation has following features: +- it's ROS-free - it's more readable and easier to understand/modify # Dependences diff --git a/common/registerer/registerer.cc b/common/registerer/registerer.cc deleted file mode 100644 index e69de29..0000000 diff --git a/common/registerer/registerer.h b/common/registerer/registerer.h index ccf8205..20919d5 100644 --- a/common/registerer/registerer.h +++ b/common/registerer/registerer.h @@ -5,15 +5,65 @@ #include #include "common/log/log.h" -#include "common/macro/macros.h" + +namespace common { template class AbstractFactory { + public: virtual ~AbstractFactory() = default; - virtual std::shared_ptr Create() = 0; + virtual BaseClass *Create() = 0; }; template -class ConcreteFactory { - virtual std::shared_ptr Create() = 0; -}; \ No newline at end of file +class ConcreteFactory : public AbstractFactory { + public: + BaseClass *Create() override { + return new DerivedClass; + } +}; + +template +inline auto &GetFactoryMap() { + static std::map>> map; + return map; +} + +template +class Registerer { + public: + template + static void Register(const std::string &derived_class_name) { + static_assert(std::is_base_of::value, ""); + auto &factory_map = GetFactoryMap(); + if (factory_map.find(derived_class_name) != factory_map.end()) { + return; + } + factory_map[derived_class_name].reset( + new ConcreteFactory); + } + + static BaseClass *NewInstance(const std::string &derived_class_name) { + auto &factory_map = GetFactoryMap(); + auto iter = factory_map.find(derived_class_name); + if (iter == factory_map.end()) { + AFATAL << "Class not registered: " << derived_class_name << "."; + return nullptr; + } + return iter->second->Create(); + } + + static bool IsRegistered(const std::string &derived_class_name) { + auto &factory_map = GetFactoryMap(); + return factory_map.find(derived_class_name) != factory_map.end(); + } +}; + +} // namespace common + +#define REGISTER_CLASS(base_class, derived_class) \ + namespace { \ + __attribute__((constructor)) void Register##derived_class() { \ + ::common::Registerer::Register(#derived_class); \ + } \ + } // namespace \ No newline at end of file diff --git a/oh_my_loam/configs/config.yaml b/oh_my_loam/configs/config.yaml index 147f537..93f46c7 100644 --- a/oh_my_loam/configs/config.yaml +++ b/oh_my_loam/configs/config.yaml @@ -1,5 +1,5 @@ # global configs -lidar: VPL16 +lidar: VLP16 log_to_file: false log_path: /data/log/oh_my_loam vis: true diff --git a/oh_my_loam/extractor/extractor_VLP16.cc b/oh_my_loam/extractor/extractor_VLP16.cc index dc419d7..171f8ca 100644 --- a/oh_my_loam/extractor/extractor_VLP16.cc +++ b/oh_my_loam/extractor/extractor_VLP16.cc @@ -1,6 +1,7 @@ #include "extractor_VLP16.h" #include "common/math/math_utils.h" +#include "common/registerer/registerer.h" namespace oh_my_loam { @@ -10,4 +11,6 @@ int ExtractorVLP16::GetScanID(const common::Point &pt) const { return static_cast(std::round(theta / 2.0) + 1.e-5); }; +REGISTER_CLASS(Extractor, ExtractorVLP16) + } // namespace oh_my_loam \ No newline at end of file diff --git a/oh_my_loam/oh_my_loam.cc b/oh_my_loam/oh_my_loam.cc index 4a8238c..09278a8 100644 --- a/oh_my_loam/oh_my_loam.cc +++ b/oh_my_loam/oh_my_loam.cc @@ -2,9 +2,8 @@ #include -#include "common/common.h" #include "common/pcl/pcl_utils.h" -#include "oh_my_loam/extractor/extractor_VLP16.h" +#include "common/registerer/registerer.h" namespace oh_my_loam { @@ -15,7 +14,8 @@ const double kPointMinDist = 0.5; bool OhMyLoam::Init() { config_ = common::YAMLConfig::Instance()->config(); is_vis_ = config_["vis"].as(); - extractor_.reset(new ExtractorVLP16); + extractor_.reset(common::Registerer::NewInstance( + "Extractor" + config_["lidar"].as())); if (!extractor_->Init()) { AERROR << "Failed to initialize extractor"; return false;