ATLAS Offline Software
Loading...
Searching...
No Matches
columnar::TestUtils::ColumnDataVectorRLink< T, Reader > Struct Template Referencefinal
Inheritance diagram for columnar::TestUtils::ColumnDataVectorRLink< T, Reader >:
Collaboration diagram for columnar::TestUtils::ColumnDataVectorRLink< T, Reader >:

Public Types

using CM = ColumnarModeArray

Public Member Functions

 ColumnDataVectorRLink (const std::string &val_branchName)
virtual bool connect (Backend source, std::unordered_map< std::string, const std::vector< ColumnarOffsetType > * > &offsetColumns, 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

Reader< std::vector< ElementLink< T > > > branchReader
const std::vector< ColumnarOffsetType > * offsetColumn = nullptr
std::vector< ColumnarOffsetTypeoffsets = {0}
LinkColumnVector columnData
Benchmark benchmarkUnpack
Benchmark benchmark
unsigned entries = 0
unsigned nullEntries = 0
std::vector< OutputColumnInfooutputColumns

Detailed Description

template<typename T, template< typename > class Reader>
struct columnar::TestUtils::ColumnDataVectorRLink< T, Reader >

Definition at line 1412 of file ColumnarPhysliteTest.cxx.

Member Typedef Documentation

◆ CM

template<typename T, template< typename > class Reader>
using columnar::TestUtils::ColumnDataVectorRLink< T, Reader >::CM = ColumnarModeArray

Definition at line 1414 of file ColumnarPhysliteTest.cxx.

Constructor & Destructor Documentation

◆ ColumnDataVectorRLink()

template<typename T, template< typename > class Reader>
columnar::TestUtils::ColumnDataVectorRLink< T, Reader >::ColumnDataVectorRLink ( const std::string & val_branchName)
inline

Definition at line 1424 of file ColumnarPhysliteTest.cxx.

1425 : branchReader(val_branchName), benchmarkUnpack(branchReader.columnName() + "(unpack)"), benchmark(branchReader.columnName())
1426 {
1427 outputColumns.push_back({.name = branchReader.columnName()});
1428 outputColumns.push_back({.name = branchReader.containerName(), .isOffset = true, .primary = false});
1429 }
std::vector< OutputColumnInfo > outputColumns

Member Function Documentation

◆ clearColumns()

template<typename T, template< typename > class Reader>
virtual void columnar::TestUtils::ColumnDataVectorRLink< T, Reader >::clearColumns ( )
inlineoverridevirtual

Implements columnar::TestUtils::IColumnData.

Definition at line 1464 of file ColumnarPhysliteTest.cxx.

1465 {
1466 columnData.clear();
1467 offsets.clear();
1468 offsets.push_back(0);
1469 }

◆ collectColumnData()

template<typename T, template< typename > class Reader>
virtual void columnar::TestUtils::ColumnDataVectorRLink< T, Reader >::collectColumnData ( )
inlineoverridevirtual

Implements columnar::TestUtils::IColumnData.

Definition at line 1533 of file ColumnarPhysliteTest.cxx.

1534 {
1535 entries += columnData.size();
1536 for (const auto& index : columnData)
1537 {
1539 nullEntries += 1;
1540 }
1541 }

◆ connect()

template<typename T, template< typename > class Reader>
virtual bool columnar::TestUtils::ColumnDataVectorRLink< T, Reader >::connect ( Backend source,
std::unordered_map< std::string, const std::vector< ColumnarOffsetType > * > & offsetColumns,
std::unordered_map< std::string, ColumnInfo > & requestedColumns )
inlineoverridevirtual

Implements columnar::TestUtils::IColumnData.

Definition at line 1431 of file ColumnarPhysliteTest.cxx.

1432 {
1433 auto iter = requestedColumns.find(outputColumns.at(0).name);
1434 if (iter == requestedColumns.end())
1435 return false;
1436 outputColumns.at(0).enabled = true;
1437
1438 branchReader.connectTree(source);
1439 if (iter->second.offsetName != outputColumns.at(1).name)
1440 throw std::runtime_error ("offset name mismatch: " + iter->second.offsetName + " != " + outputColumns.at(1).name);
1441
1442 for (auto keyColumn : columnData.connect (iter->second, offsetColumns, requestedColumns))
1443 {
1444 outputColumns.push_back ({.name = keyColumn, .primary = false, .enabled = true});
1446 }
1447 requestedColumns.erase (iter);
1448
1449 if (auto offsetIter = offsetColumns.find (outputColumns.at(1).name); offsetIter != offsetColumns.end())
1450 offsetColumn = offsetIter->second;
1451 else
1452 offsetColumns.emplace (outputColumns.at(1).name, &offsets);
1453
1454 iter = requestedColumns.find (outputColumns.at(1).name);
1455 if (iter != requestedColumns.end())
1456 {
1457 outputColumns.at(1).enabled = true;
1458 requestedColumns.erase (iter);
1459 }
1460
1461 return true;
1462 }

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

672 {
673 for (auto& col : outputColumns)
674 {
675 if (col.enabled)
676 col.columnIndex = header.getColumnIndex (col.name);
677 }
678 }

◆ getEntry()

template<typename T, template< typename > class Reader>
virtual void columnar::TestUtils::ColumnDataVectorRLink< T, Reader >::getEntry ( Long64_t entry)
inlineoverridevirtual

Implements columnar::TestUtils::IColumnData.

Definition at line 1471 of file ColumnarPhysliteTest.cxx.

1472 {
1473 benchmark.startTimer();
1474 const auto& branchData = branchReader.getEntry(entry);
1475 benchmark.stopTimer();
1476 benchmarkUnpack.startTimer();
1477
1478 columnData.checkOffsets (offsets.size() - 1);
1479 for (const auto& element : branchData)
1480 {
1481 if (element.isDefault() || element.index() == static_cast<unsigned int>(-1))
1482 columnData.addEmptyLink ();
1483 else
1484 columnData.addSplitLink (element.index(), element.key(), offsets.size()-1);
1485 }
1486
1487
1488 offsets.push_back(columnData.size());
1489
1490 if (offsetColumn) {
1491 if (offsetColumn->size() != offsets.size())
1492 {
1493 throw std::runtime_error("offset column not filled yet: " + outputColumns.at(1).name);
1494 }
1495 if (offsetColumn->back() != offsets.back())
1496 {
1497 throw std::runtime_error("offset column does not match: " + outputColumns.at(1).name);
1498 }
1499 }
1500
1501 benchmarkUnpack.stopTimer();
1502 }

◆ getPerfData()

template<typename T, template< typename > class Reader>
virtual BranchPerfData columnar::TestUtils::ColumnDataVectorRLink< T, Reader >::getPerfData ( float emptyTime)
inlinenodiscardoverridevirtual

Implements columnar::TestUtils::IColumnData.

Definition at line 1517 of file ColumnarPhysliteTest.cxx.

1518 {
1520 result.name = branchReader.columnName();
1521 result.timeRead = benchmark.getEntryTime(emptyTime);
1522 result.timeUnpack = benchmarkUnpack.getEntryTime(emptyTime);
1523 benchmark.setSilence();
1524 benchmarkUnpack.setSilence();
1525 result.entrySize = branchReader.entrySize();
1526 result.uncompressedSize = branchReader.uncompressedSize();
1527 result.numBaskets = branchReader.numBaskets();
1530 return result;
1531 }

◆ setData()

template<typename T, template< typename > class Reader>
virtual void columnar::TestUtils::ColumnDataVectorRLink< T, Reader >::setData ( ColumnVectorData & colData)
inlineoverridevirtual

Implements columnar::TestUtils::IColumnData.

Definition at line 1504 of file ColumnarPhysliteTest.cxx.

1505 {
1506 if (outputColumns.at(0).columnIndex != ColumnVectorHeader::nullIndex)
1507 colData.setColumn(outputColumns.at(0).columnIndex, columnData.size(), columnData.data());
1508 if (outputColumns.at(1).columnIndex != ColumnVectorHeader::nullIndex)
1509 colData.setColumn(outputColumns.at(1).columnIndex, offsets.size(), offsets.data());
1510 for (std::size_t i = 2; i < outputColumns.size(); ++ i)
1511 {
1512 if (outputColumns.at(i).columnIndex != ColumnVectorHeader::nullIndex)
1513 colData.setColumn (outputColumns.at(i).columnIndex, columnData.keysColumn(i-2).size(), columnData.keysColumn(i-2).data());
1514 }
1515 }

Member Data Documentation

◆ benchmark

template<typename T, template< typename > class Reader>
Benchmark columnar::TestUtils::ColumnDataVectorRLink< T, Reader >::benchmark

Definition at line 1420 of file ColumnarPhysliteTest.cxx.

◆ benchmarkUnpack

template<typename T, template< typename > class Reader>
Benchmark columnar::TestUtils::ColumnDataVectorRLink< T, Reader >::benchmarkUnpack

Definition at line 1419 of file ColumnarPhysliteTest.cxx.

◆ branchReader

template<typename T, template< typename > class Reader>
Reader<std::vector<ElementLink<T> > > columnar::TestUtils::ColumnDataVectorRLink< T, Reader >::branchReader

Definition at line 1415 of file ColumnarPhysliteTest.cxx.

◆ columnData

template<typename T, template< typename > class Reader>
LinkColumnVector columnar::TestUtils::ColumnDataVectorRLink< T, Reader >::columnData

Definition at line 1418 of file ColumnarPhysliteTest.cxx.

◆ entries

template<typename T, template< typename > class Reader>
unsigned columnar::TestUtils::ColumnDataVectorRLink< T, Reader >::entries = 0

Definition at line 1421 of file ColumnarPhysliteTest.cxx.

◆ nullEntries

template<typename T, template< typename > class Reader>
unsigned columnar::TestUtils::ColumnDataVectorRLink< T, Reader >::nullEntries = 0

Definition at line 1422 of file ColumnarPhysliteTest.cxx.

◆ offsetColumn

template<typename T, template< typename > class Reader>
const std::vector<ColumnarOffsetType>* columnar::TestUtils::ColumnDataVectorRLink< T, Reader >::offsetColumn = nullptr

Definition at line 1416 of file ColumnarPhysliteTest.cxx.

◆ offsets

template<typename T, template< typename > class Reader>
std::vector<ColumnarOffsetType> columnar::TestUtils::ColumnDataVectorRLink< T, Reader >::offsets = {0}

Definition at line 1417 of file ColumnarPhysliteTest.cxx.

1417{0};

◆ outputColumns

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

Definition at line 664 of file ColumnarPhysliteTest.cxx.


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