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
2 Comments
Solution Comments
Show comments
Loading...
Problem Recent Solvers19
Suggested Problems
-
Replace NaNs with the number that appears to its left in the row.
3064 Solvers
-
322 Solvers
-
259 Solvers
-
Determine if input is a perfect number
260 Solvers
-
Create a Multiplication table matrix...
690 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.