Interactive version: .

# Building Models¶

## Background¶

Storm supports a wide range of formalisms. Stormpy can be used to build models from some of these formalisms. Moreover, during construction, various options can be set. This document yields information about the most important options.

## Building different formalisms¶

We use some standard examples:

[1]:

>>> import stormpy.examples
>>> import stormpy.examples.files


Storm supports the explicit DRN format. From this, models can be built directly:

[2]:

>>> path = stormpy.examples.files.drn_ctmc_dft
>>> model = stormpy.build_model_from_drn(path)
>>> print(model.model_type)

ModelType.CTMC
WARN (DirectEncodingParser.cpp:119): No. of actions has to be declared. We may continue now, but future versions might not support this.


And the same for parametric models:

[3]:

>>> path = stormpy.examples.files.drn_pdtmc_die
>>> model = stormpy.build_parametric_model_from_drn(path)
>>> print(model.model_type)

ModelType.DTMC
WARN (DirectEncodingParser.cpp:119): No. of actions has to be declared. We may continue now, but future versions might not support this.


Another option are JANI descriptions. These are another high-level description format. Building models from JANI is done in two steps. First the Jani-description is parsed, and then the model is built from this description:

[4]:

>>> path = stormpy.examples.files.jani_dtmc_die
>>> jani_program, properties = stormpy.parse_jani_model(path)
>>> model = stormpy.build_model(jani_program)
>>> print(model.model_type)

ModelType.DTMC


Notice that parsing JANI files also returns properties. In JANI, properties can be embedded in the model file.