IfcOpeningElement

Natural language names
deÖffnung
enOpening Element
frOuverture
Change log
ItemSPFXMLChangeDescription
IFC2x3 to IFC4
    IfcOpeningElement
      OwnerHistoryMODIFIEDInstantiation changed to OPTIONAL.
      PredefinedTypeADDED
IFC4 Addendum 1
    IfcOpeningElement
      HasCoveringsADDED
Semantic definitions at the entity
Entity definition

The opening element stands for opening, recess or chase, all reflecting voids. It represents a void within any element that has physical manifestation. Openings can be inserted into walls, slabs, beams, columns, or other elements.

The IFC specification provides two entities for opening elements:

NOTE  View definitions or implementer agreements may restrict the types of elements which can be voided by an IfcOpeningElement or IfcOpeningStandardCase

There are two different types of opening elements:

The attribute PredefinedType should be used to capture the differences,

An IfcOpeningElement has to be inserted into an IfcElement by using the IfcRelVoidsElement relationship. The relationship implies a Boolean subtraction operation between the volume of the voided element and the volume of the opening. It may be filled by an IfcDoor, IfcWindow, or another filling element by using the relationship IfcRelFillsElements.

The IfcOpeningElement shall not participate in the containment relationship, i.e. it is not linked directly to the spatial structure of the project. It has a mandatory VoidsElements inverse relationship pointing to the IfcElement that is contained in the spatial structure.

