Rational data typeSome programming languages provide a built-in (primitive) rational data type to represent rational numbers like 1/3 and −11/17 without rounding, and to do arithmetic on them. Examples are the RepresentationA variable or value of that type is usually represented as a fraction m/n where m and n are two integer numbers, either with a fixed or arbitrary precision. Depending on the language, the denominator n may be constrained to be non-zero, and the two numbers may be kept in reduced form (without any common divisors except 1). Languages that support a rational data type usually provide special syntax for building such values, and also extend the basic arithmetic operations ('+', '−', '×', '/', integer powers) and comparisons ('=', '<', '>', '≤') to act on them — either natively or through operator overloading facilities provided by the language. These operations may be translated by the compiler into a sequence of integer machine instructions, or into library calls. Support may also extend to other operations, such as formatting, rounding to an integer or floating point value, etc.. As in mathematics, those languages often interpret an integer value as equivalent to a rational value with a unit denominator. Language supportBuilt-in or core library:
With external libraries:
Common LispCommon Lisp provides a numeric data type for arbitrarily sized rational numbers: RATIO.[7] 1/3
⇒ 1/3
The type of a rational number is (type-of 1/3)
⇒ RATIO
Dividing two integers may return a rational number and the multiplication of a rational number may return an integer number: (/ 6 8)
⇒ 3/4
(* 3/4 16)
⇒ 12
The numerator and denominator may be obtained using the homonymous functions, that reduce a rational to canonical form and compute the numerator or denominator of that form respectively:[8] (numerator 12/16)
⇒ 3
(denominator 12/16)
⇒ 4
Computing with large integers returning a large rational number: (/ (1- (expt 2 200)) (1- (expt 2 43)))
⇒ 1606938044258990275541962092341162602522202993782792835301375/8796093022207
Clojure(print (+ 1/10 2/10)) ⇒ 3/10 Juliajulia> 1//10 + 2//10
3//10
HaskellIn module Data.Ratio (1 % 10) + (2 % 10) ⇒ 3 % 10 Racket (PLT Scheme)> (+ 1/10 2/10)
3/10
RakuRaku provides my $v = 0.2;
say "{$v} is {$v.^name} and has numerator {$v.numerator} and denominator {$v.denominator}";
# ⇒ 0.2 is Rat and has numerator 1 and denominator 5
say 0.1 + 0.2
# ⇒ 0.3
say (0.1 + 0.2 - 0.3).fmt("%.17f")
# ⇒ 0.00000000000000000
say 1 / (0.1 + 0.2 - 0.3)
# ⇒ Attempt to divide by zero when coercing Rational to Str
RubyUsing special syntax in 2.1 or newer: irb(main):001:0> puts 1/10r + 2/10r
3/10
=> nil
References
|
Portal di Ensiklopedia Dunia