ATLAS Offline Software
Loading...
Searching...
No Matches
columnar::TestUtils::ColumnDataMetNames Struct Referencefinal
Inheritance diagram for columnar::TestUtils::ColumnDataMetNames:
Collaboration diagram for columnar::TestUtils::ColumnDataMetNames:

Public Member Functions

 ColumnDataMetNames (const std::string &val_branchName)
virtual bool connect (TTree *tree, std::unordered_map< std::string, const std::vector< ColumnarOffsetType > * > &, std::unordered_map< std::string, ColumnInfo > &requestedColumns) override
virtual void clearColumns () override
virtual void getEntry (Long64_t entry) override
virtual void setData (ColumnVectorData &colData) override
virtual BranchPerfData getPerfData (float emptyTime) override
virtual void collectColumnData () override
void connectColumnIndices (const ColumnVectorHeader &header)
 lookup and store column indices from the header for all enabled output columns

Public Attributes

BranchReader< std::vector< std::string > > branchReader
std::vector< ColumnarOffsetTypeoffsets = {0}
std::vector< char > columnData
std::vector< std::size_t > columnHashData
Benchmark benchmarkUnpack
Benchmark benchmark
std::vector< OutputColumnInfooutputColumns

Detailed Description

Definition at line 1457 of file ColumnarPhysliteTest.cxx.

Constructor & Destructor Documentation

◆ ColumnDataMetNames()

columnar::TestUtils::ColumnDataMetNames::ColumnDataMetNames ( const std::string & val_branchName)
inline

Definition at line 1466 of file ColumnarPhysliteTest.cxx.

1467 : branchReader (val_branchName), benchmarkUnpack (branchReader.columnName()+"(unpack)"), benchmark (branchReader.columnName())
1468 {
1469 outputColumns.push_back ({.name = branchReader.columnName() + ".data"});
1470 outputColumns.push_back ({.name = branchReader.columnName() + ".offset", .isOffset = true});
1471 outputColumns.push_back ({.name = branchReader.columnName() + "Hash"});
1472 }
std::vector< OutputColumnInfo > outputColumns
BranchReader< std::vector< std::string > > branchReader

Member Function Documentation

◆ clearColumns()

virtual void columnar::TestUtils::ColumnDataMetNames::clearColumns ( )
inlineoverridevirtual

Implements columnar::TestUtils::IColumnData.

Definition at line 1505 of file ColumnarPhysliteTest.cxx.

1506 {
1507 columnData.clear();
1508 offsets.clear();
1509 offsets.push_back (0);
1510 columnHashData.clear();
1511 }
std::vector< ColumnarOffsetType > offsets

◆ collectColumnData()

virtual void columnar::TestUtils::ColumnDataMetNames::collectColumnData ( )
inlineoverridevirtual

Implements columnar::TestUtils::IColumnData.

Definition at line 1552 of file ColumnarPhysliteTest.cxx.

1553 {}

◆ connect()

virtual bool columnar::TestUtils::ColumnDataMetNames::connect ( TTree * tree,
std::unordered_map< std::string, const std::vector< ColumnarOffsetType > * > & ,
std::unordered_map< std::string, ColumnInfo > & requestedColumns )
inlineoverridevirtual

Implements columnar::TestUtils::IColumnData.

Definition at line 1474 of file ColumnarPhysliteTest.cxx.

1475 {
1476 auto iter = requestedColumns.find (outputColumns.at(0).name);
1477 if (iter == requestedColumns.end())
1478 return false;
1479 outputColumns.at(0).enabled = true;
1480
1481 branchReader.connectTree (tree);
1482
1483 if (iter->second.offsetName != outputColumns.at(1).name)
1484 throw std::runtime_error ("offset name mismatch: " + iter->second.offsetName + " != " + outputColumns.at(1).name);
1485
1486 requestedColumns.erase (iter);
1487
1488 iter = requestedColumns.find (outputColumns.at(1).name);
1489 if (iter == requestedColumns.end())
1490 {
1491 return true;
1492 }
1493 outputColumns.at(1).enabled = true;
1494 requestedColumns.erase (iter);
1495
1496 iter = requestedColumns.find (outputColumns.at(2).name);
1497 if (iter != requestedColumns.end())
1498 {
1499 outputColumns.at(2).enabled = true;
1500 requestedColumns.erase (iter);
1501 }
1502 return true;
1503 }
TChain * tree

◆ connectColumnIndices()

void columnar::TestUtils::IColumnData::connectColumnIndices ( const ColumnVectorHeader & header)
inlineinherited

