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

Public Types

using CM = ColumnarModeArray

Public Member Functions

 ColumnDataVectorSplitLink (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

BranchReader< Int_t > branchReaderSize
BranchReaderArray< UInt_t > branchReaderKey
BranchReaderArray< UInt_t > branchReaderIndex
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>
struct columnar::TestUtils::ColumnDataVectorSplitLink< T >

Definition at line 1546 of file ColumnarPhysliteTest.cxx.

Member Typedef Documentation

◆ CM

Definition at line 1548 of file ColumnarPhysliteTest.cxx.

Constructor & Destructor Documentation

◆ ColumnDataVectorSplitLink()

template<typename T>
columnar::TestUtils::ColumnDataVectorSplitLink< T >::ColumnDataVectorSplitLink ( const std::string & val_branchName)
inline

Definition at line 1560 of file ColumnarPhysliteTest.cxx.

Member Function Documentation

◆ clearColumns()

template<typename T>
virtual void columnar::TestUtils::ColumnDataVectorSplitLink< T >::clearColumns ( )
inlineoverridevirtual

Implements columnar::TestUtils::IColumnData.

Definition at line 1603 of file ColumnarPhysliteTest.cxx.

1604 {
1605 columnData.clear();
1606 offsets.clear();
1607 offsets.push_back (0);
1608 }

◆ collectColumnData()

template<typename T>
virtual void columnar::TestUtils::ColumnDataVectorSplitLink< T >::collectColumnData ( )
inlineoverridevirtual

Implements columnar::TestUtils::IColumnData.

Definition at line 1666 of file ColumnarPhysliteTest.cxx.

1667 {
1668 entries += columnData.size();
1669 for (const auto& index : columnData)
1670 {
1672 nullEntries += 1;
1673 }
1674 }

◆ connect()

template<typename T>
virtual bool columnar::TestUtils::ColumnDataVectorSplitLink< T >::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 1567 of file ColumnarPhysliteTest.cxx.

1568 {
1569 auto iter = requestedColumns.find (outputColumns.at(0).name);
1570 if (iter == requestedColumns.end())
1571 return false;
1572 outputColumns.at(0).enabled = true;
1573 auto* tree = std::get<TTree*>(source);
1574 branchReaderSize.connectTree (tree);
1575 branchReaderKey.connectTree (tree);
1576 branchReaderIndex.connectTree (tree);
1577
1578 if (iter->second.offsetName != outputColumns.at(1).name)
1579 throw std::runtime_error ("offset name mismatch: " + iter->second.offsetName + " != " + outputColumns.at(1).name);
1580
1581 for (auto keyColumn : columnData.connect (iter->second, offsetColumns, requestedColumns))
1582 {
1583 outputColumns.push_back ({.name = keyColumn, .primary = false, .enabled = true});
1585 }
1586 requestedColumns.erase (iter);
1587
1588 if (auto offsetIter = offsetColumns.find (outputColumns.at(1).name); offsetIter != offsetColumns.end())
1589 offsetColumn = offsetIter->second;
1590 else
1591 offsetColumns.emplace (outputColumns.at(1).name, &offsets);
1592
1593 iter = requestedColumns.find (outputColumns.at(1).name);
1594 if (iter != requestedColumns.end())
1595 {
1596 outputColumns.at(1).enabled = true;
1597 requestedColumns.erase (iter);
1598 }
1599
1600 return true;
1601 }

◆ 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>
virtual void columnar::TestUtils::ColumnDataVectorSplitLink< T >::getEntry ( Long64_t entry)
inlineoverridevirtual

Implements columnar::TestUtils::IColumnData.

Definition at line 1610 of file ColumnarPhysliteTest.cxx.

1611 {
1612 benchmark.startTimer ();
1616 benchmark.stopTimer ();
1617 benchmarkUnpack.startTimer ();
1618 columnData.checkOffsets (offsets.size() - 1);
1620 {
1621 if (branchDataIndex[index] == static_cast<UInt_t>(-1))
1622 columnData.addEmptyLink ();
1623 else
1624 columnData.addSplitLink (branchDataIndex[index], branchDataKey[index], offsets.size()-1);
1625 }
1626 offsets.push_back (columnData.size());
1627 if (offsetColumn)
1628 {
1629 if (offsetColumn->size() != offsets.size())
1630 throw std::runtime_error ("offset column not filled yet: " + outputColumns.at(1).name);
1631 if (offsetColumn->back() != offsets.back())
1632 throw std::runtime_error ("offset column does not match: " + outputColumns.at(1).name);
1633 }
1634 benchmarkUnpack.stopTimer ();
1635 }

◆ getPerfData()

template<typename T>
virtual BranchPerfData columnar::TestUtils::ColumnDataVectorSplitLink< T >::getPerfData ( float emptyTime)
inlinenodiscardoverridevirtual

Implements columnar::TestUtils::IColumnData.

Definition at line 1650 of file ColumnarPhysliteTest.cxx.

1651 {
1653 result.name = branchReaderSize.columnName();
1654 result.timeRead = benchmark.getEntryTime(emptyTime);
1655 result.timeUnpack = benchmarkUnpack.getEntryTime(emptyTime);
1656 benchmark.setSilence();
1657 benchmarkUnpack.setSilence();
1658 result.entrySize = branchReaderSize.entrySize().value() + branchReaderKey.entrySize().value() + branchReaderIndex.entrySize().value();
1659 result.uncompressedSize = branchReaderSize.uncompressedSize().value() + branchReaderKey.uncompressedSize().value() + branchReaderIndex.uncompressedSize().value();
1660 result.numBaskets = branchReaderSize.numBaskets().value() + branchReaderKey.numBaskets().value() + branchReaderIndex.numBaskets().value();
1663 return result;
1664 }

◆ setData()

template<typename T>
virtual void columnar::TestUtils::ColumnDataVectorSplitLink< T >::setData ( ColumnVectorData & colData)
inlineoverridevirtual

Implements columnar::TestUtils::IColumnData.

Definition at line 1637 of file ColumnarPhysliteTest.cxx.

1638 {
1639 if (outputColumns.at(0).columnIndex != ColumnVectorHeader::nullIndex)
1640 colData.setColumn (outputColumns.at(0).columnIndex, columnData.size(), columnData.data());
1641 if (outputColumns.at(1).columnIndex != ColumnVectorHeader::nullIndex)
1642 colData.setColumn (outputColumns.at(1).columnIndex, offsets.size(), offsets.data());
1643 for (std::size_t i = 2; i < outputColumns.size(); ++ i)
1644 {
1645 if (outputColumns.at(i).columnIndex != ColumnVectorHeader::nullIndex)
1646 colData.setColumn (outputColumns.at(i).columnIndex, columnData.keysColumn(i-2).size(), columnData.keysColumn(i-2).data());
1647 }
1648 }

Member Data Documentation

◆ benchmark

template<typename T>
Benchmark columnar::TestUtils::ColumnDataVectorSplitLink< T >::benchmark

Definition at line 1556 of file ColumnarPhysliteTest.cxx.

◆ benchmarkUnpack

template<typename T>
Benchmark columnar::TestUtils::ColumnDataVectorSplitLink< T >::benchmarkUnpack

Definition at line 1555 of file ColumnarPhysliteTest.cxx.

◆ branchReaderIndex

template<typename T>
BranchReaderArray<UInt_t> columnar::TestUtils::ColumnDataVectorSplitLink< T >::branchReaderIndex

Definition at line 1551 of file ColumnarPhysliteTest.cxx.

◆ branchReaderKey

template<typename T>
BranchReaderArray<UInt_t> columnar::TestUtils::ColumnDataVectorSplitLink< T >::branchReaderKey

Definition at line 1550 of file ColumnarPhysliteTest.cxx.

◆ branchReaderSize

template<typename T>
BranchReader<Int_t> columnar::TestUtils::ColumnDataVectorSplitLink< T >::branchReaderSize

Definition at line 1549 of file ColumnarPhysliteTest.cxx.

◆ columnData

Definition at line 1554 of file ColumnarPhysliteTest.cxx.

◆ entries

template<typename T>
unsigned columnar::TestUtils::ColumnDataVectorSplitLink< T >::entries = 0

Definition at line 1557 of file ColumnarPhysliteTest.cxx.

◆ nullEntries

template<typename T>
unsigned columnar::TestUtils::ColumnDataVectorSplitLink< T >::nullEntries = 0

Definition at line 1558 of file ColumnarPhysliteTest.cxx.

◆ offsetColumn

template<typename T>
const std::vector<ColumnarOffsetType>* columnar::TestUtils::ColumnDataVectorSplitLink< T >::offsetColumn = nullptr

Definition at line 1552 of file ColumnarPhysliteTest.cxx.

◆ offsets

template<typename T>
std::vector<ColumnarOffsetType> columnar::TestUtils::ColumnDataVectorSplitLink< T >::offsets = {0}

Definition at line 1553 of file ColumnarPhysliteTest.cxx.

1553{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: