The DecFP package is a Julia wrapper around the Intel Decimal Floating-Point Math Library, providing a software implementation of the IEEE 754-2008 Decimal Floating-Point Arithmetic specification.
32-bit, 64-bit, and 128-bit decimal floating-point types
Dec128, respectively, are provided. This is very
different from packages such as
Decimals.jl, which provide
arbitrary-precision decimal types analogous to
precision types are very flexible, but fixed-precision types such
as those in DecFP are much faster (though still about 100x slower than
the hardware binary floating-point types
The DecFP package currently requires the Julia 0.5 release or later.
Dec64 and the other types mentioned above can be constructed from
other Julia numeric types (binary floating-point or integers) via
Dec(3), from strings by
parse(Dec64, "3.2") or
d64"3.2" (a Julia string macro); similarly for
The string macro
Once a decimal float is constructed, most Julia arithmetic and
special functions should work without modification. For example,
d"3.2" * d"4.5" produces the
Most basic arithmetic functions are supported, and many special functions
log, trigonometric functions, etc.). Mixed operations
involving decimal and binary floating-point or integer types are supported
(the result is promoted to decimal floating-point).
In general, you should be able to use the
DecFP types in any context
where you would have used binary floating-point types: arrays, complex
arithmetic, and linear algebra should all work, for the most part.
3 months ago