lookup and store column indices from the header for all enabled output columns

Definition at line 303 of file ColumnarPhysliteTest.cxx.

304 {
305 for (auto& col : outputColumns)
306 {
307 if (col.enabled)
308 col.columnIndex = header.getColumnIndex (col.name);
309 }
310 }

◆ getEntry()

virtual void columnar::TestUtils::ColumnDataMetNames::getEntry ( Long64_t entry)
inlineoverridevirtual

Implements columnar::TestUtils::IColumnData.

Definition at line 1513 of file ColumnarPhysliteTest.cxx.

1514 {
1515 benchmark.startTimer ();
1516 const auto& branchData = branchReader.getEntry (entry);
1517 benchmark.stopTimer ();
1518 benchmarkUnpack.startTimer ();
1519 for (auto& data : branchData)
1520 {
1521 columnData.insert (columnData.end(), data.begin(), data.end());
1522 offsets.push_back (columnData.size());
1523 columnHashData.push_back (std::hash<std::string> () (data));
1524 }
1525 benchmarkUnpack.stopTimer ();
1526 }
char data[hepevt_bytes_allocation_ATLAS]
Definition HepEvt.cxx:11

◆ getPerfData()

virtual BranchPerfData columnar::TestUtils::ColumnDataMetNames::getPerfData ( float emptyTime)
inlinenodiscardoverridevirtual

Implements columnar::TestUtils::IColumnData.

Definition at line 1538 of file ColumnarPhysliteTest.cxx.

1539 {
1540 BranchPerfData result;
1541 result.name = branchReader.columnName();
1542 result.timeRead = benchmark.getEntryTime(emptyTime);
1543 result.timeUnpack = benchmarkUnpack.getEntryTime(emptyTime);
1544 benchmark.setSilence();
1545 benchmarkUnpack.setSilence();
1546 result.entrySize = branchReader.entrySize();
1547 result.uncompressedSize = branchReader.uncompressedSize();
1548 result.numBaskets = branchReader.numBaskets();
1549 return result;
1550 }

◆ setData()

virtual void columnar::TestUtils::ColumnDataMetNames::setData ( ColumnVectorData & colData)
inlineoverridevirtual

Implements columnar::TestUtils::IColumnData.

Definition at line 1528 of file ColumnarPhysliteTest.cxx.

1529 {
1530 if (outputColumns.at(0).columnIndex != ColumnVectorHeader::nullIndex)
1531 colData.setColumn (outputColumns.at(0).columnIndex, columnData.size(), columnData.data());
1532 if (outputColumns.at(1).columnIndex != ColumnVectorHeader::nullIndex)
1533 colData.setColumn (outputColumns.at(1).columnIndex, offsets.size(), offsets.data());
1534 if (outputColumns.at(2).columnIndex != ColumnVectorHeader::nullIndex)
1535 colData.setColumn (outputColumns.at(2).columnIndex, columnHashData.size(), columnHashData.data());
1536 }
static constexpr std::size_t nullIndex
the index used for an invalid index (always has to be 0)

Member Data Documentation

◆ benchmark

Benchmark columnar::TestUtils::ColumnDataMetNames::benchmark

Definition at line 1464 of file ColumnarPhysliteTest.cxx.

◆ benchmarkUnpack

Benchmark columnar::TestUtils::ColumnDataMetNames::benchmarkUnpack

Definition at line 1463 of file ColumnarPhysliteTest.cxx.

◆ branchReader

BranchReader<std::vector<std::string> > columnar::TestUtils::ColumnDataMetNames::branchReader

Definition at line 1459 of file ColumnarPhysliteTest.cxx.

◆ columnData

std::vector<char> columnar::TestUtils::ColumnDataMetNames::columnData

Definition at line 1461 of file ColumnarPhysliteTest.cxx.

◆ columnHashData

std::vector<std::size_t> columnar::TestUtils::ColumnDataMetNames::columnHashData

Definition at line 1462 of file ColumnarPhysliteTest.cxx.

◆ offsets

std::vector<ColumnarOffsetType> columnar::TestUtils::ColumnDataMetNames::offsets = {0}

Definition at line 1460 of file ColumnarPhysliteTest.cxx.

1460{0};

◆ outputColumns

std::vector<OutputColumnInfo> columnar::TestUtils::IColumnData::outputColumns
inherited

Definition at line 296 of file ColumnarPhysliteTest.cxx.


The documentation for this struct was generated from the following file: