EENX15/simulink_export/html/rt_nonfinite_cpp.html

217 lines
16 KiB
HTML
Raw Normal View History

2021-04-15 16:54:53 +02:00
<!DOCTYPE html>
<html>
<head>
<script type="text/javascript" src="./js/coder_app.js"></script>
<meta http-equiv="content-type" content="text/html; charset=utf-8" />
<script type="text/javascript" src="./rtwreport_utils.js"></script>
<script type="text/javascript" src="./rtwannotate.js"></script>
<link rel="stylesheet" type="text/css" href="./css/coder_app.css"/>
</head>
<body onload="srcFileOnload();">
<pre id="code">
<table class="code" id="codeTbl">
<tr name="1" id="1">
<td><a id="l1" class='ln'>1</a></td><td><span class="ct">/*</span></td></tr>
<tr name="2" id="2">
<td><a id="l2" class='ln'>2</a></td><td><span class="ct"> * rt_nonfinite.cpp</span></td></tr>
<tr name="3" id="3">
<td><a id="l3" class='ln'>3</a></td><td><span class="ct"> *</span></td></tr>
<tr name="4" id="4">
<td><a id="l4" class='ln'>4</a></td><td><span class="ct"> * Academic License - for use in teaching, academic research, and meeting</span></td></tr>
<tr name="5" id="5">
<td><a id="l5" class='ln'>5</a></td><td><span class="ct"> * course requirements at degree granting institutions only. Not for</span></td></tr>
<tr name="6" id="6">
<td><a id="l6" class='ln'>6</a></td><td><span class="ct"> * government, commercial, or other organizational use.</span></td></tr>
<tr name="7" id="7">
<td><a id="l7" class='ln'>7</a></td><td><span class="ct"> *</span></td></tr>
<tr name="8" id="8">
<td><a id="l8" class='ln'>8</a></td><td><span class="ct"> * Code generation for model "Arduino_skal".</span></td></tr>
<tr name="9" id="9">
<td><a id="l9" class='ln'>9</a></td><td><span class="ct"> *</span></td></tr>
<tr name="10" id="10">
<td><a id="l10" class='ln'>10</a></td><td><span class="ct"> * Model version : 1.1</span></td></tr>
<tr name="11" id="11">
<td><a id="l11" class='ln'>11</a></td><td><span class="ct"> * Simulink Coder version : 9.5 (R2021a) 14-Nov-2020</span></td></tr>
<tr name="12" id="12">
<td><a id="l12" class='ln'>12</a></td><td><span class="ct"> * C++ source code generated on : Thu Apr 15 15:56:50 2021</span></td></tr>
<tr name="13" id="13">
<td><a id="l13" class='ln'>13</a></td><td><span class="ct"> *</span></td></tr>
<tr name="14" id="14">
<td><a id="l14" class='ln'>14</a></td><td><span class="ct"> * Target selection: grt.tlc</span></td></tr>
<tr name="15" id="15">
<td><a id="l15" class='ln'>15</a></td><td><span class="ct"> * Note: GRT includes extra infrastructure and instrumentation for prototyping</span></td></tr>
<tr name="16" id="16">
<td><a id="l16" class='ln'>16</a></td><td><span class="ct"> * Embedded hardware selection: Intel-&gt;x86-64 (Windows64)</span></td></tr>
<tr name="17" id="17">
<td><a id="l17" class='ln'>17</a></td><td><span class="ct"> * Code generation objective: Debugging</span></td></tr>
<tr name="18" id="18">
<td><a id="l18" class='ln'>18</a></td><td><span class="ct"> * Validation result: Not run</span></td></tr>
<tr name="19" id="19">
<td><a id="l19" class='ln'>19</a></td><td><span class="ct"> */</span></td></tr>
<tr name="20" id="20">
<td><a id="l20" class='ln'>20</a></td><td></td></tr>
<tr name="21" id="21">
<td><a id="l21" class='ln'>21</a></td><td><span class="ct">/*</span></td></tr>
<tr name="22" id="22">
<td><a id="l22" class='ln'>22</a></td><td><span class="ct"> * Abstract:</span></td></tr>
<tr name="23" id="23">
<td><a id="l23" class='ln'>23</a></td><td><span class="ct"> * Function to initialize non-finites,</span></td></tr>
<tr name="24" id="24">
<td><a id="l24" class='ln'>24</a></td><td><span class="ct"> * (Inf, NaN and -Inf).</span></td></tr>
<tr name="25" id="25">
<td><a id="l25" class='ln'>25</a></td><td><span class="ct"> */</span></td></tr>
<tr name="26" id="26">
<td><a id="l26" class='ln'>26</a></td><td><span class="pp">#include "rt_nonfinite.h"</span></td></tr>
<tr name="27" id="27">
<td><a id="l27" class='ln'>27</a></td><td><span class="pp">#include "rtGetNaN.h"</span></td></tr>
<tr name="28" id="28">
<td><a id="l28" class='ln'>28</a></td><td><span class="pp">#include "rtGetInf.h"</span></td></tr>
<tr name="29" id="29">
<td><a id="l29" class='ln'>29</a></td><td><span class="pp">#define</span> <a id="29c9" class="tk">NumBitsPerChar</a> 8U</td></tr>
<tr name="30" id="30">
<td><a id="l30" class='ln'>30</a></td><td></td></tr>
<tr name="31" id="31">
<td><a id="l31" class='ln'>31</a></td><td><span class="kw">extern</span> "C" <span class="br">{</span></td></tr>
<tr name="32" id="32">
<td><a id="l32" class='ln'>32</a></td><td> <a id="32c3" class="tk">real_T</a> <a id="32c10" class="tk">rtInf</a>;</td></tr>
<tr name="33" id="33">
<td><a id="l33" class='ln'>33</a></td><td> <a id="33c3" class="tk">real_T</a> <a id="33c10" class="tk">rtMinusInf</a>;</td></tr>
<tr name="34" id="34">
<td><a id="l34" class='ln'>34</a></td><td> <a id="34c3" class="tk">real_T</a> <a id="34c10" class="tk">rtNaN</a>;</td></tr>
<tr name="35" id="35">
<td><a id="l35" class='ln'>35</a></td><td> <a id="35c3" class="tk">real32_T</a> <a id="35c12" class="tk">rtInfF</a>;</td></tr>
<tr name="36" id="36">
<td><a id="l36" class='ln'>36</a></td><td> <a id="36c3" class="tk">real32_T</a> <a id="36c12" class="tk">rtMinusInfF</a>;</td></tr>
<tr name="37" id="37">
<td><a id="l37" class='ln'>37</a></td><td> <a id="37c3" class="tk">real32_T</a> <a id="37c12" class="tk">rtNaNF</a>;</td></tr>
<tr name="38" id="38">
<td><a id="l38" class='ln'>38</a></td><td><span class="br">}</span></td></tr>
<tr name="39" id="39">
<td><a id="l39" class='ln'>39</a></td><td> <span class="kw">extern</span> "C"</td></tr>
<tr name="40" id="40">
<td><a id="l40" class='ln'>40</a></td><td><span class="br">{</span></td></tr>
<tr name="41" id="41">
<td><a id="l41" class='ln'>41</a></td><td> <span class="ct">/*</span></td></tr>
<tr name="42" id="42">
<td><a id="l42" class='ln'>42</a></td><td><span class="ct"> * Initialize the rtInf, rtMinusInf, and rtNaN needed by the</span></td></tr>
<tr name="43" id="43">
<td><a id="l43" class='ln'>43</a></td><td><span class="ct"> * generated code. NaN is initialized as non-signaling. Assumes IEEE.</span></td></tr>
<tr name="44" id="44">
<td><a id="l44" class='ln'>44</a></td><td><span class="ct"> */</span></td></tr>
<tr name="45" id="45">
<td><a id="l45" class='ln'>45</a></td><td> <span class="kw">void</span> <a id="45c8" class="tk">rt_InitInfAndNaN</a>(<a id="45c25" class="tk">size_t</a> <a id="45c32" class="tk">realSize</a>)</td></tr>
<tr name="46" id="46">
<td><a id="l46" class='ln'>46</a></td><td> <span class="br">{</span></td></tr>
<tr name="47" id="47">
<td><a id="l47" class='ln'>47</a></td><td> (<span class="kw">void</span>) (<a id="47c13" class="tk">realSize</a>);</td></tr>
<tr name="48" id="48">
<td><a id="l48" class='ln'>48</a></td><td> <a id="48c5" class="tk">rtNaN</a> = <a id="48c13" class="tk">rtGetNaN</a>();</td></tr>
<tr name="49" id="49">
<td><a id="l49" class='ln'>49</a></td><td> <a id="49c5" class="tk">rtNaNF</a> = <a id="49c14" class="tk">rtGetNaNF</a>();</td></tr>
<tr name="50" id="50">
<td><a id="l50" class='ln'>50</a></td><td> <a id="50c5" class="tk">rtInf</a> = <a id="50c13" class="tk">rtGetInf</a>();</td></tr>
<tr name="51" id="51">
<td><a id="l51" class='ln'>51</a></td><td> <a id="51c5" class="tk">rtInfF</a> = <a id="51c14" class="tk">rtGetInfF</a>();</td></tr>
<tr name="52" id="52">
<td><a id="l52" class='ln'>52</a></td><td> <a id="52c5" class="tk">rtMinusInf</a> = <a id="52c18" class="tk">rtGetMinusInf</a>();</td></tr>
<tr name="53" id="53">
<td><a id="l53" class='ln'>53</a></td><td> <a id="53c5" class="tk">rtMinusInfF</a> = <a id="53c19" class="tk">rtGetMinusInfF</a>();</td></tr>
<tr name="54" id="54">
<td><a id="l54" class='ln'>54</a></td><td> <span class="br">}</span></td></tr>
<tr name="55" id="55">
<td><a id="l55" class='ln'>55</a></td><td></td></tr>
<tr name="56" id="56">
<td><a id="l56" class='ln'>56</a></td><td> <span class="ct">/* Test if value is infinite */</span></td></tr>
<tr name="57" id="57">
<td><a id="l57" class='ln'>57</a></td><td> <a id="57c3" class="tk">boolean_T</a> <a id="57c13" class="tk">rtIsInf</a>(<a id="57c21" class="tk">real_T</a> <a id="57c28" class="tk">value</a>)</td></tr>
<tr name="58" id="58">
<td><a id="l58" class='ln'>58</a></td><td> <span class="br">{</span></td></tr>
<tr name="59" id="59">
<td><a id="l59" class='ln'>59</a></td><td> <span class="kw">return</span> (<a id="59c13" class="tk">boolean_T</a>)((<a id="59c25" class="tk">value</a><a id="59c30" class="tk">==</a><a id="59c32" class="tk">rtInf</a> <a id="59c38" class="tk">||</a> <a id="59c41" class="tk">value</a><a id="59c46" class="tk">==</a><a id="59c48" class="tk">rtMinusInf</a>) <a id="59c60" class="tk">?</a> 1U <a id="59c65" class="tk">:</a> 0U);</td></tr>
<tr name="60" id="60">
<td><a id="l60" class='ln'>60</a></td><td> <span class="br">}</span></td></tr>
<tr name="61" id="61">
<td><a id="l61" class='ln'>61</a></td><td></td></tr>
<tr name="62" id="62">
<td><a id="l62" class='ln'>62</a></td><td> <span class="ct">/* Test if single-precision value is infinite */</span></td></tr>
<tr name="63" id="63">
<td><a id="l63" class='ln'>63</a></td><td> <a id="63c3" class="tk">boolean_T</a> <a id="63c13" class="tk">rtIsInfF</a>(<a id="63c22" class="tk">real32_T</a> <a id="63c31" class="tk">value</a>)</td></tr>
<tr name="64" id="64">
<td><a id="l64" class='ln'>64</a></td><td> <span class="br">{</span></td></tr>
<tr name="65" id="65">
<td><a id="l65" class='ln'>65</a></td><td> <span class="kw">return</span> (<a id="65c13" class="tk">boolean_T</a>)(((<a id="65c26" class="tk">value</a>)<a id="65c32" class="tk">==</a><a id="65c34" class="tk">rtInfF</a> <a id="65c41" class="tk">||</a> (<a id="65c45" class="tk">value</a>)<a id="65c51" class="tk">==</a><a id="65c53" class="tk">rtMinusInfF</a>) <a id="65c66" class="tk">?</a> 1U <a id="65c71" class="tk">:</a> 0U);</td></tr>
<tr name="66" id="66">
<td><a id="l66" class='ln'>66</a></td><td> <span class="br">}</span></td></tr>
<tr name="67" id="67">
<td><a id="l67" class='ln'>67</a></td><td></td></tr>
<tr name="68" id="68">
<td><a id="l68" class='ln'>68</a></td><td> <span class="ct">/* Test if value is not a number */</span></td></tr>
<tr name="69" id="69">
<td><a id="l69" class='ln'>69</a></td><td> <a id="69c3" class="tk">boolean_T</a> <a id="69c13" class="tk">rtIsNaN</a>(<a id="69c21" class="tk">real_T</a> <a id="69c28" class="tk">value</a>)</td></tr>
<tr name="70" id="70">
<td><a id="l70" class='ln'>70</a></td><td> <span class="br">{</span></td></tr>
<tr name="71" id="71">
<td><a id="l71" class='ln'>71</a></td><td> <a id="71c5" class="tk">boolean_T</a> <a id="71c15" class="tk">result</a> = (<a id="71c25" class="tk">boolean_T</a>) 0;</td></tr>
<tr name="72" id="72">
<td><a id="l72" class='ln'>72</a></td><td> <a id="72c5" class="tk">size_t</a> <a id="72c12" class="tk">bitsPerReal</a> = <span class="kw">sizeof</span>(<a id="72c33" class="tk">real_T</a>) <a id="72c41" class="tk">*</a> (<a id="72c44" class="tk">NumBitsPerChar</a>);</td></tr>
<tr name="73" id="73">
<td><a id="l73" class='ln'>73</a></td><td> <span class="kw">if</span> (<a id="73c9" class="tk">bitsPerReal</a> <a id="73c21" class="tk">==</a> 32U) <span class="br">{</span></td></tr>
<tr name="74" id="74">
<td><a id="l74" class='ln'>74</a></td><td> <a id="74c7" class="tk">result</a> = <a id="74c16" class="tk">rtIsNaNF</a>((<a id="74c26" class="tk">real32_T</a>)<a id="74c35" class="tk">value</a>);</td></tr>
<tr name="75" id="75">
<td><a id="l75" class='ln'>75</a></td><td> <span class="br">}</span> <span class="kw">else</span> <span class="br">{</span></td></tr>
<tr name="76" id="76">
<td><a id="l76" class='ln'>76</a></td><td> <span class="kw">union</span> <span class="br">{</span></td></tr>
<tr name="77" id="77">
<td><a id="l77" class='ln'>77</a></td><td> <a id="77c9" class="tk">LittleEndianIEEEDouble</a> <a id="77c32" class="tk">bitVal</a>;</td></tr>
<tr name="78" id="78">
<td><a id="l78" class='ln'>78</a></td><td> <a id="78c9" class="tk">real_T</a> <a id="78c16" class="tk">fltVal</a>;</td></tr>
<tr name="79" id="79">
<td><a id="l79" class='ln'>79</a></td><td> <span class="br">}</span> <a id="79c9" class="tk">tmpVal</a>;</td></tr>
<tr name="80" id="80">
<td><a id="l80" class='ln'>80</a></td><td></td></tr>
<tr name="81" id="81">
<td><a id="l81" class='ln'>81</a></td><td> <a id="81c7" class="tk">tmpVal</a>.<a id="81c14" class="tk">fltVal</a> = <a id="81c23" class="tk">value</a>;</td></tr>
<tr name="82" id="82">
<td><a id="l82" class='ln'>82</a></td><td> <a id="82c7" class="tk">result</a> = (<a id="82c17" class="tk">boolean_T</a>)((<a id="82c29" class="tk">tmpVal</a>.<a id="82c36" class="tk">bitVal</a>.<a id="82c43" class="tk">words</a>.<a id="82c49" class="tk">wordH</a> <a id="82c55" class="tk">&amp;</a> 0x7FF00000) <a id="82c69" class="tk">==</a></td></tr>
<tr name="83" id="83">
<td><a id="l83" class='ln'>83</a></td><td> 0x7FF00000 <a id="83c39" class="tk">&amp;&amp;</a></td></tr>
<tr name="84" id="84">
<td><a id="l84" class='ln'>84</a></td><td> ( (<a id="84c31" class="tk">tmpVal</a>.<a id="84c38" class="tk">bitVal</a>.<a id="84c45" class="tk">words</a>.<a id="84c51" class="tk">wordH</a> <a id="84c57" class="tk">&amp;</a> 0x000FFFFF) <a id="84c71" class="tk">!=</a> 0 <a id="84c76" class="tk">||</a></td></tr>
<tr name="85" id="85">
<td><a id="l85" class='ln'>85</a></td><td> (<a id="85c30" class="tk">tmpVal</a>.<a id="85c37" class="tk">bitVal</a>.<a id="85c44" class="tk">words</a>.<a id="85c50" class="tk">wordL</a> <a id="85c56" class="tk">!=</a> 0) ));</td></tr>
<tr name="86" id="86">
<td><a id="l86" class='ln'>86</a></td><td> <span class="br">}</span></td></tr>
<tr name="87" id="87">
<td><a id="l87" class='ln'>87</a></td><td></td></tr>
<tr name="88" id="88">
<td><a id="l88" class='ln'>88</a></td><td> <span class="kw">return</span> <a id="88c12" class="tk">result</a>;</td></tr>
<tr name="89" id="89">
<td><a id="l89" class='ln'>89</a></td><td> <span class="br">}</span></td></tr>
<tr name="90" id="90">
<td><a id="l90" class='ln'>90</a></td><td></td></tr>
<tr name="91" id="91">
<td><a id="l91" class='ln'>91</a></td><td> <span class="ct">/* Test if single-precision value is not a number */</span></td></tr>
<tr name="92" id="92">
<td><a id="l92" class='ln'>92</a></td><td> <a id="92c3" class="tk">boolean_T</a> <a id="92c13" class="tk">rtIsNaNF</a>(<a id="92c22" class="tk">real32_T</a> <a id="92c31" class="tk">value</a>)</td></tr>
<tr name="93" id="93">
<td><a id="l93" class='ln'>93</a></td><td> <span class="br">{</span></td></tr>
<tr name="94" id="94">
<td><a id="l94" class='ln'>94</a></td><td> <a id="94c5" class="tk">IEEESingle</a> <a id="94c16" class="tk">tmp</a>;</td></tr>
<tr name="95" id="95">
<td><a id="l95" class='ln'>95</a></td><td> <a id="95c5" class="tk">tmp</a>.<a id="95c9" class="tk">wordL</a>.<a id="95c15" class="tk">wordLreal</a> = <a id="95c27" class="tk">value</a>;</td></tr>
<tr name="96" id="96">
<td><a id="l96" class='ln'>96</a></td><td> <span class="kw">return</span> (<a id="96c13" class="tk">boolean_T</a>)( (<a id="96c26" class="tk">tmp</a>.<a id="96c30" class="tk">wordL</a>.<a id="96c36" class="tk">wordLuint</a> <a id="96c46" class="tk">&amp;</a> 0x7F800000) <a id="96c60" class="tk">==</a> 0x7F800000 <a id="96c74" class="tk">&amp;&amp;</a></td></tr>
<tr name="97" id="97">
<td><a id="l97" class='ln'>97</a></td><td> (<a id="97c25" class="tk">tmp</a>.<a id="97c29" class="tk">wordL</a>.<a id="97c35" class="tk">wordLuint</a> <a id="97c45" class="tk">&amp;</a> 0x007FFFFF) <a id="97c59" class="tk">!=</a> 0 );</td></tr>
<tr name="98" id="98">
<td><a id="l98" class='ln'>98</a></td><td> <span class="br">}</span></td></tr>
<tr name="99" id="99">
<td><a id="l99" class='ln'>99</a></td><td><span class="br">}</span></td></tr>
<tr name="100" id="100">
<td><a id="l100" class='ln'>100</a></td><td></td></tr>
</table>
</pre>
</body>
</html>