-
Notifications
You must be signed in to change notification settings - Fork 17
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Adjusted join in flat reps to account for different timestamps with t… #107
base: main
Are you sure you want to change the base?
Changes from 5 commits
720e6cb
b006195
9e0acf7
22dca2d
435d968
5c6cb4b
69b99ce
bf453e1
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -46,6 +46,7 @@ def load_flat_rep( | |
do_update_if_missing: bool = True, | ||
task_df_name: str | None = None, | ||
do_cache_filtered_task: bool = True, | ||
overwrite_cache_filtered_task: bool = False, | ||
subjects_included: dict[str, set[int]] | None = None, | ||
) -> dict[str, pl.LazyFrame]: | ||
"""Loads a set of flat representations from a passed dataset that satisfy the given constraints. | ||
|
@@ -67,14 +68,16 @@ def load_flat_rep( | |
do_update_if_missing: If `True`, then if any window sizes or features are missing, the function will | ||
try to update the stored flat representations to reflect these. If `False`, if information is | ||
missing, it will raise a `FileNotFoundError` instead. | ||
task_df_name: If specified, the flat representations loaded will be (inner) joined against the task | ||
task_df_name: If specified, the flat representations loaded will be joined against the task | ||
dataframe of this name on the columns ``"subject_id"`` and ``"end_time"`` (which will be renamed | ||
to ``"timestamp"``). This is to avoid needing to load the full dataset in flattened form into | ||
memory. This is also used as a cache key; if a pre-filtered dataset is written to disk at a | ||
specified path for this task, then the data will be loaded from there, rather than from the base | ||
dataset. | ||
do_cache_filtered_task: If `True`, the flat representations will, after being filtered to just the | ||
relevant rows for the task, be cached to disk for faster re-use. | ||
overwrite_cache_filtered_task: If `True`, the flat representations will be regenerated. If `False`, | ||
the cached file will be loaded if exists. | ||
Comment on lines
+79
to
+80
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Tip Codebase Verification Ensure all calls to The following calls to
Please update these calls to include the Analysis chainLGTM! But verify the new parameter usage in the codebase. The code changes are approved. However, ensure that all function calls to Scripts executedThe following scripts were executed for the analysis: Script: #!/bin/bash
# Description: Verify all function calls to `load_flat_rep` match the new signature.
# Test: Search for the function usage. Expect: Only occurrences of the new signature.
rg --type python $'load_flat_rep'
Length of output: 63 Script: #!/bin/bash
# Description: Verify all function calls to `load_flat_rep` match the new signature.
# Test: Search for the function usage. Expect: Only occurrences of the new signature.
rg 'load_flat_rep'
Length of output: 1215 Script: #!/bin/bash
# Description: Extract lines around each call to `load_flat_rep` to verify the usage of the new parameter.
# Extract lines around the calls in the Jupyter notebook
rg -A 3 -B 3 'load_flat_rep' sample_data/examine_synthetic_data.ipynb
# Extract lines around the calls in the Python file
rg -A 3 -B 3 'load_flat_rep' EventStream/baseline/FT_task_baseline.py
Length of output: 3273 |
||
subjects_included: A dictionary by split of the subjects to include in the task. Omitted splits are | ||
used wholesale. | ||
|
||
|
@@ -170,7 +173,7 @@ def load_flat_rep( | |
if task_df_name is not None: | ||
fn = fp.parts[-1] | ||
cached_fp = task_window_dir / fn | ||
if cached_fp.is_file(): | ||
if cached_fp.is_file() and not overwrite_cache_filtered_task: | ||
df = pl.scan_parquet(cached_fp).select("subject_id", "timestamp", *window_features) | ||
if subjects_included.get(sp, None) is not None: | ||
subjects = list(set(subjects).intersection(subjects_included[sp])) | ||
|
@@ -182,7 +185,12 @@ def load_flat_rep( | |
if task_df_name is not None: | ||
filter_join_df = sp_join_df.select(join_keys).filter(pl.col("subject_id").is_in(subjects)) | ||
|
||
df = df.join(filter_join_df, on=join_keys, how="inner") | ||
df = filter_join_df.join_asof( | ||
df, | ||
by="subject_id", | ||
on="timestamp", | ||
strategy="forward" if "-" in window_size else "backward", | ||
) | ||
|
||
if do_cache_filtered_task: | ||
cached_fp.parent.mkdir(exist_ok=True, parents=True) | ||
|
Original file line number | Diff line number | Diff line change | ||||
---|---|---|---|---|---|---|
@@ -0,0 +1,44 @@ | ||||||
#!/usr/bin/env python | ||||||
"""Builds a flat representation dataset given a hydra config file.""" | ||||||
|
||||||
try: | ||||||
import stackprinter | ||||||
|
||||||
stackprinter.set_excepthook(style="darkbg2") | ||||||
except ImportError: | ||||||
pass # no need to fail because of missing dev dependency | ||||||
|
||||||
from pathlib import Path | ||||||
import hydra | ||||||
from omegaconf import DictConfig, OmegaConf | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Remove unused import to clean up the code. - from omegaconf import DictConfig, OmegaConf
+ from omegaconf import DictConfig Committable suggestion
Suggested change
ToolsRuff
|
||||||
from loguru import logger | ||||||
|
||||||
from EventStream.data.dataset_polars import Dataset | ||||||
|
||||||
@hydra.main(version_base=None, config_path="../configs", config_name="dataset_base") | ||||||
def main(cfg: DictConfig): | ||||||
cfg = hydra.utils.instantiate(cfg, _convert_="all") | ||||||
save_dir = Path(cfg.pop("save_dir")) | ||||||
window_sizes = cfg.pop("window_sizes") | ||||||
subjects_per_output_file = cfg.pop("subjects_per_output_file") if 'subjects_per_output_file' in cfg else None | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Consider adding error handling for missing configuration items to prevent runtime errors. # Example of adding default values and error handling
save_dir = Path(cfg.pop("save_dir", "default/path"))
window_sizes = cfg.pop("window_sizes", [default_window_size])
subjects_per_output_file = cfg.pop("subjects_per_output_file", default_subjects_per_output_file) |
||||||
|
||||||
# Build flat reps for specified task and window sizes | ||||||
logger.debug('Loading ESD..') | ||||||
ESD = Dataset.load(save_dir) | ||||||
feature_inclusion_frequency, include_only_measurements = ESD._resolve_flat_rep_cache_params( | ||||||
feature_inclusion_frequency=None, include_only_measurements=None | ||||||
) | ||||||
cache_kwargs = dict( | ||||||
subjects_per_output_file=subjects_per_output_file, | ||||||
feature_inclusion_frequency=feature_inclusion_frequency, #0.1 | ||||||
window_sizes=window_sizes, | ||||||
include_only_measurements=include_only_measurements, | ||||||
do_overwrite=False, | ||||||
do_update=True, | ||||||
) | ||||||
logger.debug('Caching flat representation..') | ||||||
ESD.cache_flat_representation(**cache_kwargs) | ||||||
logger.debug('Done') | ||||||
|
||||||
if __name__ == "__main__": | ||||||
main() |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Ensure proper documentation for the new parameter.
The new parameter
overwrite_cache_filtered_task
should be included in the function's docstring to maintain comprehensive documentation.+ overwrite_cache_filtered_task: If `True`, the flat representations will be regenerated. If `False`, the cached file will be loaded if exists.
Committable suggestion