Uudelleenkirjoitus - laaja valikoima tekniikoita, menetelmiä ja teoreettisia tuloksia, jotka liittyvät muodollisen kielen kaavojen tai termien osien peräkkäiseen korvaamiseen tietyn järjestelmän mukaisesti - uudelleenkirjoitussääntöjen järjestelmä . Yleisimmässä muodossaan puhumme tietyn objektien ja sääntöjen kokoelmasta - näiden objektien välisistä suhteista, jotka osoittavat, kuinka tämä joukko muutetaan.
Uudelleenkirjoitus voi olla epädeterministinen. Esimerkiksi uudelleenkirjoitussääntöjen järjestelmä voi sisältää säännön, jota voidaan soveltaa samaan termiin usealla eri tavalla, mutta joka ei sisällä samaan aikaan viittausta siitä, mitä menetelmää tietyssä tapauksessa tulisi soveltaa. Jos uudelleenkirjoitusjärjestelmä on kuitenkin kehystetty yksiselitteisesti ymmärrettäväksi algoritmiksi, sitä voidaan pitää tietokoneohjelmana. Useat interaktiiviset lauseiden todistamisjärjestelmät [1] ja deklaratiiviset ohjelmointikielet [2] [3] perustuvat uudelleenkirjoitustekniikoihin .
Uudelleenkirjoitusjärjestelmien tärkeimmät ominaisuudet voidaan muotoilla turvautumatta niiden erityiseen toteutukseen operaatioiden muodossa. Tätä varten käytetään usein käsitettä Abstract Reduction System tai ARS ( englanninkielisestä Abstract Reduction Systemsistä ) . ARS koostuu joukosta A ja joukosta siinä olevia binäärisuhteita , joita kutsutaan vähennyksiksi . A:n sanotaan pienennettävän tai kirjoitetun uudelleen b : ksi yhdessä vaiheessa suhteessa annettuun ARS:iin, jos pari ( a , b ) kuuluu johonkin . Pelkistysjärjestelmien tärkeimmät ominaisuudet ovat:
On selvää, että yhtymä tarkoittaa heikkoa yhtymäkohtaa ja pysähtyminen, vastaavasti, heikkoa pysähtymistä. Yhtymä ja pysähtyminen eivät kuitenkaan liity toisiinsa. Esimerkiksi järjestelmä, joka koostuu yhdestä säännöstä a•b → b•a, on konfluentti, mutta ei pysähtyvä. Järjestelmä, joka koostuu kahdesta säännöstä a → b ja a → c , on pysähtyvä, mutta ei yhtyvä, ja kaikki kolme sääntöä yhdessä muodostavat järjestelmän, joka ei ole pysähtyvä eikä yhtyvä.
Pelkistysjärjestelmän pysäytysluonne mahdollistaa sen, että jokaiselle elementille voidaan määrittää sen normaalimuoto - elementti, johon se voidaan pelkistää, mutta jota itse ei enää pelkistetä. Jos lisäksi havaitaan konfluenssi, niin tällainen normaalimuoto on aina ainutlaatuinen tai kanoninen . Tässä suhteessa Church-Rosserin ominaisuus on erityisen arvokas, koska sen avulla voit nopeasti ja tehokkaasti ratkaista kahden elementin a ja b yhtäläisyyden ongelman suhteessa yhtäläisyysjärjestelmään, joka vastaa vähennysjoukkoa ilman suuntaa . Tätä varten riittää laskea molempien elementtien normaalimuodot. Koska tässä tapauksessa normaalimuoto on myös kanoninen, elementit ovat samanarvoisia silloin ja vain, jos tulokset täsmäävät.
Vaikka uudelleenkirjoituksen käsite otettiin alun perin käyttöön lambda-laskennassa , suurin osa tuloksista ja sovelluksista koskee tällä hetkellä ensimmäisen asteen uudelleenkirjoitusta. Tällaisia uudelleenkirjoitusjärjestelmiä kutsutaan termien uudelleenkirjoitusjärjestelmiksi tai TRS :ksi ( englanniksi Term rewriting systems ).