error using zeros,integers problem
조회 수: 5 (최근 30일)
이전 댓글 표시
i have this code
x = 1 +((riskf_end - riskf_start)/riskf_step);
y = 1 +((volatility_end - volatility_start)/volatility_step);
A = zeros(1 + x, 1 + y);
x and y are integers but the output of y is in exp notation and the 'zeros' command takes y as non integer. i can't figure this out.I tried 'format long g' but again the matrix does not recognize y as an integer.
ex.
riskf_end = 0.04
riskf_start = 0
riskf_step = 0.001
volatility_start = 0.13
volatility_step = 0.0001
volatility_end = 0.25
when putting volatility_step = 0.001 the problem disappears, but for smaller steps it apears again.x and y are always integers as the step will always be smaller than the boundaries. I would appriciate any help.Thanks in advance.
댓글 수: 0
채택된 답변
Mischa Kim
2016년 9월 9일
Why not simply round the numbers, e.g.
A = zeros(1 + round(x), 1 + round(y));
댓글 수: 4
Guillaume
2016년 9월 9일
편집: Guillaume
2016년 9월 9일
@Kostas, I think you misunderstood Mischa. He's telling you to round the inputs you give to the zeros function (so x and y), not your original values ( the riskf_* and volatility_* which obviously have to stay what they are).
The problem you are encountering is that, even if the numbers are symbolically integer, since computers can only store an approximate representation of most numbers, you have small rounding errors that means the result of calculation is often not exactly integer. As point out by Mischa, your y is 0.00000000000181... off from the integer 12001.
You can't avoid that, so if the result is meant to be integer, simply round it to integer.
Note that playing with format will have absolutely no effect on the actual value of the number. format only changes the way matlab displays numbers to you, not how they are stored in memory.
추가 답변 (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!