155 lines
3.3 KiB
C++
155 lines
3.3 KiB
C++
/*
|
|
* rtGetInf.cpp
|
|
*
|
|
* 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.
|
|
*
|
|
* Code generation for model "VFControl".
|
|
*
|
|
* Model version : 1.1
|
|
* Simulink Coder version : 24.1 (R2024a) 19-Nov-2023
|
|
* C++ source code generated on : Wed Oct 16 10:45:53 2024
|
|
*/
|
|
|
|
#include "rtwtypes.h"
|
|
|
|
extern "C"
|
|
{
|
|
|
|
#include "rtGetInf.h"
|
|
|
|
}
|
|
|
|
#include <stddef.h>
|
|
|
|
extern "C"
|
|
{
|
|
|
|
#include "rt_nonfinite.h"
|
|
|
|
}
|
|
|
|
#define NumBitsPerChar 8U
|
|
|
|
extern "C"
|
|
{
|
|
/*
|
|
* Initialize rtInf needed by the generated code.
|
|
* Inf is initialized as non-signaling. Assumes IEEE.
|
|
*/
|
|
real_T rtGetInf(void)
|
|
{
|
|
size_t bitsPerReal = sizeof(real_T) * (NumBitsPerChar);
|
|
real_T inf = 0.0;
|
|
if (bitsPerReal == 32U) {
|
|
inf = rtGetInfF();
|
|
} else {
|
|
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;
|
|
}
|
|
|
|
/*
|
|
* Initialize rtInfF needed by the generated code.
|
|
* Inf is initialized as non-signaling. Assumes IEEE.
|
|
*/
|
|
real32_T rtGetInfF(void)
|
|
{
|
|
IEEESingle infF;
|
|
infF.wordL.wordLuint = 0x7F800000U;
|
|
return infF.wordL.wordLreal;
|
|
}
|
|
|
|
/*
|
|
* Initialize rtMinusInf needed by the generated code.
|
|
* Inf is initialized as non-signaling. Assumes IEEE.
|
|
*/
|
|
real_T rtGetMinusInf(void)
|
|
{
|
|
size_t bitsPerReal = sizeof(real_T) * (NumBitsPerChar);
|
|
real_T minf = 0.0;
|
|
if (bitsPerReal == 32U) {
|
|
minf = rtGetMinusInfF();
|
|
} else {
|
|
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;
|
|
}
|
|
|
|
/*
|
|
* Initialize rtMinusInfF needed by the generated code.
|
|
* Inf is initialized as non-signaling. Assumes IEEE.
|
|
*/
|
|
real32_T rtGetMinusInfF(void)
|
|
{
|
|
IEEESingle minfF;
|
|
minfF.wordL.wordLuint = 0xFF800000U;
|
|
return minfF.wordL.wordLreal;
|
|
}
|
|
}
|