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

MATLAB/SIMULINK Code Generation with CCS
Goto page 1, 2  Next
 
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion
View previous topic :: View next topic  
Author Message
Cyberian



Joined: 06 May 2017
Posts: 7

View user's profile Send private message

MATLAB/SIMULINK Code Generation with CCS
PostPosted: Sun May 07, 2017 8:16 pm     Reply with quote

Hi, I use matlab and simulink to generate code, both in diagrams and in stateflow. I use it perfectly with uVision for ARM, XC8 for pic18 and XC16 for dsPIC and HDL for my Spartan and Virtex. First of all I had a hard time generating a compilation with several compilation units. Once I did this, I wanted to use matlab-generated code, as I've been doing so far. The thing is, I do not hit the ball with CCS.
The issue is that with CCS, everything is more complicated. Is it possible to use the code generated by matlab ? In all the other compilers you can, and honestly you save thousands of complex lines of code, even implementing Kalman, LQG control etc., etc. is very simple with code generation.
I am currently using the dsPIC33EP512GM706.
CCS complies with the C99 standard ? Wth XC16, in order to use Simulink Coder, I must add to the compiler directives: -std = c99. In CCS is there any way to use the generated code?

Best Regards,
Sylvestre.


Last edited by Cyberian on Mon May 08, 2017 6:08 am; edited 1 time in total
Ttelmah



Joined: 11 Mar 2010
Posts: 19588

View user's profile Send private message

PostPosted: Mon May 08, 2017 12:41 am     Reply with quote

Try it.
Just make sure you set the ANSI directive in CCS.
Generally the core code from Matlab, will work if you use the ANSI directive in CCS. A little depends on the compiler version, and it can have problems if you start using complex variable types. I found that static variable allocation always worked better than the dynamic forms.
The ANSI setting is vital though. Otherwise things like the CCS meaning of const, will 'bite you'.
I found it worked much better to just generate the code block as readable C code, and include this into a CCS project, rather than have the compilation done through Matlab.
It was a couple of years ago that I played with it, it may have improved since in this area.
RF_Developer



Joined: 07 Feb 2011
Posts: 839

View user's profile Send private message

PostPosted: Mon May 08, 2017 4:55 am     Reply with quote

We are not CCS. This is a user self-help forum with no input, other than moderation, from CCS. As such passive-aggressive threats to use other compilers has little effect on us. My advice is to use whatever tools you feel are most appropriate to your applications and business model.

Personally I would never use any auto-generated code, no matter what source, blindly. I expect that it will always need and could generally do with some sort of optimisation to best suit the environment in which it is intended to run. in any case, wherever possible, its useful to understand the complexities of any code that you use. One issue that instantly springs to mind is that most PICs have very limited dynamic memory available, and that auto-generated code may well tend to make liberal use of dynamic memory, assuming a large, Gbytes, flat memory space, rather than the few kbytes that are available on most PICs. Also the way ANSI compilation mode is implemented means it generally uses more RAM than native mode would have done, putting further pressure on already limited meory space.

I do not know the full details of CCS C C99 compatibility. There is an ANSI compatibility mode. I don't know which ANSI C it most closely matches. I do know its not completely compatibile. There may be significant issues in some cases. I stress that's a may, and that you therefore exercise caution, and expect there may be a need to modify auto-generated code.

I suspect the best way to incorporate any such code is as a library or plug-in, depending on your frame of mind, and wrap it with whatever processor/target specific handwritten code that may be necessary. So, you set your code generation tool to generate your code as a library.

As Ttelmah says, try it and see.
Cyberian



Joined: 06 May 2017
Posts: 7

View user's profile Send private message

PostPosted: Mon May 08, 2017 6:11 am     Reply with quote

Ttelmah wrote:
Try it.
Just make sure you set the ANSI directive in CCS.
Generally the core code from Matlab, will work if you use the ANSI directive in CCS. A little depends on the compiler version, and it can have problems if you start using complex variable types. I found that static variable allocation always worked better than the dynamic forms.
The ANSI setting is vital though. Otherwise things like the CCS meaning of const, will 'bite you'.
I found it worked much better to just generate the code block as readable C code, and include this into a CCS project, rather than have the compilation done through Matlab.
It was a couple of years ago that I played with it, it may have improved since in this area.


Hi Ttelmah,
Thanks for answering. How do I add the ANSI directive to CCS? I am looking in the manual and still can not find anything. I will continue investigating, but if you can help me in that I will thank you.

Best regards,
Sylvestre.
temtronic



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

View user's profile Send private message

PostPosted: Mon May 08, 2017 6:15 am     Reply with quote

I'm with RF-D and do NOT use ANY 'wizard' generated code. Frankly no 'high level' code genny can replace a good human code cutter. This site is filled with posts that the 'wizard' or 'simulator' created doesn't work in the Real World. Most programmers will have built their own libraries of drivers, functions, etc. over the years (decades to some of us) and have tweaked the code to be the best it can be.
The huge problem with the 'wizards' is that they are based on someone else's idea as to what it 'correct'. If 'tight', they won't work for you, if 'flexible', they chew up a LOT of code space and clock cycles....aka bad programming.

Jay
Ttelmah



Joined: 11 Mar 2010
Posts: 19588

View user's profile Send private message

PostPosted: Mon May 08, 2017 7:30 am     Reply with quote

#device ANSI

At the top of the code (after the processor include).
newguy



Joined: 24 Jun 2004
Posts: 1911

View user's profile Send private message

PostPosted: Mon May 08, 2017 7:46 am     Reply with quote

RF_Developer wrote:
Personally I would never use any auto-generated code, no matter what source, blindly.


My personal motto is "never trust anything you didn't write yourself."

