Öğretim düzeyinde paralellik - Instruction-level parallelism

Atanasoff – Berry bilgisayarı paralel işleme özelliğine sahip ilk bilgisayar[1]

Öğretim düzeyinde paralellik (ILP) kaç tanesinin ölçüsüdür Talimatlar içinde bilgisayar programı eşzamanlı olarak yürütülebilir.

ILP ile karıştırılmamalıdır eşzamanlılık:

  • ILP, belirli bir programa ait bir dizi talimatın paralel olarak yürütülmesidir. yürütme dizisi bir süreç (kaynak kümesiyle çalışan bir program: adres alanı, bir dizi kayıtlar, tanımlayıcıları, durumu, program sayacı (diğer adıyla komut işaretçisi) ve daha fazlası).
  • Öte yandan, eşzamanlılık, bir veya farklı süreçlerin iş parçacığının bir İşlemci çekirdeği katı bir değişimde veya yeterli CPU çekirdeği varsa gerçek paralellikte, her çalıştırılabilir iş parçacığı için ideal olarak bir çekirdek.

Öğretim düzeyinde paralellik için iki yaklaşım vardır: Donanım ve Yazılım.

Donanım seviyesi dinamik paralellik üzerinde çalışırken, yazılım seviyesi statik paralellik üzerinde çalışır. Dinamik paralellik, işlemcinin çalışma zamanında hangi komutların paralel olarak yürütüleceğine karar vermesi anlamına gelirken, statik paralellik derleyici Hangi komutların paralel olarak yürütüleceğine karar verir.[2][açıklama gerekli ] Pentium işlemci dinamik paralel yürütme dizisi üzerinde çalışır, ancak Itanium işlemci, statik seviye paralelliği üzerinde çalışır.

Aşağıdaki programı düşünün:

1   e = a + b2   f = c + d3   m = e * f

İşlem 3, işlem 1 ve 2'nin sonuçlarına bağlıdır, bu nedenle ikisi de tamamlanana kadar hesaplanamaz. Bununla birlikte, operasyon 1 ve 2 başka herhangi bir işleme bağlı değildir, bu nedenle aynı anda hesaplanabilirler. Her bir işlemin bir birim zamanda tamamlanabileceğini varsayarsak, bu üç talimat, 3/2 ILP vererek toplam iki birim zamanda tamamlanabilir.

Bir hedef derleyici ve işlemci tasarımcılar mümkün olduğu kadar çok ILP belirlemek ve bundan yararlanmaktır. Sıradan programlar tipik olarak, komutların birbiri ardına ve programcı tarafından belirtilen sırada yürütüldüğü sıralı bir yürütme modeli altında yazılır. ILP, derleyicinin ve işlemcinin birden fazla komutun yürütülmesini üst üste getirmesine veya hatta komutların yürütüldüğü sırayı değiştirmesine izin verir.

Programlarda ne kadar ILP olduğu uygulamaya özeldir. Grafikler gibi belirli alanlarda ve bilimsel hesaplama miktar çok büyük olabilir. Ancak, aşağıdaki gibi iş yükleri kriptografi çok daha az paralellik sergileyebilir.

