readout_rm/nco_dpi/codegen/dll/nco_model/rtGetInf.c

131 lines
2.9 KiB
C

/*
* Academic License - for use in teaching, academic research, and meeting
* course requirements at degree granting institutions only. Not for
* government, commercial, or other organizational use.
* File: rtGetInf.c
*
* MATLAB Coder version : 24.1
* C/C++ source code generated on : 2025-04-09 02:18:34
*/
/*
* Abstract:
* MATLAB for code generation function to initialize non-finite, Inf and
* MinusInf
*/
/* Include Files */
#include "rtGetInf.h"
#include "rt_nonfinite.h"
/*
* Function: rtGetInf
* ================================================================== Abstract:
* Initialize rtInf needed by the generated code.
*/
real_T rtGetInf(void)
{
real_T inf = 0.0;
uint16_T one = 1U;
enum
{
LittleEndian,
BigEndian
} machByteOrder = (*((uint8_T *)&one) == 1U) ? LittleEndian : BigEndian;
switch (machByteOrder) {
case LittleEndian: {
union {
LittleEndianIEEEDouble bitVal;
real_T fltVal;
} tmpVal;
tmpVal.bitVal.words.wordH = 0x7FF00000U;
tmpVal.bitVal.words.wordL = 0x00000000U;
inf = tmpVal.fltVal;
break;
}
case BigEndian: {
union {
BigEndianIEEEDouble bitVal;
real_T fltVal;
} tmpVal;
tmpVal.bitVal.words.wordH = 0x7FF00000U;
tmpVal.bitVal.words.wordL = 0x00000000U;
inf = tmpVal.fltVal;
break;
}
}
return inf;
}
/*
* Function: rtGetInfF
* ================================================================= Abstract:
* Initialize rtInfF needed by the generated code.
*/
real32_T rtGetInfF(void)
{
IEEESingle infF;
infF.wordL.wordLuint = 0x7F800000U;
return infF.wordL.wordLreal;
}
/*
* Function: rtGetMinusInf
* ============================================================= Abstract:
* Initialize rtMinusInf needed by the generated code.
*/
real_T rtGetMinusInf(void)
{
real_T minf = 0.0;
uint16_T one = 1U;
enum
{
LittleEndian,
BigEndian
} machByteOrder = (*((uint8_T *)&one) == 1U) ? LittleEndian : BigEndian;
switch (machByteOrder) {
case LittleEndian: {
union {
LittleEndianIEEEDouble bitVal;
real_T fltVal;
} tmpVal;
tmpVal.bitVal.words.wordH = 0xFFF00000U;
tmpVal.bitVal.words.wordL = 0x00000000U;
minf = tmpVal.fltVal;
break;
}
case BigEndian: {
union {
BigEndianIEEEDouble bitVal;
real_T fltVal;
} tmpVal;
tmpVal.bitVal.words.wordH = 0xFFF00000U;
tmpVal.bitVal.words.wordL = 0x00000000U;
minf = tmpVal.fltVal;
break;
}
}
return minf;
}
/*
* Function: rtGetMinusInfF
* ============================================================ Abstract:
* Initialize rtMinusInfF needed by the generated code.
*/
real32_T rtGetMinusInfF(void)
{
IEEESingle minfF;
minfF.wordL.wordLuint = 0xFF800000U;
return minfF.wordL.wordLreal;
}
/*
* File trailer for rtGetInf.c
*
* [EOF]
*/