NOTE  See IfcRelVoidsElement for a diagram on how to apply spatial containment and the voiding relationship.
HISTORY  New entity in IFC1.0
IFC2x CHANGE  The intermediate ABSTRACT supertypes IfcFeatureElement and IfcFeatureSubtraction have been added.
IFC4 CHANGE  The attribute PredefinedType has been added at the end of attribute list. It should be used instead of the inherited attribute ObjectType from now on.
Attribute definitions
#AttributeTypeCardinalityDescription C
9PredefinedTypeIfcOpeningElementTypeEnum[0:1] Predefined generic type for an opening that is specified in an enumeration. There may be a property set given specificly for the predefined types. X
HasFillingsIfcRelFillsElement
@RelatingOpeningElement
S[0:?]Reference to the Filling Relationship that is used to assign Elements as Fillings for this Opening Element. The Opening Element can be filled with zero-to-many Elements. X
Inherited definitions from supertypes
Entity inheritance IfcOpeningStandardCase IfcFeatureElementSubtraction IfcFeatureElement IfcElement IfcProduct IfcObject IfcObjectDefinition IfcRoot
Attribute inheritance
#AttributeTypeCardinalityDescriptionC
IfcRoot
1GlobalIdIfcGloballyUniqueId[1:1] Assignment of a globally unique identifier within the entire software world. X
2OwnerHistoryIfcOwnerHistory[0:1] Assignment of the information about the current ownership of that object, including owning actor, application, local identification and information captured about the recent changes of the object,
NOTE  only the last modification in stored - either as addition, deletion or modification.
X
3NameIfcLabel[0:1] Optional name for use by the participating software systems or users. For some subtypes of IfcRoot the insertion of the Name attribute may be required. This would be enforced by a where rule. X
4DescriptionIfcText[0:1] Optional description, provided for exchanging informative comments.X
IfcObjectDefinition
HasAssignmentsIfcRelAssigns
@RelatedObjects
S[0:?]Reference to the relationship objects, that assign (by an association relationship) other subtypes of IfcObject to this object instance. Examples are the association to products, processes, controls, resources or groups.X
NestsIfcRelNests
@RelatedObjects
S[0:1]References to the decomposition relationship being a nesting. It determines that this object definition is a part within an ordered whole/part decomposition relationship. An object occurrence or type can only be part of a single decomposition (to allow hierarchical strutures only). X
IsNestedByIfcRelNests
@RelatingObject
S[0:?]References to the decomposition relationship being a nesting. It determines that this object definition is the whole within an ordered whole/part decomposition relationship. An object or object type can be nested by several other objects (occurrences or types). X
HasContextIfcRelDeclares
@RelatedDefinitions
S[0:1]References to the context providing context information such as project unit or representation context. It should only be asserted for the uppermost non-spatial object. X
IsDecomposedByIfcRelAggregates
@RelatingObject
S[0:?]References to the decomposition relationship being an aggregation. It determines that this object definition is whole within an unordered whole/part decomposition relationship. An object definitions can be aggregated by several other objects (occurrences or parts). X
DecomposesIfcRelAggregates
@RelatedObjects
S[0:1]References to the decomposition relationship being an aggregation. It determines that this object definition is a part within an unordered whole/part decomposition relationship. An object definitions can only be part of a single decomposition (to allow hierarchical strutures only). X
HasAssociationsIfcRelAssociates
@RelatedObjects
S[0:?]Reference to the relationship objects, that associates external references or other resource definitions to the object.. Examples are the association to library, documentation or classification.X
IfcObject
5ObjectTypeIfcLabel[0:1] The type denotes a particular type that indicates the object further. The use has to be established at the level of instantiable subtypes. In particular it holds the user defined type, if the enumeration of the attribute PredefinedType is set to USERDEFINED.
X
IsDeclaredByIfcRelDefinesByObject
@RelatedObjects
S[0:1]Link to the relationship object pointing to the declaring object that provides the object definitions for this object occurrence. The declaring object has to be part of an object type decomposition. The associated IfcObject, or its subtypes, contains the specific information (as part of a type, or style, definition), that is common to all reflected instances of the declaring IfcObject, or its subtypes. X
DeclaresIfcRelDefinesByObject
@RelatingObject
S[0:?]Link to the relationship object pointing to the reflected object(s) that receives the object definitions. The reflected object has to be part of an object occurrence decomposition. The associated IfcObject, or its subtypes, provides the specific information (as part of a type, or style, definition), that is common to all reflected instances of the declaring IfcObject, or its subtypes. X
IsTypedByIfcRelDefinesByType
@RelatedObjects
S[0:1]Set of relationships to the object type that provides the type definitions for this object occurrence. The then associated IfcTypeObject, or its subtypes, contains the specific information (or type, or style), that is common to all instances of IfcObject, or its subtypes, referring to the same type. X
IsDefinedByIfcRelDefinesByProperties
@RelatedObjects
S[0:?]Set of relationships to property set definitions attached to this object. Those statically or dynamically defined properties contain alphanumeric information content that further defines the object. X
IfcProduct
6ObjectPlacementIfcObjectPlacement[0:1] Placement of the product in space, the placement can either be absolute (relative to the world coordinate system), relative (relative to the object placement of another product), or constraint (e.g. relative to grid axes). It is determined by the various subtypes of IfcObjectPlacement, which includes the axis placement information to determine the transformation for the object coordinate system.X
7RepresentationIfcProductRepresentation[0:1] Reference to the representations of the product, being either a representation (IfcProductRepresentation) or as a special case a shape representations (IfcProductDefinitionShape). The product definition shape provides for multiple geometric representations of the shape property of the object within the same object coordinate system, defined by the object placement.X
ReferencedByIfcRelAssignsToProduct
@RelatingProduct
S[0:?]Reference to the IfcRelAssignsToProduct relationship, by which other products, processes, controls, resources or actors (as subtypes of IfcObjectDefinition) can be related to this product.X
IfcElement
8TagIfcIdentifier[0:1] The tag (or label) identifier at the particular instance of a product, e.g. the serial number, or the position number. It is the identifier at the occurrence level.X
FillsVoidsIfcRelFillsElement
@RelatedBuildingElement
S[0:1]Reference to the IfcRelFillsElement Relationship that puts the element as a filling into the opening created within another element. X
ConnectedToIfcRelConnectsElements
@RelatingElement
S[0:?]Reference to the element connection relationship. The relationship then refers to the other element to which this element is connected to. X
IsInterferedByElementsIfcRelInterferesElements
@RelatedElement
S[0:?]Reference to the interference relationship to indicate the element that is interfered. The relationship, if provided, indicates that this element has an interference with one or many other elements.
NOTE  There is no indication of precedence between IsInterferedByElements and InterferesElements.
X
InterferesElementsIfcRelInterferesElements
@RelatingElement
S[0:?]Reference to the interference relationship to indicate the element that interferes. The relationship, if provided, indicates that this element has an interference with one or many other elements.
NOTE  There is no indication of precedence between IsInterferedByElements and InterferesElements.
X
HasProjectionsIfcRelProjectsElement
@RelatingElement
S[0:?]Projection relationship that adds a feature (using a Boolean union) to the IfcBuildingElement.X
ReferencedInStructuresIfcRelReferencedInSpatialStructure
@RelatedElements
S[0:?]Reference relationship to the spatial structure element, to which the element is additionally associated. This relationship may not be hierarchical, an element may be referenced by zero, one or many spatial structure elements. X
HasOpeningsIfcRelVoidsElement
@RelatingBuildingElement
S[0:?]Reference to the IfcRelVoidsElement relationship that creates an opening in an element. An element can incorporate zero-to-many openings. For each opening, that voids the element, a new relationship IfcRelVoidsElement is generated. X
IsConnectionRealizationIfcRelConnectsWithRealizingElements
@RealizingElements
S[0:?]Reference to the connection relationship with realizing element. The relationship, if provided, assigns this element as the realizing element to the connection, which provides the physical manifestation of the connection relationship. X
ProvidesBoundariesIfcRelSpaceBoundary
@RelatedBuildingElement
S[0:?]Reference to space boundaries by virtue of the objectified relationship IfcRelSpaceBoundary. It defines the concept of an element bounding spaces. X
ConnectedFromIfcRelConnectsElements
@RelatedElement
S[0:?]Reference to the element connection relationship. The relationship then refers to the other element that is connected to this element. X
ContainedInStructureIfcRelContainedInSpatialStructure
@RelatedElements
S[0:1]Containment relationship to the spatial structure element, to which the element is primarily associated. This containment relationship has to be hierachical, i.e. an element may only be assigned directly to zero or one spatial structure. X
HasCoveringsIfcRelCoversBldgElements
@RelatingBuildingElement
S[0:?]Reference to IfcCovering by virtue of the objectified relationship IfcRelCoversBldgElement. It defines the concept of an element having coverings associated.X
IfcFeatureElement
IfcFeatureElementSubtraction
VoidsElementsIfcRelVoidsElement
@RelatedOpeningElement
[1:1]Reference to the Voids Relationship that uses this Opening Element to create a void within an Element. The Opening Element can only be used to create a single void within a single Element. X
IfcOpeningElement
9PredefinedTypeIfcOpeningElementTypeEnum[0:1] Predefined generic type for an opening that is specified in an enumeration. There may be a property set given specificly for the predefined types. X
HasFillingsIfcRelFillsElement
@RelatingOpeningElement
S[0:?]Reference to the Filling Relationship that is used to assign Elements as Fillings for this Opening Element. The Opening Element can be filled with zero-to-many Elements. X
Definitions applying to Common Use Definitions

 Instance diagram


