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

Hex to binary converter

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



Joined: 21 May 2015
Posts: 181

View user's profile Send private message

Hex to binary converter
PostPosted: Mon May 15, 2017 2:29 am     Reply with quote

Hi,

I'm trying to convert Hexadecimal to Binary numbers.
However, when i enter hex number such as FF it will reply ERROR.
Why is this happening? It should reply 11111111
Kindly please help me.

Here is my code:


Code:



#include <18F4550.h>
#fuses HSPLL,NOWDT,PROTECT,NOLVP,NODEBUG,USBDIV,PLL5,CPUDIV1,VREGEN       
#use delay(clock=48000000)
#use rs232(baud=9600, xmit=PIN_C6, rcv=PIN_C7,ERRORS)
#include <string.h>
#include <input.c>
#include <stdio.h>
#include <stdlib.h>
#include <usb_cdc.h>

#define MAX 5

void main()
   {
      char c;
      unsigned char d;
      unsigned char key;
     
      unsigned char hexa[MAX];
      long int i=0;
   

   usb_init_cs();


   while (TRUE)
         {
         usb_task();


            if (usb_cdc_kbhit())
               {
                 c=usb_cdc_getc();
                 if (c=='\n') {putc('\r'); putc('\n');}
                 if (c=='\r') {putc('\r'); putc('\n');}

                                       

                 while(true)
                 
                     {
                  ART:

                  d = usb_cdc_getc();


                         if(d=='D')
                             {
                                while (key!=32) // push SPACE BAR to stop
                                   {           
                                   
                                       printf(usb_cdc_putc,"\n ENTER HEX VALUE : ");
                                             get_string_usb(hexa,3);



                                       printf(usb_cdc_putc," Binary Value : ");
   
                                       while (hexa[i])
                                           {
                                              switch(hexa[i])
                                              {
                                                case '0':
                                                printf(usb_cdc_putc,"0000");
                                                break;

                                                case '1':
                                                printf(usb_cdc_putc,"0001");
                                                break;

                                                case '2':
                                                printf(usb_cdc_putc,"0010");
                                                break;

                                                case '3':
                                                printf(usb_cdc_putc,"0011",);
                                                break;
           
                                                case '4':
                                                printf(usb_cdc_putc,"0100");
                                                break;

                                                case '5':
                                                printf(usb_cdc_putc,"0101");
                                                break;

                                                case '6':
                                                printf(usb_cdc_putc,"0110");
                                                break;

                                                case '7':
                                                printf(usb_cdc_putc,"0111");
                                                break;           
           
                                                case '8':
                                                printf(usb_cdc_putc,"1000");
                                                break;

                                                case '9':
                                                printf(usb_cdc_putc,"1001");
                                                break;

                                                case 'A':
                                                printf(usb_cdc_putc,"1010");
                                                break;

                                                case 'B':
                                                printf(usb_cdc_putc,"1011");
                                                break;
           
                                                case 'C':
                                                printf(usb_cdc_putc,"1100");
                                                break;

                                                case 'D':
                                                printf(usb_cdc_putc,"1101");
                                                break;

                                                case 'E':
                                                printf(usb_cdc_putc,"1110");
                                                break;

                                                case 'F':
                                                printf(usb_cdc_putc,"1111");
                                                break;             
         
                 
                                                default:
                                                printf(usb_cdc_putc,"\n ERROR %c",hexa[i]);
                                              }
                                             i++;
   
                                           } 
   
                   
 
                                   
                                   } key=0; // to initialize 'key' not as SPACE BAR
                             }



                     }
               }       
         }             

temtronic



Joined: 01 Jul 2010
Posts: 9295
Location: Greensville,Ontario

View user's profile Send private message

PostPosted: Mon May 15, 2017 5:35 am     Reply with quote

this...

while (hexa[i])

just doesn't seem correct or proper to me.

WHILE normally needs a 'condition' (IE: X <=64 ) though it does accept 1 or true, I'm wondering how it handles 'hexa[i]'.

You don't show us but do single characters (0...F) work fine? do 3 characters say 123 decode properly?

Also, I'd put a space in the display ( 0101 1100 instead of 01011100 ), makes it easier to read and debug.

Jay
jeremiah



Joined: 20 Jul 2010
Posts: 1362

View user's profile Send private message

PostPosted: Mon May 15, 2017 7:22 am     Reply with quote

One thing you can do to improve your chances of figuring this out is change your debug line:

Code:

printf(usb_cdc_putc,"\n ERROR %c",hexa[i]);


to

Code:

printf(usb_cdc_putc,"\n ERROR %02x",hexa[i]);


This will output the hex of the value being seen by your logic. %c won't always be useful because a lot of characters are not displayable. With the hex value, you can go check an ASCII chart and see exactly what value is sneaking into your stream. It could simply be a left over whitespace character (like new line or carriage return).
art



Joined: 21 May 2015
Posts: 181

View user's profile Send private message

PostPosted: Mon May 15, 2017 6:31 pm     Reply with quote

Hi,
If i put F, FF or FFF the result will display Binary : ERROR

When I change %c to %02x , result is

Code:


 Binary :  ERROR e1 ERROR 04 ERROR c3 ERROR 05 ERROR f3 ERROR 20 ERROR 0e ERROR 04 ERROR 6f ERROR 02 ERROR b5 ERROR 05 ERROR d0 ERROR 02 ERROR b3 ERROR 07



Which part cause the problem ?
PCM programmer



Joined: 06 Sep 2003
Posts: 21708

View user's profile Send private message

PostPosted: Mon May 15, 2017 7:02 pm     Reply with quote

One problem is that you initialize 'i' to 0 at the start of your program and
then you never reset it again.

This stuff here is illusory:
Quote:
long int i=0;

It makes you think you've taken care of 'i', but in reality you have a
while() loop that parses the string. You need to reinitialize 'i' at the start
of each new string. You need to add the line shown in bold below:
Quote:

printf(usb_cdc_putc,"\n ENTER HEX VALUE : ");
get_string_usb(hexa,3); // Get a new hex string
printf(usb_cdc_putc," Binary Value : ");

i = 0;

while (hexa[i]) // Scan the new string until a 0x00 is found
{
switch(hexa[i])
{
case '0':
art



Joined: 21 May 2015
Posts: 181

View user's profile Send private message

PostPosted: Mon May 15, 2017 7:41 pm     Reply with quote

Hi PCM,

It works!!! Thanks PCM.
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