Cloud based distributed TLC

1 Motivation

2 Warning

Using cloud based TLC launches compute instances at your cloud provider which may incur costs. While the cloud based distributed TLC tries to minimize costs by terminating instances as soon as possible, do not rely on it. Always check if cloud instances have been correctly terminated.

3 Limitation

4 Usage

Additionally to the instructions below, you can watch a eight minutes introductory video online.
  1. Set AWS access key and secret as environment variables prior to launching the Toolbox. See the example with dummy keys below.
    1. export AWS_ACCESS_KEY_ID=AKIA7D89HCLJKHZASD7F
      export AWS_SECRET_ACCESS_KEY=6FDASAIG7DAS976TYDKHCGQAS5D\FA77
      
    2. Alternatively for Azure, after the one-time creation and installation of a certificate, set:
    3. export AZURE_COMPUTE_CREDENTIALS=ThePasswordUsedForTheCertificate   (The "password" supplied during certificate creation)
      export AZURE_COMPUTE_IDENTITY=/absolute/path/to/the/azure.p12
      export AZURE_COMPUTE_SUBSCRIPTION=YourAzureSubscriptionId   (Extract the ID from the Azure portal under "Subscriptions")
      
  2. Create a specification and a model
  3. Open your model in the model editor
    figure ModelEditorA.png
    Figure 1 Model Editor
  4. Expand the “How to run” section of the “Model Overview” page
    figure ModelEditorB.png
    Figure 2 How to run section
  5. Select “aws-ec2” from the “Run in distributed mode” drop down
    figure ModelEditorC.png
    Figure 3 Select your cloud provider
  6. Enter an email address into “Result mailto address” at which you want to receive the model checking result
    figure ModelEditorD.png
    Figure 4 Enter your email address
  7. Click “Run TLC” to start model checking in the cloud and wait for the start-up to finish (it takes approximately five minutes to set-up the cloud instance)
    1. The Toolbox switches to the “Model checking results” page and opens a progress dialog indicating the state of cloud instance provisioning
      figure ProgressBar.png
      Figure 5 Progress Dialog
    2. After provisioning the cloud instance, the Toolbox prompts the user to open a website in a browser.
      figure ProgressBarFinal.png
      Figure 6 Progress Dialog Final
      This website is hosted on the cloud instance and shows the TLC process output as well as runtime statistics similar to Toolbox stats
      figure MCoutInBrowser.png
      Figure 7 TLC runtime statistics in your browser
  8. Walk out and enjoy the weekend while TLC is busy checking
  9. On Monday expect to find an email in your inbox
    figure EMailResult.png
    Figure 8 Email Result
  10. Save MC.out file somewhere to disc
  11. Switch back to the Toolbox and open the model editor
  12. Open the “Model Checking Results” page
    figure LoadResultIntoToolbox.png
    Figure 9 Load result into Toolbox
  13. Import the MC.out from disc
    figure LoadIntoResultPageB.png
    Figure 10 Load into results page
  14. Voilá
    figure FinalResultLoaded.png
    Figure 11 Final result loaded

5 Common problems