LCOV - code coverage report
Current view: top level - HLT/MUON/OfflineInterface - AliHLTMUONESDMaker.h (source / functions) Hit Total Coverage
Test: coverage.info Lines: 1 1 100.0 %
Date: 2016-06-14 17:26:59 Functions: 1 5 20.0 %

          Line data    Source code
       1             : #ifndef ALIHLTMUONESDMAKER_H
       2             : #define ALIHLTMUONESDMAKER_H
       3             : /* This file is property of and copyright by the ALICE HLT Project        *
       4             :  * ALICE Experiment at CERN, All rights reserved.                         *
       5             :  * See cxx source for full Copyright notice                               */
       6             : 
       7             : // $Id: $
       8             : 
       9             : ///
      10             : /// @file   AliHLTMUONESDMaker.h
      11             : /// @author Artur Szostak <artursz@iafrica.com>
      12             : /// @date   30 June 2008
      13             : /// @brief  Component for converting dHLT raw data into AliESDEvent objects.
      14             : ///
      15             : 
      16             : #include "AliHLTMUONProcessor.h"
      17             : #include <vector>
      18             : 
      19             : extern "C" struct AliHLTMUONTriggerRecordStruct;
      20             : class AliESDMuonTrack;
      21             : class AliESDEvent;
      22             : 
      23             : /**
      24             :  * @class AliHLTMUONESDMaker
      25             :  * \brief Component for converting dHLT results into ESD format.
      26             :  *
      27             :  * The component is used to convert dHLT reconstructed data into AliESDEvent
      28             :  * objects which can be stored in ROOT files during offline reconstruction.
      29             :  * Only the dHLT track and trigger record data is converted, then filled in the ESD.
      30             :  * These should then be merged together with ESDs from all the other parts of
      31             :  * HLT (eg. TPC HLT).<br>
      32             :  * This component can also be run online to have ESDs directly in the raw
      33             :  * HLT output data stream.<br>
      34             :  *
      35             :  * Component ID: \b MUONESDMaker <br>
      36             :  * Library: \b libAliHLTMUON.so  <br>
      37             :  *
      38             :  * Optional arguments:<br>
      39             :  * \li -make_minimal_esd <br>
      40             :  *       Indicates that AliESDEvent objects should be created with only the TClonesArray
      41             :  *       for the muon tracks created. (default is to generate all standard ESD objects)<br>
      42             :  * \li -add_rootified_objects <br>
      43             :  *       If specified then the any rootified dHLT event data that is found is added to the
      44             :  *       ESD list of objects as a custom data object.<br>
      45             :  * \li -makeclonesarray <br>
      46             :  *      This option will cause the component to generate a TClonesArray of MUON ESD tracks
      47             :  *      and send it as a kAliHLTDataTypeTObject data block type. <br>
      48             :  * \li -makeonlyclonesarray <br>
      49             :  *      Same as the -makeclonesarray option, however the data block with the AliESDEvent
      50             :  *      object is not generated at all. <br>
      51             :  * \li -warn_on_unexpected_block <br>
      52             :  *       If set, then warning messages are generated for any data block types that
      53             :  *       were not expected. (default is to generate only debug messages)<br>
      54             :  * \li -dumponerror <br>
      55             :  *      This flag will cause the component to dump the data blocks it received if
      56             :  *      an error occurs during the processing of an event. <br>
      57             :  * \li -dumppath <i>path</i> <br>
      58             :  *      Allows one to specify the path in which to dump the received data blocks
      59             :  *      if an error occurs. <br>
      60             :  *
      61             :  * @ingroup alihlt_muon_components
      62             :  */
      63             : class AliHLTMUONESDMaker : public AliHLTMUONProcessor
      64             : {
      65             : public:
      66             : 
      67             :         AliHLTMUONESDMaker();
      68             :         virtual ~AliHLTMUONESDMaker();
      69             :         
      70             :         virtual const char* GetComponentID();
      71             : 
      72             :         virtual void GetInputDataTypes(AliHLTComponentDataTypeList& list);
      73             :         virtual AliHLTComponentDataType GetOutputDataType();
      74             :         virtual int GetOutputDataTypes(AliHLTComponentDataTypeList& list);
      75             :         virtual void GetOutputDataSize(unsigned long& constBase, double& inputMultiplier);
      76             : 
      77             :         virtual AliHLTComponent* Spawn();
      78             : 
      79             : protected:
      80             : 
      81             :         virtual int DoInit(int argc, const char** argv);
      82             :         virtual int DoDeinit();
      83             :         virtual int DoEvent(const AliHLTComponentEventData& evtData, AliHLTComponentTriggerData& trigData);
      84             :         virtual bool IgnoreArgument(const char* arg) const;
      85             :         using AliHLTProcessor::DoEvent;
      86             :         
      87             : private:
      88             : 
      89             :         // Prevent copying of these objects.
      90             :         AliHLTMUONESDMaker(const AliHLTMUONESDMaker& /*object*/);
      91             :         AliHLTMUONESDMaker& operator = (const AliHLTMUONESDMaker& /*object*/);
      92             :         
      93             :         typedef std::vector<const AliHLTMUONTriggerRecordStruct*> AliTriggerRecordList;
      94             :         
      95             :         /**
      96             :          * Finds the trigger record with the specified ID in the list of trigger records
      97             :          * and then fills the ESD muon track structure with the information.
      98             :          * \param [in] triggerRecords  The list of trigger records to search in.
      99             :          * \param [in] trigRecId  The trigger record ID to seach for.
     100             :          * \param [in] trackId  The track ID of the track structure where the trigger
     101             :          *                     record ID comes from.
     102             :          * \param [out] muTrack  The track structure to fill.
     103             :          * \param [in,out] event  The ESD event to store the new hits
     104             :          */
     105             :         void FillTriggerInfo(
     106             :                         const AliTriggerRecordList& triggerRecords,
     107             :                         AliHLTInt32_t trigRecId, AliHLTInt32_t trackId,
     108             :                         AliESDMuonTrack& muTrack, AliESDEvent& event
     109             :                 );
     110             :         
     111             :         bool fWarnForUnexpecedBlock;  /// Flag indicating if we should log a warning if we got a block of an unexpected type.
     112             :         bool fMakeMinimalESD;  /// Flag to indicate if a minimal ESD object should be created.
     113             :         bool fAddCustomData;  /// Flag to turn on adding of all dHLT rootified objects to the ESD.
     114             :         bool fMakeClonesArray;  /// Flag indicating if a data block of TClonesArray with AliESDMuonTrack objects should be generated.
     115             :         bool fMakeESDDataBlock;  /// Flag indicating if the ESD data block should generated.
     116             :         AliHLTUInt32_t fClusterIndex;  /// Running counter for the unique cluster index number.
     117             : 
     118           6 :         ClassDef(AliHLTMUONESDMaker, 0); // Component for converting dHLT reconstructed data into the ESD format.
     119             : };
     120             : 
     121             : #endif // ALIHLTMUONESDMAKER_H

Generated by: LCOV version 1.11