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

Add ability to shuffle (and reshuffle) batches #170

Open
wants to merge 2 commits into
base: main
Choose a base branch
from

Conversation

arbennett
Copy link

Description of proposed changes

This relatively simple addition just adds the shuffle flag and reshuffle method to allow for randomizing the ordering of batches. This can be useful to reduce the effect of auto-correlation between samples that are nearby in space/time. The way I've implemented it is to simply preemptively turn the patch_selectors into a list which might not be optimal. But, in my testing, these are usually explicitly loaded at some point before the batch generator is iterated over anyhow so hopefully that's not a huge blocker.

Fixes # <--- I thought there used to be an issue around this, but I was unsuccessful in finding it. I'll update this if someone links the relevant issue.

@arbennett arbennett changed the title [WIP] - Add ability to shuffle (and reshuffle) batches Add ability to shuffle (and reshuffle) batches Mar 21, 2023
@arbennett
Copy link
Author

I've been using this long enough on my own work that I think it's behaving as intended. If the code/approach is good I would be happy to add some tests.

@weiji14
Copy link
Member

weiji14 commented Mar 21, 2023

Going on a bit of a tangent, but continuing on a bit from #176 (comment), have you tried Shuffler in torchdata? My impression with torchdata's Shuffler is that it's slow, so maybe it is worth adding a shuffle option in xbatcher, but just wanted to know your experience so far.

@arbennett
Copy link
Author

I'll give it a shot! Apparently I need to dig into the torchdata docs a bit more closely 😅

@arbennett
Copy link
Author

I tried using the built in torchdata shuffler and, at least for subsampling from a large zarr file, it is extremely slow. Using the method implemented here is much faster/lightweight.

@weiji14
Copy link
Member

weiji14 commented Mar 22, 2023

I tried using the built in torchdata shuffler and, at least for subsampling from a large zarr file, it is extremely slow. Using the method implemented here is much faster/lightweight.

Hmm yes, that's what I expected. You could change the buffer_size in Shuffler from 10000 to a smaller number, but this would still be slower for the reason below.

What you've done in this xbatcher PR is essentially shuffling of the indexes (lightweight on RAM). With torchdata's Shuffler, you would be shuffling the arrays (heavy on RAM), unless you find a way to get in between the slicing and batching part.

This sort of ties in to my proposal at #172 on decomposing xbatcher into a Slicer and Batcher. So instead of a slow datapipe like Slicer -> Batcher -> Shuffler, you would be doing Slicer -> Shuffler -> Batcher that is faster (as you've proved in this PR) because it just randomizing the indexes/pointers to the arrays.

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

Successfully merging this pull request may close these issues.

2 participants