Skip to content

Sample's step_kwargs argument doesn't recognize 'metropolis' #3197

Closed
@moeyensj

Description

@moeyensj

Hello pymc3-devs and company,

Thank you for your time and effort.

I was trying to set the scaling for the Metropolis-Hastings sampler using the step_kwargs argument but it doesn't recognize the lower case name. It could also very well be that I am misunderstanding the docstring:

"""
step_kwargs : dict
        Options for step methods. Keys are the lower case names of the step method, values are
        dicts of keyword arguments. You can find a full list of arguments in the docstring of the
        step methods. If you want to pass arguments only to nuts, you can use `nuts_kwargs`.
"""

Here is a simplified example showing the problem:

import pymc3 as pm
import numpy as np

m = 2
b = 1.5
x = np.linspace(1, 10, 10)
Y = m*x + b

with pm.Model():
    b_m = pm.Uniform("b", lower=0, upper=1)
    m_m = pm.Uniform("m", lower=0, upper=1)
    y_m = pm.Normal("y", mu=m_m*x + b_m , observed=Y)
    
    step = pm.Metropolis()
    trace = pm.sample(draws=500, step=step, njobs=1, chains=10, step_kwargs={"metropolis": {"scaling": 100}})
---------------------------------------------------------------------------
ValueError                                Traceback (most recent call last)
<ipython-input-1-7a473d66c703> in <module>()
     13 
     14     step = pm.Metropolis()
---> 15     trace = pm.sample(draws=500, step=step, njobs=1, chains=10, step_kwargs={"metropolis": {"scaling": 100}})

~/anaconda3/envs/py36/lib/python3.6/site-packages/pymc3/sampling.py in sample(draws, step, init, n_init, start, trace, chain_idx, chains, cores, tune, nuts_kwargs, step_kwargs, progressbar, model, random_seed, live_plot, discard_tuned_samples, live_plot_kwargs, compute_convergence_checks, use_mmap, **kwargs)
    413                 step = assign_step_methods(model, step, step_kwargs=step_kwargs)
    414         else:
--> 415             step = assign_step_methods(model, step, step_kwargs=step_kwargs)
    416 
    417         if isinstance(step, list):

~/anaconda3/envs/py36/lib/python3.6/site-packages/pymc3/sampling.py in assign_step_methods(model, step, methods, step_kwargs)
    149             selected_steps[selected].append(var)
    150 
--> 151     return instantiate_steppers(model, steps, selected_steps, step_kwargs)
    152 
    153 

~/anaconda3/envs/py36/lib/python3.6/site-packages/pymc3/sampling.py in instantiate_steppers(model, steps, selected_steps, step_kwargs)
     75     unused_args = set(step_kwargs).difference(used_keys)
     76     if unused_args:
---> 77         raise ValueError('Unused step method arguments: %s' % unused_args)
     78 
     79     if len(steps) == 1:

ValueError: Unused step method arguments: {'metropolis'}

This problem can be bypassed if I just instantiated the step method as follows step = pm.Metropolis(scaling=100) but I am trying to allow the users of the code I am working on to chose what step method they want to use and its kwargs.

Versions and main components

  • PyMC3 Version: 3.5
  • Theano Version: 1.0.2
  • Python Version: 3.6.6
  • Operating system: Mac OS 10.13.6
  • How did you install PyMC3: conda

Metadata

Metadata

Assignees

No one assigned

    Labels

    No labels
    No labels

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions