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

Public Member Functions

 ColumnDataVectorVectorVariantLink (const std::string &val_branchName)
 
 ~ColumnDataVectorVectorVariantLink ()
 
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 (ColumnarToolWrapperData &tool) override
 

Public Attributes

BranchReader< std::vector< std::vector< ElementLink< T > > > > branchReader
 
std::vector< ColumnarOffsetTypeoffsets = {0}
 
std::vector< ColumnarOffsetTypecolumnData
 
std::vector< std::uint8_t > keysColumn
 
std::vector< std::string > containers
 
std::vector< SG::sgkey_tcontainerKeys
 
std::vector< const std::vector< ColumnarOffsetType > * > containerOffsets
 
Benchmark benchmarkUnpack
 
Benchmark benchmark
 
bool checkUnknownKeys = false
 
std::unordered_map< SG::sgkey_t, std::unordered_set< std::string > > unknownKeys
 
std::vector< OutputColumnInfooutputColumns
 

Detailed Description

template<typename T>
struct columnar::PhysliteTestHelpers::ColumnDataVectorVectorVariantLink< T >

Definition at line 802 of file ColumnarPhysliteTest.cxx.

Constructor & Destructor Documentation

◆ ColumnDataVectorVectorVariantLink()

template<typename T >
columnar::PhysliteTestHelpers::ColumnDataVectorVectorVariantLink< T >::ColumnDataVectorVectorVariantLink ( const std::string &  val_branchName)
inlineexplicit

Definition at line 817 of file ColumnarPhysliteTest.cxx.

819  {
820  outputColumns.push_back ({.name = branchReader.columnName() + ".data"});
821  outputColumns.push_back ({.name = branchReader.columnName() + ".offset", .isOffset = true});
822  outputColumns.push_back ({.name = branchReader.columnName() + ".keys"});
823  }

◆ ~ColumnDataVectorVectorVariantLink()

Definition at line 825 of file ColumnarPhysliteTest.cxx.

826  {
827  // print unknown keys and containers they may be associated
828  // with, based on whether they were always within the range of
829  // elements allowed for the container.
830  for (auto& [key, forbiddenContainer] : unknownKeys)
831  {
832  std::cout << "unknown key: " << std::hex << key << std::dec << ", allowed containers:";
833  for (const auto& container : containers)
834  {
835  if (forbiddenContainer.find (container) == forbiddenContainer.end())
836  std::cout << " " << container;
837  }
838  std::cout << std::endl;
839  }
840  }

Member Function Documentation

◆ clearColumns()

template<typename T >
virtual void columnar::PhysliteTestHelpers::ColumnDataVectorVectorVariantLink< T >::clearColumns ( )
inlineoverridevirtual

Implements columnar::PhysliteTestHelpers::IColumnData.

Definition at line 891 of file ColumnarPhysliteTest.cxx.

892  {
893  columnData.clear();
894  offsets.clear();
895  offsets.push_back (0);
896  }

◆ connect()

template<typename T >
virtual bool columnar::PhysliteTestHelpers::ColumnDataVectorVectorVariantLink< T >::connect ( TTree *  tree,
std::unordered_map< std::string, const std::vector< ColumnarOffsetType > * > &  offsetColumns,
std::unordered_map< std::string, ColumnInfo > &  requestedColumns 
)
inlineoverridevirtual

Implements columnar::PhysliteTestHelpers::IColumnData.

Definition at line 842 of file ColumnarPhysliteTest.cxx.

843  {
844  auto iter = requestedColumns.find (outputColumns.at(0).name);
845  if (iter == requestedColumns.end())
846  return false;
847  outputColumns.at(0).enabled = true;
848 
850 
851  if (iter->second.offsetName != outputColumns.at(1).name)
852  throw std::runtime_error ("offset name mismatch: " + iter->second.offsetName + " != " + outputColumns.at(1).name);
853  containers = iter->second.variantLinkContainers;
854  if (containers.empty() || iter->second.variantLinkKeyColumn.empty())
855  throw std::runtime_error ("no variant link containers for: " + outputColumns.at(0).name);
856  if (iter->second.variantLinkKeyColumn != outputColumns.at(2).name)
857  throw std::runtime_error ("variant link key column mismatch: " + iter->second.variantLinkKeyColumn + " != " + outputColumns.at(2).name);
858 
859  for ([[maybe_unused]] auto& container : containers)
860  {
861  keysColumn.push_back (keysColumn.size()+1);
862  containerOffsets.push_back (offsetColumns.at (container));
863  if (auto iter = knownKeys.find (container); iter != knownKeys.end())
864  {
865  containerKeys.push_back (iter->second);
866  } else
867  {
868  checkUnknownKeys = true;
869  containerKeys.push_back (0u);
870  }
871  }
872 
873  requestedColumns.erase (iter);
874 
875  iter = requestedColumns.find (outputColumns.at(1).name);
876  if (iter != requestedColumns.end())
877  {
878  outputColumns.at(1).enabled = true;
879  requestedColumns.erase (iter);
880  }
881 
882  iter = requestedColumns.find (outputColumns.at(2).name);
883  if (iter != requestedColumns.end())
884  {
885  outputColumns.at(2).enabled = true;
886  requestedColumns.erase (iter);
887  }
888  return true;
889  }

