Difference between pages "Code Generation Activity" and "Rodin Platform 2.1 Release Notes"

From Event-B
(Difference between pages)
Jump to navigationJump to search
imported>Andy
 
imported>Tommy
 
Line 1: Line 1:
Tasking Event-B is the extension of Event-B for defining concurrent systems sharing data, for details see the [[Tasking Event-B Overview]] page. For more information contact Andy Edmunds - University of Southampton - mailto:ae2@ecs.soton.ac.uk, or Chris Lovell mailto:cjl3@ecs.soton.ac.uk
+
{{TOCright}}
=== Code Generation Feature - Version 0.2.2 For Rodin 2.4===
 
  
We released V0.2.2 on 22-03-2012. The main changes, to the interface, and translation from theories are described below:
+
== What's New in Rodin 2.1? ==
 +
* General Interface
 +
**Improved general platform performance.
 +
**Preferences for the automatic tactics changed.
 +
:::It is now possible to define profiles (e.g. ordered lists) of tactics to be used in post or automatic tactics at both workspace and/or project level. A mechanism is also provided in order to export and share these profiles.
 +
:::See [[Preferences_for_the_automatic_tactics | Preferences for the automatic tactics]]
  
* Tasking Event-B is now integrated with the Event-B Editors.
+
* Modelling
* We have the ability to translate to C, Java, etc. in addition to Ada source code.
 
* We use theories to define translations of the Event-B mathematical language (Theories for Ada, Java and C are supplied).
 
* We use the theory plug-in as a mechanism for defining new data types , and the translations to target data types.
 
* The translator is extensible.
 
* Minimal use is made of the EMF tree editor in Rose.
 
  
To install v0.2.2:
+
* Proving
 +
:'''New automatic rewriting rules'''. Over 150 automatic rewriting rules have been added, making it easier to discharge proof obligations.
 +
:See: [[All_Rewrite_Rules]]
  
* Access the main Rodin Update Site. In Eclispe click on Help/Install new Software. Find the Rodin update site from the list. In Utilities add Code Generation.
+
== Requirements ==
The approach makes use of the following, which should be installed if the features are required by the user for editing:
+
{{TODO | COPY REQUIREMENTS FROM PREVIOUS PAGES / VERIFY}}<br>
*Model Decomposition: Download from the main Rodin Update Site, in the Decomposition section.
+
{{TODO | Inform here of some specific system requirements (version of Java, etc).}}
*Shared Event Composition: Download from the main Rodin Update Site, in the Decomposition section.
 
