1 /**************************************************************************
2 * Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. *
4 * Author: The ALICE Off-line Project. *
5 * Contributors are mentioned in the code where appropriate. *
7 * Permission to use, copy, modify and distribute this software and its *
8 * documentation strictly for non-commercial purposes is hereby granted *
9 * without fee, provided that the above copyright notice appears in all *
10 * copies and that both the copyright notice and this permission notice *
11 * appear in the supporting documentation. The authors make no claims *
12 * about the suitability of this software for any purpose. It is *
13 * provided "as is" without express or implied warranty. *
14 **************************************************************************/
18 // Do the Digitization (Digit) from summable Digits (SDigit)
19 // Allow the merging of signal file with background file(s).
21 /////////////////////////////////////////////////////////////////////////////////
23 // AliMUONDigitizerv2 digitizes digits from s-digits.
24 // Merging is allowed from multiple input streams. The first input stream is
25 // assumed to be the signal and all other input streams as assumed to be
27 // Chamber response is applied to the digits identically to AliMUONDigitizerv1.
29 /////////////////////////////////////////////////////////////////////////////////
31 #include "AliMUONData.h"
32 #include "AliMUONLoader.h"
33 #include "AliMUONConstants.h"
34 #include "AliMUONDigit.h"
35 #include "AliMUONDigitizerv2.h"
36 #include "AliMUONTransientDigit.h"
38 ClassImp(AliMUONDigitizerv2)
40 //___________________________________________
41 AliMUONDigitizerv2::AliMUONDigitizerv2() : AliMUONDigitizerv1()
43 // Default ctor - don't use it
46 //___________________________________________
47 AliMUONDigitizerv2::AliMUONDigitizerv2(AliRunDigitizer* manager) : AliMUONDigitizerv1(manager)
49 // ctor which should be used
52 //___________________________________________
53 AliMUONDigitizerv2::~AliMUONDigitizerv2()
58 //-----------------------------------------------------------------------
59 void AliMUONDigitizerv2::GenerateTransientDigits()
61 // Loop over all chambers and s-digits in the input stream and create
62 // AliMUONTransientDigit objects from them. These are then added to fTDList.
65 Info("GenerateTransientDigits", "Generating transient digits using treeH = 0x%X");
71 TClonesArray* muonSDigits;
72 for (Int_t ich = 0; ich < AliMUONConstants::NCh(); ich++) // loop over chamber
74 fMUONData->ResetSDigits();
75 fMUONData->GetCathodeS(0);
76 muonSDigits = fMUONData->SDigits(ich);
77 ndig = muonSDigits->GetEntriesFast();
78 for (k = 0; k < ndig; k++)
80 sDigit = (AliMUONDigit*) muonSDigits->UncheckedAt(k);
81 MakeTransientDigitFromSDigit(ich,sDigit);
83 fMUONData->ResetSDigits();
84 fMUONData->GetCathodeS(1);
85 muonSDigits = fMUONData->SDigits(ich);
86 ndig=muonSDigits->GetEntriesFast();
87 for (k = 0; k < ndig; k++)
89 sDigit = (AliMUONDigit*) muonSDigits->UncheckedAt(k);
90 MakeTransientDigitFromSDigit(ich,sDigit);
92 } // SDigits loop, end loop over chamber
95 //------------------------------------------------------------------------
96 void AliMUONDigitizerv2::MakeTransientDigitFromSDigit(Int_t iChamber, AliMUONDigit* sDigit)
98 // Makes a transient digit from the specified s-digit from the specified chamber.
99 // Once the digit is created it is added to the fTDList.
102 Info("MakeTransientDigitFromSDigit",
103 "Making transient digit from s-digit for chamber %d.", iChamber);
107 // Creating a new TransientDigits from SDigit
108 digits[0] = sDigit->PadX(); // Padx of the Digit
109 digits[1] = sDigit->PadY(); // Pady of the Digit
110 digits[2] = sDigit->Cathode()+1; // Cathode plane
111 digits[3] = sDigit->Signal(); // Induced charge in the Pad
113 digits[4] = sDigit->Signal();
117 digits[5] = sDigit->Hit(); // Hit number in the list
120 Info("MakeTransientDigitFromSDigit",
121 "Made digit from sDigit 0x%X: PadX %d\tPadY %d\tPlane %d\tCharge %d\tHit %d",
122 (void*)sDigit, digits[0], digits[1], digits[2], digits[3], digits[5]);
124 AliMUONTransientDigit* mTD = new AliMUONTransientDigit(iChamber, digits);
125 // Copy list of tracks and trackcharge
126 for(Int_t itrack = 0; itrack < kMAXTRACKS; itrack++)
128 Int_t track = sDigit->Track(itrack);
129 if (track < 0) break; // Check if we reached the end of the track list.
130 mTD->AddToTrackList( track + fMask, sDigit->TrackCharge(itrack) );
133 OnCreateTransientDigit(mTD, sDigit);
134 AddOrUpdateTransientDigit(mTD);
137 //------------------------------------------------------------------------
138 void AliMUONDigitizerv2::AddDigit(Int_t chamber, Int_t tracks[kMAXTRACKS], Int_t charges[kMAXTRACKS], Int_t digits[6])
140 // Override to add new digits to the digits tree TreeD.
141 fMUONData->AddDigit(chamber, tracks, charges, digits);
144 //------------------------------------------------------------------------
145 Bool_t AliMUONDigitizerv2::InitInputData(AliMUONLoader* muonloader)
147 // Overridden to initialize fMUONData to read from the s-digits tree TreeS.
148 // If the s-digits are not loaded then the muon loader is used to load the
149 // s-digits into memory.
152 Info("InitInputData", "Loading s-digits in READ mode and setting the tree address.");
154 fMUONData->SetLoader(muonloader);
156 if (muonloader->TreeS() == NULL)
158 muonloader->LoadSDigits("READ");
159 if (muonloader->TreeS() == NULL)
161 Error("InitInputData", "Can not load the s-digits tree.");
166 fMUONData->SetTreeAddress("S");
170 //------------------------------------------------------------------------
171 void AliMUONDigitizerv2::CleanupInputData(AliMUONLoader* muonloader)
173 // Overridden to release and unload s-digits from memory.
175 if (GetDebug() > 2) Info("CleanupInputData", "Releasing loaded s-digits.");
176 fMUONData->ResetSDigits();
177 muonloader->UnloadSDigits();