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 + -
显示快捷键?