///////////////////////////////////////////////////////////////////////////////
// Copyright (C) 2002-2025, Open Design Alliance (the "Alliance").
// All rights reserved.
//
// This software and its documentation and related materials are owned by
// the Alliance. The software may only be incorporated into application
// programs owned by members of the Alliance, subject to a signed
// Membership Agreement and Supplemental Software License Agreement with the
// Alliance. The structure and organization of this software are the valuable
// trade secrets of the Alliance and its suppliers. The software is also
// protected by copyright law and international treaty provisions. Application
// programs incorporating this software must include the following statement
// with their copyright notices:
//
// This application incorporates Open Design Alliance software pursuant to a license
// agreement with Open Design Alliance.
// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.
// All rights reserved.
//
// By use of this software, its documentation or related materials, you
// acknowledge and accept the above terms.
///////////////////////////////////////////////////////////////////////////////
// This file is generated automatically.
#ifndef _IFC2X3_IFCPRODUCTSOFCOMBUSTIONPROPERTIES_AUTO_IMPL_H
#define _IFC2X3_IFCPRODUCTSOFCOMBUSTIONPROPERTIES_AUTO_IMPL_H
#include "IfcMaterialPropertiesAutoImpl.h"
#include "TD_PackPush.h"
/** \details
The namespace contains schema-dependent classes, definitions and sub routines
for work with IFC2X3 express schema definitions.
*/
namespace OdIfc2x3 {
/** \details
This is a common definition that captures the properties of products of combustion generated
by elements typically used within the context of building services and flow distribution systems.
*/
class IFC2X3_EXPORT IfcProductsOfCombustionProperties : public IfcMaterialProperties
{
//DOM-IGNORE-BEGIN
OD_EXP_DECLARE_MEMBERS(OdIfc2x3::IfcProductsOfCombustionProperties);
//DOM-IGNORE-END
public:
//
// OdDAI early binding accessors
//
/** \details
Returns the value of SpecificHeatCapacity attribute.
This attribute represents the specific heat of the products of combustion: heat energy absorbed per
temperature unit. Usually measured in [J/kg K].
\returns
Returns the value of SpecificHeatCapacity attribute.
*/
double getSpecificHeatCapacity() const;
/** \details
Sets the value of SpecificHeatCapacity attribute.
This attribute represents the specific heat of the products of combustion: heat energy absorbed per
temperature unit. Usually measured in [J/kg K].
\param SpecificHeatCapacity [in] SpecificHeatCapacity attribute to set.
*/
void setSpecificHeatCapacity(double SpecificHeatCapacity);
/** \details
Returns the value of N20Content attribute.
This attribute represents the Nitrous Oxide (N2O) content of the products of combustion.
This is measured in weight of N2O per unit weight and is therefore unitless.
\returns
Returns the value of N20Content attribute.
*/
double getN20Content() const;
/** \details
Sets the value of N20Content attribute.
This attribute represents the Nitrous Oxide (N2O) content of the products of combustion.
This is measured in weight of N2O per unit weight and is therefore unitless.
\param N20Content [in] N20Content attribute to set.
*/
void setN20Content(double N20Content);
/** \details
Returns the value of COContent attribute.
This attribute represents the Carbon Monoxide (CO) content of the products of combustion.
This is measured in weight of CO per unit weight and is therefore unitless.
\returns
Returns the value of COContent attribute.
*/
double getCOContent() const;
/** \details
Sets the value of COContent attribute.
This attribute represents the Carbon Monoxide (CO) content of the products of combustion.
This is measured in weight of CO per unit weight and is therefore unitless.
\param COContent [in] COContent attribute to set.
*/
void setCOContent(double COContent);
/** \details
Returns the value of CO2Content attribute.
This attribute represents the Carbon Dioxide (CO2) content of the products of combustion.
This is measured in weight of CO2 per unit weight and is therefore unitless.
\returns
Returns the value of CO2Content attribute.
*/
double getCO2Content() const;
/** \details
Sets the value of CO2Content attribute.
This attribute represents the Carbon Dioxide (CO2) content of the products of combustion.
This is measured in weight of CO2 per unit weight and is therefore unitless.
\param CO2Content [in] CO2Content attribute to set.
*/
void setCO2Content(double CO2Content);
public:
/** \details
Default constructor for the IfcPlateStandardCase class.
*/
IfcProductsOfCombustionProperties();
/** \details
Reads object's data from the specified filer.
\param rdFiler [in] Pointer to a filer from which to read the data.
\returns
A value of OdResult type that contains the result of the method execution.
*/
virtual OdResult inFields(OdDAI::OdSpfFilerBase* rdFiler) override;
/** \details
Writes object's data the the specified filer.
\param wrFiler [in] Pointer to a filer to which to write the data.
\returns
A value of OdResult type that contains the result of the method execution.
*/
virtual OdResult outFields(OdDAI::OdSpfFilerBase* wrFiler) override;
/** \details
Returns a type of a class instance.
\returns
Pointer to the