Is there any error in my code?

1 view (last 30 days)
LAWRENCE DUMEBI
LAWRENCE DUMEBI on 9 Jun 2017
Edited: John BG on 11 Jun 2017
These are my codes to plot the graph of f(x, q) = (q^4/(q^3+6))(1+x^3)exp(-qx)
clear all
q = 0.4;
x = linspace(0,20);
for i = 1:length(x);
f(i) = (q^4/(q^3+6))*(1+x(i))*exp(-q*x(i));
end
plot(x,f,'linewidth',2)
xlabel(x)
ylabel('f(x)')
please reply me with the correction. Thanks.
  2 Comments
Adam
Adam on 9 Jun 2017
Edited: Adam on 9 Jun 2017
You are missing a ^3 from your code, but this really is something you should double-check yourself before asking other people!
You don't need a for loop either, you can just vectorise it, but if at the moment you are only at the level of for loops I will leave that aside.
You can also easily create a quick test script with correct results calculated by hand or by calculator to check whether your answer is right or not.
Jan
Jan on 9 Jun 2017
I've used the "{} Code" button to format your code, which was unreadable. Please do this by your own in the future - thanks.

Sign in to comment.

Accepted Answer

John BG
John BG on 11 Jun 2017
Edited: John BG on 11 Jun 2017
Hi Lawrence
even better, since you are after f(x,q) perhaps a 2D plot is more helpful
q = [0:.1:4];
x = linspace(0,20);
[Q,X]=meshgrid(q,x)
F = (Q.^4 ./ (Q.^3 + 6)) .* (1 + X.^3) .* exp(-Q .* X);
surf(F)
.
.
So Lawrence, if you find this answer useful would you please be so kind to consider marking my answer as Accepted Answer?
To any other reader, if you find this answer useful please consider clicking on the thumbs-up vote link
thanks in advance
John BG

More Answers (1)

Jan
Jan on 9 Jun 2017
Edited: Jan on 9 Jun 2017
The ^3 in (1+x^3) has been forgotton:
... (1+x(i)^3) ...
You can do this without a loop also:
x = linspace(0,20);
f = (q^4 / (q^3 + 6)) * (1 + x.^3) .* exp(-q * x);

Categories

Find more on Creating and Concatenating Matrices in Help Center and File Exchange

Tags

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!