ATLAS Offline Software
Loading...
Searching...
No Matches
columnar::TestUtils::ColumnDataSamplingPattern< Reader > Struct Template Referencefinal
Inheritance diagram for columnar::TestUtils::ColumnDataSamplingPattern< Reader >:
Collaboration diagram for columnar::TestUtils::ColumnDataSamplingPattern< Reader >:

Public Member Functions

 ColumnDataSamplingPattern (const std::string &val_branchName)
virtual bool connect (Backend source, std::unordered_map< std::string, const std::vector< ColumnarOffsetType > * > &, std::unordered_map< std::string, ColumnInfo > &requestedColumns) override
virtual void clearColumns () override
virtual void getEntry (Long64_t entry) override
virtual void setData (ColumnVectorData &colData) override
virtual BranchPerfData getPerfData (float emptyTime) override
virtual void collectColumnData () override
void connectColumnIndices (const ColumnVectorHeader &header)
 lookup and store column indices from the header for all enabled output columns

Public Attributes

Reader< xAOD::CaloClusterContainerbranchReader
std::vector< ColumnarOffsetTypeoffsets = {0}
std::vector< std::uint32_t > columnData
Benchmark benchmarkUnpack
Benchmark benchmark
unsigned entries = 0
std::vector< OutputColumnInfooutputColumns

Detailed Description

template<template< typename > class Reader>
struct columnar::TestUtils::ColumnDataSamplingPattern< Reader >

Definition at line 2006 of file ColumnarPhysliteTest.cxx.

Constructor & Destructor Documentation

◆ ColumnDataSamplingPattern()

template<template< typename > class Reader>
columnar::TestUtils::ColumnDataSamplingPattern< Reader >::ColumnDataSamplingPattern ( const std::string & val_branchName)
inline

Definition at line 2015 of file ColumnarPhysliteTest.cxx.

2016 : branchReader (val_branchName), benchmarkUnpack (branchReader.columnName()+".samplingPattern(fallback)(unpack)"), benchmark (branchReader.columnName() + ".samplingPattern(fallback)")
2017 {
2018 outputColumns.push_back ({.name = branchReader.columnName() + ".samplingPattern"});
2019 outputColumns.push_back ({.name = branchReader.columnName(), .isOffset = true, .primary = false});
2020 }
std::vector< OutputColumnInfo > outputColumns
Reader< xAOD::CaloClusterContainer > branchReader

Member Function Documentation

◆ clearColumns()

template<template< typename > class Reader>
virtual void columnar::TestUtils::ColumnDataSamplingPattern< Reader >::clearColumns ( )
inlineoverridevirtual

Implements columnar::TestUtils::IColumnData.

Definition at line 2045 of file ColumnarPhysliteTest.cxx.

2046 {
2047 columnData.clear();
2048 offsets.clear();
2049 offsets.push_back (0);
2050 }

◆ collectColumnData()

template<template< typename > class Reader>
virtual void columnar::TestUtils::ColumnDataSamplingPattern< Reader >::collectColumnData ( )
inlineoverridevirtual

◆ connect()

template<template< typename > class Reader>
virtual bool columnar::TestUtils::ColumnDataSamplingPattern< Reader >::connect ( Backend source,
std::unordered_map< std::string, const std::vector< ColumnarOffsetType > * > & ,
std::unordered_map< std::string, ColumnInfo > & requestedColumns )
inlineoverridevirtual

Implements columnar::TestUtils::IColumnData.

Definition at line 2022 of file ColumnarPhysliteTest.cxx.

2023 {
2024 auto iter = requestedColumns.find (outputColumns.at(0).name);
2025 if (iter == requestedColumns.end())
2026 return false;
2027 outputColumns.at(0).enabled = true;
2028
2029 branchReader.connectTree(source);
2030 if (iter->second.offsetName != outputColumns.at(1).name)
2031 throw std::runtime_error ("offset name mismatch: " + iter->second.offsetName + " != " + outputColumns.at(1).name);
2032
2033 requestedColumns.erase (iter);
2034
2035 iter = requestedColumns.find (outputColumns.at(1).name);
2036 if (iter == requestedColumns.end())
2037 {
2038 return true;
2039 }
2040 outputColumns.at(1).enabled = true;
2041 requestedColumns.erase (iter);
2042 return true;
2043 }

◆ connectColumnIndices()

