Mini Shell
�
�>�b�w�� �� � d Z ddlmZ ddlZddlZddlZddlZddlZdgZej j
Zej j Z
ej dej ej z � � Z G d� dej � � ZdS )z/Fraction, infinite-precision, rational numbers.� ��DecimalN�Fractiona�
\A\s* # optional whitespace at the start,
(?P<sign>[-+]?) # an optional sign, then
(?=\d|\.\d) # lookahead for digit or .digit
(?P<num>\d*|\d+(_\d+)*) # numerator (possibly empty)
(?: # followed by
(?:/(?P<denom>\d+(_\d+)*))? # an optional denominator
| # or
(?:\.(?P<decimal>\d*|\d+(_\d+)*))? # an optional fractional part
(?:E(?P<exp>[-+]?\d+(_\d+)*))? # and optional exponent
)
\s*\Z # and optional whitespace to finish
c �l � � e Zd ZdZdZd.dd�� fd�Zed� � � Zed � � � Zd
� Z d/d�Z
ed
� � � Zed� � � Z
d� Zd� Zd� Zd� Z eeej � � \ ZZd� Z eeej � � \ ZZd� Z eeej � � \ ZZd� Z eeej � � \ Z Z!d� Z" ee"ej# � � \ Z$Z%d� Z& ee&e'� � \ Z(Z)d� Z* ee*ej+ � � \ Z,Z-d� Z.d� Z/d� Z0d� Z1d� Z2ej3 fd�Z4d� Z5d � Z6d!� Z7d0d"�Z8d#� Z9d$� Z:d%� Z;d&� Z<d'� Z=d(� Z>d)� Z?d*� Z@d+� ZAd,� ZBd-� ZC� xZDS )1r a] This class implements rational numbers.
In the two-argument form of the constructor, Fraction(8, 6) will
produce a rational number equivalent to 4/3. Both arguments must
be Rational. The numerator defaults to 0 and the denominator
defaults to 1 so that Fraction(3) == 3 and Fraction() == 0.
Fractions can also be constructed from:
- numeric strings similar to those accepted by the
float constructor (for example, '-2.3' or '1e10')
- strings of the form '123/456'
- float and Decimal instances
- other Rational instances (including integers)
��
_numerator�_denominatorr NT��
_normalizec �� �� t t | � � � | � � }|���t |� � t u r||_ d|_ |S t |t j � � r|j
|_ |j |_ |S t |t t f� � r#|� � � \ |_ |_ |S t |t � � �r/t � |� � }|�t% d|z � � �t |� d� � pd� � }|� d� � }|rt |� � }n�d}|� d� � }|rB|� dd � � }d
t+ |� � z }||z t |� � z }||z }|� d� � } | r't | � � } | dk r |d
| z z }n |d
| z z }|� d
� � dk r| }n�t- d� � �t |� � t cxu rt |� � u rn nnbt |t j � � r9t |t j � � r|j
|j z |j
|j z }}nt- d� � �|dk rt/ d|z � � �|r(t1 j ||� � }
|dk r|
}
||
z }||
z }||_ ||_ |S )a� Constructs a Rational.
Takes a string like '3/2' or '1.5', another Rational instance, a
numerator/denominator pair, or a float.
Examples
--------
>>> Fraction(10, -8)
Fraction(-5, 4)
>>> Fraction(Fraction(1, 7), 5)
Fraction(1, 35)
>>> Fraction(Fraction(1, 7), Fraction(2, 3))
Fraction(3, 14)
>>> Fraction('314')
Fraction(314, 1)
>>> Fraction('-35/4')
Fraction(-35, 4)
>>> Fraction('3.1415') # conversion from numeric string
Fraction(6283, 2000)
>>> Fraction('-47e-2') # string may include a decimal exponent
Fraction(-47, 100)
>>> Fraction(1.47) # direct construction from float (exact conversion)
Fraction(6620291452234629, 4503599627370496)
>>> Fraction(2.25)
Fraction(9, 4)
>>> Fraction(Decimal('1.47'))
Fraction(147, 100)
N� z Invalid literal for Fraction: %r�num�0�denom�decimal�_� �
�expr �sign�-z2argument should be a string or a Rational instancez+both arguments should be Rational instanceszFraction(%s, 0))�superr �__new__�type�intr r �
isinstance�numbers�Rational� numerator�denominator�floatr �as_integer_ratio�str�_RATIONAL_FORMAT�match�
ValueError�group�replace�len� TypeError�ZeroDivisionError�math�gcd)�clsr r r �self�mr r �scaler �g� __class__s ��0/opt/alt/python311/lib64/python3.11/fractions.pyr zFraction.__new__>