ATLAS Offline Software
Public Types | Public Member Functions | Public Attributes | List of all members
columnar::TestUtils::ColumnDataVectorLink< T > Struct Template Referencefinal
Inheritance diagram for columnar::TestUtils::ColumnDataVectorLink< T >:
Collaboration diagram for columnar::TestUtils::ColumnDataVectorLink< T >:

Public Types

using CM = ColumnarModeArray
 

Public Member Functions

 ColumnDataVectorLink (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< std::vector< ElementLink< T > > > branchReader
 
const std::vector< ColumnarOffsetType > * offsetColumn = nullptr
 
std::vector< ColumnarOffsetTypeoffsets = {0}
 
std::vector< typename CM::LinkIndexTypecolumnData
 
const std::vector< ColumnarOffsetType > * targetOffsetColumn = nullptr
 
SG::sgkey_t targetKey = 0
 
std::string targetContainerName
 
Benchmark benchmarkUnpack
 
Benchmark benchmark
 
std::vector< OutputColumnInfooutputColumns
 

Detailed Description

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

Definition at line 951 of file ColumnarPhysliteTest.cxx.

Member Typedef Documentation

◆ CM

template<typename T >
using columnar::TestUtils::ColumnDataVectorLink< T >::CM = ColumnarModeArray

Definition at line 953 of file ColumnarPhysliteTest.cxx.

Constructor & Destructor Documentation

◆ ColumnDataVectorLink()

template<typename T >
columnar::TestUtils::ColumnDataVectorLink< T >::ColumnDataVectorLink ( const std::string &  val_branchName)
inline

Definition at line 964 of file ColumnarPhysliteTest.cxx.

966  {
967  outputColumns.push_back ({.name = branchReader.columnName()});
968  outputColumns.push_back ({.name = branchReader.containerName(), .isOffset = true, .primary = false});
969  }

Member Function Documentation

◆ clearColumns()

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

Implements columnar::TestUtils::IColumnData.

Definition at line 1010 of file ColumnarPhysliteTest.cxx.

1011  {
1012  columnData.clear();
1013  offsets.clear();
1014  offsets.push_back (0);
1015  }

◆ connect()

template<typename T >
virtual bool columnar::TestUtils::ColumnDataVectorLink< 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 971 of file ColumnarPhysliteTest.cxx.

972  {
973  auto iter = requestedColumns.find (outputColumns.at(0).name);
974  if (iter == requestedColumns.end())
975  return false;
976  outputColumns.at(0).enabled = true;
977 
979 
980  if (iter->second.offsetName != outputColumns.at(1).name)
981  throw std::runtime_error ("offset name mismatch: " + iter->second.offsetName + " != " + outputColumns.at(1).name);
982 
983  if (iter->second.linkTargetNames.size() != 1)
984  throw std::runtime_error ("expected exactly one link target name for: " + outputColumns.at(0).name);
985  targetContainerName = iter->second.linkTargetNames.at(0);
986  if (auto keyIter = knownKeys.find (targetContainerName); keyIter != knownKeys.end())
987  targetKey = keyIter->second;
988  if (auto targetOffsetIter = offsetColumns.find (iter->second.linkTargetNames.at(0)); targetOffsetIter != offsetColumns.end())
989  targetOffsetColumn = targetOffsetIter->second;
990  else
991  throw std::runtime_error ("missing offset column(vector-link): " + iter->second.linkTargetNames.at(0));
992 
993  requestedColumns.erase (iter);
994 
995  if (auto offsetIter = offsetColumns.find (outputColumns.at(1).name); offsetIter != offsetColumns.end())
996  offsetColumn = offsetIter->second;
997  else
998  offsetColumns.emplace (outputColumns.at(1).name, &offsets);
999 
1000  iter = requestedColumns.find (outputColumns.at(1).name);
1001  if (iter != requestedColumns.end())
1002  {
1003  outputColumns.at(1).enabled = true;
1004  requestedColumns.erase (iter);
1005  }
1006 
1007  return true;
1008  }

◆ getEntry()

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

Implements columnar::TestUtils::IColumnData.

Definition at line 1017 of file ColumnarPhysliteTest.cxx.

1018  {
1019  benchmark.startTimer ();
1020  const auto& branchData = branchReader.getEntry (entry);
1021  benchmark.stopTimer ();
1022  benchmarkUnpack.startTimer ();
1023  if (targetOffsetColumn->size() < 2)
1024  throw std::runtime_error ("target offset column not yet filled for: " + outputColumns.at(0).name);
1025  for (auto& element : branchData)
1026  {
1027  if (element.isDefault())
1028  columnData.push_back (invalidObjectIndex);
1029  else
1030  {
1031  columnData.push_back (element.index() + targetOffsetColumn->at (targetOffsetColumn->size()-2));
1032  if (element.key() != targetKey)
1033  {
1034  if (targetKey == 0)
1035  {
1036  targetKey = element.key();
1037  std::cout << "assume target key for " << targetContainerName << " is " << std::hex << targetKey << std::dec << std::endl;
1038  } else
1039  {
1040  throw std::runtime_error ("target key mismatch: " + std::to_string (element.key()) + " != " + std::to_string (targetKey) + " for " + outputColumns.at(0).name);
1041  }
1042  }
1043  }
1044  }
1045  offsets.push_back (columnData.size());
1046  if (offsetColumn)
1047  {
1048  if (offsetColumn->size() != offsets.size())
1049  throw std::runtime_error ("offset column not filled yet: " + outputColumns.at(1).name);
1050  if (offsetColumn->back() != offsets.back())
1051  throw std::runtime_error ("offset column does not match: " + outputColumns.at(1).name);
1052  }
1053  benchmarkUnpack.stopTimer ();
1054  }

◆ getPerfData()

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

Implements columnar::TestUtils::IColumnData.

Definition at line 1064 of file ColumnarPhysliteTest.cxx.

1065  {
1066  BranchPerfData result;
1067  result.name = branchReader.columnName();
1068  result.timeRead = benchmark.getEntryTime(emptyTime);
1069  result.timeUnpack = benchmarkUnpack.getEntryTime(emptyTime);
1070  benchmark.setSilence();
1071  benchmarkUnpack.setSilence();
1072  result.entrySize = branchReader.entrySize();
1073  result.uncompressedSize = branchReader.uncompressedSize();
1074  result.numBaskets = branchReader.numBaskets();
1075  return result;
1076  }

◆ setData()

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

Implements columnar::TestUtils::IColumnData.

Definition at line 1056 of file ColumnarPhysliteTest.cxx.

1057  {
1058  if (outputColumns.at(0).enabled)
1059  tool.setColumn (outputColumns.at(0).name, columnData.size(), columnData.data());
1060  if (outputColumns.at(1).enabled)
1061  tool.setColumn (outputColumns.at(1).name, offsets.size(), offsets.data());
1062  }

Member Data Documentation

◆ benchmark

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

Definition at line 962 of file ColumnarPhysliteTest.cxx.

◆ benchmarkUnpack

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

Definition at line 961 of file ColumnarPhysliteTest.cxx.

◆ branchReader

template<typename T >
BranchReader<std::vector<ElementLink<T> > > columnar::TestUtils::ColumnDataVectorLink< T >::branchReader

Definition at line 954 of file ColumnarPhysliteTest.cxx.

◆ columnData

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

Definition at line 957 of file ColumnarPhysliteTest.cxx.

◆ offsetColumn

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

Definition at line 955 of file ColumnarPhysliteTest.cxx.

◆ offsets

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

Definition at line 956 of file ColumnarPhysliteTest.cxx.

◆ outputColumns

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

Definition at line 369 of file ColumnarPhysliteTest.cxx.

◆ targetContainerName

template<typename T >
std::string columnar::TestUtils::ColumnDataVectorLink< T >::targetContainerName

Definition at line 960 of file ColumnarPhysliteTest.cxx.

◆ targetKey

template<typename T >
SG::sgkey_t columnar::TestUtils::ColumnDataVectorLink< T >::targetKey = 0

Definition at line 959 of file ColumnarPhysliteTest.cxx.

◆ targetOffsetColumn

template<typename T >
const std::vector<ColumnarOffsetType>* columnar::TestUtils::ColumnDataVectorLink< T >::targetOffsetColumn = nullptr

Definition at line 958 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
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
MuonR4::to_string
std::string to_string(const SectorProjector proj)
Definition: MsTrackSeeder.cxx:74
columnar::TestUtils::BranchReader::entrySize
std::optional< float > entrySize() const
Definition: ColumnarPhysliteTest.cxx:246
StateLessPT_NewConfig.primary
primary
Definition: StateLessPT_NewConfig.py:234
columnar::TestUtils::BranchReader::numBaskets
std::optional< unsigned > numBaskets()
Definition: ColumnarPhysliteTest.cxx:262
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:369
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