]> git.proxmox.com Git - ceph.git/blame - ceph/src/arrow/ruby/red-arrow/benchmark/values/dictionary.yml
import quincy 17.2.0
[ceph.git] / ceph / src / arrow / ruby / red-arrow / benchmark / values / dictionary.yml
CommitLineData
1d09f67e
TL
1# Licensed to the Apache Software Foundation (ASF) under one
2# or more contributor license agreements. See the NOTICE file
3# distributed with this work for additional information
4# regarding copyright ownership. The ASF licenses this file
5# to you under the Apache License, Version 2.0 (the
6# "License"); you may not use this file except in compliance
7# with the License. You may obtain a copy of the License at
8#
9# http://www.apache.org/licenses/LICENSE-2.0
10#
11# Unless required by applicable law or agreed to in writing,
12# software distributed under the License is distributed on an
13# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
14# KIND, either express or implied. See the License for the
15# specific language governing permissions and limitations
16# under the License.
17
18contexts:
19 - name: master
20 prelude: |
21 $LOAD_PATH.unshift(File.expand_path("ext/arrow"))
22 $LOAD_PATH.unshift(File.expand_path("lib"))
23prelude: |-
24 require "arrow"
25 require "faker"
26
27 state = ENV.fetch("FAKER_RANDOM_SEED", 17).to_i
28 Faker::Config.random = Random.new(state)
29
30 n_values = 1000
31 type = Arrow::DictionaryDataType.new(:int8, :string, true)
32
33 dictionary = Arrow::StringArray.new(
34 100.times.map { Faker::Book.genre }.uniq.sort
35 )
36 indices = Arrow::Int8Array.new(
37 n_values.times.map {
38 Faker::Number.within(range: 0 ... dictionary.length)
39 }
40 )
41 array = Arrow::DictionaryArray.new(type, indices, dictionary)
42benchmark:
43 pure_ruby: |-
44 array.length.times.collect {|i| array.indices[i]}
45 values: |-
46 array.values