| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148 | <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html401/loose.dtd"><html><!-- Created on December 10, 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.8.1 Field</title><meta name="description" content="avram - a virtual machine code interpreter: 2.7.8.1 Field"><meta name="keywords" content="avram - a virtual machine code interpreter: 2.7.8.1 Field"><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="Field"></a><table cellpadding="1" cellspacing="1" border="0"><tr><td valign="middle" align="left">[<a href="Deconstruction.html#Deconstruction" title="Previous section in reading order"> < </a>]</td><td valign="middle" align="left">[<a href="Fan.html#Fan" 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="Deconstruction.html#Deconstruction" 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="Field-1"></a><h4 class="subsubsection">2.7.8.1 Field</h4><p>The virtual machine supports a generalization of the <code>left</code> and<a name="index-left-1"></a><a name="index-right-1"></a><code>right</code> deconstruction operations that is applicable to deeply nestedstructures. Use of this feature is conducive to code that is faster andmore compact than is possible by relying on the primitive deconstructorsalone. It may also be easier for a code optimizer to recognize andtransform.</p><p>The general form of a virtual code application to perform deconstructionis that it is a pair with a <code>nil</code> left side, and a non-<code>nil</code>right side. The right side indicates the nature of the deconstruction tobe performed when the function is evaluated on an argument.</p><p>To make the expression of deconstruction functions more readable in<code>silly</code>, the standard library contains the declaration</p><table><tr><td> </td><td><pre class="example">field = couple(constant nil,identity)</pre></td></tr></table><p>which implies the following theorem.</p><dl compact="compact"><dt> <em>T13</em></dt><dd><p>[[<code>field</code>]] <code><var>w</var></code> = <code>(nil,<var>w</var>)</code></p></dd></dl><a name="index-field"></a><p>The virtual machine recognizes an application in this form and evaluatesit according to the following properties, where <code><var>u</var></code> and<code><var>v</var></code> are other than <code>nil</code>, but <code><var>x</var></code>,<code><var>y</var></code>, and <code><var>z</var></code> are unrestricted.</p><dl compact="compact"><dt> <em>P10</em></dt><dd><p>([[<code>field</code>]] <code>(<var>u</var>,nil)</code>) <code>(<var>x</var>,<var>y</var>)</code> = ([[<code>field</code>]] <code><var>u</var></code>) <code><var>x</var></code></p></dd><dt> <em>P11</em></dt><dd><p>([[<code>field</code>]] <code>(nil,<var>v</var>)</code>) <code>(<var>x</var>,<var>y</var>)</code> = ([[<code>field</code>]] <code><var>v</var></code>) <code><var>y</var></code></p></dd><dt> <em>P12</em></dt><dd><p>([[<code>field</code>]] <code>(<var>u</var>,<code>v</code>)</code>) <code><var>z</var></code> = <code>((</code>[[<code>field</code>]] <code><var>u</var>) <var>z</var>,(</code>[[<code>field</code>]] <code><var>v</var>) <var>z</var>)</code></p></dd></dl><p>One might also add that ([[<code>field</code>]] <code>(nil,nil)</code>)<code><var>z</var></code> = <code><var>z</var></code>, but this statement would be equivalent to<em>P0</em>.</p><p>A suitable choice of the <code>field</code> operand permits the implementationof any deconstruction function expressible in terms of <code>compose</code>,<code>couple</code>, <code>identity</code>, <code>left</code> and <code>right</code>. Forexample, the application <code>couple(compose(right,right),left)</code> has anequivalent representation in<code>field((nil,(nil,(nil,nil))),((nil,nil),nil))</code>. The latter lookslonger in <code>silly</code> but is smaller and faster in virtual code.</p><hr size="1"><table cellpadding="1" cellspacing="1" border="0"><tr><td valign="middle" align="left">[<a href="Deconstruction.html#Deconstruction" title="Previous section in reading order"> < </a>]</td><td valign="middle" align="left">[<a href="Fan.html#Fan" 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="Deconstruction.html#Deconstruction" 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>December 10, 2012</i> using <a href="http://www.nongnu.org/texi2html/"><i>texi2html 1.82</i></a>. </font> <br></p></body></html>
 |