X-Git-Url: https://git.martlubbers.net/?a=blobdiff_plain;f=an_variabelen.tex;h=9e46b6b7e62b54113eda2c46239a6006ca282e71;hb=5e9465159adcd89f3739735ef20d7e8c508f0acb;hp=c3115d13b4add93f942286dfd548a0ffd7cd1cb8;hpb=65303619b64820767647cdfbae6e57676be7ce66;p=sec1415.git diff --git a/an_variabelen.tex b/an_variabelen.tex index c3115d1..9e46b6b 100644 --- a/an_variabelen.tex +++ b/an_variabelen.tex @@ -1 +1,16 @@ \subsection{Variabelen} +Variabelen in \textit{While} worden op een totaal andere manier opgeslagen in +\textit{Piet}. Waar variabelen in while een naam hebben, hebben variabelen in +\textit{Piet} een nummer en kunnen ze door het aanroepen van een functie +bovenaan gezet worden. De functie kan precies $1$ of precies $2$ variabelen +boven aan de stack zetten. Hetzelfde kan voor de variabelen posities $a$ en $b$ +waarbij $b>a$. De piet' code om de variabele boven aan te krijgen is dan als +volgt: $push b-1, push b-a, roll, push b, push b, push b*2, sub, roll$.\\ +Allereerst wordt $b-1$ op de stack gedrukt, dit bepaalt de diepte van de eerste +$roll$ en zorgt ervoor dat $a$ tegen $b$ aan komt te liggen. $b-a$ wordt dat op +de stack gepushed, dit is het verschil tussen $a$ en $b$ en bepaalt het aantal +rolls er gedaan wordt op de stack, dit zijn er precies genoeg om $a$ bij $b$ te +plaatsen. Vervolgens moeten ze nog naar boven en dat kan door $-b+1$ stappen te +rollen met een diepte van $b$. de eerste $push b$ bepaalt de diepje en +vervolgens wordt met $push b, push b*2-1, sub$ $b-1$ op de stack gepushed om te +rollen en $a$ en $b$ bovenaan te plaatsen.