Configure Language Standard for Target System
Specify standard library extensions that the code generator uses for math operations. When you generate code for a new model or with a new configuration set object, the code generator uses the ISO®/IEC 9899:1999 C (C99 (ISO)) library by default. For preexisting models and configuration set objects, the code generator uses the library specified by the Language standard parameter.
If your compiler supports the ISO®/IEC 9899:1990 (C89/C90 (ANSI)), ISO/IEC 14882:2003(C++03 (ISO) or ISO/IEC 14882:2011(C++11 (ISO)) math library extensions, you can change the language standard setting. The C++03 (ISO) or C++11 (ISO) library is an option when you select C++ for the programming language.
The C99 library leverages the performance that a compiler offers over standard ANSI C. When using the C99 library, the code generator produces calls to ISO C functions when possible. For example, the generated code calls the function sqrtf()
, which operates on single-precision data, instead of sqrt()
.
To change the library setting, use the Configuration Parameters > Code Generation > Language standard parameter. The command-line equivalent is TargetLangStandard
.
Generate and Inspect ANSI C Code
1. Open the example model CStandardMathLib
.
2. Generate code.
### Starting build procedure for: CStandardMathLib ### Successful completion of code generation for: CStandardMathLib Build Summary Top model targets built: Model Action Rebuild Reason ===================================================================================== CStandardMathLib Code generated. Code generation information file does not exist. 1 of 1 models built (0 models already up to date) Build duration: 0h 0m 10.873s
3. Examine the code in the generated file CStandardMathLib.c
. Note that the code calls the sqrt
function.
if (rtb_Abs2 < 0.0F) { rtb_Abs2 = -(real32_T)sqrt((real32_T)fabs(rtb_Abs2)); } else { rtb_Abs2 = (real32_T)sqrt(rtb_Abs2); } /* Gain: '<Root>/Gain1' incorporates: * Constant: '<Root>/Constant' * Sqrt: '<Root>/get_hypot1' * Sum: '<Root>/Sum' * * About '<Root>/get_hypot1': * Operator: signedSqrt */ rtb_Abs2 = (rtb_Abs2 - 1.0F) * 343.0F; /* Rounding: '<Root>/fix1' */ if (rtb_Abs2 < 0.0F) { /* Outport: '<Root>/Out1' */ CStandardMathLib_Y.Out1 = (real32_T)ceil(rtb_Abs2); } else { /* Outport: '<Root>/Out1' */ CStandardMathLib_Y.Out1 = (real32_T)floor(rtb_Abs2); } /* End of Rounding: '<Root>/fix1' */ /* Abs: '<Root>/Abs2' incorporates: * Inport: '<Root>/In2' */ rtb_Abs2 = (real32_T)fabs(CStandardMathLib_U.In2); /* Outport: '<Root>/Out2' incorporates: * Constant: '<Root>/Constant1' * Gain: '<Root>/Gain2' * Math: '<Root>/get_hypot2' * Rounding: '<Root>/fix2' * Sum: '<Root>/Sum2' * Trigonometry: '<S1>/cos' * Trigonometry: '<S1>/sin' */ CStandardMathLib_Y.Out2 = (real32_T)floor((rt_hypotf_snf((real32_T)sin (rtb_Abs2), (real32_T)cos(rtb_Abs2)) - 1.0F) * 343.0F); } /* Model initialize function */ void CStandardMathLib_initialize(void) { /* Registration code */ /* initialize non-finites */ rt_InitInfAndNaN(sizeof(real_T)); /* initialize error status */ rtmSetErrorStatus(CStandardMathLib_M, (NULL)); /* external inputs */ (void)memset(&CStandardMathLib_U, 0, sizeof(ExtU_CStandardMathLib_T)); /* external outputs */ (void)memset(&CStandardMathLib_Y, 0, sizeof(ExtY_CStandardMathLib_T)); } /* Model terminate function */ void CStandardMathLib_terminate(void) { /* (no terminate code required) */ }
Generate and Inspect ISO C Code
1. Change the setting of Language standard to C99 (ISO)
. Alternatively, at the command line, set TargetLangStandard
to C99 (ISO)
.
2. Regenerate the code.
### Starting build procedure for: CStandardMathLib ### Successful completion of code generation for: CStandardMathLib Build Summary Top model targets built: Model Action Rebuild Reason ===================================================================================== CStandardMathLib Code generated. Code generation information file does not exist. 1 of 1 models built (0 models already up to date) Build duration: 0h 0m 8.9385s
3. Reexamine the code in the generated file CStandardMathLib.c
. Now the generated code calls the function sqrtf
instead of sqrt
.
if (rtb_Abs2 < 0.0F) { rtb_Abs2 = -sqrtf(fabsf(rtb_Abs2)); } else { rtb_Abs2 = sqrtf(rtb_Abs2); } /* Outport: '<Root>/Out1' incorporates: * Constant: '<Root>/Constant' * Gain: '<Root>/Gain1' * Rounding: '<Root>/fix1' * Sqrt: '<Root>/get_hypot1' * Sum: '<Root>/Sum' * * About '<Root>/get_hypot1': * Operator: signedSqrt */ CStandardMathLib_Y.Out1 = truncf((rtb_Abs2 - 1.0F) * 343.0F); /* Abs: '<Root>/Abs2' incorporates: * Inport: '<Root>/In2' */ rtb_Abs2 = fabsf(CStandardMathLib_U.In2); /* Outport: '<Root>/Out2' incorporates: * Constant: '<Root>/Constant1' * Gain: '<Root>/Gain2' * Math: '<Root>/get_hypot2' * Rounding: '<Root>/fix2' * Sum: '<Root>/Sum2' * Trigonometry: '<S1>/cos' * Trigonometry: '<S1>/sin' */ CStandardMathLib_Y.Out2 = floorf((rt_hypotf_snf(sinf(rtb_Abs2), cosf(rtb_Abs2)) - 1.0F) * 343.0F); } /* Model initialize function */ void CStandardMathLib_initialize(void) { /* Registration code */ /* initialize error status */ rtmSetErrorStatus(CStandardMathLib_M, (NULL)); /* external inputs */ (void)memset(&CStandardMathLib_U, 0, sizeof(ExtU_CStandardMathLib_T)); /* external outputs */ (void)memset(&CStandardMathLib_Y, 0, sizeof(ExtY_CStandardMathLib_T)); } /* Model terminate function */ void CStandardMathLib_terminate(void) { /* (no terminate code required) */ }