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

Compiler precalculations

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



Joined: 22 Feb 2007
Posts: 55

View user's profile Send private message

Compiler precalculations
PostPosted: Thu Aug 06, 2015 2:01 am     Reply with quote

Can the compiler make some calculations of fixed values related to other fixed values so I don’t these calculation in the program?

Example 1:
Code:

#define version 0b0000000111110101
#define value_1 ((version & 448)/64)

Example 2:
Code:

#define version 128
#define value_1
{
 if (version == 128) value_1=7;
 if (version == 64) value_1=6;
}

It seems to that example 1 is OK when I test this, but example 2 is not accepted by the compiler.
Ttelmah



Joined: 11 Mar 2010
Posts: 19605

View user's profile Send private message

PostPosted: Thu Aug 06, 2015 2:35 am     Reply with quote

This is a C textbook job... Smile

'if' is a runtime statement. Doesn't get executed till the code runs....

The pre-processor statement, is #if

The compiler can make decisions based on a define, using this. So:
Code:

#define VERSION 128

#if VERSION == 128
   #define VALUE 7
#else
   #define VALUE 6
#endif


Now realise that 'VALUE' (or value_1 in your example), is a define (a text substitution macro), so you can't set it '=' to something, you can only #define it to something.

There is also #elif (with a second test), and #ifdef, which returns 'TRUE' if a value is #defined.

There is a 'C' 'semi-standard', to use 'ALL_CAPITALS' for things that are #defined. It's quite a sensible thing, since there are points in the code, where it can make a difference. Being not able to set it = to something, is an example!....
Mortenc



Joined: 22 Feb 2007
Posts: 55

View user's profile Send private message

PostPosted: Thu Aug 06, 2015 3:54 am     Reply with quote

Many thanks Ttelmah.
That was just what I need.
However I'm a little in doubt whether all math operations can be used in my define lines. In my example 1, the bitwise AND and division seems to work. So is there any math which should not work or any restrictions of how complicated this math can be in the define line?
RF_Developer



Joined: 07 Feb 2011
Posts: 839

View user's profile Send private message

PostPosted: Thu Aug 06, 2015 4:00 am     Reply with quote

Mortenc wrote:
However I'm a little in doubt whether all math operations can be used in my define lines. ... So is there any math which should not work or any restrictions of how complicated this math can be in the define line?


This "pre-calculation" is known as "constant collapse". Its a compiler thing, not a preprocessor thing. So, it doesn't happen in the #define, it happens when the compiler actually compiles the code, i.e. after all the text substitutions. It can only work with expressions that evaluate to a constant at compile time. It doesn't work with expressions with C maths functions, such as log(), sin() and so on, even if the parameters are constant. So things like ln(10.0) cannot be collapsed/pre-computed.
Mortenc



Joined: 22 Feb 2007
Posts: 55

View user's profile Send private message

PostPosted: Thu Aug 06, 2015 7:05 am     Reply with quote

Thanks it's a great forum.

I have a lot of pre-calculations to be done.
I must test every line a think, to be sure that all math I working.
Mortenc



Joined: 22 Feb 2007
Posts: 55

View user's profile Send private message

PostPosted: Fri Aug 07, 2015 1:19 am     Reply with quote

Now I have made a lot of pre-calculation that the compiler shall do.
First the compiling suddenly going slow and when I add more calculations to do, the compiler freeze and don't get finish.
Does anyone get an idea why?
It's just simple #if with define like:
Code:

#if dataBit4Or == 16
 #define dataBit4 4;
#else
#if dataBit4Or == 8
 #define dataBit4 3;
#else
#if dataBit4Or == 4
 #define dataBit4 2;
#else
 # define dataBit4 1
#endif
#endif
#endif
Ttelmah



Joined: 11 Mar 2010
Posts: 19605

View user's profile Send private message

PostPosted: Fri Aug 07, 2015 1:33 am     Reply with quote

First, lay them out as they are used:
Code:

#if dataBit4Or == 16
  #define dataBit4 4;
#else
  #if dataBit4Or == 8
    #define dataBit4 3;
  #else
    #if dataBit4Or == 4
      #define dataBit4 2;
    #else
      #define dataBit4 1
    #endif
  #endif
#endif

Then if this is what you actually want, use #elif
So:
Code:

#if dataBit4Or == 16
  #define dataBit4 4;
#elif dataBit4Or == 8
 #define dataBit4 3;
#elif dataBit4Or == 4
 #define dataBit4 2;
#else
 #define dataBit4 1
#endif

You are creating a triple deep stack of if conditions, when the whole thing can be done in one. The compiler has to work out all the possibilities in all possible states, so it takes work!...
Mortenc



Joined: 22 Feb 2007
Posts: 55

