Converting Matlab code to C code
Show older comments
I'm trying to convert the following matlab code to c code, I did it both in windows and in linux systems by using Visual Studio in windows and gcc in linux as the compiler. However I couldn't get correct results by running the generated c code. Can anyone have a idea how to modify this matlab code in order to generate the matched c code? I would appreciate that!
function matc(n)
val = 0;
for i = 1:n
x = 2*rand(3,1);
val = val + f(x);
end
val = 2^3*val/n
6 Comments
Friedrich
on 29 Feb 2012
What is f ?
AW
on 29 Feb 2012
James Tursa
on 29 Feb 2012
Please format your code so it is readable. Is the function supposed to return val? Are you looking for a mex function, or just a C-language code snippet?
AW
on 29 Feb 2012
Kaustubha Govind
on 29 Feb 2012
How exactly do the results vary?
AW
on 29 Feb 2012
Answers (6)
Kaustubha Govind
on 1 Mar 2012
To expand's on Walter's answer, your MATLAB code should look like this:
function val = matc(n)
val = 0;
for i = 1:n
x = 2*rand(3,1);
val = val + f(x);
end
val = 2^3*val/n
function y = f(x)
y = sin(x(1) + x(2)^2 +x(3)^3);
(Note how 'val' is being returned from the function by adding it to the "function" line).
And your C code should look like this:
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#include "matc.h"
int main()
{
printf("matc=%g\n", matc(0.2));
return 0;
}
Note how an input value needs to be passed into matc.
Walter Roberson
on 29 Feb 2012
0 votes
You are not passing any value from the C code to the matc() routine. The initial value of an undefined parameter is undefined, so any result could occur.
AW
on 29 Feb 2012
0 votes
1 Comment
Walter Roberson
on 29 Feb 2012
Yes, having it declared as type double is fine, but you still need to pass a specific variable in to matc() when you make the call to matc()
printf("matc=%g\n", matc(42.));
AW
on 1 Mar 2012
0 votes
10 Comments
Walter Roberson
on 1 Mar 2012
What does your code look like at present?
AW
on 1 Mar 2012
Walter Roberson
on 1 Mar 2012
Looks plausible. I would put a line in matc() displaying the value of n at the beginning, to cross-check that you are getting the input you expect.
AW
on 2 Mar 2012
Kaustubha Govind
on 2 Mar 2012
Try putting a statement "disp(val)" at the bottom of your "matc" function and recompile the code. Does the MATLAB code display a zero too?
AW
on 2 Mar 2012
Walter Roberson
on 2 Mar 2012
So somehow the argument isn't getting passed in correctly, I don't know why at the moment.
Say, what does matc.h contain?
AW
on 2 Mar 2012
Walter Roberson
on 2 Mar 2012
Hmmm, I wonder if real_T is single or double precision?
And I wonder if the code generator is treating 1000 as integer?
Could I ask you to indulge my curiosity and try 1000. (with the perod to force syntactic floating point) ? And to also try with
single(1000) and double(1000) ?
AW
on 2 Mar 2012
AW
on 7 Mar 2012
0 votes
1 Comment
Kaustubha Govind
on 8 Mar 2012
AW: I would recommend using a "disp" command in your script. Since disp is not supported for code-generation, you need to add this line at the top of your function:
coder.extrinsic('disp');
%eml.extrinsic('disp') for older versions of MATLAB
Then, generate a MEX-file from your code (instead of standalone C code). You can use the command:
>> codegen -config:mex matc.m
Then run the generated MEX-file in MATLAB. What does the disp command show?
AW
on 21 Mar 2012
2 Comments
Kaustubha Govind
on 22 Mar 2012
Thanks for posting back your answer, AW. So what exactly was the error you were making before?
Walter Roberson
on 22 Mar 2012
The difference seems to be the %#codegen
Categories
Find more on MATLAB Coder in Help Center and File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!