SysML v2 Views

SysML v2 views let you define which elements to include in a diagram and how to render them. A view selects elements using expose statements and optionally narrows the results with filter expressions. Rendering options such as layout style and depth are controlled through attributes on each view.

Views work in both Modeler and Modeler CLI.

package MyViews {
    private import Views::asTreeDiagram;

    part def SystemViews {
        view customDroneView {
            expose DroneModel::DroneSystem::myDrone;
            filter @ SysML::PartUsage;

            attribute depth = 2;
            render asTreeDiagram;
        }
    }
}

This view exposes the myDrone element and filters its contents to show only elements which have metadata of type SysML::PartUsage. The @ operator includes subtypes, which may return more results than expected. See Understanding Filters below for details.

Configurable Attributes

The following attributes can be set on each view:

Attribute

Default

Scope

Description

depth

1

Both 1

How many levels of descendants to show. -1 for infinite depth

render

Nested Diagram

Both 1

Layout style. Use render asTreeDiagram (from Views::asTreeDiagram) for tree layout. Omit for nested

fileType

SVG

CLI 2

Output format: PNG, SVG, or PDF. If both fileType and fileName are set, fileType determines the output format

fileName

diagram-${self.name}

CLI 2

Output file name

zoomLevel

3.0

CLI 2

Zoom level for rendering. Applicable only to PNG output

1 Applicable to both Modeler and Modeler CLI.
2 Applicable to Modeler CLI only. These attributes are used for file-based diagram export.

Understanding Filters

A filter expression inside a view narrows the exposed elements to only those that match a condition. Filters can test an element’s type using classification operators defined in the KerML specification (see section 7.4.9.2). For example, filter @ SysML::PartUsage checks each exposed element and keeps only those whose type matches PartUsage.

There are four classification operators:

  • @at least one classification matches (includes subtypes). Returns false on null.

  • istypeall classifications must match (includes subtypes). Returns true on null.

  • hastypeall classifications must match (exact type only, no subtypes). Returns true on null.

  • as (cast) — selects values classified by the given type. Useful for accessing metadata attributes in filter expressions.

Consider the following model. It uses the standard library’s RiskMetadata package and a custom FlightCritical metadata tag:

package FilterExample {
    private import RiskMetadata::*;
    metadata def FlightCritical;

    part def DroneSystem {
        part sensor;
        #FlightCritical part controller;
        part camera { @Risk { technicalRisk = RiskLevelEnum::high; } }
        part radio { @Risk { technicalRisk = RiskLevelEnum::medium; } }
        #FlightCritical part battery { @Risk { technicalRisk = RiskLevelEnum::low; } }

        action processData;
        connection dataLink connect sensor to controller;
        allocate processData to controller;
        connect camera to controller;
    }
}

Applying different filters to expose DroneSystem::* produces different results:

Filter

Matches

@ SysML::PartUsage

sensor, controller, camera, radio, battery, dataLink, allocate *, connect *

istype SysML::PartUsage

sensor, dataLink, allocate *, connect *

hastype SysML::PartUsage

sensor

(as Risk).technicalRisk == RiskLevelEnum::high

camera

(as SysML::PartUsage) hastype SysML::PartUsage

sensor, controller, camera, radio, battery

* Unnamed elements created by allocate and connect statements.

The sections below explain why each filter returns what it does.

Matching types and subtypes

filter @ SysML::PartUsage selects every element whose type is PartUsage or any of its specializations. In SysML v2, several usage types specialize PartUsage, including ConnectionUsage and AllocationUsage. This means a view that filters for parts will also include connections and allocations, as shown in the table above.

Note

This is standard SysML v2 behavior, not specific to Syside. The SysML v2 spec (section 7.26.2) uses filter @SysML::PartUsage in its view examples, so users naturally reach for it first. Be aware of the subtype-inclusive semantics.

istype works the same way but with a stricter condition: @ requires at least one of the element’s classifications to match, while istype requires all of them to match. In practice, this means istype fails on elements with metadata annotations (e.g., #FlightCritical part controller), while @ still matches them.

Matching exact types

filter hastype SysML::PartUsage selects only elements whose declared type is exactly PartUsage, excluding specializations. It also fails on elements with metadata annotations, just like istype.

In the model above, only sensor matches because it is the only part with no metadata and no subtype classification.

Warning

Both hastype and istype fail on elements with metadata annotations (e.g., #FlightCritical part controller). Use @ if metadata is present and you don’t need exact type matching.

Accessing metadata attributes

as casts the element to a metadata type, allowing you to access its attributes in filter expressions:

filter (as Risk).technicalRisk == RiskLevelEnum::high;

This casts each element to the Risk metadata type, then checks the technicalRisk attribute. When elements carry multiple metadata annotations, as ensures the attribute is evaluated on the correct type.

For a complete example of metadata-based filtering, see the Filter Evaluation example.

Combining operators

To filter for an exact type while still matching elements with metadata, combine as with hastype:

filter (as SysML::PartUsage) hastype SysML::PartUsage;

The as cast isolates the PartUsage classification, and hastype checks that it is exactly PartUsage, not a subtype. This returns all five parts regardless of metadata, while keeping connections and allocations out.

Tip

Start with hastype for precise filtering, then broaden to @ if you need subtypes included.