Paralel Algoritma - Giriş

Bir algorithmkullanıcıdan girdi alan ve bir miktar hesaplamadan sonra bir çıktı üreten bir dizi adımdır. Birparallel algorithm farklı işleme cihazlarında aynı anda birkaç talimatı uygulayabilen ve ardından nihai sonucu üretmek için tüm bağımsız çıktıları birleştiren bir algoritmadır.

Eşzamanlı İşleme

İnternetin büyümesiyle birlikte bilgisayarların kolay kullanılabilirliği, verileri saklama ve işleme şeklimizi değiştirdi. Verilerin bol olduğu bir çağda yaşıyoruz. Her gün karmaşık bilgi işlem gerektiren büyük hacimli verilerle uğraşıyoruz ve bunu da hızlı bir şekilde gerçekleştiriyoruz. Bazen aynı anda meydana gelen benzer veya birbiriyle ilişkili olaylardan veri almamız gerekir. Bu ihtiyacımız olan yerconcurrent processing Hızlı zamanda çıktı üretmek için karmaşık bir görevi bölebilir ve birden çok sistemde işleyebilen.

Eşzamanlı işleme, görevin büyük bir karmaşık veri yığınını işlemeyi içerdiği durumlarda önemlidir. Örnekler şunları içerir: büyük veri tabanlarına erişim, uçak testi, astronomik hesaplamalar, atomik ve nükleer fizik, biyomedikal analiz, ekonomik planlama, görüntü işleme, robotik, hava durumu tahmini, web tabanlı hizmetler vb.

Paralellik nedir?

Parallelismbirkaç komut dizisini aynı anda işleme sürecidir. Toplam hesaplama süresini azaltır. Paralellik kullanılarak uygulanabilirparallel computers,yani birçok işlemciye sahip bir bilgisayar. Paralel bilgisayarlar, çoklu görevi destekleyen paralel algoritma, programlama dilleri, derleyiciler ve işletim sistemi gerektirir.

Bu eğitimde sadece aşağıdakileri tartışacağız: parallel algorithms. Daha fazla ilerlemeden önce, önce algoritmalar ve türleri hakkında konuşalım.

Algoritma nedir?

Bir algorithmbir sorunu çözmek için izlenen talimatlar dizisidir. Bir algoritma tasarlarken, algoritmanın çalıştırılacağı bilgisayarın mimarisini göz önünde bulundurmalıyız. Mimariye göre, iki tür bilgisayar vardır -

  • Sıralı Bilgisayar
  • Paralel Bilgisayar

Bilgisayarların mimarisine bağlı olarak, iki tür algoritmamız vardır -

  • Sequential Algorithm - Bir problemi çözmek için bazı ardışık talimat adımlarının kronolojik bir sırada yürütüldüğü bir algoritma.

  • Parallel Algorithm- Problem, alt problemlere bölünmüştür ve ayrı çıktılar elde etmek için paralel olarak yürütülür. Daha sonra bu bağımsız çıktılar, istenen nihai çıktıyı elde etmek için birleştirilir.

Büyük bir problemi ikiye bölmek kolay değil sub-problems. Alt problemler, aralarında veri bağımlılığına sahip olabilir. Bu nedenle, işlemcilerin sorunu çözmek için birbirleriyle iletişim kurması gerekir.

İşlemcilerin birbirleriyle iletişim kurarken ihtiyaç duydukları sürenin gerçek işlem süresinden daha fazla olduğu bulunmuştur. Bu nedenle, paralel bir algoritma tasarlarken, verimli bir algoritma elde etmek için uygun CPU kullanımı dikkate alınmalıdır.

Bir algoritmayı doğru şekilde tasarlamak için, temelde net bir fikre sahip olmalıyız model of computation paralel bir bilgisayarda.

Hesaplama Modeli

Hem sıralı hem de paralel bilgisayarlar, algoritma adı verilen bir dizi talimat (akışı) üzerinde çalışır. Bu talimat seti (algoritma), bilgisayara her adımda ne yapması gerektiği konusunda talimat verir.

Talimat akışına ve veri akışına bağlı olarak, bilgisayarlar dört kategoriye ayrılabilir -

  • Tek Yönerge akışı, Tek Veri akışı (SISD) bilgisayarlar
  • Tek Yönerge akışı, Çoklu Veri akışı (SIMD) bilgisayarlar
  • Çoklu Talimat akışı, Tek Veri akışı (MISD) bilgisayarlar
  • Çoklu Talimat akışı, Çoklu Veri akışı (MIMD) bilgisayarlar

SISD Bilgisayarları

SISD bilgisayarları şunları içerir: one control unit, one processing unit, ve one memory unit.

Bu tür bilgisayarlarda, işlemci kontrol biriminden tek bir talimat akışı alır ve bellek biriminden tek bir veri akışı üzerinde çalışır. Hesaplama sırasında, her adımda işlemci kontrol biriminden bir talimat alır ve bellek biriminden alınan tek bir veri üzerinde çalışır.

SIMD Bilgisayarlar

SIMD bilgisayarlar şunları içerir: one control unit, multiple processing units, ve shared memory or interconnection network.

Burada, tek bir kontrol ünitesi tüm işleme birimlerine talimatlar gönderir. Hesaplama sırasında, her adımda, tüm işlemciler kontrol ünitesinden tek bir talimat seti alır ve bellek ünitesinden farklı veri seti üzerinde çalışır.

İşlem birimlerinin her biri, hem verileri hem de talimatları depolamak için kendi yerel bellek birimine sahiptir. SIMD bilgisayarlarda, işlemcilerin kendi aralarında iletişim kurması gerekir. Bu tarafından yapılırshared memory veya tarafından interconnection network.

Bazı işlemciler bir dizi talimat uygularken, geri kalan işlemciler bir sonraki talimat setini bekler. Kontrol ünitesinden gelen talimatlar hangi işlemcinin olacağına karar veriractive (talimatları uygulayın) veya inactive (bir sonraki talimatı bekleyin).

MISD Bilgisayarlar

Adından da anlaşılacağı gibi, MISD bilgisayarlar şunları içerir: multiple control units, multiple processing units, ve one common memory unit.

Burada her işlemcinin kendi kontrol birimi vardır ve ortak bir bellek birimini paylaşırlar. Tüm işlemciler kendi kontrol birimlerinden ayrı ayrı talimatlar alırlar ve ilgili kontrol birimlerinden aldıkları talimatlara göre tek bir veri akışı üzerinde çalışırlar. Bu işlemci aynı anda çalışır.

MIMD Bilgisayarlar

MIMD bilgisayarlarda multiple control units, multiple processing units, ve bir shared memory veya interconnection network.

Burada her işlemcinin kendi kontrol birimi, yerel bellek birimi ve aritmetik ve mantık birimi vardır. İlgili kontrol birimlerinden farklı talimat setleri alırlar ve farklı veri setleri üzerinde çalışırlar.

Not

  • Ortak bir belleği paylaşan bir MIMD bilgisayar, multiprocessors, bir ara bağlantı ağı kullananlar ise multicomputers.

  • İşlemcilerin fiziksel mesafesine bağlı olarak, çoklu bilgisayarlar iki türdendir -

    • Multicomputer - Tüm işlemciler birbirine çok yakın olduğunda (örneğin aynı odada).

    • Distributed system - Tüm işlemciler birbirinden uzakta olduğunda (örneğin, farklı şehirlerde)