Skip to content

Commit

Permalink
Remove cudf._lib.rolling in favor of inlining pylibcudf
Browse files Browse the repository at this point in the history
  • Loading branch information
mroeschke committed Nov 22, 2024
1 parent 881afd1 commit 354b031
Show file tree
Hide file tree
Showing 4 changed files with 34 additions and 79 deletions.
1 change: 0 additions & 1 deletion python/cudf/cudf/_lib/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,6 @@ set(cython_sources
reduce.pyx
replace.pyx
reshape.pyx
rolling.pyx
round.pyx
scalar.pyx
search.pyx
Expand Down
1 change: 0 additions & 1 deletion python/cudf/cudf/_lib/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,6 @@
reduce,
replace,
reshape,
rolling,
round,
search,
sort,
Expand Down
67 changes: 0 additions & 67 deletions python/cudf/cudf/_lib/rolling.pyx

This file was deleted.

44 changes: 34 additions & 10 deletions python/cudf/cudf/core/window/rolling.py
Original file line number Diff line number Diff line change
Expand Up @@ -8,8 +8,11 @@
import pandas as pd
from pandas.api.indexers import BaseIndexer

import pylibcudf as plc

import cudf
from cudf import _lib as libcudf
from cudf._lib.aggregation import make_aggregation
from cudf.api.types import is_integer, is_number
from cudf.core.buffer import acquire_spill_lock
from cudf.core.column.column import as_column
Expand Down Expand Up @@ -284,16 +287,37 @@ def _apply_agg_column(self, source_column, agg_name):
)
window = None

return libcudf.rolling.rolling(
source_column=source_column,
pre_column_window=preceding_window,
fwd_column_window=following_window,
window=window,
min_periods=min_periods,
center=self.center,
op=agg_name,
agg_params=self.agg_params,
)
with acquire_spill_lock():
if window is None:
if self.center:
# TODO: we can support this even though Pandas currently does not
raise NotImplementedError(
"center is not implemented for offset-based windows"
)
pre = preceding_window.to_pylibcudf(mode="read")
fwd = following_window.to_pylibcudf(mode="read")
else:
if self.center:
pre = (window // 2) + 1
fwd = window - (pre)
else:
pre = window
fwd = 0

return libcudf.column.Column.from_pylibcudf(
plc.rolling.rolling_window(
source_column.to_pylibcudf(mode="read"),
pre,
fwd,
min_periods,
make_aggregation(
agg_name,
{"dtype": source_column.dtype}
if callable(agg_name)
else self.agg_params,
).c_obj,
)
)

def _reduce(
self,
Expand Down

0 comments on commit 354b031

Please sign in to comment.