00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00036
00037
00038
00039
00040
00041
00042
00043
00044
00045
00046
00047 #ifndef __visp_tracker__MOVINGEDGECONFIG_H__
00048 #define __visp_tracker__MOVINGEDGECONFIG_H__
00049
00050 #include <dynamic_reconfigure/config_tools.h>
00051 #include <limits>
00052 #include <ros/node_handle.h>
00053 #include <dynamic_reconfigure/ConfigDescription.h>
00054 #include <dynamic_reconfigure/ParamDescription.h>
00055 #include <dynamic_reconfigure/config_init_mutex.h>
00056
00057 namespace visp_tracker
00058 {
00059 class MovingEdgeConfigStatics;
00060
00061 class MovingEdgeConfig
00062 {
00063 public:
00064 class AbstractParamDescription : public dynamic_reconfigure::ParamDescription
00065 {
00066 public:
00067 AbstractParamDescription(std::string n, std::string t, uint32_t l,
00068 std::string d, std::string e)
00069 {
00070 name = n;
00071 type = t;
00072 level = l;
00073 description = d;
00074 edit_method = e;
00075 }
00076
00077 virtual void clamp(MovingEdgeConfig &config, const MovingEdgeConfig &max, const MovingEdgeConfig &min) const = 0;
00078 virtual void calcLevel(uint32_t &level, const MovingEdgeConfig &config1, const MovingEdgeConfig &config2) const = 0;
00079 virtual void fromServer(const ros::NodeHandle &nh, MovingEdgeConfig &config) const = 0;
00080 virtual void toServer(const ros::NodeHandle &nh, const MovingEdgeConfig &config) const = 0;
00081 virtual bool fromMessage(const dynamic_reconfigure::Config &msg, MovingEdgeConfig &config) const = 0;
00082 virtual void toMessage(dynamic_reconfigure::Config &msg, const MovingEdgeConfig &config) const = 0;
00083 };
00084
00085 typedef boost::shared_ptr<AbstractParamDescription> AbstractParamDescriptionPtr;
00086 typedef boost::shared_ptr<const AbstractParamDescription> AbstractParamDescriptionConstPtr;
00087
00088 template <class T>
00089 class ParamDescription : public AbstractParamDescription
00090 {
00091 public:
00092 ParamDescription(std::string name, std::string type, uint32_t level,
00093 std::string description, std::string edit_method, T MovingEdgeConfig::* f) :
00094 AbstractParamDescription(name, type, level, description, edit_method),
00095 field(f)
00096 {}
00097
00098 T (MovingEdgeConfig::* field);
00099
00100 virtual void clamp(MovingEdgeConfig &config, const MovingEdgeConfig &max, const MovingEdgeConfig &min) const
00101 {
00102 if (config.*field > max.*field)
00103 config.*field = max.*field;
00104
00105 if (config.*field < min.*field)
00106 config.*field = min.*field;
00107 }
00108
00109 virtual void calcLevel(uint32_t &comb_level, const MovingEdgeConfig &config1, const MovingEdgeConfig &config2) const
00110 {
00111 if (config1.*field != config2.*field)
00112 comb_level |= level;
00113 }
00114
00115 virtual void fromServer(const ros::NodeHandle &nh, MovingEdgeConfig &config) const
00116 {
00117 nh.getParam(name, config.*field);
00118 }
00119
00120 virtual void toServer(const ros::NodeHandle &nh, const MovingEdgeConfig &config) const
00121 {
00122 nh.setParam(name, config.*field);
00123 }
00124
00125 virtual bool fromMessage(const dynamic_reconfigure::Config &msg, MovingEdgeConfig &config) const
00126 {
00127 return dynamic_reconfigure::ConfigTools::getParameter(msg, name, config.*field);
00128 }
00129
00130 virtual void toMessage(dynamic_reconfigure::Config &msg, const MovingEdgeConfig &config) const
00131 {
00132 dynamic_reconfigure::ConfigTools::appendParameter(msg, name, config.*field);
00133 }
00134 };
00135
00136
00137 int mask_size;
00138
00139 int n_mask;
00140
00141 int range;
00142
00143 double threshold;
00144
00145 double mu1;
00146
00147 double mu2;
00148
00149 double sample_step;
00150
00151 int ntotal_sample;
00152
00153 int strip;
00154
00155 double min_samplestep;
00156
00157 double aberration;
00158
00159 double init_aberration;
00160
00161 double lambda;
00162
00163 double first_threshold;
00164
00165
00166 bool __fromMessage__(dynamic_reconfigure::Config &msg)
00167 {
00168 const std::vector<AbstractParamDescriptionConstPtr> &__param_descriptions__ = __getParamDescriptions__();
00169 int count = 0;
00170 for (std::vector<AbstractParamDescriptionConstPtr>::const_iterator i = __param_descriptions__.begin(); i != __param_descriptions__.end(); i++)
00171 if ((*i)->fromMessage(msg, *this))
00172 count++;
00173 if (count != dynamic_reconfigure::ConfigTools::size(msg))
00174 {
00175 ROS_ERROR("MovingEdgeConfig::__fromMessage__ called with an unexpected parameter.");
00176 ROS_ERROR("Booleans:");
00177 for (unsigned int i = 0; i < msg.bools.size(); i++)
00178 ROS_ERROR(" %s", msg.bools[i].name.c_str());
00179 ROS_ERROR("Integers:");
00180 for (unsigned int i = 0; i < msg.ints.size(); i++)
00181 ROS_ERROR(" %s", msg.ints[i].name.c_str());
00182 ROS_ERROR("Doubles:");
00183 for (unsigned int i = 0; i < msg.doubles.size(); i++)
00184 ROS_ERROR(" %s", msg.doubles[i].name.c_str());
00185 ROS_ERROR("Strings:");
00186 for (unsigned int i = 0; i < msg.strs.size(); i++)
00187 ROS_ERROR(" %s", msg.strs[i].name.c_str());
00188
00189
00190 return false;
00191 }
00192 return true;
00193 }
00194
00195
00196
00197 void __toMessage__(dynamic_reconfigure::Config &msg, const std::vector<AbstractParamDescriptionConstPtr> &__param_descriptions__) const
00198 {
00199 dynamic_reconfigure::ConfigTools::clear(msg);
00200 for (std::vector<AbstractParamDescriptionConstPtr>::const_iterator i = __param_descriptions__.begin(); i != __param_descriptions__.end(); i++)
00201 (*i)->toMessage(msg, *this);
00202 }
00203
00204 void __toMessage__(dynamic_reconfigure::Config &msg) const
00205 {
00206 const std::vector<AbstractParamDescriptionConstPtr> &__param_descriptions__ = __getParamDescriptions__();
00207 __toMessage__(msg, __param_descriptions__);
00208 }
00209
00210 void __toServer__(const ros::NodeHandle &nh) const
00211 {
00212 const std::vector<AbstractParamDescriptionConstPtr> &__param_descriptions__ = __getParamDescriptions__();
00213 for (std::vector<AbstractParamDescriptionConstPtr>::const_iterator i = __param_descriptions__.begin(); i != __param_descriptions__.end(); i++)
00214 (*i)->toServer(nh, *this);
00215 }
00216
00217 void __fromServer__(const ros::NodeHandle &nh)
00218 {
00219 const std::vector<AbstractParamDescriptionConstPtr> &__param_descriptions__ = __getParamDescriptions__();
00220 for (std::vector<AbstractParamDescriptionConstPtr>::const_iterator i = __param_descriptions__.begin(); i != __param_descriptions__.end(); i++)
00221 (*i)->fromServer(nh, *this);
00222 }
00223
00224 void __clamp__()
00225 {
00226 const std::vector<AbstractParamDescriptionConstPtr> &__param_descriptions__ = __getParamDescriptions__();
00227 const MovingEdgeConfig &__max__ = __getMax__();
00228 const MovingEdgeConfig &__min__ = __getMin__();
00229 for (std::vector<AbstractParamDescriptionConstPtr>::const_iterator i = __param_descriptions__.begin(); i != __param_descriptions__.end(); i++)
00230 (*i)->clamp(*this, __max__, __min__);
00231 }
00232
00233 uint32_t __level__(const MovingEdgeConfig &config) const
00234 {
00235 const std::vector<AbstractParamDescriptionConstPtr> &__param_descriptions__ = __getParamDescriptions__();
00236 uint32_t level = 0;
00237 for (std::vector<AbstractParamDescriptionConstPtr>::const_iterator i = __param_descriptions__.begin(); i != __param_descriptions__.end(); i++)
00238 (*i)->calcLevel(level, config, *this);
00239 return level;
00240 }
00241
00242 static const dynamic_reconfigure::ConfigDescription &__getDescriptionMessage__();
00243 static const MovingEdgeConfig &__getDefault__();
00244 static const MovingEdgeConfig &__getMax__();
00245 static const MovingEdgeConfig &__getMin__();
00246 static const std::vector<AbstractParamDescriptionConstPtr> &__getParamDescriptions__();
00247
00248 private:
00249 static const MovingEdgeConfigStatics *__get_statics__();
00250 };
00251
00252 template <>
00253 inline void MovingEdgeConfig::ParamDescription<std::string>::clamp(MovingEdgeConfig &config, const MovingEdgeConfig &max, const MovingEdgeConfig &min) const
00254 {
00255 return;
00256 }
00257
00258 class MovingEdgeConfigStatics
00259 {
00260 friend class MovingEdgeConfig;
00261
00262 MovingEdgeConfigStatics()
00263 {
00264
00265 __min__.mask_size = 0;
00266
00267 __max__.mask_size = 15;
00268
00269 __default__.mask_size = 7;
00270
00271 __param_descriptions__.push_back(MovingEdgeConfig::AbstractParamDescriptionConstPtr(new MovingEdgeConfig::ParamDescription<int>("mask_size", "int", 0, "mask size", "", &MovingEdgeConfig::mask_size)));
00272
00273 __min__.n_mask = 0;
00274
00275 __max__.n_mask = 500;
00276
00277 __default__.n_mask = 180;
00278
00279 __param_descriptions__.push_back(MovingEdgeConfig::AbstractParamDescriptionConstPtr(new MovingEdgeConfig::ParamDescription<int>("n_mask", "int", 0, "number of masks", "", &MovingEdgeConfig::n_mask)));
00280
00281 __min__.range = 0;
00282
00283 __max__.range = 50;
00284
00285 __default__.range = 5;
00286
00287 __param_descriptions__.push_back(MovingEdgeConfig::AbstractParamDescriptionConstPtr(new MovingEdgeConfig::ParamDescription<int>("range", "int", 0, "range", "", &MovingEdgeConfig::range)));
00288
00289 __min__.threshold = 0.0;
00290
00291 __max__.threshold = 5000.0;
00292
00293 __default__.threshold = 2000.0;
00294
00295 __param_descriptions__.push_back(MovingEdgeConfig::AbstractParamDescriptionConstPtr(new MovingEdgeConfig::ParamDescription<double>("threshold", "double", 0, "threshold", "", &MovingEdgeConfig::threshold)));
00296
00297 __min__.mu1 = 0.0;
00298
00299 __max__.mu1 = 1.0;
00300
00301 __default__.mu1 = 0.5;
00302
00303 __param_descriptions__.push_back(MovingEdgeConfig::AbstractParamDescriptionConstPtr(new MovingEdgeConfig::ParamDescription<double>("mu1", "double", 0, "contrast continuity (mu1)", "", &MovingEdgeConfig::mu1)));
00304
00305 __min__.mu2 = 0.0;
00306
00307 __max__.mu2 = 1.0;
00308
00309 __default__.mu2 = 0.5;
00310
00311 __param_descriptions__.push_back(MovingEdgeConfig::AbstractParamDescriptionConstPtr(new MovingEdgeConfig::ParamDescription<double>("mu2", "double", 0, "contrast continuity (mu2)", "", &MovingEdgeConfig::mu2)));
00312
00313 __min__.sample_step = 0.0;
00314
00315 __max__.sample_step = 50.0;
00316
00317 __default__.sample_step = 1.0;
00318
00319 __param_descriptions__.push_back(MovingEdgeConfig::AbstractParamDescriptionConstPtr(new MovingEdgeConfig::ParamDescription<double>("sample_step", "double", 0, "sample step", "", &MovingEdgeConfig::sample_step)));
00320
00321 __min__.ntotal_sample = 0;
00322
00323 __max__.ntotal_sample = 10000;
00324
00325 __default__.ntotal_sample = 1000;
00326
00327 __param_descriptions__.push_back(MovingEdgeConfig::AbstractParamDescriptionConstPtr(new MovingEdgeConfig::ParamDescription<int>("ntotal_sample", "int", 0, "total samples number", "", &MovingEdgeConfig::ntotal_sample)));
00328
00329 __min__.strip = 0;
00330
00331 __max__.strip = 10;
00332
00333 __default__.strip = 2;
00334
00335 __param_descriptions__.push_back(MovingEdgeConfig::AbstractParamDescriptionConstPtr(new MovingEdgeConfig::ParamDescription<int>("strip", "int", 0, "strip", "", &MovingEdgeConfig::strip)));
00336
00337 __min__.min_samplestep = 0.0;
00338
00339 __max__.min_samplestep = 50.0;
00340
00341 __default__.min_samplestep = 4.0;
00342
00343 __param_descriptions__.push_back(MovingEdgeConfig::AbstractParamDescriptionConstPtr(new MovingEdgeConfig::ParamDescription<double>("min_samplestep", "double", 0, "min sample step", "", &MovingEdgeConfig::min_samplestep)));
00344
00345 __min__.aberration = 0.0;
00346
00347 __max__.aberration = 10.0;
00348
00349 __default__.aberration = 2.0;
00350
00351 __param_descriptions__.push_back(MovingEdgeConfig::AbstractParamDescriptionConstPtr(new MovingEdgeConfig::ParamDescription<double>("aberration", "double", 0, "aberration", "", &MovingEdgeConfig::aberration)));
00352
00353 __min__.init_aberration = 0.0;
00354
00355 __max__.init_aberration = 10.0;
00356
00357 __default__.init_aberration = 5.0;
00358
00359 __param_descriptions__.push_back(MovingEdgeConfig::AbstractParamDescriptionConstPtr(new MovingEdgeConfig::ParamDescription<double>("init_aberration", "double", 0, "init aberration", "", &MovingEdgeConfig::init_aberration)));
00360
00361 __min__.lambda = 0.0;
00362
00363 __max__.lambda = 1.0;
00364
00365 __default__.lambda = 1.0;
00366
00367 __param_descriptions__.push_back(MovingEdgeConfig::AbstractParamDescriptionConstPtr(new MovingEdgeConfig::ParamDescription<double>("lambda", "double", 0, "lambda (mbt)", "", &MovingEdgeConfig::lambda)));
00368
00369 __min__.first_threshold = 0.0;
00370
00371 __max__.first_threshold = 1.0;
00372
00373 __default__.first_threshold = 0.4;
00374
00375 __param_descriptions__.push_back(MovingEdgeConfig::AbstractParamDescriptionConstPtr(new MovingEdgeConfig::ParamDescription<double>("first_threshold", "double", 0, "init threshold (mbt)", "", &MovingEdgeConfig::first_threshold)));
00376
00377
00378 for (std::vector<MovingEdgeConfig::AbstractParamDescriptionConstPtr>::const_iterator i = __param_descriptions__.begin(); i != __param_descriptions__.end(); i++)
00379 __description_message__.parameters.push_back(**i);
00380 __max__.__toMessage__(__description_message__.max, __param_descriptions__);
00381 __min__.__toMessage__(__description_message__.min, __param_descriptions__);
00382 __default__.__toMessage__(__description_message__.dflt, __param_descriptions__);
00383 }
00384 std::vector<MovingEdgeConfig::AbstractParamDescriptionConstPtr> __param_descriptions__;
00385 MovingEdgeConfig __max__;
00386 MovingEdgeConfig __min__;
00387 MovingEdgeConfig __default__;
00388 dynamic_reconfigure::ConfigDescription __description_message__;
00389 static const MovingEdgeConfigStatics *get_instance()
00390 {
00391
00392
00393
00394
00395 static MovingEdgeConfigStatics instance;
00396 return &instance;
00397 }
00398 };
00399
00400 inline const dynamic_reconfigure::ConfigDescription &MovingEdgeConfig::__getDescriptionMessage__()
00401 {
00402 return __get_statics__()->__description_message__;
00403 }
00404
00405 inline const MovingEdgeConfig &MovingEdgeConfig::__getDefault__()
00406 {
00407 return __get_statics__()->__default__;
00408 }
00409
00410 inline const MovingEdgeConfig &MovingEdgeConfig::__getMax__()
00411 {
00412 return __get_statics__()->__max__;
00413 }
00414
00415 inline const MovingEdgeConfig &MovingEdgeConfig::__getMin__()
00416 {
00417 return __get_statics__()->__min__;
00418 }
00419
00420 inline const std::vector<MovingEdgeConfig::AbstractParamDescriptionConstPtr> &MovingEdgeConfig::__getParamDescriptions__()
00421 {
00422 return __get_statics__()->__param_descriptions__;
00423 }
00424
00425 inline const MovingEdgeConfigStatics *MovingEdgeConfig::__get_statics__()
00426 {
00427 const static MovingEdgeConfigStatics *statics;
00428
00429 if (statics)
00430 return statics;
00431
00432 boost::mutex::scoped_lock lock(dynamic_reconfigure::__init_mutex__);
00433
00434 if (statics)
00435 return statics;
00436
00437 statics = MovingEdgeConfigStatics::get_instance();
00438
00439 return statics;
00440 }
00441
00442
00443 }
00444
00445 #endif // __MOVINGEDGERECONFIGURATOR_H__