sparrow 0.3.0
Loading...
Searching...
No Matches
record_batch_example.cpp
Go to the documentation of this file.
1
4
5
6#include <cassert>
7
10
11std::vector<sparrow::array> make_array_list(const std::size_t data_size)
12{
14 std::ranges::iota_view{std::size_t(0), std::size_t(data_size)}
15 | std::views::transform(
16 [](auto i)
17 {
18 return static_cast<std::uint16_t>(i);
19 }
20 )
21 );
23 std::ranges::iota_view{std::int32_t(4), 4 + std::int32_t(data_size)}
24 );
26 std::ranges::iota_view{std::int32_t(2), 2 + std::int32_t(data_size)}
27 );
28
29 std::vector<sparrow::array> arr_list = {
30 sparrow::array{std::move(pr0)},
31 sparrow::array{std::move(pr1)},
32 sparrow::array{std::move(pr2)}
33 };
34 return arr_list;
35}
36
37int main()
38{
40 const std::vector<std::string> name_list = {"first", "second", "third"};
41 constexpr std::size_t data_size = 10;
42 const std::vector<sparrow::array> array_list = make_array_list(data_size);
43 const sparrow::record_batch record{name_list, array_list};
44 assert(record.nb_columns() == array_list.size());
45 assert(record.nb_rows() == data_size);
46 assert(record.contains_column(name_list[0]));
47 assert(record.get_column_name(0) == name_list[0]);
48 assert(record.get_column(0) == array_list[0]);
49 assert(std::ranges::equal(record.names(), name_list));
50 assert(std::ranges::equal(record.columns(), array_list));
52 return EXIT_SUCCESS;
53}
int main()
Dynamically typed array encapsulating an Arrow layout.
Definition array_api.hpp:39
Table-like data structure.
array_trivial_copyable< T > primitive_array
Array of values of whose type has fixed binary size.
std::vector< sparrow::array > make_array_list(const std::size_t data_size)