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 (TTree *tree, 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}
std::vector< typename CM::LinkIndexTypecolumnData
std::vector< const std::vector< ColumnarOffsetType > * > targetOffsetColumns
std::vector< SG::sgkey_ttargetKeys
std::vector< typename CM::LinkKeyTypekeyColumnData
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 1085 of file ColumnarPhysliteTest.cxx.

Member Typedef Documentation

◆ CM

Definition at line 1087 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 1102 of file ColumnarPhysliteTest.cxx.

1103 : branchReaderSize (val_branchName), branchReaderKey (val_branchName + ".m_persKey"), branchReaderIndex (val_branchName + ".m_persIndex"), benchmarkUnpack (branchReaderSize.columnName()+"(unpack)"), benchmark (branchReaderSize.columnName())
1104 {
1105 outputColumns.push_back ({.name = branchReaderSize.columnName()});
1106 outputColumns.push_back ({.name = branchReaderSize.containerName(), .isOffset = true, .primary = false});
1107 outputColumns.push_back ({.name = branchReaderSize.columnName() + ".keys", .primary = false});
1108 }
std::vector< OutputColumnInfo > outputColumns

Member Function Documentation

◆ clearColumns()

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

Implements columnar::TestUtils::IColumnData.

Definition at line 1161 of file ColumnarPhysliteTest.cxx.

1162 {
1163 columnData.clear();
1164 offsets.clear();
1165 offsets.push_back (0);
1166 }

◆ collectColumnData()

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

Implements columnar::TestUtils::IColumnData.

Definition at line 1258 of file ColumnarPhysliteTest.cxx.

1259 {
1260 entries += columnData.size();
1261 for (const auto& index : columnData)
1262 {
1264 nullEntries += 1;
1265 }
1266 }

◆ connect()

