summaryrefslogtreecommitdiff
path: root/ext/bigdecimal/lib/bigdecimal-rational.rb
blob: de999d19cf4900ca88abb011d75540e0778e7be6 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
#
# BigDecimal <-> Rational 
#
class BigDecimal
    # Convert BigDecimal to Rational
    def to_r 
       sign,digits,base,power = self.to_parts
       numerator = sign*digits.to_i
       denomi_power = power - digits.size # base is always 10
       if denomi_power < 0
          denominator = base ** (-denomi_power)
       else
          denominator = base ** denomi_power
       end
       Rational.new(numerator,denominator)
    end
end

class Rational
  # Convert Rational to BigDecimal
  # to_d returns an array [quotient,residue]
  def to_d(nFig=0)
     num = self.numerator.to_s
     if nFig<=0
        nFig = BigDecimal.double_fig*2+1
     end
     BigDecimal.new(num).div(self.denominator,nFig)
  end
end