We present an implementation of double precision interval arithmetic using the single-instruction-multiple-data SSE-2 instruction and register set extensions. The implementation is part of a package for exact real arithmetic, which defines the interval arithmetic variation that must be used: incorrect operations such as division by zero cause exceptions and loose evaluation of the operations is in effect. The SSE-2 extensions are suitable for the job, because they can be used to operate on a pair of double precision numbers and include separate rounding mode control and detection of the exceptional conditions. The paper describes the ideas we use to fit interval arithmetic to this set of instructions, shows a performance comparison with other freely available interval arithmetic packages, and discusses possible very simple hardware extensions that can significantly increase the performance of interval arithmetic.
[1]
Guillaume Melquiond,et al.
The Boost Interval Arithmetic Library
,
2003
.
[2]
D. B. Davis,et al.
Intel Corp.
,
1993
.
[3]
R. B. Kearfott,et al.
Interval Computations: Introduction, Uses, and Resources
,
2000
.
[4]
IEEE standard for binary floating-point arithmetic - IEEE standard 754-1985
,
1985
.
[5]
Branimir Lambov.
RealLib: An efficient implementation of exact real arithmetic
,
2007,
Math. Struct. Comput. Sci..
[6]
Jürgen Wolff von Gudenberg.
Interval Arithmetic on Multimedia Architectures
,
2002,
Reliab. Comput..