ILP'den yararlanmak için kullanılan mikro mimari teknikler şunları içerir:

  • Talimat ardışık düzeni Birden fazla talimatın yürütülmesi kısmen örtüşebilir.
  • Süper skalar yürütme VLIW ve yakından ilgili açıkça paralel talimat hesaplama birden çok yürütme birimleri birden çok talimatı paralel olarak yürütmek için kullanılır.
  • Arıza yürütme talimatların veri bağımlılıklarını ihlal etmeyen herhangi bir sırayla yürütüldüğü yer. Bu tekniğin hem ardışık düzen hem de süper skalar yürütmeden bağımsız olduğunu unutmayın. Mevcut sıra dışı yürütme uygulamaları dinamik olarak (yani, program yürütülürken ve derleyicinin yardımı olmadan) normal programlardan ILP'yi ayıklayın. Bir alternatif, bu paralelliği şuradan çıkarmaktır: Derleme zamanı ve bir şekilde bu bilgileri donanıma aktarın. Sıra dışı yürütme tekniğini ölçeklendirmenin karmaşıklığı nedeniyle, endüstri yeniden incelemiştir. komut setleri komut başına birden çok bağımsız işlemi açıkça kodlayan.
  • Yeniden adlandırma kaydı Bu, sırasız yürütmeyi sağlamak için kullanılan kayıtların bu işlemler tarafından yeniden kullanılmasıyla empoze edilen program işlemlerinin gereksiz serileştirilmesini önlemek için kullanılan bir tekniği ifade eder.
  • Spekülatif uygulama bu, bu uygulamanın gerçekleşip gerçekleşmeyeceğinden emin olmadan önce tüm talimatların veya talimatların bir kısmının yürütülmesine izin verir. Yaygın olarak kullanılan bir spekülatif yürütme biçimi, bir kontrol akışı talimatını (örneğin, bir dal) geçen talimatların, kontrol akışı talimatının hedefi belirlenmeden önce yürütüldüğü kontrol akışı spekülasyonudur. Diğer bazı spekülatif uygulama biçimleri önerilmiştir ve bunlar tarafından yönlendirilen spekülatif uygulama da dahil olmak üzere kullanımdadır. değer tahmini, bellek bağımlılığı tahmini ve önbellek gecikme tahmini.
  • Dal tahmini kontrol bağımlılıklarının çözülmesi için gecikmeyi önlemek için kullanılır. Dal tahmini, spekülatif yürütme ile kullanılır.

ILP'nin hem derleyici hem de donanım desteği tarafından istismar edildiği bilinmektedir, ancak derleyici ayrıca derleme optimizasyonu ile donanımlara programlarda içsel ve örtük ILP sağlar. Programlarda mevcut ILP'nin çıkarılmasına yönelik bazı optimizasyon teknikleri, programlama, kayıt tahsisi / yeniden adlandırma ve bellek erişim optimizasyonunu içerir.

Veri akışı mimarileri ILP'nin açıkça belirtildiği başka bir mimari sınıfıdır, yeni bir örnek için bkz. TRIPS mimarisi.

Son yıllarda, işlemci çalışma frekansları ile bellek erişim süreleri arasında giderek artan eşitsizliğe rağmen performans iyileştirmeleri sağlamak için ILP teknikleri kullanılmıştır ( IBM Sistemi / 360 Modeli 91 nispeten küçük bir kayıt dosyasının getirdiği sınırlamaların üstesinden gelmek için ILP tekniklerini kullandı). Şu anda, bir önbellek, ana belleğin cezasını kaçırmak için yüzlerce CPU döngüsüne mal oluyor. Prensipte bu tür bellek gecikmelerini bile tolere etmek için ILP kullanmak mümkün olmakla birlikte, ilişkili kaynak ve güç tüketme maliyetleri orantısızdır. Dahası, temeldeki donanım yapılarının karmaşıklığı ve genellikle gecikme süresi, çalışma frekansının düşmesine neden olur ve herhangi bir avantajı daha da azaltır. Bu nedenle, yukarıda bahsedilen teknikler, CPU'nun çip dışı veriler için durmasını önlemek için yetersizdir. Bunun yerine, endüstri, aşağıdaki gibi tekniklerle yararlanılabilecek daha yüksek seviyelerde paralellikten yararlanmaya yöneliyor. çoklu işlem ve çok iş parçacıklı.[3]

Ayrıca bakınız

Referanslar

  1. ^ "Bilgi İşlem Tarihi". mason.gmu.edu. Alındı 2019-03-24.
  2. ^ Hennessy, John L .; Patterson, David A. Bilgisayar Mimarisi: Nicel Bir Yaklaşım.
  3. ^ Hafıza Duvarının Yansımaları

daha fazla okuma

  • Aiken, Alex; Banerjee, Utpal; Kejariwal, Arun; Nicolau, Alexandru (2016-11-30). Öğretim Düzeyi Paralellik. Professional Computing (1 ed.). Springer. ISBN  978-1-4899-7795-3. ISBN  1-4899-7795-3. (276 sayfa)

Dış bağlantılar