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 (TestUtils::ToolWrapperData &tool) override
virtual BranchPerfData getPerfData (float emptyTime) override
virtual void collectColumnData () override

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

Member Typedef Documentation

◆ CM

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

1168 : branchReaderSize (val_branchName), branchReaderKey (val_branchName + ".m_persKey"), branchReaderIndex (val_branchName + ".m_persIndex"), benchmarkUnpack (branchReaderSize.columnName()+"(unpack)"), benchmark (branchReaderSize.columnName())
1169 {
1170 outputColumns.push_back ({.name = branchReaderSize.columnName()});
1171 outputColumns.push_back ({.name = branchReaderSize.containerName(), .isOffset = true, .primary = false});
1172 outputColumns.push_back ({.name = branchReaderSize.columnName() + ".keys", .primary = false});
1173 }
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 1226 of file ColumnarPhysliteTest.cxx.

1227 {
1228 columnData.clear();
1229 offsets.clear();
1230 offsets.push_back (0);
1231 }

◆ collectColumnData()

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

Implements columnar::TestUtils::IColumnData.

Definition at line 1323 of file ColumnarPhysliteTest.cxx.

1324 {
1325 entries += columnData.size();
1326 for (const auto& index : columnData)
1327 {
1329 nullEntries += 1;
1330 }
1331 }

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

1176 {
1177 auto iter = requestedColumns.find (outputColumns.at(0).name);
1178 if (iter == requestedColumns.end())
1179 return false;
1180 outputColumns.at(0).enabled = true;
1181
1182 branchReaderSize.connectTree (tree);
1183 branchReaderKey.connectTree (tree);
1184 branchReaderIndex.connectTree (tree);
1185
1186 if (iter->second.offsetName != outputColumns.at(1).name)
1187 throw std::runtime_error ("offset name mismatch: " + iter->second.offsetName + " != " + outputColumns.at(1).name);
1188
1189 const auto& linkContainers = iter->second.linkTargetNames;
1190 for (const auto& container : linkContainers)
1191 {
1192 if (auto keyIter = knownKeys.find (container); keyIter != knownKeys.end())
1193 targetKeys.push_back (keyIter->second);
1194 else
1195 throw std::runtime_error ("no key known for link container: " + container);
1197 targetOffsetColumns.push_back (targetOffsetIter->second);
1198 else
1199 throw std::runtime_error ("missing offset column: " + container);
1200 keyColumnData.push_back (keyColumnData.size());
1201 }
1202 requestedColumns.erase (iter);
1203
1204 if (auto offsetIter = offsetColumns.find (outputColumns.at(1).name); offsetIter != offsetColumns.end())
1205 offsetColumn = offsetIter->second;
1206 else
1207 offsetColumns.emplace (outputColumns.at(1).name, &offsets);
1208
1209 iter = requestedColumns.find (outputColumns.at(1).name);
1210 if (iter != requestedColumns.end())
1211 {
1212 outputColumns.at(1).enabled = true;
1213 requestedColumns.erase (iter);
1214 }
1215
1216 iter = requestedColumns.find (outputColumns.at(2).name);
1217 if (iter != requestedColumns.end())
1218 {
1219 outputColumns.at(2).enabled = true;
1220 requestedColumns.erase (iter);
1221 }
1222
1223 return true;
1224 }

◆ getEntry()

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

Implements columnar::TestUtils::IColumnData.

Definition at line 1233 of file ColumnarPhysliteTest.cxx.

1234 {
1235 benchmark.startTimer ();
1239 benchmark.stopTimer ();
1240 benchmarkUnpack.startTimer ();
1242 {
1243 if (targetOffsetColumn->size() <= offsets.size())
1244 throw std::runtime_error ("target offset column not yet filled for: " + outputColumns.at(0).name);
1245 }
1247 {
1248 if (branchDataIndex[index] == static_cast<UInt_t>(-1))
1249 columnData.push_back (invalidObjectIndex);
1250 else
1251 {
1253 if (auto keyIter = std::find(targetKeys.begin(), targetKeys.end(), branchDataKey[index]); keyIter != targetKeys.end())
1254 {
1256 } else if (targetKeys.empty())
1257 {
1258 targetKeys.push_back (branchDataKey[index]);
1259 keyIndex = 0;
1260 std::cout << "assume target key for " << outputColumns.at(0).name << " is " << std::hex << branchDataKey[index] << std::dec << std::endl;
1261 } else if (branchDataKey[index] != 0)
1262 {
1264 error << "target key mismatch: read " << std::hex << branchDataKey[index];
1265 error << ", expected one of";
1266 for (const auto& key : targetKeys)
1267 error << " " << key;
1268 error << " for " << outputColumns.at(0).name;
1270 }
1272 {
1273 columnData.push_back (CM::invalidLinkValue);
1274 } else
1275 {
1277 auto targetOffset = targetOffsetColumn.at (offsets.size()-1);
1280 if (linkIndex >= targetOffsetColumn.at(offsets.size()))
1281 throw std::runtime_error (std::format ("index out of range for link: {} >= {} (base index {})", outputColumns.at(0).name, linkIndex, targetOffsetColumn.at(offsets.size()), targetOffset));
1283 }
1284 }
1285 }
1286 offsets.push_back (columnData.size());
1287 if (offsetColumn)
1288 {
1289 if (offsetColumn->size() != offsets.size())
1290 throw std::runtime_error ("offset column not filled yet: " + outputColumns.at(1).name);
1291 if (offsetColumn->back() != offsets.back())
1292 throw std::runtime_error ("offset column does not match: " + outputColumns.at(1).name);
1293 }
1294 benchmarkUnpack.stopTimer ();
1295 }
std::size_t LinkIndexType
the type used for columns that represent element links
Definition ColumnarDef.h:68
static constexpr LinkIndexType invalidLinkValue
the value used for an invalid link (a.k.a. empty/null link)
Definition ColumnarDef.h:71
static LinkIndexType mergeLinkKeyIndex(LinkIndexType key, LinkIndexType index)
merge a key and index value into a link value
Definition ColumnarDef.h:96

◆ getPerfData()

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

Implements columnar::TestUtils::IColumnData.

Definition at line 1307 of file ColumnarPhysliteTest.cxx.

1308 {
1310 result.name = branchReaderSize.columnName();
1311 result.timeRead = benchmark.getEntryTime(emptyTime);
1312 result.timeUnpack = benchmarkUnpack.getEntryTime(emptyTime);
1313 benchmark.setSilence();
1314 benchmarkUnpack.setSilence();
1315 result.entrySize = branchReaderSize.entrySize().value() + branchReaderKey.entrySize().value() + branchReaderIndex.entrySize().value();
1316 result.uncompressedSize = branchReaderSize.uncompressedSize().value() + branchReaderKey.uncompressedSize().value() + branchReaderIndex.uncompressedSize().value();
1317 result.numBaskets = branchReaderSize.numBaskets().value() + branchReaderKey.numBaskets().value() + branchReaderIndex.numBaskets().value();
1320 return result;
1321 }

◆ setData()

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

Implements columnar::TestUtils::IColumnData.

Definition at line 1297 of file ColumnarPhysliteTest.cxx.

1298 {
1299 if (outputColumns.at(0).enabled)
1300 tool.setColumn (outputColumns.at(0).name, columnData.size(), columnData.data());
1301 if (outputColumns.at(1).enabled)
1302 tool.setColumn (outputColumns.at(1).name, offsets.size(), offsets.data());
1303 if (outputColumns.at(2).enabled)
1304 tool.setColumn (outputColumns.at(2).name, keyColumnData.size(), keyColumnData.data());
1305 }

Member Data Documentation

◆ benchmark

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

Definition at line 1163 of file ColumnarPhysliteTest.cxx.

◆ benchmarkUnpack

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

Definition at line 1162 of file ColumnarPhysliteTest.cxx.

◆ branchReaderIndex

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

Definition at line 1155 of file ColumnarPhysliteTest.cxx.

◆ branchReaderKey

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

Definition at line 1154 of file ColumnarPhysliteTest.cxx.

◆ branchReaderSize

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

Definition at line 1153 of file ColumnarPhysliteTest.cxx.

◆ columnData

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

Definition at line 1158 of file ColumnarPhysliteTest.cxx.

◆ entries

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

Definition at line 1164 of file ColumnarPhysliteTest.cxx.

◆ keyColumnData

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

Definition at line 1161 of file ColumnarPhysliteTest.cxx.

◆ nullEntries

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

Definition at line 1165 of file ColumnarPhysliteTest.cxx.

◆ offsetColumn

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

Definition at line 1156 of file ColumnarPhysliteTest.cxx.

◆ offsets

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

Definition at line 1157 of file ColumnarPhysliteTest.cxx.

1157{0};

◆ outputColumns

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

Definition at line 371 of file ColumnarPhysliteTest.cxx.

◆ targetKeys

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

Definition at line 1160 of file ColumnarPhysliteTest.cxx.

◆ targetOffsetColumns

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

Definition at line 1159 of file ColumnarPhysliteTest.cxx.


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