Skip to content

Commit

Permalink
Removed documentation on pGCL as support was removed (#471)
Browse files Browse the repository at this point in the history
  • Loading branch information
volkm authored Dec 14, 2023
2 parents 21026f9 + d3457f1 commit 0bdf3c9
Show file tree
Hide file tree
Showing 3 changed files with 2 additions and 19 deletions.
1 change: 0 additions & 1 deletion _layouts/home.html
Original file line number Diff line number Diff line change
Expand Up @@ -127,7 +127,6 @@ <h3 class="panel-title">Input languages</h3>
<li>JANI</li>
<li>GSPNs</li>
<li>DFTs</li>
<li>cpGCL</li>
<li>explicit</li>
</ul>
<div class="pull-right">
Expand Down
4 changes: 0 additions & 4 deletions documentation/background/languages.md
Original file line number Diff line number Diff line change
Expand Up @@ -39,10 +39,6 @@ The [GreatSPN editor](http://www.di.unito.it/~amparore/mc4cslta/editor.html){:ta
Dynamic Fault Trees are given in the so-called [Galileo Format](https://www.cse.msu.edu/~cse870/Materials/FaultTolerant/manual-galileo.htm#Editing%20in%20the%20Textual%20View){:target="_blank"}.
The format is a simple textual format naming the root of the tree and then lists all nodes of the tree, together with the children of each node. A [rich collection](https://github.com/moves-rwth/dft-examples){:target="_blank"} of examples is available.

## cpGCL

The conditional probabilistic guarded command language, cpGCL for short, is an extension of Dijkstra's guarded command language and pGCL {% cite HSM97 %} to also accommodate probabilistic choice and conditional observations. Examples can be found in some of the folders in the [JANI repository](#jani). For example, the famous coupon collector example encoded as a cpGCL program can be found [here](https://github.com/ahartmanns/jani-models/blob/master/CouponCollector/MultiAllowed/coupon_m_03_02.pgcl){:target="_blank"}.

## Explicit

In the spirit of [MRMC](http://www.mrmc-tool.org/){:target="_blank"}, Storm also supports input models specified in an explicit format. While the format closely resembles that of MRMC, it does not match exactly. Likewise, at the moment the model export of PRISM generates files that can be easily modified to be handled by Storm, but they still need to be adapted by hand.
Expand Down
16 changes: 2 additions & 14 deletions documentation/usage/running-storm.md
Original file line number Diff line number Diff line change
Expand Up @@ -43,12 +43,6 @@ Storm takes [many languages]({{ '/documentation/background/languages.html' | rel
<td>storm-gspn-cli</td>
<td><a href="running-storm.html#running-storm-on-gspns">Running Storm on GSPNs</a></td>
</tr>
<tr>
<td><a href="{{ '/documentation/background/languages.html#cpgcl' | relative_url }}">pGCL</a></td>
<td>storm-pgcl</td>
<td>storm-pgcl-cli</td>
<td><a href="running-storm.html#running-storm-on-pgcl">Running Storm on pGCL</a></td>
</tr>
</tbody>
</table>

Expand Down Expand Up @@ -215,7 +209,7 @@ In case you also want to read the properties from the jani file, the option `--j

#### Example 4 (Analysis of a rejection-sampling algorithm to approximate $$\pi$$)

Here, we are going to analyze a model of an algorithm that approximates $$\pi$$. It does so by repeated sampling according to a uniform distribution. While this model is a JANI model, the original model was written in [pGCL]({{ '/documentation/background/languages.html#cpgcl' | relative_url }}) and has been translated to JANI by Storm's `storm-pgcl` binary. The JANI model and the original pGCL code is available from the [JANI models repository](https://github.com/ahartmanns/jani-models){:target="_blank"}.
Here, we are going to analyze a model of an algorithm that approximates $$\pi$$. It does so by repeated sampling according to a uniform distribution. While this model is a JANI model, the original model was written in the probabilistic guarded command language (pGCL) and has been translated to JANI. The JANI model and the original pGCL code is available from the [JANI models repository](https://github.com/ahartmanns/jani-models){:target="_blank"}.

{% include includes/show_model.html name="original pGCL program" class="jani_approxpi_pgcl" path="jani/approx_pi_00100_010_full.pgcl" %}

Expand All @@ -231,7 +225,7 @@ $ storm --jani approx_pi_00100_010_full.jani --engine hybrid

As we selected the *hybrid* engine, Storm builds the MDP in terms of a symbolic data structure ((MT)BDDs), hence the `(symbolic)` marker. For this representation, Storm also reports the sizes of the state and transition DDs in terms of the number of nodes.

The algorithm uses a sampling-based technique to approximate $$\pi$$. More specifically, it repeatedly (100 times in this particular instance) samples points in a square and checks whether they are in a circle whose diameter is the edge length of the square (which is called a hit). From this, we can derive $$\pi \approx 4 \frac{hits}{100}$$ (for more details, we refer to [this explanation](https://theclevermachine.wordpress.com/tag/rejection-sampling/){:target="_blank"}). We are therefore interested in the expected number of hits until termination of the algorithm (as all JANI models obtained from `storm-pgcl`, it has a transient Boolean variable `_ret0_` that marks termination of the pGCL program; this transient variable can be used as a label in properties):
The algorithm uses a sampling-based technique to approximate $$\pi$$. More specifically, it repeatedly (100 times in this particular instance) samples points in a square and checks whether they are in a circle whose diameter is the edge length of the square (which is called a hit). From this, we can derive $$\pi \approx 4 \frac{hits}{100}$$ (for more details, we refer to [this explanation](https://theclevermachine.wordpress.com/tag/rejection-sampling/){:target="_blank"}). We are therefore interested in the expected number of hits until termination of the algorithm. The program has a transient Boolean variable `_ret0_` that marks termination of the pGCL program; this transient variable can be used as a label in properties:

```console
$ storm --jani approx_pi_00100_010_full.jani --engine hybrid --prop "Rmax=? [F \"_ret0_\"]"
Expand Down Expand Up @@ -338,9 +332,3 @@ For additional command-line options see the help for GSPNs with:
```console
$ storm-gspn --help gspn
```


## Running Storm on pGCL

{:.alert .alert-info}
Coming soon.

0 comments on commit 0bdf3c9

Please sign in to comment.