93 lines
2.2 KiB
C
93 lines
2.2 KiB
C
![]() |
/*
|
||
|
* File: rt_nonfinite.c
|
||
|
*
|
||
|
* Code generated for Simulink model 'fuc'.
|
||
|
*
|
||
|
* Model version : 1.18
|
||
|
* Simulink Coder version : 9.8 (R2022b) 13-May-2022
|
||
|
* C/C++ source code generated on : Sat Jan 6 10:24:46 2024
|
||
|
*
|
||
|
* Target selection: ert.tlc
|
||
|
* Embedded hardware selection: ARM Compatible->ARM 64-bit (LP64)
|
||
|
* Code generation objectives: Unspecified
|
||
|
* Validation result: Not run
|
||
|
*/
|
||
|
|
||
|
#include "rtGetNaN.h"
|
||
|
#include "rtGetInf.h"
|
||
|
#include <stddef.h>
|
||
|
#include "rtwtypes.h"
|
||
|
#include "rt_nonfinite.h"
|
||
|
#define NumBitsPerChar 8U
|
||
|
|
||
|
real_T rtInf;
|
||
|
real_T rtMinusInf;
|
||
|
real_T rtNaN;
|
||
|
real32_T rtInfF;
|
||
|
real32_T rtMinusInfF;
|
||
|
real32_T rtNaNF;
|
||
|
|
||
|
/*
|
||
|
* Initialize the rtInf, rtMinusInf, and rtNaN needed by the
|
||
|
* generated code. NaN is initialized as non-signaling. Assumes IEEE.
|
||
|
*/
|
||
|
void rt_InitInfAndNaN(size_t realSize)
|
||
|
{
|
||
|
(void) (realSize);
|
||
|
rtNaN = rtGetNaN();
|
||
|
rtNaNF = rtGetNaNF();
|
||
|
rtInf = rtGetInf();
|
||
|
rtInfF = rtGetInfF();
|
||
|
rtMinusInf = rtGetMinusInf();
|
||
|
rtMinusInfF = rtGetMinusInfF();
|
||
|
}
|
||
|
|
||
|
/* Test if value is infinite */
|
||
|
boolean_T rtIsInf(real_T value)
|
||
|
{
|
||
|
return (boolean_T)((value==rtInf || value==rtMinusInf) ? 1U : 0U);
|
||
|
}
|
||
|
|
||
|
/* Test if single-precision value is infinite */
|
||
|
boolean_T rtIsInfF(real32_T value)
|
||
|
{
|
||
|
return (boolean_T)(((value)==rtInfF || (value)==rtMinusInfF) ? 1U : 0U);
|
||
|
}
|
||
|
|
||
|
/* Test if value is not a number */
|
||
|
boolean_T rtIsNaN(real_T value)
|
||
|
{
|
||
|
boolean_T result = (boolean_T) 0;
|
||
|
size_t bitsPerReal = sizeof(real_T) * (NumBitsPerChar);
|
||
|
if (bitsPerReal == 32U) {
|
||
|
result = rtIsNaNF((real32_T)value);
|
||
|
} else {
|
||
|
union {
|
||
|
LittleEndianIEEEDouble bitVal;
|
||
|
real_T fltVal;
|
||
|
} tmpVal;
|
||
|
|
||
|
tmpVal.fltVal = value;
|
||
|
result = (boolean_T)((tmpVal.bitVal.words.wordH & 0x7FF00000) == 0x7FF00000 &&
|
||
|
( (tmpVal.bitVal.words.wordH & 0x000FFFFF) != 0 ||
|
||
|
(tmpVal.bitVal.words.wordL != 0) ));
|
||
|
}
|
||
|
|
||
|
return result;
|
||
|
}
|
||
|
|
||
|
/* Test if single-precision value is not a number */
|
||
|
boolean_T rtIsNaNF(real32_T value)
|
||
|
{
|
||
|
IEEESingle tmp;
|
||
|
tmp.wordL.wordLreal = value;
|
||
|
return (boolean_T)( (tmp.wordL.wordLuint & 0x7F800000) == 0x7F800000 &&
|
||
|
(tmp.wordL.wordLuint & 0x007FFFFF) != 0 );
|
||
|
}
|
||
|
|
||
|
/*
|
||
|
* File trailer for generated code.
|
||
|
*
|
||
|
* [EOF]
|
||
|
*/
|