Concept usage

Property Sets for Objects

The Property Sets for Objects concept applies to this entity as shown in Table 54.

PredefinedTypeNameProperties
 Pset_OpeningElementCommonSingle Value
NameValue
ReferenceIfcIdentifier
PurposeIfcLabel
FireExitIfcBoolean
ProtectedOpeningIfcBoolean
Enumerated Value
NameValueValue
StatusIfcLabelIfcLabel
 Pset_EnvironmentalImpactIndicatorsSingle Value
NameValue
ReferenceIfcIdentifier
FunctionalUnitReferenceIfcLabel
UnitIfcText
ExpectedServiceLifeIfcTimeMeasure
TotalPrimaryEnergyConsumptionPerUnitIfcEnergyMeasure
WaterConsumptionPerUnitIfcVolumeMeasure
HazardousWastePerUnitIfcMassMeasure
NonHazardousWastePerUnitIfcMassMeasure
ClimateChangePerUnitIfcMassMeasure
AtmosphericAcidificationPerUnitIfcMassMeasure
RenewableEnergyConsumptionPerUnitIfcEnergyMeasure
NonRenewableEnergyConsumptionPerUnitIfcEnergyMeasure
ResourceDepletionPerUnitIfcMassMeasure
InertWastePerUnitIfcMassMeasure
RadioactiveWastePerUnitIfcMassMeasure
StratosphericOzoneLayerDestructionPerUnitIfcMassMeasure
PhotochemicalOzoneFormationPerUnitIfcMassMeasure
EutrophicationPerUnitIfcMassMeasure
Enumerated Value
NameValueValue
LifeCyclePhaseIfcLabelIfcLabel
 Pset_EnvironmentalImpactValuesSingle Value
