-
Notifications
You must be signed in to change notification settings - Fork 4
Expand file tree
/
Copy pathwrite.C
More file actions
94 lines (82 loc) · 3.27 KB
/
write.C
File metadata and controls
94 lines (82 loc) · 3.27 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
#include <ROOT/RField.hxx>
#include <ROOT/RNTupleModel.hxx>
#include <ROOT/RNTupleUtil.hxx>
#include <ROOT/RNTupleWriteOptions.hxx>
#include <ROOT/RNTupleWriter.hxx>
using ROOT::Experimental::EColumnType;
using ROOT::Experimental::RField;
using ROOT::Experimental::RNTupleModel;
using ROOT::Experimental::RNTupleWriteOptions;
using ROOT::Experimental::RNTupleWriter;
#include <cstdint>
#include <memory>
#include <string>
#include <string_view>
#include <variant>
#include <vector>
using PtrInt32Ty = std::unique_ptr<std::int32_t>;
using VariantTy = std::variant<std::int32_t, std::string>;
using VectorInt32Ty = std::vector<std::int32_t>;
static std::shared_ptr<PtrInt32Ty> MakeIntField(RNTupleModel &model,
std::string_view name,
EColumnType indexType) {
auto field = std::make_unique<RField<PtrInt32Ty>>(name);
field->SetColumnRepresentatives({{indexType}});
model.AddField(std::move(field));
return model.GetDefaultEntry().GetPtr<PtrInt32Ty>(name);
}
void write(std::string_view filename = "types.unique_ptr.root") {
auto model = RNTupleModel::Create();
// Non-split index encoding
auto Index32 = MakeIntField(*model, "Index32", EColumnType::kIndex32);
auto Index64 = MakeIntField(*model, "Index64", EColumnType::kIndex64);
// Split index encoding
auto SplitIndex32 =
MakeIntField(*model, "SplitIndex32", EColumnType::kSplitIndex32);
auto SplitIndex64 =
MakeIntField(*model, "SplitIndex64", EColumnType::kSplitIndex64);
auto String = model->MakeField<std::unique_ptr<std::string>>("String");
auto Variant = model->MakeField<std::unique_ptr<VariantTy>>("Variant");
auto VectorInt32 =
model->MakeField<std::unique_ptr<VectorInt32Ty>>("VectorInt32");
auto VectorPtr =
model->MakeField<std::vector<std::unique_ptr<std::int32_t>>>("VectorPtr");
RNTupleWriteOptions options;
options.SetCompression(0);
auto writer =
RNTupleWriter::Recreate(std::move(model), "ntpl", filename, options);
// First entry: simple values
*Index32 = std::make_unique<std::int32_t>(1);
*Index64 = std::make_unique<std::int32_t>(2);
*SplitIndex32 = std::make_unique<std::int32_t>(3);
*SplitIndex64 = std::make_unique<std::int32_t>(4);
*String = std::make_unique<std::string>("abc");
*Variant = std::make_unique<VariantTy>("def");
*VectorInt32 = std::make_unique<VectorInt32Ty>();
**VectorInt32 = {1, 2, 3};
VectorPtr->push_back(std::make_unique<std::int32_t>(4));
VectorPtr->push_back(std::make_unique<std::int32_t>(5));
VectorPtr->push_back(std::make_unique<std::int32_t>(6));
writer->Fill();
// Second entry: no value
Index32->reset();
Index64->reset();
SplitIndex32->reset();
SplitIndex64->reset();
String->reset();
Variant->reset();
VectorInt32->reset();
VectorPtr->clear();
VectorPtr->push_back(nullptr);
writer->Fill();
// Third entry: zero / empty value
*Index32 = std::make_unique<std::int32_t>(0);
*Index64 = std::make_unique<std::int32_t>(0);
*SplitIndex32 = std::make_unique<std::int32_t>(0);
*SplitIndex64 = std::make_unique<std::int32_t>(0);
*String = std::make_unique<std::string>("");
*Variant = std::make_unique<VariantTy>(0);
*VectorInt32 = std::make_unique<VectorInt32Ty>();
VectorPtr->clear();
writer->Fill();
}