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

initmarginals in rxinference confusing (not starting inference) #77

Open
bartvanerp opened this issue Feb 28, 2023 · 1 comment
Open
Labels
documentation Improvements or additions to documentation enhancement New feature or request

Comments

@bartvanerp
Copy link
Member

Ran into an issue that I think a lot of people will get who want to try out the rxinference() function.
For the simple model

@model function observation_model(Hs, Qs, R)

    # specify data variables
    μ_s = datavar(Vector{Float64})
    Σ_s = datavar(Matrix{Float64})

    # specify priors
    s_prev ~ MvNormalMeanCovariance(μ_s, Σ_s)

    # add process noise
    s ~ MvNormalMeanCovariance(s_prev, Qs)

    # form observation
    y = datavar(Float64)
    y ~ NormalMeanVariance(dot(Hs, s), R)

    # return variables
    return y, s, n 

end

with auto updates:

autoupdates = @autoupdates begin
	μ_s, Σ_s = mean_cov(q(s))
end;

I started off with the following implementation:

rxinference(
        model = observation_model(Hs, Qs, R),
        data          = (y = data, ),
        autoupdates   = autoupdates,
        initmarginals = (
            s_prev = vague(MvNormalMeanCovariance, deployed_model_signal.dim_in), 
        ), 
        returnvars    = (:s,),
        keephistory   = length(data),
        historyvars   = (s = KeepLast(),),
        autostart     = true,
   )

which did not start the inference procedure, i.e. methoderror: iterate(::Nothing) as a result of mean_cov(::Missing). It turned out that initmarginals first sets the marginals, then autoupdates is called and then inference actually starts. Below code did run:

rxinference(
        model = observation_model(Hs, Qs, R),
        data          = (y = data, ),
        autoupdates   = autoupdates,
        initmarginals = (
            s= vague(MvNormalMeanCovariance, deployed_model_signal.dim_in), 
        ), # specifies the initial q(s) to get the inference starting (i.e. first autoupdates, then message passing)
        returnvars    = (:s,),
        keephistory   = length(data),
        historyvars   = (s = KeepLast(),),
        autostart     = true,
   )

I understand why it is implemented as such, but it is not clear from the error message what is going wrong. Perhaps we can improve the error handling by first check whether all marginals in autoupdates are specified in the initmarginals struct. If this is not the case we should throw an error message stating that first marginals are set, then autoupdates is called and then data is fed into the model.

@bartvanerp bartvanerp added documentation Improvements or additions to documentation enhancement New feature or request labels Feb 28, 2023
@albertpod albertpod added this to RxInfer Mar 6, 2023
@bvdmitri
Copy link
Member

bvdmitri commented Oct 5, 2023

#61 link

@wouterwln wouterwln modified the milestones: RxInfer 3.0.0 release, RxInfer 3.1.0 release Mar 15, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
documentation Improvements or additions to documentation enhancement New feature or request
Projects
None yet
Development

No branches or pull requests

3 participants