NameValue
TotalPrimaryEnergyConsumptionIfcEnergyMeasure
WaterConsumptionIfcVolumeMeasure
HazardousWasteIfcMassMeasure
NonHazardousWasteIfcMassMeasure
ClimateChangeIfcMassMeasure
AtmosphericAcidificationIfcMassMeasure
RenewableEnergyConsumptionIfcEnergyMeasure
NonRenewableEnergyConsumptionIfcEnergyMeasure
ResourceDepletionIfcMassMeasure
InertWasteIfcMassMeasure
RadioactiveWasteIfcMassMeasure
StratosphericOzoneLayerDestructionIfcMassMeasure
PhotochemicalOzoneFormationIfcMassMeasure
EutrophicationIfcMassMeasure
LeadInTimeIfcDuration
DurationIfcDuration
LeadOutTime 
 Pset_ConditionSingle Value
NameValue
AssessmentDateIfcDate
AssessmentConditionIfcLabel
AssessmentDescriptionIfcText
 Pset_ManufacturerOccurrenceSingle Value
NameValue
AcquisitionDateIfcDate
BarCodeIfcIdentifier
SerialNumberIfcIdentifier
BatchReferenceIfcIdentifier
Enumerated Value
NameValueValue
AssemblyPlaceIfcLabelIfcLabel
 Pset_ManufacturerTypeInformationSingle Value
NameValue
GlobalTradeItemNumberIfcIdentifier
ArticleNumberIfcIdentifier
ModelReferenceIfcLabel
ModelLabelIfcLabel
ManufacturerIfcLabel
ProductionYearIfcLabel
Enumerated Value
NameValueValue
AssemblyPlaceIfcLabelIfcLabel
 Pset_ServiceLifeSingle Value
NameValue
MeanTimeBetweenFailureIfcDuration
Bounded Value
NameValueValue
ServiceLifeDurationIfcDurationIfcDuration
 Pset_WarrantySingle Value
NameValue
WarrantyIdentifierIfcIdentifier
WarrantyStartDateIfcDate
WarrantyEndDateIfcDate
IsExtendedWarrantyIfcBoolean
WarrantyPeriodIfcTimeMeasure
WarrantyContentIfcText
ExclusionsIfcText

Table 54 — IfcOpeningElement Property Sets for Objects



Quantity Sets

The Quantity Sets concept applies to this entity as shown in Table 55.

Name
Qto_OpeningElementBaseQuantities

Table 55 — IfcOpeningElement Quantity Sets



Element Filling

The Element Filling concept applies to this entity.



Product Local Placement

The Product Local Placement concept applies to this entity as shown in Table 56.

TypeRelativeDescription
IfcLocalPlacementIfcLocalPlacementRelative placement according to position and rotation relative to container.
IfcLocalPlacementAbsolute placement according to position and rotation of world coordinate system.
IfcGridPlacementPlacement according to grid intersection.

Table 56 — IfcOpeningElement Product Local Placement

The local placement for IfcOpeningElement is defined in its supertype IfcProduct. It is defined by the IfcLocalPlacement, which defines the local coordinate system that is referenced by all geometric representations.

  • The PlacementRelTo relationship of IfcLocalPlacement should point to the local placement of the same element, which is voided by the opening, i.e. referred to by VoidsElement.RelatingBuildingElement.


Body Geometry

The Body Geometry concept applies to this entity as shown in Table 57.

IdentifierType
  

Table 57 — IfcOpeningElement Body Geometry

Currently, the 'Body', and 'Box' representations are supported. The 'Box' representation includes the representation type 'BoundingBox' and is explained at IfcFeatureElement.

The 'Body' representation of IfcOpeningElement can be represented using the representation types 'SweptSolid', and 'Brep'. The representation type 'Brep' is explained at IfcFeatureElement

