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!