Error : Output argument "y" (and maybe others) not assigned during call to "N".
1 view (last 30 days)
Show older comments
I am currently working on building B spline curves basis function which is a recursive function. I am always getting this error Output argument "y" (and maybe others) not assigned during call to "N". Please let me know how to sort this.
function y = N(k,i,t,m)
%k is the order
%i is the pointer for the control point
%t (knot value) is the parameter used for defining a point on the curve
%m is the knot vector
% for the knot value t to be in between the ti and ti+k
if t < m(1,i+k+1)
if t > m(1,i+1)
if k == 1
y = 1;
end
for h = 2:1:k
y = ((((t - m(1,i+1))/ (m(1,i+h)- m(1,i+1)))* N(h-1,i,t,m)) + (((m(1,i+h+1) - t)/ (m(1,i+h+1)- m(1,i+2)))* N(h-1,i+1,t,m)));
end
else
y = 0;
end
end
end
1 Comment
Stephen23
on 8 Sep 2019
"Please let me know how to sort this."
Use consistent code indentation.
Your code is very badly indented. Badly indented code is one way that beginners hide bugs in their code, by making the logic of the code hard to understand.
Make your code easier to understand by using consistent indexing (e.g. the MATLAB default indexing: select all code text, ctrl+i). Then the reason for your unassigned output is obvious.
Answers (2)
Star Strider
on 7 Sep 2019
The easiest way is to assign a value to ‘y’ at the outset. It will be re-assigned if the if blocks allow it.
Example —
function y = N(k,i,t,m)
y = NaN;
%k is the order
... rest of the function code ...
end
Walter Roberson
on 7 Sep 2019
Reformat your code:
if t < m(1,i+k+1)
if t > m(1,i+1)
if k == 1
y = 1;
end
for h = 2:1:k
y = ((((t - m(1,i+1))/ (m(1,i+h)- m(1,i+1)))* N(h-1,i,t,m)) + (((m(1,i+h+1) - t)/ (m(1,i+h+1)- m(1,i+2)))* N(h-1,i+1,t,m)));
end
else
y = 0;
end
end
Notice that the else is associated with the inner if t > m(1,i+1) and so is not invoked in the case where t < m(1,i+k+1) is false. Therefore if t < m(1,i+k+1) is false, nothing is assigned to y.
2 Comments
See Also
Categories
Find more on Polynomials 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!