Swept Solid Representation Type with Horizontal Extrusion

The 'SweptSolid' geometric representation of IfcOpeningElement, using horizontal extrusion direction (for walls), is defined using the swept area solid geometry. The following attribute values for the IfcShapeRepresentation holding this geometric representation shall be used:

  • RepresentationIdentifier : 'Body'
  • RepresentationType : 'SweptSolid'

The following additional constraints apply to the swept solid representation:

NOTE  In case of non-parallel jambs, the shape representation shall be a 'SweptSolid' representation with vertical extrusion.

Figure 151 illustrates an opening with horizontal extrusion.

NOTE  The local placement directions for the IfcOpeningElement are only given as an example, other directions are valid as well.
standard opening

Figure 151 — Opening with full extrusion

Figure 152 illustrates an opening for a recess.

NOTE  The local placement directions for the IfcOpeningElement are only given as an example, other directions are valid as well.
NOTE  Rectangles are now defined centric, the placement location has to be set:
recess

Figure 152 — Opening with recess extrusion

Swept Solid Representation with Vertical Extrusion

The 'SweptSolid' geometric representation of IfcOpeningElement, using vertical extrusion direction (for walls), is defined using the swept area solid geometry, however the extrusion direction may be vertical, i.e. in case of a wall opening, the extrusion would be in the direction of the wall height. The following attribute values for the IfcShapeRepresentation holding this geometric representation shall be used:

  • RepresentationIdentifier : 'Body'
  • RepresentationType : 'SweptSolid'

The following additional constraints apply to the swept solid representation:

Vertical extrusions shall be used when an opening or recess has a non rectangular foot print geometry that does not change along the height of the opening or recess.

Figure 153 shows a vertical extrusion with multiple extrusion bodies for the opening. Each extrusion body has a different extrusion lenght.

NOTE  The local placement directions for the IfcOpeningElement are only given as an example, other directions are valid as well.
vertical extrusion

Figure 153 — Opening with multiple extrusions



Concept inheritance

#ConceptModel View
IfcRoot
Software IdentityCommon Use Definitions
Revision ControlCommon Use Definitions
IfcObject
Object Occurrence Predefined TypeCommon Use Definitions
IfcElement
Box GeometryCommon Use Definitions
FootPrint GeometryCommon Use Definitions
Body SurfaceOrSolidModel GeometryCommon Use Definitions
Body SurfaceModel GeometryCommon Use Definitions
Body Tessellation GeometryCommon Use Definitions
Body Brep GeometryCommon Use Definitions
Body AdvancedBrep GeometryCommon Use Definitions
Body CSG GeometryCommon Use Definitions
Mapped GeometryCommon Use Definitions
Mesh GeometryCommon Use Definitions
IfcFeatureElement
Spatial ContainmentCommon Use Definitions
IfcOpeningElement
Property Sets for ObjectsCommon Use Definitions
Quantity SetsCommon Use Definitions
Element FillingCommon Use Definitions
Product Local PlacementCommon Use Definitions
Body GeometryCommon Use Definitions
Examples
Formal representations
XSD Specification
 <xs:element name="IfcOpeningElement" type="ifc:IfcOpeningElement" substitutionGroup="ifc:IfcFeatureElementSubtraction" nillable="true"/>
 <xs:complexType name="IfcOpeningElement">
  <xs:complexContent>
   <xs:extension base="ifc:IfcFeatureElementSubtraction">
    <xs:attribute name="PredefinedType" type="ifc:IfcOpeningElementTypeEnum" use="optional"/>
   </xs:extension>
  </xs:complexContent>
 </xs:complexType>
EXPRESS Specification
ENTITY IfcOpeningElement
 SUPERTYPE OF(IfcOpeningStandardCase)
 SUBTYPE OF (IfcFeatureElementSubtraction);
  PredefinedType : OPTIONAL IfcOpeningElementTypeEnum;
 INVERSE
  HasFillings : SET OF IfcRelFillsElement FOR RelatingOpeningElement;
END_ENTITY;

Link to EXPRESS-G diagram EXPRESS-G diagram

Link to this page  Link to this page