Source code for cmdstanpy.stanfit.metadata

"""Container for metadata parsed from the output of a CmdStan run"""

import copy
from typing import Any, Dict

import stanio


[docs]class InferenceMetadata: """ CmdStan configuration and contents of output file parsed out of the Stan CSV file header comments and column headers. Assumes valid CSV files. """ def __init__(self, config: Dict[str, Any]) -> None: """Initialize object from CSV headers""" self._cmdstan_config = config vars = stanio.parse_header(config['raw_header']) self._method_vars = { k: v for (k, v) in vars.items() if k.endswith('__') } self._stan_vars = { k: v for (k, v) in vars.items() if not k.endswith('__') } def __repr__(self) -> str: return 'Metadata:\n{}\n'.format(self._cmdstan_config) @property def cmdstan_config(self) -> Dict[str, Any]: """ Returns a dictionary containing a set of name, value pairs parsed out of the Stan CSV file header. These include the command configuration and the CSV file header row information. Uses deepcopy for immutability. """ return copy.deepcopy(self._cmdstan_config) @property def method_vars(self) -> Dict[str, stanio.Variable]: """ Method variable names always end in `__`, e.g. `lp__`. """ return self._method_vars @property def stan_vars(self) -> Dict[str, stanio.Variable]: """ These are the user-defined variables in the Stan program. """ return self._stan_vars