Mine sisu juurde

Ujukomaarv

Allikas: Vikipeedia
(Ümber suunatud leheküljelt Normaliseeritud ujukomaarv)

Ujukomaarv või liikuva komaga arv[1] (inglise keeles floating-point number) on andmetüüp, mis on loodud esitamaks väga suuri ja väga väikseid arve, mida oleks ebaotstarbekas esitada täisarvudena.

Ujukomaarv on paigutatav arvuti mällu kolme komponendi, märgi, arvu tüve ehk mantissi ja astendaja ehk eksponendiga. Ujukomaarvu väärtus avaldub korrutisena kujul .[2] Termin "ujukoma" viitab sellele, et komakoht on liigutatav – seda saab paigutada mantissi suhtes nii paremale kui ka vasakule.

Iga lõplik arv on kirjeldatud kolme komponendiga: . Lõpliku arvu väärtus on , kus b on astme alus.

Kahend-ujukomaarvud

[muuda | muuda lähteteksti]

Standardi IEEE 754 järgi esitatakse kahend-ujukomaarv kujul , kus M on arvu tüve ehk mantissi murdosa (fractional part)[3]. Arvuti mälus säilitatakse murdosa M, mitte tüvi (significand).

Arvu varjatud tüvenumber

[muuda | muuda lähteteksti]

Töötades kahendarvudega on arvu tüvel alati kindel arv bitte. Kuna normaliseeritud arvu kõige suurema kohakaaluga bitt on alati 1, siis seda arvuti mällu ei salvestata ja nimetatakse varjatud bitiks (hidden bit). Kontekstist sõltuvalt võib varjatud bitti võib arvu tüve hulka mitte arvestada. Näiteks IEEE 754 topelttäpsusega (double precision) vorming on tavaliselt 53-bitilise tüvega, millesse on arvestatud ka "varjatud bitt" või 52-bitilise tüvega, millesse ei ole arvestatud "varjatud bitti". Varjatud biti (hidden bit) mõiste kehtib ainult arvu kahendkujule. IEEE 745 määrab täpsuse p, mis peab olema kirjeldatud teatud arvu tüvenumbritega, kaasaarvatud tähenduseta järgnevad bitid (st. topelttäpsusega ujukomaarvu puhul p=53).

Väga nullilähedasi arve, mille puhul on vajalik nullist erinev varjatud bitt (hidden bit) kutsutakse "denormaliseeritud arvudeks" (Denormal number) või IEEE 745 järgi "subnormal number" [4][5][6]. Lahenduseks on arvu Bias [7] mahalahutamine astmenäitajast sõltuvalt esitatavast arvust.

Kümnend-ujukomaaarvud

[muuda | muuda lähteteksti]

Kümnendarve saab esitada täpselt kümnend-ujukomaarvudega. Näiteks arvudel 1,1 või 2,2 pole täpset vastet kahend-ujukomaarvudena. Lõppkasutaja ei soovi, et 1,1 + 2,2 annaks tulemuseks 3,3000000000000003 nagu kahend-ujukomaarvude puhul. Seetõttu kasutatakse mitmete programmeerimiskeelte interpretaatorites (Python[8], Java) ja ka mõnedes protsessorkiipides (näiteks IBM POWER6) kümnend-ujukomaarve (astmealusel 10)[9].

Normaliseeritud ujukomaarv

[muuda | muuda lähteteksti]

Normaliseeritud ujukomaarv on ujukomaarv, mille puhul kehtib 1 ≤ arvu tüvi < k, kus k on alus arvusüsteemile, milles arvu esitatakse.

Kahend-ujukomaaarvu normaliseerimine

[muuda | muuda lähteteksti]

Tehte tulemiks võib kujuneda mittenormaliseeritud arv. Lõpptulemuse saamiseks on vajalik tulem normaliseerida. Sõltuvalt mittenormaliseeritud mantissi väärtusest toimub normaliseerimine erinevalt[1]:

  • Kui mittenormaliseeritud mantiss > 1, siis tuleb mantissi nihutada üks koht paremale koos 1 lisamisega astmenäitajale
  • Kui mittenormaliseeritud mantiss < 1/2, siis tuleb mantissi nihutada r kohta vasakule nii, et positiivsel arvul oleks pärast koma esimese koha väärtuseks 1 ja negatiivsel arvul 0. Samas tuleb astmenäitajast lahutada r.
  1. 1,0 1,1 Digitaalseadmete aritmeetika ja loogika I. Ariste,A.; Loengukonspekt, Tallinna Polütehniline Instituut, Informatsioonitehnika kateeder, 95lk, TPI rotaprint, Tallinn, 1971
  2. Floating-Point Arithmetic
  3. "(Katkine link)". Originaali arhiivikoopia seisuga 17. jaanuar 2013. Vaadatud 23. detsembril 2019.
  4. Denormal number (ingliskeelne Vikipeedia)
  5. Floating Point Representation
  6. Denormal numbers in floating point signal processing applications
  7. Exponent bias (ingliskeelne Vikipeedia)
  8. decimal — Decimal fixed point and floating point arithmetic
  9. Decimal floating point (ingliskeelne Vikipeedia)

Välislingid

[muuda | muuda lähteteksti]