sparrow 0.3.0
Loading...
Searching...
No Matches
record_batch_example.cpp

Example of usage of the record_batch class.

Example of usage of the record_batch class.

#include <cassert>
std::vector<sparrow::array> make_array_list(const std::size_t data_size)
{
std::ranges::iota_view{std::size_t(0), std::size_t(data_size)}
| std::views::transform(
[](auto i)
{
return static_cast<std::uint16_t>(i);
}
)
);
std::ranges::iota_view{std::int32_t(4), 4 + std::int32_t(data_size)}
);
std::ranges::iota_view{std::int32_t(2), 2 + std::int32_t(data_size)}
);
std::vector<sparrow::array> arr_list = {
sparrow::array{std::move(pr0)},
sparrow::array{std::move(pr1)},
sparrow::array{std::move(pr2)}
};
return arr_list;
}
int main()
{
const std::vector<std::string> name_list = {"first", "second", "third"};
constexpr std::size_t data_size = 10;
const std::vector<sparrow::array> array_list = make_array_list(data_size);
const sparrow::record_batch record{name_list, array_list};
assert(record.nb_columns() == array_list.size());
assert(record.nb_rows() == data_size);
assert(record.contains_column(name_list[0]));
assert(record.get_column_name(0) == name_list[0]);
assert(record.get_column(0) == array_list[0]);
assert(std::ranges::equal(record.names(), name_list));
assert(std::ranges::equal(record.columns(), array_list));
return EXIT_SUCCESS;
}
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)