CCS C Software and Maintenance Offers
FAQFAQ   FAQForum Help   FAQOfficial CCS Support   SearchSearch  RegisterRegister 

ProfileProfile   Log in to check your private messagesLog in to check your private messages   Log inLog in 

CCS does not monitor this forum on a regular basis.

Please do not post bug reports on this forum. Send them to CCS Technical Support

Dec to Hex - Merge Digits to a Num

 
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion
View previous topic :: View next topic  
Author Message
delilcodes



Joined: 12 May 2021
Posts: 5

View user's profile Send private message

Dec to Hex - Merge Digits to a Num
PostPosted: Sat May 15, 2021 12:16 pm     Reply with quote

I am trying to change dec numbers to hex. It turned out to be harder than I thought. Maybe I think too much. I just want to turn change just non-fractional side of number.

Code:

      doubleWeigth = 695.581;
      intPart = (doubleWeigth*100);
      hexDigits[0] = intPart%16;
      intPart = (intPart/16-(intPart/16)%1);
      hexDigits[1] = intPart%16;
      intPart = (intPart/16-(intPart/16)%1);
      hexDigits[2] = intPart%16;

      for(i=0;i<3;i++){
         switch (hexDigits[i]){
            case 10:
               hexDigits[i] = 0x10;
               break;
            case 11:
               hexDigits[i] = 0x11;
               break;
            case 12:
               hexDigits[i] = 0x12;
               break;
            case 13:
               hexDigits[i] = 0x13;
               break;
            case 14:
               hexDigits[i] = 0x14;
               break;
            case 15:
               hexDigits[i] = 0x15;
               break;
         }
      }

I stacked here. How can i merge the numbers as one hex number?
delilcodes



Joined: 12 May 2021
Posts: 5

View user's profile Send private message

PostPosted: Sat May 15, 2021 1:00 pm     Reply with quote

I used the expression like;

Code:
i = (hexDigits[2]<<16)|(hexDigits[1]<<8)|(hexDigits[0]);

But i didnot work. Whats the problem here?
dluu13



Joined: 28 Sep 2018
Posts: 395
Location: Toronto, ON

View user's profile Send private message Visit poster's website

PostPosted: Sat May 15, 2021 2:28 pm     Reply with quote

Are you trying to store each hex digit as an element of an array?
Ttelmah



Joined: 11 Mar 2010
Posts: 19513

View user's profile Send private message

PostPosted: Sat May 15, 2021 11:14 pm     Reply with quote

Seriously, a hugely complicated way to do thing....
Code:

   char hexdigits[10]; //male sure this is large enough.....
   int32 intpart;

   doubleWeigth = 695.581;
   intpart = doubleWeight; //This now contains just the integer part
   //intpart will now be 695

   itos(intpart, 16, hexdigits);


hexdigits[0] will be '2', [1] will be 'b', [2] will be '7'. [3] will be '\0'.

This allows the conversion maths to be done in integer. Trying to do this as
float will be slow and inaccurate.

You need to #include <stdlib.h> before this is available.

Multiplying by 100, meant your intpart value was 69500. So the
[0] digit would always be 0. Then %1 would effectively only give binary
for the second and third part of your result. Not what you want....
Then your handling of values above 10, was fundamentally flawed.
You are generating the number 20, for a digit of 14, which is not either
ASCII or correct in decimal. 14 wants to be ASCII 'E', or the number
14.

Remember hex is an ASCII encoding, so 0 needs to be '0'.

If you just want base 16 'digits', not hex, then simply use %16, and
then divide by 16 for each hex value, till the remaining value is zero.
delilcodes



Joined: 12 May 2021
Posts: 5

View user's profile Send private message

PostPosted: Sun May 16, 2021 1:04 am     Reply with quote

dluu13 wrote:
Are you trying to store each hex digit as an element of an array?


Yeah. I wanna create modbus communication and send value of weigth to master for respond. I wanted to send hex digits but it is does not make sense. So I simply wanna send only digits no matter is hex or dec.

