finding a number that satisfies given conditions
조회 수: 3 (최근 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!