Modern bilgisayarlar ve cep hesap makineleri artık özel matematiksel kod kütüphaneleri kullanarak talep üzerine trigonometrik fonksiyon değerleri üretmektedir. Bu kütüphaneler, genellikle önceden hesaplanmış tabloları dahili olarak kullanır ve gerekli değeri uygun bir interpolasyon (iç-değer biçme) yöntemi kullanarak hesaplar. Trigonometrik fonksiyonların basit aramalı tabloların[a] interpolasyonu, yalnızca kabul edilebilir bir doğruluğun gerekli olabileceği ve hızın genellikle çok önemli olduğu bilgisayar grafikleri alanında hala kullanılmaktadır.
Trigonometrik tabloların ve hesaplama şemalarının bir diğer önemli uygulaması da hızlı Fourier dönüşümü (FFT) algoritmalarıdır; burada aynı trigonometrik fonksiyon değerleri (“twiddle faktörleri” olarak adlandırılır) belirli bir dönüşümde, özellikle de aynı boyutta birçok dönüşümün hesaplandığı yaygın durumda birçok kez değerlendirilmelidir. Bu durumda, her seferinde genel kütüphane rutinlerini çağırmak kabul edilemeyecek kadar yavaştır. Bir seçenek, ihtiyaç duyulacak trigonometrik değerlerin bir tablosunu oluşturmak için kütüphane rutinlerini bir kez çağırmaktır, ancak bu tabloyu saklamak için önemli miktarda bellek gerektirir. Diğer olasılık, düzenli bir değer dizisi gerektiğinden, trigonometrik değerleri anında hesaplamak için bir yineleme formülü kullanmaktır. FFT'nin doğruluğunu korumak için (trigonometrik hatalara karşı çok hassastır) doğru, kararlı yineleme şemaları bulmaya yönelik önemli araştırmalar yapılmıştır.
Trigonometri tablosu esasen çeşitli açılar için sinüs, kosinüs, tanjant ve diğer trigonometrik fonksiyonların değerlerini içeren ve kullanıcılara sunan bir referans tablosudur. Bu açılar genellikle tablonun üst sırası boyunca düzenlenirken, farklı trigonometrik fonksiyonlar soldaki ilk sütunda etiketlenir. Belirli bir açıda belirli bir trigonometrik fonksiyonun değerini bulmak için, fonksiyonun satırını bulur ve istenen açının altındaki sütuna kadar takip edersiniz.[1]
Bir trigonometri tablosunu kullanmak birkaç basit adım içerir
Trigonometrik değerleri bulmanız gereken spesifik açıyı belirleyin.
Bu açıyı tablonun yatay ekseni (üst satır) boyunca arayıp bulun.
Fonksiyon boyunca ve açıdan aşağıya doğru tabloda kesiştikleri noktaya kadar izleyin; bu kesişme noktasındaki sayı, o açı için trigonometrik fonksiyonun değerini verir.
İsteğe bağlı hesaplama
Modern bilgisayarlar ve hesap makineleri keyfi açılar için talep üzerine trigonometrik fonksiyon değerleri sağlamak için çeşitli teknikler kullanmaktadır (Kantabutra, 1996). Özellikle kayan nokta birimlerine sahip üst düzey işlemcilerde yaygın bir yöntem, bir polinom veya rasyonelyaklaşıklık (örneğin Chebyshev yaklaşıklığı, en iyi düzgün yaklaşım, Padé yaklaşımı ve tipik olarak daha yüksek veya değişken kesinlikler için Taylor ve Laurent serisi) aralık azaltma ve tablo arama — önce küçük bir tabloda en yakın açıyı ararlar ve ardından düzeltmeyi hesaplamak için polinomu kullanırlar. Böyle bir interpolasyon gerçekleştirirken hassasiyeti korumak önemsizdir, ancak Gal'in doğru tabloları, Cody ve Waite aralık azaltma ve Payne ve Hanek radyan azaltma algoritmaları gibi yöntemler bu amaç için kullanılabilir. Bir donanım çarpanı bulunmayan daha basit cihazlarda, CORDIC (ve ilgili teknikler) adı verilen ve yalnızca kaydırma ve toplama işlemlerini kullandığı için daha verimli olan bir algoritma vardır. Bu yöntemlerin tümü, performans nedenleriyle donanımda yaygın olarak uygulanmaktadır.
2π'nin rasyonel katları olan açıların trigonometrik fonksiyonları cebirsel sayılardır. a/b-2π değerleri, n = a için de Moivre özdeşliği, aynı zamanda karmaşık düzlemdexb - 1 polinomunun bir kökü olan binci birimin köküne uygulanarak bulunabilir. Örneğin, 2π ⋅ 5/37'nin kosinüs ve sinüsü, sırasıyla, 37. derecedenx37 − 1 polinomunun bir kökü olan, cos(2π/37) + sin(2π/37)i birliğinin 37. kökünün 5. kuvvetinin gerçek ve sanal kısmıdır. Bu durum için, Newton yöntemi gibi bir kök bulma algoritması, benzer bir asimptotik oranda yakınsarken yukarıdaki aritmetik-geometrik ortalama algoritmalarından çok daha basittir. Ancak ikinci algoritmalar transandantal trigonometrik sabitler için gereklidir.
Yarım açı ve açı toplamı formülleri
Tarihsel olarak, trigonometrik tabloların hesaplandığı en eski ve bilgisayarların ortaya çıkışına kadar muhtemelen en yaygın olan yöntem, bilinen bir değerden başlayarak (sin(π/2) = 1, cos(π/2) = 0 gibi) yarım açı ve açı toplamı için trigonometrik özdeşlik yöntemlerini tekrar tekrar (yani yinelemeli olarak) uygulamaktı. Bu yöntem, astronomi üzerine bir inceleme olan Almagest adlı eserinde bunları türeten antik Yunan astronom Batlamyus tarafından kullanılmıştır. Modern formda, türettiği özdeşlikler aşağıdaki gibi ifade edilir (xin bulunduğu çeyrek tarafından belirlenen işaretlerle):
Bu özdeşlikler üzerinde başka permütasyonlar da mümkündür: örneğin, bazı erken dönem trigonometrik tablolarda sinüs ve kosinüs değil, sinüs ve versinüs kullanılmıştır.
Hızlı ama kusurlu bir yaklaşım
N yaklaşım tablosunu hesaplamak için hızlı, ancak hatalı bir algoritma sin(2πn/N) için sn ve cos(2πn/N) için cn:
s(0) = 0 ve c(0) = 1 başlangıç koşulları ile analitik çözümü s = sin(t) ve c = cos(t) şeklindedir.
Ne yazık ki, bu sinüs tabloları oluşturmak için kullanışlı bir algoritma değildir çünkü 1/N ile orantılı önemli derecede bir hatası vardır.
Örneğin, N = 256 için sinüs değerlerindeki maksimum hata ~0.061'dir (s202 = −0,9757 yerine −1,0368). N = 1024 için, sinüs değerlerindeki maksimum hata ~0,015 (s803 = −0,97832 yerine −0,99321), yani yaklaşık 4 kat daha küçüktür. Eğer elde edilen sinüs ve kosinüs değerleri çizilecek olsaydı, bu algoritma bir daire yerine logaritmik bir spiral çizerdi.
Daha iyi, ancak hala kusurlu bir yineleme formülü
Trigonometrik tablolar oluşturmak için basit bir yineleme formülü, Euler formülü ve ilişkiye dayanır:
Bu, yukarıdaki gibi trigonometrik sn ve cn değerlerini hesaplamak için aşağıdaki yinelemeye yol açar:
c0 = 1
s0 = 0
cn+1 = wrcn − wisn
sn+1 = wicn + wrsn
n = 0, ..., N − 1 için, burada wr = cos(2π/N) ve wi = sin(2π/N). Bu iki başlangıç trigonometrik değeri genellikle mevcut kütüphane fonksiyonları kullanılarak hesaplanır (ancak örneğin karmaşık düzlemde Newton yöntemi kullanılarak zN − 1'in ilkel kök için çözülerek de bulunabilir).
Bu yöntem kesin aritmetikte tam bir tablo üretir, ancak sonlu hassasiyetli kayan nokta aritmetiğinde hatalar vardır. Aslında, hatalar O(ε N) olarak büyür (hem en kötü hem de ortalama durumlarda), burada ε kayan nokta hassasiyetidir.
Önemli bir gelişme, FFT uygulamaları için trigonometrik değerler üretmek üzere sıklıkla kullanılan bir hile (Singleton'a göre[2]) olan yukarıdaki aşağıdaki modifikasyonu kullanmaktır:
c0 = 1
s0 = 0
cn+1 = cn − (α cn + β sn)
sn+1 = sn + (β cn − α sn)
Burada α = 2 sin2(π/N) ve β = sin(2π/N). Bu yöntemin hataları çok daha küçüktür, ortalama olarak O(ε √N) ve en kötü durumda O(ε N), ancak bu hala büyük boyutlardaki FFT'lerin doğruluğunu önemli ölçüde azaltacak kadar büyüktür.
Manfred Tasche and Hansmartin Zeuner (2002) "Improved roundoff error analysis for precomputed twiddle factors", Journal for Computational Analysis and Applications 4(1): 1–18.
James C. Schatzman (1996) "Accuracy of the discrete Fourier transform and the fast Fourier transform", SIAM Journal on Scientific Computing 17(5): 1150–1166.
Vitit Kantabutra (1996) "On hardware for computing exponential and trigonometric functions," IEEE Transactions on Computers 45(3): 328–339 .