Logo ROOT   6.10/09
Reference Guide
mp103_processSelector.C
Go to the documentation of this file.
1 /// \file
2 /// \ingroup tutorial_multicore
3 /// \notebook -nodraw
4 /// Illustrate the usage of the multiproc TSelector interfaces with the h1 analysis
5 /// example.
6 ///
7 /// \macro_code
8 ///
9 /// \author Anda Chelba
10 /// \author Gerardo Ganis
11 
12 #include "TString.h"
13 #include "TROOT.h"
14 #include "TChain.h"
15 #include "TFileCollection.h"
16 #include "TH1F.h"
17 #include "TTreeReader.h"
19 
20 const char *fh1[] = {"http://root.cern.ch/files/h1/dstarmb.root",
21  "http://root.cern.ch/files/h1/dstarp1a.root",
22  "http://root.cern.ch/files/h1/dstarp1b.root",
23  "http://root.cern.ch/files/h1/dstarp2.root"};
24 
25 int mp103_processSelector(){
26 
27  // MacOSX may generate connection to WindowServer errors
28  gROOT->SetBatch(kTRUE);
29 
30  TString selectorPath = gROOT->GetTutorialDir();
31  selectorPath += "/tree/h1analysis.C+";
32  std::cout << "selector used is: "<< selectorPath<<"\n";
33  TSelector *sel = TSelector::GetSelector(selectorPath);
34 
35 // The following code generates a crash when Davix is used for HTTP
36 // Davix does not seem fork-safe; the problem has been reported to the
37 // Davix developers. For the time being we disable this part.
38 // To repoduce the problem, uncomment the next line.
39 //
40 // #define __reproduce_davix
41 #if defined(__reproduce_davix)
42  TFile *fp = TFile::Open(fh1[0]);
43  TTree *tree = (TTree *) fp->Get("h42");
44 #endif
45 
46  ROOT::TTreeProcessorMP pool(3);
47 
48  TList* out = 0;
49 #if defined(__reproduce_davix)
50  //TTreeProcessorMP::Process with a single tree
51  out = pool.Process(*tree, *sel);;
52  sel->GetOutputList()->Delete();
53 #endif
54 
55  //TTreeProcessorMP::Process with single file name and tree name
56  //Note: we have less files than workers here
57  out = pool.Process(fh1[0], *sel, "h42");
58  sel->GetOutputList()->Delete();
59 
60  // Prepare datasets: vector of files, TFileCollection
61  TChain ch;
63  std::vector<std::string> files;
64  for (int i = 0; i < 4; i++) {
65  files.push_back(fh1[i]);
66  fc.Add(new TFileInfo(fh1[i]));
67  ch.Add(fh1[i]);
68  }
69 
70  //TTreeProcessorMP::Process with vector of files and tree name
71  //Note: we have more files than workers here (different behaviour)
72  out = pool.Process(files, *sel, "h42");
73  sel->GetOutputList()->Delete();
74 
75  //TTreeProcessorMP::Process with TFileCollection, no tree name
76  out = pool.Process(fc, *sel);
77  sel->GetOutputList()->Delete();
78 
79  // TTreeProcessorMP::Process with TChain, no tree name
80  out = pool.Process(ch, *sel);
81  sel->GetOutputList()->Delete();
82 
83  return 0;
84 }
virtual void Delete(Option_t *option="")
Remove all objects from the list AND delete all heap based objects.
Definition: TList.cxx:409
A ROOT file is a suite of consecutive data records (TKey instances) with a well defined format...
Definition: TFile.h:46
virtual TObject * Get(const char *namecycle)
Return pointer to object identified by namecycle.
#define gROOT
Definition: TROOT.h:375
Basic string class.
Definition: TString.h:129
static TFile * Open(const char *name, Option_t *option="", const char *ftitle="", Int_t compress=1, Int_t netopt=0)
Create / open a file.
Definition: TFile.cxx:3909
static struct mg_connection * fc(struct mg_context *ctx)
Definition: civetweb.c:1956
This class provides an interface to process a TTree dataset in parallel with multi-process technology...
A doubly linked list.
Definition: TList.h:43
Int_t Add(TFileInfo *info)
Add TFileInfo to the collection.
static TSelector * GetSelector(const char *filename)
The code in filename is loaded (interpreted or compiled, see below), filename must contain a valid cl...
Definition: TSelector.cxx:142
Class that contains a list of TFileInfo&#39;s and accumulated meta data information about its entries...
A chain is a collection of files containing TTree objects.
Definition: TChain.h:33
Definition: tree.py:1
A TTree object has a header with a name and a title.
Definition: TTree.h:78
Class describing a generic file including meta information.
Definition: TFileInfo.h:38
A TSelector object is used by the TTree::Draw, TTree::Scan, TTree::Process to navigate in a TTree and...
Definition: TSelector.h:33
const Bool_t kTRUE
Definition: RtypesCore.h:91
virtual TList * GetOutputList() const
Definition: TSelector.h:71
virtual Int_t Add(TChain *chain)
Add all files referenced by the passed chain to this chain.
Definition: TChain.cxx:220