Matroid bölümleme - Matroid partitioning - Wikipedia

matroid bölümleme problem, matematiksel çalışmasında ortaya çıkan bir problemdir. matroidler ve tasarım ve analizinde algoritmalar, burada amaç bir matroidin öğelerini olabildiğince az bağımsız kümeye bölmektir. Bir örnek, hesaplama problemidir. ağaçlandırma bir yönsüz grafik minimum sayı ormanlar tüm kenarlarını kaplaması gerekiyordu. Matroid bölümleme şu şekilde çözülebilir: polinom zamanı verilen bağımsızlık kahini matroid için. Bunu göstermek için genelleştirilebilir. matroid toplamı kendisi bir matroid, bilgi işlem için bir algoritma sağlamak için rütbeler ve matroid toplamlarında bağımsız kümeler ve en büyük ortak bağımsız kümeyi hesaplamak için kavşak verilen iki matroidin.[1]

Misal

Kenarlarının bir bölümü tam iki parçalı grafik K4,4 en fazla üç ormanlık olduğunu gösteren üç ormana

ağaçlandırma bir yönsüz grafik minimum sayıdır ormanlar içine kenarlarının bölünebileceği veya eşdeğer olarak (gerektiğinde her bir ormana üst üste binen kenarlar ekleyerek) minimum sayıda ormanları kapsayan kimin birlikteliği tüm grafiktir. Tarafından kanıtlanmış bir formül Crispin Nash-Williams arboriciteyi tam olarak karakterize eder: tüm alt grafiklerde maksimumdur verilen grafiğin , miktar .[2]

Bir grafiğin ormanları, ilgili grafiklerin bağımsız kümelerini oluşturur. grafik matroid ve miktar Nash-Williams'ın formülünde yer alan grafik matroid sıralamasıdır. , bağımsız kümelerinden birinin maksimum boyutu. Dolayısıyla, bir grafiğin arborikliğini belirleme problemi, grafik matroid için tam olarak matroid bölümleme problemidir. Gerçeği bu matroidin öğeleri şundan daha azına bölünemez: bağımsız alt kümeler, bu durumda yalnızca güvercin deliği ilkesi bunu söyleyerek, eğer öğeler en fazla boyut kümelerine bölünür en azından setlere ihtiyaç vardır. Tüm matroidlere genelleştirilebilen Nash-Williams formülünün daha zor yönü, bu boyutta bir bölümün her zaman var olduğunun kanıtıdır.[1]

Bölüm boyutu için formül

Nash-Williams'ın formülünü genellemek için, biri değiştirilebilir bir matroid tarafından ve alt grafik nın-nin Birlikte kısıtlama nın-nin bir alt kümeye öğelerinin. Alt grafiğin kenar sayısı bu genellemede, asıllık seçilen alt kümenin ve formülün bir ormanın maksimum boyutu için rütbe olur . Böylece, verilen matroidin bir bölümündeki minimum bağımsız küme sayısı formül ile verilmelidir

tüm matroidler için geçerlidir ve algoritmik bir kanıt verilmiştir. Edmonds (1965).[1][3]

Algoritmalar

Matroid bölümleme için ilk algoritma şu şekilde verilmiştir: Edmonds (1965).[3] Algoritmanın her adımında, şimdiye kadar dikkate alınan öğeler için en uygun bölümü koruyarak, matroidin öğelerini rastgele bir sırayla tek tek değerlendiren artımlı bir artırma yolu algoritmasıdır. Her adımda, bir unsuru değerlendirirken henüz bir bölüme yerleştirilmemişse, algoritma bir Yönlendirilmiş grafik düğümleri halihazırda bölümlenmiş öğeleri olan yeni öğe ve özel bir unsur her biri için geçerli bölümdeki bağımsız kümeler. Daha sonra yönlendirilmiş bir grafik oluşturur bu düğüm kümesinde, yönlendirilmiş bir yay ile her matroid öğesi için bölüm kümesine eklenebilir bağımlı olmasına neden olmadan ve yönlendirilmiş bir yay ile her bir matroid eleman çifti için öyle ki çıkarmak bölümünden ve yerine başka bir bağımsız küme oluşturur.[1][3]

Şimdi iki durum var:

  • Bu grafik bir yönlendirilmiş yol bir elementten yeni düşünülen öğeye , daha sonra bu tür en kısa yol (veya daha genel olarak herhangi bir kısayol kenarı olmayan herhangi bir yol), aynı sayıda kümeyle yeni bir bölüm oluşturmak için bölüm kümelerinde eşzamanlı olarak yapılabilecek bir değişiklik dizisini açıklar. ayrıca içerir . Bu durumda algoritma bu değişiklikleri yapar ve devam eder.
  • Öte yandan, böyle bir yol yoksa, bırakın hangi matroid öğelerden oluşur dır-dir ulaşılabilir içinde . Geçerli bölümdeki her küme, en büyük bağımsız küme olmalıdır. kısıtlama , eğer bazı unsurlar nın-nin bölüm kümesine eklenebilir kısıtlamada, o zaman ya bir yay olurdu (bölüm ayarlanmışsa tam matroid içinde maksimal değildir ) veya bir yay nerede (bölüm kümesi maksimal değilse ancak tam matroid içinde maksimal). Her iki durumda da, bu arkın varlığı setin varsayılan yapısıyla çelişir. ve çelişki, her bölüm kümesinin maksimum olduğunu kanıtlıyor. Böylece, matroid bölümleme formülünün kolay yönü ile bölümleme için gereken set sayısı en azından
,

dolayısıyla bu durumda algoritma yerleştirerek en uygun bölümü bulabilir kendi yeni bağımsız kümesine giriyor ve diğer bağımsız kümeleri değiştirmeden bırakıyor.[1][3]

Genel algoritma daha sonra her bir öğeyi dikkate alır sırayla verilen matroidin grafiğini oluşturur , hangi düğümlerin ulaşabileceğini test eder ve bu bilgileri, mevcut bölümü içerecek şekilde güncellemek için kullanır. . Her adımda, şimdiye kadar dikkate alınan elemanların bölünmesi optimaldir, bu nedenle algoritma sona erdiğinde tüm matroid için optimal bir bölüm bulmuş olacaktır.Bu algoritmanın doğru olduğunu kanıtlamak, yardımcı grafikte kısayolsuz bir yolun gösterilmesini gerektirir. her zaman, eşzamanlı olarak gerçekleştirildiğinde, bölümdeki kümelerin bağımsızlığını doğru bir şekilde koruyan bir dizi işlem açıklar; Bu gerçeğin bir kanıtı Edmonds tarafından verildi. Algoritma, matroid bölümleme formülü daha büyük bir sayıya ihtiyaç olduğunu gösterdiğinde yalnızca bölümdeki set sayısını artırdığından, bu algoritmanın doğruluğu formülün doğruluğunu da gösterir.[1][3]

Bu algoritma yalnızca bir bağımsızlık kahini Doğruluğu için, belirli matroid türlerinin daha özel yapısından yararlanarak birçok durumda daha hızlı algoritmalar bulunabilir (örneğin grafik matroidler ) belirli bir bölümleme probleminin tanımlandığı.[4]

İlgili sorunlar

Bir matroid toplamı (her biri nerede bir matroid) kendisi bir matroid olup, öğeleri olarak zirvelerin öğelerinin birliğine sahiptir. Bir küme, her zirvede bağımsız olan kümelere bölünebiliyorsa, toplamdan bağımsızdır. Matroid bölümleme algoritması, bir matroid toplamında bir kümenin bağımsız olup olmadığını test etme problemine genelleştirir ve doğruluğu, bir matroid toplamının zorunlu olarak bir matroid olduğunu kanıtlamak için kullanılabilir.[3][4]

matroid kesişimi iki matroid içinde bağımsız olan en büyük seti bulma sorunu ve eşdeğer bir matroid toplam problemine dönüştürülerek çözülebilir: eğer toplamın temelidir , nerede ikilisi , sonra tam rütbeye sahip olmalı ve maksimum bağımsız bir kümenin kaldırılması itibaren maksimum bir kavşak bırakır.[5]

Matroid bölümleme bir biçimdir kapağı ayarla sorun ve ilgili paketleme seti problem (belirli bir matroid içinde maksimum sayıda ayrık yayılma kümesi bulma) da ilgi çekicidir. Matroid bölümlemeye benzer algoritmalarla çözülebilir.[4] Bir matroid ile ilişkili kesirli küme paketleme ve küme kaplama problemleri (yani, her bir bağımsız kümeye, onu içeren kümelerin toplam ağırlığının en fazla bir veya en az bir olacak şekilde bir ağırlık ataması, maksimize veya sırasıyla tüm setlerin toplam ağırlığının en aza indirilmesi) matroid bölümleme yöntemleri kullanılarak polinom zamanında da çözülebilir.[1]

Bir grafiğin arborikliğini hesaplamadaki kullanımının yanı sıra, matroid bölümleme, ortalaması olan belirli bir grafiğin bir alt grafiğini bulmak için diğer matroidlerle birlikte kullanılabilir. derece maksimumdur ve bir grafiğin kenar tokluğunu bulmak için (bir varyantı grafik tokluğu köşelerin yerine kenarların silinmesini içeren).[1]

Referanslar

  1. ^ a b c d e f g h Scheinerman, Edward R.; Ullman, Daniel H. (1997), "5. Kesirli arboriklik ve matroid yöntemleri", Kesirli grafik teorisi, Wiley-Interscience Series in Discrete Mathematics and Optimization, New York: John Wiley & Sons Inc., s. 99–126, ISBN  0-471-17864-0, BAY  1481157.
  2. ^ Nash-Williams, C. St.J.A. (1964), "Sonlu grafiklerin ormanlara ayrıştırılması", Journal of the London Mathematical Society, 39 (1): 12, doi:10.1112 / jlms / s1-39.1.12, BAY  0161333.
  3. ^ a b c d e f Edmonds, Jack (1965), "Bir matroidin bağımsız alt kümelere minimum bölümü", Ulusal Standartlar Bürosu Araştırma Dergisi, 69B: 67–72, doi:10.6028 / jres.069b.004, BAY  0190025.
  4. ^ a b c Gabow, Harold N .; Westermann, Herbert H. (1992), "Ormanlar, çerçeveler ve oyunlar: matroid toplamları ve uygulamaları için algoritmalar", Algoritma, 7 (5–6): 465–497, doi:10.1007 / BF01758774, BAY  1154585.
  5. ^ Edmonds, Jack (1970), "Alt modüler fonksiyonlar, matroidler ve belirli çokyüzlüler", Kombinatoryal Yapılar ve Uygulamaları (Proc. Calgary Internat. Conf., Calgary, Alta., 1969), New York: Gordon and Breach, s. 69–87, BAY  0270945.