ATLAS Offline Software
Public Types | Public Member Functions | Public Attributes | List of all members
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
 

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
 
std::vector< OutputColumnInfooutputColumns
 

Detailed Description

template<typename T>
struct columnar::TestUtils::ColumnDataVectorSplitLink< T >

Definition at line 1080 of file ColumnarPhysliteTest.cxx.

Member Typedef Documentation

◆ CM

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

1096  : branchReaderSize (val_branchName), branchReaderKey (val_branchName + ".m_persKey"), branchReaderIndex (val_branchName + ".m_persIndex"), benchmarkUnpack (branchReaderSize.columnName()+"(unpack)"), benchmark (branchReaderSize.columnName())
1097  {
1098  outputColumns.push_back ({.name = branchReaderSize.columnName()});
1099  outputColumns.push_back ({.name = branchReaderSize.containerName(), .isOffset = true, .primary = false});
1100  outputColumns.push_back ({.name = branchReaderSize.columnName() + ".keys", .primary = false});
1101  }

Member Function Documentation

◆ clearColumns()

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

Implements columnar::TestUtils::IColumnData.

Definition at line 1154 of file ColumnarPhysliteTest.cxx.

1155  {
1156  columnData.clear();
1157  offsets.clear();
1158  offsets.push_back (0);
1159  }

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

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

◆ getEntry()

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

Implements columnar::TestUtils::IColumnData.

Definition at line 1161 of file ColumnarPhysliteTest.cxx.

1162  {
1163  benchmark.startTimer ();
1164  std::size_t branchDataSize = branchReaderSize.getEntry (entry);
1165  auto branchDataKey = branchReaderKey.getEntry (entry, branchDataSize);
1166  auto branchDataIndex = branchReaderIndex.getEntry (entry, branchDataSize);
1167  benchmark.stopTimer ();
1168  benchmarkUnpack.startTimer ();
1169  for (auto& targetOffsetColumn : targetOffsetColumns)
1170  {
1171  if (targetOffsetColumn->size() <= offsets.size())
1172  throw std::runtime_error ("target offset column not yet filled for: " + outputColumns.at(0).name);
1173  }
1174  for (std::size_t index = 0; index < branchDataSize; ++index)
1175  {
1176  if (branchDataIndex[index] == static_cast<UInt_t>(-1))
1177  columnData.push_back (invalidObjectIndex);
1178  else
1179  {
1181  if (auto keyIter = std::find(targetKeys.begin(), targetKeys.end(), branchDataKey[index]); keyIter != targetKeys.end())
1182  {
1183  keyIndex = std::distance(targetKeys.begin(), keyIter);
1184  } else if (targetKeys.empty())
1185  {
1186  targetKeys.push_back (branchDataKey[index]);
1187  keyIndex = 0;
1188  std::cout << "assume target key for " << outputColumns.at(0).name << " is " << std::hex << branchDataKey[index] << std::dec << std::endl;
1189  } else if (branchDataKey[index] != 0)
1190  {
1191  std::ostringstream error;
1192  error << "target key mismatch: read " << std::hex << branchDataKey[index];
1193  error << ", expected one of";
1194  for (const auto& key : targetKeys)
1195  error << " " << key;
1196  error << " for " << outputColumns.at(0).name;
1197  throw std::runtime_error (std::move (error).str());
1198  }
1199  if (keyIndex == CM::invalidLinkValue)
1200  {
1201  columnData.push_back (CM::invalidLinkValue);
1202  } else
1203  {
1204  auto& targetOffsetColumn = *targetOffsetColumns.at(keyIndex);
1205  auto targetOffset = targetOffsetColumn.at (offsets.size()-1);
1206  CM::LinkIndexType linkIndex = branchDataIndex[index];
1207  linkIndex += targetOffset;
1208  if (linkIndex >= targetOffsetColumn.at(offsets.size()))
1209  throw std::runtime_error (std::format ("index out of range for link: {} >= {} (base index {})", outputColumns.at(0).name, linkIndex, targetOffsetColumn.at(offsets.size()), targetOffset));
1210  columnData.push_back (CM::mergeLinkKeyIndex (keyIndex, branchDataIndex[index] + targetOffset));
1211  }
1212  }
1213  }
1214  offsets.push_back (columnData.size());
1215  if (offsetColumn)
1216  {
1217  if (offsetColumn->size() != offsets.size())
1218  throw std::runtime_error ("offset column not filled yet: " + outputColumns.at(1).name);
1219  if (offsetColumn->back() != offsets.back())
1220  throw std::runtime_error ("offset column does not match: " + outputColumns.at(1).name);
1221  }
1222  benchmarkUnpack.stopTimer ();
1223  }

◆ getPerfData()

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

Implements columnar::TestUtils::IColumnData.

Definition at line 1235 of file ColumnarPhysliteTest.cxx.

1236  {
1237  BranchPerfData result;
1239  result.timeRead = benchmark.getEntryTime(emptyTime);
1240  result.timeUnpack = benchmarkUnpack.getEntryTime(emptyTime);
1241  benchmark.setSilence();
1242  benchmarkUnpack.setSilence();
1243  result.entrySize = branchReaderSize.entrySize().value() + branchReaderKey.entrySize().value() + branchReaderIndex.entrySize().value();
1244  result.uncompressedSize = branchReaderSize.uncompressedSize().value() + branchReaderKey.uncompressedSize().value() + branchReaderIndex.uncompressedSize().value();
1245  result.numBaskets = branchReaderSize.numBaskets().value() + branchReaderKey.numBaskets().value() + branchReaderIndex.numBaskets().value();
1246  return result;
1247  }

◆ setData()

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

Implements columnar::TestUtils::IColumnData.

Definition at line 1225 of file ColumnarPhysliteTest.cxx.

1226  {
1227  if (outputColumns.at(0).enabled)
1228  tool.setColumn (outputColumns.at(0).name, columnData.size(), columnData.data());
1229  if (outputColumns.at(1).enabled)
1230  tool.setColumn (outputColumns.at(1).name, offsets.size(), offsets.data());
1231  if (outputColumns.at(2).enabled)
1232  tool.setColumn (outputColumns.at(2).name, keyColumnData.size(), keyColumnData.data());
1233  }

Member Data Documentation

◆ benchmark

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

Definition at line 1093 of file ColumnarPhysliteTest.cxx.

◆ benchmarkUnpack

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

Definition at line 1092 of file ColumnarPhysliteTest.cxx.

◆ branchReaderIndex

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

Definition at line 1085 of file ColumnarPhysliteTest.cxx.

◆ branchReaderKey

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

Definition at line 1084 of file ColumnarPhysliteTest.cxx.

◆ branchReaderSize

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

Definition at line 1083 of file ColumnarPhysliteTest.cxx.

◆ columnData

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

Definition at line 1088 of file ColumnarPhysliteTest.cxx.

◆ keyColumnData

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

Definition at line 1091 of file ColumnarPhysliteTest.cxx.

◆ offsetColumn

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

Definition at line 1086 of file ColumnarPhysliteTest.cxx.

◆ offsets

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

Definition at line 1087 of file ColumnarPhysliteTest.cxx.

◆ outputColumns

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

Definition at line 369 of file ColumnarPhysliteTest.cxx.

◆ targetKeys

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

Definition at line 1090 of file ColumnarPhysliteTest.cxx.

◆ targetOffsetColumns

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

Definition at line 1089 of file ColumnarPhysliteTest.cxx.


The documentation for this struct was generated from the following file:
createLinkingScheme.iter
iter
Definition: createLinkingScheme.py:62
columnar::TestUtils::BranchReader::getEntry
const T & getEntry(Long64_t entry)
Definition: ColumnarPhysliteTest.cxx:230
get_generator_info.result
result
Definition: get_generator_info.py:21
vtune_athena.format
format
Definition: vtune_athena.py:14
find
std::string find(const std::string &s)
return a remapped string
Definition: hcg.cxx:135
columnar::TestUtils::BranchReaderArray::connectTree
void connectTree(TTree *tree)
Definition: ColumnarPhysliteTest.cxx:310
index
Definition: index.py:1
columnar::TestUtils::BranchReader::connectTree
void connectTree(TTree *tree)
Definition: ColumnarPhysliteTest.cxx:218
columnar::TestUtils::BranchReader::containerName
std::string containerName() const
Definition: ColumnarPhysliteTest.cxx:206
tree
TChain * tree
Definition: tile_monitor.h:30
columnar::TestUtils::BranchReader::entrySize
std::optional< float > entrySize() const
Definition: ColumnarPhysliteTest.cxx:246
columnar::ColumnarModeArray::LinkIndexType
std::size_t LinkIndexType
the type used for columns that represent element links
Definition: ColumnarDef.h:68
StateLessPT_NewConfig.primary
primary
Definition: StateLessPT_NewConfig.py:234
columnar::TestUtils::BranchReader::numBaskets
std::optional< unsigned > numBaskets()
Definition: ColumnarPhysliteTest.cxx:262
python.CaloAddPedShiftConfig.str
str
Definition: CaloAddPedShiftConfig.py:42
GetAllXsec.entry
list entry
Definition: GetAllXsec.py:132
columnar::TestUtils::BranchReaderArray::entrySize
std::optional< float > entrySize() const
Definition: ColumnarPhysliteTest.cxx:334
AtlCoolConsole.tool
tool
Definition: AtlCoolConsole.py:452
columnar::invalidObjectIndex
constexpr ColumnarOffsetType invalidObjectIndex
the value for an invalid element index
Definition: IColumnarTool.h:25
columnar::TestUtils::IColumnData::outputColumns
std::vector< OutputColumnInfo > outputColumns
Definition: ColumnarPhysliteTest.cxx:369
columnar::ColumnarModeArray::mergeLinkKeyIndex
static LinkIndexType mergeLinkKeyIndex(LinkIndexType key, LinkIndexType index)
merge a key and index value into a link value
Definition: ColumnarDef.h:96
columnar::TestUtils::BranchReaderArray::uncompressedSize
std::optional< float > uncompressedSize() const
Definition: ColumnarPhysliteTest.cxx:341
DeMoScan.index
string index
Definition: DeMoScan.py:362
columnar::ColumnarModeArray::invalidLinkValue
static constexpr LinkIndexType invalidLinkValue
the value used for an invalid link (a.k.a. empty/null link)
Definition: ColumnarDef.h:71
columnar::TestUtils::BranchReader::columnName
std::string columnName() const
Definition: ColumnarPhysliteTest.cxx:194
columnar::TestUtils::BranchReader::uncompressedSize
std::optional< float > uncompressedSize() const
Definition: ColumnarPhysliteTest.cxx:253
egammaParameters::linkIndex
@ linkIndex
link index for multiple track and vertex matches
Definition: egammaParamDefs.h:574
get_generator_info.error
error
Definition: get_generator_info.py:40
error
Definition: IImpactPoint3dEstimator.h:70
Amg::distance
float distance(const Amg::Vector3D &p1, const Amg::Vector3D &p2)
calculates the distance between two point in 3D space
Definition: GeoPrimitivesHelpers.h:54
columnar::TestUtils::BranchReaderArray::getEntry
std::span< const T > getEntry(Long64_t entry, std::size_t size)
Definition: ColumnarPhysliteTest.cxx:320
columnar::TestUtils::BranchReaderArray::numBaskets
std::optional< unsigned > numBaskets()
Definition: ColumnarPhysliteTest.cxx:350
mapkey::key
key
Definition: TElectronEfficiencyCorrectionTool.cxx:37