15#include <arrow/util/key_value_metadata.h>
16#include <arrow/util/config.h>
31 throw o2::framework::runtime_error_f(
"Trying to dereference index with a wrong type in %s_as<T> for base target \"%s\". Note that if you have several compatible index targets in your process() signature, the last one will be the one actually bound.", getter,
target);
51 rows.resize(sel->GetNumSlots());
52 for (
auto i = 0;
i < sel->GetNumSlots(); ++
i) {
53 rows[
i] = sel->GetIndex(
i);
62 auto start_iterator = std::lower_bound(mSelectedRows.begin(), mSelectedRows.end(),
start);
63 auto stop_iterator = std::lower_bound(start_iterator, mSelectedRows.end(),
end);
65 std::ranges::transform(slicedSelection.begin(), slicedSelection.end(), slicedSelection.begin(),
66 [&
start](int64_t idx) {
67 return idx - static_cast<int64_t>(start);
69 return slicedSelection;
74 std::vector<std::shared_ptr<arrow::Field>>
fields;
75 std::vector<std::shared_ptr<arrow::ChunkedArray>> columns;
76 bool notEmpty = (tables[0]->num_rows() != 0);
77 std::ranges::for_each(tables, [&
fields, &columns, notEmpty](
auto const& t) {
78 std::ranges::copy(t->fields(), std::back_inserter(
fields));
80 std::ranges::copy(t->columns(), std::back_inserter(columns));
84 return arrow::Table::Make(
schema, columns);
90 requires(std::same_as<T, std::string>)
91auto makeString(T
const&
str)
96 requires(std::same_as<T, const char*>)
97auto makeString(T
const&
str)
103void canNotJoin(std::vector<std::shared_ptr<arrow::Table>>
const& tables, std::span<T>
labels)
105 for (
auto i = 0U;
i < tables.size() - 1; ++
i) {
106 if (tables[
i]->num_rows() != tables[
i + 1]->num_rows()) {
108 makeString(
labels[
i]), makeString(
labels[
i + 1]), tables[
i]->num_rows(), tables[
i + 1]->num_rows());
116 if (tables.size() == 1) {
119 canNotJoin(tables,
labels);
120 return joinTables(std::forward<std::vector<std::shared_ptr<arrow::Table>>>(tables));
125 if (tables.size() == 1) {
128 canNotJoin(tables,
labels);
129 return joinTables(std::forward<std::vector<std::shared_ptr<arrow::Table>>>(tables));
134 if (tables.size() == 1) {
137 std::vector<std::shared_ptr<arrow::ChunkedArray>> columns;
138 std::vector<std::shared_ptr<arrow::Field>> resultFields = tables[0]->schema()->fields();
139 auto compareFields = [](std::shared_ptr<arrow::Field>
const& f1, std::shared_ptr<arrow::Field>
const& f2) {
141 return (!f1->Equals(f2)) && (f1->name() < f2->name());
143 for (
size_t i = 1;
i < tables.size(); ++
i) {
144 auto&
fields = tables[
i]->schema()->fields();
145 std::vector<std::shared_ptr<arrow::Field>> intersection;
147 std::set_intersection(resultFields.begin(), resultFields.end(),
149 std::back_inserter(intersection), compareFields);
150 resultFields.swap(intersection);
153 for (
auto& field : resultFields) {
154 arrow::ArrayVector chunks;
155 for (
auto& table : tables) {
156 auto ci = table->schema()->GetFieldIndex(field->name());
158 throw std::runtime_error(
"Unable to find field " + field->name());
160 auto column = table->column(ci);
161 auto otherChunks = column->chunks();
162 chunks.insert(chunks.end(), otherChunks.begin(), otherChunks.end());
164 columns.push_back(std::make_shared<arrow::ChunkedArray>(chunks));
167 return arrow::Table::Make(std::make_shared<arrow::Schema>(resultFields), columns);
172 auto field = std::ranges::find_if(table->schema()->fields(), [&](std::shared_ptr<arrow::Field>
const&
f) {
173 auto caseInsensitiveCompare = [](const std::string_view& str1, const std::string& str2) {
174 return std::ranges::equal(
176 [](char c1, char c2) {
177 return std::tolower(static_cast<unsigned char>(c1)) ==
178 std::tolower(static_cast<unsigned char>(c2));
182 return caseInsensitiveCompare(
label,
f->name());
184 if (field == table->schema()->fields().end()) {
187 auto index = std::distance(table->schema()->fields().begin(), field);
188 return table->column(
index).get();
208 Int_t previousErrorLevel = gErrorIgnoreLevel;
209 gErrorIgnoreLevel = kFatal;
211 TMemFile
file(
"name", (
char*)payload,
size,
"READ");
212 gErrorIgnoreLevel = previousErrorLevel;
213 if (
file.IsZombie()) {
220 auto object =
file.GetObjectChecked(what, cl);
224 std::string objectName(cl->GetName());
225 objectName.erase(std::find_if(objectName.rbegin(), objectName.rend(), [](
unsigned char ch) {
226 return !std::isspace(ch);
229 objectName.erase(objectName.begin(), std::find_if(objectName.begin(), objectName.end(), [](
unsigned char ch) {
230 return !std::isspace(ch);
233 object =
file.GetObjectChecked(objectName.c_str(), cl);
234 LOG(warn) <<
"Did not find object under expected name " << what;
238 LOG(warn) <<
"Found object under deprecated name " << cl->GetName();
243 if (cl->InheritsFrom(
"TObject")) {
246 auto tree =
dynamic_cast<TTree*
>((
TObject*)
object);
248 tree->LoadBaskets(0x1L << 32);
249 tree->SetDirectory(
nullptr);
252 auto h =
dynamic_cast<TH1*
>((
TObject*)
object);
254 h->SetDirectory(
nullptr);
269 if (
pos != std::string::npos) {
277 std::transform(
str.begin(),
str.end(),
str.begin(), [](
unsigned char c) { return std::toupper(c); });
305 offset =
static_cast<int64_t
>(offset_);
std::vector< std::string > labels
std::shared_ptr< arrow::Schema > schema
std::vector< std::shared_ptr< arrow::Field > > fields
Class for time synchronization of RawReader instances.
GLsizei const GLfloat * value
GLuint GLsizei const GLchar * label
std::shared_ptr< gandiva::SelectionVector > Selection
Defining PrimaryVertex explicitly as messageable.
RuntimeErrorRef runtime_error(const char *)
void throw_error(RuntimeErrorRef)
std::string strToUpper(std::string &&str)
RuntimeErrorRef runtime_error_f(const char *,...)
std::string cutString(std::string &&str)
void * extractCCDBPayload(char *payload, size_t size, TClass const *cl, const char *what)
SelectionVector selectionToVector(gandiva::Selection const &sel)
void notBoundTable(const char *tableName)
SelectionVector sliceSelection(std::span< int64_t const > const &mSelectedRows, int64_t nrows, uint64_t offset)
std::vector< int64_t > SelectionVector
void missingFilterDeclaration(int hash, int ai)
void accessingInvalidIndexFor(const char *getter)
void dereferenceWithWrongType(const char *getter, const char *target)
void getterNotFound(const char *targetColumnLabel)
void missingOptionalPreslice(const char *label, const char *key)
arrow::ChunkedArray * getIndexFromLabel(arrow::Table *table, std::string_view label)
void notFoundColumn(const char *label, const char *key)
const std::string binding
Entry const & getBindingKey() const
SliceInfoUnsortedPtr sliceInfo
std::span< const int64_t > getSliceFor(int value) const
void updateSliceInfo(SliceInfoUnsortedPtr &&si)
void updateSliceInfo(SliceInfoPtr &&si)
std::shared_ptr< arrow::Table > getSliceFor(int value, std::shared_ptr< arrow::Table > const &input, uint64_t &offset) const
std::pair< int64_t, int64_t > getSliceFor(int value) const
std::span< int64_t const > getSliceFor(int value) const
static std::shared_ptr< arrow::Table > joinTables(std::vector< std::shared_ptr< arrow::Table > > &&tables)
static std::shared_ptr< arrow::Table > concatTables(std::vector< std::shared_ptr< arrow::Table > > &&tables)
LOG(info)<< "Compressed in "<< sw.CpuTime()<< " s"
std::unique_ptr< TTree > tree((TTree *) flIn.Get(std::string(o2::base::NameConf::CTFTREENAME).c_str()))
std::vector< ReadoutWindowData > rows