Receiving Errors On Matrix Dimensions
1 view (last 30 days)
Show older comments
Hello, I am unsure if I am making a simple mistake but I am receiving errors for matrix size within my equation code. Here is the code:
for
Z = 0.1
W_n = 2.5;
B = sqrt(1 - Z^2);
Theta = atan(B/Z);
c(t) = 1 - (1/B) * exp(1) .^ -(Z * W_n * t) * sin(B * W_n * t + Theta);
end
I am receiving these error messages:
Error using * Inner matrix dimensions must agree.
Error in FeedbackControlSystem (line 65) c(t) = 1 - (1/B) * exp(1) .^ -(Z * W_n * t) * sin(B * W_n * t + Theta);
Error using ^ One argument must be a square matrix and the other must be a scalar. Use POWER (.^) for elementwise power.
Error in FeedbackControlSystem (line 65) c(t) = 1 - (1/B) * exp(1)^-(Z * W_n * t) * sin(B * W_n * t + Theta);
Any help would be greatly appreciated. Thank you!
7 Comments
Accepted Answer
Ameer Hamza
on 24 Apr 2018
From your code in the comment section, It can be seen that you are making a couple of mistakes.
- t contain non-integers and thus can't be used to index c. In fact in this case you don't need to initialize c with zeros since it will not bring any speed up. Pre-allocation is only useful if your array size is changing in every loop iteration, here you can avoid that as given in below code snippet.
- Not taking care of matrix dimension when multiplying. In MATLAB * is for matrix multiplication and .* is for element-wise multiplication. (exp(1) .^ -(Z * W_n .* t)) is 1*360000 and (sin(B * W_n .* t + Theta))) is also 1*360000. Therefore you need .* operation between them.
t = linspace(1,3600,360000);
Z = 0.1;
W_n = 2.5;
B = sqrt(1 - Z^2);
Theta = atan(B/Z);
c = 1 - ((1/B) * (exp(1) .^ -(Z * W_n .* t)) .* (sin(B * W_n .* t + Theta)));
4 Comments
Ameer Hamza
on 24 Apr 2018
Yes, t and c have same dimensions. But the range of t is rather too large to see anything useful in plot. You might want to reduce the range of t.
More Answers (0)
See Also
Categories
Find more on Creating and Concatenating Matrices 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!