◆ getEntry()

template<typename T >
virtual void columnar::PhysliteTestHelpers::ColumnDataVectorVectorVariantLink< T >::getEntry ( Long64_t  entry)
inlineoverridevirtual

Implements columnar::PhysliteTestHelpers::IColumnData.

Definition at line 898 of file ColumnarPhysliteTest.cxx.

899  {
900  benchmark.startTimer ();
901  const auto& branchData = branchReader.getEntry (entry);
902  benchmark.stopTimer ();
903  benchmarkUnpack.startTimer ();
904  for (auto& data : branchData)
905  {
906  for (auto& element : data)
907  {
908  if (element.isDefault())
909  columnData.push_back (invalidObjectIndex);
910  else
911  {
912  ColumnarOffsetType key = 0xff;
914  for (std::size_t i = 0; i < containers.size(); ++i)
915  {
916  if (element.key() == containerKeys[i])
917  {
918  if (containerOffsets[i]->back() <= element.index())
919  throw std::runtime_error ("invalid index: " + std::to_string (element.index()) + " in container: " + containers[i] + " with size: " + std::to_string (containerOffsets[i]->back()));
920  key = keysColumn[i];
921  if (containerOffsets[i]->size() < 2)
922  throw std::runtime_error ("container offset not yet filled for: " + containers[i]);
923  index = containerOffsets[i]->at (containerOffsets[i]->size()-2) + element.index();
924  break;
925  }
926  }
927  if (key == 0xff && checkUnknownKeys)
928  {
929  // this records which containers the unknown key is
930  // compatible with, so that I may figure out which
931  // container it is and hard-code it above.
932  auto& forbiddenContainers = unknownKeys[element.key()];
933  for (std::size_t i = 0; i < containers.size(); ++i)
934  {
935  if (containerOffsets[i]->back() <= containerOffsets[i]->at (containerOffsets[i]->size()-2) + element.index())
936  forbiddenContainers.insert (containers[i]);
937  }
938  }
939  columnData.push_back (index | (key << 8*(sizeof(ColumnarOffsetType)-1)));
940  }
941  }
942  offsets.push_back (columnData.size());
943  }
944  benchmarkUnpack.stopTimer ();
945  }

◆ setData()

template<typename T >
virtual void columnar::PhysliteTestHelpers::ColumnDataVectorVectorVariantLink< T >::setData ( ColumnarToolWrapperData tool)
inlineoverridevirtual

Implements columnar::PhysliteTestHelpers::IColumnData.

Definition at line 947 of file ColumnarPhysliteTest.cxx.

948  {
949  if (outputColumns.at(0).enabled)
950  tool.setColumn (outputColumns.at(0).name, columnData.size(), columnData.data());
951  if (outputColumns.at(1).enabled)
952  tool.setColumn (outputColumns.at(1).name, offsets.size(), offsets.data());
953  if (outputColumns.at(2).enabled)
954  tool.setColumn (outputColumns.at(2).name, keysColumn.size(), keysColumn.data());
955  }

Member Data Documentation

◆ benchmark

template<typename T >
Benchmark columnar::PhysliteTestHelpers::ColumnDataVectorVectorVariantLink< T >::benchmark

Definition at line 812 of file ColumnarPhysliteTest.cxx.

◆ benchmarkUnpack

template<typename T >
Benchmark columnar::PhysliteTestHelpers::ColumnDataVectorVectorVariantLink< T >::benchmarkUnpack

Definition at line 811 of file ColumnarPhysliteTest.cxx.

