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

Public Types

using CM = ColumnarModeArray

Public Member Functions

 ColumnDataVectorVectorLink (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< std::vector< ElementLink< T > > > > branchReader
std::vector< ColumnarOffsetTypeoffsets = {0}
std::vector< ColumnarOffsetTypeeventOffsets = {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::ColumnDataVectorVectorLink< T, Reader >

Definition at line 1065 of file ColumnarPhysliteTest.cxx.

Member Typedef Documentation

◆ CM

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

Definition at line 1067 of file ColumnarPhysliteTest.cxx.

Constructor & Destructor Documentation

◆ ColumnDataVectorVectorLink()

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

Definition at line 1077 of file ColumnarPhysliteTest.cxx.

1078 : branchReader (val_branchName), benchmarkUnpack (branchReader.columnName()+"(unpack)"), benchmark (branchReader.columnName())
1079 {
1080 outputColumns.push_back ({.name = branchReader.columnName() + ".data"});
1081 outputColumns.push_back ({.name = branchReader.columnName() + ".offset", .isOffset = true});
1082 }
std::vector< OutputColumnInfo > outputColumns

Member Function Documentation

◆ clearColumns()

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

Implements columnar::TestUtils::IColumnData.

Definition at line 1111 of file ColumnarPhysliteTest.cxx.

1112 {
1113 columnData.clear();
1114 offsets.clear();
1115 offsets.push_back (0);
1116 eventOffsets.clear();
1117 eventOffsets.push_back (0);
1118 }

◆ collectColumnData()

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

Implements columnar::TestUtils::IColumnData.

Definition at line 1168 of file ColumnarPhysliteTest.cxx.

1169 {
1170 entries += columnData.size();
1171 for (const auto& index : columnData)
1172 {
1174 nullEntries += 1;
1175 }
1176 }

◆ connect()

template<typename T, template< typename > class Reader>
virtual bool columnar::TestUtils::ColumnDataVectorVectorLink< 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 1084 of file ColumnarPhysliteTest.cxx.

1085 {
1086 auto iter = requestedColumns.find (outputColumns.at(0).name);
1087 if (iter == requestedColumns.end())
1088 return false;
1089 outputColumns.at(0).enabled = true;
1090
1091 branchReader.connectTree(source);
1092
1093 if (iter->second.offsetName != outputColumns.at(1).name)
1094 throw std::runtime_error ("offset name mismatch: " + iter->second.offsetName + " != " + outputColumns.at(1).name);
1095 for (auto keyColumn : columnData.connect (iter->second, offsetColumns, requestedColumns))
1096 {
1097 outputColumns.push_back ({.name = keyColumn, .primary = false, .enabled = true});
1099 }
1100
1101 requestedColumns.erase (iter);
1102
1103 iter = requestedColumns.find (outputColumns.at(1).name);
1104 if (iter == requestedColumns.end())
1105 return true;
1106 requestedColumns.erase (iter);
1107 outputColumns.at(1).enabled = true;
1108 return true;
1109 }

◆ 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::ColumnDataVectorVectorLink< T, Reader >::getEntry ( Long64_t entry)
inlineoverridevirtual

Implements columnar::TestUtils::IColumnData.

Definition at line 1120 of file ColumnarPhysliteTest.cxx.

1121 {
1122 benchmark.startTimer ();
1123 const auto& branchData = branchReader.getEntry (entry);
1124 benchmark.stopTimer ();
1125 benchmarkUnpack.startTimer ();
1126 columnData.checkOffsets (eventOffsets.size() - 1);
1127 for (auto& data : branchData)
1128 {
1129 for (auto& element : data)
1130 {
1131 columnData.addLink (element, eventOffsets.size()-1);
1132 }
1133 offsets.push_back (columnData.size());
1134 }
1135 eventOffsets.push_back (offsets.size());
1136 benchmarkUnpack.stopTimer ();
1137 }

◆ getPerfData()

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

Implements columnar::TestUtils::IColumnData.

Definition at line 1152 of file ColumnarPhysliteTest.cxx.

1153 {
1155 result.name = branchReader.columnName();
1156 result.timeRead = benchmark.getEntryTime(emptyTime);
1157 result.timeUnpack = benchmarkUnpack.getEntryTime(emptyTime);
1158 benchmark.setSilence();
1159 benchmarkUnpack.setSilence();
1160 result.entrySize = branchReader.entrySize();
1161 result.uncompressedSize = branchReader.uncompressedSize();
1162 result.numBaskets = branchReader.numBaskets();
1165 return result;
1166 }

◆ setData()

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

Implements columnar::TestUtils::IColumnData.

Definition at line 1139 of file ColumnarPhysliteTest.cxx.

1140 {
1141 if (outputColumns.at(0).columnIndex != ColumnVectorHeader::nullIndex)
1142 colData.setColumn (outputColumns.at(0).columnIndex, columnData.size(), columnData.data());
1143 if (outputColumns.at(1).columnIndex != ColumnVectorHeader::nullIndex)
1144 colData.setColumn (outputColumns.at(1).columnIndex, offsets.size(), offsets.data());
1145 for (std::size_t i = 2; i < outputColumns.size(); ++ i)
1146 {
1147 if (outputColumns.at(i).columnIndex != ColumnVectorHeader::nullIndex)
1148 colData.setColumn (outputColumns.at(i).columnIndex, columnData.keysColumn(i-2).size(), columnData.keysColumn(i-2).data());
1149 }
1150 }

Member Data Documentation

◆ benchmark

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

Definition at line 1073 of file ColumnarPhysliteTest.cxx.

◆ benchmarkUnpack

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

Definition at line 1072 of file ColumnarPhysliteTest.cxx.

◆ branchReader

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

Definition at line 1068 of file ColumnarPhysliteTest.cxx.

◆ columnData

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

Definition at line 1071 of file ColumnarPhysliteTest.cxx.

◆ entries

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

Definition at line 1074 of file ColumnarPhysliteTest.cxx.

◆ eventOffsets

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

Definition at line 1070 of file ColumnarPhysliteTest.cxx.

1070{0};

◆ nullEntries

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

Definition at line 1075 of file ColumnarPhysliteTest.cxx.

◆ offsets

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

Definition at line 1069 of file ColumnarPhysliteTest.cxx.

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