Sanojen kombinatoriikka

Sanojen kombinatoriikka on 1900-luvun lopulla kehittynyt matematiikan ja teoreettisen tietojenkäsittelytieteen haara, jossa tutkitaan sanoja symbolijonoina ilman semanttista merkitystä. Sovelluksia löytyy esimerkiksi molekyylibiologiasta, jossa DNA:ta voidaan mallintaa sanoina nelikirjaimisessa aakkostossa A,C,G, T. [1]

Symboliaakkosto merkitään usein Σ {\displaystyle \Sigma } (kreikkalaisen aakkoston iso sigma-kirjain). Tällöin DNA:n kohdalla Σ = { A , C , G , T } {\displaystyle \Sigma =\{A,C,G,T\}} ja bittien kohdalla Σ = { 0 , 1 } {\displaystyle \Sigma =\{0,1\}} . Yleensä vaaditaan, että symboliaakkoston on oltava äärellisen kokoinen, ja usein käytetty esimerkki edellisten lisäksi on Σ = { a , b , c } {\displaystyle \Sigma =\{a,b,c\}} , jolloin kyseessä on siis 3-kirjaiminen symboliaakkosto.

Symboliaakkostoon liittyvä sana on mikä tahansa äärellisen pituinen merkkijono, jonka merkit kuuluvat annettuun symboliaakkostoon, ja sanan pituus on sen merkkien lukumäärä. Esimerkiksi Σ = { a , b , c } {\displaystyle \Sigma =\{a,b,c\}} -aakkoston kohdalla b b a c b {\displaystyle bbacb} on eräs 5-pituinen sana ja a c c c b c c a b a {\displaystyle acccbccaba} on eräs 10-pituinen sana. Sanoja merkitään usein "sanamuuttujilla" kuten w , u , v , x {\displaystyle w,u,v,x} tai y {\displaystyle y} , jolloin | w | {\displaystyle \vert w\vert } merkitsee w {\displaystyle w} -sanan pituutta. Esimerkiksi jos w = a c b a {\displaystyle w=acba} , | w | = 4 {\displaystyle \vert w\vert =4} .

Tietyn symboliaakkoston Σ {\displaystyle \Sigma } määräämää sanojen joukkoa merkitään Σ {\displaystyle \Sigma ^{*}} , ja siihen kuuluu lisäksi tyhjä sana, jossa ei ole yhtään symbolia (Se on siis 0-pituinen.), ja jota merkitään usein ϵ {\displaystyle \epsilon } (kreikkalaisen aakkoston pieni epsilon-kirjain). Selvästi Σ {\displaystyle \Sigma ^{*}} -joukon eri sanoja on (numeroituvasti) ääretön määrä: 0-pituinen tyhjä sana ϵ {\displaystyle \epsilon } , 1-pituiset, 2-pituiset, jne.

Äärellisen pituisten sanojen lisäksi toisinaan tarkastellaan äärettömän pituisia sanoja, joiden kohdalla symbolijono jatkuu äärettömän pitkälle oikealle. Näin on esimerkiksi, kun w = a b c a b c a b c a b c . . . {\displaystyle w=abcabcabcabc...} , missä a b c {\displaystyle abc} -"jakso" jatkuu oikealle äärettömän monta kertaa, mutta tietenkään kaikkien äärettömän pitkien sanojen rakenteen ei tarvitse olla näin säännöllinen.

Sanojen kohdalla niiden välinen peruslaskutoimitus on tulo eli katenaatio, joka yksinkertaisesti tarkoittaa kerrottavien sanojen symbolijonojen asettamista peräkkäin niin, että näin muodostuu uusi sana. Esimerkiksi jos w = a b b c a {\displaystyle w=abbca} , u = b b b c a a {\displaystyle u=bbbcaa} ja . {\displaystyle .} merkitsee tuloa, w . u = a b b c a . b b b c a a = a b b c a b b b c a a {\displaystyle w.u=abbca.bbbcaa=abbcabbbcaa} tai u . ϵ = b b b c a a . ϵ = b b b c a a {\displaystyle u.\epsilon =bbbcaa.\epsilon =bbbcaa} . Selvästi tämä tulo on epäkommutatiivinen (Sillä yleensä w . u u . w {\displaystyle w.u\neq u.w} .) ja assosiatiivinen (Sillä ( w . u ) . v = w . ( u . v ) {\displaystyle (w.u).v=w.(u.v)} suoraan symbolien peräkkäin asettamisesta johtuen, koska w , u {\displaystyle w,u} ja v {\displaystyle v} ovat molemmilla puolilla samassa vasemmalta-oikealle-järjestyksessä.).

