The other diagram types of SysML will be available in the next few releases of System Architect.
SysML metamodel
The SysML property set is a result of importing the OMG SysML XMI into System Architect’s metamodel structure. Property subsets and derived properties have been introduced to support newly required structures.
Classes have been mapped to definition types and the System Architect subtyping support extended to allow for multiple inheritance. Those SysML specializations which had isSubstitutable set to false merely copied properties from the source rather than becoming a subtype.
SysML Stereotypes
SysML Stereotypes provided in the XMI are supported through new definition types with a controlling property and the tab (or Chapter) containing properties only enabled if that controlling property is ticked. The definition types representing classes which could be assigned those stereotypes merely subtype those stereotype definition types. They have a Stereotype chapter containing a sorted list of these control properties. Users tick those that they want and press Apply to make the applicable Chapters (tabs) appear. Not all stereotypes add Chapters.
SysML and UML tab (Chapter) and property positioning
In SysML, where attributes have already been provided for a type from UML, System Architect provides SysML and UML suffixed Chapters of properties. All Chapters appear in a sequence according to the generalization structure with the Chapters for those classes which were most immediately inherited appearing first.
All properties appear in the sequence in which they were provided in the XMI. In SysML the UML attributes appear first. Any attribute that could reference another model element is assumed to be able to reference that definition type and any subtype in order to support use of specializations.
Property nomenclature
Properties prefixed ‘A_’ are those modeled by the OMG as association-owned. They had to be part of System Architect’s implementation due to the way they were linked with other properties through subset relationships. They have been made available rather than being hidden because they may prove useful for tracing relationships.
Object Constraint Language (OCL) properties
Properties that are based on OCL processing have been made available for update by users. System Architect has not implemented any rules or operations besides what items attributes can reference.
Model elements are keyed by their own GUID to allow same name
All model elements that you create are keyed by their own GUID to allow you to use the same name multiple times for a definition type, which is mandated by the SysML spec. System Architect will not currently allow unnamed items.
To allow you to differentiate between same-named artifacts of the same type, System Architect implements the property subtyping and through that, some items gain an owner indicator in the browser. This is not currently shown everywhere, so users, on encountering like-named artifacts with the same type, will have to use the Property Pane (View, Properties) or the Details function of Choices lists (right-mouse click in the Choices dialog, and choose Details) to show details to enable them to pick the proper item to distinguish from multiple definitions of same type and same name.
Diagram support
Diagram borders are not provided but they can be added manually if required through the Picture or Rectangle and Text symbols.
Modeling structures were mapped to either implicit references where a line represents a single reference of a definition, or where a line represents two references of a definition; to the source or target. Where this was not possible, Explorer Relationships have been used.
Drawing relationship lines
Most line connections, such as associations, are drawn by creating an association node and then drawing lines representing the association members.
For example, to create an Association between Class A and Class B, you create AssociationNode A-B, and then model an AssociationNode to Class as Property relationship from the Association to the class you want the property to reference.
class A Association A-B class B
If you draw from the association to B you are indicating that you want to create a property in either the association or class A.
Then you edit either the property or the intended owner and set ownership
▪Property:class / owningAssociation
▪Class:ownedAttribute / Association:ownedEnd
Further details are provided in the help for each relationship type: