]>
git.proxmox.com Git - ceph.git/blob - ceph/src/arrow/ruby/red-arrow/lib/arrow/rolling-window.rb
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
9 # http://www.apache.org/licenses/LICENSE-2.0
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
21 # TODO: Almost codes should be implemented in Apache Arrow C++.
23 def initialize(table
, size
)
31 windows
= column
.each_slice(@size)
35 lag_values
= [nil] * diff
36 windows
.each_cons(diff
+ 1) do |values
|
39 if target
.nil? or current
.nil?
42 lag_values
<< current
- target
45 ArrayBuilder
.build(lag_values
)