]> git.uio.no Git - u/mrichter/AliRoot.git/blobdiff - MUON/AliMUONRawWriter.cxx
Adding commented lines for setting local misalignment data
[u/mrichter/AliRoot.git] / MUON / AliMUONRawWriter.cxx
index 01476bd1cdf18e2a8a426a1d54bf14739ec7930d..f328bc325931d2fa3fb991a8f27c8016e8cee57e 100644 (file)
  * provided "as is" without express or implied warranty.                  *
  **************************************************************************/
 
+/* $Id$ */
+
 ////////////////////////////////////
 //
-// MUON Raw Data generator and reader in ALICE-MUON
+// MUON Raw Data generaton in ALICE-MUON
 // This class version 3 (further details could be found in Alice-note)
 //
 // Implemented non-constant buspatch numbers for tracking
 // Using real mapping (inverse) for tracker
 // For trigger there is no mapping (mapping could be found in AliMUONTriggerCircuit)
 // Ch. Finck july 04
-//
-// Raw2Digits:
-// Using real mapping  for tracker
-// Indranil Das (Adapted for runloader: Ch. Finck) july 05
+// Use memcpy instead of assignment elt by elt
+// Introducing variable DSP numbers, real manu numbers per buspatch for st12
+// Implemented scaler event for Trigger
+// Ch. Finck , Jan. 06
 // 
 ////////////////////////////////////
 
-#include <fstream>
-#include <string>
-
-#include <TClonesArray.h>
+#include "AliMUONRawWriter.h"
 
-#include "AliLoader.h"
 #include "AliBitPacking.h" 
-#include "AliRawReader.h"
+#include "AliLoader.h"
 #include "AliLog.h"
-#include "AliRun.h"
-
 #include "AliMUON.h"
-#include "AliMUONRawWriter.h"
-#include "AliMUONDigit.h"
-
 #include "AliMUONConstants.h"
-#include "AliMUONData.h"
-
-#include "AliMUONSubEventTrigger.h"
 #include "AliMUONDDLTracker.h"
 #include "AliMUONDDLTrigger.h"
-
-#include "AliMUONLocalTrigger.h"
-#include "AliMUONGlobalTrigger.h"
-
-#include "AliMUONGeometrySegmentation.h"
+#include "AliMUONData.h"
+#include "AliMUONDigit.h"
 #include "AliMUONGeometryModule.h"
+#include "AliMUONGeometrySegmentation.h"
 #include "AliMUONGeometryStore.h"
-#include "AliMpSegFactory.h"
+#include "AliMUONGlobalTrigger.h"
+#include "AliMUONLocalTrigger.h"
+#include "AliMUONScalerEventTrigger.h"
+#include "AliMUONSubEventTrigger.h"
+#include "AliMpBusPatch.h"
+#include "AliMpDEManager.h"
+#include "AliMpPad.h"
 #include "AliMpPlaneType.h"
+#include "AliMpSegFactory.h"
+#include "AliMpStationType.h"
 #include "AliMpVSegmentation.h"
-#include "AliMpHelper.h"
-#include "AliMpPad.h"
+#include "AliRun.h"
+#include "TClonesArray.h"
+ClassImp(AliMUONRawWriter) // Class implementation in ROOT context
+
+Int_t AliMUONRawWriter::fgManuPerBusSwp1B[12]  = {1, 27, 53, 79, 105, 131, 157, 183, 201, 214, 224, 232};
+Int_t AliMUONRawWriter::fgManuPerBusSwp1NB[12] = {1, 27, 53, 79, 105, 131, 157, 183, 201, 214, 225, 233};
+
+Int_t AliMUONRawWriter::fgManuPerBusSwp2B[12]  = {1, 27, 53, 79, 105, 131, 157, 183, 201, 214, 226, 246};
+Int_t AliMUONRawWriter::fgManuPerBusSwp2NB[12] = {1, 27, 53, 79, 105, 131, 157, 183, 201, 214, 227, 245};
 
 
-ClassImp(AliMUONRawWriter) // Class implementation in ROOT context
 //__________________________________________________________________________
