| No edit summary | |||
| (14 intermediate revisions by 2 users not shown) | |||
| Line 2: | Line 2: | ||
| We assume that you grasped the first steps of opening and animating a B machine as outlined in [[Tutorial First  | We assume that you have grasped the first steps of opening and animating a B machine as outlined in [[Tutorial First Step]]. | ||
| In this lesson, we examine more closely the various steps that ProB undertakes before a machine can be animated. | In this lesson, we examine more closely the various steps that ProB undertakes before a machine can be animated. | ||
| Line 15: | Line 15: | ||
| * 1. Loading the machine and determining the sizes of the deferred sets, as well as fixing the values of MININT and MAXINT. | * 1. Loading the machine and determining the sizes of the deferred sets, as well as fixing the values of MININT and MAXINT. | ||
| * 2. Setting up the constants of the machine, such that the PROPERTIES and CONSTRAINTS are satisfied. | * 2. Setting up the constants of the machine, such that the PROPERTIES and CONSTRAINTS are satisfied. | ||
| * 3. Performing a valid  | * 3. Performing a valid initialization of the machine. | ||
| This process is illustrated in the following picture: | This process is illustrated in the following picture: | ||
| Line 30: | Line 30: | ||
| * by using "Animation Preferences..." command in the "Preferences" menu and modifying the corresponding preferences. | * by using "Animation Preferences..." command in the "Preferences" menu and modifying the corresponding preferences. | ||
| * by including a "DEFINITIONS" section in your machine (if there is not yet one) and then adding a definition of the form <tt>SET_PREF_MAXINT == 5</tt> or <tt>SET_PREF_MININT == -2147483648</tt>. | * by including a "DEFINITIONS" section in your machine (if there is not yet one) and then adding a definition of the form <tt>SET_PREF_MAXINT == 5</tt> or <tt>SET_PREF_MININT == -2147483648</tt>. | ||
| Note that these preferences determine the elements of the sets <tt>INT</tt> (implementable integers), <tt>NAT</tt> (implementable natural numbers) and <tt>NAT1</tt>. In addition, they are used to control the enumeration of variables of type <tt>INTEGER</tt | Note that these preferences determine the elements of the sets <tt>INT</tt> (implementable integers), <tt>NAT</tt> (implementable natural numbers) and <tt>NAT1</tt>. In addition, they are used to control the enumeration of variables of type <tt>INTEGER</tt> (mathematical integers), in case a definite value cannot be inferred from the machine. | ||
| Afterwards, ProB will determine the cardinality of all deferred sets (such as <tt>TRACK</tt> in the Jukebox machine).There are several ways you can influence this: | Afterwards, ProB will determine the cardinality of all deferred sets (such as <tt>TRACK</tt> in the Jukebox machine). There are several ways you can influence this: | ||
| * by using "Animation Preferences..." command in the "Preferences" menu and modifying the preference "Size of unspecified deferred sets in SETS section". | * by using "Animation Preferences..." command in the "Preferences" menu and modifying the preference "Size of unspecified deferred sets in SETS section". | ||
| * by including a "DEFINITIONS" section in your machine (if there is not yet one) and then adding a definition of the form <tt>scope_TRACK == 5</tt> (where <tt>TRACK</tt> is the name of the deferred set you wish to influence and 5 is its desired cardinality). This will override the default size. | * by including a "DEFINITIONS" section in your machine (if there is not yet one) and then adding a definition of the form <tt>scope_TRACK == 5</tt> (where <tt>TRACK</tt> is the name of the deferred set you wish to influence and 5 is its desired cardinality). This will override the default size. | ||
| * by including a predicate of the form <tt>card(TRACK)=5</tt> in the <tt>PROPERTIES</tt> or <tt>CONSTRAINTS</tt> section of your machine. | * by including a predicate of the form <tt>card(TRACK)=5</tt> in the <tt>PROPERTIES</tt> or <tt>CONSTRAINTS</tt> section of your machine. | ||
| As you can see above in the "State Properties" pane, ProB has chosen MAXINT=3, MININT=-1 and card(TRACK)=2. If you wish to change these settings, perform the steps above and reload the machine. Hint: there is a "Reopen" command in the "File" menu: | |||
| [[file:ProB_JukeboxReopenCommand.png|center]] | |||
| == 2. SETUP_CONSTANTS == | |||
| In this phase ProB will try and find values for the constants and parameters of your machine, so that the <tt>PROPERTIES</tt> and <tt>CONSTRAINTS</tt> are true. | |||
| Note that ProB will '''not''' (yet) modify the settings from phase 1 for MAXINT, MININT and the size of the deferred sets. | |||
| ProB will initiate this phase automatically, and as we can see above, ProB has found three distinct ways to setup the constant limit. Observe that a little orange button labeled max has appeared in the "Enabled Operations" pane. This means that there might actually be more than three ways to setup the constants. (If you wish you can right-click in the pane and select "Execute an Operation..." which allows you to choose other values such as limit=4. We will [[Tutorial_Animation_Tips|return to this issue later]].) | |||
| By double clicking on "SETUP_CONSTANTS(2)" we proceed to the next phase: | |||
| [[file:ProB_JukeboxAfterSETUPCONSTANTS.png|center||700px]] | |||
| == 3. INITIALIZATION == | |||
| In this phase the values for the constants have been found, but the initial values of the variables still remain to be determined. For this, ProB will try to execute the <tt>INITIALISATION</tt> substitution. | |||
| As we can see above, ProB has found just one possible way to initialize the variables <tt>credit</tt> and <tt>playset</tt>. Double-clicking on INITIALISATION(0,{}) leads the animator into a state where all constants and variables are valued, and where the <tt>INVARIANT</tt> can be checked and operations can be applied: | |||
| [[file:ProB_JukeboxAfterINITIALISATION.png|center|700px]] | |||
| Let us conclude by  choosing the "View Statespace" command in the "Animate" menu: | |||
| [[file:ProB_Jukebox_Statespace.png|center|500px]] | |||
| As you can see, there is only one root node (inverted triangle): in order to change MAXINT, MININT or the deferred set sizes you have to reload the machine. There are, however, three different ways to setup the constants. The model checker will explore all of them. Let us choose the "Model Check..." command in the "Verify" menu and then press on the "Model Check" button. | |||
| If we now choose the "View Statespace" command in the "Animate" menu, we get the following picture: | |||
| [[file:ProB_Jukebox_StatespaceFull.png|center]] | |||
| We can see (or guess at least) that ProB has validated the machine and explored the statespace not just for <tt>limit=2</tt> but also for <tt>limit=1</tt> and <tt>limit=3</tt>. | |||
We assume that you have grasped the first steps of opening and animating a B machine as outlined in Tutorial First Step.
In this lesson, we examine more closely the various steps that ProB undertakes before a machine can be animated.
First, open the machine "Jukebox.mch" which can be found in the SchneiderBook/Jukebox_Chapter13 subdirectory of the ProB Examples folder. The main ProB window should look more or less as follows:

In general, before the operations of a machine can be applied, ProB needs to traverse three phases:
This process is illustrated in the following picture:

We now examine these phases on the Jukebox machine in more detail
Here ProB parses and type checks the machine.
Then it will fix the values of MININT and MAXINT. There are two ways you can influence this:
Note that these preferences determine the elements of the sets INT (implementable integers), NAT (implementable natural numbers) and NAT1. In addition, they are used to control the enumeration of variables of type INTEGER (mathematical integers), in case a definite value cannot be inferred from the machine.
Afterwards, ProB will determine the cardinality of all deferred sets (such as TRACK in the Jukebox machine). There are several ways you can influence this:
As you can see above in the "State Properties" pane, ProB has chosen MAXINT=3, MININT=-1 and card(TRACK)=2. If you wish to change these settings, perform the steps above and reload the machine. Hint: there is a "Reopen" command in the "File" menu:

In this phase ProB will try and find values for the constants and parameters of your machine, so that the PROPERTIES and CONSTRAINTS are true. Note that ProB will not (yet) modify the settings from phase 1 for MAXINT, MININT and the size of the deferred sets.
ProB will initiate this phase automatically, and as we can see above, ProB has found three distinct ways to setup the constant limit. Observe that a little orange button labeled max has appeared in the "Enabled Operations" pane. This means that there might actually be more than three ways to setup the constants. (If you wish you can right-click in the pane and select "Execute an Operation..." which allows you to choose other values such as limit=4. We will return to this issue later.)
By double clicking on "SETUP_CONSTANTS(2)" we proceed to the next phase:

In this phase the values for the constants have been found, but the initial values of the variables still remain to be determined. For this, ProB will try to execute the INITIALISATION substitution. As we can see above, ProB has found just one possible way to initialize the variables credit and playset. Double-clicking on INITIALISATION(0,{}) leads the animator into a state where all constants and variables are valued, and where the INVARIANT can be checked and operations can be applied:

Let us conclude by  choosing the "View Statespace" command in the "Animate" menu:

As you can see, there is only one root node (inverted triangle): in order to change MAXINT, MININT or the deferred set sizes you have to reload the machine. There are, however, three different ways to setup the constants. The model checker will explore all of them. Let us choose the "Model Check..." command in the "Verify" menu and then press on the "Model Check" button.
If we now choose the "View Statespace" command in the "Animate" menu, we get the following picture:

We can see (or guess at least) that ProB has validated the machine and explored the statespace not just for limit=2 but also for limit=1 and limit=3.