◆ branchReader

template<typename T >
BranchReader<std::vector<std::vector<ElementLink<T> > > > columnar::PhysliteTestHelpers::ColumnDataVectorVectorVariantLink< T >::branchReader

Definition at line 804 of file ColumnarPhysliteTest.cxx.

◆ checkUnknownKeys

template<typename T >
bool columnar::PhysliteTestHelpers::ColumnDataVectorVectorVariantLink< T >::checkUnknownKeys = false

Definition at line 814 of file ColumnarPhysliteTest.cxx.

◆ columnData

template<typename T >
std::vector<ColumnarOffsetType> columnar::PhysliteTestHelpers::ColumnDataVectorVectorVariantLink< T >::columnData

Definition at line 806 of file ColumnarPhysliteTest.cxx.

◆ containerKeys

template<typename T >
std::vector<SG::sgkey_t> columnar::PhysliteTestHelpers::ColumnDataVectorVectorVariantLink< T >::containerKeys

Definition at line 809 of file ColumnarPhysliteTest.cxx.

◆ containerOffsets

template<typename T >
std::vector<const std::vector<ColumnarOffsetType>*> columnar::PhysliteTestHelpers::ColumnDataVectorVectorVariantLink< T >::containerOffsets

Definition at line 810 of file ColumnarPhysliteTest.cxx.

◆ containers

template<typename T >
std::vector<std::string> columnar::PhysliteTestHelpers::ColumnDataVectorVectorVariantLink< T >::containers

Definition at line 808 of file ColumnarPhysliteTest.cxx.

◆ keysColumn

template<typename T >
std::vector<std::uint8_t> columnar::PhysliteTestHelpers::ColumnDataVectorVectorVariantLink< T >::keysColumn

Definition at line 807 of file ColumnarPhysliteTest.cxx.

◆ offsets

template<typename T >
std::vector<ColumnarOffsetType> columnar::PhysliteTestHelpers::ColumnDataVectorVectorVariantLink< T >::offsets = {0}

Definition at line 805 of file ColumnarPhysliteTest.cxx.

◆ outputColumns

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

Definition at line 197 of file ColumnarPhysliteTest.cxx.

◆ unknownKeys

template<typename T >
std::unordered_map<SG::sgkey_t,std::unordered_set<std::string> > columnar::PhysliteTestHelpers::ColumnDataVectorVectorVariantLink< T >::unknownKeys

Definition at line 815 of file ColumnarPhysliteTest.cxx.


The documentation for this struct was generated from the following file:
data
char data[hepevt_bytes_allocation_ATLAS]
Definition: HepEvt.cxx:11
columnar::PhysliteTestHelpers::BranchReader::getEntry
const T & getEntry(Long64_t entry)
Definition: ColumnarPhysliteTest.cxx:176
createLinkingScheme.iter
iter
Definition: createLinkingScheme.py:62
index
Definition: index.py:1
columnar::PhysliteTestHelpers::BranchReader::columnName
std::string columnName() const
Definition: ColumnarPhysliteTest.cxx:140
tree
TChain * tree
Definition: tile_monitor.h:30
columnar::PhysliteTestHelpers::BranchReader::connectTree
void connectTree(TTree *tree)
Definition: ColumnarPhysliteTest.cxx:164
Trk::u
@ u
Enums for curvilinear frames.
Definition: ParamDefs.h:77
lumiFormat.i
int i
Definition: lumiFormat.py:85
columnar::size
std::size_t size() const noexcept
Definition: ObjectRange.h:166
columnar::PhysliteTestHelpers::IColumnData::outputColumns
std::vector< OutputColumnInfo > outputColumns
Definition: ColumnarPhysliteTest.cxx:197
GetAllXsec.entry
list entry
Definition: GetAllXsec.py:132
ActsTrk::to_string
std::string to_string(const DetectorType &type)
Definition: GeometryDefs.h:34
AtlCoolConsole.tool
tool
Definition: AtlCoolConsole.py:452
columnar::invalidObjectIndex
constexpr ColumnarOffsetType invalidObjectIndex
the value for an invalid element index
Definition: IColumnarTool.h:25
columnar::ColumnarOffsetType
std::size_t ColumnarOffsetType
the type used for the size and offsets in the columnar data
Definition: IColumnarTool.h:20
mapkey::key
key
Definition: TElectronEfficiencyCorrectionTool.cxx:37