-AliMUONRawWriter::AliMUONRawWriter(AliLoader* loader,  AliMUONData* data)
-  : TObject()
+AliMUONRawWriter::AliMUONRawWriter(AliMUONData* data)
+: TObject(),
+  fScalerEvent(kFALSE)
 {
   // Standard Constructor
  
-  // initialize loader's
-  fLoader = loader;
-
-  // initialize segmentation factory
-  fSegFactory = new AliMpSegFactory();
-
+  AliDebug(1,"Standard ctor");
+      
   // initialize container
-//   fMUONData  = new AliMUONData(fLoader,"MUON","MUON");
   fMUONData  = data;
 
   // initialize array
   fSubEventArray = new TClonesArray("AliMUONSubEventTracker",1000);
-
+  fSubEventArray->SetOwner(kTRUE);
 
   // ddl pointer
   fDDLTracker = new AliMUONDDLTracker();
@@ -97,20 +95,30 @@ AliMUONRawWriter::AliMUONRawWriter(AliLoader* loader,  AliMUONData* data)
   fBusPatchManager = new AliMpBusPatch();
   fBusPatchManager->ReadBusPatchFile();
 
+  fSegFactory = new AliMpSegFactory();
+
+  fTrackerTimer.Start(kTRUE); fTrackerTimer.Stop();
+  fTriggerTimer.Start(kTRUE); fTriggerTimer.Stop();
+  fMappingTimer.Start(kTRUE); fMappingTimer.Stop();
+  
 }
 
 //__________________________________________________________________________
 AliMUONRawWriter::AliMUONRawWriter()
   : TObject(),
     fMUONData(0),
-    fLoader(0),    
-    fSegFactory(0),
     fDDLTracker(0),
-    fDDLTrigger(0)
+    fDDLTrigger(0),
+    fBusPatchManager(0),
+    fScalerEvent(kFALSE),
+    fSegFactory(0x0)
 {
   // Default Constructor
-  fFile[0] = fFile[1] = 0x0;
-  
+  AliDebug(1,"Default ctor");   
+  fFile[0] = fFile[1] = 0x0;  
+  fTrackerTimer.Start(kTRUE); fTrackerTimer.Stop();
+  fTriggerTimer.Start(kTRUE); fTriggerTimer.Stop();
+  fMappingTimer.Start(kTRUE); fMappingTimer.Stop();
 }
 
 //_______________________________________________________________________
@@ -138,22 +146,26 @@ AliMUONRawWriter::operator=(const AliMUONRawWriter& rhs)
 //__________________________________________________________________________
 AliMUONRawWriter::~AliMUONRawWriter(void)
 {
-  if (fSegFactory) 
-    fSegFactory->DeleteSegmentations();
-  delete fSegFactory;  
-
-  if (fSubEventArray)
-    fSubEventArray->Delete(); //using delete cos allocating memory in copy ctor.
-
-  if (fDDLTracker)
-    delete fDDLTracker;
-  if (fDDLTrigger)
-    delete fDDLTrigger;
-
-  fBusPatchManager->Delete();
+  AliDebug(1,"dtor");
+  
+  delete fSubEventArray;
+  
+  delete fDDLTracker;
+  delete fDDLTrigger;
 
-  return;
+  delete fBusPatchManager;
+  
+  delete fSegFactory;
+  
+  AliInfo(Form("Execution time for MUON tracker : R:%.2fs C:%.2fs",
+               fTrackerTimer.RealTime(),fTrackerTimer.CpuTime()));
+  AliInfo(Form("   Execution time for MUON tracker (mapping calls part) "
+               ": R:%.2fs C:%.2fs",
+               fMappingTimer.RealTime(),fMappingTimer.CpuTime()));
+  AliInfo(Form("Execution time for MUON trigger : R:%.2fs C:%.2fs",
+               fTriggerTimer.RealTime(),fTriggerTimer.CpuTime()));
 }
