/[PAMELA software]/yoda/event/PamelaRun.cpp
ViewVC logotype

Annotation of /yoda/event/PamelaRun.cpp

Parent Directory Parent Directory | Revision Log Revision Log


Revision 6.7 - (hide annotations) (download)
Wed Aug 16 13:23:00 2006 UTC (18 years, 4 months ago) by kusanagi
Branch: MAIN
CVS Tags: YODA6_3/06
Changes since 6.6: +3 -2 lines
Added the "missing" CalibCal packet

1 kusanagi 1.1 /** @file
2 kusanagi 6.0 * $Author: kusanagi $
3 kusanagi 6.7 * $Date: 2006/06/26 08:43:20 $
4     * $Revision: 6.6 $
5 kusanagi 1.1 *
6     * Implementation of the PamelaRun class.
7     */
8     #include <iostream>
9     #include <iomanip>
10     #include <list>
11     #include <exception>
12 kusanagi 1.6 #include <log4cxx/logger.h>
13 kusanagi 1.1
14     #include <TFile.h> //Substituted by Maurizio 05 Feb 2004
15     #include <TTree.h> //Substituted by Maurizio 05 Feb 2004
16     #include <TChain.h> //Substituted by Maurizio 05 Feb 2004
17     #include <TKey.h> //Substituted by Maurizio 05 Feb 2004
18     #include <TList.h> //Substituted by Maurizio 05 Feb 2004
19    
20    
21     #include "PamelaRun.h"
22     #include "EventHeader.h"
23     #include "Algorithm.h"
24     #include "AlgorithmInfo.h"
25     #include "Exception.h"
26 kusanagi 1.6 #include <sys/stat.h>
27    
28 kusanagi 1.1 extern "C" {
29 kusanagi 1.6 #include <dirent.h>
30 kusanagi 1.1 #include "DirectoryStructure.h"
31     }
32    
33     using namespace pamela;
34    
35 kusanagi 1.6 static log4cxx::LoggerPtr logger = log4cxx::Logger::getLogger(_T("pamela.PamelaRun"));
36 kusanagi 1.1
37     /**
38     * Get the run name according to a certain run number.
39     * @param run Run number.
40     * @return a string with the run name.
41     */
42     std::string PamelaRun::GetRunName(int run) {
43 kusanagi 2.5 std::stringstream temp;
44     temp.str("");
45     temp << std::setw( 4 ) << std::setfill( '0' ) << run;
46     return "Run" + temp.str();
47 kusanagi 1.1 }
48    
49     /**
50     * Check if the run number is already assigned
51     * @param int run - Number of the run to check
52     * @return int
53     */
54 kusanagi 2.5 void PamelaRun::RunExists(std::string input) throw (std::exception){
55 kusanagi 1.1 int res;
56     DIR *dirp;
57     std::string fileName;
58 kusanagi 6.2 //std::string pathDir((char*)getenv("YODA_DATA"));
59     std::string pathDir(GetPath());
60 kusanagi 1.1 std::string tempName;
61     std::string::size_type pos;
62 kusanagi 2.5
63 kusanagi 1.1 pos = input.find_last_of("/");
64     fileName = input.substr(pos+1);
65     pos = fileName.find_last_of(".");
66     fileName = fileName.substr(0,pos);
67     pathDir = pathDir + "/";
68 kusanagi 6.3 tempName = pathDir + fileName;
69 kusanagi 6.2 oss.str("");
70 kusanagi 6.3 oss << Path << "/" << fileName;
71 kusanagi 6.2 UnpackPath = oss.str();
72 kusanagi 2.5 oss.str("");
73 kusanagi 6.3 oss << fileName;
74 kusanagi 2.5 Run = oss.str();
75 kusanagi 1.1 }
76    
77     /**
78     * Create a new Pamela run.
79     * @param run Run number
80     * @param path Base path name to the data
81     */
82 kusanagi 5.1 PamelaRun::PamelaRun(std::string fileName, std::string path, bool multiple, short compr):
83 kusanagi 2.5 Path(path),
84     Run(fileName),
85 kusanagi 5.1 RunNumber(1),//veirificare se รจ possibilie eliminare questa variabile
86     Multiple(multiple),
87     SingleFile(0),
88     compression(compr){
89 kusanagi 1.6 logger->debug(_T("Constructor"));
90 kusanagi 2.5 //Run = RunExists(fileName);
91     RunExists(fileName);
92 kusanagi 1.1 info = RunInfo(this);
93     }
94    
95     /**
96     * Get the directory name that contains the files of a certain event
97     * type for this run.
98     * @param type the packet type.
99     * @return the complete path for this event type.
100     */
101     std::string PamelaRun::GetDirName(PacketType const * type) const {
102 kusanagi 2.5 //std::stringstream oss;
103     //std::string name = type->GetName();
104     //oss.str("");
105     //oss << Path << "/" << Run << "/" << "pippo";
106     //return oss.str();
107     //return "pippo";
108     //std::string EventType = type->GetName();
109     return Path + "/" + Run + "/" + type->GetName();
110 kusanagi 1.1 }
111    
112     /**
113     * Get the file name for a certain event type.
114     * @param type subpacket type.
115     * @param name subpacket name.
116     * @return the complete path and file name.
117     */
118 kusanagi 2.5 std::string PamelaRun::GetFileName(const SubPacket* type, std::string name) {
119 kusanagi 1.1 if (type->IsDetectorSpecific()) {
120 kusanagi 6.2 return UnpackPath + "/" + type->GetPacketType()->GetName() + "/"
121 kusanagi 2.5 + Run + "." + type->GetPacketType()->GetName() + "."
122 kusanagi 1.1 + type->GetSubDetector()->GetName() + "."
123     + name + ".root";
124     } else {
125 kusanagi 6.2 return UnpackPath + "/" + type->GetPacketType()->GetName() + "/"
126 kusanagi 1.1 + Run + "." + type->GetPacketType()->GetName() + "."
127     + name + ".root";
128 kusanagi 2.5 /*
129     return Path + "/" + type->GetPacketType()->GetName() + "/"
130     + Run + "." + type->GetPacketType()->GetName() + "."
131     + name + ".root"; */
132 kusanagi 1.1 }
133     }
134    
135     /**
136     * Get the file name for a certain event type.
137     * @param type subpacket type.
138     * @return the complete path and file name.
139     */
140 kusanagi 2.5 std::string PamelaRun::GetFileName(const SubPacket* type) {
141     //return GetFileName(type, type->GetSubPacketName());
142     return GetFileName(type, "pippo");
143 kusanagi 1.1 }
144    
145     /**
146     * Get the branch name that corresponds to a certain
147     * subpacket. Usually, this is the name of the subpacket.
148     * @param type subpacket type.
149     * @return the corresponding branch name.
150     */
151     static std::string GetDefaultBranchName(const SubPacket* type) {
152     return type->GetSubPacketName();
153     }
154    
155     /**
156     * Get the tree name for a certain subpacket. This is the name of the
157     * subdetector for detector specific subpackets, and the packet name
158     * ("Physics" etc.) for common packets.
159     * @param type the packet type.
160     * @return the corresponding tree name.
161     */
162     static std::string GetTreeName(const SubPacket* type) {
163     if (type->IsDetectorSpecific()) {
164     return type->GetSubDetector()->GetName();
165     } else {
166     return type->GetPacketType()->GetName();
167     }
168     }
169    
170     /**
171     * Get a list of all root files from a certain path.
172     * @param path Path name to start the search.
173     * @return A list of all file names.
174     */
175     static std::list<std::string> GetRootFiles(std::string path) throw (std::exception) {
176     std::list<std::string> files;
177     DIR *dir = opendir(path.c_str());
178     if (dir == 0) {
179 kusanagi 2.5 logger->debug("Could not open " + path);
180 kusanagi 2.3 //throw Exception("Could not open " + path);
181 kusanagi 1.1 }
182    
183     for (struct dirent *d = readdir(dir); d != NULL; d = readdir(dir)) {
184     if ((strcmp(".",d->d_name) == 0) || (strcmp("..",d->d_name) == 0))
185     continue;
186     std::string filename = path + "/" + d->d_name;
187     struct stat buf;
188     stat(filename.c_str(), &buf);
189     if S_ISDIR(buf.st_mode) {
190     std::list<std::string>toAdd = GetRootFiles(filename);
191     files.insert(files.end(), toAdd.begin(), toAdd.end());
192     } else if ((filename.substr(filename.size()-5, filename.size())
193     == ".root") // correct suffix
194     && (!isdigit(filename[filename.size()-6]))) { // base file
195     std::string nextfilename = filename;
196     nextfilename.insert(filename.size()-5, "_1");
197     if (stat(nextfilename.c_str(), &buf) == 0) {
198     filename.insert(filename.size()-5, "*");
199     }
200 kusanagi 2.5 logger->debug("Using " + filename);
201 kusanagi 1.1 files.push_back(filename);
202     }
203     }
204     return files;
205     }
206    
207     /**
208     * Helper function to open the ROOT TTree of the header within the run
209     * framework.
210     * @param type The packet type.
211     * @return the ROOT TTree.
212     */
213     TChain* PamelaRun::ReadHeaderTree(const PacketType *type)
214     throw (std::exception) {
215     EventHeader header(type);
216     std::string FileName = GetFileName(&header);
217     std::string TreeName = GetTreeName(&header);
218     TChain *tree = new TChain(TreeName.c_str());
219     tree->Add(FileName.c_str());
220     return tree;
221     }
222    
223     /**
224     * All add trees of a file as friend to a given tree. The tree name of
225     * each tree found in the file is used as the name of the friend alias.
226     * @param tree The base tree to add all other as friends.
227     * @param FileName The name of the file with other trees.
228     */
229     static void AddAllAsFriend(TChain* tree, std::string FileName) {
230     std::string BaseFileName = FileName;
231     bool HaveChain = false;
232     if (BaseFileName[BaseFileName.size()-6] == '*') {
233     BaseFileName.erase(BaseFileName.size()-6, 1);
234     HaveChain = true;
235     }
236     TFile* File = new TFile(BaseFileName.c_str(), "read");
237     if (!File->IsOpen()) {
238 kusanagi 2.6 logger->error("Could not open file " + BaseFileName + " for reading.");
239 kusanagi 1.1 return;
240     }
241     TList* list = File->GetListOfKeys();
242     if (HaveChain) {
243     for (TIter i(list); TKey* k = (TKey*)i();) {
244     if (std::string(TTree::Class()->GetName()) == k->GetClassName()) {
245     std::string TreeName = k->GetName();
246     TChain* FriendChain = new TChain(TreeName.c_str());
247     FriendChain->Add(FileName.c_str());
248     tree->AddFriend(FriendChain, TreeName.c_str());
249 kusanagi 2.5 //logger->warn("Adding chain " + TreeName + " with " + FriendChain->GetEntries() + " entries as Friend");
250 kusanagi 1.1 }
251     }
252     File->Close();
253     } else {
254     for (TIter i(list); TKey* k = (TKey*)i();) {
255     if (std::string(TTree::Class()->GetName()) == k->GetClassName()) {
256     std::string TreeName = k->GetName();
257     TTree* FriendTree = (TTree *)File->Get(TreeName.c_str());
258     tree->AddFriend(FriendTree, TreeName.c_str());
259 kusanagi 2.5 //logger->debug("Adding tree " + TreeName + " with " + FriendTree->GetEntries() + " entries as Friend");
260 kusanagi 1.1 }
261     }
262     }
263     }
264    
265     /**
266     * Read all Root TTrees which belong to a certain event type and mount them
267     * together as "friends".
268     * @param type The packet type.
269     * @return The root trees with the friends.
270     */
271     TTree* PamelaRun::ReadTTree(const PacketType* type) {
272 kusanagi 2.3 oss.str("");
273 kusanagi 1.6 oss << "Getting root files of " << type->GetName();
274     logger->debug(oss.str().c_str());
275 kusanagi 1.1 RootTreeMap::iterator t = TTreeMap.find(type);
276     if (t != TTreeMap.end()) {
277     return t->second;
278     } else {
279 kusanagi 2.3 oss.str("");
280 kusanagi 1.6 oss << "Reading root files of " << type->GetName();
281     logger->debug(oss.str().c_str());
282 kusanagi 1.1 EventHeader header(type);
283     std::string HeaderFileName = GetFileName(&header);
284     TChain* HeaderTree = ReadHeaderTree(type);
285     std::list<std::string> rootfiles = GetRootFiles(GetDirName(type));
286     for (std::list<std::string>::iterator i = rootfiles.begin();
287     i != rootfiles.end(); i++){
288     if (*i == HeaderFileName)
289     continue; // dont add the header tree itself.
290     AddAllAsFriend(HeaderTree, *i);
291     }
292     TTreeMap.insert(RootTreeMap::value_type(type, HeaderTree));
293     return HeaderTree;
294     }
295     }
296    
297     /**
298     * Register a certain SubPacket, identified by its name, to be read
299     * from the repository. This function is made for interactive work.
300     * @param subpacket A pointer to the pointer of the packet.
301     * @param name The name of the subpacket
302     */
303     void PamelaRun::ReadSubPacket(void* subpacket, std::string name) {
304     SubPacket *packet = *(SubPacket**)subpacket;
305    
306     // look into the map of subpackets if we already read it.
307     std::string FullName = packet->GetPacketType()->GetName() + "." + name;
308     SubPacketMap::iterator i = SubPacketAddresses.find(FullName);
309     if (i != SubPacketAddresses.end()) { // it is in the map
310     *(SubPacket**)subpacket = i->second;
311     return;
312     } else { // not found in the map of used subpackets
313     TTree* tree = ReadTTree(packet->GetPacketType());
314     TBranch* branch = tree->GetBranch(name.c_str());
315     if (branch != 0) {
316     branch->SetAddress(subpacket);
317     SubPacketAddresses.insert(SubPacketMap::value_type(FullName, packet));
318     } else {
319 kusanagi 2.3 oss.str("");
320 kusanagi 1.6 oss << "Could not find data for " << packet->GetPacketType()->GetName() << "/" << name ;
321     logger->error(oss.str().c_str());
322 kusanagi 1.1 }
323     }
324     }
325    
326     /**
327     * Register a certain SubPacket, identified by its default name, to be
328     * read from the repository. This function is made for
329     * interactive work.
330     * @param subpacket A pointer to the pointer of the packet.
331     */
332     void PamelaRun::ReadSubPacket(void* subpacket) {
333     SubPacket *packet = *(SubPacket**)subpacket;
334     ReadSubPacket(subpacket, GetDefaultBranchName(packet));
335     }
336    
337     /**
338     * Register a certain SubPacket with its default name, to be read from
339     * the repository. This functions is for use from the algorithm.
340     * @param algo Algorithm that needs this SubPacket.
341     * @param subpacket A pointer to the pointer of the packet.
342     */
343     void PamelaRun::ReadSubPacket(const Algorithm* algo, void* subpacket) {
344     //:TODO: store the request of the algorithm here.
345     ReadSubPacket(subpacket);
346     }
347    
348     /**
349     * Register a certain SubPacket, with a custom name, to
350     * be read from the repository. This functions is for use from
351     * the algorithm.
352     * @param algo Algorithm that needs this SubPacket.
353     * @param subpacket A pointer to the pointer of the packet.
354     * @param name The name of the subpacket
355     */
356     void PamelaRun::ReadSubPacket(const Algorithm* algo, void* subpacket,
357     std::string name) {
358     //:TODO: store the request of the algorithm here.
359     ReadSubPacket(subpacket, name);
360     }
361    
362     /**
363     * Helper function to create a ROOT TTree within the run framework.
364     * @param algo Algorithm that creates this SubPacket.
365     * @param packet subpacket type
366     * @param name the name of the subpacket
367     * @return the ROOT TTree.
368     */
369     TTree* PamelaRun::CreateTTree(Algorithm* algo, const SubPacket* packet,
370     std::string name)
371     throw (std::exception) {
372 kusanagi 5.1 std::string FileName = "";
373 kusanagi 1.1 std::string EventType = packet->GetPacketType()->GetName();
374 kusanagi 5.1 TFile* File = 0;
375     std::string TreeName = GetTreeName(packet);
376     TTree *tree = 0;
377     FileName = GetFileName(packet, name);
378 kusanagi 1.1 CreateDirectoryStructure(FileName.c_str());
379 kusanagi 5.1 File = new TFile(FileName.c_str(), "create");
380     tree = new TTree(TreeName.c_str(), algo->GetAlgorithmName().c_str());
381     WritingRootTrees[packet->GetPacketType()].push_back(tree);
382    
383     File->SetCompressionLevel(compression);
384 kusanagi 1.1 if (!File->IsOpen()) {
385 kusanagi 2.5 logger->error("Could not open file " + FileName);
386 kusanagi 2.3 //throw Exception("Could not open file " + FileName);
387 kusanagi 1.1 }
388 kusanagi 2.6 logger->debug("Creating file " + FileName + " with Tree " + TreeName);
389 kusanagi 1.1 return tree;
390     }
391    
392    
393     /**
394     * Register a certain SubPacket to be written to the repository. A
395     * usual call sequence for this function ist
396     * MyEvent *event = new MyEvent();
397     * run->WriteSubPacket(this, &event, event->Class()
398     * @param algo Algorithm that produces this SubPacket.
399     * @param subpacket A pointer to the pointer of the subpacket.
400     * @param c The class the subpacket belongs to.
401     * @param name The name of the packet.
402     */
403     void PamelaRun::WriteSubPacket(Algorithm *algo, void* subpacket,
404     const TClass *c, std::string name) {
405     SubPacket *packet = *(SubPacket **)subpacket;
406 kusanagi 2.3 oss.str("");
407 kusanagi 1.6 oss << "Register: " << name << " for " << algo->GetAlgorithmName() << " (writing)";
408     logger->debug(oss.str().c_str());
409 kusanagi 1.1 TTree* HeaderTree = ReadTTree(packet->GetPacketType());
410     std::string FullName = packet->GetPacketType()->GetName() + "." + name;
411 kusanagi 5.1 if (Multiple) {
412     TTree* tree = CreateTTree(algo, packet, name);
413     oss.str("");
414     oss << "Branch: " << name << " Class: " << c->GetName();
415     logger->debug(oss.str().c_str());
416     tree->Branch(name.c_str(), c->GetName(), subpacket);
417     HeaderTree->AddFriend(tree, tree->GetName());
418     SubPacketAddresses.insert(SubPacketMap::value_type(FullName, packet));
419     } else {
420     std::string nameBranch(name);
421     HeaderTree->Branch(nameBranch.c_str(), c->GetName(), subpacket);
422     SubPacketAddresses.insert(SubPacketMap::value_type(FullName, packet));
423     }
424 kusanagi 1.1 }
425    
426     /**
427     * Register a certain SubPacket with its default name to be written to
428     * the repository. A usual call sequence for this function ist
429     * MyEvent *event = new MyEvent();
430     * run->WriteSubPacket(this, &event, event->Class()
431     * @param algo Algorithm that produces this SubPacket.
432     * @param subpacket A pointer to the pointer of the subpacket.
433     * @param c The class the subpacket belongs to.
434     */
435     void PamelaRun::WriteSubPacket(Algorithm *algo, void* subpacket,
436     const TClass *c) {
437     SubPacket *packet = *(SubPacket **)subpacket;
438     WriteSubPacket(algo, subpacket, c, GetDefaultBranchName(packet));
439     }
440    
441     /**
442     * Write the header packet to all ROOT files in the tree. Intended to
443     * be used for raw data readers that create the initial event structure.
444     * @param algo Algorithm that produces this SubPacket.
445     * @param subpacket A pointer to the pointer of the header packet.
446     */
447     void PamelaRun::WriteHeaders(Algorithm* algo, EventHeader** subpacket) {
448 kusanagi 1.4 WriteHeader(algo, subpacket, PacketType::PhysEndRun);
449     WriteHeader(algo, subpacket, PacketType::CalibCalPulse1);
450     WriteHeader(algo, subpacket, PacketType::CalibCalPulse2);
451 kusanagi 1.1 WriteHeader(algo, subpacket, PacketType::Physics);
452 kusanagi 6.4 WriteHeader(algo, subpacket, PacketType::CalibTrkBoth);
453 kusanagi 1.2 WriteHeader(algo, subpacket, PacketType::CalibTrk1);
454     WriteHeader(algo, subpacket, PacketType::CalibTrk2);
455 kusanagi 1.1 WriteHeader(algo, subpacket, PacketType::CalibTof);
456     WriteHeader(algo, subpacket, PacketType::CalibS4);
457 kusanagi 1.4 WriteHeader(algo, subpacket, PacketType::CalibCalPed);
458 kusanagi 2.5 WriteHeader(algo, subpacket, PacketType::Calib1_Ac1);
459     WriteHeader(algo, subpacket, PacketType::Calib1_Ac2);
460     WriteHeader(algo, subpacket, PacketType::Calib2_Ac1);
461     WriteHeader(algo, subpacket, PacketType::Calib2_Ac2);
462 kusanagi 6.7 WriteHeader(algo, subpacket, PacketType::CalibCal);
463 kusanagi 1.1 WriteHeader(algo, subpacket, PacketType::RunHeader);
464     WriteHeader(algo, subpacket, PacketType::RunTrailer);
465 kusanagi 1.4 WriteHeader(algo, subpacket, PacketType::CalibHeader);
466     WriteHeader(algo, subpacket, PacketType::CalibTrailer);
467     WriteHeader(algo, subpacket, PacketType::InitHeader);
468     WriteHeader(algo, subpacket, PacketType::InitTrailer);
469 kusanagi 6.1 WriteHeader(algo, subpacket, PacketType::EventTrk);
470 kusanagi 1.4 WriteHeader(algo, subpacket, PacketType::Log);
471     WriteHeader(algo, subpacket, PacketType::VarDump);
472     WriteHeader(algo, subpacket, PacketType::ArrDump);
473     WriteHeader(algo, subpacket, PacketType::TabDump);
474     WriteHeader(algo, subpacket, PacketType::Tmtc);
475     WriteHeader(algo, subpacket, PacketType::Mcmd);
476     WriteHeader(algo, subpacket, PacketType::ForcedFECmd);
477 kusanagi 2.5 WriteHeader(algo, subpacket, PacketType::Ac1Init);
478 kusanagi 1.4 WriteHeader(algo, subpacket, PacketType::CalInit);
479     WriteHeader(algo, subpacket, PacketType::TrkInit);
480     WriteHeader(algo, subpacket, PacketType::TofInit);
481     WriteHeader(algo, subpacket, PacketType::TrgInit);
482 kusanagi 2.1 WriteHeader(algo, subpacket, PacketType::NdInit);
483 kusanagi 2.4 WriteHeader(algo, subpacket, PacketType::S4Init);
484 kusanagi 2.5 WriteHeader(algo, subpacket, PacketType::Ac2Init);
485 kusanagi 1.6 WriteHeader(algo, subpacket, PacketType::CalAlarm);
486 kusanagi 6.4 WriteHeader(algo, subpacket, PacketType::Ac1Alarm);
487 kusanagi 1.6 WriteHeader(algo, subpacket, PacketType::TrkAlarm);
488     WriteHeader(algo, subpacket, PacketType::TrgAlarm);
489 kusanagi 2.4 WriteHeader(algo, subpacket, PacketType::TofAlarm);
490     WriteHeader(algo, subpacket, PacketType::S4Alarm);
491 kusanagi 6.4 WriteHeader(algo, subpacket, PacketType::Ac2Alarm);
492 kusanagi 2.7 WriteHeader(algo, subpacket, PacketType::TsbT);
493     WriteHeader(algo, subpacket, PacketType::TsbB);
494 kusanagi 1.1 }
495    
496     /**
497     * Write the ROOT files to disk.
498     */
499     void PamelaRun::WriteFiles(void) {
500     // Workaround: unlink all friend trees first top avoid to store
501     // the links in the header tree file.
502     for (RootTreeMap::iterator i = TTreeMap.begin(); i != TTreeMap.end(); i++) {
503     if (i->second->GetListOfFriends() != 0) {
504     i->second->GetListOfFriends()->Delete();
505     }
506     }
507    
508     for (TTreeListMap::iterator i = WritingRootTrees.begin();
509     i != WritingRootTrees.end(); i++) {
510     for (TTreeList::iterator j = i->second.begin();
511     j != i->second.end(); j++) {
512 kusanagi 5.1 (*j)->GetCurrentFile()->Write(0,TObject::kOverwrite);
513 kusanagi 1.1 }
514     }
515     }
516    
517     /**
518     * Fill all ROOT trees of a certain type that were opened for writing.
519     * @param type the package type of the trees to fill.
520     */
521     void PamelaRun::FillTrees(const PacketType* type) {
522 kusanagi 3.1 try{
523     for (TTreeList::iterator j = WritingRootTrees[type].begin();
524     j != WritingRootTrees[type].end(); j++) {
525     (*j)->Fill();
526     }
527     } catch(Exception exc){
528     logger->fatal("ORRORE!!!");
529 kusanagi 1.1 }
530     }
531    
532 kusanagi 1.6
533 kusanagi 5.1 /**
534     * Write the header packet of a specified packet type. This is mainly used
535     * for the raw reader to create the base for the event structure.
536     * @param algo Algorithm that produces this SubPacket.
537     * @param subpacket A pointer to the pointer of the packet.
538     * @param type The packet type.
539     */
540     void PamelaRun::WriteHeader(Algorithm* algo, EventHeader** subpacket,
541     const PacketType* type) {
542     EventHeader header(type);
543     std::string EventType = (&header)->GetPacketType()->GetName();
544 kusanagi 2.5
545 kusanagi 5.1 std::string FileName = "";
546     TFile* File = 0;
547 kusanagi 6.6 Long64_t maxsize = 5000000000LL;
548     TTree::SetMaxTreeSize(maxsize);
549 kusanagi 5.1 TTree *tree = 0;
550     if ( Multiple ){
551     FileName = GetFileName(&header, GetDefaultBranchName(&header));
552     CreateDirectoryStructure(FileName.c_str());
553     File = new TFile(FileName.c_str(), "create");
554     File->SetCompressionLevel(compression);
555     tree = new TTree("Pscu", algo->GetAlgorithmName().c_str());
556     WritingRootTrees[(&header)->GetPacketType()].push_back(tree);
557     tree->GetCurrentFile()->cd();
558     tree->Branch(GetDefaultBranchName(&header).c_str(),
559     (*subpacket)->Class()->GetName(), subpacket);
560     TTreeMap.insert(RootTreeMap::value_type(type, tree));
561     } else {
562     if (!Multiple && (SingleFile == NULL)){
563 kusanagi 6.2 //std::string pathDir((char*)getenv("YODA_DATA"));
564     SingleFile = new TFile((GetPath() + "/" + Run + ".root").c_str(), "update");
565 kusanagi 5.1 SingleFile->SetCompressionLevel(compression);
566     }
567     tree = new TTree(EventType.c_str(), algo->GetAlgorithmName().c_str());
568     WritingRootTrees[type].push_back(tree);
569     tree->GetCurrentFile()->cd();
570     tree->Branch(GetDefaultBranchName(&header).c_str(),
571     (*subpacket)->Class()->GetName(), subpacket);
572     TTreeMap.insert(RootTreeMap::value_type(type, tree));
573     }
574     }

  ViewVC Help
Powered by ViewVC 1.1.23