Μ-recursieve functie

Uit testwiki
Naar navigatie springen Naar zoeken springen

In de theoretische informatica vormen de μ-recursieve functies een klasse van functies. De klasse is gedefinieerd als de klasse van functies die de basisfuncties bevat (de constante nulfunctie, de opvolgerfunctie en de projectiefuncties) en afgesloten is onder compositie, primitieve recursie en minimalisatie. De klasse van primitief recursieve functies vormen een onderklasse van de μ-recursieve functies. De μ-recursieve functies komen precies overeen met de berekenbare functies.

Definitie

μ-recursieve functies zijn partiële functies op de natuurlijke getallen, de verzameling ={0,1,2,3,}; het zijn functies die een of meer natuurlijke getallen als argumenten nemen en als functiewaarde ofwel een natuurlijk getal opleveren, ofwel niet gedefinieerd zijn.

De klasse der μ-recursieve functies is als volgt inductief gedefinieerd:

  • de constante 0-functie, dat wil zeggen de functie c0: zodat c0(x)=0, voor alle x, is μ-recursief;
  • de opvolgerfunctie s:, gedefinieerd als s(x)=x+1, is μ-recursief;
  • voor elke 0<jk is de projectiefunctie πj,k:k, gedefinieerd als πj,k(n1,,nk)=nj, μ-recursief;
  • de compositie van μ-recursieve functies is μ-recursief;
  • primitieve recursie: als g:k en h:k+2 μ-recursieve functies zijn, dan is ook de functie f:k+1 die gedefinieerd wordt als
f(0,n1,,nk)=g(n1,,nk)f(m+1,n1,,nk)=h(m,n1,,nk,f(m,n1,,nk))
μ-recursief.
  • minimalisatie: als f:k+1 een μ-recursieve functie is, dan is ook μf:k, die als volgt gedefinieerd is:
μf(n1,,nk)=min{mf(n1,,nk,m)=0 en voor alle m<m is f(n1,,nk,m) gedefinieerd}
μ-recursief. Hierbij is min niet gedefinieerd.

De minimalisatie μf van een functie f(x,y) is de kleinste waarde van y zodat f(x,y)=0. Als het zo is dat f(x,y)0 voor alle y, dan is μf(x) niet gedefinieerd.

Voorbeelden

  • Alle primitief recursieve functies zijn ook μ-recursief.
  • In het bijzonder is de primitief recursieve functie f(x,y)=1 voor alle x,y μ-recursief, want ze is de compositie van de opvolgerfunctie, de constante 0-functie en een projectiefunctie.
  • De overal ongedefinieerde functie ω, met ω(x) is niet gedefinieerd voor alle x, is μ-recursief. Deze functie ω is gelijk aan de minimalisatie μf van f (zie hierboven), omdat er geen m bestaat zodat f(x,m)=0. Dat wil zeggen: ω=μf.

Verband met andere klassen van functies

De μ-recursieve functies komen precies overeen met de berekenbare functies. Dat wil zeggen dat er voor elke μ-recursieve functie een turingmachine bestaat die de functie berekent, en andersom, dat elke turingmachine een μ-recursieve functie berekent. Functies die niet berekenbaar zijn, zoals de busy beaver-functie, zijn daarom ook niet μ-recursief.

De primitief recursieve functies vormen een echte onderklasse van de μ-recursieve functies. De klasse der μ-recursieve functies ontstaat als we de klasse der primitief recursieve functies onder minimalisatie afsluiten. Alle primitief recursieve functies zijn dus ook μ-recursief. Aan de andere kant bestaan er μ-recursieve functies die niet primitief recursief zijn, zoals de Ackermannfunctie.

Literatuur

  • Uwe Schöning, Theoretische Informatik – kurz gefasst, 5. Auflage, Spektrum, 2009
  • Elaine Rich, Automata, Computability and Complexity, Pearson, 2008

Sjabloon:Kleine letter