| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122 | <!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: D.12.3 Additional mtwist notes</title><meta name="description" content="avram - a virtual machine code interpreter: D.12.3 Additional mtwist notes"><meta name="keywords" content="avram - a virtual machine code interpreter: D.12.3 Additional mtwist notes"><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="Additional-mtwist-notes"></a><table cellpadding="1" cellspacing="1" border="0"><tr><td valign="middle" align="left">[<a href="mtwist-exceptions.html#mtwist-exceptions" title="Previous section in reading order"> < </a>]</td><td valign="middle" align="left">[<a href="minpack.html#minpack" title="Next section in reading order"> > </a>]</td><td valign="middle" align="left">   </td><td valign="middle" align="left">[<a href="External-Libraries.html#External-Libraries" title="Beginning of this chapter or previous chapter"> << </a>]</td><td valign="middle" align="left">[<a href="mtwist.html#mtwist" title="Up section"> Up </a>]</td><td valign="middle" align="left">[<a href="Copying.html#Copying" 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="Additional-mtwist-notes-1"></a><h3 class="subsection">D.12.3 Additional <code>mtwist</code> notes</h3><p>Although the <code>mtwist</code> library is “external”, it requires nospecial configuration on the host because the uniform variategenerator in the form developed by its original authors is short andelegant enough to be packaged easily within the <code>avram</code>distribution. All further embellishments are home grown despite theadvice at the end of <a href="Implementing-new-library-functions.html#Implementing-new-library-functions">Implementing new library functions</a>.</p><p>The <code>u_path</code> function is intended to allow sampling from a largepopulation in logarithmic time when it is stored in a balanced tree. Aleft-heavy tree should be constructed initially with the data itemsall at the same level. Thereafter, a result returned by <code>u_path</code>with the appropriate dimensions can be used as an index into the treefor fast retrieval by the virtual machine’s <code>field</code> combinator(<a href="Field.html#Field">Field</a>).</p><p>The last three functions, <code>u_enum</code>, <code>w_disc</code>, and<code>w_enum</code> use an inversion method with a binary search.  The firstdraw from a given list will take a time asymptotically proportional tothe length of the list, but subsequent draws from the same list areconsiderably faster due to a persistent cache maintained transparentlyby <code>avram</code>. For lists whose length is up to 2^16, the timerequired for a subsequent draw consists mainly of constant overheadwith a small logarithmic component in the length of the list. Forlonger lists, the time ramps up linearly by a small factor.</p><p>Information allowing fast draws from up to sixteen lists can be cachedsimultaneously. If an application uses more than sixteen, the cacheddata are replaced in first-in first-out order. The size of the cacheand the maximum list length for logarithmic time access can beadjusted easily by redefining constants in ‘<tt>mtwist.c</tt>’ under the<code>avram</code> source tree, but will require recompilation.</p><hr size="1"><table cellpadding="1" cellspacing="1" border="0"><tr><td valign="middle" align="left">[<a href="mtwist-exceptions.html#mtwist-exceptions" title="Previous section in reading order"> < </a>]</td><td valign="middle" align="left">[<a href="minpack.html#minpack" title="Next section in reading order"> > </a>]</td><td valign="middle" align="left">   </td><td valign="middle" align="left">[<a href="External-Libraries.html#External-Libraries" title="Beginning of this chapter or previous chapter"> << </a>]</td><td valign="middle" align="left">[<a href="mtwist.html#mtwist" title="Up section"> Up </a>]</td><td valign="middle" align="left">[<a href="Copying.html#Copying" 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>
 |