Určení počtu klastrů v datové sadě - Determining the number of clusters in a data set
Určení počtu klastrů v datové sadě, množství často označované k jako v k- znamená algoritmus, je častým problémem v shlukování dat, a je odlišným problémem od procesu skutečného řešení problému shlukování.
Pro určitou třídu klastrových algoritmů (zejména k-prostředek, k-medoidy a algoritmus očekávání – maximalizace ), existuje parametr běžně označovaný jako k který určuje počet shluků, které se mají detekovat. Jiné algoritmy jako např DBSCAN a Algoritmus OPTICS nevyžadují specifikaci tohoto parametru; hierarchické shlukování problém se úplně vyhne.
Správná volba k je často nejednoznačný a jeho interpretace závisí na tvaru a rozsahu distribuce bodů v datové sadě a na požadovaném klastrovaném rozlišení uživatele. Kromě toho se zvyšuje k bez pokuty vždy sníží množství chyb ve výsledném shlukování, v krajním případě nulové chyby, pokud je každý datový bod považován za svůj vlastní shluk (tj. když k rovná se počtu datových bodů, n). Intuitivně pak, optimální volba k vytvoří rovnováhu mezi maximální kompresí dat pomocí jediného clusteru a maximální přesností přiřazením každého datového bodu jeho vlastnímu clusteru. Pokud je vhodná hodnota k není zřejmé z předchozí znalosti vlastností datové sady, musí být nějakým způsobem vybráno. Existuje několik kategorií metod pro toto rozhodnutí.
Loketní metoda
The loketní metoda se dívá na procento rozptylu vysvětleno jako funkce počtu klastrů: Jeden by měl zvolit počet klastrů, aby přidání dalšího klastru neposkytlo mnohem lepší modelování dat. Přesněji, pokud člověk vykreslí procento rozptylu shluky oproti počtu shluků, první shluky přidají mnoho informací (vysvětlete spoustu variací), ale v určitém okamžiku poklesne mezní zisk, což v grafu dá úhel. V tomto okamžiku je zvolen počet klastrů, proto je „kritérium lokte“. Toto „loket“ nelze vždy jednoznačně identifikovat,[1] což činí tuto metodu velmi subjektivní a nespolehlivou. vysvětleno procento rozptylu je poměr rozptylu mezi skupinami k celkovému rozptylu, také známý jako F-test. Mírná variace této metody vykresluje zakřivení rozptylu uvnitř skupiny.[2]
Metodu lze vysledovat ke spekulacím pomocí Robert L. Thorndike v roce 1953.[3]
X znamená shlukování
Ve statistikách a dolování dat, X znamená shlukování je variace k-znamená shlukování který upřesňuje přiřazení klastrů opakovaným pokusem o dělení a udržováním nejlepších výsledných rozdělení, dokud nebude splněno kritérium jako Informační kritérium Akaike (AIC) nebo Bayesovské informační kritérium (BIC) je dosaženo.[4]
Přístup informačního kritéria
Další sadou metod pro určování počtu klastrů jsou informační kritéria, například Informační kritérium Akaike (AIC), Bayesovské informační kritérium (BIC) nebo Informační kritérium odchylky (DIC) - pokud je možné vytvořit funkci pravděpodobnosti pro model shlukování. Například: The k- znamená, že model je „téměř“ a Gaussův model směsi a lze vytvořit pravděpodobnost pro model Gaussovy směsi a tak také určit hodnoty informačního kritéria.[5]
Informační a teoretický přístup
Teorie zkreslení rychlosti byl použit při výběru k nazývá se „skoková“ metoda, která určuje počet shluků, které maximalizují účinnost při minimalizaci chyb o informační teoretik standardy.[6] Strategií algoritmu je generování křivky zkreslení pro vstupní data spuštěním standardního klastrového algoritmu, jako je k-prostředky pro všechny hodnoty k mezi 1 a na výpočet zkreslení (popsaného níže) výsledného shlukování. Křivka zkreslení je poté transformována zápornou silou zvolenou na základě rozměrnosti dat. Skoky ve výsledných hodnotách pak znamenají rozumnou volbu k, přičemž největší skok představuje nejlepší volbu.
Zkreslení shlukování některých vstupních dat je formálně definováno takto: Nechte datovou sadu modelovat jako a p-dimenzionální náhodná proměnná, X, skládající se z a distribuce směsi z G komponenty se společnými kovariance, Γ. Pokud to necháme být soubor K. klastrová centra, s nejbližší střed k danému vzorku X, pak minimální průměrné zkreslení na dimenzi při montáži K. datových center je:
To je také průměr Mahalanobisova vzdálenost na dimenzi mezi X a soubor klastrových center C. Protože minimalizace přes všechny možné sady center klastru je neúměrně složitá, je narušení v praxi vypočítáno generováním sady center klastru pomocí standardního klastrového algoritmu a výpočtem zkreslení pomocí výsledku. Pseudokód pro metodu skoku se vstupní sadou p-dimenzionální datové body X je:
JumpMethod (X): Nechat Y = (p / 2) Init seznam D o velikosti n + 1 Nechat D [0] = 0 Pro k = 1 ... n: shluk X se shluky k (např. s k-means) Nechat d = Zkreslení výsledného shlukování D [k] = d ^ (- Y) Definovat J (i) = D [i] - D [i-1] Vrátit se k mezi 1 a n, které maximalizuje J (k)
Volba transformační síly je motivován asymptotické uvažování pomocí výsledků z teorie zkreslení rychlosti. Nechte data X mít libovolně libovolný p-dimenzionální Gaussovo rozdělení a nechte opravit , pro některé α větší než nula. Pak narušení shlukování K. klastry v omezit tak jako p jde do nekonečna je . Je vidět, že asymptoticky, narušení shlukování síly je úměrný , což je podle definice přibližně počet klastrů K.. Jinými slovy, pro jedinou Gaussovu distribuci roste K. nad skutečný počet klastrů, který by měl být jeden, způsobí lineární nárůst zkreslení. Toto chování je důležité v obecném případě směsi více distribučních komponent.
Nechat X být směsí G p-dimenzionální Gaussovo rozdělení se společnou kovariancí. Pak pro všechny pevné K. méně než G, zkreslení shlukování jako p jde do nekonečna je nekonečné. Intuitivně to znamená, že shlukování menšího než správného počtu shluků není schopno popsat asymptoticky vysokodimenzionální data, což způsobí narušení narušení bez omezení. Pokud, jak je popsáno výše, K. se zvyšuje funkce p, jmenovitě , je dosaženo stejného výsledku jako výše, s hodnotou zkreslení v limitu jako p jde do nekonečna se rovná . Odpovídajícím způsobem existuje stejný proporcionální vztah mezi transformovaným zkreslením a počtem shluků, K..
Dáme-li výše uvedené výsledky dohromady, je vidět, že pro dostatečně vysoké hodnoty p, transformované zkreslení je přibližně nula pro K. < G, pak náhle skočí a začne lineárně narůstat K. ≥ G. Algoritmus skoku pro výběr K. využívá tato chování k identifikaci nejpravděpodobnější hodnoty pro skutečný počet klastrů.
Ačkoli je matematická podpora metody poskytována z hlediska asymptotických výsledků, algoritmus byl empiricky ověřeno, že funguje dobře v různých souborech dat s rozumnou dimenzionálností. Kromě výše popsané metody lokalizovaného skoku existuje druhý algoritmus pro výběr K. pomocí stejných transformovaných hodnot zkreslení známých jako metoda přerušované čáry. Metoda přerušované čáry identifikuje skokový bod v grafu transformovaného zkreslení jednoduchým způsobem nejmenší čtverce chybová přímka dvou úseček, které teoreticky budou spadat podél X- osa pro K. < Ga podél lineárně rostoucí fáze transformovaného zkreslení pro K. ≥ G. Metoda přerušované čáry je robustnější než metoda skoku v tom, že její rozhodnutí je spíše globální než místní, ale také se spoléhá na předpoklad složek Gaussovy směsi, zatímco metoda skoku je plně neparametrické a bylo prokázáno, že je životaschopný pro obecné distribuce směsi.
Metoda siluety
Průměrný silueta dat je dalším užitečným kritériem pro hodnocení přirozeného počtu klastrů. Silueta datové instance je měřítkem toho, jak úzce je porovnána s daty v jejím klastru a jak volně je porovnána s daty sousedního klastru, tj. Klastru, jehož průměrná vzdálenost od vztažného bodu je nejnižší.[7] Silueta blízká 1 znamená, že vztažný bod je ve vhodném klastru, zatímco silueta blízký -1 znamená, že vztažný bod je ve špatném klastru. Optimalizační techniky jako např genetické algoritmy jsou užitečné při určování počtu klastrů, které vedou k největší siluetě.[8]Je také možné změnit měřítko dat takovým způsobem, že je pravděpodobnější, že silueta bude maximalizována při správném počtu klastrů.[9]
Křížová validace
Lze také použít proces křížová validace analyzovat počet klastrů. V tomto procesu jsou data rozdělena na proti části. Každá z částí je poté na tahu odložena jako testovací sada, na druhé vypočítaný model shlukování proti - 1 tréninkové sady a hodnota objektivní funkce (například součet čtverců vzdáleností k centroidům pro k-průměrů) vypočteno pro testovací sadu. Tyto proti hodnoty se vypočítají a zprůměrují pro každý alternativní počet klastrů a počet klastrů zvolený tak, aby další zvyšování počtu klastrů vedlo pouze k malému snížení objektivní funkce. [10]
Nalezení počtu klastrů v textových databázích
V textových databázích lze kolekci dokumentů definovanou dokumentem pomocí matice termínu D (o velikosti m x n, m: počet dokumentů, n: počet termínů) počet shluků zhruba odhadnout podle následujícího vzorce kde t je počet nenulových položek v D. Všimněte si, že v D musí každý řádek a každý sloupec obsahovat alespoň jeden nenulový prvek.[11]
Analýza matice jádra
Matice jádra definuje blízkost vstupních informací. Například v Gaussovské radiální bázové funkci určuje bodový součin vstupů v prostoru s vyšší dimenzí, který se nazývá prostor funkcí. Předpokládá se, že data se stanou více lineárně oddělitelnými v prostoru funkcí, a proto lze na data s vyšší úspěšností aplikovat lineární algoritmy.
Matici jádra lze tedy analyzovat za účelem nalezení optimálního počtu klastrů.[12] Metoda probíhá rozkladem vlastních čísel matice jádra. Poté bude analyzovat vlastní čísla a vlastní vektory, aby získala míru kompaktnosti vstupního rozdělení. Nakonec bude nakreslen graf, kde loket tohoto grafu označuje optimální počet klastrů v datové sadě. Na rozdíl od předchozích metod tato technika nemusí provádět žádné shlukování a-a priori. Přímo vyhledá počet klastrů z dat.
Bibliografie
- ^ Viz např. David J. Ketchen ml .; Christopher L. Shook (1996). „Aplikace klastrové analýzy ve výzkumu strategického managementu: analýza a kritika“. Deník strategického řízení. 17 (6): 441–458. doi:10.1002 / (SICI) 1097-0266 (199606) 17: 6 <441 :: AID-SMJ819> 3.0.CO; 2-G.[mrtvý odkaz ]
- ^ Viz např. Obrázek 6 v
- Cyril Goutte, Peter Toft, Egill Rostrup, Finn Årup Nielsen, Lars Kai Hansen (Březen 1999). "On Clustering fMRI Time Series". NeuroImage. 9 (3): 298–310. doi:10.1006 / nimg.1998.0391. PMID 10075900.CS1 maint: více jmen: seznam autorů (odkaz)
- ^ Robert L. Thorndike (Prosinec 1953). „Kdo patří do rodiny?“. Psychometrika. 18 (4): 267–276. doi:10.1007 / BF02289263.
- ^ D. Pelleg; AW Moore. X-means: Rozšíření K-means s efektivním odhadem počtu klastrů (PDF). Sborník ze sedmnácté mezinárodní konference o strojovém učení (ICML 2000). Citováno 2016-08-16.
- ^ Cyril Goutte, Lars Kai Hansen, Matthew G. Liptrot a Egill Rostrup (2001). „Klastrování v prostoru a prostoru pro fMRI metaanalýzu“. Mapování lidského mozku. 13 (3): 165–183. doi:10,1002 / hbm.1031. PMC 6871985. PMID 11376501. Archivovány od originál dne 2012-12-17.CS1 maint: více jmen: seznam autorů (odkaz) viz zejména obrázek 14 a dodatek.
- ^ Catherine A. Sugar; Gareth M. James (2003). "Nalezení počtu klastrů v datové sadě: informační-teoretický přístup". Journal of the American Statistical Association. 98 (Leden): 750–763. doi:10.1198/016214503000000666.
- ^ Peter J. Rousseuw (1987). „Siluety: grafická pomoc při interpretaci a validaci klastrové analýzy“. Výpočetní a aplikovaná matematika. 20: 53–65. doi:10.1016/0377-0427(87)90125-7.
- ^ R. Lleti; M.C. Ortiz; L.A. Sarabia; SLEČNA. Sánchez (2004). "Výběr proměnných pro k- Znamená shlukovou analýzu pomocí genetického algoritmu, který optimalizuje siluety “. Analytica Chimica Acta. 515: 87–100. doi:10.1016 / j.aca.2003.12.020.
- ^ R.C. de Amorim & C. Hennig (2015). "Obnova počtu klastrů v souborech dat s funkcemi šumu pomocí faktorů změny měřítka funkcí". Informační vědy. 324: 126–145. arXiv:1602.06989. doi:10.1016 / j.ins.2015.06.039.
- ^ Viz např. „Nalezení správného počtu klastrů v k-Means a EM Clustering: křížová validace v-fold“. Učebnice elektronické statistiky. StatSoft. 2010. Citováno 2010-05-03.
- ^ Can, F .; Ozkarahan, E. A. (1990). "Koncepty a účinnost metodologie shlukování na základě koeficientu krytí pro textové databáze". Transakce ACM v databázových systémech. 15 (4): 483. doi:10.1145/99935.99938. hdl:2374.MIA / 246. zejména viz část 2.7.
- ^ Honarkhah, M; Caers, J (2010). "Stochastická simulace vzorů pomocí modelování vzorů na základě vzdálenosti". Matematické geovědy. 42 (5): 487–517. doi:10.1007 / s11004-010-9276-7.
- Ralf Wagner „Sören W. Scholz, Reinhold Decker (2005): Počet klastrů v segmentaci trhu, in: Daniel Baier, Reinhold Decker; Lars Schmidt-Thieme (Eds.): Analýza dat a podpora rozhodování, Berlín, Springer, 157–176.
externí odkazy
- Clustergram - diagnostický diagram klastru - pro vizuální diagnostiku výběru počtu (k) klastry (R kód)
- Osm metod pro stanovení optimální hodnoty k pro k- znamená analýzu - Odpověď na přetečení zásobníku obsahující R kód pro několik metod výpočtu optimální hodnoty k pro k- znamená klastrovou analýzu
- Rozdělení a shlukování: Kolik tříd? Na serveru HAL je k dispozici bezplatná seminární práce, id = hal-02124947: jsou prezentovány dvě neparametrické metody (jsou dodány bibliografické odkazy), jedna pro numerické proměnné (pracuje s řadou vzdáleností, nemusí to být nutně euklidovská), druhá pro kategorické proměnné ( optimální rozdělení; funguje také se značnými odlišnostmi).