00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017 #ifndef ROO_PDF_CUSTOMIZER
00018 #define ROO_PDF_CUSTOMIZER
00019
00020 #include "Rtypes.h"
00021 #include "TList.h"
00022 #include "TNamed.h"
00023 #include "TString.h"
00024 #include "RooArgSet.h"
00025 #include "RooPrintable.h"
00026 #include "RooFactoryWSTool.h"
00027 class RooAbsCategoryLValue ;
00028 class RooAbsCategory ;
00029 class RooAbsArg ;
00030 class RooAbsPdf ;
00031
00032 class RooCustomizer : public TNamed, public RooPrintable {
00033
00034 public:
00035
00036
00037 RooCustomizer(const RooAbsArg& pdf, const RooAbsCategoryLValue& masterCat, RooArgSet& splitLeafListOwned, RooArgSet* splitLeafListAll=0) ;
00038 RooCustomizer(const RooAbsArg& pdf, const char* name) ;
00039 virtual ~RooCustomizer() ;
00040
00041 void setOwning(Bool_t flag) {
00042
00043 _owning = flag ;
00044 }
00045
00046 void splitArgs(const RooArgSet& argSet, const RooAbsCategory& splitCat) ;
00047 void splitArg(const RooAbsArg& arg, const RooAbsCategory& splitCat) ;
00048 void replaceArg(const RooAbsArg& orig, const RooAbsArg& subst) ;
00049 RooAbsArg* build(const char* masterCatState, Bool_t verbose=kFALSE) ;
00050 RooAbsArg* build(Bool_t verbose=kFALSE) ;
00051
00052 const RooArgSet& cloneBranchList() const {
00053
00054 return *_cloneBranchList ;
00055 }
00056 const RooArgSet& cloneLeafList() const {
00057
00058 return *_cloneNodeListOwned ;
00059 }
00060
00061
00062 virtual void printName(ostream& os) const ;
00063 virtual void printTitle(ostream& os) const ;
00064 virtual void printClassName(ostream& os) const ;
00065 virtual void printArgs(ostream& os) const ;
00066 virtual void printMultiline(ostream& os, Int_t content, Bool_t verbose=kFALSE, TString indent= "") const;
00067
00068 inline virtual void Print(Option_t *options= 0) const {
00069
00070 printStream(defaultPrintStream(),defaultPrintContents(options),defaultPrintStyle(options));
00071 }
00072
00073
00074 void setCloneBranchSet(RooArgSet& cloneBranchSet) ;
00075
00076
00077 class CustIFace : public RooFactoryWSTool::IFace {
00078 public:
00079 virtual ~CustIFace() {} ;
00080 std::string create(RooFactoryWSTool& ft, const char* typeName, const char* instanceName, std::vector<std::string> args) ;
00081 } ;
00082
00083 protected:
00084
00085 RooCustomizer(const RooCustomizer&) ;
00086 void initialize() ;
00087
00088 RooAbsArg* doBuild(const char* masterCatState, Bool_t verbose) ;
00089
00090 Bool_t _sterile ;
00091 Bool_t _owning ;
00092 TString _name ;
00093
00094 TList _splitArgList ;
00095 TList _splitCatList ;
00096
00097 TList _replaceArgList ;
00098 TList _replaceSubList ;
00099
00100
00101 RooAbsArg* _masterPdf ;
00102 RooAbsCategoryLValue* _masterCat ;
00103
00104 TIterator* _masterLeafListIter ;
00105 TIterator* _masterBranchListIter ;
00106
00107 RooArgSet _masterBranchList ;
00108 RooArgSet _masterLeafList ;
00109
00110 RooArgSet _internalCloneBranchList ;
00111 RooArgSet* _cloneBranchList ;
00112
00113
00114 RooArgSet* _cloneNodeListAll ;
00115 RooArgSet* _cloneNodeListOwned ;
00116
00117 ClassDef(RooCustomizer,0)
00118 } ;
00119
00120 #endif