sqrt_rnd.m
来自「intlab 工具用于快速计算 各各层的倒数等等」· M 代码 · 共 36 行
M
36 行
function y = sqrt_rnd(x,rnd)
%SQRT_RND Rigorous bounds for sqrt(x) according to round
%
% y = sqrt_rnd(x,rnd)
%
% x may be vector, assumed to be nonnegative, rnd is -1 or +1, rounding unchanged after use.
% Routine necessary because Matlab-sqrt not IEEE 754 but seemingly always round to nearest.
%
% written 01/20/03 S.M. Rump
%
global INTLAB_INTVAL_ETA
y = sqrt(x);
switch rnd
case -1
setround(1)
index = ( y.*y>x );
while any(index(:))
setround(-1)
y(index) = y(index) - INTLAB_INTVAL_ETA;
setround(1)
index = ( y.*y>x );
end
case 1
setround(-1)
index = ( y.*y<x );
while any(index(:))
setround(1)
y(index) = y(index) + INTLAB_INTVAL_ETA;
setround(-1)
index = ( y.*y<x );
end
end
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?