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

Public Member Functions

 ColumnDataVectorVector (const std::string &val_branchName)
virtual bool connect (Backend source, 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

Reader< std::vector< std::vector< T > > > branchReader
std::vector< ColumnarOffsetTypeoffsets = {0}
std::vector< T > columnData
Benchmark benchmarkUnpack
Benchmark benchmark
unsigned entries = 0
std::vector< OutputColumnInfooutputColumns

Detailed Description

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

Definition at line 980 of file ColumnarPhysliteTest.cxx.

Constructor & Destructor Documentation

◆ ColumnDataVectorVector()

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

Definition at line 989 of file ColumnarPhysliteTest.cxx.

990 : branchReader (val_branchName), benchmarkUnpack (branchReader.columnName()+"(unpack)"), benchmark (branchReader.columnName())
991 {
992 outputColumns.push_back ({.name = branchReader.columnName() + ".data"});
993 outputColumns.push_back ({.name = branchReader.columnName() + ".offset", .isOffset = true});
994 }
std::vector< OutputColumnInfo > outputColumns
Reader< std::vector< std::vector< T > > > branchReader

Member Function Documentation

◆ clearColumns()

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

Implements columnar::TestUtils::IColumnData.

Definition at line 1018 of file ColumnarPhysliteTest.cxx.

1019 {
1020 columnData.clear();
1021 offsets.clear();
1022 offsets.push_back (0);
1023 }

◆ collectColumnData()

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

◆ connect()

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

Implements columnar::TestUtils::IColumnData.

Definition at line 996 of file ColumnarPhysliteTest.cxx.

997 {
998 auto iter = requestedColumns.find (outputColumns.at(0).name);
999 if (iter == requestedColumns.end())
1000 return false;
1001 outputColumns.at(0).enabled = true;
1002
1003 branchReader.connectTree(source);
1004
1005 if (iter->second.offsetName != outputColumns.at(1).name)
1006 throw std::runtime_error ("offset name mismatch: " + iter->second.offsetName + " != " + outputColumns.at(1).name);
1007
1008 requestedColumns.erase (iter);
1009
1010 iter = requestedColumns.find (outputColumns.at(1).name);
1011 if (iter == requestedColumns.end())
1012 return true;
1013 requestedColumns.erase (iter);
1014 outputColumns.at(1).enabled = true;
1015 return true;
1016 }

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

676 {
677 for (auto& col : outputColumns)
678 {
679 if (col.enabled)
680 col.columnIndex = header.getColumnIndex (col.name);
681 }
682 }

◆ getEntry()

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

Implements columnar::TestUtils::IColumnData.

Definition at line 1025 of file ColumnarPhysliteTest.cxx.

1026 {
1027 benchmark.startTimer ();
1028 const auto& branchData = branchReader.getEntry (entry);
1029 benchmark.stopTimer ();
1030 benchmarkUnpack.startTimer ();
1031 for (auto& data : branchData)
1032 {
1033 columnData.insert (columnData.end(), data.begin(), data.end());
1034 offsets.push_back (columnData.size());
1035 }
1036 benchmarkUnpack.stopTimer ();
1037 }

◆ getPerfData()

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

Implements columnar::TestUtils::IColumnData.

Definition at line 1047 of file ColumnarPhysliteTest.cxx.

1048 {
1050 result.name = branchReader.columnName();
1051 result.timeRead = benchmark.getEntryTime(emptyTime);
1052 result.timeUnpack = benchmarkUnpack.getEntryTime(emptyTime);
1053 benchmark.setSilence();
1054 benchmarkUnpack.setSilence();
1055 result.entrySize = branchReader.entrySize();
1056 result.uncompressedSize = branchReader.uncompressedSize();
1057 result.numBaskets = branchReader.numBaskets();
1059 return result;
1060 }

◆ setData()

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

Implements columnar::TestUtils::IColumnData.

Definition at line 1039 of file ColumnarPhysliteTest.cxx.

1040 {
1041 if (outputColumns.at(0).columnIndex != ColumnVectorHeader::nullIndex)
1042 colData.setColumn (outputColumns.at(0).columnIndex, columnData.size(), columnData.data());
1043 if (outputColumns.at(1).columnIndex != ColumnVectorHeader::nullIndex)
1044 colData.setColumn (outputColumns.at(1).columnIndex, offsets.size(), offsets.data());
1045 }

Member Data Documentation

◆ benchmark

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

Definition at line 986 of file ColumnarPhysliteTest.cxx.

◆ benchmarkUnpack

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

Definition at line 985 of file ColumnarPhysliteTest.cxx.

◆ branchReader

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

Definition at line 982 of file ColumnarPhysliteTest.cxx.

◆ columnData

template<typename T, template< typename > class Reader>
std::vector<T> columnar::TestUtils::ColumnDataVectorVector< T, Reader >::columnData

Definition at line 984 of file ColumnarPhysliteTest.cxx.

◆ entries

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

Definition at line 987 of file ColumnarPhysliteTest.cxx.

◆ offsets

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

Definition at line 983 of file ColumnarPhysliteTest.cxx.

983{0};

◆ outputColumns

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

Definition at line 668 of file ColumnarPhysliteTest.cxx.


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