Aralık planlama - Interval scheduling

Aralık planlama bir sorun sınıfıdır bilgisayar Bilimi özellikle alanında algoritma tasarım. Sorunlar bir dizi görevi dikkate alır. Her görev bir Aralık uygulanması gereken zamanı açıklayan. Örneğin, A görevi 2:00 ile 5:00 arasında, B görevi 4:00 ile 10:00 arasında ve C görevi 9:00 ile 11:00 arasında çalışabilir. Aralıkların bir alt kümesi uyumlu iki aralık çakışmıyorsa. Örneğin, {A, C} alt kümesi, {B} alt kümesi gibi uyumludur; ancak ne {A, B} ne de {B, C} uyumlu alt kümelerdir, çünkü her alt küme içindeki karşılık gelen aralıklar örtüşmektedir.

aralıklı zamanlama maksimizasyonu problemi (ISMP), en büyük uyumlu seti - maksimum boyutta üst üste binmeyen aralıklar kümesi bulmaktır. Buradaki amaç, mümkün olduğu kadar çok görevi yürütmektir.

Sorunun yükseltilmiş bir versiyonunda, aralıklar gruplara bölünmüştür. Aralıkların bir alt kümesi uyumlu iki aralık çakışmazsa ve dahası, iki aralık aynı gruba ait değildir (yani, alt küme her grubun en fazla tek bir temsili aralığını içerir).

grup aralığı planlama karar problemi (GISDP), tüm grupların temsil edildiği uyumlu bir küme olup olmadığına karar vermektir. Buradaki amaç, her gruptan tek bir temsilci görevi yürütmektir. GISDPk, her gruptaki aralık sayısının en fazla olduğu GISDP'nin sınırlı bir sürümüdür. k.

grup aralığı zamanlama maksimizasyonu problemi (GISMP), en büyük uyumlu seti - üst üste binmeyen maksimum boyutta bir dizi temsilci bulmaktır. Buradaki amaç, mümkün olduğu kadar çok gruptan temsili bir görev yürütmektir. GISMPk, her gruptaki aralık sayısının en fazla olduğu GISMP'nin sınırlı bir sürümüdür. k. Bu soruna genellikle JISPk denir ve burada J İş.

