RangeLayerConfig.h 27 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571
  1. //#line 2 "/opt/ros/melodic/share/dynamic_reconfigure/cmake/../templates/ConfigType.h.template"
  2. // *********************************************************
  3. //
  4. // File autogenerated for the costmap_2d package
  5. // by the dynamic_reconfigure package.
  6. // Please do not edit.
  7. //
  8. // ********************************************************/
  9. #ifndef __costmap_2d__RANGELAYERCONFIG_H__
  10. #define __costmap_2d__RANGELAYERCONFIG_H__
  11. #if __cplusplus >= 201103L
  12. #define DYNAMIC_RECONFIGURE_FINAL final
  13. #else
  14. #define DYNAMIC_RECONFIGURE_FINAL
  15. #endif
  16. #include <dynamic_reconfigure/config_tools.h>
  17. #include <limits>
  18. #include <ros/node_handle.h>
  19. #include <dynamic_reconfigure/ConfigDescription.h>
  20. #include <dynamic_reconfigure/ParamDescription.h>
  21. #include <dynamic_reconfigure/Group.h>
  22. #include <dynamic_reconfigure/config_init_mutex.h>
  23. #include <boost/any.hpp>
  24. namespace costmap_2d
  25. {
  26. class RangeLayerConfigStatics;
  27. class RangeLayerConfig
  28. {
  29. public:
  30. class AbstractParamDescription : public dynamic_reconfigure::ParamDescription
  31. {
  32. public:
  33. AbstractParamDescription(std::string n, std::string t, uint32_t l,
  34. std::string d, std::string e)
  35. {
  36. name = n;
  37. type = t;
  38. level = l;
  39. description = d;
  40. edit_method = e;
  41. }
  42. virtual void clamp(RangeLayerConfig &config, const RangeLayerConfig &max, const RangeLayerConfig &min) const = 0;
  43. virtual void calcLevel(uint32_t &level, const RangeLayerConfig &config1, const RangeLayerConfig &config2) const = 0;
  44. virtual void fromServer(const ros::NodeHandle &nh, RangeLayerConfig &config) const = 0;
  45. virtual void toServer(const ros::NodeHandle &nh, const RangeLayerConfig &config) const = 0;
  46. virtual bool fromMessage(const dynamic_reconfigure::Config &msg, RangeLayerConfig &config) const = 0;
  47. virtual void toMessage(dynamic_reconfigure::Config &msg, const RangeLayerConfig &config) const = 0;
  48. virtual void getValue(const RangeLayerConfig &config, boost::any &val) const = 0;
  49. };
  50. typedef boost::shared_ptr<AbstractParamDescription> AbstractParamDescriptionPtr;
  51. typedef boost::shared_ptr<const AbstractParamDescription> AbstractParamDescriptionConstPtr;
  52. // Final keyword added to class because it has virtual methods and inherits
  53. // from a class with a non-virtual destructor.
  54. template <class T>
  55. class ParamDescription DYNAMIC_RECONFIGURE_FINAL : public AbstractParamDescription
  56. {
  57. public:
  58. ParamDescription(std::string a_name, std::string a_type, uint32_t a_level,
  59. std::string a_description, std::string a_edit_method, T RangeLayerConfig::* a_f) :
  60. AbstractParamDescription(a_name, a_type, a_level, a_description, a_edit_method),
  61. field(a_f)
  62. {}
  63. T RangeLayerConfig::* field;
  64. virtual void clamp(RangeLayerConfig &config, const RangeLayerConfig &max, const RangeLayerConfig &min) const
  65. {
  66. if (config.*field > max.*field)
  67. config.*field = max.*field;
  68. if (config.*field < min.*field)
  69. config.*field = min.*field;
  70. }
  71. virtual void calcLevel(uint32_t &comb_level, const RangeLayerConfig &config1, const RangeLayerConfig &config2) const
  72. {
  73. if (config1.*field != config2.*field)
  74. comb_level |= level;
  75. }
  76. virtual void fromServer(const ros::NodeHandle &nh, RangeLayerConfig &config) const
  77. {
  78. nh.getParam(name, config.*field);
  79. }
  80. virtual void toServer(const ros::NodeHandle &nh, const RangeLayerConfig &config) const
  81. {
  82. nh.setParam(name, config.*field);
  83. }
  84. virtual bool fromMessage(const dynamic_reconfigure::Config &msg, RangeLayerConfig &config) const
  85. {
  86. return dynamic_reconfigure::ConfigTools::getParameter(msg, name, config.*field);
  87. }
  88. virtual void toMessage(dynamic_reconfigure::Config &msg, const RangeLayerConfig &config) const
  89. {
  90. dynamic_reconfigure::ConfigTools::appendParameter(msg, name, config.*field);
  91. }
  92. virtual void getValue(const RangeLayerConfig &config, boost::any &val) const
  93. {
  94. val = config.*field;
  95. }
  96. };
  97. class AbstractGroupDescription : public dynamic_reconfigure::Group
  98. {
  99. public:
  100. AbstractGroupDescription(std::string n, std::string t, int p, int i, bool s)
  101. {
  102. name = n;
  103. type = t;
  104. parent = p;
  105. state = s;
  106. id = i;
  107. }
  108. std::vector<AbstractParamDescriptionConstPtr> abstract_parameters;
  109. bool state;
  110. virtual void toMessage(dynamic_reconfigure::Config &msg, const boost::any &config) const = 0;
  111. virtual bool fromMessage(const dynamic_reconfigure::Config &msg, boost::any &config) const =0;
  112. virtual void updateParams(boost::any &cfg, RangeLayerConfig &top) const= 0;
  113. virtual void setInitialState(boost::any &cfg) const = 0;
  114. void convertParams()
  115. {
  116. for(std::vector<AbstractParamDescriptionConstPtr>::const_iterator i = abstract_parameters.begin(); i != abstract_parameters.end(); ++i)
  117. {
  118. parameters.push_back(dynamic_reconfigure::ParamDescription(**i));
  119. }
  120. }
  121. };
  122. typedef boost::shared_ptr<AbstractGroupDescription> AbstractGroupDescriptionPtr;
  123. typedef boost::shared_ptr<const AbstractGroupDescription> AbstractGroupDescriptionConstPtr;
  124. // Final keyword added to class because it has virtual methods and inherits
  125. // from a class with a non-virtual destructor.
  126. template<class T, class PT>
  127. class GroupDescription DYNAMIC_RECONFIGURE_FINAL : public AbstractGroupDescription
  128. {
  129. public:
  130. GroupDescription(std::string a_name, std::string a_type, int a_parent, int a_id, bool a_s, T PT::* a_f) : AbstractGroupDescription(a_name, a_type, a_parent, a_id, a_s), field(a_f)
  131. {
  132. }
  133. GroupDescription(const GroupDescription<T, PT>& g): AbstractGroupDescription(g.name, g.type, g.parent, g.id, g.state), field(g.field), groups(g.groups)
  134. {
  135. parameters = g.parameters;
  136. abstract_parameters = g.abstract_parameters;
  137. }
  138. virtual bool fromMessage(const dynamic_reconfigure::Config &msg, boost::any &cfg) const
  139. {
  140. PT* config = boost::any_cast<PT*>(cfg);
  141. if(!dynamic_reconfigure::ConfigTools::getGroupState(msg, name, (*config).*field))
  142. return false;
  143. for(std::vector<AbstractGroupDescriptionConstPtr>::const_iterator i = groups.begin(); i != groups.end(); ++i)
  144. {
  145. boost::any n = &((*config).*field);
  146. if(!(*i)->fromMessage(msg, n))
  147. return false;
  148. }
  149. return true;
  150. }
  151. virtual void setInitialState(boost::any &cfg) const
  152. {
  153. PT* config = boost::any_cast<PT*>(cfg);
  154. T* group = &((*config).*field);
  155. group->state = state;
  156. for(std::vector<AbstractGroupDescriptionConstPtr>::const_iterator i = groups.begin(); i != groups.end(); ++i)
  157. {
  158. boost::any n = boost::any(&((*config).*field));
  159. (*i)->setInitialState(n);
  160. }
  161. }
  162. virtual void updateParams(boost::any &cfg, RangeLayerConfig &top) const
  163. {
  164. PT* config = boost::any_cast<PT*>(cfg);
  165. T* f = &((*config).*field);
  166. f->setParams(top, abstract_parameters);
  167. for(std::vector<AbstractGroupDescriptionConstPtr>::const_iterator i = groups.begin(); i != groups.end(); ++i)
  168. {
  169. boost::any n = &((*config).*field);
  170. (*i)->updateParams(n, top);
  171. }
  172. }
  173. virtual void toMessage(dynamic_reconfigure::Config &msg, const boost::any &cfg) const
  174. {
  175. const PT config = boost::any_cast<PT>(cfg);
  176. dynamic_reconfigure::ConfigTools::appendGroup<T>(msg, name, id, parent, config.*field);
  177. for(std::vector<AbstractGroupDescriptionConstPtr>::const_iterator i = groups.begin(); i != groups.end(); ++i)
  178. {
  179. (*i)->toMessage(msg, config.*field);
  180. }
  181. }
  182. T PT::* field;
  183. std::vector<RangeLayerConfig::AbstractGroupDescriptionConstPtr> groups;
  184. };
  185. class DEFAULT
  186. {
  187. public:
  188. DEFAULT()
  189. {
  190. state = true;
  191. name = "Default";
  192. }
  193. void setParams(RangeLayerConfig &config, const std::vector<AbstractParamDescriptionConstPtr> params)
  194. {
  195. for (std::vector<AbstractParamDescriptionConstPtr>::const_iterator _i = params.begin(); _i != params.end(); ++_i)
  196. {
  197. boost::any val;
  198. (*_i)->getValue(config, val);
  199. if("enabled"==(*_i)->name){enabled = boost::any_cast<bool>(val);}
  200. if("phi"==(*_i)->name){phi = boost::any_cast<double>(val);}
  201. if("inflate_cone"==(*_i)->name){inflate_cone = boost::any_cast<double>(val);}
  202. if("no_readings_timeout"==(*_i)->name){no_readings_timeout = boost::any_cast<double>(val);}
  203. if("clear_threshold"==(*_i)->name){clear_threshold = boost::any_cast<double>(val);}
  204. if("mark_threshold"==(*_i)->name){mark_threshold = boost::any_cast<double>(val);}
  205. if("clear_on_max_reading"==(*_i)->name){clear_on_max_reading = boost::any_cast<bool>(val);}
  206. }
  207. }
  208. bool enabled;
  209. double phi;
  210. double inflate_cone;
  211. double no_readings_timeout;
  212. double clear_threshold;
  213. double mark_threshold;
  214. bool clear_on_max_reading;
  215. bool state;
  216. std::string name;
  217. }groups;
  218. //#line 291 "/opt/ros/melodic/lib/python2.7/dist-packages/dynamic_reconfigure/parameter_generator_catkin.py"
  219. bool enabled;
  220. //#line 291 "/opt/ros/melodic/lib/python2.7/dist-packages/dynamic_reconfigure/parameter_generator_catkin.py"
  221. double phi;
  222. //#line 291 "/opt/ros/melodic/lib/python2.7/dist-packages/dynamic_reconfigure/parameter_generator_catkin.py"
  223. double inflate_cone;
  224. //#line 291 "/opt/ros/melodic/lib/python2.7/dist-packages/dynamic_reconfigure/parameter_generator_catkin.py"
  225. double no_readings_timeout;
  226. //#line 291 "/opt/ros/melodic/lib/python2.7/dist-packages/dynamic_reconfigure/parameter_generator_catkin.py"
  227. double clear_threshold;
  228. //#line 291 "/opt/ros/melodic/lib/python2.7/dist-packages/dynamic_reconfigure/parameter_generator_catkin.py"
  229. double mark_threshold;
  230. //#line 291 "/opt/ros/melodic/lib/python2.7/dist-packages/dynamic_reconfigure/parameter_generator_catkin.py"
  231. bool clear_on_max_reading;
  232. //#line 228 "/opt/ros/melodic/share/dynamic_reconfigure/cmake/../templates/ConfigType.h.template"
  233. bool __fromMessage__(dynamic_reconfigure::Config &msg)
  234. {
  235. const std::vector<AbstractParamDescriptionConstPtr> &__param_descriptions__ = __getParamDescriptions__();
  236. const std::vector<AbstractGroupDescriptionConstPtr> &__group_descriptions__ = __getGroupDescriptions__();
  237. int count = 0;
  238. for (std::vector<AbstractParamDescriptionConstPtr>::const_iterator i = __param_descriptions__.begin(); i != __param_descriptions__.end(); ++i)
  239. if ((*i)->fromMessage(msg, *this))
  240. count++;
  241. for (std::vector<AbstractGroupDescriptionConstPtr>::const_iterator i = __group_descriptions__.begin(); i != __group_descriptions__.end(); i ++)
  242. {
  243. if ((*i)->id == 0)
  244. {
  245. boost::any n = boost::any(this);
  246. (*i)->updateParams(n, *this);
  247. (*i)->fromMessage(msg, n);
  248. }
  249. }
  250. if (count != dynamic_reconfigure::ConfigTools::size(msg))
  251. {
  252. ROS_ERROR("RangeLayerConfig::__fromMessage__ called with an unexpected parameter.");
  253. ROS_ERROR("Booleans:");
  254. for (unsigned int i = 0; i < msg.bools.size(); i++)
  255. ROS_ERROR(" %s", msg.bools[i].name.c_str());
  256. ROS_ERROR("Integers:");
  257. for (unsigned int i = 0; i < msg.ints.size(); i++)
  258. ROS_ERROR(" %s", msg.ints[i].name.c_str());
  259. ROS_ERROR("Doubles:");
  260. for (unsigned int i = 0; i < msg.doubles.size(); i++)
  261. ROS_ERROR(" %s", msg.doubles[i].name.c_str());
  262. ROS_ERROR("Strings:");
  263. for (unsigned int i = 0; i < msg.strs.size(); i++)
  264. ROS_ERROR(" %s", msg.strs[i].name.c_str());
  265. // @todo Check that there are no duplicates. Make this error more
  266. // explicit.
  267. return false;
  268. }
  269. return true;
  270. }
  271. // This version of __toMessage__ is used during initialization of
  272. // statics when __getParamDescriptions__ can't be called yet.
  273. void __toMessage__(dynamic_reconfigure::Config &msg, const std::vector<AbstractParamDescriptionConstPtr> &__param_descriptions__, const std::vector<AbstractGroupDescriptionConstPtr> &__group_descriptions__) const
  274. {
  275. dynamic_reconfigure::ConfigTools::clear(msg);
  276. for (std::vector<AbstractParamDescriptionConstPtr>::const_iterator i = __param_descriptions__.begin(); i != __param_descriptions__.end(); ++i)
  277. (*i)->toMessage(msg, *this);
  278. for (std::vector<AbstractGroupDescriptionConstPtr>::const_iterator i = __group_descriptions__.begin(); i != __group_descriptions__.end(); ++i)
  279. {
  280. if((*i)->id == 0)
  281. {
  282. (*i)->toMessage(msg, *this);
  283. }
  284. }
  285. }
  286. void __toMessage__(dynamic_reconfigure::Config &msg) const
  287. {
  288. const std::vector<AbstractParamDescriptionConstPtr> &__param_descriptions__ = __getParamDescriptions__();
  289. const std::vector<AbstractGroupDescriptionConstPtr> &__group_descriptions__ = __getGroupDescriptions__();
  290. __toMessage__(msg, __param_descriptions__, __group_descriptions__);
  291. }
  292. void __toServer__(const ros::NodeHandle &nh) const
  293. {
  294. const std::vector<AbstractParamDescriptionConstPtr> &__param_descriptions__ = __getParamDescriptions__();
  295. for (std::vector<AbstractParamDescriptionConstPtr>::const_iterator i = __param_descriptions__.begin(); i != __param_descriptions__.end(); ++i)
  296. (*i)->toServer(nh, *this);
  297. }
  298. void __fromServer__(const ros::NodeHandle &nh)
  299. {
  300. static bool setup=false;
  301. const std::vector<AbstractParamDescriptionConstPtr> &__param_descriptions__ = __getParamDescriptions__();
  302. for (std::vector<AbstractParamDescriptionConstPtr>::const_iterator i = __param_descriptions__.begin(); i != __param_descriptions__.end(); ++i)
  303. (*i)->fromServer(nh, *this);
  304. const std::vector<AbstractGroupDescriptionConstPtr> &__group_descriptions__ = __getGroupDescriptions__();
  305. for (std::vector<AbstractGroupDescriptionConstPtr>::const_iterator i = __group_descriptions__.begin(); i != __group_descriptions__.end(); i++){
  306. if (!setup && (*i)->id == 0) {
  307. setup = true;
  308. boost::any n = boost::any(this);
  309. (*i)->setInitialState(n);
  310. }
  311. }
  312. }
  313. void __clamp__()
  314. {
  315. const std::vector<AbstractParamDescriptionConstPtr> &__param_descriptions__ = __getParamDescriptions__();
  316. const RangeLayerConfig &__max__ = __getMax__();
  317. const RangeLayerConfig &__min__ = __getMin__();
  318. for (std::vector<AbstractParamDescriptionConstPtr>::const_iterator i = __param_descriptions__.begin(); i != __param_descriptions__.end(); ++i)
  319. (*i)->clamp(*this, __max__, __min__);
  320. }
  321. uint32_t __level__(const RangeLayerConfig &config) const
  322. {
  323. const std::vector<AbstractParamDescriptionConstPtr> &__param_descriptions__ = __getParamDescriptions__();
  324. uint32_t level = 0;
  325. for (std::vector<AbstractParamDescriptionConstPtr>::const_iterator i = __param_descriptions__.begin(); i != __param_descriptions__.end(); ++i)
  326. (*i)->calcLevel(level, config, *this);
  327. return level;
  328. }
  329. static const dynamic_reconfigure::ConfigDescription &__getDescriptionMessage__();
  330. static const RangeLayerConfig &__getDefault__();
  331. static const RangeLayerConfig &__getMax__();
  332. static const RangeLayerConfig &__getMin__();
  333. static const std::vector<AbstractParamDescriptionConstPtr> &__getParamDescriptions__();
  334. static const std::vector<AbstractGroupDescriptionConstPtr> &__getGroupDescriptions__();
  335. private:
  336. static const RangeLayerConfigStatics *__get_statics__();
  337. };
  338. template <> // Max and min are ignored for strings.
  339. inline void RangeLayerConfig::ParamDescription<std::string>::clamp(RangeLayerConfig &config, const RangeLayerConfig &max, const RangeLayerConfig &min) const
  340. {
  341. (void) config;
  342. (void) min;
  343. (void) max;
  344. return;
  345. }
  346. class RangeLayerConfigStatics
  347. {
  348. friend class RangeLayerConfig;
  349. RangeLayerConfigStatics()
  350. {
  351. RangeLayerConfig::GroupDescription<RangeLayerConfig::DEFAULT, RangeLayerConfig> Default("Default", "", 0, 0, true, &RangeLayerConfig::groups);
  352. //#line 291 "/opt/ros/melodic/lib/python2.7/dist-packages/dynamic_reconfigure/parameter_generator_catkin.py"
  353. __min__.enabled = 0;
  354. //#line 291 "/opt/ros/melodic/lib/python2.7/dist-packages/dynamic_reconfigure/parameter_generator_catkin.py"
  355. __max__.enabled = 1;
  356. //#line 291 "/opt/ros/melodic/lib/python2.7/dist-packages/dynamic_reconfigure/parameter_generator_catkin.py"
  357. __default__.enabled = 1;
  358. //#line 291 "/opt/ros/melodic/lib/python2.7/dist-packages/dynamic_reconfigure/parameter_generator_catkin.py"
  359. Default.abstract_parameters.push_back(RangeLayerConfig::AbstractParamDescriptionConstPtr(new RangeLayerConfig::ParamDescription<bool>("enabled", "bool", 0, "Whether to apply this plugin or not", "", &RangeLayerConfig::enabled)));
  360. //#line 291 "/opt/ros/melodic/lib/python2.7/dist-packages/dynamic_reconfigure/parameter_generator_catkin.py"
  361. __param_descriptions__.push_back(RangeLayerConfig::AbstractParamDescriptionConstPtr(new RangeLayerConfig::ParamDescription<bool>("enabled", "bool", 0, "Whether to apply this plugin or not", "", &RangeLayerConfig::enabled)));
  362. //#line 291 "/opt/ros/melodic/lib/python2.7/dist-packages/dynamic_reconfigure/parameter_generator_catkin.py"
  363. __min__.phi = -std::numeric_limits<double>::infinity();
  364. //#line 291 "/opt/ros/melodic/lib/python2.7/dist-packages/dynamic_reconfigure/parameter_generator_catkin.py"
  365. __max__.phi = std::numeric_limits<double>::infinity();
  366. //#line 291 "/opt/ros/melodic/lib/python2.7/dist-packages/dynamic_reconfigure/parameter_generator_catkin.py"
  367. __default__.phi = 1.2;
  368. //#line 291 "/opt/ros/melodic/lib/python2.7/dist-packages/dynamic_reconfigure/parameter_generator_catkin.py"
  369. Default.abstract_parameters.push_back(RangeLayerConfig::AbstractParamDescriptionConstPtr(new RangeLayerConfig::ParamDescription<double>("phi", "double", 0, "Phi value", "", &RangeLayerConfig::phi)));
  370. //#line 291 "/opt/ros/melodic/lib/python2.7/dist-packages/dynamic_reconfigure/parameter_generator_catkin.py"
  371. __param_descriptions__.push_back(RangeLayerConfig::AbstractParamDescriptionConstPtr(new RangeLayerConfig::ParamDescription<double>("phi", "double", 0, "Phi value", "", &RangeLayerConfig::phi)));
  372. //#line 291 "/opt/ros/melodic/lib/python2.7/dist-packages/dynamic_reconfigure/parameter_generator_catkin.py"
  373. __min__.inflate_cone = 0.0;
  374. //#line 291 "/opt/ros/melodic/lib/python2.7/dist-packages/dynamic_reconfigure/parameter_generator_catkin.py"
  375. __max__.inflate_cone = 1.0;
  376. //#line 291 "/opt/ros/melodic/lib/python2.7/dist-packages/dynamic_reconfigure/parameter_generator_catkin.py"
  377. __default__.inflate_cone = 1.0;
  378. //#line 291 "/opt/ros/melodic/lib/python2.7/dist-packages/dynamic_reconfigure/parameter_generator_catkin.py"
  379. Default.abstract_parameters.push_back(RangeLayerConfig::AbstractParamDescriptionConstPtr(new RangeLayerConfig::ParamDescription<double>("inflate_cone", "double", 0, "Inflate the triangular area covered by the sensor (percentage)", "", &RangeLayerConfig::inflate_cone)));
  380. //#line 291 "/opt/ros/melodic/lib/python2.7/dist-packages/dynamic_reconfigure/parameter_generator_catkin.py"
  381. __param_descriptions__.push_back(RangeLayerConfig::AbstractParamDescriptionConstPtr(new RangeLayerConfig::ParamDescription<double>("inflate_cone", "double", 0, "Inflate the triangular area covered by the sensor (percentage)", "", &RangeLayerConfig::inflate_cone)));
  382. //#line 291 "/opt/ros/melodic/lib/python2.7/dist-packages/dynamic_reconfigure/parameter_generator_catkin.py"
  383. __min__.no_readings_timeout = 0.0;
  384. //#line 291 "/opt/ros/melodic/lib/python2.7/dist-packages/dynamic_reconfigure/parameter_generator_catkin.py"
  385. __max__.no_readings_timeout = std::numeric_limits<double>::infinity();
  386. //#line 291 "/opt/ros/melodic/lib/python2.7/dist-packages/dynamic_reconfigure/parameter_generator_catkin.py"
  387. __default__.no_readings_timeout = 0.0;
  388. //#line 291 "/opt/ros/melodic/lib/python2.7/dist-packages/dynamic_reconfigure/parameter_generator_catkin.py"
  389. Default.abstract_parameters.push_back(RangeLayerConfig::AbstractParamDescriptionConstPtr(new RangeLayerConfig::ParamDescription<double>("no_readings_timeout", "double", 0, "No Readings Timeout", "", &RangeLayerConfig::no_readings_timeout)));
  390. //#line 291 "/opt/ros/melodic/lib/python2.7/dist-packages/dynamic_reconfigure/parameter_generator_catkin.py"
  391. __param_descriptions__.push_back(RangeLayerConfig::AbstractParamDescriptionConstPtr(new RangeLayerConfig::ParamDescription<double>("no_readings_timeout", "double", 0, "No Readings Timeout", "", &RangeLayerConfig::no_readings_timeout)));
  392. //#line 291 "/opt/ros/melodic/lib/python2.7/dist-packages/dynamic_reconfigure/parameter_generator_catkin.py"
  393. __min__.clear_threshold = 0.0;
  394. //#line 291 "/opt/ros/melodic/lib/python2.7/dist-packages/dynamic_reconfigure/parameter_generator_catkin.py"
  395. __max__.clear_threshold = 1.0;
  396. //#line 291 "/opt/ros/melodic/lib/python2.7/dist-packages/dynamic_reconfigure/parameter_generator_catkin.py"
  397. __default__.clear_threshold = 0.2;
  398. //#line 291 "/opt/ros/melodic/lib/python2.7/dist-packages/dynamic_reconfigure/parameter_generator_catkin.py"
  399. Default.abstract_parameters.push_back(RangeLayerConfig::AbstractParamDescriptionConstPtr(new RangeLayerConfig::ParamDescription<double>("clear_threshold", "double", 0, "Probability below which cells are marked as free", "", &RangeLayerConfig::clear_threshold)));
  400. //#line 291 "/opt/ros/melodic/lib/python2.7/dist-packages/dynamic_reconfigure/parameter_generator_catkin.py"
  401. __param_descriptions__.push_back(RangeLayerConfig::AbstractParamDescriptionConstPtr(new RangeLayerConfig::ParamDescription<double>("clear_threshold", "double", 0, "Probability below which cells are marked as free", "", &RangeLayerConfig::clear_threshold)));
  402. //#line 291 "/opt/ros/melodic/lib/python2.7/dist-packages/dynamic_reconfigure/parameter_generator_catkin.py"
  403. __min__.mark_threshold = 0.0;
  404. //#line 291 "/opt/ros/melodic/lib/python2.7/dist-packages/dynamic_reconfigure/parameter_generator_catkin.py"
  405. __max__.mark_threshold = 1.0;
  406. //#line 291 "/opt/ros/melodic/lib/python2.7/dist-packages/dynamic_reconfigure/parameter_generator_catkin.py"
  407. __default__.mark_threshold = 0.8;
  408. //#line 291 "/opt/ros/melodic/lib/python2.7/dist-packages/dynamic_reconfigure/parameter_generator_catkin.py"
  409. Default.abstract_parameters.push_back(RangeLayerConfig::AbstractParamDescriptionConstPtr(new RangeLayerConfig::ParamDescription<double>("mark_threshold", "double", 0, "Probability above which cells are marked as occupied", "", &RangeLayerConfig::mark_threshold)));
  410. //#line 291 "/opt/ros/melodic/lib/python2.7/dist-packages/dynamic_reconfigure/parameter_generator_catkin.py"
  411. __param_descriptions__.push_back(RangeLayerConfig::AbstractParamDescriptionConstPtr(new RangeLayerConfig::ParamDescription<double>("mark_threshold", "double", 0, "Probability above which cells are marked as occupied", "", &RangeLayerConfig::mark_threshold)));
  412. //#line 291 "/opt/ros/melodic/lib/python2.7/dist-packages/dynamic_reconfigure/parameter_generator_catkin.py"
  413. __min__.clear_on_max_reading = 0;
  414. //#line 291 "/opt/ros/melodic/lib/python2.7/dist-packages/dynamic_reconfigure/parameter_generator_catkin.py"
  415. __max__.clear_on_max_reading = 1;
  416. //#line 291 "/opt/ros/melodic/lib/python2.7/dist-packages/dynamic_reconfigure/parameter_generator_catkin.py"
  417. __default__.clear_on_max_reading = 0;
  418. //#line 291 "/opt/ros/melodic/lib/python2.7/dist-packages/dynamic_reconfigure/parameter_generator_catkin.py"
  419. Default.abstract_parameters.push_back(RangeLayerConfig::AbstractParamDescriptionConstPtr(new RangeLayerConfig::ParamDescription<bool>("clear_on_max_reading", "bool", 0, "Clear on max reading", "", &RangeLayerConfig::clear_on_max_reading)));
  420. //#line 291 "/opt/ros/melodic/lib/python2.7/dist-packages/dynamic_reconfigure/parameter_generator_catkin.py"
  421. __param_descriptions__.push_back(RangeLayerConfig::AbstractParamDescriptionConstPtr(new RangeLayerConfig::ParamDescription<bool>("clear_on_max_reading", "bool", 0, "Clear on max reading", "", &RangeLayerConfig::clear_on_max_reading)));
  422. //#line 246 "/opt/ros/melodic/lib/python2.7/dist-packages/dynamic_reconfigure/parameter_generator_catkin.py"
  423. Default.convertParams();
  424. //#line 246 "/opt/ros/melodic/lib/python2.7/dist-packages/dynamic_reconfigure/parameter_generator_catkin.py"
  425. __group_descriptions__.push_back(RangeLayerConfig::AbstractGroupDescriptionConstPtr(new RangeLayerConfig::GroupDescription<RangeLayerConfig::DEFAULT, RangeLayerConfig>(Default)));
  426. //#line 366 "/opt/ros/melodic/share/dynamic_reconfigure/cmake/../templates/ConfigType.h.template"
  427. for (std::vector<RangeLayerConfig::AbstractGroupDescriptionConstPtr>::const_iterator i = __group_descriptions__.begin(); i != __group_descriptions__.end(); ++i)
  428. {
  429. __description_message__.groups.push_back(**i);
  430. }
  431. __max__.__toMessage__(__description_message__.max, __param_descriptions__, __group_descriptions__);
  432. __min__.__toMessage__(__description_message__.min, __param_descriptions__, __group_descriptions__);
  433. __default__.__toMessage__(__description_message__.dflt, __param_descriptions__, __group_descriptions__);
  434. }
  435. std::vector<RangeLayerConfig::AbstractParamDescriptionConstPtr> __param_descriptions__;
  436. std::vector<RangeLayerConfig::AbstractGroupDescriptionConstPtr> __group_descriptions__;
  437. RangeLayerConfig __max__;
  438. RangeLayerConfig __min__;
  439. RangeLayerConfig __default__;
  440. dynamic_reconfigure::ConfigDescription __description_message__;
  441. static const RangeLayerConfigStatics *get_instance()
  442. {
  443. // Split this off in a separate function because I know that
  444. // instance will get initialized the first time get_instance is
  445. // called, and I am guaranteeing that get_instance gets called at
  446. // most once.
  447. static RangeLayerConfigStatics instance;
  448. return &instance;
  449. }
  450. };
  451. inline const dynamic_reconfigure::ConfigDescription &RangeLayerConfig::__getDescriptionMessage__()
  452. {
  453. return __get_statics__()->__description_message__;
  454. }
  455. inline const RangeLayerConfig &RangeLayerConfig::__getDefault__()
  456. {
  457. return __get_statics__()->__default__;
  458. }
  459. inline const RangeLayerConfig &RangeLayerConfig::__getMax__()
  460. {
  461. return __get_statics__()->__max__;
  462. }
  463. inline const RangeLayerConfig &RangeLayerConfig::__getMin__()
  464. {
  465. return __get_statics__()->__min__;
  466. }
  467. inline const std::vector<RangeLayerConfig::AbstractParamDescriptionConstPtr> &RangeLayerConfig::__getParamDescriptions__()
  468. {
  469. return __get_statics__()->__param_descriptions__;
  470. }
  471. inline const std::vector<RangeLayerConfig::AbstractGroupDescriptionConstPtr> &RangeLayerConfig::__getGroupDescriptions__()
  472. {
  473. return __get_statics__()->__group_descriptions__;
  474. }
  475. inline const RangeLayerConfigStatics *RangeLayerConfig::__get_statics__()
  476. {
  477. const static RangeLayerConfigStatics *statics;
  478. if (statics) // Common case
  479. return statics;
  480. boost::mutex::scoped_lock lock(dynamic_reconfigure::__init_mutex__);
  481. if (statics) // In case we lost a race.
  482. return statics;
  483. statics = RangeLayerConfigStatics::get_instance();
  484. return statics;
  485. }
  486. }
  487. #undef DYNAMIC_RECONFIGURE_FINAL
  488. #endif // __RANGELAYERRECONFIGURATOR_H__