+
 //____________________________________________________________________
 Int_t AliMUONRawWriter::Digits2Raw()
 {
@@ -162,15 +174,20 @@ Int_t AliMUONRawWriter::Digits2Raw()
   Int_t idDDL;
   Char_t name[20];
 
-  fLoader->LoadDigits("READ");
+  fMUONData->GetLoader()->LoadDigits("READ");
 
   fMUONData->SetTreeAddress("D,GLT");
 
-
+  fMUONData->ResetDigits();
+  fMUONData->ResetTrigger();
+  
+  // This will get both tracker and trigger digits.
+  fMUONData->GetDigits();
+  
   // tracking chambers
 
-  for (Int_t ich = 0; ich < AliMUONConstants::NTrackingCh(); ich++) {
+  for (Int_t ich = 0; ich < AliMUONConstants::NTrackingCh(); ich++) 
+  {
     // open files
     idDDL = ich * 2  + 0x900; // official number for MUON
     sprintf(name, "MUON_%d.ddl",idDDL);
@@ -179,13 +196,12 @@ Int_t AliMUONRawWriter::Digits2Raw()
     idDDL = (ich * 2) + 1 + 0x900;
     sprintf(name, "MUON_%d.ddl",idDDL);
     fFile[1] = fopen(name,"w");
-
+    
     WriteTrackerDDL(ich);
   
     // reset and close
     fclose(fFile[0]);
     fclose(fFile[1]);
-    fMUONData->ResetDigits();
   }
  
   // trigger chambers
@@ -204,36 +220,35 @@ Int_t AliMUONRawWriter::Digits2Raw()
   // reset and close
   fclose(fFile[0]);
   fclose(fFile[1]);
-  fMUONData->ResetTrigger();
-  
-  fLoader->UnloadDigits();
+
+  fMUONData->ResetDigits();
+  fMUONData->ResetTrigger();  
+  fMUONData->GetLoader()->UnloadDigits();
 
   return kTRUE;
 }
+
 //____________________________________________________________________
 Int_t AliMUONRawWriter::WriteTrackerDDL(Int_t iCh)
 {
   // writing DDL for tracker
   // used inverse mapping
 
+  fTrackerTimer.Start(kFALSE);
+  
+  static const Int_t MAXADC = (1<<12)-1; // We code the charge on a 12 bits ADC.
   // resets
   TClonesArray* muonDigits = 0;
-  fSubEventArray->Clear();
+  fSubEventArray->Delete();
 
   //
-  TArrayI nbInBus;
-
-  nbInBus.Set(5000);
-
+  TArrayI nbInBus(5000);
   nbInBus.Reset();
 
   // DDL header
   AliRawDataHeader header = fDDLTracker->GetHeader();
   Int_t headerSize = fDDLTracker->GetHeaderSize();
 
-  // DDL event one per half chamber
-  AliMUONSubEventTracker* subEvent;
-
   // data format
   Char_t parity = 0x4;
   UShort_t manuId = 0;
@@ -257,9 +272,6 @@ Int_t AliMUONRawWriter::WriteTrackerDDL(Int_t iCh)
 
   AliDebug(3, Form("WriteDDL chamber %d\n", iCh+1));
 
-  // getting digits
-  fMUONData->ResetDigits();
-  fMUONData->GetDigits();
   muonDigits = fMUONData->Digits(iCh);
 
   nDigits = muonDigits->GetEntriesFast();
@@ -272,36 +284,52 @@ Int_t AliMUONRawWriter::WriteTrackerDDL(Int_t iCh)
 
     padX = digit->PadX();
     padY = digit->PadY();
-    charge = digit->Signal();
-    charge &= 0xFFF;
+    charge = digit->ADC();
+    if ( charge > MAXADC )
+    {
+      // This is most probably an error in the digitizer (which should insure
+      // the adc is below MAXADC), so make it a (non-fatal) error indeed.
+      AliError(Form("adc value %d above %x. Setting to %x",
+                      charge,MAXADC,MAXADC));
+      charge = MAXADC;
+    }
     cathode = digit->Cathode();
     detElemId = digit->DetElemId();
 
     // inverse mapping
-    Int_t error = GetInvMapping(digit, busPatchId, manuId, channelId);
-    if (error) continue;
-
-    AliDebug(3,Form("input  IdDE %d busPatchId %d PadX %d PadY %d iCath %d \n", 
+    busPatchId = GetBusPatch(*digit);
+    if (busPatchId<0) continue;
+
+    if ( digit->ManuId() > 0x7FF || digit->ManuId() < 0 ||
+         digit->ManuChannel() > 0x3F || digit->ManuChannel() < 0 )
+    {
+      StdoutToAliError(digit->Print(););
+      AliFatal("ManuId,ManuChannel are invalid for the digit above.");
+    }
+    
+    manuId = ( digit->ManuId() & 0x7FF ); // 11 bits
+    channelId = ( digit->ManuChannel() & 0x3F ); // 6 bits
+    
+    AliDebug(3,Form("input  detElemId %d busPatchId %d PadX %d PadY %d iCath %d \n", 
                    detElemId, busPatchId, padX, padY, cathode));
-
+    
     AliDebug(3,Form("busPatchId %d, manuId %d channelId %d\n", busPatchId, manuId, channelId ));
-
+          
     //packing word
     AliBitPacking::PackWord((UInt_t)parity,word,29,31);
     AliBitPacking::PackWord((UInt_t)manuId,word,18,28);
     AliBitPacking::PackWord((UInt_t)channelId,word,12,17);
     AliBitPacking::PackWord((UInt_t)charge,word,0,11);
 
+    // DDL event one per half chamber
+    AliMUONSubEventTracker subEvent;
     // set sub Event
-    subEvent = new AliMUONSubEventTracker();
-    subEvent->AddData(word);
-    subEvent->SetBusPatchId(busPatchId);
+    subEvent.AddData(word);
+    subEvent.SetBusPatchId(busPatchId);
        
     // storing the number of identical buspatches
     nbInBus[busPatchId]++;
     AddData(subEvent);
-   
-    delete subEvent;
   }
 
   // sorting by buspatch
@@ -310,13 +338,15 @@ Int_t AliMUONRawWriter::WriteTrackerDDL(Int_t iCh)
   // gather datas from same bus patch
   nEntries = fSubEventArray->GetEntriesFast();
 
-  for (Int_t i = 0; i < nEntries; i++) {
+  for (Int_t i = 0; i < nEntries; i++) 
+  {
     AliMUONSubEventTracker* temp = (AliMUONSubEventTracker*)fSubEventArray->At(i);
     busPatchId = temp->GetBusPatchId();
 
     // add bus patch header, length and total length managed by subevent class
     temp->SetTriggerWord(0xdeadbeef);
-    for (Int_t j = 0; j < nbInBus[busPatchId]-1; j++) {
+    for (Int_t j = 0; j < nbInBus[busPatchId]-1; j++) 
+    {
       AliMUONSubEventTracker* temp1 =  (AliMUONSubEventTracker*)fSubEventArray->At(++i);
       temp->AddData(temp1->GetData(0));
       fSubEventArray->RemoveAt(i) ;
@@ -324,15 +354,18 @@ Int_t AliMUONRawWriter::WriteTrackerDDL(Int_t iCh)
   }
   fSubEventArray->Compress();
 
-  if (AliLog::GetGlobalDebugLevel() == 3) {
+  if (AliLog::GetGlobalDebugLevel() == 3) 
+  {
     nEntries = fSubEventArray->GetEntriesFast();
-    for (Int_t i = 0; i < nEntries; i++) {
+    for (Int_t i = 0; i < nEntries; i++) 
+    {
       AliMUONSubEventTracker* temp =  (AliMUONSubEventTracker*)fSubEventArray->At(i);
       printf("busPatchid back %d\n",temp->GetBusPatchId());
-      for (Int_t j = 0; j < temp->GetLength(); j++) {
-       printf("manuId back %d, ",temp->GetManuId(j));
-       printf("channelId back %d, ",temp->GetChannelId(j));
-       printf("charge back %d\n",temp->GetCharge(j));
+      for (Int_t j = 0; j < temp->GetLength(); j++) 
+      {
+        printf("manuId back %d, ",temp->GetManuId(j));
+        printf("channelId back %d, ",temp->GetChannelId(j));
+        printf("charge back %d\n",temp->GetCharge(j));
       }
     }
     printf("\n");
@@ -355,86 +388,87 @@ Int_t AliMUONRawWriter::WriteTrackerDDL(Int_t iCh)
 
   iBusPatch = iBus0AtCh - 1; // starting point for each chamber
 
-  // nEntries = fSubEventArray->GetEntriesFast();
-  AliMUONSubEventTracker* temp = 0x0;
-
   // open DDL file, on per 1/2 chamber
-  for (Int_t iDDL = 0; iDDL < 2; iDDL++) {
-    
-
+  for (Int_t iDDL = 0; iDDL < 2; iDDL++) 
+  {
     // filling buffer
     buffer = new Int_t [(2048+24)*50]; // 24 words in average for one buspatch and 2048 manu info at most
-
+    
     indexBlk = 0;
     indexDsp = 0;
     index = 0;
-
+    
     // two blocks A and B per DDL
-    for (Int_t iBlock = 0; iBlock < 2; iBlock++) {
-
+    for (Int_t iBlock = 0; iBlock < 2; iBlock++) 
+    {
       // block header
       length = fDDLTracker->GetBlkHeaderLength();
       memcpy(&buffer[index],fDDLTracker->GetBlkHeader(),length*4);
       indexBlk = index;
       index += length; 
-
+      
       // 5 DSP's max per block
-      for (Int_t iDsp = 0; iDsp < iDspMax; iDsp++) {
-
-       // DSP header
-       length = fDDLTracker->GetDspHeaderLength();
-       memcpy(&buffer[index],fDDLTracker->GetDspHeader(),length*4);
-       indexDsp = index;
-       index += length; 
-
-       // 5 buspatches max per DSP
-       for (Int_t i = 0; i < iBusPerDSP[iDsp]; i++) {
-
-         iBusPatch ++;
-         if ((fBusPatchManager->GetDDLfromBus(iBusPatch) % 2) == 1) // comparing to DDL file
-           iFile = 0;
-         else
-           iFile = 1;
-
-         AliDebug(3,Form("iCh %d iDDL %d iBlock %d iDsp %d busPatchId %d", iCh, iDDL, iBlock, iDsp, iBusPatch));
-
-         nEntries = fSubEventArray->GetEntriesFast();
-
-         for (Int_t iEntries = 0; iEntries < nEntries; iEntries++) { // method "bourrique"...
-           temp = (AliMUONSubEventTracker*)fSubEventArray->At(iEntries);
-           busPatchId = temp->GetBusPatchId();
-           if (busPatchId == iBusPatch) break;
-           busPatchId = -1;
-           AliDebug(3,Form("busPatchId %d", temp->GetBusPatchId()));
-         } 
-        
-         // check if buspatchid has digit
-         if (busPatchId != -1) {
-           // add bus patch structure
-           length = temp->GetHeaderLength();
-           memcpy(&buffer[index],temp->GetAddress(),length*4);
-           index += length;
-           for (Int_t j = 0; j < temp->GetLength(); j++) {
-             buffer[index++] =  temp->GetData(j);
-             AliDebug(3,Form("busPatchId %d, manuId %d channelId %d\n", temp->GetBusPatchId(), 
-                             temp->GetManuId(j), temp->GetChannelId(j) ));
-           }
-           //        fSubEventArray->RemoveAt(iEntries);
-           //        fSubEventArray->Compress();
-         } else {
-           // writting anyhow buspatch structure (empty ones)
-           buffer[index++] = 4; // total length
-           buffer[index++] = 0; // raw data length
-           buffer[index++] = iBusPatch; // bus patch
-           buffer[index++] = 0xdeadbeef; // trigger word
-         }
-       } // bus patch
-       buffer[indexDsp] = index - indexDsp; // dsp length
-       buffer[indexDsp+1] = index - indexDsp - fDDLTracker->GetDspHeaderLength();
-       if ((index - indexDsp) % 2 == 0)
-         buffer[indexDsp+7] = 0;
-       else
-         buffer[indexDsp+7] = 1;
+      for (Int_t iDsp = 0; iDsp < iDspMax; iDsp++) 
+      {
+        
+        // DSP header
+        length = fDDLTracker->GetDspHeaderLength();
+        memcpy(&buffer[index],fDDLTracker->GetDspHeader(),length*4);
+        indexDsp = index;
+        index += length; 
+        
+        // 5 buspatches max per DSP
+        for (Int_t i = 0; i < iBusPerDSP[iDsp]; i++) 
+        {          
+          iBusPatch ++;
+          if ((fBusPatchManager->GetDDLfromBus(iBusPatch) % 2) == 1) // comparing to DDL file
+            iFile = 0;
+          else
+            iFile = 1;
+          
+          AliDebug(3,Form("iCh %d iDDL %d iBlock %d iDsp %d busPatchId %d", iCh, iDDL, iBlock, iDsp, iBusPatch));
+          
+          nEntries = fSubEventArray->GetEntriesFast();
+          AliMUONSubEventTracker* temp = 0x0;
+         busPatchId = -1;
+          for (Int_t iEntries = 0; iEntries < nEntries; iEntries++)
+          { // method "bourrique"...
+            temp = (AliMUONSubEventTracker*)fSubEventArray->At(iEntries);
+            busPatchId = temp->GetBusPatchId();
+            if (busPatchId == iBusPatch) break;
+            busPatchId = -1;
+            AliDebug(3,Form("busPatchId %d", temp->GetBusPatchId()));
+          } 
+          
+          // check if buspatchid has digit
+          if (busPatchId != -1) 
+          {
+            // add bus patch structure
+            length = temp->GetHeaderLength();
+            memcpy(&buffer[index],temp->GetBusPatchHeader(),length*4);
+            index += length;
+            for (Int_t j = 0; j < temp->GetLength(); j++) 
+            {
+              buffer[index++] =  temp->GetData(j);
+              AliDebug(3,Form("busPatchId %d, manuId %d channelId %d\n", temp->GetBusPatchId(), 
+                              temp->GetManuId(j), temp->GetChannelId(j) ));
+            }
+          }
+          else 
+          {
+            // writting anyhow buspatch structure (empty ones)
+            buffer[index++] = 4; // total length
+            buffer[index++] = 0; // raw data length
+            buffer[index++] = iBusPatch; // bus patch
+            buffer[index++] = 0xdeadbeef; // trigger word
+          }
+        } // bus patch
+        buffer[indexDsp] = index - indexDsp; // dsp length
+        buffer[indexDsp+1] = index - indexDsp - fDDLTracker->GetDspHeaderLength();
+        if ((index - indexDsp) % 2 == 0)
+          buffer[indexDsp+7] = 0;
+        else
+          buffer[indexDsp+7] = 1;
       } // dsp
       buffer[indexBlk] = index - indexBlk; // block length
       buffer[indexBlk+1] = index - indexBlk - fDDLTracker->GetBlkHeaderLength();
@@ -445,19 +479,106 @@ Int_t AliMUONRawWriter::WriteTrackerDDL(Int_t iCh)
     header.fSize = (index + headerSize) * 4;// total length in bytes
     fwrite((char*)(&header),headerSize*4,1,fFile[iFile]);
     fwrite(buffer,sizeof(int),index,fFile[iFile]);
-   
+      
     delete[] buffer;
   }
 
+  fTrackerTimer.Stop();
   return kTRUE;
 }
+
+//____________________________________________________________________
+Int_t AliMUONRawWriter::GetBusPatch(const AliMUONDigit& digit)
+{
+  // Determine the BusPatch this digit belongs to.
+  
+  fMappingTimer.Start(kFALSE);
+  
+  Int_t* ptr = 0;
+
+  // information from digits
+  Int_t detElemId  = digit.DetElemId();
+
+  AliMpVSegmentation* seg = 
+    fSegFactory->CreateMpSegmentationByElectronics(detElemId, digit.ManuId());
+  
+  AliMpPlaneType plane = seg->PlaneType();
+
+  AliMpStationType stationType = AliMpDEManager::GetStationType(detElemId);
+
+  if ( stationType == kStation1 || stationType == kStation2 )
+  {
+    if (plane == kBendingPlane) 
+    {
+      ptr = &fgManuPerBusSwp1B[0];
+    }
+    else 
+    {
+      ptr = &fgManuPerBusSwp1NB[0];
+    }
+  }
+  else
+  {
+    if (plane == kBendingPlane)
+    {
+      ptr = &fgManuPerBusSwp2B[0];
+    }
+    else
+    {
+      ptr = &fgManuPerBusSwp2NB[0];
+    }
+  }
+
+  // Getting buspatch id
+  TArrayI* vec = fBusPatchManager->GetBusfromDE(detElemId);
+  Int_t pos = 0;
+
+  Int_t m = ( digit.ManuId() & 0x3FF ); // remove bit 10
+                                //FIXME : how can we remove that condition
+  // on the 10-th bit ? All the rest need not any knowledge about it,
+  // can't we find a way to get manu<->buspatch transparent to this too ?
+  
+  if ( stationType == kStation1 || stationType == kStation2 )
+  {
+    for (Int_t i = 0; i < 12; i++)
+    {
+      if (m >= *(ptr + pos++)) break;
+    }
+  }
+  else 
+  {
+    // offset of 100 in manuId for following bus patch
+    pos = m/100;
+  }
+
+  if (pos >(Int_t) vec->GetSize())
+  {
+    AliError(Form("pos greater %d than size %d manuId %d detElemId %d \n", 
+                   pos, (Int_t)vec->GetSize(), digit.ManuId(), detElemId));
+    AliError(Form("Chamber %s Plane %s manuId %d m %d",
+                    StationTypeName(stationType).Data(),
+                    PlaneTypeName(plane).Data(),
+                    digit.ManuId(),
+                    m));
+    return -1;
+  }
+  
+  Int_t busPatchId = vec->At(pos);
+
+  fMappingTimer.Stop();
+  
+  return busPatchId;
+}
+
 //____________________________________________________________________
 Int_t AliMUONRawWriter::WriteTriggerDDL()
 {
 
+  fTriggerTimer.Start(kFALSE);
+  
  // DDL event one per half chamber
-  AliMUONSubEventTrigger* subEvent = 0x0;
-
+  AliMUONSubEventTrigger*    subEvent    = 0x0;
+  AliMUONScalerEventTrigger* scalerEvent = 0x0;
 
   // stored local id number 
   TArrayI isFired(256);
@@ -467,15 +588,12 @@ Int_t AliMUONRawWriter::WriteTriggerDDL()
  // DDL header
   AliRawDataHeader header = fDDLTrigger->GetHeader();
   Int_t headerSize = fDDLTrigger->GetHeaderSize();
-  Int_t length;
+
   TClonesArray* localTrigger;
   TClonesArray* globalTrigger;
   AliMUONGlobalTrigger* gloTrg;
   AliMUONLocalTrigger* locTrg = 0x0;
 
-  // getting information from trigger
-  fMUONData->GetTriggerD();
-
   // global trigger for trigger pattern
   globalTrigger = fMUONData->GlobalTrigger(); 
   gloTrg = (AliMUONGlobalTrigger*)globalTrigger->UncheckedAt(0);
@@ -496,6 +614,9 @@ Int_t AliMUONRawWriter::WriteTriggerDDL()
   Int_t serialNb = 0xF; // serial nb of card: all bits on for the moment
   Int_t globalFlag = 1; // set to 2 if global info present in DDL else set to 1
 
+  if(fScalerEvent)
+    eventType = 2; //set to generate scaler events
+
   Int_t nEntries = (Int_t) (localTrigger->GetEntries());// 234 local cards
   // stored the local card id that's fired
   for (Int_t i = 0; i <  nEntries; i++) {
@@ -506,7 +627,17 @@ Int_t AliMUONRawWriter::WriteTriggerDDL()
   if (!nEntries)
     AliError("No Trigger information available");
 
-  buffer = new Int_t [672]; // [16(local)*5 words + 3 words]*8(reg) + 8 words = 672
+  if(fScalerEvent)
+    // [16(local)*50 words + 14 words]*8(reg) + 6 + 10 + 6 words scaler event 6534 words
+    buffer = new Int_t [6534];
+  else
+    // [16(local)*5 words + 3 words]*8(reg) + 8 words = 672 
+    buffer = new Int_t [672];
+
+  if(fScalerEvent) {
+    scalerEvent = new  AliMUONScalerEventTrigger();
+    scalerEvent->SetNumbers(); // set some numbers for scalers
+  }
 
   // open DDL file, on per 1/2 chamber
   for (Int_t iDDL = 0; iDDL < 2; iDDL++) {
@@ -524,16 +655,31 @@ Int_t AliMUONRawWriter::WriteTriggerDDL()
       globalFlag = 2;
     else 
       globalFlag = 1;
+
     AliBitPacking::PackWord((UInt_t)globalFlag,word,8,11);
     fDDLTrigger->SetDDLWord(word);
+    buffer[index++]= word;
 
     if (iDDL == 0)
       fDDLTrigger->SetGlobalOutput(gloTrigPat);// no global input for the moment....
     else 
       fDDLTrigger->SetGlobalOutput(0);
-    length = fDDLTrigger->GetHeaderLength(); 
-    memcpy(&buffer[index],fDDLTrigger->GetEnhancedHeader(),length*4);
-    index += length; 
+
+    if (fScalerEvent) {
+      // 6 DARC scaler words
+      memcpy(&buffer[index], scalerEvent->GetDarcScalers(),scalerEvent->GetDarcScalerLength()*4);
+      index += scalerEvent->GetDarcScalerLength();
+    }
+
+    // 4 words of global board input + Global board output
+    memcpy(&buffer[index], fDDLTrigger->GetGlobalInput(), (fDDLTrigger->GetHeaderLength()-1)*4); 
+    index += fDDLTrigger->GetHeaderLength() - 1; // kind tricky cos scaler info in-between Darc header
+
+    if (fScalerEvent) {
+      // 10 Global scaler words
+      memcpy(scalerEvent->GetGlobalScalers(), &buffer[index], scalerEvent->GetGlobalScalerLength()*4);
+      index += scalerEvent->GetGlobalScalerLength();
+    }
 
     // 8 regional cards per DDL
     for (Int_t iReg = 0; iReg < 8; iReg++) {
@@ -549,10 +695,14 @@ Int_t AliMUONRawWriter::WriteTriggerDDL()
       AliBitPacking::PackWord((UInt_t)regOut,word,0,7); // whenever regional output will be implemented
 
       subEvent->SetRegWord(word);
-      memcpy(&buffer[index++],subEvent->GetAddress(),4);
+      memcpy(&buffer[index],subEvent->GetRegHeader(),subEvent->GetRegHeaderLength()*4);
+      index += subEvent->GetRegHeaderLength();
 
-      buffer[index++] = 0;// 2 words of regional input
-      buffer[index++] = 0;
+      // 11 regional scaler word
+      if (fScalerEvent) {
+       memcpy(&buffer[index], scalerEvent->GetRegScalers(), scalerEvent->GetRegScalerLength()*4);
+       index += scalerEvent->GetRegScalerLength();
+      }
 
       // 16 local card per regional board
       for (Int_t iLoc = 0; iLoc < 16; iLoc++) {
@@ -604,6 +754,12 @@ Int_t AliMUONRawWriter::WriteTriggerDDL()
          buffer[index++] = (Int_t)word; // data word
 
        }
+       // 45 regional scaler word
+       if (fScalerEvent) {
+         memcpy(&buffer[index], scalerEvent->GetLocalScalers(), scalerEvent->GetLocalScalerLength()*4);
+         index += scalerEvent->GetLocalScalerLength();
+       }
+
       } // local card 
 
       delete subEvent; 
@@ -622,85 +778,11 @@ Int_t AliMUONRawWriter::WriteTriggerDDL()
   }
   delete[] buffer;
 
-  return kTRUE;
-}
-
-//____________________________________________________________________
-Int_t AliMUONRawWriter::GetInvMapping(const AliMUONDigit* digit,
-                                    Int_t &busPatchId, UShort_t &manuId, UChar_t &channelId)
-{
+  delete scalerEvent;
 
-  // Inverse mapping for tracker
-
-  // information from digits
-  Int_t iCath = digit->Cathode();
-  Int_t idDE  = digit->DetElemId();
-  Int_t padX  = digit->PadX();
-  Int_t padY  = digit->PadY();
-
-  if (idDE >= 500) { // Since in AliMpSlat pads begin at (0,0) 
-    padX--;         // while in AliMUONSt345Seg. they begin at (1,1)
-    padY--;
-  }
-
-  // segmentation
-  AliMpPlaneType plane;
-  AliMpPlaneType plane1 = kBendingPlane;
-  AliMpPlaneType plane2 = kNonBendingPlane;
-
-  if (idDE < 500) { // should use GetDirection somehow (ChF)
-    if ( ((idDE % 100) % 2) != 0 ) {
-      plane1 = kNonBendingPlane;
-      plane2 = kBendingPlane;
-    }
-  }
-  // station 345 bending == cath0 for the moment
-   plane = (iCath == 0) ? plane1 : plane2;
-
-  //AliMpVSegmentation* seg = AliMUONSegmentationManager::Segmentation(idDE, plane);
-  AliMpVSegmentation* seg = fSegFactory->CreateMpSegmentation(idDE, iCath);
-  AliMpPad pad = seg->PadByIndices(AliMpIntPair(padX,padY),kTRUE);
-
-  if(!pad.IsValid()) {
-     AliWarning(Form("No elec. for idDE: %d, padx: %d pady %d, charge: %d\n",
-                 idDE, digit->PadX(), digit->PadY(), digit->Signal()));
-    return kTRUE;
-  }
-
-  // Getting Manu id
-  manuId = pad.GetLocation().GetFirst();
-  manuId &= 0x7FF; // 11 bits 
-
-  // Getting channel id
-  channelId =  pad.GetLocation().GetSecond();
-  channelId &= 0x3F; // 6 bits
-
-  // Getting buspatch id
-  TArrayI* vec = fBusPatchManager->GetBusfromDE(idDE);
-  Int_t pos;
-
-  if (idDE < 500) { // station 1 & 2
-    // set 32 manus for one bus patch ? (ChF)
-    pos = manuId/32;
-  } else {
-    // offset of 100 in manuId for following bus patch
-    pos = manuId/100;
-  }
-
- //  if (pos >(int_t) vec.size())
-//     AliWarning("pos greater than size\n");
-  busPatchId = vec->At(pos);
-
-  if (plane ==  kNonBendingPlane) // for Non-Bending manuid+= 1000;
-    manuId += 1000; // tmp solution til one finds something better  (ChF)
+  fTriggerTimer.Stop();
   
-  AliDebug(3,Form("idDE: %d, busPatchId %d, manuId: %d, channelId:%d\n",
-                 idDE, busPatchId, manuId, channelId));
-
-  AliDebug(3,Form("idDE: %d, busPatchId %d, manuId: %d, channelId: %d, padx: %d pady: %d, charge: %d\n",
-                 idDE, busPatchId, manuId, channelId, digit->PadX(), digit->PadY(), digit->Signal()));
-
-  return kFALSE; // no error
+  return kTRUE;
 }
 
 //____________________________________________________________________