GISMP en genel sorundur; diğer iki sorun bunun özel durumları olarak görülebilir:

  • ISMP, her görevin kendi grubuna ait olduğu özel durumdur (yani GISMP1'e eşittir).
  • GSYİH, maksimumun grup sayısına tam olarak eşit olup olmadığına karar verme sorunudur.

Aralık Çizelgeleme Maksimizasyonu

[1]

IntervalSelection.svg

İlk bakışta umut verici görünen birkaç algoritma aslında en uygun çözümü bulamıyor:

  • En erken başlayan aralıkları seçmek optimal bir çözüm değildir, çünkü en erken aralık çok uzun olursa, bunu kabul etmek diğer birçok kısa isteği reddetmemize neden olur.
  • En kısa aralıkları seçmek veya en az çakışmaya sahip aralıkları seçmek de optimal değildir.

Açgözlü polinom çözümü

Aşağıdaki Açgözlü algoritma en uygun çözümü buluyor:

  1. Aralığı seçin, xen erken bitirme zamanı.
  2. Kaldırmak xve kesişen tüm aralıklar x, aday aralıklar kümesinden.
  3. Aday aralık seti boşalana kadar tekrarlayın.

1. adımda bir aralık seçtiğimizde, 2. adımda birçok aralığı kaldırmamız gerekebilir. Ancak, tüm bu aralıklar zorunlu olarak bitiş süresinin xve böylece hepsi birbiriyle kesişir (şekle bakın). Bu nedenle, bu aralıklardan en fazla 1 tanesi optimal çözümde olabilir. Dolayısıyla, optimal çözümdeki her aralık için, açgözlü çözümde bir aralık vardır. Bu, açgözlü algoritmanın gerçekten de en uygun çözümü bulduğunu kanıtlıyor.

Daha resmi bir açıklama bir Şarj argümanı.

Açgözlü algoritma O zamanında çalıştırılabilir (n günlük n), nerede n görevlerin bitirme zamanlarına göre sıralandığı bir ön işleme adımı kullanan görevlerin sayısıdır.

Grup Aralığı Planlama Kararı

Bazı gruplar 3 veya daha fazla aralık içerdiğinde NP tamamlandı

GISDPk, NP-tamamlandığında ,[2] tüm aralıklar aynı uzunluğa sahip olsa bile.[3] Bu, aşağıdaki sürümden bir indirim ile gösterilebilir. Boole karşılanabilirlik sorunu:

İzin Vermek Boolean değişkenleri kümesi olabilir. İzin Vermek bir dizi olmak

maddeler bitti X öyle ki (1) her cümle C en fazla üç değişmez ve (2) her değişken, genel olarak bir veya iki kez pozitif ve bir kez de negatif görünecek şekilde sınırlandırılmıştır. C. Değişkenlerine bir atama olup olmadığına karar verin X öyle ki her bir cümle C en az bir gerçek kelimeye sahiptir.

Bu sürüm gösterildi [4] olmak NP tamamlandı aynı şekilde sınırsız versiyona.

Bu tatmin edilebilirlik sorununun bir örneği göz önüne alındığında, aşağıdaki GISDP örneğini oluşturun. Tüm aralıkların uzunluğu 3'tür, bu nedenle her aralığı başlangıç ​​zamanına göre göstermek yeterlidir:

  • Her değişken için (için ben=1,...,p), iki aralıklı bir grup oluşturun: biri (ödevi temsil eden ) ve bir başkası (ödevi temsil eden ).
  • Her madde için (için j=1,...,q), aşağıdaki aralıklarla bir grup oluşturun:
    • Her değişken için için olumlu görünüyor ilk zaman C - başlayan bir aralık .
    • Her değişken için için olumlu görünüyor ikinci zaman C - başlayan bir aralık . Bu aralıkların her ikisinin de aralığı kesiştiğine dikkat edin ile ilişkili .
    • Her değişken için negatif görünen - bir aralık . Bu aralık, aralığı kesişir ile ilişkili .

Farklı maddelerle ilişkili gruplardaki aralıklar arasında örtüşme olmadığına dikkat edin. Bu, bir değişkenin en fazla iki kez olumlu ve bir kez olumsuz görünmesi nedeniyle sağlanır.

Oluşturulan GISDP'nin uygulanabilir bir çözümü vardır (yani, her grubun temsil edildiği bir zamanlama), ancak ve ancak verilen boole cümlecikleri kümesi tatmin edici bir atamaya sahipse. Dolayısıyla, GISDP3 NP-tamamlanmıştır ve her biri için GISDPk da öyledir. .

Tüm gruplar en fazla 2 aralık içerdiğinde polinom

GISDP2, polinom zamanında aşağıdaki indirgeme ile çözülebilir: 2-tatmin sorun:[3]

  • Her grup için ben iki aralığını temsil eden iki değişken oluşturun: ve .
  • Her grup için ben, maddeleri oluşturun: ve , bu iki aralıktan tam olarak birinin seçilmesi gerektiği iddiasını temsil eder.
  • Her iki kesişen aralık için (ör. ve ) cümle oluşturun: , bu iki aralıktan en fazla birinin seçilmesi gerektiği iddiasını temsil eder.

Bu yapı en fazla O (n2) cümleleri (aralıklar arasındaki her kesişim için bir artı her grup için iki). Her cümle 2 değişmez içerir. Bu tür formüllerin tatmin edilip edilemeyeceğine cümle sayısında doğrusal zaman içinde karar verilebilir (bkz. 2-SAT ). Bu nedenle, GISDP2 polinom zamanda çözülebilir.

Grup Aralığı Planlama Maksimizasyonu

Bazı gruplar 2 veya daha fazla aralık içerdiğinde MaxSNP tamamlandı

GISMPk, şu durumlarda bile NP-tamamlanmıştır: .[5]

Dahası, GISMPk MaxSNP -komple, yani P = NP olmadıkça bir PTAS'ye sahip değildir. Bu, MAX 3-SAT-3'ten GISMP2'ye yaklaşımı koruyan bir düşüş gösterilerek kanıtlanabilir.[5]

Polinom 2 yaklaşımı

Aşağıdaki açgözlü algoritma, optimum aralık sayısının en az 1 / 2'sini içeren bir çözüm bulur:[5]

  1. Aralığı seçin, xen erken bitirme zamanı.
  2. Kaldırmak xve kesişen tüm aralıklar xve aynı gruptaki tüm aralıklar x, aday aralıklar kümesinden.
  3. Aday aralık seti boşalana kadar devam edin.

Resmi bir açıklama, bir Şarj argümanı.

Yaklaşık 2 faktörü sıkıdır. Örneğin, aşağıdaki GISMP2 örneğinde:

  • 1. Grup: {[0..2], [4..6]}
  • 2. Grup: {[1..3]}

Açgözlü algoritma, grup # 1'den yalnızca 1 aralık [0..2] seçerken, en uygun zamanlama, grup # 2'den [1..3] ve ardından grup # 1'den [4..6] seçmektir.

LP tabanlı yaklaşım algoritmaları

Tekniğini kullanarak Doğrusal programlama gevşetme biraz daha iyi yaklaşım faktörleri ile optimal zamanlamayı yaklaşık olarak tahmin etmek mümkündür. Bu tür ilk algoritmanın yaklaşım oranı asimptotik olarak 2'dir. k büyük, ama ne zaman k = 2 algoritma yaklaşık 5/3 oranına ulaşır.[5] Keyfi için yaklaşım faktörü k daha sonra 1.582'ye yükseltildi.[6]

Grafik gösterimleri

Bir aralık programlama problemi, bir kavşak grafiği, burada her köşe bir aralıktır ve iki köşe arasında yalnızca aralıkları çakışırsa bir kenar vardır. Bu gösterimde, aralık programlama problemi maksimum değeri bulmaya eşdeğerdir. bağımsız küme Bu kesişme grafiğinde. Genel grafiklerde, maksimum bağımsız bir küme bulmak NP zordur. Bu nedenle, ilginçtir ki, aralıklı kesişim grafiklerinde, tam olarak polinom zamanında yapılabilir.[kaynak belirtilmeli ]

Bir grup-aralık programlama problemi, yani GISMPk, aynı grubun her iki aralığı arasında ek kenarlar bulunan benzer bir aralık-kesişim grafiği ile tanımlanabilir, yani bu, bir aralık grafiğinin kenar birleşimidir ve n'den oluşan bir grafiktir. ayrık boyut grupları k.

Varyasyonlar

Zamanlama algoritmalarının önemli bir sınıfı, dinamik öncelikli algoritmalar sınıfıdır. Aralıkların hiçbiri çakışmadığında optimum çözüm önemsizdir. Ağırlıksız versiyon için optimum, en erken son tarih ilk planlama. Ağırlıklı aralık planlama, yürütülen her göreve bir değerin atandığı ve amacın toplam değeri maksimize etmek olduğu bir genellemedir. Çözümün benzersiz olması gerekmez.

Aralık planlama problemi 1 boyutludur - sadece zaman boyutu önemlidir. Maksimum ayrık set problem 2 veya daha fazla boyuta genellemedir. Bu genelleme de NP-tamamlandı.

Diğer bir varyasyon, kaynaklar kullanılarak bir dizi aralığın planlandığı kaynak tahsisidir. k öyle ki k küçültülmüştür. Yani, tüm aralıklar planlanmalıdır, ancak amaç kaynak sayısını mümkün olduğunca azaltmaktır.

Başka bir varyasyon, m tek bir işlemci yerine işlemciler. Yani, m farklı görevler paralel olarak çalışabilir.[2]

Ayrıca bakınız

Kaynaklar

  1. ^ Kleinberg, Jon; Tardos, Éva (2006). Algoritma Tasarımı. ISBN  978-0-321-29535-4.
  2. ^ a b Nakajima, K .; Hakimi, S.L. (1982). "Ayrı başlangıç ​​zamanlarına sahip görevlerin planlanması için karmaşıklık sonuçları". Algoritmalar Dergisi. 3 (4): 344. doi:10.1016 / 0196-6774 (82) 90030-X.
  3. ^ a b Mark Keil, J. (1992). "Ayrık başlangıç ​​zamanlarına sahip zamanlama görevlerinin karmaşıklığı hakkında". Yöneylem Araştırma Mektupları. 12 (5): 293–295. doi:10.1016 / 0167-6377 (92) 90087-j.
  4. ^ Papadimitriou, Christos H .; Steiglitz, Kenneth (Temmuz 1998). Kombinatoryal Optimizasyon: Algoritmalar ve Karmaşıklık. Dover. ISBN  978-0-486-40258-1.CS1 bakimi: ref = harv (bağlantı)
  5. ^ a b c d Spieksma, F. C.R. (1999). "Bir aralık planlama probleminin yaklaşıklığı hakkında". Çizelgeleme Dergisi. 2 (5): 215–227. CiteSeerX  10.1.1.603.5538. doi:10.1002 / (sici) 1099-1425 (199909/10) 2: 5 <215 :: aid-jos27> 3.0.co; 2-y. kişisel iletişimde Kolen'den alıntı yapmak
  6. ^ Chuzhoy, J.; Ostrovsky, R.; Rabani, Y. (2006). "İş Aralığı Seçimi Problemi ve İlgili Çizelgeleme Problemleri için Yaklaşık Algoritmalar". Yöneylem Araştırması Matematiği. 31 (4): 730. CiteSeerX  10.1.1.105.2578. doi:10.1287 / moor.1060.0218.