Perms output as trials to solve an equation
显示 更早的评论
Is there a way to use the perms output as the variable values of an equation and identify a unique solution?
For example, perms(1:2) gives [2 1; 1 2]
If I have an equation 4x + 2y, can I use the different values (x=2, y=1 and x=1, y=2) in an equation to determine a desired solution (i.e. 10)?
If I wanted to have a final value of 10, the identified values would x=2 and y=1.
回答(2 个)
Image Analyst
2014-4-30
I would not think so. What makes you think that you would happen to have the solution already in your list of numbers that you're going to make permutations of? If you want to do it numerically, you could use linspace() to make a list of values for x and y, then use meshgrid() to get every (x,y) coordinate in the space, then plug those x,y into your equation, then search for the coordinate that has a value closest to your desired value (10) with min() and ind2sub.
% Make x and y axes.
x=linspace(1,10,100);
y = linspace(1, 20, 100);
% Get x and y over the entire grid.
[xg, yg] = meshgrid(x, y);
% Make the equation for every x and y.
z = 4*xg + 2* yg
% Display it.
image(z);
colormap(gray);
colorbar
% Find where target value lives.
targetValue = 10;
diffMatrix = abs(z - targetValue);
[minDiff, linearIndex] = min(diffMatrix(:))
[row, col] = ind2sub(size(z), linearIndex)
7 个评论
Image Analyst
2014-4-30
B's "Answer" moved here:
Thanks for your reply.
I have an equation that has 6 variables in it, and the variables can take on the unique values 1 through 6. There are 720 permutations (6!) of values that the variables can take on, and I know that one arrangement will produce the unique solution that I'm looking for (final value of 10).
I'm hoping there's an easy way to determine the values of the variables which results in an answer of 10.
Image Analyst
2014-4-30
Well then I think that might work, though of course you could also use 6 nested for loops to do the same thing. Not sure which would be faster, though with only 720 they'll both be incredibly fast and you probably won't notice a difference.
B
2014-5-1
Star Strider
2014-5-1
Wouldn’t the matrix equation Ax = y work with gcd to help identify the integers? (Or maybe I’m once again missing something.)
Image Analyst
2014-5-1
Do you fully understand this section of the FAQ: http://matlab.wikia.com/wiki/FAQ#Why_is_0.3_-_0.2_-_0.1_.28or_similar.29_not_equal_to_zero.3F and how you need to test floating point numbers for "matching" values?
Image Analyst
2014-5-3
At the very inside of the 6 for loops, do this:
value = -402u^6 + 67v^5 + 48w^4 + 295x^3 - 720y^2 + 1145z - 14648;
if value == 10
foundAnswer = true;
message = sprintf('It is 10 for u=%d, v=%d, w=%d, x=%d, y=%d, z=%d',...
u,v,w,x,y,z);
uiwait(helpdlg(message));
break;
end
Before the 6 for loops have
foundAnswer = false;
and then at the end of each for loop, just before its end statement, you'll have:
if foundAnswer = true;
break;
end
类别
在 帮助中心 和 File Exchange 中查找有关 Matrix Indexing 的更多信息
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!