CrossSubsetting

CrossSubsetting is defined in SysML specification on page 0. Excerpt from the machine readable specification:

CrossSubsetting is a kind of Subsetting for end Features, as identified by crossingFeature, to subset a chained Feature, identified by crossedFeature. It navigates to instances of the end Feature’s type from instances of other end Feature types on the same owningType (at least two end Features are required for any of them to have a CrossSubsetting).

The crossedFeature of a CrossSubsetting must have a feature chain of exactly two Features. The second Feature in the chain is the crossFeature of the crossingFeature (end Feature), which has the same type as the crossingFeature. When the owningType of the crossingFeature has exactly two end Features, the first Feature in the chain of the crossedFeature is the other end Feature. The crossFeature’s featuringType in this case is the other end Feature. When the owningType has more than two end Features, the first Feature in the chain is a Feature that CrossMultiplies all the other end Features, which is also the featuringType of the crossFeature.

A crossFeature must be owned by its featureCrossing (end Feature) when the featureCrossing owningType has more than two end Features. Otherwise, for exactly two end Features, the crossFeatures of each the ends can instead optionally be inherited by the other end from one of its types or a subsetted Feature.

The following diagram shows the inheritance hierarchy of CrossSubsetting according to the specification:

// Class: CrossSubsetting
 digraph {
     CrossSubsetting [label="CrossSubsetting (SysML)" shape=plaintext]
     Subsetting -> CrossSubsetting
     Subsetting [label="Subsetting (KerML)" shape=plaintext]
     Specialization -> Subsetting
     Specialization [label="Specialization (KerML)" shape=plaintext]
     Relationship -> Specialization
     Relationship [label="Relationship (KerML)" shape=plaintext]
     Element -> Relationship
     Element [label="Element (KerML)" shape=plaintext]
 }

The following table shows all attributes defined for CrossSubsetting according to the specification together with the documentation from the machine readable specification. Note that in SysIDE API, we use snake case for attribute names instead of Pascal case used in the specification.

Attribute

Documentation from machine readable specification

Attributes defined in CrossSubsetting:

crossed_feature

The chained Feature that is cross subset by the crossingFeature of this CrossSubsetting.

crossing_feature

The end Feature that owns this CrossSubsetting relationship and is also its subsettingFeature.

Attributes defined in Subsetting:

owning_feature

A subsettingFeature that is also the owningRelatedElement of this Subsetting.

subsetted_feature

The Feature that is subsetted by the subsettingFeature of this Subsetting.

subsetting_feature

The Feature that is a subset of the subsettedFeature of this Subsetting.

Attributes defined in Specialization:

general

A Type with a superset of all instances of the specific Type, which might be the same set.

owning_type

The Type that is the specific Type of this Specialization and owns it as its owningRelatedElement.

specific

A Type with a subset of all instances of the general Type, which might be the same set.

Attributes defined in Relationship:

is_implied

Whether this Relationship was generated by tooling to meet semantic rules, rather than being directly created by a modeler.

owned_related_elements

The relatedElements of this Relationship that are owned by the Relationship.

owning_related_element

The relatedElement of this Relationship that owns the Relationship, if any.

related_elements

The Elements that are related by this Relationship, derived as the union of the source and target Elements of the Relationship.

sources

The relatedElements from which this Relationship is considered to be directed.

targets

The relatedElements to which this Relationship is considered to be directed.

Attributes defined in Element:

declared_name

The declared name of this Element.

declared_short_name

An optional alternative name for the Element that is intended to be shorter or in some way more succinct than its primary name. It may act as a modeler-specified identifier for the Element, though it is then the responsibility of the modeler to maintain the uniqueness of this identifier within a model or relative to some other context.

documentation

The Documentation owned by this Element.

element_id

The globally unique identifier for this Element. This is intended to be set by tooling, and it must not change during the lifetime of the Element.

is_implied_included

Whether all necessary implied Relationships have been included in the ownedRelationships of this Element. This property may be true, even if there are not actually any ownedRelationships with isImplied = true, meaning that no such Relationships are actually implied for this Element. However, if it is false, then ownedRelationships may not contain any implied Relationships. That is, either all required implied Relationships must be included, or none of them.

is_library_element

Whether this Element is contained in the ownership tree of a library model.

name

The name to be used for this Element during name resolution within its owningNamespace. This is derived using the effectiveName() operation. By default, it is the same as the declaredName, but this is overridden for certain kinds of Elements to compute a name even when the declaredName is null.

owned_annotations

The ownedRelationships of this Element that are Annotations, for which this Element is the annotatedElement.

owned_elements

The Elements owned by this Element, derived as the ownedRelatedElements of the ownedRelationships of this Element.

owned_relationships

The Relationships for which this Element is the owningRelatedElement.

owner

The owner of this Element, derived as the owningRelatedElement of the owningRelationship of this Element, if any.

owning_membership

The owningRelationship of this Element, if that Relationship is a Membership.

owning_namespace

The Namespace that owns this Element, which is the membershipOwningNamespace of the owningMembership of this Element, if any.

owning_relationship

The Relationship for which this Element is an ownedRelatedElement, if any.

qualified_name

The full ownership-qualified name of this Element, represented in a form that is valid according to the KerML textual concrete syntax for qualified names (including use of unrestricted name notation and escaped characters, as necessary). The qualifiedName is null if this Element has no owningNamespace or if there is not a complete ownership chain of named Namespaces from a root Namespace to this Element.

short_name

The short name to be used for this Element during name resolution within its owningNamespace. This is derived using the effectiveShortName() operation. By default, it is the same as the declaredShortName, but this is overridden for certain kinds of Elements to compute a shortName even when the declaredName is null.

textual_representations

The TextualRepresentations that annotate this Element.

The following table lists SysIDE specific attributes available for class CrossSubsetting:

class CrossSubsetting
__cpp_name__: str = 'syside::sysml::CrossSubsetting'
STD: tuple[type[syside.CrossSubsetting], ...] = ()
CHAINABLE: bool = True
property crossed_feature: syside.Feature | None
property crossing_feature: syside.Feature | None
property crossed_feature_target: syside.ChainedFeatureReference
property crossing_feature_target: syside.ChainedFeatureReference