📄 sqrt_rnd.m
字号:
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 + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -