BOSS 7.1.1
BESIII Offline Software System
Loading...
Searching...
No Matches
TofConverter Class Reference

#include <TofConverter.h>

Public Member Functions

StatusCode convert (const BufferHolder &src, TofDigiCol *des, LumiDigiCol *des2=0)
 
StatusCode convert (const BufferHolder &tof, const BufferHolder &etf, TofDigiCol *des, LumiDigiCol *des2=0)
 
StatusCode convert (TofDigiCol *src, WriteRawEvent *&des)
 

Static Public Member Functions

static TofConverterinstance ()
 
static void destroy ()
 

Detailed Description

Definition at line 10 of file TofConverter.h.

Member Function Documentation

◆ convert() [1/3]

StatusCode TofConverter::convert ( const BufferHolder & src,
TofDigiCol * des,
LumiDigiCol * des2 = 0 )

Definition at line 23 of file TofConverter.cxx.

24{
25 BufferHolder tmp;
26 return this->convert(src, tmp, des, des2);
27}
StatusCode convert(const BufferHolder &src, TofDigiCol *des, LumiDigiCol *des2=0)

Referenced by convert(), RawDataTofDigiCnv::createObj(), RawDataTofDigiCnv::createRep(), MixerAlg::decodeTof(), and RawEventReader::execute().

◆ convert() [2/3]

StatusCode TofConverter::convert ( const BufferHolder & tof,
const BufferHolder & etf,
TofDigiCol * des,
LumiDigiCol * des2 = 0 )

Definition at line 29 of file TofConverter.cxx.

33{
34 uint32_t REId, TEId, TEData, TEOverflow, TETorQ;
35 uint32_t n1buf = tof.nBuf();
36 uint32_t n2buf = etf.nBuf();
37 uint32_t nbuf = n1buf + n2buf;
38
39 TofDigi* tofDigi;
40 typedef std::multimap<uint32_t, TofDigi*>::iterator my_iter;
41 std::multimap<uint32_t, TofDigi*> mapIdData;
42 my_iter it;
43
44 for (uint32_t i = 0; i < nbuf; ++i) {
45 bool isTof = (i < n1buf);
46 const BufferHolder& rBH = isTof ? tof : etf;
47 uint32_t ii = isTof ? i : (i-n1buf);
48 uint32_t* buf = rBH(ii);
49 uint32_t bufSize = rBH.bufSize(ii);
50 for (uint32_t j = 0; j < bufSize; ++j) {
51 if ( isTof ) {
52 m_builder.unPack(buf[j], REId, TEData, TEOverflow, TETorQ);
53 TEId = m_builder.getTEID( REId);
54 }
55 else { //ETF
56 this->unPackETF(buf[j], TEId, TEData, TEOverflow, TETorQ);
57 }
58
59 if ( TEId == 0xFFFFFFFF ) {
60 uint32_t data_unit = buf[j];
61 if ( (data_unit >> 25) == 0x7F ) {
62 tofDigi = new TofDigi(Identifier(0xFFFFFFFF), 0x7FFFFFFF, 0x7FFFFFFF);
63 tofDigi->setOverflow(data_unit);
64 des->push_back(tofDigi);
65 }
66 continue;
67 }
68
69 uint32_t count = mapIdData.count(TEId);
70
71 if (count == 0) {
72 if (TETorQ) { //Q
73 tofDigi = new TofDigi(Identifier(TEId), 0x7FFFFFFF, TEData);
74 tofDigi->setOverflow(0x10 | (TEOverflow<<1));
75 }
76 else { //T
77 tofDigi = new TofDigi(Identifier(TEId), TEData, 0x7FFFFFFF);
78 tofDigi->setOverflow(0x20 | TEOverflow);
79 }
80 mapIdData.insert(make_pair(TEId, tofDigi));
81 }
82 else {
83 pair<my_iter, my_iter> range = mapIdData.equal_range(TEId);
84 it = range.first;
85 tofDigi = it->second;
86 if (TETorQ) { //Q
87 if (tofDigi->getChargeChannel() == 0x7FFFFFFF) { //matched Q and T, first Q
88 tofDigi->setChargeChannel(TEData);
89 tofDigi->setOverflow((tofDigi->getOverflow() | (TEOverflow<<1)) & 0xF);
90 while ((++it) != range.second) { //multiT
91 tofDigi = it->second;
92 tofDigi->setOverflow(tofDigi->getOverflow() & 0xF);
93 }
94 }
95 else { //multiQ
96 uint32_t flag = (tofDigi->getOverflow() & 0x3C) | 8;
97 while (it != range.second) {
98 tofDigi = (it++)->second;
99 tofDigi->setOverflow((tofDigi->getOverflow()&0x3) | flag);
100 }
101 tofDigi = new TofDigi(Identifier(TEId), 0x7FFFFFFF, TEData);
102 tofDigi->setOverflow(flag | (TEOverflow<<1));
103 mapIdData.insert(make_pair(TEId, tofDigi));
104 }
105 }
106 else { //T
107 if (tofDigi->getTimeChannel() == 0x7FFFFFFF) { //matched T and Q, firstT
108 tofDigi->setTimeChannel(TEData);
109 tofDigi->setOverflow((tofDigi->getOverflow() | TEOverflow) & 0xF);
110 while ((++it) != range.second) { //multiQ
111 tofDigi = it->second;
112 tofDigi->setOverflow(tofDigi->getOverflow() & 0xF);
113 }
114 }
115 else { //multiT
116 uint32_t flag = (tofDigi->getOverflow() & 0x3C) | 4;
117 while (it != range.second) {
118 tofDigi = (it++)->second;
119 tofDigi->setOverflow((tofDigi->getOverflow()&0x3) | flag);
120 }
121 tofDigi = new TofDigi(Identifier(TEId), TEData, 0x7FFFFFFF);
122 tofDigi->setOverflow(flag | TEOverflow);
123 mapIdData.insert(make_pair(TEId, tofDigi));
124 }
125 }
126 }
127 }
128 }
129
130 my_iter end = mapIdData.end();
131 for (it = mapIdData.begin(); it != end; ++it) {
132 TEId = it->first;
133 tofDigi = it->second;
134 if ( (TEId&0xFFFF7FFF) != 0x20000060 ) {
135 des->push_back(tofDigi);
136 }
137 //zoujh: for luminosity
138 else {
139 if (des2 != 0) {
140 des2->push_back(new LumiDigi(tofDigi));
141 }
142 delete tofDigi;
143 }
144 }
145
146 return StatusCode::SUCCESS;
147}
DOUBLE_PRECISION count[3]
uint32_t nBuf() const
uint32_t bufSize(int i) const
void setChargeChannel(const unsigned int chargeChannel)
Definition RawData.cxx:30
unsigned int getChargeChannel() const
Definition RawData.cxx:45
void setTimeChannel(const unsigned int timeChannel)
Definition RawData.cxx:25
unsigned int getTimeChannel() const
Definition RawData.cxx:40
virtual uint32_t getTEID(uint32_t reid)
Definition TofBuilder.h:16
virtual void unPack(uint32_t reDigi, uint32_t &REId, uint32_t &TEData, uint32_t &overFlow, uint32_t &TorQ)
unsigned int getOverflow()
Definition TofDigi.h:26
void setOverflow(const unsigned int overflow)
Definition TofDigi.h:23

◆ convert() [3/3]

StatusCode TofConverter::convert ( TofDigiCol * src,
WriteRawEvent *& des )

Definition at line 149 of file TofConverter.cxx.

150{
151 return m_builder.pack(src, des);
152}
virtual StatusCode pack(TofDigiCol *digiCol, WriteRawEvent *&re)

◆ destroy()

void TofConverter::destroy ( )
static

Definition at line 15 of file TofConverter.cxx.

16{
17 if ( s_instance != 0 ) {
18 delete s_instance;
19 s_instance = 0;
20 }
21}

Referenced by RawDataTofDigiCnv::~RawDataTofDigiCnv(), and RawEventReader::~RawEventReader().

◆ instance()

TofConverter * TofConverter::instance ( )
static

Definition at line 6 of file TofConverter.cxx.

7{
8 if ( s_instance == 0 ) {
9 s_instance = new TofConverter();
10 }
11
12 return s_instance;
13}

Referenced by RawDataTofDigiCnv::initialize(), MixerAlg::MixerAlg(), and RawEventReader::RawEventReader().


The documentation for this class was generated from the following files: