ATLAS Offline Software
Loading...
Searching...
No Matches
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
virtual void collectColumnData () 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
unsigned entries = 0
unsigned nullEntries = 0
std::vector< OutputColumnInfooutputColumns

Detailed Description

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

Definition at line 1007 of file ColumnarPhysliteTest.cxx.

Member Typedef Documentation

◆ CM

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

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

1023 : branchReader (val_branchName), benchmarkUnpack (branchReader.columnName()+"(unpack)"), benchmark (branchReader.columnName())
1024 {
1025 outputColumns.push_back ({.name = branchReader.columnName()});
1026 outputColumns.push_back ({.name = branchReader.containerName(), .isOffset = true, .primary = false});
1027 }
std::vector< OutputColumnInfo > outputColumns

Member Function Documentation

◆ clearColumns()

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

Implements columnar::TestUtils::IColumnData.

Definition at line 1068 of file ColumnarPhysliteTest.cxx.

1069 {
1070 columnData.clear();
1071 offsets.clear();
1072 offsets.push_back (0);
1073 }

◆ collectColumnData()

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

Implements columnar::TestUtils::IColumnData.

Definition at line 1138 of file ColumnarPhysliteTest.cxx.

1139 {
1140 entries += columnData.size();
1141 for (const auto& index : columnData)
1142 {
1144 nullEntries += 1;
1145 }
1146 }

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

1030 {
1031 auto iter = requestedColumns.find (outputColumns.at(0).name);
1032 if (iter == requestedColumns.end())
1033 return false;
1034 outputColumns.at(0).enabled = true;
1035
1036 branchReader.connectTree (tree);
1037
1038 if (iter->second.offsetName != outputColumns.at(1).name)
1039 throw std::runtime_error ("offset name mismatch: " + iter->second.offsetName + " != " + outputColumns.at(1).name);
1040
1041 if (iter->second.linkTargetNames.size() != 1)
1042 throw std::runtime_error ("expected exactly one link target name for: " + outputColumns.at(0).name);
1043 targetContainerName = iter->second.linkTargetNames.at(0);
1044 if (auto keyIter = knownKeys.find (targetContainerName); keyIter != knownKeys.end())
1045 targetKey = keyIter->second;
1046 if (auto targetOffsetIter = offsetColumns.find (iter->second.linkTargetNames.at(0)); targetOffsetIter != offsetColumns.end())
1048 else
1049 throw std::runtime_error ("missing offset column(vector-link): " + iter->second.linkTargetNames.at(0));
1050
1051 requestedColumns.erase (iter);
1052
1053 if (auto offsetIter = offsetColumns.find (outputColumns.at(1).name); offsetIter != offsetColumns.end())
1054 offsetColumn = offsetIter->second;
1055 else
1056 offsetColumns.emplace (outputColumns.at(1).name, &offsets);
1057
1058 iter = requestedColumns.find (outputColumns.at(1).name);
1059 if (iter != requestedColumns.end())
1060 {
1061 outputColumns.at(1).enabled = true;
1062 requestedColumns.erase (iter);
1063 }
1064
1065 return true;
1066 }

◆ getEntry()

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

Implements columnar::TestUtils::IColumnData.

Definition at line 1075 of file ColumnarPhysliteTest.cxx.

1076 {
1077 benchmark.startTimer ();
1078 const auto& branchData = branchReader.getEntry (entry);
1079 benchmark.stopTimer ();
1080 benchmarkUnpack.startTimer ();
1081 if (targetOffsetColumn->size() < 2)
1082 throw std::runtime_error ("target offset column not yet filled for: " + outputColumns.at(0).name);
1083 for (auto& element : branchData)
1084 {
1085 if (element.isDefault() || (element.key() == 0 && element.index() == 0))
1086 columnData.push_back (invalidObjectIndex);
1087 else
1088 {
1089 columnData.push_back (element.index() + targetOffsetColumn->at (targetOffsetColumn->size()-2));
1090 if (element.key() != targetKey)
1091 {
1092 if (targetKey == 0)
1093 {
1094 targetKey = element.key();
1095 std::cout << "assume target key for " << targetContainerName << " is " << std::hex << targetKey << std::dec << std::endl;
1096 } else
1097 {
1098 throw std::runtime_error ("target key mismatch: " + std::to_string (element.key()) + " != " + std::to_string (targetKey) + " for " + outputColumns.at(0).name);
1099 }
1100 }
1101 }
1102 }
1103 offsets.push_back (columnData.size());
1104 if (offsetColumn)
1105 {
1106 if (offsetColumn->size() != offsets.size())
1107 throw std::runtime_error ("offset column not filled yet: " + outputColumns.at(1).name);
1108 if (offsetColumn->back() != offsets.back())
1109 throw std::runtime_error ("offset column does not match: " + outputColumns.at(1).name);
1110 }
1111 benchmarkUnpack.stopTimer ();
1112 }

◆ getPerfData()

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

Implements columnar::TestUtils::IColumnData.

Definition at line 1122 of file ColumnarPhysliteTest.cxx.

1123 {
1125 result.name = branchReader.columnName();
1126 result.timeRead = benchmark.getEntryTime(emptyTime);
1127 result.timeUnpack = benchmarkUnpack.getEntryTime(emptyTime);
1128 benchmark.setSilence();
1129 benchmarkUnpack.setSilence();
1130 result.entrySize = branchReader.entrySize();
1131 result.uncompressedSize = branchReader.uncompressedSize();
1132 result.numBaskets = branchReader.numBaskets();
1135 return result;
1136 }

◆ setData()

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

Implements columnar::TestUtils::IColumnData.

Definition at line 1114 of file ColumnarPhysliteTest.cxx.

1115 {
1116 if (outputColumns.at(0).enabled)
1117 tool.setColumn (outputColumns.at(0).name, columnData.size(), columnData.data());
1118 if (outputColumns.at(1).enabled)
1119 tool.setColumn (outputColumns.at(1).name, offsets.size(), offsets.data());
1120 }

Member Data Documentation

◆ benchmark

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

Definition at line 1018 of file ColumnarPhysliteTest.cxx.

◆ benchmarkUnpack

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

Definition at line 1017 of file ColumnarPhysliteTest.cxx.

◆ branchReader

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

Definition at line 1010 of file ColumnarPhysliteTest.cxx.

◆ columnData

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

Definition at line 1013 of file ColumnarPhysliteTest.cxx.

◆ entries

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

Definition at line 1019 of file ColumnarPhysliteTest.cxx.

◆ nullEntries

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

Definition at line 1020 of file ColumnarPhysliteTest.cxx.

◆ offsetColumn

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

Definition at line 1011 of file ColumnarPhysliteTest.cxx.

◆ offsets

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

Definition at line 1012 of file ColumnarPhysliteTest.cxx.

1012{0};

◆ outputColumns

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

Definition at line 371 of file ColumnarPhysliteTest.cxx.

◆ targetContainerName

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

Definition at line 1016 of file ColumnarPhysliteTest.cxx.

◆ targetKey

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

Definition at line 1015 of file ColumnarPhysliteTest.cxx.

◆ targetOffsetColumn

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

Definition at line 1014 of file ColumnarPhysliteTest.cxx.


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