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 (TestUtils::ToolWrapperData &tool) override
virtual BranchPerfData getPerfData (float emptyTime) override
virtual void collectColumnData () override

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 1462 of file ColumnarPhysliteTest.cxx.

Constructor & Destructor Documentation

◆ ColumnDataMetNames()

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

Definition at line 1471 of file ColumnarPhysliteTest.cxx.

1472 : branchReader (val_branchName), benchmarkUnpack (branchReader.columnName()+"(unpack)"), benchmark (branchReader.columnName())
1473 {
1474 outputColumns.push_back ({.name = branchReader.columnName() + ".data"});
1475 outputColumns.push_back ({.name = branchReader.columnName() + ".offset", .isOffset = true});
1476 outputColumns.push_back ({.name = branchReader.columnName() + "Hash"});
1477 }
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 1510 of file ColumnarPhysliteTest.cxx.

1511 {
1512 columnData.clear();
1513 offsets.clear();
1514 offsets.push_back (0);
1515 columnHashData.clear();
1516 }
std::vector< ColumnarOffsetType > offsets

◆ collectColumnData()

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

Implements columnar::TestUtils::IColumnData.

Definition at line 1557 of file ColumnarPhysliteTest.cxx.

1558 {}

◆ 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 1479 of file ColumnarPhysliteTest.cxx.

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

◆ getEntry()

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

Implements columnar::TestUtils::IColumnData.

Definition at line 1518 of file ColumnarPhysliteTest.cxx.

1519 {
1520 benchmark.startTimer ();
1521 const auto& branchData = branchReader.getEntry (entry);
1522 benchmark.stopTimer ();
1523 benchmarkUnpack.startTimer ();
1524 for (auto& data : branchData)
1525 {
1526 columnData.insert (columnData.end(), data.begin(), data.end());
1527 offsets.push_back (columnData.size());
1528 columnHashData.push_back (std::hash<std::string> () (data));
1529 }
1530 benchmarkUnpack.stopTimer ();
1531 }
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 1543 of file ColumnarPhysliteTest.cxx.

1544 {
1545 BranchPerfData result;
1546 result.name = branchReader.columnName();
1547 result.timeRead = benchmark.getEntryTime(emptyTime);
1548 result.timeUnpack = benchmarkUnpack.getEntryTime(emptyTime);
1549 benchmark.setSilence();
1550 benchmarkUnpack.setSilence();
1551 result.entrySize = branchReader.entrySize();
1552 result.uncompressedSize = branchReader.uncompressedSize();
1553 result.numBaskets = branchReader.numBaskets();
1554 return result;
1555 }

◆ setData()

virtual void columnar::TestUtils::ColumnDataMetNames::setData ( TestUtils::ToolWrapperData & tool)
inlineoverridevirtual

Implements columnar::TestUtils::IColumnData.

Definition at line 1533 of file ColumnarPhysliteTest.cxx.

1534 {
1535 if (outputColumns.at(0).enabled)
1536 tool.setColumn (outputColumns.at(0).name, columnData.size(), columnData.data());
1537 if (outputColumns.at(1).enabled)
1538 tool.setColumn (outputColumns.at(1).name, offsets.size(), offsets.data());
1539 if (outputColumns.at(2).enabled)
1540 tool.setColumn (outputColumns.at(2).name, columnHashData.size(), columnHashData.data());
1541 }

Member Data Documentation

◆ benchmark

Benchmark columnar::TestUtils::ColumnDataMetNames::benchmark

Definition at line 1469 of file ColumnarPhysliteTest.cxx.

◆ benchmarkUnpack

Benchmark columnar::TestUtils::ColumnDataMetNames::benchmarkUnpack

Definition at line 1468 of file ColumnarPhysliteTest.cxx.

◆ branchReader

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

Definition at line 1464 of file ColumnarPhysliteTest.cxx.

◆ columnData

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

Definition at line 1466 of file ColumnarPhysliteTest.cxx.

◆ columnHashData

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

Definition at line 1467 of file ColumnarPhysliteTest.cxx.

◆ offsets

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

Definition at line 1465 of file ColumnarPhysliteTest.cxx.

1465{0};

◆ outputColumns

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

Definition at line 311 of file ColumnarPhysliteTest.cxx.


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