Skip to content
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

[ENH] enable large data use cases - decouple data input from pandas, allow polars, dask, and/or spark #1685

Open
fkiraly opened this issue Sep 23, 2024 · 7 comments
Labels
enhancement New feature or request

Comments

@fkiraly
Copy link
Collaborator

fkiraly commented Sep 23, 2024

A key limitation of current architecture seems to be the reliance on pandas of the input, which limites useability in large data cases.

While torch with appropriate backends should be able to handle large data, pandas as a container choice, in particular the current instantiation which seems to rely on in-memory, will prove to be the bottleneck.

We should therefore consider and implement support for data backends that scale better, such as polars, dask, or spark, and see how easy it is to get the pandas pyarrow integration to work.

Architecturally, I think we should:

  • build a more abstract data loader layer
  • make pandas one of multiple potential data soft dependencies
  • try to prioritize the solution that would provide us with the quickest "impact for time invested"

The key entry point for this extension or refactor is TimeSeriesDataSet, which requires pandas objects to be passed.

@fkiraly fkiraly added the enhancement New feature or request label Sep 23, 2024
@fkiraly fkiraly changed the title [ENH] decouple data input form pandas, allow polars, dask, and/or spark [ENH] enable large data use cases - decouple data input form pandas, allow polars, dask, and/or spark Sep 23, 2024
@fkiraly fkiraly changed the title [ENH] enable large data use cases - decouple data input form pandas, allow polars, dask, and/or spark [ENH] enable large data use cases - decouple data input from pandas, allow polars, dask, and/or spark Sep 23, 2024
@Spinachboul
Copy link

@fkiraly
Can I be assigned this issue?
I have a little idea about using rust under the hood for integrating polars as one of the dataset.
Also this might be a bit complex given we are handling multiple backend formats
So this might take some time to maintain consistency across all frameworks

@fkiraly
Copy link
Collaborator Author

fkiraly commented Jan 4, 2025

@Spinachboul, this is a very complex issue because it relies on at least a redesign of the API.

You can work on this, but first we need an API written down that would allow multiple backends.

Feel free to suggest something, or participate in the discussions in #1736 until we have consolidated this!

We will also use some of the meet-ups for the pytorch-forecasting rework.

@Spinachboul
Copy link

@fkiraly Ohk then! I am not quite familiar with the abbreviation DSIPTS, could you please give some reference for it?
Also could you direct me towards what code files to look for amendments in the backend for better understanding as I am unfamiliar with the codebase!!
Thanks!

@fkiraly
Copy link
Collaborator Author

fkiraly commented Jan 4, 2025

I am not quite familiar with the abbreviation DSIPTS, could you please give some reference for it?

There is a link directly at the top of the mentioned issue #1736

Also could you direct me towards what code files to look for amendments in the backend for better understanding as I am unfamiliar with the codebase!

Primarily BaseModel and TimeSeriesDataSet in pytorch-forecasting.

@Spinachboul
Copy link

I am not quite familiar with the abbreviation DSIPTS, could you please give some reference for it?

There is a link directly at the top of the mentioned issue #1736

Also could you direct me towards what code files to look for amendments in the backend for better understanding as I am unfamiliar with the codebase!

Primarily BaseModel and TimeSeriesDataSet in pytorch-forecasting.

oh ok, thanks!!

@benHeid
Copy link
Collaborator

benHeid commented Jan 10, 2025

One addition from my side. We should at least implement one dataset that is able to read data by itself. So that the user does not need to provide a data object during initialisation. This would also improve or enable usage with large datasets.

fkiraly added a commit that referenced this issue Jan 10, 2025
This PR carries out a clean-up refactor of `TimeSeriesDataSet`. No
changes are made to the logic.

This is in preparation for major work items impacting the logic, e.g.,
removal of the `pandas` coupling (see
#1685), or a 2.0
rework (see #1736).
In general, a clean state would make these easier.

Work carried out:

* clear, and complete docstrings, in numpydoc format
* separating logic, e.g., for parameter checking, data formatting,
default handling
* reducing cognitive complexity and max indentations, addressing "code
smells"
* linting
@fkiraly
Copy link
Collaborator Author

fkiraly commented Jan 12, 2025

agree!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request
Projects
None yet
Development

No branches or pull requests

3 participants