<?xml version="1.0" encoding="UTF-8"?>
<rss xmlns:content="http://purl.org/rss/1.0/modules/content/" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:taxo="http://purl.org/rss/1.0/modules/taxonomy/" version="2.0">
  <channel>
    <title>topic Bytes to Float not working in S32 Design Studio</title>
    <link>https://community.nxp.com/t5/S32-Design-Studio/Bytes-to-Float-not-working/m-p/2000140#M12813</link>
    <description>&lt;P&gt;Hello all.&lt;/P&gt;&lt;P&gt;I am trying to convert some bytes that I receive from CAN to a float variable.&lt;/P&gt;&lt;P&gt;However, the result is not correctly. I tried to change from little endian to big endian, not works.&lt;/P&gt;&lt;P&gt;For example, I am receiving the data 0x40333333, it`s suposed to be 2.8, but the result is totally different.&lt;/P&gt;&lt;P&gt;The images below will help to explain the situation (the variable that I am focusing in this example is&amp;nbsp;&lt;STRONG&gt;cellParams.underVoltage&lt;/STRONG&gt;&lt;LI-EMOJI id="lia_disappointed-face" title=":disappointed_face:"&gt;&lt;/LI-EMOJI&gt;&lt;/P&gt;&lt;P&gt;- variable initialiazion&lt;/P&gt;&lt;P&gt;cellParams.underVoltage = 2.80;&lt;/P&gt;&lt;P&gt;- initialization confirmation:&lt;/P&gt;&lt;P&gt;&lt;span class="lia-inline-image-display-wrapper lia-image-align-inline" image-alt="Marcos_Eztronic_1-1732282497069.png" style="width: 400px;"&gt;&lt;img src="https://community.nxp.com/t5/image/serverpage/image-id/312030iEEBE591E30C0CC65/image-size/medium?v=v2&amp;amp;px=400" role="button" title="Marcos_Eztronic_1-1732282497069.png" alt="Marcos_Eztronic_1-1732282497069.png" /&gt;&lt;/span&gt;&lt;/P&gt;&lt;P&gt;So after the initialization, I will send a CAN command to change the value (I will send the same value)&lt;/P&gt;&lt;P&gt;The new value is in the image below, from buffer position 3 until 6&lt;/P&gt;&lt;P&gt;&lt;span class="lia-inline-image-display-wrapper lia-image-align-left" image-alt="Marcos_Eztronic_2-1732282634455.png" style="width: 722px;"&gt;&lt;img src="https://community.nxp.com/t5/image/serverpage/image-id/312031i2932CAF28C1972E2/image-dimensions/722x640?v=v2" width="722" height="640" role="button" title="Marcos_Eztronic_2-1732282634455.png" alt="Marcos_Eztronic_2-1732282634455.png" /&gt;&lt;/span&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;When I receive the buffer, I try to do the following:&lt;/P&gt;&lt;P&gt;int dummyInt = DeserializeInt32(&amp;amp;cmdMsg-&amp;gt;data[3]);&lt;BR /&gt;//cellParams.underVoltage = atof(&amp;amp;cmdMsg-&amp;gt;data[3]); (same problem...)&lt;BR /&gt;cellParams.underVoltage = (float)(dummyInt);&lt;/P&gt;&lt;DIV&gt;static uint32_t DeserializeUint32(const uint8_t *buffer)&lt;/DIV&gt;&lt;DIV&gt;{&lt;/DIV&gt;&lt;DIV&gt;&lt;SPAN&gt;&amp;nbsp; &amp;nbsp; int value = 0;&lt;/SPAN&gt;&lt;/DIV&gt;&lt;DIV&gt;&amp;nbsp;&lt;/DIV&gt;&lt;DIV&gt;&lt;SPAN&gt;&amp;nbsp; &amp;nbsp; value += (int)buffer[3] &amp;lt;&amp;lt; 24U;&lt;/SPAN&gt;&lt;/DIV&gt;&lt;DIV&gt;&lt;SPAN&gt;&amp;nbsp; &amp;nbsp; value += (int)buffer[2] &amp;lt;&amp;lt; 16U;&lt;/SPAN&gt;&lt;/DIV&gt;&lt;DIV&gt;&lt;SPAN&gt;&amp;nbsp; &amp;nbsp; value += (int)buffer[1] &amp;lt;&amp;lt; 8U;&lt;/SPAN&gt;&lt;/DIV&gt;&lt;DIV&gt;&lt;SPAN&gt;&amp;nbsp; &amp;nbsp; value += (int)buffer[0];&lt;/SPAN&gt;&lt;/DIV&gt;&lt;DIV&gt;&lt;SPAN&gt;&amp;nbsp; &amp;nbsp; return value;&lt;/SPAN&gt;&lt;/DIV&gt;&lt;DIV&gt;}&lt;/DIV&gt;&lt;DIV&gt;&amp;nbsp;&lt;/DIV&gt;&lt;DIV&gt;the returned value to dummyInt is OK:&lt;/DIV&gt;&lt;DIV&gt;&lt;span class="lia-inline-image-display-wrapper lia-image-align-inline" image-alt="Marcos_Eztronic_3-1732282807587.png" style="width: 400px;"&gt;&lt;img src="https://community.nxp.com/t5/image/serverpage/image-id/312034iB879995DC7B1F72E/image-size/medium?v=v2&amp;amp;px=400" role="button" title="Marcos_Eztronic_3-1732282807587.png" alt="Marcos_Eztronic_3-1732282807587.png" /&gt;&lt;/span&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;The float value, before&amp;nbsp;cellParams.underVoltage = (float)(dummyInt), is:&lt;/P&gt;&lt;span class="lia-inline-image-display-wrapper lia-image-align-inline" image-alt="Marcos_Eztronic_4-1732282862589.png" style="width: 400px;"&gt;&lt;img src="https://community.nxp.com/t5/image/serverpage/image-id/312037iE4BFA2216DD1B948/image-size/medium?v=v2&amp;amp;px=400" role="button" title="Marcos_Eztronic_4-1732282862589.png" alt="Marcos_Eztronic_4-1732282862589.png" /&gt;&lt;/span&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;And after&amp;nbsp;cellParams.underVoltage = (float)(dummyInt), is:&lt;/P&gt;&lt;span class="lia-inline-image-display-wrapper lia-image-align-inline" image-alt="Marcos_Eztronic_5-1732283003922.png" style="width: 632px;"&gt;&lt;img src="https://community.nxp.com/t5/image/serverpage/image-id/312038i3C94EBE926FE050C/image-dimensions/632x49?v=v2" width="632" height="49" role="button" title="Marcos_Eztronic_5-1732283003922.png" alt="Marcos_Eztronic_5-1732283003922.png" /&gt;&lt;/span&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;but if I check the variable (not in memory monitor), the hex value looks fine, but the float value lookw incorrect:&lt;/P&gt;&lt;span class="lia-inline-image-display-wrapper lia-image-align-inline" image-alt="Marcos_Eztronic_6-1732283097162.png" style="width: 400px;"&gt;&lt;img src="https://community.nxp.com/t5/image/serverpage/image-id/312039i8DA1EE2D0425534F/image-size/medium?v=v2&amp;amp;px=400" role="button" title="Marcos_Eztronic_6-1732283097162.png" alt="Marcos_Eztronic_6-1732283097162.png" /&gt;&lt;/span&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;PS.: I tried&amp;nbsp;&lt;SPAN&gt;atof, memcpy, not success.&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN&gt;Could someone help me? Thanks in advance!&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;/DIV&gt;</description>
    <pubDate>Fri, 22 Nov 2024 13:46:00 GMT</pubDate>
    <dc:creator>Marcos_Eztronic</dc:creator>
    <dc:date>2024-11-22T13:46:00Z</dc:date>
    <item>
      <title>Bytes to Float not working</title>
      <link>https://community.nxp.com/t5/S32-Design-Studio/Bytes-to-Float-not-working/m-p/2000140#M12813</link>
      <description>&lt;P&gt;Hello all.&lt;/P&gt;&lt;P&gt;I am trying to convert some bytes that I receive from CAN to a float variable.&lt;/P&gt;&lt;P&gt;However, the result is not correctly. I tried to change from little endian to big endian, not works.&lt;/P&gt;&lt;P&gt;For example, I am receiving the data 0x40333333, it`s suposed to be 2.8, but the result is totally different.&lt;/P&gt;&lt;P&gt;The images below will help to explain the situation (the variable that I am focusing in this example is&amp;nbsp;&lt;STRONG&gt;cellParams.underVoltage&lt;/STRONG&gt;&lt;LI-EMOJI id="lia_disappointed-face" title=":disappointed_face:"&gt;&lt;/LI-EMOJI&gt;&lt;/P&gt;&lt;P&gt;- variable initialiazion&lt;/P&gt;&lt;P&gt;cellParams.underVoltage = 2.80;&lt;/P&gt;&lt;P&gt;- initialization confirmation:&lt;/P&gt;&lt;P&gt;&lt;span class="lia-inline-image-display-wrapper lia-image-align-inline" image-alt="Marcos_Eztronic_1-1732282497069.png" style="width: 400px;"&gt;&lt;img src="https://community.nxp.com/t5/image/serverpage/image-id/312030iEEBE591E30C0CC65/image-size/medium?v=v2&amp;amp;px=400" role="button" title="Marcos_Eztronic_1-1732282497069.png" alt="Marcos_Eztronic_1-1732282497069.png" /&gt;&lt;/span&gt;&lt;/P&gt;&lt;P&gt;So after the initialization, I will send a CAN command to change the value (I will send the same value)&lt;/P&gt;&lt;P&gt;The new value is in the image below, from buffer position 3 until 6&lt;/P&gt;&lt;P&gt;&lt;span class="lia-inline-image-display-wrapper lia-image-align-left" image-alt="Marcos_Eztronic_2-1732282634455.png" style="width: 722px;"&gt;&lt;img src="https://community.nxp.com/t5/image/serverpage/image-id/312031i2932CAF28C1972E2/image-dimensions/722x640?v=v2" width="722" height="640" role="button" title="Marcos_Eztronic_2-1732282634455.png" alt="Marcos_Eztronic_2-1732282634455.png" /&gt;&lt;/span&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;When I receive the buffer, I try to do the following:&lt;/P&gt;&lt;P&gt;int dummyInt = DeserializeInt32(&amp;amp;cmdMsg-&amp;gt;data[3]);&lt;BR /&gt;//cellParams.underVoltage = atof(&amp;amp;cmdMsg-&amp;gt;data[3]); (same problem...)&lt;BR /&gt;cellParams.underVoltage = (float)(dummyInt);&lt;/P&gt;&lt;DIV&gt;static uint32_t DeserializeUint32(const uint8_t *buffer)&lt;/DIV&gt;&lt;DIV&gt;{&lt;/DIV&gt;&lt;DIV&gt;&lt;SPAN&gt;&amp;nbsp; &amp;nbsp; int value = 0;&lt;/SPAN&gt;&lt;/DIV&gt;&lt;DIV&gt;&amp;nbsp;&lt;/DIV&gt;&lt;DIV&gt;&lt;SPAN&gt;&amp;nbsp; &amp;nbsp; value += (int)buffer[3] &amp;lt;&amp;lt; 24U;&lt;/SPAN&gt;&lt;/DIV&gt;&lt;DIV&gt;&lt;SPAN&gt;&amp;nbsp; &amp;nbsp; value += (int)buffer[2] &amp;lt;&amp;lt; 16U;&lt;/SPAN&gt;&lt;/DIV&gt;&lt;DIV&gt;&lt;SPAN&gt;&amp;nbsp; &amp;nbsp; value += (int)buffer[1] &amp;lt;&amp;lt; 8U;&lt;/SPAN&gt;&lt;/DIV&gt;&lt;DIV&gt;&lt;SPAN&gt;&amp;nbsp; &amp;nbsp; value += (int)buffer[0];&lt;/SPAN&gt;&lt;/DIV&gt;&lt;DIV&gt;&lt;SPAN&gt;&amp;nbsp; &amp;nbsp; return value;&lt;/SPAN&gt;&lt;/DIV&gt;&lt;DIV&gt;}&lt;/DIV&gt;&lt;DIV&gt;&amp;nbsp;&lt;/DIV&gt;&lt;DIV&gt;the returned value to dummyInt is OK:&lt;/DIV&gt;&lt;DIV&gt;&lt;span class="lia-inline-image-display-wrapper lia-image-align-inline" image-alt="Marcos_Eztronic_3-1732282807587.png" style="width: 400px;"&gt;&lt;img src="https://community.nxp.com/t5/image/serverpage/image-id/312034iB879995DC7B1F72E/image-size/medium?v=v2&amp;amp;px=400" role="button" title="Marcos_Eztronic_3-1732282807587.png" alt="Marcos_Eztronic_3-1732282807587.png" /&gt;&lt;/span&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;The float value, before&amp;nbsp;cellParams.underVoltage = (float)(dummyInt), is:&lt;/P&gt;&lt;span class="lia-inline-image-display-wrapper lia-image-align-inline" image-alt="Marcos_Eztronic_4-1732282862589.png" style="width: 400px;"&gt;&lt;img src="https://community.nxp.com/t5/image/serverpage/image-id/312037iE4BFA2216DD1B948/image-size/medium?v=v2&amp;amp;px=400" role="button" title="Marcos_Eztronic_4-1732282862589.png" alt="Marcos_Eztronic_4-1732282862589.png" /&gt;&lt;/span&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;And after&amp;nbsp;cellParams.underVoltage = (float)(dummyInt), is:&lt;/P&gt;&lt;span class="lia-inline-image-display-wrapper lia-image-align-inline" image-alt="Marcos_Eztronic_5-1732283003922.png" style="width: 632px;"&gt;&lt;img src="https://community.nxp.com/t5/image/serverpage/image-id/312038i3C94EBE926FE050C/image-dimensions/632x49?v=v2" width="632" height="49" role="button" title="Marcos_Eztronic_5-1732283003922.png" alt="Marcos_Eztronic_5-1732283003922.png" /&gt;&lt;/span&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;but if I check the variable (not in memory monitor), the hex value looks fine, but the float value lookw incorrect:&lt;/P&gt;&lt;span class="lia-inline-image-display-wrapper lia-image-align-inline" image-alt="Marcos_Eztronic_6-1732283097162.png" style="width: 400px;"&gt;&lt;img src="https://community.nxp.com/t5/image/serverpage/image-id/312039i8DA1EE2D0425534F/image-size/medium?v=v2&amp;amp;px=400" role="button" title="Marcos_Eztronic_6-1732283097162.png" alt="Marcos_Eztronic_6-1732283097162.png" /&gt;&lt;/span&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;PS.: I tried&amp;nbsp;&lt;SPAN&gt;atof, memcpy, not success.&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN&gt;Could someone help me? Thanks in advance!&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;/DIV&gt;</description>
      <pubDate>Fri, 22 Nov 2024 13:46:00 GMT</pubDate>
      <guid>https://community.nxp.com/t5/S32-Design-Studio/Bytes-to-Float-not-working/m-p/2000140#M12813</guid>
      <dc:creator>Marcos_Eztronic</dc:creator>
      <dc:date>2024-11-22T13:46:00Z</dc:date>
    </item>
    <item>
      <title>Re: Bytes to Float not working</title>
      <link>https://community.nxp.com/t5/S32-Design-Studio/Bytes-to-Float-not-working/m-p/2000987#M12816</link>
      <description>&lt;P&gt;Hi,&amp;nbsp;&lt;/P&gt;
&lt;P&gt;I tried it on my side and only working method for me is memcpy - like this:&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;unsigned int counter = 0x40333333;&lt;BR /&gt;float f=0.0;&lt;BR /&gt;memcpy(&amp;amp;f,&amp;amp;counter,4);&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Mon, 25 Nov 2024 10:26:06 GMT</pubDate>
      <guid>https://community.nxp.com/t5/S32-Design-Studio/Bytes-to-Float-not-working/m-p/2000987#M12816</guid>
      <dc:creator>jiri_kral</dc:creator>
      <dc:date>2024-11-25T10:26:06Z</dc:date>
    </item>
    <item>
      <title>Re: Bytes to Float not working</title>
      <link>https://community.nxp.com/t5/S32-Design-Studio/Bytes-to-Float-not-working/m-p/2001037#M12817</link>
      <description>&lt;P&gt;Hello, thank you so much for the answer.&lt;/P&gt;&lt;P&gt;Memcpy not worked for me, but I found another solution (thats similar to memcpy, but that`s the onlyone that worked...)&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;DIV&gt;static float DeserializeFloat(const uint8_t *buffer)&lt;/DIV&gt;&lt;DIV&gt;{&lt;/DIV&gt;&lt;DIV&gt;&lt;SPAN&gt;uint32_t value = 0;&lt;/SPAN&gt;&lt;/DIV&gt;&lt;DIV&gt;&amp;nbsp;&lt;/DIV&gt;&lt;DIV&gt;&lt;SPAN&gt;value |= buffer[3] &amp;lt;&amp;lt; 24U;&lt;/SPAN&gt;&lt;/DIV&gt;&lt;DIV&gt;&lt;SPAN&gt;value |= buffer[2] &amp;lt;&amp;lt; 16U;&lt;/SPAN&gt;&lt;/DIV&gt;&lt;DIV&gt;&lt;SPAN&gt;value |= buffer[1] &amp;lt;&amp;lt; 8U;&lt;/SPAN&gt;&lt;/DIV&gt;&lt;DIV&gt;&lt;SPAN&gt;value |= buffer[0];&lt;/SPAN&gt;&lt;/DIV&gt;&lt;DIV&gt;&lt;SPAN&gt;float f = *((float*)&amp;amp;value);&lt;/SPAN&gt;&lt;/DIV&gt;&lt;DIV&gt;&lt;SPAN&gt;return f;&lt;/SPAN&gt;&lt;/DIV&gt;&lt;DIV&gt;}&lt;/DIV&gt;&lt;DIV&gt;&amp;nbsp;&lt;/DIV&gt;&lt;DIV&gt;Anyway, thank you very much for your time.&lt;/DIV&gt;</description>
      <pubDate>Mon, 25 Nov 2024 11:20:57 GMT</pubDate>
      <guid>https://community.nxp.com/t5/S32-Design-Studio/Bytes-to-Float-not-working/m-p/2001037#M12817</guid>
      <dc:creator>Marcos_Eztronic</dc:creator>
      <dc:date>2024-11-25T11:20:57Z</dc:date>
    </item>
  </channel>
</rss>