Ttelmah wrote:



Thanks for reply. You are soo right. I got so confused while coding.
I will use your way like:
Code:

      int16 intPart; // i think its enough for 3 digit number
      int8 fracPart; // i think this is enough for 2 digit number: i%100

      int16 weigthDigits[4];
      intPart = (doubleWeigth); // you are soo right :)

      weigthDigits[0] = (intPart - intPart%100)/100;
      weigthDigits[1] = (intPart%100 - intPart%10)/10;
      weigthDigits[2] = (intPart%10);


But I need fractional numbers to send to master. tenths maybe hundredths
So I can do this like;
Code:
 
      //fracPart = (doubleWeigth*100)%100;//this is notworking cuz of doubleWeigth not integer. so:
      int32 i; //this must be int32, cuz of  (doubleWeigth*100)
      i= doubleWeigth*100;
      fracPart = i%100;
      weigthDigits[3] = (fracPart - fracPart%10)/10;
      weigthDigits[4] = fracPart%10;

Is this a reasonable structure?

This error occurs when I want to use itos.

Code:
*** Error 12 "modbus_loadcell_led_slave_2.c" Line 136(11,12): Undefined identifier  -- itos


edit: some parameters edited
Ttelmah



Joined: 11 Mar 2010
Posts: 19513

View user's profile Send private message

PostPosted: Sun May 16, 2021 1:31 am     Reply with quote

As I said:

Quote:

You need to #include <stdlib.h> before this is available.


How you send fractional numbers will depend totally on what the device
you are talking to expects.
Modbus does not support this. Making it into hex, wastes digits. Modbus
by standard supports 165bit binary values. Normally to send a FP number,
what you do is send two 16bit binary numbers that together contain the
IEEE 32bit numeric value, and the second device combines these back
to a IEEE value.
The library ieeefloat.c contains the code to convert a MicroChip float
value to IEEE format. Then you would send the 32bit result as two 16bit
transfers.
The other way devices do this (which may be why you have the *100),
is to take the float, multiply by 100, and send the result of this as a 32
bit integer, again as two 16bit transfers.
This though again never involves sending as hex.

Honestly if the other device expects to receive the value as 32bit integer
*100, then you would be much better off writing the code in the PIC
to actually use the values in this format. If it is coming from a sensor
rethink the code that is actually generating the value so that it works in
this format. CCS does support using integers in this way, and this
results in much faster/smaller maths than using FP.
delilcodes



Joined: 12 May 2021
Posts: 5

View user's profile Send private message

PostPosted: Sun May 16, 2021 4:52 am     Reply with quote

Ttelmah wrote:
As I said:

Quote:

You need to #include <stdlib.h> before this is available.


How you send fractional numbers will depend totally on what the device
you are talking to expects.
Modbus does not support this. Making it into hex, wastes digits. Modbus
by standard supports 165bit binary values. Normally to send a FP number,
what you do is send two 16bit binary numbers that together contain the
IEEE 32bit numeric value, and the second device combines these back
to a IEEE value.
The library ieeefloat.c contains the code to convert a MicroChip float
value to IEEE format. Then you would send the 32bit result as two 16bit
transfers.
The other way devices do this (which may be why you have the *100),
is to take the float, multiply by 100, and send the result of this as a 32
bit integer, again as two 16bit transfers.
This though again never involves sending as hex.

Honestly if the other device expects to receive the value as 32bit integer
*100, then you would be much better off writing the code in the PIC
to actually use the values in this format. If it is coming from a sensor
rethink the code that is actually generating the value so that it works in
this format. CCS does support using integers in this way, and this
results in much faster/smaller maths than using FP.


I understand. Thanks for your help.
Display posts from previous:   
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion All times are GMT - 6 Hours
Page 1 of 1

 
Jump to:  
You cannot post new topics in this forum
You cannot reply to topics in this forum
You cannot edit your posts in this forum
You cannot delete your posts in this forum
You cannot vote in polls in this forum


Powered by phpBB © 2001, 2005 phpBB Group