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 ///////////////////////////////////////////////////////////////////////////////
20 // Class to define a Trigger Past Future Protection
22 // name description INT1 INT2
24 // AliTriggerPFProtection sc( "BARREL", "BARREL DET Pb-Pb", "SC","PE" );
25 // sc.SetINTa("PE"); // Peripheral
26 // sc.SetINTb("SC"); // Semicentral
35 ///////////////////////////////////////////////////////////////////////////////
37 #include <Riostream.h>
41 #include <TObjString.h>
44 #include "AliTriggerPFProtection.h"
50 ClassImp( AliTriggerPFProtection )
51 //_____________________________________________________________________________
52 AliTriggerPFProtection::AliTriggerPFProtection() :
54 fINTa(), fINTb(),fINT(),
55 fNa1(0),fNa2(0),fTa(0),
56 fNb1(0),fNb2(0),fTb(0)
58 for(Int_t i=0;i<12;i++)fPFdef[i]=0;
60 AliTriggerPFProtection::AliTriggerPFProtection( TString & name) :
62 fINTa(), fINTb(),fINT(),
63 fNa1(0),fNa2(0),fTa(0),
64 fNb1(0),fNb2(0),fTb(0)
66 for(Int_t i=0;i<12;i++)fPFdef[i]=0;
68 AliTriggerPFProtection::AliTriggerPFProtection( TString & name,TString & inta, TString & intb, TString & interaction ) :
70 fINTa(inta), fINTb(intb),fINT(interaction),
71 fNa1(0),fNa2(0),fTa(0),
72 fNb1(0),fNb2(0),fTb(0)
74 for(Int_t i=0;i<12;i++)fPFdef[i]=0;
76 AliTriggerPFProtection::AliTriggerPFProtection(TString& name,UInt_t* pfdef)
78 fINTa(), fINTb(),fINT(),
79 fNa1(0),fNa2(0),fTa(0),
80 fNb1(0),fNb2(0),fTb(0)
82 for(Int_t i=0;i<12;i++)fPFdef[i]=pfdef[i];
84 //_____________________________________________________________________________
85 void AliTriggerPFProtection::Print( const Option_t* ) const
88 cout << "Trigger Past-Future Protection: " << endl;
89 cout << " Name: " << GetName() << endl;
90 cout << " Interaction_a: " << fINTa.Data() << endl;
91 cout << " Interaction_b: " << fINTb.Data() << endl;
92 cout << " Interaction: " << fINT.Data() << endl;
93 cout << " Na1: " << fNa1 << " Na2: " << fNa2 << " Ta: " << fTa << endl;
94 cout << " Nb1: " << fNb1 << " Nb2: " << fNb2 << " Tb: " << fTb << endl;
95 cout << "PFdef: " << hex;
96 for(Int_t i=0;i<12;i++)cout << " 0x" << fPFdef[i];
100 //_____________________________________________________________________________
101 Bool_t AliTriggerPFProtection::CheckInteractions(TObjArray &interactions) const
103 // Check if the interactions are valid
105 TString logic( GetINTa() );
106 TObjArray* tokens = logic.Tokenize(" !&|()\t");
108 Int_t ntokens = tokens->GetEntriesFast();
109 for( Int_t i=0; i<ntokens; i++ ) {
110 TObjString* iname = (TObjString*)tokens->At( i );
112 if (!interactions.FindObject(iname->String().Data())) {
113 AliError( Form( "The trigger interaction (%s) is not available for past-future protection (%s)",
114 iname->String().Data(), GetName() ) );
122 TString logic( GetINTb() );
123 TObjArray* tokens = logic.Tokenize(" !&|()\t");
125 Int_t ntokens = tokens->GetEntriesFast();
126 for( Int_t i=0; i<ntokens; i++ ) {
127 TObjString* iname = (TObjString*)tokens->At( i );
129 if (!interactions.FindObject(iname->String().Data())) {
130 AliError( Form( "The trigger interaction (%s) is not available for past-future protection (%s)",
131 iname->String().Data(), GetName() ) );
139 TString logic( GetINT() );
140 TObjArray* tokens = logic.Tokenize(" !&|()\t");
142 Int_t ntokens = tokens->GetEntriesFast();
143 for( Int_t i=0; i<ntokens; i++ ) {
144 TObjString* iname = (TObjString*)tokens->At( i );
146 if (!interactions.FindObject(iname->String().Data())) {
147 AliError( Form( "The trigger interaction (%s) is not available for past-future protection (%s)",
148 iname->String().Data(), GetName() ) );