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

Embedded bias initial implementation #114

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

Conversation

danielandresarcones
Copy link
Collaborator

@danielandresarcones danielandresarcones commented Aug 26, 2024

This is the initial implementation of embedded bias approaches to be integrated in probeye. It provides a working implementation for the computation of inverse problems with embedded bias.

  • Currently the bias embedding must be implemented manually in the forward model. Ideally, this should not be the case and the bias should be specified in the parameters and variables description.
  • The additions take care of the MCMC solver with stochastic forward model response and introduce four embedded likelihood formulations: ABC Moment matching, Global Moment Matching, Relative Global Moment Matching and Independent Normal. The details on the implementations will eventually be published.
  • Kennedy and O'Hagan-type formulations are not implemented in this PR and have been eliminated from the branched code.
  • Tests and one simple example for the documentation have been added.
  • chaospy has been added as a dependency. Probably should be an optional one, but kept as compulsory for now.
  • mypy was updated to the latest version

@danielandresarcones
Copy link
Collaborator Author

This update also implements the proposed solution of Issue #90 .

@danielandresarcones
Copy link
Collaborator Author

Tests cover is not 100% on the new implementations as there probably will be changes in the definition of the bias in the near future. The lack of cover is precisely on that front, the checks that some parameter definitions are correctly imported to the models. Nevertheless, they can be tested if considered necessary.

@danielandresarcones danielandresarcones marked this pull request as ready for review August 28, 2024 11:48
b_dist = chaospy.Normal(0.0, b)

# generate the polynomial chaos expansion
expansion = chaospy.generate_expansion(self.pce_order, bias_dist)
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It should be b_dist instead of bias_dist

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I missed that totally, thanks!

Copy link
Collaborator

@aradermacher aradermacher left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks Daniel,
I had problems running the example file, because of a typo (see comment)
Furthermore, during creating a new env I run into an error with python 3.13. Changing to 3.10 solved it.

bias_std -> b_dist
@danielandresarcones
Copy link
Collaborator Author

Do you remember what whas the error with python 3.13? I think probeye had some problems with it at some point, not necessarily the embedded bias implementation only.

@aradermacher
Copy link
Collaborator

Do you remember what whas the error with python 3.13? I think probeye had some problems with it at some point, not necessarily the embedded bias implementation only.

Yes it was something with the required packages (but I didn't saved the message sorry). So I think it's a general problem of probeye and not with your implementation.

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