Along those lines, I've been bitten by Linux (both drivers and the gnu compiler) so many times.... The ironic aspect is that I've barely used Linux - only when I was literally forced to by the circumstances - and I've discovered so many bugs. Just because something is open source doesn't mean that the people playing with it know what they're doing.
Cyberian



Joined: 06 May 2017
Posts: 7

View user's profile Send private message

PostPosted: Mon May 08, 2017 7:50 am     Reply with quote

The code generated by matlab is very good, I always check it and never need to change anything, it is wonderful, since it is the same implementation of the diagrams in blocks. Besides the great advantage is STATEFLOW, you can make very long and complex state machines, that doing them manually would take a lot of time and it would be tedious to debug. Please stop attacking the automatically generated code, it is really efficient and it is the future in the big developments. Move forward with technology!
I entered because I need help finding the way to use the code generated by matlab with CCS. In the industry it is good to implement certain standards of good programming like MISRA 2012, the code generated by Matlab complies with these rules of good programming, in addition to generating security code for automotive implementation. We use code generation on all our development platforms, ARM, FPGA, Texas DSP, in particular Delfino and Piccolo, dsPIC33E and PICs 16 and 18. It really saves us a lot of code, we can make more complex developments in less time.
I keep trying, but without results, now I'll start verifying which part of the generated code is not CCS compliant.
I will comment on progress and if I make it work, I will upload a complete project with code generator.

Best regards,
Sylvestre.
Cyberian



Joined: 06 May 2017
Posts: 7

View user's profile Send private message

PostPosted: Mon May 08, 2017 7:56 am     Reply with quote

Ttelmah wrote:
#device ANSI

At the top of the code (after the processor include).


Hi Ttelmah,
Thanks for answering.
Yes, I tried with that directive and still nothing, I found it in the CCS manual, page 94, but still unable to compile. Something that also delayed me a little was the compilation of multiple units, but I think I have overcome it.
I'll keep trying.

Best regards,
Sylvestre.
Ttelmah



Joined: 11 Mar 2010
Posts: 19588

View user's profile Send private message

PostPosted: Mon May 08, 2017 8:00 am     Reply with quote

I would not use multiple units.
This reduces the efficiency of CCS.

As I already said, and others are also saying, the way to do this is to have a CCS project, and compile this. Tell MATLAB to generate readable C code, and then include this code into the CCS project.
All you then have to do is have your CCS code setup the variables, and call the Matlab functions.
Cyberian



Joined: 06 May 2017
Posts: 7

View user's profile Send private message

PostPosted: Mon May 08, 2017 8:08 am     Reply with quote

Ttelmah wrote:
I would not use multiple units.
This reduces the efficiency of CCS.

As I already said, and others are also saying, the way to do this is to have a CCS project, and compile this. Tell MATLAB to generate readable C code, and then include this code into the CCS project.
All you then have to do is have your CCS code setup the variables, and call the Matlab functions.


Hi Ttelmah,
Thank you for your response, I will implement what you are telling me.
I will comment on the progress.

Best regards,
Sylvestre.
jeremiah



Joined: 20 Jul 2010
Posts: 1358

View user's profile Send private message

PostPosted: Mon May 08, 2017 10:45 am     Reply with quote

I have a general question here:

If you are using a code generator to make the code, and you have it working for XC16, then why are you looking to have it compile in CCS? If you aren't going to mess with the generated code, then the compiler shouldn't matter as long as you can get the hex file at the end to program your PIC.

I'm not saying don't use CCS, but am curious as to the reasoning.
Cyberian



Joined: 06 May 2017
Posts: 7

View user's profile Send private message

PostPosted: Mon May 08, 2017 12:07 pm     Reply with quote

jeremiah wrote:
I have a general question here:

If you are using a code generator to make the code, and you have it working for XC16, then why are you looking to have it compile in CCS? If you aren't going to mess with the generated code, then the compiler shouldn't matter as long as you can get the hex file at the end to program your PIC.

I'm not saying don't use CCS, but am curious as to the reasoning.


I want to use CCS for what I said before, it is faster to configure the peripherals of the microcontroller, one line of code initializes the ADC module and another the PWM, another the UART, etc (using PCD Wizard). With Microchip you had the peripheral library, but it was never reliable, and no longer support. Also the dsPIC we use is not in MPLAB Code Configurator, which is also a powerful tool for configuring PICs.

Regards,
Sylvestre.
temtronic



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

View user's profile Send private message

PostPosted: Mon May 08, 2017 12:20 pm     Reply with quote

Be careful when invoking the 'Wizard'. It is known(reported here..) that it doesn't set the correct bits for certain registers for certain chips. Just something to be aware of. So if your code doesn't run as expected, dump the listing and check to see if the bits are being properly coded.

Jay
Cyberian



Joined: 06 May 2017
Posts: 7

View user's profile Send private message

PostPosted: Mon May 08, 2017 12:38 pm     Reply with quote

temtronic wrote:
Be careful when invoking the 'Wizard'. It is known(reported here..) that it doesn't set the correct bits for certain registers for certain chips. Just something to be aware of. So if your code doesn't run as expected, dump the listing and check to see if the bits are being properly coded.

Jay


Hi temtronic,
Yes, I consider that, in fact, I print the registers by UART, to see how CCS configured them, and I use that information to learn faster about the dsPIC registers, and I can copy the configuration to XC16 or modify some Bit if it is not good.
I've had those kind of problems with some PIC18, which did not configure me well some registers the PCW Wizard.

Best regards,
Sylvestre
Display posts from previous:   
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion All times are GMT - 6 Hours
Goto page 1, 2  Next
Page 1 of 2

 
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