Funcții zecimale în Python | Setul 1
Python, în definiția sa, oferă anumite metode pentru a efectua o aritmetică zecimală cu virgulă mobilă mai rapidă folosind modulul „zecimal”.
Operații importante cu zecimale
1. sqrt() :- Această funcție calculează rădăcină pătrată a numărului zecimal.
2. exp() :- Această funcție returnează e^x (exponent) a numărului zecimal.
# Python code to demonstrate the working of # sqrt() and exp() # importing 'decimal' module to use decimal functions import decimal # using exp() to compute the exponent of decimal number a = decimal . Decimal ( 4.5 ) . exp () # using sqrt() to compute the square root of decimal number b = decimal . Decimal ( 4.5 ) . sqrt () # printing the exponent print ( 'The exponent of decimal number is : ' end = '' ) print ( a ) # printing the square root print ( 'The square root of decimal number is : ' end = '' ) print ( b )
Ieșire:
The exponent of decimal number is : 90.01713130052181355011545675
The square root of decimal number is : 2.121320343559642573202533086Python
3. ln() :- Această funcție este folosită pentru a calcula logaritmul natural a numărului zecimal.
4. log10() :- Această funcție este folosită pentru a calcula jurnal (baza 10) a unui număr zecimal.
# Python code to demonstrate the working of # ln() and log10() # importing 'decimal' module to use decimal functions import decimal # using ln() to compute the natural log of decimal number a = decimal . Decimal ( 4.5 ) . ln () # using sqrt() to compute the log10 of decimal number b = decimal . Decimal ( 4.5 ) . log10 () # printing the natural logarithm print ( 'The natural logarithm of decimal number is : ' end = '' ) print ( a ) # printing the log10 print ( 'The log(base 10) of decimal number is : ' end = '' ) print ( b )Ieșire:
The natural logarithm of decimal number is : 1.504077396776274073373258352
The log(base 10) of decimal number is : 0.6532125137753436793763169118
5. ca_tuplu() :- Returnează numărul zecimal ca un tuplu care conține 3 argumente semnul (0 pentru + 1 pentru -) cifre și valoarea exponentului .
6. fma(ab) :- Acest „fma” înseamnă topite înmulțiți și adăugați . Se calculează (num*a)+b din numerele în argument. Fără rotunjire a (num*a) are loc în această funcție.
Exemplu:
decimal.Decimal(5).fma(23) --> (5*2)+3 = 13Python
# Python code to demonstrate the working of # as_tuple() and fma() # importing 'decimal' module to use decimal functions import decimal # using as_tuple() to return decimal number as tuple a = decimal . Decimal ( - 4.5 ) . as_tuple () # using fma() to compute fused multiply and addition b = decimal . Decimal ( 5 ) . fma ( 2 3 ) # printing the tuple print ( 'The tuple form of decimal number is : ' end = '' ) print ( a ) # printing the fused multiple and addition print ( 'The fused multiply and addition of decimal number is : ' end = '' ) print ( b )Ieșire:
The tuple form of decimal number is : DecimalTuple(sign=1 digits=(4 5) exponent=-1)
The fused multiply and addition of decimal number is : 13Python
7. compara() :- Această funcție este folosită pentru a compara numere zecimale. Returnează 1 dacă primul argument zecimal este mai mare decât al doilea -1 dacă primul argument zecimal este mai mic decât al doilea și 0 dacă ambele sunt egale.
8. compare_total_mag() :- Compară mărimea totală a numerelor zecimale. Returnează 1 dacă primul argument zecimal este mai mare decât al 2-lea (semnul ignorând) -1 dacă primul argument zecimal este mai mic decât al 2-lea (semnul ignorând) și 0 dacă ambele sunt egale (semnul ignorând).
# Python code to demonstrate the working of # compare() and compare_total_mag() # importing 'decimal' module to use decimal functions import decimal # Initializing decimal number a = decimal . Decimal ( 9.53 ) # Initializing decimal number b = decimal . Decimal ( - 9.56 ) # comparing decimal numbers using compare() print ( 'The result of comparison using compare() is : ' end = '' ) print ( a . compare ( b )) # comparing decimal numbers using compare_total_mag() print ( 'The result of comparison using compare_total_mag() is : ' end = '' ) print ( a . compare_total_mag ( b ))Ieșire:
The result of comparison using compare() is : 1
The result of comparison using compare_total_mag() is : -1Python
9. copy_abs() :- Această funcție imprimă absolut valoarea argumentului zecimal.
10. copy_negate() :- Această funcție imprimă negare de argument zecimal.
11. copy_sign() :- Această funcție imprimă primul argument prin copierea semnului din al 2-lea argument .
# Python code to demonstrate the working of # copy_abs()copy_sign() and copy_negate() # importing 'decimal' module to use decimal functions import decimal # Initializing decimal number a = decimal . Decimal ( 9.53 ) # Initializing decimal number b = decimal . Decimal ( - 9.56 ) # printing absolute value using copy_abs() print ( 'The absolute value using copy_abs() is : ' end = '' ) print ( b . copy_abs ()) # printing negated value using copy_negate() print ( 'The negated value using copy_negate() is : ' end = '' ) print ( b . copy_negate ()) # printing sign effected value using copy_sign() print ( 'The sign effected value using copy_sign() is : ' end = '' ) print ( a . copy_sign ( b ))Ieșire:
The absolute value using copy_abs() is : 9.5600000000000004973799150320701301097869873046875
The negated value using copy_negate() is : 9.5600000000000004973799150320701301097869873046875
The sign effected value using copy_sign() is : -9.5299999999999993605115378159098327159881591796875Python
12. max() :- Această funcție calculează maxim din două numere zecimale.
13. min() :- Această funcție calculează minim din două numere zecimale.
# Python code to demonstrate the working of # min() and max() # importing 'decimal' module to use decimal functions import decimal # Initializing decimal number a = decimal . Decimal ( 9.53 ) # Initializing decimal number b = decimal . Decimal ( 7.43 ) # printing minimum of both values print ( 'The minimum of two numbers is : ' end = '' ) print ( a . min ( b )) # printing maximum of both values print ( 'The maximum of two numbers is : ' end = '' ) print ( a . max ( b ))Ieșire:
The minimum of two numbers is : 7.429999999999999715782905696
The maximum of two numbers is : 9.529999999999999360511537816