(Translated by https://www.hiragana.jp/)
Kayan nokta - Vikipedi İçeriğe atla

Kayan nokta

Vikipedi, özgür ansiklopedi
00.29, 23 Aralık 2007 tarihinde Ahsenbahar (mesaj | katkılar) tarafından oluşturulmuş 2562351 numaralı sürüm

Kayan noktalı sayılar gerçel sayıların bilgisayar ortamındaki gösterim şekillerinden biridir. Gerçek dünyada sayılar sonsuza kadar giderken, bilgisayar ortamında bilgisayar donanımının getirdiği sınırlamalardan dolayı bütün sayıların gösterilmesi mümkün değildir. Bununla birlikte gerçekte sonsuza kadar giden birtakım değerler bilgisayar ortamında ortamın kapasitesine bağlı olarak yaklaşık değerlerle temsil edilirler. Bu sınırlamaların etkisini en aza indiren, sayıların maksimum miktarda ve gerçeğe en yakın şekilde temsilini sağlayan sisteme "Kayan-Noktalı Sayılar" sistemi denir. Kayan-Noktalı sayılar sistemi, bir sayı ile 10'un herhangi bir kuvvetinin çarpımı şeklinde sıklıkla kullanılan bilimsel gösterime oldukça benzeyen bir notasyona sahiptir ve en sık kullanılan IEEE 754 standardına göre şekillendirilmiştir.

Bilinen gösterim şekillerinde n bitlik kapasiteyle gösterilebilecek sayı aralığı bellidir. İşaretsiz gösterimde; 0 ile 2n, bire tümleyen şeklindeki gösterimde; -2n-1+1 ile 2n-1, ikiye tümleyen gösteriminde ise; -2n-1 ile 2n-1 arasındaki sayıları göstermek mümkündür.

Bu gösterim şekillerinde çok büyük ve çok küçük değerlerin ifade edilmesi için çok miktarda bilgisayar donanımına ihtiyaç duyulmaktadır. Örneğin sabit noktalı gösterimde n bitlik alanda noktanın yeri bellirlenmiş ve x bit anlamlı kısım için, geri kalan (n-x) bit ise virgülden sonraki kısım için ayrılmıştır. Bu durumda 8 bitin 5 biti sayının tam kısmını, kalan 3 biti virgülden sonraki kısmını ifade ederse 10110,011, 11101,001, 11111,111 şeklindeki sayılar gösterilebilir. Kayan noktalı gösterimde ise eşit miktarda bilgisayar donanımı ile daha geniş aralıktaki sayılar üretilebilir. Yani 8 bitlik alanda 1,1101101, 10,101011, 11111,111 şeklinde virgülün herhangi bir aralığa gelerek oluşturacağı bütün kombinasyonları ifade etmek mümkündür.


Kayan Nokta Gösterimi

Bilimsel gösterimde sayılar, virgülün solunda 0'dan farklı bir basamak kalacak şekilde 10'un kuvvetiyle çarpım halinde gösterilir. Örneğin; 5647 ve 0.0003456 sayıları sırasıyla 5.647x103 ve 3.456x10-4 şeklinde yazılır. Bu formatta 10'un kuvveti değiştikçe çarpan sayının tam sayı kısmını belirleyen nokta, kuvvetin değişme yönüne uygun olarak kaydırılır. Bu kaydırma işlemine olağanlaştıma(normalizasyon) denir. Kayan noktalı sayılar sistemi de bu temel prensibe dayalı bir sisteme sahiptir.

Kayan noktalı sayılar, ikilik düzendeki sayıların bilimsel gösterimle gösterilmesidir. Kayan noktalı sayılar işaret, anlamlı kısım ve üst(2'nin üssü şeklinde) olmak üzere üç kısımdan oluşur.

M x BE

Burada M kayan noktalı sayının mantis'i; B tabanı, E ise üssüdür.

Dosya:Kayan nokta.jpg

Bu modele göre 13 sayısını gösterelim;
13 sayısı, 13 = 13,0x100 = 1,3x101 = 0,13x102 olarak ifade edilebilir.
İkilik sistemde düşünürsek: 1310 = 11012x20 = 110,12x21 = 11,012x22 = 1,1012x23 = 0,1101x24

Son şekliyle ele alırsak, işaret biti 0, anlamlı kısım 11010000 ve üst 00101 olacaktır.

Dosya:Kayan nokta ornek.jpg

Aynı şekilde 6553610 sayısını göstermek istersek: 6553610 = 0,12x217 yani işaret biti 0, anlamlı kısım 10000000 ve üst 10001 olacaktır.

Dosya:Kayan nokta ornek2.jpg

Fakat bu modelde 0,2510 sayısını göstermek istersek: 0,2510 = 1,0x2-2 olacağından üst için ayrı bir işaret biti kullanmak gerekmektedir. Bunun yerine saptırılmış üst yöntemini kullanmak daha verimli olmaktadır. Bu yöntemde, gerçek üst değerine sabit sapma değeri eklenerek saptırılmış üst elde edilir.
Örneğin bu modelde saptırma değeri olarak 16 seçilmiş olsun. Bu durumda üst değeri 16'dan büyük olan değerler pozitif üstleri, 16'dan küçük olan değerler için negatif üstleri gösterir. Böylece ilk örnek için saptırılmış üst 5+16=21 yani 101012 olacağından, 13 sayısının yeni gösterimi aşağıdaki gibi olacaktır.

Aynı şekilde 0,2510 sayısı için işaret biti 0, anlamlı kısım 100000002, negatif üst için saptırılmış değer -2+16=14 yani 011102 olacaktır.


Olağanlaştırma

Kayan noktalı sayıları bu yöntemle ifade ederken karşılaşılan sorunlardan biri de sayıların benzersiz gösteriminin sağlanamamasıdır. Kayan nokta yöntemiyle gösterim yapılırken virgülün yeri ile birlikte üst değeri değiştiğinde aynı sayı birden farklı şekilde yazılabilir.

Dosya:Olaganlastirma.jpg

Şekilde gösterilen sayıların tümü aynı değere sahiptir, ancak gösterim farkından dolayı değişik şekillerde ifade edilebilmektedirler. Bu durum bilgisayarlar için verimli olmadığından sayıların eşsiz gösterimini sağlayan bir yöntem hayata geçirilmiştir. Bu yöntemde ikilik sistemdeki sayılar bilimsel gösterimdeki gibi, virgülün solunda sıfırdan farklı bir sayı kalana kadar kaydırılır ve o şekliyle ifade edilir. Bu işleme "olağanlaştırma(normalizasyon)" denir. Bu işlem sonunda her sayının benzersiz gösterimi sağlanırken, sayı 1 ve 0 lardan oluştuğu için virgülün solunda sıfırdan farkı olan değerin 1 olduğu bilindiğinden, anlamlı kısımın ifadesi için fazladan bir bit kazanılmış olur.

Şablon:Kitap belirt

Dış Bağlantılar

  • [1] Münih Teknik Üniversitesi Nümerik Programlama dersi ders notları