Skip to end of metadata
Go to start of metadata

You are viewing an old version of this page. View the current version.

Compare with Current View Page History

« Previous Version 2 Next »

This section presents details of drag-n-drop operations for NX models in local file system or Teamcenter. The following scenarios are presented in a step-by-step manner:

  • Generating SysML block structure from NX CAD assembly structure
  • Generating NX CAD part with features from SysML block structure

The capabilities presented in this section require the NX license feature for Syndeia.

Generate SysML block structure from NX CAD assembly structure

The process of generating SysML models from NX CAD assembly structure follows the common drag-n-drop pattern in Syndeia. Follow the instructions below to generate SysML block structure from NX CAD assembly structure or a piece part. 

The NX CAD model used in this illustration is the Toycar model that is available with NX installation. It is located under:
<NX_Installation>\ UGOPEN\SampleNXOpenApplications\Java\parts, e.g.
C:\Program Files\Siemens\NX 9.0\UGOPEN\SampleNXOpenApplications\Java\parts

  1. Create a new Rhapsody project. Add the Syndeia profile to your SysML model, as shown in Section 2.1.
  2. Launch the Syndeia Dashboard and access the NX CAD model (.prt) file, using a repository link pointing to the section of your local file system where the CAD model is located (see Section 2.1 for adding a repository link).
  3. Expand the prt file to view the NX model structure. This will initialize a NX session if this is the first time you are accessing NX models after creating/opening your SysML project. Once the NX session is initialized, you will see an assembly icon (for NX assemblies) or a part icon (for NX piece parts) under the prt file, as shown for the toycar_assy assembly model under toycar_assy.prt file in Figure 108 below.

     

    Figure 108: NX model loads when a NX prt file is expanded

  4. Expand the NX model to view the assembly structure, as shown in Figure 109. You can also expand any other NX prt file to view the part/assembly structure, as shown for the toycar_axle_assy.prt file below. You can right-click the prt file or the NX CAD model in the RHS pane and select Open, as show in Figure 110 below. This will open the CAD model in NX, as shown in Figure 111 below.

     

    Figure 109: Expand the NX model to view the assembly structure

     

    Figure 110: Right click on the prt file or NX model and select Open

     

    Figure 111: Syndeia opens the NX CAD model from the Dashboard

     
  5. Go to Settings tab on Syndeia dashboard and uncheck Get features of NX parts option, as shown in Figure 112 below. Click Apply. This prevents part features with invalid names from creating problems in the Rhapsody SysML model.

     

    Figure 112: Turn off Get features of NX parts option in Syndeia dashboard, Settings tab
     
  6. Return to the Connection Manager tab (make sure you clicked Apply on the Settings tab). Select Model Transform connection type in the middle panel and drag and drop the NX model (e.g. toycar_assy) from the RHS pane to a SysML package on the LHS pane, as shown in Figure 113.

     

    Figure 113: Drag and drop the NX model to a SysML package 
     
  7. Select Yes at the prompt.

     

    Figure 114: Select Yes to confirm generation of SysML block structure from NX assembly structure 

  8. This will generate a SysML block structure from NX assembly structure, as shown in Figure 115 below. Notice the generation of block value properties and part properties corresponding to mass properties and assembly components respectively in the CAD model.



    Figure 115: SysML block structure generated (LHS) from the NX model structure (RHS)
     
  9. Create a SysML block diagram in Rhapsody and drag and drop the blocks generated in the previous step to the diagram and expose all the parts (as association ends) and values (as attributes) of the toycar_assy block, as shown in Figure 116 below. Now, you can see the details of the block structure generated from NX assembly structure by Syndeia. The toycar_assy block has 4 part properties—3 shown in the parts compartment and 1 shown in an expanded form (FRONT_AXLE). The semantic mapping from NX CAD assembly structure to SysML block structure is as follows:

    • NX part or assembly -> SysML block
    • NX part or assembly mass properties -> SysML block attributes
    • NX assembly component -> SysML block part property with an association block
    • NX part feature -> SysML block and part property (optional)
    • NX feature expression -> SysML value property (optional)

       

      Figure 116: SysML BDD showing the block structure generated from NX assembly structure 

    Syndeia generates a SysML block corresponding to every NX CAD part or sub-assembly in the root assembly structure. It applies the NX_Part stereotype to identify NX parts (piece parts or assemblies) and sets the base unit for the part (e.g. mm) in the unit stereotype tag. The mass properties of the part or assembly are generated as attributes. This includes mass, volume, density, surface area, center of gravity, and the coordinates of the lower left corner and upper right corner of the geometric bounding box of that part/assembly). 

    Figure 117: Model browser after model transform

    Figure 118: Association block attributes for toycar – body association (BODY)


    A CAD assembly is made of up of components, each of which are usages of a part (or sub-assembly) in the context of that assembly. Syndeia generates two important elements for assembly components. First, it creates an Association relationship (FRONT_AXLE) from the parent assembly block (toycar_assy) to the child part or sub-assembly block (toycar_axle_assy). Syndeia applies the NX_Component stereotype to the association, as shown in Figure 117. Second, it creates an association block as part of the association, where Syndeia stores information regarding the placement of the component in the assembly. The transformation from the child part (or sub-assembly) co-ordinate system to the parent assembly (or global) co-ordinate system is expressed in terms of a translation vector and a 3x3 rotation matrix, as shown in Figure 118. 

     
  10. Similar to all drag and drop operations, Syndeia generates connections between SysML blocks and the NX CAD parts/assemblies. These connections are stored in the SysML model. You can view the connections organized by the SysML model in the Connection Browser tab or as a flat list in the Connection Summary tab, as shown in Figure 119 below. Users can invoke compare and sync operations by right clicking on one or more connections.

     

    Figure 119: Invoke SysML-NX compare and sync operations using connections generated by Syndeia 

Currently, the following are supported in the compare and sync operations.

  • Compare only compares the mass properties between the SysML blocks and NX parts/assemblies.
  • Sync from Target > SysML only updates the mass properties in the SysML block from the NX part/assembly
  • Sync SysML > Target is not supported. This use case is not a high priority for system engineers since they usually do not modify existing CAD models directly. Mass properties in a CAD model are computed from the geometry and hence they are read-only properties.

Generate NX CAD part with features from a SysML block structure

Syndeia can also seed NX CAD models from SysML block structures. This is very useful for enabling model-based communication between system engineers and mechanical/electrical designers during early phases of system development. This enables system engineers to enrich the representation of system-level geometric requirements and pass them to the mechanical designers by seeding CAD models with features corresponding to those requirements, such as the desired boundaries of an assembly, max/min distance between parts, keep-out zones around parts and assemblies, and desired center-of-gravity location.

The SysML model used in these instructions is the My System Part Features model included in the Syndeia plugin installation at <Syndeia_Installation_Folder> \models. The resulting NX CAD model is also included in <Syndeia_Installation_Folder> \models.

The process of generating a NX CAD model from a SysML model follows the common pattern of drag-n-drop operations in Syndeia. Follow the instructions below. First, the instructions show the mechanics of generating a NX CAD model with features from the given My System Part Features SysML model. Then, the instructions present the general rules for creating your own SysML model for generate NX CAD models.

  1. Open the MySystemPartFeatures model in Rhapsody. Open the Part feature decomposition BDD under the Part package, as shown in Figure 120 below.
  2. Right click on the Part package in the SysML model containment tree and select Syndeia > Dashboard menu. This will launch the Syndeia dashboard. Go to the Connection Manager tab, as shown in Figure 121 below.


    Figure 120: SysML block structure with feature definitions for generating NX CAD model with features


    Figure 121: Drag SysML block with feature definitions (LHS) to a folder (RHS) to generate NX CAD model
     
  3. In the Syndeia dashboard, select the connection type in the middle panel as Model Transform and drag-n-drop the My_System block from the SysML tree (LHS) to a folder on your local file system (RHS), as shown Figure 121.
     
  4. Select the option to Generate NX CAD model in the dialog box, as shown in Figure 122 below, and then click Yes to generate the NX CAD model, as shown in Figure 123.

     
    Figure 122: Select option to generate NX CAD model


    Figure 123: Click Yes to generate NX CAD model
     
  5. This will generate a NX CAD model with the same name as the SysML block (e.g. My_System), as shown in Figure 124 below.

     
    Figure 124: NX CAD model My_System generated from SysML block structure 
     
  6. Right click on the My_System.prt file or My_System NX model in the Syndeia dashboard and select Open. This will open the CAD model in NX, as shown in Figure 125 below. Note that 7 features have been generated in NX (as highlighted) from the 7 feature definitions in the SysML block structure (Figure 120). The part property names for the feature definitions in the SysML model have been used to name the features in the NX CAD model, e.g. "itsSphere" for the Sphere feature used in My_System.

     
    Figure 125: Open NX CAD model from the Syndeia Dashboard 
     
  7. Follow the general rules below to create your own SysML model for generating NX CAD parts with features. These rules are also mentioned in a note form in the SysML BDD Part::Part feature decomposition in the My System Part Features SysML model. 

  8. Define a block to represent the parent part. Apply the NX_Part stereotype to this block and populate the unit tag, as shown in Figure 126 below (allowable values are mm and inch). The units apply to everything in the part, including computed parameters such as volume and bounding box.

     
    Figure 126: Populate the unit tag of the NX_Part stereotype to specify the base units for the NX part 
     

  9. Create blocks to represent the primitive features. Allowable names are - Point, Line, Plane, Cuboid, Cone, Cylinder, and Sphere. Apply the NX_Part_Feature stereotype to these blocks, as shown in Figure 120.
  10. Create and populate (default value) the value properties of the feature blocks, as shown in Figure 120. The names of value properties for the feature blocks must be exactly same as in the My_System_PartFeatures model (Figure 120).

    For steps 2-3 above, it is recommended that you copy the feature blocks in the example model My_System_Part_Features in your own SysML model and then modify the value properties for the feature parameters, as needed. 
     
  11. Create part properties (composition relationships) from the parent part block to the feature blocks, as shown in the My_System_Part_Features model (Figure 120).
  12. Name the part properties with names that are relevant to your domain. These names will be used to set the feature names in the NX CAD model, as shown in Figure 125.


  • No labels