Structure of Application Protocols
AP-238 describes the STEP-NC application interpreted model (AIM) for the application reference model (ARM) defined by ISO 14649-10, 11, 12, 111 and 121, augmented with ISO 10303 product geometry, geometric dimensioning and tolerancing, and product data management information. The AIM is for implementations, and the ARM is for understanding the meaning. This two-level approach lets the people document the information requirements clearly in the ARM, while the actual data is represented by the AIM in an extensible way that remains stable across APs and handles aspects of a product never considered by the folks who made the ARM.
In the AP document, clause 4 defines the ARM "units of functionality" which are groups of information requirements described as application objects. The application objects describing the machining process are referenced from ISO 14649 while the STEP-specific things like GD&T, Features, and PDM are defined in clause 4 or referenced from the common STEP Module and Resource Library (SMRL). In some cases we extend some of the definitions with additional information for harmonization purposes.
The AIM is defined by the mapping tables in clause 5. As you look through these tables, you will see reference paths that show how ARM concepts are represented by a collection of AIM objects. So you will refer to the ARM descriptions to understand what is in the AP, and the AIM descriptions to understand how it is represented and exchanged by implementations.
The short and long form EXPRESS schemas for the AIM give you the structures used by the mapping tables. The short form schema only contains the new subtypes of existing integrated resources. APs are allowed to create subtypes for clarity, but they are not allowed to add any new attributes or create new top-level entities. The long form EXPRESS contains all of the definitions required to work with the AP-238 AIM.
Many of the sample data files have been organized and commented to show the relationship between ARM concepts and the underlying AIM data instances. For example, a workplan and machining workingstep may appear as follows:
/************************************************ * Application object: WORKPLAN (#34597) * ITS_ELEMENTS [1]: #34597, #34598, #34608, ['machining_workingstep'] * ITS_ELEMENTS [2]: #34597, #34599, #35301, ['machining_workingstep'] * ITS_ELEMENTS [3]: #34597, #34600, #36105, ['machining_workingstep'] * ITS_ELEMENTS [4]: #34597, #34601, #37196, ['machining_workingstep'] * ITS_ELEMENTS [5]: #34597, #34602, #37296, ['machining_workingstep'] * ITS_ELEMENTS [6]: #34597, #34603, #37388, ['machining_workingstep'] * TO_BE_GEOMETRY: #34597, #34604, #34605, #56486 * ITS_ID: #34597, ['Stage_2'] * AS_IS_GEOMETRY: #34597, #34606, #34607, #16975 */ #34597=MACHINING_WORKPLAN('Stage_2','','',''); #34598=MACHINING_PROCESS_SEQUENCE_RELATIONSHIP('','',#34597,#34608,1.); #34599=MACHINING_PROCESS_SEQUENCE_RELATIONSHIP('','',#34597,#35301,2.); #34600=MACHINING_PROCESS_SEQUENCE_RELATIONSHIP('','',#34597,#36105,3.); #34601=MACHINING_PROCESS_SEQUENCE_RELATIONSHIP('','',#34597,#37196,4.); #34602=MACHINING_PROCESS_SEQUENCE_RELATIONSHIP('','',#34597,#37296,5.); #34603=MACHINING_PROCESS_SEQUENCE_RELATIONSHIP('','',#34597,#37388,6.); #34604=PRODUCT_DEFINITION_PROCESS('to-be shape','',#34597,''); #34605=PROCESS_PRODUCT_ASSOCIATION('','',#56486,#34604); #34606=PRODUCT_DEFINITION_PROCESS('as-is shape','',#34597,''); #34607=PROCESS_PRODUCT_ASSOCIATION('','',#16975,#34606); /************************************************ * Application object: MACHINING_WORKINGSTEP (#34608) * ITS_OPERATION: #34608, #34609, #34657 * ITS_ID: #34608, ['R_CLOSED_POCKET_2'] * ITS_FEATURE: #34608, #34610, #34611, #34612, #34613, #34691 */ #34608=MACHINING_WORKINGSTEP('R_CLOSED_POCKET_2','machining','',''); #34609=MACHINING_OPERATION_RELATIONSHIP('','machining',#34608,#34657); #34610=MACHINING_FEATURE_RELATIONSHIP('','machining',#34608,#34611); #34611=MACHINING_FEATURE_PROCESS('','machining','',''); #34612=PROPERTY_PROCESS('machining','machining',#34611,''); #34613=PROCESS_PROPERTY_ASSOCIATION('','machining',#34612,#34691);