Comments (4)
Closing this due to inactivity.
from elfi.
Hi!
Have you given pool
for the inference method (see the attached example)?
If you're dealing with "accepted" simulations, then you're doing rejection sampling or smc? You can look at the results-object which contains the accepted samples for each of the nodes. e.g. result.outputs['t1']
. If you want all the generated samples, you can now access the batches in pool.stores['t1']
.
import elfi
from elfi.examples import ma2
# load the model from elfi.examples
model = ma2.get_model()
# Set up output pool for the desired nodes
pool = elfi.OutputPool(['MA2', 'S1', 'S2', 't1', 't2'])
rej = elfi.Rejection(model['d'], batch_size=10, pool=pool)
result = rej.sample(n_samples=100, quantile=0.2)
print("Accepted samples of node \'t1\' = \n" + str(result.outputs['t1']))
print("Generated samples from node \'t1\' = \n" + str(pool.stores['t1']))
from elfi.
Thanks for the quick response @hpesonen !
Yes I do hand the pool = elfi.OutputPool
instance to the inference method (elfi.Rejection(d, pool=pool)
). The MA2 example also works fine: I can access both the result.outputs
and the pool.stores
. Although the results.outputs
does not contain the node outputs from MA2, S1 and S2 - just from d, t1 and t2.
In my own model result.outputs
only contains the prior samples as well as the output of my distance function - but not of either the summary nor the simulator function. My simulator function output is a set
of tuples (graph edges) that get compared to the observation(s) using a custom Summary statistic function (Jaccard index), which outputs a float
. Could the set
be a dtype that can't get stored?
from elfi.
Could you include a small reproducible example of the issue? You could give keyword output_names
(list) to Rejection
to get the node outputs from the ELFI graph. However, unfortunately this feature currently supports only numpy arrays and won't help if your simulator data are sets
.
You should be able to access all the samples you have generated via OutputPool
even if the node output is e.g. a list of sets of size batch_size
. And if you use Rejection
, you could manually choose and store only samples with the lowest discrepancy.
from elfi.
Related Issues (20)
- threshold value returned when specifying 'n_sim' in Rejection sampler HOT 1
- Use Dask for parallel computing? HOT 5
- Can rejection sampling be done with no explicit passing of observed data to a simulator? HOT 2
- Regression adjustment returns point estimate in specific case HOT 3
- networkx 2 compatibility HOT 3
- stochastic_optimization call to differential_evolution broken in newer scipy HOT 1
- Implement initial standard BSL HOT 1
- Implement initial semiBSL method HOT 1
- Tightly pinned requirements are becoming out of date HOT 2
- elfi.examples docstrings are missing details HOT 1
- BOLFIRE target nodes
- Extend sample result summaries HOT 1
- Issue in trying to setup RandMaxVar in BOLFI HOT 4
- Require `plot_gp` inputs `const` and `bounds` to be given as dictionaries
- Random variation in default kernel parameters
- BOLFI posterior.py logging
- Processing failed simulations / samples HOT 2
- BOLFI fails if numpy version is >= 1.20 HOT 1
- Basic rejection method of inferring parameters of an SIR disease model HOT 4
- import elfi fails HOT 1
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from elfi.