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
 

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

Member Typedef Documentation

◆ CM

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

912  : branchReaderSize (val_branchName), branchReaderKey (val_branchName + ".m_persKey"), branchReaderIndex (val_branchName + ".m_persIndex"), benchmarkUnpack (branchReaderSize.columnName()+"(unpack)"), benchmark (branchReaderSize.columnName())
913  {
914  outputColumns.push_back ({.name = branchReaderSize.columnName()});
915  outputColumns.push_back ({.name = branchReaderSize.containerName(), .isOffset = true, .primary = false});
916  outputColumns.push_back ({.name = branchReaderSize.columnName() + ".keys", .primary = false});
917  }

Member Function Documentation

◆ clearColumns()

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

Implements columnar::TestUtils::IColumnData.

Definition at line 970 of file ColumnarPhysliteTest.cxx.

971  {
972  columnData.clear();
973  offsets.clear();
974  offsets.push_back (0);
975  }

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

920  {
921  auto iter = requestedColumns.find (outputColumns.at(0).name);
922  if (iter == requestedColumns.end())
923  return false;
924  outputColumns.at(0).enabled = true;
925 
929 
930  if (iter->second.offsetName != outputColumns.at(1).name)
931  throw std::runtime_error ("offset name mismatch: " + iter->second.offsetName + " != " + outputColumns.at(1).name);
932 
933  const auto& linkContainers = iter->second.linkTargetNames;
934  for (const auto& container : linkContainers)
935  {
936  if (auto keyIter = knownKeys.find (container); keyIter != knownKeys.end())
937  targetKeys.push_back (keyIter->second);
938  else
939  throw std::runtime_error ("no key known for link container: " + container);
940  if (auto targetOffsetIter = offsetColumns.find (container); targetOffsetIter != offsetColumns.end())
941  targetOffsetColumns.push_back (targetOffsetIter->second);
942  else
943  throw std::runtime_error ("missing offset column: " + container);
944  keyColumnData.push_back (keyColumnData.size());
945  }
946  requestedColumns.erase (iter);
947 
948  if (auto offsetIter = offsetColumns.find (outputColumns.at(1).name); offsetIter != offsetColumns.end())
949  offsetColumn = offsetIter->second;
950  else
951  offsetColumns.emplace (outputColumns.at(1).name, &offsets);
952 
953  iter = requestedColumns.find (outputColumns.at(1).name);
954  if (iter != requestedColumns.end())
955  {
956  outputColumns.at(1).enabled = true;
957  requestedColumns.erase (iter);
958  }
959 
960  iter = requestedColumns.find (outputColumns.at(2).name);
961  if (iter != requestedColumns.end())
962  {
963  outputColumns.at(2).enabled = true;
964  requestedColumns.erase (iter);
965  }
966 
967  return true;
968  }

◆ getEntry()

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

Implements columnar::TestUtils::IColumnData.

Definition at line 977 of file ColumnarPhysliteTest.cxx.

978  {
979  benchmark.startTimer ();
980  std::size_t branchDataSize = branchReaderSize.getEntry (entry);
981  auto branchDataKey = branchReaderKey.getEntry (entry, branchDataSize);
982  auto branchDataIndex = branchReaderIndex.getEntry (entry, branchDataSize);
983  benchmark.stopTimer ();
984  benchmarkUnpack.startTimer ();
985  for (auto& targetOffsetColumn : targetOffsetColumns)
986  {
987  if (targetOffsetColumn->size() <= offsets.size())
988  throw std::runtime_error ("target offset column not yet filled for: " + outputColumns.at(0).name);
989  }
990  for (std::size_t index = 0; index < branchDataSize; ++index)
991  {
992  if (branchDataIndex[index] == static_cast<UInt_t>(-1))
993  columnData.push_back (invalidObjectIndex);
994  else
995  {
997  if (auto keyIter = std::find(targetKeys.begin(), targetKeys.end(), branchDataKey[index]); keyIter != targetKeys.end())
998  {
999  keyIndex = std::distance(targetKeys.begin(), keyIter);
1000  } else if (targetKeys.empty())
1001  {
1002  targetKeys.push_back (branchDataKey[index]);
1003  keyIndex = 0;
1004  std::cout << "assume target key for " << outputColumns.at(0).name << " is " << std::hex << branchDataKey[index] << std::dec << std::endl;
1005  } else
1006  {
1007  std::ostringstream error;
1008  error << "target key mismatch: read " << std::hex << branchDataKey[index];
1009  error << ", expected one of";
1010  for (const auto& key : targetKeys)
1011  error << " " << key;
1012  error << " for " << outputColumns.at(0).name;
1013  throw std::runtime_error (std::move (error).str());
1014  }
1015  auto& targetOffsetColumn = *targetOffsetColumns.at(keyIndex);
1016  auto targetOffset = targetOffsetColumn.at (offsets.size()-1);
1017  CM::LinkIndexType linkIndex = branchDataIndex[index];
1018  linkIndex += targetOffset;
1019  if (linkIndex >= targetOffsetColumn.at(offsets.size()))
1020  throw std::runtime_error (std::format ("index out of range for link: {} >= {} (base index {})", outputColumns.at(0).name, linkIndex, targetOffsetColumn.at(offsets.size()), targetOffset));
1021  columnData.push_back (CM::mergeLinkKeyIndex (keyIndex, branchDataIndex[index] + targetOffset));
1022  }
1023  }
1024  offsets.push_back (columnData.size());
1025  if (offsetColumn)
1026  {
1027  if (offsetColumn->size() != offsets.size())
1028  throw std::runtime_error ("offset column not filled yet: " + outputColumns.at(1).name);
1029  if (offsetColumn->back() != offsets.back())
1030  throw std::runtime_error ("offset column does not match: " + outputColumns.at(1).name);
1031  }
1032  benchmarkUnpack.stopTimer ();
1033  }

◆ setData()

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

Implements columnar::TestUtils::IColumnData.

Definition at line 1035 of file ColumnarPhysliteTest.cxx.

1036  {
1037  if (outputColumns.at(0).enabled)
1038  tool.setColumn (outputColumns.at(0).name, columnData.size(), columnData.data());
1039  if (outputColumns.at(1).enabled)
1040  tool.setColumn (outputColumns.at(1).name, offsets.size(), offsets.data());
1041  if (outputColumns.at(2).enabled)
1042  tool.setColumn (outputColumns.at(2).name, keyColumnData.size(), keyColumnData.data());
1043  }

Member Data Documentation

◆ benchmark

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

Definition at line 909 of file ColumnarPhysliteTest.cxx.

◆ benchmarkUnpack

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

Definition at line 908 of file ColumnarPhysliteTest.cxx.

◆ branchReaderIndex

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

Definition at line 901 of file ColumnarPhysliteTest.cxx.

◆ branchReaderKey

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

Definition at line 900 of file ColumnarPhysliteTest.cxx.

◆ branchReaderSize

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

Definition at line 899 of file ColumnarPhysliteTest.cxx.

◆ columnData

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

Definition at line 904 of file ColumnarPhysliteTest.cxx.

◆ keyColumnData

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

Definition at line 907 of file ColumnarPhysliteTest.cxx.

◆ offsetColumn

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

Definition at line 902 of file ColumnarPhysliteTest.cxx.

◆ offsets

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

Definition at line 903 of file ColumnarPhysliteTest.cxx.

◆ outputColumns

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

Definition at line 285 of file ColumnarPhysliteTest.cxx.

◆ targetKeys

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

Definition at line 906 of file ColumnarPhysliteTest.cxx.

◆ targetOffsetColumns

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

Definition at line 905 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:192
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:249
index
Definition: index.py:1
columnar::TestUtils::BranchReader::connectTree
void connectTree(TTree *tree)
Definition: ColumnarPhysliteTest.cxx:180
columnar::TestUtils::BranchReader::containerName
std::string containerName() const
Definition: ColumnarPhysliteTest.cxx:168
tree
TChain * tree
Definition: tile_monitor.h:30
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
python.CaloAddPedShiftConfig.str
str
Definition: CaloAddPedShiftConfig.py:42
GetAllXsec.entry
list entry
Definition: GetAllXsec.py:132
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:285
columnar::ColumnarModeArray::mergeLinkKeyIndex
static LinkIndexType mergeLinkKeyIndex(LinkIndexType key, LinkIndexType index)
merge a key and index value into a link value
Definition: ColumnarDef.h:96
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:156
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:259
mapkey::key
key
Definition: TElectronEfficiencyCorrectionTool.cxx:37