Return an n-dimensional array whose elements are the results of a function over a set of vectors.
The (i,j,k, ...n)th element of the output matrix is the results of executing the function on the ith element of the first vector, jth element of the second, and so forth. The function will be passed in, accepts n arguments, and returns a single number.
For example, if the function is:
minus12 = @(a) a(1)-a(2);
and the inputs are:
as = [1 3 5 7];
bs = [0 1 2 3 4];then the output would be:
>> gridit(minus12, as, bs)
ans =
1 0 -1 -2 -3
3 2 1 0 -1
5 4 3 2 1
7 6 5 4 3
Solution Stats
Problem Comments
Solution Comments
Show commentsProblem Recent Solvers19
Suggested Problems
-
3997 Solvers
-
Find state names that end with the letter A
1197 Solvers
-
Find third Side of a right triangle given hypotenuse and a side. No * - or other functions allowed
252 Solvers
-
Detect a number and replace with two NaN's
199 Solvers
-
Calculate the height of an object dropped from the sky
284 Solvers
More from this Author3
Problem Tags
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!
I'd like to include the test case listed below, but I'm stumped as to why it doesn't work:
%%
x1 = [ 1 2 3 ]
x2 = [ 10 20 ]
y_correct = [9 19; 8 18; 7 17]
y_actual = gridit(@minus, x1, x2);
assert(isequal(y_actual, y_correct));
Alex, I believe it is because the 'minus' function requires two input arguments. The test cases and the example use functions that accept a single input argument. Hope that helps.