Class: Arrow::ChunkedArray
Instance Method Summary
collapse
#refer_input, #share_input
included, #take_generic
#filter_generic, included
#index, #max, #min, #uniq
Constructor Details
Returns a new instance of ChunkedArray.
20
21
22
|
# File 'lib/arrow/jruby/chunked-array.rb', line 20
def initialize(arrays)
@arrays = arrays
end
|
Instance Method Details
#[](i) ⇒ Object
86
87
88
89
90
91
92
93
|
# File 'lib/arrow/chunked-array.rb', line 86
def [](i)
i += length if i < 0
chunks.each do |array|
return array[i] if i < array.length
i -= array.length
end
nil
end
|
#cast(target_data_type, options: nil) ⇒ Object
139
140
141
142
143
144
|
# File 'lib/arrow/chunked-array.rb', line 139
def cast(target_data_type, options: nil)
casted_chunks = chunks.collect do |chunk|
chunk.cast(target_data_type, options)
end
self.class.new(casted_chunks)
end
|
#chunks ⇒ Object
57
58
59
60
61
62
63
|
# File 'lib/arrow/chunked-array.rb', line 57
def chunks
@chunks ||= chunks_raw.tap do |_chunks|
_chunks.each do |chunk|
share_input(chunk)
end
end
end
|
#chunks_raw ⇒ Object
56
|
# File 'lib/arrow/chunked-array.rb', line 56
alias_method :chunks_raw, :chunks
|
#count(options: nil) ⇒ Object
127
128
129
|
# File 'lib/arrow/chunked-array.rb', line 127
def count(options: nil)
compute("count", options: options).value
end
|
#each(&block) ⇒ Object
95
96
97
98
99
100
101
|
# File 'lib/arrow/chunked-array.rb', line 95
def each(&block)
return to_enum(__method__) unless block_given?
chunks.each do |array|
array.each(&block)
end
end
|
#each_chunk(&block) ⇒ Object
111
112
113
|
# File 'lib/arrow/chunked-array.rb', line 111
def each_chunk(&block)
chunks.each(&block)
end
|
#freeze ⇒ Object
27
28
29
30
31
32
33
|
# File 'lib/arrow/chunked-array.rb', line 27
def freeze
unless frozen?
chunks
end
super
end
|
#get_chunk(i) ⇒ Object
66
67
68
|
# File 'lib/arrow/chunked-array.rb', line 66
def get_chunk(i)
chunks[i]
end
|
#get_chunk_raw ⇒ Object
65
|
# File 'lib/arrow/chunked-array.rb', line 65
alias_method :get_chunk_raw, :get_chunk
|
#length ⇒ Object
53
|
# File 'lib/arrow/chunked-array.rb', line 53
alias_method :length, :n_rows
|
#n_rows ⇒ Object
24
25
26
|
# File 'lib/arrow/jruby/chunked-array.rb', line 24
def n_rows
@arrays.sum(&:size)
end
|
#null?(i) ⇒ Boolean
70
71
72
73
74
75
76
|
# File 'lib/arrow/chunked-array.rb', line 70
def null?(i)
chunks.each do |array|
return array.null?(i) if i < array.length
i -= array.length
end
nil
end
|
#pack ⇒ Object
115
116
117
118
119
120
121
122
123
124
125
|
# File 'lib/arrow/chunked-array.rb', line 115
def pack
first_chunk = chunks.first
data_type = first_chunk.value_data_type
case data_type
when TimestampDataType
builder = TimestampArrayBuilder.new(data_type)
builder.build(to_a)
else
first_chunk.class.new(to_a)
end
end
|
#reverse_each(&block) ⇒ Object
103
104
105
106
107
108
109
|
# File 'lib/arrow/chunked-array.rb', line 103
def reverse_each(&block)
return to_enum(__method__) unless block_given?
chunks.reverse_each do |array|
array.reverse_each(&block)
end
end
|
#size ⇒ Object
51
|
# File 'lib/arrow/chunked-array.rb', line 51
alias_method :size, :n_rows
|
#sum(options: nil) ⇒ Object
131
132
133
|
# File 'lib/arrow/chunked-array.rb', line 131
def sum(options: nil)
compute("sum", options: options).value
end
|
#to_arrow ⇒ Object
35
36
37
|
# File 'lib/arrow/chunked-array.rb', line 35
def to_arrow
self
end
|
#to_arrow_array ⇒ Object
39
40
41
42
43
44
45
|
# File 'lib/arrow/chunked-array.rb', line 39
def to_arrow_array
if n_chunks.zero?
value_data_type.build_array([])
else
combine
end
end
|
#to_arrow_chunked_array ⇒ Object
47
48
49
|
# File 'lib/arrow/chunked-array.rb', line 47
def to_arrow_chunked_array
self
end
|
#unique ⇒ Object
135
136
137
|
# File 'lib/arrow/chunked-array.rb', line 135
def unique
compute("unique")
end
|
#valid?(i) ⇒ Boolean
78
79
80
81
82
83
84
|
# File 'lib/arrow/chunked-array.rb', line 78
def valid?(i)
chunks.each do |array|
return array.valid?(i) if i < array.length
i -= array.length
end
nil
end
|