*Theory Plug-in: Download from the main Rodin Update Site, in the Modelling Extensions section.
 
  
Examples available at:
+
== External plug-ins ==
+
{{:Rodin_Platform_2.1_External_Plug-ins}}
* Tutorial, and example, projects are available from the Examples directory: [https://codegenerationd.svn.sourceforge.net/svnroot/codegenerationd/Examples/v0.2.2/ SVN].
 
* Test projects are also available from the Examples directory [https://codegenerationd.svn.sourceforge.net/svnroot/codegenerationd/Examples/v0.2.2/CG_v0.2.2_Tests SVN].
 
* Sources at: [https://rodin-b-sharp.svn.sourceforge.net/svnroot/rodin-b-sharp/trunk/CodeGeneration SVN]
 
* Example Theories at: [https://codegenerationd.svn.sourceforge.net/svnroot/codegenerationd/Examples/TheoriesForCG SVN]
 
  
=== Code Generation Feature - Version 0.2.1 For Rodin 2.3===
+
== Downloading ==
Contains Bug Fixes for previous release. 14-12-2011
+
{{TODO | Add here a link to download the platform.}}
  
=== Code Generation Feature - Version 0.2.0 For Rodin 2.3===
+
== Fixed Bugs ==
We released a new version of the code generator on 30-11-2011, and updated documentation.
+
{{TODO | Add here a list of the fixed bugs.}}
===== Changes to the Tooling and Approach =====
 
The main changes are:
 
* The code generators have been completely re-written. The translators are now implemented in Java, i.e. there is no longer a dependence on the Epsilon tool set. This was undertaken for code maintenance reasons.
 
* Tasking Event-B is now integrated with the Event-B explorer.
 
* The Rose Editor is used for editing the Tasking Event-B, and
 
* a text-based editor is provided, using the Rose extension, for editing the TaskBody. This feature has been added to address some of the usability concerns. It also overcomes the 'problem' experienced with duplicate event names in a development, since the parser-builder that has been implemented automatically selects the correct event.
 
* The EMF tree editor in Rose is only used minimally; we plan enhancements to further reduce its use.
 
* Composed machines are used to store event 'synchronizations'; these are generated automatically during the decomposition process. This reduces the amount of typing in the TaskBody editor, since we no longer need to specify both local and remote (synchronizing) events.
 
* The code generation approach is now extensible; new target language constructs can be added using the Eclipse extension mechanism.
 
* The translation of target's mathematical language is now specified in the theory plug-in. This improves clarity since the the translation from source to target is achieved by specifying pattern matching rules. Extensibility is also improved; the theory plug-in is used to specify new data-types, and how they are implemented.
 
* Translated code is deposited in a directory in the appropriate files. An Ada project file is generated for use with AdaCore's GPS workbench. Eventually this could be enabled/disabled in a preferences dialog box.
 
* The Tasking Event-B to Event-B translator is now properly integrated. Control variable updates to the Event-B model are made in a similar way to the equivalent updates in the state-machine plug-in. The additional elements are added to the Event-B model and marked as 'generated'. This prevents users from manually modifying them, and allows them to be removed through a menu choice.
 
  
===== Changes to the Documentation =====
+
== Known Issues ==
The following Pages have been updated:
+
{{TODO | COPY KNOWN ISSUES FROM PREVIOUS PAGES / VERIFY}}<br>
* [http://wiki.event-b.org/index.php/Tasking_Event-B_Overview Tasking Event-B Overview]
+
{{TODO | Add here a link to the SourceForge Bugs page, after filtering bugs (Assignee Any, Status Open, Category Any, Group 1.2).}}
* [http://wiki.event-b.org/index.php/Tasking_Event-B_Tutorial Tutorial]
 
  
TODO
+
== About ==
* Add addressed variables (for direct read/write access to memory)
+
Rodin Platform up to rxxxx <br>
* Flattening of composed machines/implementation machines.
+
Developer Release date : dd/mm/yyyy.<br>
* Interrupts
+
User Release date : 28/01/2011.<br>
  
=== Sensing and Actuating for Tasking Event-B ===
+
[[Category:Rodin Platform Release Notes]]
Version 0.1.5. Sensing and actuating events, and an Environ Machine have been added to allow simulation of the environment and implementation using memory mapped IO.
 
 
 
* The new v0.1.5 feature is available from the Rodin Update Site, it resides in the Utilities Category.
 
 
 
* As in previous releases, the code generation plug-in relies on the Epsilon tool suite. Add the following Epsilon interim update site to the list of available update sites in the Eclipse menu ''help/install new software'': http://download.eclipse.org/modeling/gmt/epsilon/interim/
 
 
 
* Select 'the Epsilon Core (Incubation)' component, this is the only component that is required for Tasking Event-B.
 
 
 
A new [http://wiki.event-b.org/index.php?title=Tasking_Event-B_Tutorial Code Generation Tutorial] has been produced, that makes use of these new features. There is an explanation of the heating controller, upon which it is based, [http://wiki.event-b.org/index.php/Development_of_a_Heating_Controller_System here].
 
 
 
The example/tutorial projects, and also and a Bundled Windows 7 version, are available in the [http://deploy-eprints.ecs.soton.ac.uk/304/ Deploy E-Prints archive] or [https://codegenerationd.svn.sourceforge.net/svnroot/codegenerationd/Examples/HeatingController_Tutorial_v0.1.4/ Examples SVN site].
 
 
 
=== The Code Generation Demonstrator for Rodin 2.1.x ===
 
 
 
Released 24 January 2011.
 
 
 
The Rodin 2.1.x compatible code generation demonstrator plug-ins have been released into the Rodin Sourceforge repository at:
 
 
 
  https://rodin-b-sharp.svn.sourceforge.net/svnroot/rodin-b-sharp/trunk/CodeGeneration
 
 
 
The update-site is available through the Rodin update site in the ''Utilities'' category.
 
 
 
The code generation tutorial examples are available for download at:
 
 
 
  https://sourceforge.net/projects/codegenerationd/files/DemoFiles/
 
 
 
The code generation plug-in relies on the Epsilon tool suite. Install Epsilon manually, since the automatic install utility does not seem to work for this feature. We currently use the Epsilon interim update site available at:
 
 
 
  http://download.eclipse.org/modeling/gmt/epsilon/interim/
 
 
 
Select 'the Epsilon Core (Incubation)' component, this is the only component that is required for Tasking Event-B.
 
 
 
== Code Generation Status ==
 
=== Latest Developments ===
 
* Demonstrator plug-in feature version 0.1.0
 
** for Rodin 2.1.x version is available.
 
 
 
* The Code Generation feature consists of,
 
** a tasking Development Generator.
 
** a tasking Development Editor (Based on an EMF Tree Editor).
 
** a translator, from Tasking Development to Common Language Model (IL1).
 
** a translator, from the Tasking Development to Event-B model of the implementation.
 
** a pretty-printer for the Tasking Development.
 
** a pretty-printer for Common Language Model, which generates Ada Source Code.
 
 
 
* A tutorial is available [[Code Generation Tutorial]]
 
** Step 1 - Create the tasking development.
 
** Step 2 - Add annotations.
 
** Step 3 - Invoke translators.
 
 
 
=== Ongoing Work ===
 
 
 
* Full Rodin Integration
 
* Sensed Variables
 
* Branching in Shared Machines
 
 
 
=== Future Work ===
 
* Support for Interrupts.
 
* Richer DataTypes.
 
* Accommodation of duplicate event names in tasking developments.
 
 
 
== Metamodels ==
 
* In the plug-in we define several meta-models:
 
** CompositeControl: for the control flow (algorithmic) constructs such as branch, loop and sequence etc. These constructs may be used in the specification of either  sequential or concurrent systems.
 
** Tasking Meta-model: defines the tasking model where we attach tasking specific details, such as task priority, task type. The tasking structures provide the ability to define single tasking or multi-tasking (concurrent) systems. We make use of the composite control plug-in to specify the flow of control.
 
** Common Language (IL1) Meta-model: defines an abstraction of common programming language constructs for use in translations to implementations.
 
 
 
== Translation Rules ==
 
* Tasking to IL1/Event-B translation rules [[http://wiki.event-b.org/images/Translation.pdf]]
 
 
 
== Release History ==
 
=== The Code Generation Demonstrator for Rodin 1.3.x ===
 
 
 
 
 
First release: 30 November 2010.
 
 
 
available from:
 
 
 
https://sourceforge.net/projects/codegenerationd/files/
 
 
 
The zip file contains a windows XP bundle, and a Windows V7 bundle. Alternatively, if you wish to build using an update-site, this is also included in the zip file, along with some notes on installation. However, note that the demonstrator tool is only compatible with Rodin 1.3.
 
 
 
A simple shared buffer example is provided. This will form the basis of a tutorial (which is work in progress). The WindowsBundles directory contains a Rodin 1.3.1 platform with the Code Generation plug-ins, together with a patch plug-in. The patch plug-in is required to correct an inconsistency in the org.eventb.emf.persistence plug-in. For the bundles, simply extract the appropriate zip file into a directory and run the rodin.exe. The plug-ins are pre-installed - the only configuration necessary may be to switch workspace to ''<installPath>\rodin1.3bWin7\workspace''. When using the update-site the example projects, and the project forming the basis of a simple tutorial, are provided in the accompanying zip file. These should be imported manually.
 
 
 
Mac users - no bundled version available at present, but use the update site in the 'advanced' folder.
 
 
 
'''A step-by-step [[Code Generation Tutorial]] is available'''
 
 
 
==== About the Initial Release ====
 
The Code Generation (CG) Feature in the initial release is a demonstration tool; a proof of concept, rather than a prototype. The tool has no static checker and, therefore, there will be a heavy reliance on docs and dialogue to facilitate exploration of the tools and concepts.
 
 
 
==== Source Code ====
 
 
 
The sources are available from,
 
 
 
https://codegenerationd.svn.sourceforge.net/svnroot/codegenerationd
 
 
 
Note - I used Eclipse 3.5 Galileo, and you will need to install (or have sources from) Epsilon's interim update site. There is also dependency on Camille v2.0.0
 
 
 
 
 
 
 
[[Category:Work in progress]]
 

Revision as of 14:03, 10 January 2011

What's New in Rodin 2.1?

  • General Interface
    • Improved general platform performance.
    • Preferences for the automatic tactics changed.
It is now possible to define profiles (e.g. ordered lists) of tactics to be used in post or automatic tactics at both workspace and/or project level. A mechanism is also provided in order to export and share these profiles.
See Preferences for the automatic tactics
  • Modelling
  • Proving
New automatic rewriting rules. Over 150 automatic rewriting rules have been added, making it easier to discharge proof obligations.
See: All_Rewrite_Rules

Requirements

TODO: COPY REQUIREMENTS FROM PREVIOUS PAGES / VERIFY
TODO: Inform here of some specific system requirements (version of Java, etc).

External plug-ins

Rodin Update Site

Plug-in name Version Status MCV* Release Date Contact Additional info
Umlb32.gif UML-B 2.2.0 available 9th Feb. 2011 email
UML-B Statemachine Animation 1.1.0 available 15th Feb. 2011 email Compatible with UML-B 2.2 and ProB 2.1.
Event-B EMF framework 3.2.1 available Users should not need to install this framework. It will be installed automatically by other plug-ins as required.
Export to Isabelle available 2.x.x email
Rose.gif Rose 1.1.0 available email
Records 1.0.1 available email This release includes EMF and Refactory support for records.
Teamwork not available
Shared Event Composition 1.3.1 available 9th Mar. 2011 email
Refactory 1.1.0 available 11th Feb. 2011 email
DecompositionPlug-in logo.png Decomposition 1.2.0 available 11th Feb. 2011 email
Project diagram icon s.png Project Diagram 1.0.0 available email
Relevance Filter 1.0.0 available 2.x.x email
Theory Plug-in v0.6 available 4th Jan. 2011 email
Code Generation Feature 0.1.5 available 17th May 2011 email

B Method Update Site

Plug-in name Version Status MCV* Release Date Contact Additional info
Atelier-B provers 1.2.2 available 17th Feb. 2011

Other Updates Sites

Plug-in name Version Status MCV* Release Date Contact Additional info
AnimB.png AnimB not available Christophe Métayer Use the update site http://www.animb.org/updatesite
Camille available Use the Camille update site. http://www.stups.uni-duesseldorf.de/camille_updates
Mlogo big.png Modularisation available 2.x.x email Use the update site http://www.iliasov.org/modplugin
Group refinement available 2.x.x email Use the update site http://iliasov.org/refplugin
Flows/Use case extension available 2.x.x email Use the update site http://iliasov.org/usecase
Prob eventb wiki logo.png ProB available 8th Feb. 2011 Use the ProB update site. http://www.stups.uni-duesseldorf.de/prob_updates
The Plug-in includes BMotion Studio
ProR logo.png ProR available 20th Jan. 2012 Michael Jastram ProR support working with requirements. For traceability to Event-B, the Rodin Integration is required.
Update site: http://update.pror.org
Project web site: http://eclipse.org/rmf
ProR logo.png Rodin Integration for ProR not available 28th Feb. 2012 Michael Jastram We are currently working on a revised ProR-Rodin-Integration.

*MCV stands for the Rodin's Maximum Compatible Version

Known plug-in incompatibilities

It unfortunately exists some incompatibilities between plug-ins. This list might be non exhaustive and is updated accorded to user experiences. If you encounter some conflict while installing or using plug-ins, please send a mail to the Rodin User List or feel free to complete the following table.

Plug-in name Incompatible with

Downloading

TODO: Add here a link to download the platform.

Fixed Bugs

TODO: Add here a list of the fixed bugs.

Known Issues

TODO: COPY KNOWN ISSUES FROM PREVIOUS PAGES / VERIFY
TODO: Add here a link to the SourceForge Bugs page, after filtering bugs (Assignee Any, Status Open, Category Any, Group 1.2).

About

Rodin Platform up to rxxxx
Developer Release date : dd/mm/yyyy.
User Release date : 28/01/2011.