Java-based implementation of the OMG SysML-Modelica Transformation (SyM) using MagicDraw SysML v18.v2 or more recent version, and OpenModelica 1.9.3
##Instructions to install and execute the roundtrip SysML-Modelica transformation
By Axel Reichwein, February 22, 2016
###Installing OpenModelica
- Install OpenModelicaCompiler 1.9.3. Install it under C:\ since there may be some problems if you install it somewhere else.
- Create the OPENMODELICA Environment variable if it has not been created through the installation of the OpenModelicaCompiler. On Windows 7, Start->Control Panel->System and Security-> Advanced System Settings->Environment Variables. Define OPENMODELICAHOME to point to drive:\path\to\your\OpenModelica-X.Y.Z\ (e.g. C:\OpenModelica1.9.3).
- Restart your computer.
###Launching MagicDraw with Modelica plugins
Overview: There are two usage modes to run the bidirectional SysML-Modelica transformations: user mode and developer mode.
- User mode allows to open MagicDraw and run the bidirectional SysML-Modelica transformations.
- Developer mode allows to launch MagicDraw and run the MagicDraw plugins from the Eclipse IDE. This is helpful to review, debug, and extend the source code of the MagicDraw plugins.
####User Mode
- Download and unzip the edu.gatech.mbsec.magicdraw.plugin.modelica2sysml.zip and edu.gatech.mbsec.magicdraw.plugin.sysml2modelica.zip files as folders. Click on Raw to download the files. Place the unzipped folders in the plugins folder of your MagicDraw installation directory (e.g. C:\Program Files\MagicDraw UML\plugins).
- Launch the MagicDraw application.
####Developer mode
The code of the MagicDraw plugin for the bidirectional SysML-Modelica transformation is within an Eclipse java project. A Java launch configuration will launch Magicdraw with the SysML-> Modelica and Modelica->SysML transformation plugins. All steps of the transformation can then be followed in the debug perspective of the Eclipse environment.
####1. Installing Eclipse
Install Eclipse. For example the Eclipse IDE for Java Developers package or the Eclipse IDE for Java EE Developers package).
####2. Downloading edu.gatech.mbse.mdsysmlmodelica repository
- Open the Git Repositories View (Window -> Show View -> type “Git Repositories” in the search field)
- Click on the Clone Repository icon
- In the URI field, paste the following URL: https://github.com/SysMLModelicaIntegration/edu.gatech.mbse.mdsysmlmodelica.git
- The Host and Repository fields will autofill.
- Click Next, select the magicdraw-v18.2 branch if you are using MagicDraw 18.2. Choose before-magicdraw-v18.2 branch if you are using a MagicDraw version older than 18.1.
- Click Next until Finish.
####3. Importing projects into the Eclipse workspace
- In the Git repositories view, right-click edu.gatech.mbse.mdsysmlmodelica and select “Import Projects”. Click Next until Finish
- The 2 projects are in the Eclipse workspace
####4. Configuring Java classpath
- It is necessary to specify the location of the MagicDraw jars. In Eclipse, open the Project Explorer view. (Window → Show View → Project Explorer). For both the edu.gatech.mbse.modelica2sysml and the edu.gatech.mbse.mdsysml2modelica projects, do the following:
- Expand the project
- Right-click on the resource named MAGIC_DRAW_INSTALL_DIRECTORY
- Edit the location of the linked resources to point to your MagicDraw installation directory (for example C:\Program Files\MagicDraw18-2)
####5. Configuring the launch configuration
- In Eclipse, open the Project Explorer view. (Window → Show View → Project Explorer). Expand the project edu.gatech.mbse.modelica2sysml
- Double-click on the resource named mdsysmlmodelica.launch
- Edit the before last line (line 19) to edit the md.plugins.dir Java system property (at the end of the long line) to refer to the location of your local edu.gatech.mbse.mdsysmlmodelica Git repository. (For example, if the Git repo is located on your file system at
C:\Users\Axel\git\edu.gatech.mbse.mdsysmlmodelica-feb19-2016, then edit the md.plugins.dir Java system property to refer to
C:\Users\Axel\git\edu.gatech.mbse.mdsysmlmodelica-feb19-2016. Make sure to carefully replace the default path location with your location while considering these rules:
- Make sure to include a double backslash for every slash in the path location (Example: "gitrepos\myrepo" -> "gitrepos\\myrepo")
- Make sure to include a semicolon (;) to separate your path entry from others and to include the following character sequence at the end of the md.plugins.dir Java system property value:
""/>
####6. Running MagicDraw with Modelica plugins Select the mdsysmlmodelica.launch launch configuration (Run -> Run Configurations… and select in the Java application category the launch configuration named mdsysmlmodelica.launch) and click Run.
- Download ModelicaImportTest.mdzip. Click on Raw to download the file.
- Also download the associated SysML4Modelica profile. Download sysml4modelicaprofile.mdzip. Click on Raw to download the file.
- 2 Options to import Modelica models into SysML
- Option A: Place the sysml4modelicaprofile.mdzip file in the same folder as the ModelicaImportTest.mdzip file. This is necessary as the ModelicaImportTest model refers to the sysml4modelicaprofile profile. Open the empty ModelicaImportTest.mdzip model.
- Option B: Create a new SysML project in MagicDraw with File->New Project-> Create SysML project. Click on the Options menu. Select “use Module”. Choose the SysML4Modelica profile. Click Next. In the field “Module Packages”, the SysML4Modelica package should be displayed. If yes, make sure that it is marked and click on “Finish”. This new empty SysML project with the SysML4Modelica profile as module should be saved. It can then be reused on future occasions as a MagicDraw project that is ready to directly import a Modelica model.
- You are now ready to import a Modelica model into the MagicDraw SysML project. Go on Data (right click)->Modelica to SysML->Import Modelica. Select the Modelica .mo file. Sample Modelica files such as TwoTankExample.mo, InverseModel.mo and fullRobot.mo can be found here
- After having imported a Modelica model into SysML, it is possible to automatically create the IBD. Select the Modelica class which contains connectors and then Right mouse->New Diagram->SysML Internal Block Diagram and then choose your favorite layout. Some manual refactoring will most likely still be necessary to make it look nice
After having imported a Modelica model into SysML, or once a SysML4Modelica model is available in MagicDraw, it can be exported into Modelica. Select “Data” or a Modelica package that should be exported and right click and select SysML to Modelica->Generate Modelica. The generated Modelica model will be located in the MagicDraw installation directory and be named “generated_Modelica.mo”. If the generated Modelica model is not visible in the MagicDraw installation directory, it may not have been be created because of user rights. Make sure to launch MagicDraw with administrator rights.