Assosiatiivisuudesta johtuen sulkumerkit ovat tuloissa tarpeettomia, eli voidaan merkitä ( w . u ) . v = w . ( u . v ) = w . u . v {\displaystyle (w.u).v=w.(u.v)=w.u.v} ja yleisemminkin esimerkiksi w . x . u . y . v {\displaystyle w.x.u.y.v} . Usein "tulopisteetkin" jätetään merkitsemättä, jolloin äskeinen lyhenee muotoon w x u y v {\displaystyle wxuyv} . Tällä tulo-operaatiolla varustettu Σ {\displaystyle \Sigma ^{*}} -joukko on vapaa monoidi, mistä seuraa, että sanojen tutkimus on yhteydessä myös algebraan.

Tärkeä tulon erikoistapaus on sanan potenssi, joka tarkoittaa sanan kertomista itsellään eksponentin osoittaman määrän, eli siis w n = w w w . . . w {\displaystyle w^{\mathbf {n} }=www...w} , missä w {\displaystyle w} -sanoja on peräkkäin n kappaletta. Esimerkiksi jos w = a c c b {\displaystyle w=accb} ja n = 4 {\displaystyle n=4} , niin w n = w w w w = a c c b a c c b a c c b a c c b {\displaystyle w^{\mathbf {n} }=wwww=accbaccbaccbaccb} . Lisäksi määritellään luonnolliseen tapaan, että w 1 = w {\displaystyle w^{\mathbf {1} }=w} ja w 0 = ϵ {\displaystyle w^{\mathbf {0} }=\epsilon } .

Myös prefixin käsite on tärkeä. Sana w {\displaystyle w} on sanan u {\displaystyle u} prefix silloin, kun sanan w {\displaystyle w} kirjainjono muodostaa sanan u {\displaystyle u} kirjainjonon alkuosan, mikä merkitään w u {\displaystyle w\leq u} . Esimerkiksi w = c a b a c a b a b c c = u {\displaystyle w=caba\leq cababcc=u} , ja lisäksi Σ {\displaystyle \Sigma ^{*}} :n kaikilla sanoilla w {\displaystyle w} on tietenkin voimassa se, että w w {\displaystyle w\leq w} ja ϵ w {\displaystyle \epsilon \leq w} .

Sanojen kombinatoriikka tutkii mm. seuraavanlaisia kysymyksiä.

Esimerkki 1) Millaisten ehtojen vallitessa sanat kommutoivat, eli w . u = u . w {\displaystyle w.u=u.w} .

On selvää, että sanat w {\displaystyle w} ja u {\displaystyle u} kommutoivat ainakin silloin, jos molemmat ovat saman sanan v {\displaystyle v} potensseja, eli w = v n {\displaystyle w=v^{\mathbf {n} }} ja u = v m {\displaystyle u=v^{\mathbf {m} }} , jolloin w . u = v ( n + m ) = v ( m + n ) = u . w {\displaystyle w.u=v^{\mathbf {(n+m)} }=v^{\mathbf {(m+n)} }=u.w} . Esimerkiksi jos v = b a c a {\displaystyle v=baca} ja w = v 2 {\displaystyle w=v^{2}} ja u = v 1 {\displaystyle u=v^{1}} , w . u = b a c a b a c a b a c a = u . w {\displaystyle w.u=bacabacabaca=u.w} . On melko helposti osoitettavissa, että tämä saman v {\displaystyle v} -sanan potensseina oleminen on riittävyyden lisäksi myös välttämätön ehto sille, että sanat w {\displaystyle w} ja u {\displaystyle u} kommutoisivat, eli w . u {\displaystyle w.u} on sama sana kuin u . w {\displaystyle u.w} .

Esimerkki 2) Onko mahdollista, että äärettömän pitkälle oikealle jatkuva sana ei sisällä "neliötä" eli samaa "jaksoa" kahta kertaa peräkkäin. Jos näin on, mikä on pienin symboliaakkoston koko, jolloin tämä on mahdollista.

On selvää, että ainakaan 2-kirjaimisessa symboliaakkostossa tämä ei ole mahdollista, sillä selvästi siinä pisimmät "neliötä" sisältämättömät sanat ovat a b a {\displaystyle aba} ja b a b {\displaystyle bab} , mutta esimerkiksi jo b a b a = ( b a ) ( b a ) {\displaystyle baba=(ba)(ba)} eli siinä b a {\displaystyle ba} on toistuvana "jaksona". Myös yllä esitetty oikealle ääretön sana sisältää "neliön", sillä siinä a b c {\displaystyle abc} -"jakso" toistuu peräkkäin kahdesti. Esimerkiksi sana c a b c a c b a c a b c a c b c a c b a {\displaystyle cabcacbacabcacbcacba} voi ensisilmäyksellä näyttää "neliöttömältä", mutta se silti sisältää b c a c {\displaystyle bcac} -"jakson" kahdesti peräkkäin, sillä c a b c a c b a c a b c a c b c a c b a = c a b c a c b a c a ( b c a c ) ( b c a c ) b a {\displaystyle cabcacbacabcacbcacba=cabcacbaca(bcac)(bcac)ba} . Osoittautuu kuitenkin, että jo 3-kirjaimisessa aakkostossa on löydettävissä tällaisia oikealle äärettömiä "neliöttömiä" sanoja, joista tyypillinen esimerkki on ns. 3-symbolinen Thue-sana. Kyseinen sana on siis "neliötä" sisältämätön mutta oikealle ääretön, ja sen alku on

a b c a c b a b c b a c a b c a c b a c a b c b a b c a c b a b c b a c a b c b a b c a c b a c a b c a c b a b c b a c a b c a c b a c a b c b {\displaystyle abcacbabcbacabcacbacabcbabcacbabcbacabcbabcacbacabcacbabcbacabcacbacabcb_{\mathbf {} }} .

Tämä 3-symbolinen Thue-sana voidaan muodostaa ns. morfismi-iteroinnin avulla, mikä on sanojen kombinatoriikassa yleinen menetelmä muodostaa vastaavanlaisia sanoja. Tässä tapauksessa morfismi h {\displaystyle h} on seuraava

a a b c {\displaystyle a\mapsto abc}

b a c {\displaystyle b\mapsto ac}

c b {\displaystyle c\mapsto b}

, mikä tarkoittaa siis sitä, että mm. b {\displaystyle b} :n kohdalle kirjoitetaan a c {\displaystyle ac} , jolloin esimerkiksi h ( c a b a ) = h ( c ) . h ( a ) . h ( b ) . h ( a ) = b . a b c . a c . a b c = b a b c a c a b c {\displaystyle h(caba)=h(c).h(a).h(b).h(a)=b.abc.ac.abc=babcacabc} . Morfismin iterointi on vielä aloitettava jostain pisteestä, joka tässä tapauksessa – niin kuin usein muutenkin – on a {\displaystyle a} -kirjain. Muodostetaan siis äärellisen pituisia sanoja

a = h 0 ( a ) , h 1 ( a ) , h 2 ( a ) , h 3 ( a ) , h 4 ( a ) , . . . = a , a b c , a b c a c b , a b c a c b a b c b a c , a b c a c b a b c b a c a b c a c b a c a b c b , . . . {\displaystyle a=h^{\mathbf {0} }(a),h^{\mathbf {1} }(a),h^{\mathbf {2} }(a),h^{\mathbf {3} }(a),h^{\mathbf {4} }(a),...=a,abc,abcacb,abcacbabcbac,abcacbabcbacabcacbacabcb,...}

, sillä h x ( a ) {\displaystyle h^{\mathbf {x} }(a)} tarkoittaa h {\displaystyle h} -morfismin soveltamista a {\displaystyle a} -kirjaimeen x {\displaystyle x} kertaa, jolloin esimerkiksi

h 3 ( a ) = h ( h ( h ( a ) ) ) = h ( h ( a b c ) ) = h ( a b c . a c . b ) = h ( a b c a c b ) = a b c . a c . b . a b c . b . a c = a b c a c b a b c b a c {\displaystyle h^{\mathbf {3} }(a)=h(h(h(a)))=h(h(abc))=h(abc.ac.b)=h(abcacb)=abc.ac.b.abc.b.ac=abcacbabcbac} .

Näin saaduissa äärellisen pituisissa sanoissa aiempi on aina seuraavien prefix, mikä nähdään induktiivisesti, sillä jos induktio-oletuksen mukaan

h x ( a ) h x + 1 ( a ) {\displaystyle h^{\mathbf {x} }(a)\leq h^{\mathbf {x+1} }(a)} eli h x + 1 ( a ) = h x ( a ) . u {\displaystyle h^{\mathbf {x+1} }(a)=h^{\mathbf {x} }(a).u} (Missä siis u {\displaystyle u_{\mathbf {} }} on h x + 1 ( a ) {\displaystyle h^{\mathbf {x+1} }(a)} -sanan loppu sen induktio-oletuksen mukaisen h x ( a ) {\displaystyle h^{\mathbf {x} }(a)} -alun jälkeen.), niin

h x + 2 ( a ) = h ( h x + 1 ( a ) ) = h ( h x ( a ) . u ) = h ( h x ( a ) ) . h ( u ) = h x + 1 ( a ) . h ( u ) {\displaystyle h^{\mathbf {x+2} }(a)=h(h^{\mathbf {x+1} }(a))=h(h^{\mathbf {x} }(a).u)=h(h^{\mathbf {x} }(a)).h(u)=h^{\mathbf {x+1} }(a).h(u)} , siis h x + 2 ( a ) = h x + 1 ( a ) . h ( u ) {\displaystyle h^{\mathbf {x+2} }(a)=h^{\mathbf {x+1} }(a).h(u)}

mistä taas seuraa, että h x + 1 ( a ) h x + 2 ( a ) {\displaystyle h^{\mathbf {x+1} }(a)\leq h^{\mathbf {x+2} }(a)} . Esimerkiksi

h 2 ( a ) = a b c a c b = a b c . a c b = h 1 ( a ) . a c b {\displaystyle h^{\mathbf {2} }(a)=abcacb=abc.acb=h^{\mathbf {1} }(a).acb} , jolloin h 3 ( a ) = h ( h 2 ( a ) ) = h ( h 1 ( a ) . a c b ) = h ( h 1 ( a ) ) . h ( a c b ) = h 2 ( a ) . a b c b a c {\displaystyle h^{\mathbf {3} }(a)=h(h^{\mathbf {2} }(a))=h(h^{\mathbf {1} }(a).acb)=h(h^{\mathbf {1} }(a)).h(acb)=h^{\mathbf {2} }(a).abcbac} .

Lisäksi induktion perusaskeleena tässä on tietenkin se, että

h 0 ( a ) = a a b c = h 1 ( a ) {\displaystyle h^{\mathbf {0} }(a)=a\leq abc=h^{\mathbf {1} }(a)} .

Iteroiden saadut sanat voidaan siis tulkita saman oikealle äärettömän sanan yhä piteneviksi (On voimassa | h x ( a ) | < | h x + 1 ( a ) | {\displaystyle \vert h^{\mathbf {x} }(a)\vert <\vert h^{\mathbf {x+1} }(a)\vert } , sillä h {\displaystyle h} -morfismi kirjoittaa jokaisen kirjaimen tilalle vähintään yhden kirjaimen, ja lisäksi "iteraatioalkujen" alussa on a {\displaystyle a} -kirjain, ja a {\displaystyle a} -kirjainten tilalle kirjoitetaan a b c {\displaystyle abc} , mistä seuraa, että "iteraatioalkujen" pituus kasvaa aidosti.) äärellisen pituisiksi aluiksi, jolloin nämä "iteraatioalut" selvällä tavalla määräävät yksikäsitteisen oikealle äärettömän 3-symbolisen Thue-sanan. Tämän x:nnes kirjain määräytyy niin, että katsotaan mikä on h x ( a ) {\displaystyle h^{\mathbf {x} }(a)} -"iteraatioalun" x:nnes kirjain. Tässä h x ( a ) {\displaystyle h^{\mathbf {x} }(a)} :ää käytettiin siksi, että "iteraatioalku" olisi riittävän pitkä (Onhan x | h x ( a ) | {\displaystyle x\leq \vert h^{\mathbf {x} }(a)\vert } .), mutta käytännössä riittää iteroida selvästi vähemmän kuin x {\displaystyle x} kertaa (Oikeastaan helposti nähdään, että | h x ( a ) | = 3 2 ( x 1 ) {\displaystyle \vert h^{\mathbf {x} }(a)\vert =3\cdot 2^{\mathbf {(x-1)} }} , kun 1 x {\displaystyle 1\leq x} .).

On syytä huomata, että yllä osoitettiin vain se, että annetun h {\displaystyle h} -morfismin a {\displaystyle a} -iteroinnilla muodostuu mielekkäällä tavalla oikealle ääretön sana. Sitä tässä ei osoitettu, että kyseinen sana on myös "neliötön", vaan tämän osoittaminen vaatisi oman tarkastelunsa, jota tässä ei esitetä. Erityisesti on syytä huomata se, että yleisestikin morfismiin sijoitettavan sanan "neliöttömyys" ei vielä takaa tuloksen "neliöttömyyttä". Tästä esimerkkinä h {\displaystyle h} -morfismi, jossa nyt aiemman sijaan

a a b {\displaystyle a\mapsto ab}

b c {\displaystyle b\mapsto c}

c a c b {\displaystyle c\mapsto acb}

, jota a {\displaystyle a} -kirjaimesta iteroiden saataisiin vastaavalla tavalla oikealle ääretön sana, sillä a h 1 ( a ) {\displaystyle a\leq h^{\mathbf {1} }(a)} - ja pitenemis-vaatimukset täyttyvät. Kuitenkaan näin saatu sana ei ole "neliötön", sillä vaikka vielä h 3 ( a ) = a b c a c b {\displaystyle h^{\mathbf {3} }(a)=abcacb} on "neliötön", niin h 4 ( a ) = h ( a ) . h ( b ) . h ( c ) . h ( a ) . h ( c ) . h ( b ) = a b c a c b a b a c b c = a b c a c . b a . b a . c b c {\displaystyle h^{\mathbf {4} }(a)=h(a).h(b).h(c).h(a).h(c).h(b)=abcacbabacbc=abcac.ba.ba.cbc} , eli h 4 ( a ) {\displaystyle h^{\mathbf {4} }(a)} sisältää b a {\displaystyle ba} -"neliön". Tällainen "neliön ilmaantuminen" on mahdollista erityisesti siksi, että "ilmaantuvan neliön" ei tarvitse "osua tasan" h ( . ) {\displaystyle h(.)} -"lohkoihin", vaan se voi muodostua myös niiden välissä kuten yllä, missä b a {\displaystyle ba} -"neliö" muodostui h ( c ) . h ( a ) . h ( c ) = a c b . a b . a c b = a c . b a . b a . c b {\displaystyle h(c).h(a).h(c)=acb.ab.acb=ac.ba.ba.cb} -"osuuden" väliin niin, että "osuuden" vasen a c {\displaystyle ac} -"reuna" ja oikea c b {\displaystyle cb} -"reuna" eivät ole mukana muodostamassa "neliötä".

Lähteet

  1. http://domino.utu.fi/tiedotus/tiedotukset.nsf/61345dc704eae28ac22568bd00428706/61fab16a713b8b10c22573ef00377305?OpenDocument[vanhentunut linkki]


Tämä matematiikkaan liittyvä artikkeli on tynkä. Voit auttaa Wikipediaa laajentamalla artikkelia.