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

Variable time resampling #385

Open
reubenharry opened this issue Jan 4, 2025 · 1 comment
Open

Variable time resampling #385

reubenharry opened this issue Jan 4, 2025 · 1 comment

Comments

@reubenharry
Copy link

One feature I often want in Rhine-Bayes is the ability to control how often resampling happens (which I believe in the present implementation happens at every time step).

The simplest thing would be to specify a resampling rate for runPopulationCl. More complex would be to have the return type of runPopulationCl be ClSF m cl (a, Bool) [(b, Log Double)], where the Bool determines when resampling happens. Does this seem doable (in which case I could have a go) or do you think there's a reason it's not practical?

@turion
Copy link
Owner

turion commented Jan 4, 2025

This seems certainly doable, and I had plans for controlling when resampling happens since some time. Your approach is the most straightforward.

Another idea (which coincidentally might be what you actually want) is to make the decision whether to resample based on the effective sample size. If this is what you want then the advantage is that we don't need to change anything about rhine-bayes, it can all be done in monad-bayes by changing the resampler. In general, if the information whether to resample or not is already in the population then it's best to adjust the resampler.

There are drafts for this in tweag/monad-bayes#268 and #222.
I got stuck a bit because I was unsure what the right implementation is, but your prompt has made me come up with a new approach which I'll test now.

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

No branches or pull requests

2 participants