Skip to content

Commit

Permalink
Return the .len() diff from dedupe() instead
Browse files Browse the repository at this point in the history
Since the `diff: int` serves as a predicate anyway (when `0` nothing
duplicate was detected) might as well just return it directly since it's
likely also useful for the caller when doing deeper anal.

Also, handle the zero-diff case by just returning early with a copy of
the input frame and a `diff=0`.

CHERRY INTO #486
  • Loading branch information
goodboy committed Dec 12, 2023
1 parent 8e4d1a4 commit e8bf4c6
Showing 1 changed file with 53 additions and 27 deletions.
80 changes: 53 additions & 27 deletions piker/data/tsp.py
Original file line number Diff line number Diff line change
Expand Up @@ -262,15 +262,17 @@ def with_dts(
) -> pl.DataFrame:
'''
Insert datetime (casted) columns to a (presumably) OHLC sampled
time series with an epoch-time column keyed by ``time_col``.
time series with an epoch-time column keyed by `time_col: str`.
'''
return df.with_columns([
pl.col(time_col).shift(1).suffix('_prev'),
pl.col(time_col).diff().alias('s_diff'),
pl.from_epoch(pl.col(time_col)).alias('dt'),
]).with_columns([
pl.from_epoch(pl.col(f'{time_col}_prev')).alias('dt_prev'),
pl.from_epoch(
pl.col(f'{time_col}_prev')
).alias('dt_prev'),
pl.col('dt').diff().alias('dt_diff'),
]) #.with_columns(
# pl.col('dt').diff().dt.days().alias('days_dt_diff'),
Expand Down Expand Up @@ -369,7 +371,7 @@ def dedupe(src_df: pl.DataFrame) -> tuple[
pl.DataFrame, # with dts
pl.DataFrame, # gaps
pl.DataFrame, # with deduplicated dts (aka gap/repeat removal)
bool,
int, # len diff between input and deduped
]:
'''
Check for time series gaps and if found
Expand All @@ -380,36 +382,60 @@ def dedupe(src_df: pl.DataFrame) -> tuple[
'''
df: pl.DataFrame = with_dts(src_df)
gaps: pl.DataFrame = detect_time_gaps(df)
if not gaps.is_empty():

# remove duplicated datetime samples/sections
deduped: pl.DataFrame = dedup_dt(df)
deduped_gaps = detect_time_gaps(deduped)

log.warning(
f'Gaps found:\n{gaps}\n'
f'deduped Gaps found:\n{deduped_gaps}'
)
# TODO: rewrite this in polars and/or convert to
# ndarray to detect and remove?
# null_gaps = detect_null_time_gap()

diff: int = (
df.height
-
deduped.height
)
was_deduped: bool = False
if diff:
was_deduped: bool = True

# if no gaps detected just return carbon copies
# and no len diff.
if gaps.is_empty():
return (
df,
gaps,
deduped,
was_deduped,
df,
0,
)

# remove duplicated datetime samples/sections
deduped: pl.DataFrame = dedup_dt(df)
deduped_gaps = detect_time_gaps(deduped)

diff: int = (
df.height
-
deduped.height
)
log.warning(
f'Gaps found:\n{gaps}\n'
f'deduped Gaps found:\n{deduped_gaps}'
)
# TODO: rewrite this in polars and/or convert to
# ndarray to detect and remove?
# null_gaps = detect_null_time_gap()

return (
df,
gaps,
deduped,
diff,
)


def sort_diff(
src_df: pl.DataFrame,
col: str = 'time',

) -> tuple[
pl.DataFrame, # with dts
pl.DataFrame, # sorted
list[int], # indices of segments that are out-of-order
]:
ser: pl.Series = src_df[col]

diff: pl.Series = ser.diff()
sortd: pl.DataFrame = ser.sort()
sortd_diff: pl.Series = sortd.diff()
i_step_diff = (diff != sortd_diff).arg_true()
if i_step_diff.len():
import pdbp
pdbp.set_trace()

# NOTE: thanks to this SO answer for the below conversion routines
# to go from numpy struct-arrays to polars dataframes and back:
Expand Down

0 comments on commit e8bf4c6

Please sign in to comment.