finding a number that satisfies given conditions
1 次查看(过去 30 天)
显示 更早的评论
I need to find a floating point number x from the interval 1 < x < 2 such that: x ∗ (1/x) isn't equal to 1. I'ma beginner at Matlab and don't know how this can be done. I was given a clue that using integrals could help in solving this. Could anyone help me?
3 个评论
Walter Roberson
2013-10-25
编辑:Walter Roberson
2013-10-25
Multiplication, I would say. Looks like an exercise in exploring the limits of binary floating point representation.
回答(2 个)
Mike Hosea
2013-11-4
Integrals? Not sure about that. A random search will finish faster. There are LOTS. You can use LINSPACE to generate evenly spaced trial numbers, or you can us 1 + rand(1,n) to generate n random numbers between 1 and 2. Then you can check the condition using MATLAB's elementwise array operators: bool = x.*(1./x) ~= 1. Notice the .* instead of *, since * without the . is matrix multiplication. Same thing for division. Actually if you generate a boolean array that way from a set of trial numbers, you can also extract the results from your trial vector x using MATLAB's logical indexing, e.g. x(bool). Try it!
0 个评论
Walter Roberson
2013-11-4
Do a binary search over the interval realmin() to 1, to find the boundary point.
0 个评论
另请参阅
类别
在 Help Center 和 File Exchange 中查找有关 Logical 的更多信息
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!