-
Notifications
You must be signed in to change notification settings - Fork 33
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
Implementing Radial BNN #12
Comments
Hi,
And then the AutoRadial guide would (hopefully :-) ) work in place of an AutoNormal guide as in the examples. (2) is unfortunately a bit ugly, ideally we'd have some kind of autoguide factory class in tyxe that can generate autoguides for a given distribution to make adding custom distribution easier. I'll give this some more thought when I get the chance. As an additional note on (1), you might want to also implement the KL divergence between the RadialNormal and a Normal distribution (I think that's what they use as a prior in the paper). For that you need to implement the kl as a decorated method like:
where q is a RadialNormal and p a Normal object. Sorry this is all a bit more involved than it should be, but I hope this helps. If you need any more details or if I overlooked any issues, let me know. And if you have a go at an implementation, feel free to link your repo/a gist here, I'm happy to take a look at it. |
Hey, sorry for the delay; thanks a lot for the help! I managed to implement a script for running VI with BNNs with this radial approximation with your tips. I've actually had great results with this posterior. In general, it seems to me that the mean-field approximation often struggles to converge to an accurate solution and the radial posterior consistently seems to outperform both mean-field and low-rank approximations. Feel free to take a look at it in https://github.com/silasbrack/approximate-inference-for-bayesian-neural-networks/blob/main/src/guides/radial.py |
Hi,
I’m trying to fit a radial BNN posterior variational approximation as per this paper.
However, since I’ll be training a BNN, I don’t want to have to write a custom guide and define this variational approximation for all of my layers, and so was trying to implement a custom AutoGuide which automatically puts a radial BNN approximation on all of my weights.
The radial approximation is defined as follows:
where I just need to sample all epsilon_MFVI from an independent standard normal distribution, normalize them, and multiply them by r, which is a scalar sampled from a standard normal.
How could I go about implementing this in TyXe?
Is there a smarter way of implementing this variational approximation?
P.S. Big fan of this project!
Thanks in advance.
The text was updated successfully, but these errors were encountered: