| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136 | <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html401/loose.dtd"><html><!-- Created on November 8, 2012 by texi2html 1.82texi2html was written by:             Lionel Cons <[email protected]> (original author)            Karl Berry  <[email protected]>            Olaf Bachmann <[email protected]>            and many others.Maintained by: Many creative people.Send bugs and suggestions to <[email protected]>--><head><title>avram - a virtual machine code interpreter: 2.7.12 Iteration</title><meta name="description" content="avram - a virtual machine code interpreter: 2.7.12 Iteration"><meta name="keywords" content="avram - a virtual machine code interpreter: 2.7.12 Iteration"><meta name="resource-type" content="document"><meta name="distribution" content="global"><meta name="Generator" content="texi2html 1.82"><meta http-equiv="Content-Type" content="text/html; charset=utf-8"><style type="text/css"><!--a.summary-letter {text-decoration: none}blockquote.smallquotation {font-size: smaller}pre.display {font-family: serif}pre.format {font-family: serif}pre.menu-comment {font-family: serif}pre.menu-preformatted {font-family: serif}pre.smalldisplay {font-family: serif; font-size: smaller}pre.smallexample {font-size: smaller}pre.smallformat {font-family: serif; font-size: smaller}pre.smalllisp {font-size: smaller}span.roman {font-family:serif; font-weight:normal;}span.sansserif {font-family:sans-serif; font-weight:normal;}ul.toc {list-style: none}--></style></head><body lang="en" bgcolor="#FFFFFF" text="#000000" link="#0000FF" vlink="#800080" alink="#FF0000"><a name="Iteration"></a><table cellpadding="1" cellspacing="1" border="0"><tr><td valign="middle" align="left">[<a href="Member.html#Member" title="Previous section in reading order"> < </a>]</td><td valign="middle" align="left">[<a href="List-Combinators.html#List-Combinators" title="Next section in reading order"> > </a>]</td><td valign="middle" align="left">   </td><td valign="middle" align="left">[<a href="Virtual-Machine-Specification.html#Virtual-Machine-Specification" title="Beginning of this chapter or previous chapter"> << </a>]</td><td valign="middle" align="left">[<a href="Virtual-Code-Semantics.html#Virtual-Code-Semantics" title="Up section"> Up </a>]</td><td valign="middle" align="left">[<a href="Library-Reference.html#Library-Reference" title="Next chapter"> >> </a>]</td><td valign="middle" align="left">   </td><td valign="middle" align="left">   </td><td valign="middle" align="left">   </td><td valign="middle" align="left">   </td><td valign="middle" align="left">[<a href="avram.html#Top" title="Cover (top) of document">Top</a>]</td><td valign="middle" align="left">[<a href="avram_toc.html#SEC_Contents" title="Table of contents">Contents</a>]</td><td valign="middle" align="left">[<a href="Function-Index.html#Function-Index" title="Index">Index</a>]</td><td valign="middle" align="left">[<a href="avram_abt.html#SEC_About" title="About (help)"> ? </a>]</td></tr></table><hr size="1"><a name="Iteration-1"></a><h3 class="subsection">2.7.12 Iteration</h3><a name="index-recursion-1"></a><a name="index-iterate"></a><p>One of many alternatives to recursion provided by the virtual machine isiteration, which allows an operation to be repeated until a condition ismet. If the source language is imperative, this feature provides an easymeans of translating loop statements to virtual code. In languages that allowfunctions to be treated as data, iteration can be regarded as a functionthat takes a predicate and a function as arguments, and returns afunction that applies the given function repeatedly to its argumentuntil the predicate is refuted.</p><p>Iterative applications are expressed in virtual code by the pattern shown below.</p><dl compact="compact"><dt> <em>T21</em></dt><dd><p>[[<code>iterate</code>]] <code>(<var>p</var>,<var>f</var>)</code> = <code>((nil,nil),(nil,(<var>p</var>,<var>f</var>)))</code></p></dd></dl><p>In the <code>silly</code> language, the <code>iterate</code> mnemonic plays the roleof the function that takes the virtual code for a predicate<code><var>p</var></code> and a function <code><var>f</var></code> as arguments, and returnsthe virtual code for an iterating function.</p><p>The code for an iterating function is recognized as such by the virtualmachine emulator only if the subtrees <code><var>f</var></code> and <code><var>p</var></code> are otherthan <code>nil</code>. The resulting function tests the argument<code><var>x</var></code> with <code><var>p</var></code> and returns <code><var>x</var></code> if thepredicate is false.</p><dl compact="compact"><dt> <em>P22</em></dt><dd><p>([[<code>iterate</code>]] <code>(<var>p</var>,<var>f</var>)</code>) <code><var>x</var></code> = <code><var>x</var></code> if <code><var>p</var> <var>x</var></code> = <code>nil</code></p></dd></dl><p>If the predicate turns out to be true, <code><var>f</var></code> is applied to<code><var>x</var></code>, and then another iteration is performed.</p><dl compact="compact"><dt> <em>P23</em></dt><dd><p>([[<code>iterate</code>]] <code>(<var>p</var>,<var>f</var>)</code>) <code><var>x</var></code> =([[<code>iterate</code>]] <code>(<var>p</var>,<var>f</var>)</code>) <code><var>f</var> <var>x</var></code> if <code><var>p</var> <var>x</var></code> is a non-<code>nil</code> tree</p></dd></dl><hr size="1"><table cellpadding="1" cellspacing="1" border="0"><tr><td valign="middle" align="left">[<a href="Member.html#Member" title="Previous section in reading order"> < </a>]</td><td valign="middle" align="left">[<a href="List-Combinators.html#List-Combinators" title="Next section in reading order"> > </a>]</td><td valign="middle" align="left">   </td><td valign="middle" align="left">[<a href="Virtual-Machine-Specification.html#Virtual-Machine-Specification" title="Beginning of this chapter or previous chapter"> << </a>]</td><td valign="middle" align="left">[<a href="Virtual-Code-Semantics.html#Virtual-Code-Semantics" title="Up section"> Up </a>]</td><td valign="middle" align="left">[<a href="Library-Reference.html#Library-Reference" title="Next chapter"> >> </a>]</td><td valign="middle" align="left">   </td><td valign="middle" align="left">   </td><td valign="middle" align="left">   </td><td valign="middle" align="left">   </td><td valign="middle" align="left">[<a href="avram.html#Top" title="Cover (top) of document">Top</a>]</td><td valign="middle" align="left">[<a href="avram_toc.html#SEC_Contents" title="Table of contents">Contents</a>]</td><td valign="middle" align="left">[<a href="Function-Index.html#Function-Index" title="Index">Index</a>]</td><td valign="middle" align="left">[<a href="avram_abt.html#SEC_About" title="About (help)"> ? </a>]</td></tr></table><p> <font size="-1">  This document was generated on <i>November 8, 2012</i> using <a href="http://www.nongnu.org/texi2html/"><i>texi2html 1.82</i></a>. </font> <br></p></body></html>
 |