| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125 | <!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.7.4 Weight</title><meta name="description" content="avram - a virtual machine code interpreter: 2.7.7.4 Weight"><meta name="keywords" content="avram - a virtual machine code interpreter: 2.7.7.4 Weight"><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="Weight"></a><table cellpadding="1" cellspacing="1" border="0"><tr><td valign="middle" align="left">[<a href="Profile.html#Profile" title="Previous section in reading order"> < </a>]</td><td valign="middle" align="left">[<a href="Deconstruction.html#Deconstruction" 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="Metrics-and-Maintenance.html#Metrics-and-Maintenance" 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="Weight-1"></a><h4 class="subsubsection">2.7.7.4 Weight</h4><p>The following virtual code implements a function that returns the weightof its argument in the standard representation for natural numbers.<a name="index-weight"></a></p><table><tr><td> </td><td><pre class="example">weight = ((nil,nil),((nil,nil),(nil,(nil,nil))))</pre></td></tr></table><p>The weight of a tree is zero if the tree is <code>nil</code>, and otherwisethe sum of the weights of the two subtrees plus one.</p><p>An algorithm to compute the weight of a tree would be trivial toimplement without being built in to the virtual machine. The built incapability could also be used for purposes unrelated to codemaintenance. Nevertheless, it is built in for the following reasons.</p><ul><li> Computing weights happened to be a bottleneck for a particularaspect of code generation that was of interest to the author,<a name="index-compression"></a>namely the compression of generated code.</li><li> A built in implementation in C runs at least an order of magnitudefaster than the equivalent implementation in virtual code.</li><li> It runs even faster when repeated on the same data, by retrievingpreviously calculated weights rather than recalculating them.</li></ul><p>The only disadvantage of using this feature instead of implementing afunction in virtual code to compute weights is that it relies on native<a name="index-native-integer-arithmetic"></a><a name="index-overflow-1"></a>integer arithmetic and could overflow, causing a fatal error. It hasnever occurred in practice, but is possible due to sharing, whereby thenominal weight of a tree could be exponentially larger than the actualamount of memory occupied by it.</p><hr size="1"><table cellpadding="1" cellspacing="1" border="0"><tr><td valign="middle" align="left">[<a href="Profile.html#Profile" title="Previous section in reading order"> < </a>]</td><td valign="middle" align="left">[<a href="Deconstruction.html#Deconstruction" 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="Metrics-and-Maintenance.html#Metrics-and-Maintenance" 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>
 |