void columnar::TestUtils::IColumnData::connectColumnIndices ( const ColumnVectorHeader & header)
inlineinherited

lookup and store column indices from the header for all enabled output columns

Definition at line 675 of file ColumnarPhysliteTest.cxx.

676 {
677 for (auto& col : outputColumns)
678 {
679 if (col.enabled)
680 col.columnIndex = header.getColumnIndex (col.name);
681 }
682 }

◆ getEntry()

template<template< typename > class Reader>
virtual void columnar::TestUtils::ColumnDataSamplingPattern< Reader >::getEntry ( Long64_t entry)
inlineoverridevirtual

Implements columnar::TestUtils::IColumnData.

Definition at line 2052 of file ColumnarPhysliteTest.cxx.

2053 {
2054 benchmark.startTimer ();
2055 const auto& branchData = branchReader.getEntry (entry);
2056 benchmark.stopTimer ();
2057 benchmarkUnpack.startTimer ();
2058 for (auto data : branchData)
2059 {
2060 columnData.push_back (data->samplingPattern());
2061 }
2062 offsets.push_back (columnData.size());
2063 benchmarkUnpack.stopTimer ();
2064 }

◆ getPerfData()

template<template< typename > class Reader>
virtual BranchPerfData columnar::TestUtils::ColumnDataSamplingPattern< Reader >::getPerfData ( float emptyTime)
inlinenodiscardoverridevirtual

Implements columnar::TestUtils::IColumnData.

Definition at line 2074 of file ColumnarPhysliteTest.cxx.

2075 {
2077 result.name = branchReader.columnName() + "(fallback)";
2078 result.timeRead = benchmark.getEntryTime(emptyTime);
2079 result.timeUnpack = benchmarkUnpack.getEntryTime(emptyTime);
2080 benchmark.setSilence();
2081 benchmarkUnpack.setSilence();
2082 result.entrySize = branchReader.entrySize();
2083 result.uncompressedSize = branchReader.uncompressedSize();
2084 result.numBaskets = branchReader.numBaskets();
2086 return result;
2087 }

◆ setData()

template<template< typename > class Reader>
virtual void columnar::TestUtils::ColumnDataSamplingPattern< Reader >::setData ( ColumnVectorData & colData)
inlineoverridevirtual

Implements columnar::TestUtils::IColumnData.

Definition at line 2066 of file ColumnarPhysliteTest.cxx.

2067 {
2068 if (outputColumns.at(0).columnIndex != ColumnVectorHeader::nullIndex)
2069 colData.setColumn (outputColumns.at(0).columnIndex, columnData.size(), columnData.data());
2070 if (outputColumns.at(1).columnIndex != ColumnVectorHeader::nullIndex)
2071 colData.setColumn (outputColumns.at(1).columnIndex, offsets.size(), offsets.data());
2072 }

Member Data Documentation

◆ benchmark

template<template< typename > class Reader>
Benchmark columnar::TestUtils::ColumnDataSamplingPattern< Reader >::benchmark

Definition at line 2012 of file ColumnarPhysliteTest.cxx.

◆ benchmarkUnpack

template<template< typename > class Reader>
Benchmark columnar::TestUtils::ColumnDataSamplingPattern< Reader >::benchmarkUnpack

Definition at line 2011 of file ColumnarPhysliteTest.cxx.

◆ branchReader

template<template< typename > class Reader>
Reader<xAOD::CaloClusterContainer> columnar::TestUtils::ColumnDataSamplingPattern< Reader >::branchReader

Definition at line 2008 of file ColumnarPhysliteTest.cxx.

◆ columnData

template<template< typename > class Reader>
std::vector<std::uint32_t> columnar::TestUtils::ColumnDataSamplingPattern< Reader >::columnData

Definition at line 2010 of file ColumnarPhysliteTest.cxx.

◆ entries

template<template< typename > class Reader>
unsigned columnar::TestUtils::ColumnDataSamplingPattern< Reader >::entries = 0

Definition at line 2013 of file ColumnarPhysliteTest.cxx.

◆ offsets

template<template< typename > class Reader>
std::vector<ColumnarOffsetType> columnar::TestUtils::ColumnDataSamplingPattern< Reader >::offsets = {0}

Definition at line 2009 of file ColumnarPhysliteTest.cxx.

2009{0};

◆ outputColumns

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

Definition at line 668 of file ColumnarPhysliteTest.cxx.


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