View user's profile Send private message

PostPosted: Fri Aug 07, 2015 2:56 am     Reply with quote

I have tried to make it like you said, using #elif and place text like your example, but the same happen.
I have more of these "if" defining and the compiling go fine, but it seems too, that there is a limit how many there can be.
Mortenc



Joined: 22 Feb 2007
Posts: 55

View user's profile Send private message

PostPosted: Fri Aug 07, 2015 4:27 am     Reply with quote

Could it be my large amount of #defines?
I have about 100 defines.
My compiler version is: PCM compiler 4.067
Mortenc



Joined: 22 Feb 2007
Posts: 55

View user's profile Send private message

PostPosted: Mon Aug 10, 2015 2:02 am     Reply with quote

Does any have an idea what can be done to come over the limit?


My #defines look like these.
Nothing seems to be wrong with the #defines, but when I get to about 60 defines of these, the compiler freeze and don't get finish with the building.
Code:

#define protocol 278      //
#define resolution 16     //
#define x_delay 1                            //
#define y_delay 10                         //
#define alarm_level 6    //
//***********************************************************
#define firstBit ((protocol & 448)/64)
#define secondBit ((protocol & 56)/8)
#define thirdBit (protocol & 7)
#define firstBitOr (1<<firstBit)
#define secondBitOr (1<<secondBit)
#define thirdBitOr (1<<thirdBit)
#define available (((255^firstBitOr)^secondBitOr)^thirdBitOr)
#define G22 (128 & available)
#define H22 (G22>>1)
#define I22 (64^H22)
#define G23 ((64 & available) & I22)
#define H23 ((G23^H22)>>1)
#define I23 (32^H23)
#define G24 ((32 & available) & I23)
#define H24 ((G24^H23)>>1)
#define I24 (16^H24)
#define G25 ((16 & available) & I24)
#define dataBit1Or (((G24^G25)^G23)^G22)
//
#if dataBit1Or == 128
#define dataBit1 7;
#elif dataBit1Or == 64
#define dataBit1 6;
#elif dataBit1Or == 32
#define dataBit1 5;
#else
#define dataBit1 4
#endif
Ttelmah



Joined: 11 Mar 2010
Posts: 19605

View user's profile Send private message

PostPosted: Mon Aug 10, 2015 5:03 am     Reply with quote

Seriously, number of defines is not the problem. There are several hundred in the include file for the processor.

Odds are you have something 'recursive'. A define that depends on another define, that depends on another define, that depend in some way on the first define. So the compiler works round the loop trying to calculate the value, and gets stuck....

I'd say rethink the logic of what you are doing. The defines you list really are a mess.
temtronic



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

View user's profile Send private message

PostPosted: Mon Aug 10, 2015 5:15 am     Reply with quote

I have to second Mr. t on this ! Just trying to 'play compute' to figure out what 'datbit10r' is hurt my head.
If you give us an example of what you're trying to do others can show you a simpler, faster, cleaner way of doing it.

Jay
Mortenc



Joined: 22 Feb 2007
Posts: 55

View user's profile Send private message

PostPosted: Mon Aug 10, 2015 6:29 am     Reply with quote

Thanks for your responds.
All the pre-calculations is taken from an excel-document which is made with microprocessor friendly math like shift, AND, OR and some IF decisions.
These calculations shall be used in a special encoding based of the protocol number. Then the idea is that you only have to change the protocol number, and then get the new encoding.
Of course I could take all pre-calculated values from the Excel document so the compiler not should make these, but it will be more easy if the compiler could make these calculation when I want to make a new protocol encoding.
So maybe if I could control the compiler to finish some #define first before it go to further #defines.
Ttelmah



Joined: 11 Mar 2010
Posts: 19605

View user's profile Send private message

PostPosted: Mon Aug 10, 2015 8:23 am     Reply with quote

Defines are not 'dealt with'. They are a simple text macro substitution. Nothing else.

What happens is each one is effectively typed 'in' where it is used to build the final statement. So dataBit1Or expands to a sequence that it something over several hundred characters long.
So in fact splitting the maths up into dozens of little sub bits, just makes the expansion more bulky. Put the actual formula in directly. It'll be shorter.

The sequence that results, is then treated from the inside out (inner bracket), and solved as far as possible to generate the final value. This is the constant collapse.
Mortenc



Joined: 22 Feb 2007
Posts: 55

View user's profile Send private message

PostPosted: Mon Aug 10, 2015 1:19 pm     Reply with quote

Thanks for your explanation of the problem Ttelmah.
I have just made the same calculations as were made in the excel document by another person. In the excel these calculation are tested and worked as it should.
Whether I can make the same special encoding by another way I need to study.
Thanks for your good explanations. I learn more every time.
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