template<typename T>
virtual bool columnar::TestUtils::ColumnDataVectorSplitLink< T >::connect ( TTree * tree,
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 1110 of file ColumnarPhysliteTest.cxx.

1111 {
1112 auto iter = requestedColumns.find (outputColumns.at(0).name);
1113 if (iter == requestedColumns.end())
1114 return false;
1115 outputColumns.at(0).enabled = true;
1116
1117 branchReaderSize.connectTree (tree);
1118 branchReaderKey.connectTree (tree);
1119 branchReaderIndex.connectTree (tree);
1120
1121 if (iter->second.offsetName != outputColumns.at(1).name)
1122 throw std::runtime_error ("offset name mismatch: " + iter->second.offsetName + " != " + outputColumns.at(1).name);
1123
1124 const auto& linkContainers = iter->second.linkTargetNames;
1125 for (const auto& container : linkContainers)
1126 {
1127 if (auto keyIter = knownKeys.find (container); keyIter != knownKeys.end())
1128 targetKeys.push_back (keyIter->second);
1129 else
1130 throw std::runtime_error ("no key known for link container: " + container);
1132 targetOffsetColumns.push_back (targetOffsetIter->second);
1133 else
1134 throw std::runtime_error ("missing offset column: " + container);
1135 keyColumnData.push_back (keyColumnData.size());
1136 }
1137 requestedColumns.erase (iter);
1138
1139 if (auto offsetIter = offsetColumns.find (outputColumns.at(1).name); offsetIter != offsetColumns.end())
1140 offsetColumn = offsetIter->second;
1141 else
1142 offsetColumns.emplace (outputColumns.at(1).name, &offsets);
1143
1144 iter = requestedColumns.find (outputColumns.at(1).name);
1145 if (iter != requestedColumns.end())
1146 {
1147 outputColumns.at(1).enabled = true;
1148 requestedColumns.erase (iter);
1149 }
1150
1151 iter = requestedColumns.find (outputColumns.at(2).name);
1152 if (iter != requestedColumns.end())
1153 {
1154 outputColumns.at(2).enabled = true;
1155 requestedColumns.erase (iter);
1156 }
1157
1158 return true;
1159 }

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

304 {
305 for (auto& col : outputColumns)
306 {
307 if (col.enabled)
308 col.columnIndex = header.getColumnIndex (col.name);
309 }
310 }

◆ getEntry()

template<typename T>
virtual void columnar::TestUtils::ColumnDataVectorSplitLink< T >::getEntry ( Long64_t entry)
inlineoverridevirtual

Implements columnar::TestUtils::IColumnData.

Definition at line 1168 of file ColumnarPhysliteTest.cxx.

1169 {
1170 benchmark.startTimer ();
1174 benchmark.stopTimer ();
1175 benchmarkUnpack.startTimer ();
1177 {
1178 if (targetOffsetColumn->size() <= offsets.size())
1179 throw std::runtime_error ("target offset column not yet filled for: " + outputColumns.at(0).name);
1180 }
1182 {
1183 if (branchDataIndex[index] == static_cast<UInt_t>(-1))
1184 columnData.push_back (invalidObjectIndex);
1185 else
1186 {
1188 if (auto keyIter = std::find(targetKeys.begin(), targetKeys.end(), branchDataKey[index]); keyIter != targetKeys.end())
1189 {
1191 } else if (targetKeys.empty())
1192 {
1193 targetKeys.push_back (branchDataKey[index]);
1194 keyIndex = 0;
1195 std::cout << "assume target key for " << outputColumns.at(0).name << " is " << std::hex << branchDataKey[index] << std::dec << std::endl;
1196 } else if (branchDataKey[index] != 0)
1197 {
1199 error << "target key mismatch: read " << std::hex << branchDataKey[index];
1200 error << ", expected one of";
1201 for (const auto& key : targetKeys)
1202 error << " " << key;
1203 error << " for " << outputColumns.at(0).name;
1205 }
1207 {
1208 columnData.push_back (CM::invalidLinkValue);
1209 } else
1210 {
1212 auto targetOffset = targetOffsetColumn.at (offsets.size()-1);
1215 if (linkIndex >= targetOffsetColumn.at(offsets.size()))
1216 throw std::runtime_error (std::format ("index out of range for link: {} >= {} (base index {})", outputColumns.at(0).name, linkIndex, targetOffsetColumn.at(offsets.size()), targetOffset));
1218 }
1219 }
1220 }
1221 offsets.push_back (columnData.size());
1222 if (offsetColumn)
1223 {
1224 if (offsetColumn->size() != offsets.size())
1225 throw std::runtime_error ("offset column not filled yet: " + outputColumns.at(1).name);
1226 if (offsetColumn->back() != offsets.back())
1227 throw std::runtime_error ("offset column does not match: " + outputColumns.at(1).name);
1228 }
1229 benchmarkUnpack.stopTimer ();
1230 }
std::size_t LinkIndexType
the type used for columns that represent element links
Definition ColumnarDef.h:92
static constexpr LinkIndexType invalidLinkValue
the value used for an invalid link (a.k.a. empty/null link)
Definition ColumnarDef.h:95
static LinkIndexType mergeLinkKeyIndex(LinkIndexType key, LinkIndexType index)
merge a key and index value into a link value

◆ getPerfData()

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

Implements columnar::TestUtils::IColumnData.

Definition at line 1242 of file ColumnarPhysliteTest.cxx.

1243 {
1245 result.name = branchReaderSize.columnName();
1246 result.timeRead = benchmark.getEntryTime(emptyTime);
1247 result.timeUnpack = benchmarkUnpack.getEntryTime(emptyTime);
1248 benchmark.setSilence();
1249 benchmarkUnpack.setSilence();
1250 result.entrySize = branchReaderSize.entrySize().value() + branchReaderKey.entrySize().value() + branchReaderIndex.entrySize().value();
1251 result.uncompressedSize = branchReaderSize.uncompressedSize().value() + branchReaderKey.uncompressedSize().value() + branchReaderIndex.uncompressedSize().value();
1252 result.numBaskets = branchReaderSize.numBaskets().value() + branchReaderKey.numBaskets().value() + branchReaderIndex.numBaskets().value();
1255 return result;
1256 }

◆ setData()

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

Implements columnar::TestUtils::IColumnData.

Definition at line 1232 of file ColumnarPhysliteTest.cxx.

1233 {
1234 if (outputColumns.at(0).columnIndex != ColumnVectorHeader::nullIndex)
1235 colData.setColumn (outputColumns.at(0).columnIndex, columnData.size(), columnData.data());
1236 if (outputColumns.at(1).columnIndex != ColumnVectorHeader::nullIndex)
1237 colData.setColumn (outputColumns.at(1).columnIndex, offsets.size(), offsets.data());
1238 if (outputColumns.at(2).columnIndex != ColumnVectorHeader::nullIndex)
1239 colData.setColumn (outputColumns.at(2).columnIndex, keyColumnData.size(), keyColumnData.data());
1240 }

Member Data Documentation

◆ benchmark

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

Definition at line 1098 of file ColumnarPhysliteTest.cxx.

◆ benchmarkUnpack

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

Definition at line 1097 of file ColumnarPhysliteTest.cxx.

◆ branchReaderIndex

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

Definition at line 1090 of file ColumnarPhysliteTest.cxx.

◆ branchReaderKey

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

Definition at line 1089 of file ColumnarPhysliteTest.cxx.

◆ branchReaderSize

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

Definition at line 1088 of file ColumnarPhysliteTest.cxx.

◆ columnData

template<typename T>
std::vector<typename CM::LinkIndexType> columnar::TestUtils::ColumnDataVectorSplitLink< T >::columnData

Definition at line 1093 of file ColumnarPhysliteTest.cxx.

◆ entries

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

Definition at line 1099 of file ColumnarPhysliteTest.cxx.

◆ keyColumnData

template<typename T>
std::vector<typename CM::LinkKeyType> columnar::TestUtils::ColumnDataVectorSplitLink< T >::keyColumnData

Definition at line 1096 of file ColumnarPhysliteTest.cxx.

◆ nullEntries

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

Definition at line 1100 of file ColumnarPhysliteTest.cxx.

◆ offsetColumn

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

Definition at line 1091 of file ColumnarPhysliteTest.cxx.

◆ offsets

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

Definition at line 1092 of file ColumnarPhysliteTest.cxx.

1092{0};

◆ outputColumns

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

Definition at line 296 of file ColumnarPhysliteTest.cxx.

◆ targetKeys

template<typename T>
std::vector<SG::sgkey_t> columnar::TestUtils::ColumnDataVectorSplitLink< T >::targetKeys

Definition at line 1095 of file ColumnarPhysliteTest.cxx.

◆ targetOffsetColumns

template<typename T>
std::vector<const std::vector<ColumnarOffsetType>*> columnar::TestUtils::ColumnDataVectorSplitLink< T >::targetOffsetColumns

Definition at line 1094 of file ColumnarPhysliteTest.cxx.


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