Logo ROOT   6.16/01
Reference Guide
GenAlgoOptions.h
Go to the documentation of this file.
1// @(#)root/mathcore:$Id$
2// Author: L. Moneta Nov 2010
3
4/**********************************************************************
5 * *
6 * Copyright (c) 2010 LCG ROOT Math Team, CERN/PH-SFT *
7 * *
8 * *
9 **********************************************************************/
10
11#ifndef ROOT_Math_GenAlgoOptions
12#define ROOT_Math_GenAlgoOptions
13
14
15#include "Math/IOptions.h"
16
17#include <map>
18#include <iomanip>
19
20namespace ROOT {
21 namespace Math {
22
23//_______________________________________________________________________________
24/**
25 class implementing generic options for a numerical algorithm
26 Just store the options in a map of string-value pairs
27
28 @ingroup NumAlgo
29*/
30class GenAlgoOptions : public IOptions {
31
32public:
33
34 GenAlgoOptions() /* : fExtraOptions(0) */ {}
35
36 virtual ~GenAlgoOptions() {}// { if (fExtraOptions) delete fExtraOptions; }
37
38 // use default copy constructor and assignment operator
39
40 /** generic methods for retrivieng options */
41
42
43 // methods implementing the IOptions interface
44
45 virtual IOptions * Clone() const {
46 return new GenAlgoOptions(*this);
47 }
48
49 // t.b.d need probably to implement in a .cxx file for CINT
50
51
52 virtual bool GetRealValue(const char * name, double & val) const {
53 const double * pval = FindValue(name, fRealOpts);
54 if (!pval) return false;
55 val = *pval;
56 return true;
57 }
58
59 virtual bool GetIntValue(const char * name, int & val) const {
60 const int * pval = FindValue(name, fIntOpts);
61 if (!pval) return false;
62 val = *pval;
63 return true;
64 }
65
66 virtual bool GetNamedValue(const char * name, std::string & val) const {
67 const std::string * pval = FindValue(name, fNamOpts);
68 if (!pval) return false;
69 val = *pval;
70 return true;
71 }
72
73 /// method wich need to be re-implemented by the derived classes
74 virtual void SetRealValue(const char * name, double val) {
76 }
77
78 virtual void SetIntValue(const char * name , int val) {
80 }
81
82 virtual void SetNamedValue(const char * name, const char * val) {
83 InsertValue(name, fNamOpts, std::string(val));
84 }
85
86
87 /// print options
88 virtual void Print(std::ostream & os = std::cout ) const {
89 Print(fNamOpts,os);
90 Print(fIntOpts,os);
91 Print(fRealOpts,os);
92 }
93
94
95 // static methods to retrieve the default options
96
97 // find the option given a name
98 // return 0 if the option is not found
99 static IOptions * FindDefault(const char * algoname);
100
101 // retrieve options given the name
102 // if option is not found create a new GenAlgoOption for the given name
103 static IOptions & Default(const char * algoname);
104
105 /// print all the default options
106 static void PrintAllDefault(std::ostream & os = std::cout);
107
108
109protected:
110
111
112
113private:
114
115 template<class M>
116 static const typename M::mapped_type * FindValue(const std::string & name, const M & opts) {
117 typename M::const_iterator pos;
118 pos = opts.find(name);
119 if (pos == opts.end()) {
120 return 0;
121 }
122 return &((*pos).second);
123 }
124
125 template<class M>
126 static void InsertValue(const std::string &name, M & opts, const typename M::mapped_type & value) {
127 typename M::iterator pos;
128 pos = opts.find(name);
129 if (pos != opts.end()) {
130 pos->second = value;
131 }
132 else {
133 opts.insert(typename M::value_type(name, value) );
134 }
135 }
136
137 template<class M>
138 static void Print( const M & opts, std::ostream & os) {
139 //const std::ios_base::fmtflags prevFmt = os.flags();
140 for (typename M::const_iterator pos = opts.begin(); pos != opts.end(); ++pos)
141 os << std::setw(25) << pos->first << " : " << std::setw(15) << pos->second << std::endl;
142 }
143
144
145 std::map<std::string, double> fRealOpts; // map of the real options
146 std::map<std::string, int> fIntOpts; // map of the integer options
147 std::map<std::string, std::string> fNamOpts; // map of the named options
148
149};
150
151
152
153 } // end namespace Math
154
155} // end namespace ROOT
156
157#endif
class implementing generic options for a numerical algorithm Just store the options in a map of strin...
std::map< std::string, double > fRealOpts
static void Print(const M &opts, std::ostream &os)
std::map< std::string, int > fIntOpts
static void PrintAllDefault(std::ostream &os=std::cout)
print all the default options
static void InsertValue(const std::string &name, M &opts, const typename M::mapped_type &value)
virtual void Print(std::ostream &os=std::cout) const
print options
virtual void SetRealValue(const char *name, double val)
method wich need to be re-implemented by the derived classes
virtual void SetIntValue(const char *name, int val)
virtual bool GetIntValue(const char *name, int &val) const
virtual IOptions * Clone() const
generic methods for retrivieng options
static IOptions & Default(const char *algoname)
static const M::mapped_type * FindValue(const std::string &name, const M &opts)
static IOptions * FindDefault(const char *algoname)
std::map< std::string, std::string > fNamOpts
virtual void SetNamedValue(const char *name, const char *val)
virtual bool GetNamedValue(const char *name, std::string &val) const
virtual bool GetRealValue(const char *name, double &val) const
Generic interface for defining configuration options of a numerical algorithm.
Definition: IOptions.h:30
Namespace for new Math classes and functions.
Namespace for new ROOT classes and functions.
Definition: StringConv.hxx:21