red_amber 0.4.1 → 0.4.2
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.rubocop.yml +3 -3
- data/CHANGELOG.md +36 -1
- data/README.md +13 -11
- data/benchmark/basic.yml +1 -1
- data/doc/CODE_OF_CONDUCT.md +1 -1
- data/docker/.env +4 -0
- data/docker/Dockerfile +66 -0
- data/docker/Gemfile +21 -0
- data/docker/Gemfile.lock +80 -0
- data/docker/docker-compose.yml +21 -0
- data/docker/example +74 -0
- data/docker/notebook/examples_of_red_amber.ipynb +8562 -0
- data/docker/notebook/red-amber.ipynb +188 -0
- data/docker/readme.md +118 -0
- data/lib/red_amber/group.rb +16 -16
- data/lib/red_amber/subframes.rb +158 -65
- data/lib/red_amber/vector_binary_element_wise.rb +54 -25
- data/lib/red_amber/version.rb +1 -1
- data/red_amber.gemspec +3 -3
- metadata +16 -7
@@ -236,7 +236,6 @@ module RedAmber
|
|
236
236
|
# division of self by other.
|
237
237
|
#
|
238
238
|
define_binary_element_wise :divide
|
239
|
-
alias_method :div, :divide
|
240
239
|
alias_method :'/', :divide
|
241
240
|
|
242
241
|
# Divide the arguments element-wise.
|
@@ -248,21 +247,21 @@ module RedAmber
|
|
248
247
|
|
249
248
|
# Returns element-wise modulo.
|
250
249
|
#
|
251
|
-
# This is equivalent to `self-
|
252
|
-
# @
|
253
|
-
#
|
250
|
+
# This is equivalent to `self-divisor*(self/divisor).floor`.
|
251
|
+
# @note Same behavior as Ruby.
|
252
|
+
# @param divisor [Vector, numeric]
|
253
|
+
# divisor numeric Vector or numeric scalar.
|
254
254
|
# @return [Vector]
|
255
|
-
# modulo of dividing self by
|
255
|
+
# modulo of dividing self by divisor.
|
256
256
|
#
|
257
|
-
def modulo(
|
258
|
-
|
259
|
-
d = find(:divide).execute([data,
|
257
|
+
def modulo(divisor)
|
258
|
+
divisor = divisor.data if divisor.is_a?(Vector)
|
259
|
+
d = find(:divide).execute([data, divisor])
|
260
260
|
d = find(:floor).execute([d]) if d.value.is_a?(Arrow::DoubleArray)
|
261
|
-
m = find(:multiply).execute([d,
|
261
|
+
m = find(:multiply).execute([d, divisor])
|
262
262
|
datum = find(:subtract).execute([data, m])
|
263
263
|
Vector.create(datum.value)
|
264
264
|
end
|
265
|
-
alias_method :mod, :modulo
|
266
265
|
alias_method :'%', :modulo
|
267
266
|
|
268
267
|
# Returns element-wise modulo.
|
@@ -270,11 +269,11 @@ module RedAmber
|
|
270
269
|
# This function is a overflow-checking variant of #modulo.
|
271
270
|
# @return (see #modulo)
|
272
271
|
#
|
273
|
-
def modulo_checked(
|
274
|
-
|
275
|
-
d = find(:divide_checked).execute([data,
|
272
|
+
def modulo_checked(divisor)
|
273
|
+
divisor = divisor.data if divisor.is_a?(Vector)
|
274
|
+
d = find(:divide_checked).execute([data, divisor])
|
276
275
|
d = find(:floor).execute([d]) if d.value.is_a?(Arrow::DoubleArray)
|
277
|
-
m = find(:multiply_checked).execute([d,
|
276
|
+
m = find(:multiply_checked).execute([d, divisor])
|
278
277
|
datum = find(:subtract_checked).execute([data, m])
|
279
278
|
Vector.create(datum.value)
|
280
279
|
end
|
@@ -323,27 +322,57 @@ module RedAmber
|
|
323
322
|
|
324
323
|
# Returns element-wise quotient by double Vector.
|
325
324
|
#
|
326
|
-
# @param
|
327
|
-
#
|
325
|
+
# @param divisor [Vector, numeric]
|
326
|
+
# divisor numeric Vector or numeric scalar.
|
328
327
|
# @return [Vector]
|
329
|
-
# quotient of dividing self by
|
328
|
+
# quotient of dividing self by divisor.
|
330
329
|
#
|
331
|
-
def
|
332
|
-
|
333
|
-
datum = find(:divide).execute([Arrow::DoubleArray.new(data),
|
330
|
+
def fdiv(divisor)
|
331
|
+
divisor = divisor.data if divisor.is_a?(Vector)
|
332
|
+
datum = find(:divide).execute([Arrow::DoubleArray.new(data), divisor])
|
334
333
|
Vector.create(datum.value)
|
335
334
|
end
|
336
|
-
alias_method :quo, :quotient
|
337
|
-
alias_method :fdiv, :quotient
|
338
335
|
|
339
336
|
# Returns element-wise quotient by double Vector.
|
340
337
|
#
|
341
338
|
# This function is a overflow-checking variant of #quotient.
|
342
339
|
# @return (see #quotient)
|
343
340
|
#
|
344
|
-
def
|
345
|
-
|
346
|
-
datum = find(:divide_checked).execute([Arrow::DoubleArray.new(data),
|
341
|
+
def fdiv_checked(divisor)
|
342
|
+
divisor = divisor.data if divisor.is_a?(Vector)
|
343
|
+
datum = find(:divide_checked).execute([Arrow::DoubleArray.new(data), divisor])
|
344
|
+
Vector.create(datum.value)
|
345
|
+
end
|
346
|
+
|
347
|
+
# Returns element-wise remainder.
|
348
|
+
#
|
349
|
+
# This is equivalent to `self-divisor*(self/divisor).trunc`.
|
350
|
+
# @note Same behavior as Ruby's remainder.
|
351
|
+
# @param divisor [Vector, numeric]
|
352
|
+
# divisor numeric Vector or numeric scalar.
|
353
|
+
# @return [Vector]
|
354
|
+
# modulo of dividing self by divisor.
|
355
|
+
#
|
356
|
+
def remainder(divisor)
|
357
|
+
divisor = divisor.data if divisor.is_a?(Vector)
|
358
|
+
d = find(:divide).execute([data, divisor])
|
359
|
+
d = find(:trunc).execute([d]) if d.value.is_a?(Arrow::DoubleArray)
|
360
|
+
m = find(:multiply).execute([d, divisor])
|
361
|
+
datum = find(:subtract).execute([data, m])
|
362
|
+
Vector.create(datum.value)
|
363
|
+
end
|
364
|
+
|
365
|
+
# Returns element-wise modulo.
|
366
|
+
#
|
367
|
+
# This function is a overflow-checking variant of #modulo.
|
368
|
+
# @return (see #modulo)
|
369
|
+
#
|
370
|
+
def remainder_checked(divisor)
|
371
|
+
divisor = divisor.data if divisor.is_a?(Vector)
|
372
|
+
d = find(:divide_checked).execute([data, divisor])
|
373
|
+
d = find(:trunc).execute([d]) if d.value.is_a?(Arrow::DoubleArray)
|
374
|
+
m = find(:multiply_checked).execute([d, divisor])
|
375
|
+
datum = find(:subtract_checked).execute([data, m])
|
347
376
|
Vector.create(datum.value)
|
348
377
|
end
|
349
378
|
|
data/lib/red_amber/version.rb
CHANGED
data/red_amber.gemspec
CHANGED
@@ -11,13 +11,13 @@ Gem::Specification.new do |spec|
|
|
11
11
|
spec.summary = 'Simple dataframe library for Ruby'
|
12
12
|
spec.description = 'RedAmber is a simple dataframe library ' \
|
13
13
|
'inspired by Rover-df and powered by Red Arrow.'
|
14
|
-
spec.homepage = 'https://github.com/
|
14
|
+
spec.homepage = 'https://github.com/red-data-tools/red_amber'
|
15
15
|
spec.license = 'MIT'
|
16
16
|
spec.required_ruby_version = '>= 3.0'
|
17
17
|
|
18
18
|
spec.metadata['homepage_uri'] = spec.homepage
|
19
|
-
spec.metadata['source_code_uri'] = 'https://github.com/
|
20
|
-
spec.metadata['changelog_uri'] = 'https://github.com/
|
19
|
+
spec.metadata['source_code_uri'] = 'https://github.com/red-data-tools/red_amber'
|
20
|
+
spec.metadata['changelog_uri'] = 'https://github.com/red-data-tools/red_amber/blob/main/CHANGELOG.md'
|
21
21
|
|
22
22
|
# Specify which files should be added to the gem when it is released.
|
23
23
|
# The `git ls-files -z` loads the files in the RubyGem that have been added into git.
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: red_amber
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.4.
|
4
|
+
version: 0.4.2
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Hirokazu SUZUKI (heronshoes)
|
8
8
|
autorequire:
|
9
9
|
bindir: exe
|
10
10
|
cert_chain: []
|
11
|
-
date: 2023-
|
11
|
+
date: 2023-04-02 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: red-arrow
|
@@ -87,6 +87,15 @@ files:
|
|
87
87
|
- doc/tdr.md
|
88
88
|
- doc/tdr_ja.md
|
89
89
|
- doc/yard-templates/default/fulldoc/html/css/common.css
|
90
|
+
- docker/.env
|
91
|
+
- docker/Dockerfile
|
92
|
+
- docker/Gemfile
|
93
|
+
- docker/Gemfile.lock
|
94
|
+
- docker/docker-compose.yml
|
95
|
+
- docker/example
|
96
|
+
- docker/notebook/examples_of_red_amber.ipynb
|
97
|
+
- docker/notebook/red-amber.ipynb
|
98
|
+
- docker/readme.md
|
90
99
|
- lib/red-amber.rb
|
91
100
|
- lib/red_amber.rb
|
92
101
|
- lib/red_amber/data_frame.rb
|
@@ -110,13 +119,13 @@ files:
|
|
110
119
|
- lib/red_amber/version.rb
|
111
120
|
- red_amber.gemspec
|
112
121
|
- sig/red_amber.rbs
|
113
|
-
homepage: https://github.com/
|
122
|
+
homepage: https://github.com/red-data-tools/red_amber
|
114
123
|
licenses:
|
115
124
|
- MIT
|
116
125
|
metadata:
|
117
|
-
homepage_uri: https://github.com/
|
118
|
-
source_code_uri: https://github.com/
|
119
|
-
changelog_uri: https://github.com/
|
126
|
+
homepage_uri: https://github.com/red-data-tools/red_amber
|
127
|
+
source_code_uri: https://github.com/red-data-tools/red_amber
|
128
|
+
changelog_uri: https://github.com/red-data-tools/red_amber/blob/main/CHANGELOG.md
|
120
129
|
rubygems_mfa_required: 'true'
|
121
130
|
post_install_message:
|
122
131
|
rdoc_options: []
|
@@ -133,7 +142,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
133
142
|
- !ruby/object:Gem::Version
|
134
143
|
version: '0'
|
135
144
|
requirements: []
|
136
|
-
rubygems_version: 3.4.
|
145
|
+
rubygems_version: 3.4.10
|
137
146
|
signing_key:
|
138
147
|
specification_version: 4
|
139
148
|
summary: Simple dataframe library for Ruby
|