Scalars#
-
struct arrow::Scalar : public arrow::util::EqualityComparable<Scalar>#
Base class for scalar values.
A Scalar represents a single value with a specific DataType. Scalars are useful for passing single value inputs to compute functions, or for representing individual array elements (with a non-trivial wrapping cost, though).
Subclassed by arrow::BaseListScalar, arrow::ExtensionScalar, arrow::internal::PrimitiveScalarBase, arrow::NullScalar, arrow::StructScalar, arrow::UnionScalar
Public Functions
-
Status Validate() const#
Perform cheap validation checks.
This is O(k) where k is the number of descendents.
- Returns
-
Status ValidateFull() const#
Perform extensive data validation checks.
This is potentially O(k*n) where k is the number of descendents and n is the length of descendents (if list scalars are involved).
- Returns
-
Status Accept(ScalarVisitor *visitor) const#
Apply the ScalarVisitor::Visit() method specialized to the scalar type.
Public Members
-
bool is_valid = false#
Whether the value is valid (not null) or not.
-
struct Hash#
-
Status Validate() const#
Factory functions#
Scalar factory for null scalars.
Scalar factory for non-null scalars.
Type-inferring scalar factory for non-null scalars.
Construct a Scalar instance with a DataType determined by the input C++ type. (for example Int8Scalar for a int8_t input). Only non-parametric primitive types and String are supported.
-
inline std::shared_ptr<Scalar> MakeScalar(std::string value)#
Concrete scalar subclasses#
-
struct arrow::NullScalar : public arrow::Scalar#
- #include <arrow/scalar.h>
A scalar value for NullType. Never valid.
Public Functions
-
inline NullScalar()#
-
inline NullScalar()#
-
struct arrow::BooleanScalar : public arrow::internal::PrimitiveScalar<BooleanType, bool>#
- #include <arrow/scalar.h>
Public Types
-
using Base = internal::PrimitiveScalar<BooleanType, bool>#
-
using Base = internal::PrimitiveScalar<BooleanType, bool>#
-
template<typename T>
struct arrow::NumericScalar : public arrow::internal::PrimitiveScalar<T># - #include <arrow/scalar.h>
Public Types
-
struct Int8Scalar : public arrow::NumericScalar<Int8Type>#
- #include <arrow/scalar.h>
-
struct Int16Scalar : public arrow::NumericScalar<Int16Type>#
- #include <arrow/scalar.h>
-
struct Int32Scalar : public arrow::NumericScalar<Int32Type>#
- #include <arrow/scalar.h>
-
struct Int64Scalar : public arrow::NumericScalar<Int64Type>#
- #include <arrow/scalar.h>
-
struct UInt8Scalar : public arrow::NumericScalar<UInt8Type>#
- #include <arrow/scalar.h>
-
struct UInt16Scalar : public arrow::NumericScalar<UInt16Type>#
- #include <arrow/scalar.h>
-
struct UInt32Scalar : public arrow::NumericScalar<UInt32Type>#
- #include <arrow/scalar.h>
-
struct UInt64Scalar : public arrow::NumericScalar<UInt64Type>#
- #include <arrow/scalar.h>
-
struct HalfFloatScalar : public arrow::NumericScalar<HalfFloatType>#
- #include <arrow/scalar.h>
-
struct FloatScalar : public arrow::NumericScalar<FloatType>#
- #include <arrow/scalar.h>
-
struct DoubleScalar : public arrow::NumericScalar<DoubleType>#
- #include <arrow/scalar.h>
-
struct arrow::BaseBinaryScalar : public arrow::internal::PrimitiveScalarBase#
- #include <arrow/scalar.h>
Subclassed by arrow::BinaryScalar, arrow::LargeBinaryScalar
-
struct arrow::BinaryScalar : public arrow::BaseBinaryScalar#
- #include <arrow/scalar.h>
Subclassed by arrow::FixedSizeBinaryScalar, arrow::StringScalar
Public Types
-
using TypeClass = BinaryType#
-
using TypeClass = BinaryType#
-
struct arrow::StringScalar : public arrow::BinaryScalar#
- #include <arrow/scalar.h>
Public Types
-
using TypeClass = StringType#
-
using TypeClass = StringType#
-
struct arrow::LargeBinaryScalar : public arrow::BaseBinaryScalar#
- #include <arrow/scalar.h>
Subclassed by arrow::LargeStringScalar
Public Types
-
using TypeClass = LargeBinaryType#
-
using TypeClass = LargeBinaryType#
-
struct arrow::LargeStringScalar : public arrow::LargeBinaryScalar#
- #include <arrow/scalar.h>
Public Types
-
using TypeClass = LargeStringType#
-
using TypeClass = LargeStringType#
-
struct arrow::FixedSizeBinaryScalar : public arrow::BinaryScalar#
- #include <arrow/scalar.h>
Public Types
-
using TypeClass = FixedSizeBinaryType#
-
using TypeClass = FixedSizeBinaryType#
-
template<typename T>
struct arrow::TemporalScalar : public arrow::internal::PrimitiveScalar<T># - #include <arrow/scalar.h>
Subclassed by arrow::DateScalar< T >, arrow::IntervalScalar< T >, arrow::TimeScalar< T >
Public Types
-
using ValueType = typename TemporalScalar<T>::ValueType#
Public Functions
-
using ValueType = typename TemporalScalar<T>::ValueType#
-
template<typename T>
struct arrow::DateScalar : public arrow::TemporalScalar<T># - #include <arrow/scalar.h>
Public Types
-
using ValueType = typename TemporalScalar<T>::ValueType#
-
using ValueType = typename TemporalScalar<T>::ValueType#
-
struct Date32Scalar : public arrow::DateScalar<Date32Type>#
- #include <arrow/scalar.h>
-
struct Date64Scalar : public arrow::DateScalar<Date64Type>#
- #include <arrow/scalar.h>
-
template<typename T>
struct arrow::TimeScalar : public arrow::TemporalScalar<T># - #include <arrow/scalar.h>
Public Functions
-
inline TimeScalar(typename TemporalScalar<T>::ValueType value, TimeUnit::type unit)#
-
inline TimeScalar(typename TemporalScalar<T>::ValueType value, TimeUnit::type unit)#
-
struct Time32Scalar : public arrow::TimeScalar<Time32Type>#
- #include <arrow/scalar.h>
-
struct Time64Scalar : public arrow::TimeScalar<Time64Type>#
- #include <arrow/scalar.h>
-
struct arrow::TimestampScalar : public arrow::TemporalScalar<TimestampType>#
- #include <arrow/scalar.h>
Public Functions
-
inline TimestampScalar(typename TemporalScalar<TimestampType>::ValueType value, TimeUnit::type unit, std::string tz = "")#
-
inline TimestampScalar(typename TemporalScalar<TimestampType>::ValueType value, TimeUnit::type unit, std::string tz = "")#
-
template<typename T>
struct arrow::IntervalScalar : public arrow::TemporalScalar<T># - #include <arrow/scalar.h>
Public Types
-
using ValueType = typename TemporalScalar<T>::ValueType#
-
using ValueType = typename TemporalScalar<T>::ValueType#
-
struct MonthIntervalScalar : public arrow::IntervalScalar<MonthIntervalType>#
- #include <arrow/scalar.h>
-
struct DayTimeIntervalScalar : public arrow::IntervalScalar<DayTimeIntervalType>#
- #include <arrow/scalar.h>
-
struct MonthDayNanoIntervalScalar : public arrow::IntervalScalar<MonthDayNanoIntervalType>#
- #include <arrow/scalar.h>
-
struct arrow::DurationScalar : public arrow::TemporalScalar<DurationType>#
- #include <arrow/scalar.h>
Public Functions
-
inline DurationScalar(typename TemporalScalar<DurationType>::ValueType value, TimeUnit::type unit)#
-
inline DurationScalar(typename TemporalScalar<DurationType>::ValueType value, TimeUnit::type unit)#
-
template<typename TYPE_CLASS, typename VALUE_TYPE>
struct arrow::DecimalScalar : public arrow::internal::PrimitiveScalarBase# - #include <arrow/scalar.h>
-
struct arrow::Decimal128Scalar : public arrow::DecimalScalar<Decimal128Type, Decimal128>#
- #include <arrow/scalar.h>
Public Functions
-
struct arrow::Decimal256Scalar : public arrow::DecimalScalar<Decimal256Type, Decimal256>#
- #include <arrow/scalar.h>
Public Functions
-
struct arrow::BaseListScalar : public arrow::Scalar#
- #include <arrow/scalar.h>
Subclassed by arrow::FixedSizeListScalar, arrow::LargeListScalar, arrow::ListScalar, arrow::MapScalar
Public Functions
-
struct arrow::ListScalar : public arrow::BaseListScalar#
- #include <arrow/scalar.h>
Public Functions
-
struct arrow::LargeListScalar : public arrow::BaseListScalar#
- #include <arrow/scalar.h>
Public Types
-
using TypeClass = LargeListType#
Public Functions
-
using TypeClass = LargeListType#
-
struct arrow::MapScalar : public arrow::BaseListScalar#
- #include <arrow/scalar.h>
Public Functions
-
struct arrow::FixedSizeListScalar : public arrow::BaseListScalar#
- #include <arrow/scalar.h>
Public Types
-
using TypeClass = FixedSizeListType#
Public Functions
-
using TypeClass = FixedSizeListType#
-
struct arrow::StructScalar : public arrow::Scalar#
- #include <arrow/scalar.h>
Public Members
-
ScalarVector value#
Public Static Functions
-
static Result<std::shared_ptr<StructScalar>> Make(ValueType value, std::vector<std::string> field_names)#
-
ScalarVector value#
-
struct arrow::UnionScalar : public arrow::Scalar#
- #include <arrow/scalar.h>
Subclassed by arrow::DenseUnionScalar, arrow::SparseUnionScalar
Public Functions
-
struct arrow::SparseUnionScalar : public arrow::UnionScalar#
- #include <arrow/scalar.h>
Public Types
-
using TypeClass = SparseUnionType#
Public Functions
-
using TypeClass = SparseUnionType#
-
struct arrow::DenseUnionScalar : public arrow::UnionScalar#
- #include <arrow/scalar.h>
Public Types
-
using TypeClass = DenseUnionType#
Public Functions
-
using TypeClass = DenseUnionType#
-
struct arrow::DictionaryScalar : public arrow::internal::PrimitiveScalarBase#
- #include <arrow/scalar.h>
A Scalar value for DictionaryType.
is_valid
denotes the validity of theindex
, regardless of the corresponding value in thedictionary
.Public Types
-
using TypeClass = DictionaryType#
Public Functions
-
inline void *mutable_data() override#
-
inline util::string_view view() const override#
Public Members
-
struct arrow::DictionaryScalar::ValueType value#
Public Static Functions
-
struct ValueType#
- #include <arrow/scalar.h>
-
using TypeClass = DictionaryType#
-
struct arrow::ExtensionScalar : public arrow::Scalar#
- #include <arrow/scalar.h>
A Scalar value for ExtensionType.
The value is the underlying storage scalar.
is_valid
must only be true ifvalue
is non-null andvalue->is_valid
is truePublic Functions
Utilities#
-
class arrow::ScalarVisitor#
Abstract scalar visitor class.
Subclass this to create a visitor that can be used with the Scalar::Accept() method.
Public Functions
-
virtual ~ScalarVisitor() = default#
-
virtual Status Visit(const NullScalar &scalar)#
-
virtual Status Visit(const BooleanScalar &scalar)#
-
virtual Status Visit(const Int8Scalar &scalar)#
-
virtual Status Visit(const Int16Scalar &scalar)#
-
virtual Status Visit(const Int32Scalar &scalar)#
-
virtual Status Visit(const Int64Scalar &scalar)#
-
virtual Status Visit(const UInt8Scalar &scalar)#
-
virtual Status Visit(const UInt16Scalar &scalar)#
-
virtual Status Visit(const UInt32Scalar &scalar)#
-
virtual Status Visit(const UInt64Scalar &scalar)#
-
virtual Status Visit(const HalfFloatScalar &scalar)#
-
virtual Status Visit(const FloatScalar &scalar)#
-
virtual Status Visit(const DoubleScalar &scalar)#
-
virtual Status Visit(const StringScalar &scalar)#
-
virtual Status Visit(const BinaryScalar &scalar)#
-
virtual Status Visit(const LargeStringScalar &scalar)#
-
virtual Status Visit(const LargeBinaryScalar &scalar)#
-
virtual Status Visit(const FixedSizeBinaryScalar &scalar)#
-
virtual Status Visit(const Date64Scalar &scalar)#
-
virtual Status Visit(const Date32Scalar &scalar)#
-
virtual Status Visit(const Time32Scalar &scalar)#
-
virtual Status Visit(const Time64Scalar &scalar)#
-
virtual Status Visit(const TimestampScalar &scalar)#
-
virtual Status Visit(const DayTimeIntervalScalar &scalar)#
-
virtual Status Visit(const MonthDayNanoIntervalScalar &type)#
-
virtual Status Visit(const MonthIntervalScalar &scalar)#
-
virtual Status Visit(const DurationScalar &scalar)#
-
virtual Status Visit(const Decimal128Scalar &scalar)#
-
virtual Status Visit(const Decimal256Scalar &scalar)#
-
virtual Status Visit(const ListScalar &scalar)#
-
virtual Status Visit(const LargeListScalar &scalar)#
-
virtual Status Visit(const FixedSizeListScalar &scalar)#
-
virtual Status Visit(const StructScalar &scalar)#
-
virtual Status Visit(const DictionaryScalar &scalar)#
-
virtual Status Visit(const SparseUnionScalar &scalar)#
-
virtual Status Visit(const DenseUnionScalar &scalar)#
-
virtual Status Visit(const ExtensionScalar &scalar)#
-
virtual ~ScalarVisitor() = default#