Привет Всем!
Я запрограммировал расчет одной периодической последовательности. Алгоритм очень простой: задаем начальное число x(0) < 1, следующие числа последовательности считаются следующим образом: x(n)=2 * x(n-1) и если полученный x(n) > 1 то x(n)=x(n) - 1.
Однако при вычислении последовательности с начальным значением 0.7 получается следующее:
0,7 0,4 0,8 0,6 0,199999999999999 0,399999999999999 0,799999999999997 0,599999999999994 0,199999999999989 0,399999999999977 0,799999999999954 0,599999999999909 и т.д.
Весь этот процесс быстро сходиться к единице, чего быть не должно.
Скажите пожалуйста, откуда вместо 0,2 появляется 0,199999999999999 и как этом можно убрать???
Код следующий: _________________________________________________________________
function bnf = bernoise(xs,l) % % Bernulli noise % Функция bernoise(xs,l) используется для вычисления значений % отображения Бернулли с начальным значением xs и длиной l % % Пример использования: % bn=bernoise(0.7,100);
bn=zeros(1,5000);
bn(1)=xs;
for n=2:1:length(bn)
bn(n)=2*bn(n-1);
if bn(n)>1 bn(n)=bn(n)-1; end
end
bnf=bn;
plot(bn); hold on;
|