<snapdata remixID="9470874"><project name="Hypercompact Mandelbrot (Snap Codegolf)" app="Snap! 6, https://snap.berkeley.edu" version="1"><notes></notes><thumbnail>data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAKAAAAB4CAYAAAB1ovlvAAAgAElEQVR4Xu2dBbRuVdWG97GxCxsbO1AUOzBBFFEQFUHBRBAUFEwUFAsxEfGKAQZcwO6mVCzsawcGdoDd5x/PGv/7jfe8Z6797QNXvRddYzC4Z397r5hr9pxrroXjjz9+8TKXucxwvetdb1A74YQThm9+85vDIx/5yNkz/vGsZz1r2G+//dqzz33uc8NNb3rTJb/rj9e//vXDgx/84Nlvr371q4fTTz99eMYznrHku+c973nDk570pPbeq171qjbec57znOEpT3nK8LGPfWy47W1v257/4x//GK573esOd7zjHYeTTjppuP3tbz8885nPHJ7+9KcPBx988PCEJzyh9eHj5hxYE40+vJ188snD7W53u/bo+9///nCVq1xl2fr0LfPdf//9h1ve8pbtHX0LLH7/+9+3b/mPfn71q18NF7jABRpcWQvreu9731vCi/5zXqzztNNOa3AERoyttTu8eM588vtyoGEYtLfA9re//W37m3/zn9Z/zDHHDBtvvHHb3zvf+c7DRz7ykdbdJz/5ydnavX+fv/6d+OHvaByeLZxyyimLAqh3+o1vfGO49rWv3R594hOfGP76178OH//4x4enPvWp7dkb3vCG4WpXu9oMSUAe32QfECS60Y1u1Cbvm6zxvvrVr7aN4r273/3ubRO32GKL4f3vf/9s4X/7299miNIDriNdIlwCr9p0J6DFxcXhIQ95SHvExl/60pdeQqSasxD3xBNPXEJ0zP3CF75wgw9jgYx///vf298raSLM3jcQAXOFKL/yla8Mf/7znxsxOLH2CM6JiDn+4Ac/mK2B/d1pp51mnwpeYgz8oGePeMQjhsMPP7zt309+8pPGbMCTI444Yjjvec/bGEqPyBYWmb115pMFqPx8zWtec/jRj37UkPCUU04ZnvjEJy6BhzZDgK4QugdAp2reUV9CVLjnwx/+8CWfa1NAONpVr3rV4etf//pws5vdbMaV4Qw0cVgHnAD/ta99bck31UYJcEnlF73oRUsJkOsB4RjbWyKVcwufpzgryJVN7zGvpz3taW2MAw44oBHJRhttNONUPEPy5PjXuc51GkcWnFwSVGvucT/hjiTmgQce2ObD3MEXGBmE/NrXvnZ46EMf2qbhsJwhYDXApz/96WGzzTZbMvkE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</thumbnail><stage name="Stage" width="480" height="360" costume="0" color="255,255,255,1" tempo="60" threadsafe="false" penlog="false" volume="100" pan="0" lines="round" ternary="false" hyperops="true" codify="false" inheritance="true" sublistIDs="false" scheduled="false" id="1"><pentrails>data:image/png;base64,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</pentrails><costumes><list struct="atomic" id="2"></list></costumes><sounds><list struct="atomic" id="3"></list></sounds><variables></variables><blocks></blocks><scripts></scripts><sprites><sprite name="Sprite" idx="1" x="21.5" y="103" heading="90" scale="1" volume="100" pan="0" rotation="1" draggable="true" costume="1" color="80,80,80,1" pen="tip" id="8"><costumes><list id="9"><item><costume name="Untitled" center-x="0.5" center-y="1" image="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAACCAYAAACZgbYnAAAAEklEQVQYV2NgYGCYz8DAwJAAAAQkAQDq7tuWAAAAAElFTkSuQmCC" id="10"/></item></list></costumes><sounds><list struct="atomic" id="11"></list></sounds><blocks></blocks><variables></variables><scripts><script x="30" y="30"><block s="receiveGo"></block><custom-block s="USE BIGNUMS %b"><l><bool>true</bool></l></custom-block><block s="clear"></block><block s="doForever"><script><block s="doGotoObject"><l><option>random position</option></l></block><block s="doSetVar"><l>a</l><l>0+0i</l></block><block s="doRepeat"><l>16</l><script><block s="doSetVar"><l>a</l><custom-block s="sum %mult%n"><list><block s="reportProduct"><block var="a"/><block var="a"/></block><block s="reportQuotient"><block s="xPosition"></block><l>120</l></block><block s="reportJoinWords"><list><block s="reportQuotient"><block s="yPosition"></block><l>120</l></block><l>i</l></list></block></list></custom-block></block><block s="doIf"><block s="reportGreaterThan"><custom-block s="Scheme number %s of %s"><l>magnitude</l><block var="a"/></custom-block><l>4</l></block><script><block s="doStamp"></block></script></block></script></block></script></block></script><comment x="40" y="348.6666666666667" w="182" collapsed="false">USE TURBO MODE&#xD;&#xD;18 blocks excluding initiation&#xD;&#xD;This was obviously optimized for. reducing block count, and so it is very slow. I would seriously recommend not using random position rendering nor using BIGNUMS complex arithmetic, nor using stamping for rendering the Mandelbrot Set. All three of these are slower but more compact rendering alternatives.</comment></scripts></sprite><watcher var="a" style="normal" x="10" y="10" color="243,118,29" hidden="true"/><watcher scope="Sprite" s="xPosition" style="normal" x="10" y="31.000001999999995" color="74,108,212" hidden="true"/><watcher scope="Sprite" s="yPosition" style="normal" x="10" y="52.00000399999999" color="74,108,212" hidden="true"/></sprites></stage><hidden></hidden><headers></headers><code></code><blocks><block-definition s="reshape as %&apos;shape&apos; $⍴-1-255-255-0 items of %&apos;data&apos;" type="reporter" category="lists"><comment x="0" y="0" w="180" collapsed="false">The first input is a shape list as in&#xD;SHAPE OF.  The output is an array with those dimensions containing  the atomic items of the second input,&#xD;repeating values if more are needed.</comment><header></header><code></code><translations></translations><inputs><input type="%l"></input><input type="%l"></input></inputs><script><block s="doReport"><custom-block s="reshape helper %l %l"><block var="shape"/><custom-block s="flatten (ravel) $,-1-255-255-0 %l"><block var="data"/></custom-block></custom-block></block></script></block-definition><block-definition s="shape of $⍴-1-255-255-0 %&apos;data&apos;" type="reporter" category="lists"><comment x="0" y="0" w="310" collapsed="false">Reports a flat list of the maximum size of the input array along&#xD;each dimension: number of rows, number of columns, etc.&#xD;&quot;Maximum&quot; because it works even if the array isn&apos;t uniformly shaped.</comment><header></header><code></code><translations></translations><inputs><input type="%l"></input></inputs><script><block s="doDeclareVariables"><list><l>sublists</l></list></block><block s="doIfElse"><block s="reportIsA"><block var="data"/><l><option>list</option></l></block><script><block s="doSetVar"><l>sublists</l><block s="reportKeep"><block s="reifyPredicate"><autolambda><block s="reportNot"><block s="reportListIsEmpty"><l/></block></block></autolambda><list></list></block><block s="reportMap"><block s="reifyReporter"><autolambda><custom-block s="shape of $⍴-1-255-255-0 %l"><l/></custom-block></autolambda><list></list></block><block var="data"/></block></block></block><block s="doIfElse"><block s="reportListIsEmpty"><block var="sublists"/></block><script><block s="doReport"><block s="reportNewList"><list><block s="reportListLength"><block var="data"/></block></list></block></block></script><script><block s="doReport"><block s="reportCONS"><block s="reportListLength"><block var="data"/></block><custom-block s="flatten (ravel) $,-1-255-255-0 %l"><block s="reportMap"><block s="reifyReporter"><autolambda><block s="reportCombine"><block s="reportMap"><block s="reifyReporter"><autolambda><block s="reportListItem"><block var="number"/><l/></block></autolambda><list></list></block><block var="sublists"/></block><block s="reifyReporter"><autolambda><custom-block s="max %s $⌈-1-255-255-0 %s"><l></l><l></l></custom-block></autolambda><list></list></block></block></autolambda><list><l>number</l></list></block><block s="reportNumbers"><l>1</l><block s="reportCombine"><block s="reportMap"><block s="reifyReporter"><autolambda><block s="reportListLength"><l/></block></autolambda><list></list></block><block var="sublists"/></block><block s="reifyReporter"><autolambda><custom-block s="max %s $⌈-1-255-255-0 %s"><l></l><l></l></custom-block></autolambda><list></list></block></block></block></block></custom-block></block></block></script></block></script><script><block s="doReport"><block s="reportNewList"><list></list></block></block></script></block></script></block-definition><block-definition s="max %&apos;a&apos; $⌈-1-255-255-0 %&apos;b&apos;" type="reporter" category="operators"><comment x="0" y="0" w="150.66666666666666" collapsed="false">Reports the greater of its two inputs. Works on strings too.</comment><header></header><code></code><translations></translations><inputs><input type="%s"></input><input type="%s"></input></inputs><script><block s="doReport"><block s="evaluate"><custom-block s="scalar -&gt; hyper %repRing"><block s="reifyReporter"><autolambda><block s="reportIfElse"><block s="reportGreaterThan"><block var="a"/><block var="b"/></block><block var="a"/><block var="b"/></block></autolambda><list><l>a</l><l>b</l></list></block></custom-block><list><block var="a"/><block var="b"/></list></block></block></script></block-definition><block-definition s="flatten (ravel) $,-1-255-255-0 %&apos;data&apos;" type="reporter" category="lists"><comment x="0" y="0" w="216" collapsed="false">Reports a flat list of all the atomic elements &#xD;of sublists of the input list.</comment><header></header><code></code><translations></translations><inputs><input type="%l"></input></inputs><script><block s="doIfElse"><block s="reportIsA"><block var="data"/><l><option>list</option></l></block><script><block s="doReport"><block s="reportConcatenatedLists"><block s="reportMap"><block s="reifyReporter"><autolambda><custom-block s="flatten (ravel) $,-1-255-255-0 %l"><l/></custom-block></autolambda><list></list></block><block var="data"/></block></block></block></script><script><block s="doReport"><block s="reportNewList"><list><block var="data"/></list></block></block></script></block></script></block-definition><block-definition s="outer product %&apos;a&apos; $○.-1-255-255-0 %&apos;function&apos; %&apos;b&apos;" type="reporter" category="lists"><comment x="0" y="0" w="297.99999999999994" collapsed="false">Given two arrays A and B, reports an array whose dimensions are&#xD;APPEND(SHAPE OF (A), SHAPE OF (B))&#xD;in which each atomic item of the result is computed by applying the dyadic function input to an item of A and an item of B.</comment><header></header><code></code><translations></translations><inputs><input type="%l"></input><input type="%repRing"></input><input type="%l"></input></inputs><script><block s="doIf"><block s="reportEquals"><custom-block s="rank of $⍴⍴-1-255-255-0 %l"><block var="a"/></custom-block><l>0</l></block><script><block s="doReport"><block s="evaluate"><block var="function"/><list><block var="a"/><block var="b"/></list></block></block></script></block><block s="doIf"><block s="reportListIsEmpty"><block var="a"/></block><script><block s="doReport"><block s="reportNewList"><list></list></block></block></script></block><block s="doReport"><block s="reportCONS"><custom-block s="outer product %l $○.-1-255-255-0 %repRing %l"><block s="reportListItem"><l>1</l><block var="a"/></block><block var="function"/><block var="b"/></custom-block><custom-block s="outer product %l $○.-1-255-255-0 %repRing %l"><block s="reportCDR"><block var="a"/></block><block var="function"/><block var="b"/></custom-block></block></block></script></block-definition><block-definition s="identity $+-1-255-255-0 %&apos;x&apos;" type="reporter" category="operators"><comment x="0" y="0" w="210.00000000000003" collapsed="false">Reports its input.&#xD;This is useful to fit a value into a different-type input slot, e.g., number into list slot.</comment><header></header><code></code><translations></translations><inputs><input type="%s"></input></inputs><script><block s="doReport"><block var="x"/></block></script></block-definition><block-definition s="rank of $⍴⍴-1-255-255-0 %&apos;array&apos;" type="reporter" category="lists"><comment x="0" y="0" w="240" collapsed="true">Reports the number of dimensions of the input.</comment><header></header><code></code><translations></translations><inputs><input type="%l"></input></inputs><script><block s="doReport"><block s="reportListItem"><l>1</l><custom-block s="shape of $⍴-1-255-255-0 %l"><custom-block s="shape of $⍴-1-255-255-0 %l"><block var="array"/></custom-block></custom-block></block></block></script></block-definition><block-definition s="inner product helper with %&apos;plus&apos; . %&apos;times&apos; %&apos;a&apos; transposed %&apos;tb&apos;" type="reporter" category="other"><header></header><code></code><translations></translations><inputs><input type="%repRing"></input><input type="%repRing"></input><input type="%l"></input><input type="%l"></input></inputs><script><block s="doIf"><block s="reportListIsEmpty"><block var="a"/></block><script><block s="doReport"><block s="reportNewList"><list></list></block></block></script></block><block s="doIf"><block s="reportNot"><block s="reportIsA"><block s="reportListItem"><l>1</l><block s="reportListItem"><l>1</l><block var="a"/></block></block><l><option>list</option></l></block></block><script><block s="doReport"><block s="reportCONS"><block s="reportMap"><block s="reifyReporter"><autolambda><custom-block s="generalized dotproduct %l %l with sum %repRing product %repRing"><block s="reportListItem"><l>1</l><block var="a"/></block><l/><block var="plus"/><block var="times"/></custom-block></autolambda><list></list></block><block var="tb"/></block><custom-block s="inner product helper with %repRing . %repRing %l transposed %l"><block var="plus"/><block var="times"/><block s="reportCDR"><block var="a"/></block><block var="tb"/></custom-block></block></block></script></block><block s="doReport"><block s="reportCONS"><custom-block s="inner product helper with %repRing . %repRing %l transposed %l"><block var="plus"/><block var="times"/><block s="reportListItem"><l>1</l><block var="a"/></block><block var="tb"/></custom-block><custom-block s="inner product helper with %repRing . %repRing %l transposed %l"><block var="plus"/><block var="times"/><block s="reportCDR"><block var="a"/></block><block var="tb"/></custom-block></block></block></script></block-definition><block-definition s="transpose $⍉-1.5-255-255-0 %&apos;array&apos;" type="reporter" category="lists"><comment x="0" y="0" w="168" collapsed="false">Takes a multidimensional array, and&#xD;reports an array whose dimensions&#xD;are reversed (as reported by&#xD;SHAPE OF).  In the case of a&#xD;two-dimensional array, does the usual transposition of rows and columns.</comment><header></header><code></code><translations></translations><inputs><input type="%l"></input></inputs><script><block s="doIf"><block s="reportNot"><block s="reportIsA"><block var="array"/><l><option>list</option></l></block></block><script><block s="doReport"><block var="array"/></block></script></block><block s="doIf"><block s="reportListIsEmpty"><block var="array"/></block><script><block s="doReport"><block s="reportNewList"><list><block s="reportNewList"><list></list></block></list></block></block></script><comment w="290.6666666666667" collapsed="true">If there are no atomic data, we don&apos;t have any shape information, so we can&apos;t really transpose it.  But an empty list is 0 rows of some number of columns, so the transpose should be 0 columns in some number of rows.  We arbitrarily make it 0 columns of one row.  This at least has one dimension of the shape correct.</comment></block><block s="doIf"><block s="reportNot"><block s="reportIsA"><block s="reportListItem"><l>1</l><block var="array"/></block><l><option>list</option></l></block></block><script><block s="doReport"><block var="array"/></block></script><comment w="274.6666666666667" collapsed="true">The transpose of a vector is just the vector itself.</comment></block><block s="doIf"><block s="reportListIsEmpty"><block s="reportListItem"><l>1</l><block var="array"/></block></block><script><block s="doReport"><block s="reportNewList"><list></list></block></block></script><comment w="274.6666666666667" collapsed="true">This is the opposite no-atomic-data situation from above.  We know that there are (length array) rows of 0 columns, so the transpose is 0 rows, i.e., an empty list.  But we lose the number of original rows, transpose columns.</comment></block><block s="doReport"><custom-block s="deep map %repRing %predRing %l"><block s="reifyReporter"><autolambda><custom-block s="nth item 1 %n %l"><block s="reportListLength"><custom-block s="shape of $⍴-1-255-255-0 %l"><block var="array"/></custom-block></block><block s="reportListItem"><block s="reportMap"><block s="reifyReporter"><autolambda><block s="reportNewList"><list><l></l></list></block></autolambda><list></list></block><block var="atom"/></block><block var="array"/></block></custom-block></autolambda><list><l>atom</l></list></block><block s="reifyPredicate"><autolambda><block s="reportCombine"><block s="reportMap"><block s="reifyReporter"><autolambda><block s="reportNot"><block s="reportIsA"><l></l><l><option>list</option></l></block></block></autolambda><list></list></block><block var="node"/></block><block s="reifyReporter"><autolambda><block s="reportAnd"><l/><l/></block></autolambda><list></list></block></block></autolambda><list><l>node</l></list></block><custom-block s="$⍳-1.5-255-255-0 %n"><custom-block s="reverse row order (column contents) $⦵-1.5-255-255-0 %l"><custom-block s="shape of $⍴-1-255-255-0 %l"><block var="array"/></custom-block></custom-block></custom-block></custom-block></block></script><scripts><script x="690.0310872395834" y="485.55555555555566"><block var="array"/></script><script x="544.6666666666666" y="306.1111111111114"><block s="doIf"><block s="reportListIsEmpty"><block s="reportCDR"><block var="array"/></block></block><script><block s="doReport"><block s="reportMap"><block s="reifyReporter"><autolambda><block s="reportNewList"><list><l></l></list></block></autolambda><list></list></block><block s="reportListItem"><l>1</l><block var="array"/></block></block></block></script><comment w="212.66666666666666" collapsed="true">This is one row, n columns.  So the transpose is n rows, one column.</comment></block></script></scripts></block-definition><block-definition s="reverse row order (column contents) $⦵-1.5-255-255-0 %&apos;list&apos;" type="reporter" category="lists"><comment x="0" y="0" w="286" collapsed="false">Reverses the order of the (toplevel) items of the input.&#xD;&#xD;If the input is a matrix, this means it reverses the order of the rows, which is a reflection through a horizontal axis, as the ⦵ symbol suggests.</comment><header></header><code></code><translations></translations><inputs><input type="%l"></input></inputs><script><block s="doIf"><block s="reportListIsEmpty"><block var="list"/></block><script><block s="doReport"><block s="reportNewList"><list></list></block></block></script></block><block s="doReport"><block s="reportMap"><block s="reifyReporter"><autolambda><block s="reportListItem"><l></l><block var="list"/></block></autolambda><list></list></block><block s="reportNumbers"><block s="reportListLength"><block var="list"/></block><l>1</l></block></block></block></script></block-definition><block-definition s="deep insert %&apos;first&apos; %&apos;rest&apos;" type="reporter" category="other"><comment x="0" y="0" w="131.33333333333334" collapsed="false">Recursively deep-inserts&#xD;the items of the first input&#xD;into the items of the second&#xD;input.  If the first input is not&#xD;a list, then it is inserted with&#xD;IN FRONT OF in the second&#xD;unless the second also isn&apos;t&#xD;a list, in which case they are&#xD;combined with LIST.</comment><header></header><code></code><translations></translations><inputs><input type="%l"></input><input type="%l"></input></inputs><script><block s="doIf"><block s="reportNot"><block s="reportIsA"><block var="first"/><l><option>list</option></l></block></block><script><block s="doIf"><block s="reportNot"><block s="reportIsA"><block var="rest"/><l><option>list</option></l></block></block><script><block s="doReport"><block s="reportNewList"><list><block var="first"/><block var="rest"/></list></block></block></script></block><block s="doReport"><block s="reportCONS"><block var="first"/><block var="rest"/></block></block></script></block><block s="doIf"><block s="reportAnd"><block s="reportNot"><block s="reportIsA"><block s="reportListItem"><l>1</l><block var="first"/></block><l><option>list</option></l></block></block><block s="reportListIsEmpty"><block s="reportCDR"><block var="first"/></block></block></block><script><block s="doReport"><block s="reportCONS"><block s="reportListItem"><l>1</l><block var="first"/></block><block var="rest"/></block></block></script></block><block s="doReport"><custom-block s="multimap %repRing %mult%l"><block s="reifyReporter"><autolambda><custom-block s="deep insert %l %l"><l/><l/></custom-block></autolambda><list></list></block><list><block var="first"/><block var="rest"/></list></custom-block></block></script></block-definition><block-definition s="multimap %&apos;function&apos; %&apos;data&apos;" type="reporter" category="other"><comment x="0" y="0" w="215.33333333333334" collapsed="false">Like MAP, but can take any number of lists&#xD;as inputs.  The lists must all be the same size.&#xD;The function input must take a number of inputs&#xD;equal to the number of lists.  MULTIMAP calls&#xD;the function with all the first items, then all the&#xD;second items, and so on.</comment><header></header><code></code><translations></translations><inputs><input type="%repRing"></input><input type="%mult%l"></input></inputs><script><block s="doIf"><custom-block s="combine in rows (reduce by column vectors) %repRing $/-1-255-255-0 %l"><block s="reifyReporter"><autolambda><block s="reportOr"><l/><l/></block></autolambda><list></list></block><block s="reportMap"><block s="reifyReporter"><autolambda><block s="reportListIsEmpty"><l/></block></autolambda><list></list></block><block var="data"/></block></custom-block><script><block s="doIfElse"><custom-block s="combine in rows (reduce by column vectors) %repRing $/-1-255-255-0 %l"><block s="reifyReporter"><autolambda><block s="reportAnd"><l/><l/></block></autolambda><list></list></block><block s="reportMap"><block s="reifyReporter"><autolambda><block s="reportListIsEmpty"><l/></block></autolambda><list></list></block><block var="data"/></block></custom-block><script><block s="doReport"><block s="reportNewList"><list></list></block></block></script><script><custom-block s="error %txt"><l>Non-conforming shapes.</l></custom-block></script></block></script></block><block s="doReport"><block s="reportCONS"><block s="evaluate"><block var="function"/><block s="reportMap"><block s="reifyReporter"><autolambda><block s="reportListItem"><l>1</l><l/></block></autolambda><list></list></block><block var="data"/></block></block><custom-block s="multimap %repRing %mult%l"><block var="function"/><block s="reportMap"><block s="reifyReporter"><autolambda><block s="reportCDR"><l/></block></autolambda><list></list></block><block var="data"/></block></custom-block></block></block></script></block-definition><block-definition s="printable %&apos;data&apos;" type="reporter" category="lists"><comment x="0" y="0" w="188.66666666666666" collapsed="false">Takes a (possibly deep) list as input,&#xD;and reports a human-readable text form &#xD;of the list (namely, Lisp notation).</comment><header></header><code></code><translations></translations><inputs><input type="%l"></input></inputs><script><block s="doIf"><block s="reportNot"><block s="reportIsA"><block var="data"/><l><option>list</option></l></block></block><script><block s="doReport"><block var="data"/></block></script></block><block s="doIf"><block s="reportListIsEmpty"><block var="data"/></block><script><block s="doReport"><l>()</l></block></script></block><block s="doReport"><block s="reportJoinWords"><list><l>(</l><block s="reportCombine"><block s="reportMap"><block s="reifyReporter"><autolambda><custom-block s="printable %l"><l/></custom-block></autolambda><list></list></block><block var="data"/></block><block s="reifyReporter"><autolambda><block s="reportJoinWords"><list><l></l><l> </l><l></l></list></block></autolambda><list></list></block></block><l>)</l></list></block></block></script></block-definition><block-definition s="generalized dotproduct %&apos;a&apos; %&apos;b&apos; with sum %&apos;sum&apos; product %&apos;product&apos;" type="reporter" category="other"><header></header><code></code><translations></translations><inputs><input type="%l"></input><input type="%l"></input><input type="%repRing"></input><input type="%repRing"></input></inputs><script><block s="doReport"><block s="reportCombine"><custom-block s="multimap %repRing %mult%l"><block var="product"/><list><block var="a"/><block var="b"/></list></custom-block><block var="sum"/></block></block></script></block-definition><block-definition s="inner product %&apos;a&apos; %&apos;plus&apos; $.-1-255-255-0 %&apos;times&apos; %&apos;b&apos;" type="reporter" category="lists"><comment x="0" y="0" w="252.66666666666666" collapsed="false">Computes a generalized matrix multiplication.&#xD;&#xD;In normal matrix multiplication, each cell of the result&#xD;is computed by multiplying individual numbers within&#xD;a row of the left input and a column of the right input,&#xD;and then adding those products.  In APL terms this is&#xD;+.× (&quot;plus dot times&quot;)&#xD;Any dyadic functions can replace addition and multiplication in this algorithm; a common case is&#xD;∨.∧ (&quot;or dot and&quot;)</comment><header></header><code></code><translations></translations><inputs><input type="%l"></input><input type="%repRing"></input><input type="%repRing"></input><input type="%l"></input></inputs><script><block s="doIf"><block s="reportNot"><block s="reportIsA"><block var="a"/><l><option>list</option></l></block></block><script><block s="doSetVar"><l>a</l><block s="reportNewList"><list><block var="a"/></list></block></block></script></block><block s="doIf"><block s="reportNot"><block s="reportIsA"><block var="b"/><l><option>list</option></l></block></block><script><block s="doSetVar"><l>b</l><block s="reportNewList"><list><block var="b"/></list></block></block></script></block><block s="doIf"><block s="reportAnd"><block s="reportEquals"><block s="reportListItem"><l><option>last</option></l><custom-block s="shape of $⍴-1-255-255-0 %l"><block var="a"/></custom-block></block><l>1</l></block><block s="reportGreaterThan"><block s="reportListItem"><l>1</l><custom-block s="shape of $⍴-1-255-255-0 %l"><block var="b"/></custom-block></block><l>1</l></block></block><script><block s="doDeclareVariables"><list><l>ta</l></list></block><block s="doSetVar"><l>ta</l><custom-block s="transpose $⍉-1.5-255-255-0 %l"><block var="a"/></custom-block></block><block s="doSetVar"><l>a</l><custom-block s="transpose $⍉-1.5-255-255-0 %l"><block s="reportMap"><block s="reifyReporter"><autolambda><block var="ta"/></autolambda><list></list></block><block s="reportNumbers"><l>1</l><block s="reportListItem"><l>1</l><custom-block s="shape of $⍴-1-255-255-0 %l"><block var="b"/></custom-block></block></block></block></custom-block></block></script></block><block s="doIf"><block s="reportAnd"><block s="reportGreaterThan"><block s="reportListItem"><l><option>last</option></l><custom-block s="shape of $⍴-1-255-255-0 %l"><block var="a"/></custom-block></block><l>1</l></block><block s="reportEquals"><block s="reportListItem"><l>1</l><custom-block s="shape of $⍴-1-255-255-0 %l"><block var="b"/></custom-block></block><l>1</l></block></block><script><block s="doSetVar"><l>b</l><block s="reportMap"><block s="reifyReporter"><autolambda><block var="b"/></autolambda><list></list></block><block s="reportNumbers"><l>1</l><block s="reportListItem"><l><option>last</option></l><custom-block s="shape of $⍴-1-255-255-0 %l"><block var="a"/></custom-block></block></block></block></block></script></block><block s="doReport"><custom-block s="inner product helper with %repRing . %repRing %l transposed %l"><block var="plus"/><block var="times"/><block var="a"/><custom-block s="transpose $⍉-1.5-255-255-0 %l"><block var="b"/></custom-block></custom-block></block></script></block-definition><block-definition s="min %&apos;a&apos; $⌊-1.2-255-255-0 %&apos;b&apos;" type="reporter" category="operators"><comment x="0" y="0" w="211.33333333333334" collapsed="true">Reports the smaller of its two inputs.</comment><header></header><code></code><translations></translations><inputs><input type="%s"></input><input type="%s"></input></inputs><script><block s="doReport"><block s="evaluate"><custom-block s="scalar -&gt; hyper %repRing"><block s="reifyReporter"><autolambda><block s="reportIfElse"><block s="reportLessThan"><block var="a"/><block var="b"/></block><block var="a"/><block var="b"/></block></autolambda><list><l>a</l><l>b</l></list></block></custom-block><list><block var="a"/><block var="b"/></list></block></block></script></block-definition><block-definition s="log base %&apos;b&apos; $⍟-1.5-255-255-0 %&apos;x&apos;" type="reporter" category="operators"><comment x="0" y="0" w="212" collapsed="false">Computes logarithms in any base.&#xD;&#xD;The base is the left input.  It&apos;s usual in APL that if there&apos;s a main data input and some sort of control input, the latter comes on the left.  This is because APL syntax, unless you use parentheses, groups computations from right to left.&#xD;&#xD;APL has a monadic version of this function that computes natural logs (log to the base e).</comment><header></header><code></code><translations></translations><inputs><input type="%n"></input><input type="%n"></input></inputs><script><block s="doReport"><block s="evaluate"><custom-block s="scalar -&gt; hyper %repRing"><block s="reifyReporter"><autolambda><block s="reportQuotient"><block s="reportMonadic"><l><option>ln</option></l><block var="x"/></block><block s="reportMonadic"><l><option>ln</option></l><block var="b"/></block></block></autolambda><list><l>b</l><l>x</l></list></block></custom-block><list><block var="b"/><block var="x"/></list></block></block></script></block-definition><block-definition s="combs %&apos;r&apos; at a time $!-1-255-255-0 of %&apos;n&apos;" type="reporter" category="operators"><comment x="0" y="0" w="218.66666666666666" collapsed="false">Computes the number of combinations of right-input things taken left-input at a time, otherwise known as the elements of Pascal&apos;s triangle.  This block shares the ! symbol with the monadic factorial function, because the formula for computing this function uses factorials.</comment><header></header><code></code><translations></translations><inputs><input type="%n"></input><input type="%n"></input></inputs><script><block s="doReport"><block s="evaluate"><custom-block s="scalar -&gt; hyper %repRing"><block s="reifyReporter"><autolambda><block s="reportIfElse"><block s="reportAnd"><custom-block s="%s ≥ %s"><block var="n"/><l>0</l></custom-block><block s="reportAnd"><custom-block s="%s ≥ %s"><block var="r"/><l>0</l></custom-block><custom-block s="%s ≤ %s"><block var="r"/><block var="n"/></custom-block></block></block><block s="reportQuotient"><custom-block s="factorial $!-1-255-255-0 %n"><block var="n"/></custom-block><block s="reportProduct"><custom-block s="factorial $!-1-255-255-0 %n"><block var="r"/></custom-block><custom-block s="factorial $!-1-255-255-0 %n"><block s="reportDifference"><block var="n"/><block var="r"/></block></custom-block></block></block><l>0</l></block></autolambda><list><l>r</l><l>n</l></list></block></custom-block><list><block var="r"/><block var="n"/></list></block></block></script></block-definition><block-definition s="factorial $!-1-255-255-0 %&apos;n&apos;" type="reporter" category="operators"><comment x="0" y="0" w="172.66666666666666" collapsed="false">The factorial of a positive integer n is the product of the integers from 1 to n.&#xD;&#xD;In real APL, the domain of this function is extended beyond integers to compute the gamma function.</comment><header></header><code></code><translations></translations><inputs><input type="%n"></input></inputs><script><block s="doIfElse"><block s="reportIsA"><block var="n"/><l><option>list</option></l></block><script><block s="doReport"><block s="reportMap"><block s="reifyReporter"><autolambda><custom-block s="factorial $!-1-255-255-0 %n"><l></l></custom-block></autolambda><list></list></block><block var="n"/></block></block></script><script><block s="doReport"><block s="reportIfElse"><custom-block s="zero? %n"><block var="n"/></custom-block><l>1</l><custom-block s="combine in rows (reduce by column vectors) %repRing $/-1-255-255-0 %l"><block s="reifyReporter"><autolambda><block s="reportProduct"><l></l><l></l></block></autolambda><list></list></block><block s="reportNumbers"><l>1</l><block var="n"/></block></custom-block></block></block></script></block></script></block-definition><block-definition s="combine in rows (reduce by column vectors) %&apos;func&apos; $/-1-255-255-0 %&apos;stuff&apos;" type="reporter" category="lists"><comment x="0" y="0" w="288.6666666666667" collapsed="false">This function has two names because there are two ways&#xD;to understand it.&#xD;&#xD;Lisp way:  A matrix is a list of rows.  This block combines the numbers in each row, producing one value for the entire row.&#xD;&#xD;APL way:  A matrix is made of vectors.  This block takes each column as a vector, and does vector arithmetic on the columns, producing one column as the result.</comment><header></header><code></code><translations></translations><inputs><input type="%repRing"></input><input type="%l"></input></inputs><script><block s="doIfElse"><block s="reportGreaterThan"><custom-block s="rank of $⍴⍴-1-255-255-0 %l"><block var="stuff"/></custom-block><l>1</l></block><script><block s="doReport"><block s="reportMap"><block s="reifyReporter"><autolambda><custom-block s="combine in rows (reduce by column vectors) %repRing $/-1-255-255-0 %l"><block var="func"/><l/></custom-block></autolambda><list></list></block><block var="stuff"/></block></block></script><script><block s="doReport"><block s="reportCombine"><block var="stuff"/><block var="func"/></block></block></script></block></script></block-definition><block-definition s="error %&apos;msg&apos;" type="command" category="control"><header></header><code></code><translations>pt:lança o erro _&#xD;</translations><inputs><input type="%txt"></input></inputs><script><block s="doRun"><block s="reportJSFunction"><list><l>msg</l></list><l>throw new Error(msg);</l></block><list><block var="msg"/></list></block></script></block-definition><block-definition s="%&apos;a&apos; scalar %&apos;pred&apos; %&apos;b&apos;" type="predicate" category="operators"><comment x="0" y="0" w="190" collapsed="false">Acts just like the function selected from&#xD;the pulldown menu, but hyperized, so&#xD;comparing two equal-sized lists reports&#xD;a list of the same length as the inputs,&#xD;with the results of item-by-item comparisons.</comment><header></header><code></code><translations></translations><inputs><input type="%s"></input><input type="%s" readonly="true">﹦<options>﹦&#xD;≠&#xD;identical to&#xD;and&#xD;or&#xD;is _ a _?</options></input><input type="%s"></input></inputs><script><block s="doReport"><block s="evaluate"><custom-block s="scalar -&gt; hyper %repRing"><block s="reifyReporter"><autolambda><block s="evaluate"><block s="reportListItem"><block s="reportListIndex"><block var="pred"/><block s="reportNewList"><list><l>﹦</l><l>≠</l><l>identical to</l><l>and</l><l>or</l><l>is _ a _?</l></list></block></block><block s="reportNewList"><list><block s="reifyPredicate"><autolambda><block s="reportEquals"><l></l><l></l></block></autolambda><list></list></block><block s="reifyPredicate"><autolambda><block s="reportNot"><block s="reportEquals"><l></l><l></l></block></block></autolambda><list></list></block><block s="reifyPredicate"><autolambda><block s="reportIsIdentical"><l></l><l></l></block></autolambda><list></list></block><block s="reifyPredicate"><autolambda><block s="reportAnd"><l/><l/></block></autolambda><list></list></block><block s="reifyPredicate"><autolambda><block s="reportOr"><l/><l/></block></autolambda><list></list></block><block s="reifyPredicate"><autolambda><block s="reportIsA"><l></l><l></l></block></autolambda><list></list></block></list></block></block><list><block var="a"/><block var="b"/></list></block></autolambda><list><l>a</l><l>b</l></list></block></custom-block><list><block var="a"/><block var="b"/></list></block></block></script></block-definition><block-definition s="%&apos;howmany&apos; deal $?-1-255-255-0 %&apos;range&apos;" type="reporter" category="operators"><comment x="0" y="0" w="177.33333333333334" collapsed="false">Report a list with left-input random integers in the range 1 to right-input.&#xD;No number appears more than once&#xD;in the result.</comment><header></header><code></code><translations></translations><inputs><input type="%n"></input><input type="%n"></input></inputs><script><block s="doReport"><block s="evaluate"><custom-block s="scalar -&gt; hyper %repRing"><block s="reifyReporter"><autolambda><custom-block s="%n deal helper %l"><block var="howmany"/><block s="reportNumbers"><l>1</l><block var="range"/></block></custom-block></autolambda><list><l>howmany</l><l>range</l></list></block></custom-block><list><block var="howmany"/><block var="range"/></list></block></block></script></block-definition><block-definition s="%&apos;howmany&apos; deal helper %&apos;data&apos;" type="reporter" category="other"><header></header><code></code><translations></translations><inputs><input type="%n"></input><input type="%l"></input></inputs><script><block s="doIf"><block s="reportEquals"><block var="howmany"/><l>0</l></block><script><block s="doReport"><block s="reportNewList"><list></list></block></block></script></block><block s="doDeclareVariables"><list><l>choice</l></list></block><block s="doSetVar"><l>choice</l><block s="reportListItem"><block s="reportRandom"><l>1</l><block s="reportListLength"><block var="data"/></block></block><block var="data"/></block></block><block s="doReport"><block s="reportCONS"><block var="choice"/><custom-block s="%n deal helper %l"><block s="reportDifference"><block var="howmany"/><l>1</l></block><block s="reportKeep"><block s="reifyPredicate"><autolambda><block s="reportNot"><block s="reportEquals"><l></l><block var="choice"/></block></block></autolambda><list></list></block><block var="data"/></block></custom-block></block></block></script></block-definition><block-definition s="signum $×-1-255-255-0 %&apos;num&apos;" type="reporter" category="operators"><comment x="0" y="0" w="159.99999999999997" collapsed="false">Reports 1 if the input is positive,&#xD;0 if the input is zero,&#xD;or -1 if the input is negative.</comment><header></header><code></code><translations></translations><inputs><input type="%n"></input></inputs><script><block s="doIf"><block s="reportIsA"><block var="num"/><l><option>list</option></l></block><script><block s="doReport"><block s="reportMap"><block s="reifyReporter"><autolambda><custom-block s="signum $×-1-255-255-0 %n"><l></l></custom-block></autolambda><list></list></block><block var="num"/></block></block></script></block><block s="doIf"><block s="reportListContainsItem"><block s="reportNewList"><list><l>0</l><block s="reportBoolean"><l><bool>false</bool></l></block></list></block><block var="num"/></block><script><block s="doReport"><l>0</l></block></script></block><block s="doReport"><block s="reportQuotient"><block var="num"/><block s="reportMonadic"><l><option>abs</option></l><block var="num"/></block></block></block></script></block-definition><block-definition s="reciprocal $÷-1-255-255-0 %&apos;num&apos;" type="reporter" category="operators"><comment x="0" y="0" w="102.66666666666667" collapsed="false">reports 1 divided&#xD;by its input.</comment><header></header><code></code><translations></translations><inputs><input type="%n"></input></inputs><script><block s="doReport"><block s="reportQuotient"><l>1</l><block var="num"/></block></block></script></block-definition><block-definition s="roll $?-1-255-255-0 %&apos;num&apos;" type="reporter" category="operators"><comment x="0" y="0" w="180.66666666666666" collapsed="false">This block reports a random integer between 1 and its input.  To roll more than one die, use (for three dice)&#xD;roll (reshape as 3 items of 6)&#xD;APL:  ?3⍴6&#xD;Don&apos;t use reshape as 3 items of roll 6, because that would roll one die and report 3 copies of the same random roll. </comment><header></header><code></code><translations></translations><inputs><input type="%n"></input></inputs><script><block s="doReport"><block s="reportRandom"><l>1</l><block var="num"/></block></block></script></block-definition><block-definition s="GCD (or) %&apos;a&apos; $∨-1.2-255-255-0 %&apos;b&apos;" type="reporter" category="operators"><comment x="0" y="0" w="230.66666666666666" collapsed="false">Reports the greatest common divisor of its inputs.&#xD;If the inputs are values in {0,1} then this is equivalent to the logical OR of the values, with 0=False, 1=True.  Hence the APL symbol ∨.&#xD;Also accepts Snap! Booleans as inputs.</comment><header></header><code></code><translations></translations><inputs><input type="%n"></input><input type="%n"></input></inputs><script><block s="doReport"><block s="evaluate"><custom-block s="scalar -&gt; hyper %repRing"><block s="reifyReporter"><script><block s="doIf"><block s="reportListContainsItem"><block s="reportNewList"><list><l>0</l><block s="reportBoolean"><l><bool>false</bool></l></block></list></block><block var="b"/></block><script><block s="doReport"><block var="a"/></block></script></block><block s="doReport"><custom-block s="GCD (or) %n $∨-1.2-255-255-0 %n"><block var="b"/><block s="reportModulus"><block var="a"/><block var="b"/></block></custom-block></block></script><list><l>a</l><l>b</l></list></block></custom-block><list><block var="a"/><block var="b"/></list></block></block></script></block-definition><block-definition s="scalar -&gt; hyper %&apos;func&apos;" type="reporter" category="control"><comment x="0" y="0" w="218" collapsed="false">Takes a dyadic scalar function as input, and&#xD;hyperizes it, so that it can take lists as inputs.</comment><header></header><code></code><translations></translations><inputs><input type="%repRing"></input></inputs><script><block s="doDeclareVariables"><list><l>hyper func</l></list></block><block s="doSetVar"><l>hyper func</l><block s="reifyReporter"><script><block s="doIfElse"><custom-block s="scalar? %s"><block var="a"/></custom-block><script><block s="doIfElse"><custom-block s="scalar? %s"><block var="b"/></custom-block><script><block s="doReport"><block s="evaluate"><block var="func"/><list><custom-block s="scalar-value helper %s"><block var="a"/></custom-block><custom-block s="scalar-value helper %s"><block var="b"/></custom-block></list></block></block></script><script><block s="doReport"><block s="reportMap"><block s="reifyReporter"><autolambda><block s="evaluate"><block var="hyper func"/><list><custom-block s="scalar-value helper %s"><block var="a"/></custom-block><l></l></list></block></autolambda><list></list></block><block var="b"/></block></block></script></block></script><script><block s="doIfElse"><custom-block s="scalar? %s"><block var="b"/></custom-block><script><block s="doReport"><block s="reportMap"><block s="reifyReporter"><autolambda><block s="evaluate"><block var="hyper func"/><list><l></l><custom-block s="scalar-value helper %s"><block var="b"/></custom-block></list></block></autolambda><list></list></block><block var="a"/></block></block></script><script><block s="doReport"><custom-block s="multimap %repRing %mult%l"><block var="hyper func"/><list><block var="a"/><block var="b"/></list></custom-block></block></script></block></script></block></script><list><l>a</l><l>b</l></list></block></block><block s="doReport"><block var="hyper func"/></block></script></block-definition><block-definition s="scalar? %&apos;x&apos;" type="predicate" category="other"><comment x="0" y="0" w="199.33333333333334" collapsed="false">Reports True if the input is an APL scalar,&#xD;i.e., either an atomic (non-list) value, or&#xD;an array (list of lists) of any depth with only&#xD;one atomic item, e.g., (list (list (list (3)))).</comment><header></header><code></code><translations></translations><inputs><input type="%s"></input></inputs><script><block s="doIf"><block s="reportNot"><block s="reportIsA"><block var="x"/><l><option>list</option></l></block></block><script><block s="doReport"><block s="reportBoolean"><l><bool>true</bool></l></block></block></script></block><block s="doReport"><block s="reportEquals"><block s="reportCombine"><custom-block s="shape of $⍴-1-255-255-0 %l"><block var="x"/></custom-block><block s="reifyReporter"><autolambda><block s="reportProduct"><l></l><l></l></block></autolambda><list></list></block></block><l>1</l></block></block></script></block-definition><block-definition s="scalar-value helper %&apos;x&apos;" type="reporter" category="other"><comment x="0" y="0" w="200.66666666666666" collapsed="false">The input must be a value for which SCALAR? reports true, i.e., either an atom or a list of any depth but only one scalar item of item of... etc.  This function returns the underlying scalar (number, etc.).</comment><header></header><code></code><translations></translations><inputs><input type="%s"></input></inputs><script><block s="doIf"><block s="reportNot"><block s="reportIsA"><block var="x"/><l><option>list</option></l></block></block><script><block s="doReport"><block var="x"/></block></script></block><block s="doReport"><custom-block s="scalar-value helper %s"><block s="reportListItem"><l>1</l><block var="x"/></block></custom-block></block></script></block-definition><block-definition s="LCM (and) %&apos;a&apos; $∧-1.2-255-255-0 %&apos;b&apos;" type="reporter" category="operators"><comment x="0" y="0" w="230.66666666666666" collapsed="false">Reports the least common multiple of its inputs.&#xD;If the inputs are values in {0,1} then this is equivalent to the logical AND of the values, with 0=False, 1=True.  Hence the APL symbol ∧.&#xD;Also accepts Snap! Booleans as inputs.</comment><header></header><code></code><translations></translations><inputs><input type="%n"></input><input type="%n"></input></inputs><script><block s="doReport"><block s="evaluate"><custom-block s="scalar -&gt; hyper %repRing"><block s="reifyReporter"><script><block s="doIf"><block s="reportListContainsItem"><block s="reportNewList"><list><l>0</l><block s="reportBoolean"><l><bool>false</bool></l></block></list></block><block var="b"/></block><script><block s="doReport"><block var="b"/></block></script></block><block s="doReport"><block s="reportProduct"><block var="a"/><block s="reportQuotient"><block var="b"/><custom-block s="GCD (or) %n $∨-1.2-255-255-0 %n"><block var="a"/><block var="b"/></custom-block></block></block></block></script><list><l>a</l><l>b</l></list></block></custom-block><list><block var="a"/><block var="b"/></list></block></block></script></block-definition><block-definition s="NAND %&apos;a&apos; $⍲-1.4-255-255-0 %&apos;b&apos;" type="predicate" category="operators"><comment x="0" y="0" w="198.66666666666666" collapsed="false">Reports the not-and of its inputs, in the form&#xD;0 for false, 1 for true.</comment><header></header><code></code><translations></translations><inputs><input type="%s"></input><input type="%s"></input></inputs><script><block s="doReport"><custom-block s="NOT $&#126;-1-255-255-0 %s"><custom-block s="LCM (and) %n $∧-1.2-255-255-0 %n"><block var="a"/><block var="b"/></custom-block></custom-block></block></script></block-definition><block-definition s="NOT $&#126;-1-255-255-0 %&apos;p&apos;" type="reporter" category="operators"><comment x="0" y="0" w="167.33333333333334" collapsed="false">Reports 1 if the input is False or 0;&#xD;otherwise reports 0.</comment><header></header><code></code><translations></translations><inputs><input type="%s"></input></inputs><script><block s="doReport"><block s="reportDifference"><l>1</l><custom-block s="signum $×-1-255-255-0 %n"><block var="p"/></custom-block></block></block></script></block-definition><block-definition s="NOR %&apos;a&apos; $⍱-1.4-255-255-0 %&apos;b&apos;" type="predicate" category="operators"><comment x="0" y="0" w="198.66666666666666" collapsed="false">Reports the not-and of its inputs, in the form&#xD;0 for false, 1 for true.</comment><header></header><code></code><translations></translations><inputs><input type="%s"></input><input type="%s"></input></inputs><script><block s="doReport"><custom-block s="NOT $&#126;-1-255-255-0 %s"><custom-block s="GCD (or) %n $∨-1.2-255-255-0 %n"><block var="a"/><block var="b"/></custom-block></custom-block></block></script></block-definition><block-definition s="%&apos;a&apos; ≤ %&apos;b&apos;" type="predicate" category="operators"><comment x="0" y="0" w="151.33333333333334" collapsed="false">Reports True if the left input is&#xD;less than or equal to the right input.&#xD;&#xD;Reports a Snap! Boolean, not an integer 0 or 1.</comment><header></header><code></code><translations></translations><inputs><input type="%s"></input><input type="%s"></input></inputs><script><block s="doReport"><custom-block s="truth %s"><custom-block s="NOT $&#126;-1-255-255-0 %s"><block s="reportGreaterThan"><block var="a"/><block var="b"/></block></custom-block></custom-block></block></script></block-definition><block-definition s="%&apos;a&apos; ≥ %&apos;b&apos;" type="predicate" category="operators"><comment x="0" y="0" w="152.66666666666666" collapsed="false">Reports True if the left input is&#xD;greater than than or equal to&#xD;the right input.&#xD;&#xD;Reports a Snap! Boolean, not an integer 0 or 1.</comment><header></header><code></code><translations></translations><inputs><input type="%s"></input><input type="%s"></input></inputs><script><block s="doReport"><custom-block s="truth %s"><custom-block s="NOT $&#126;-1-255-255-0 %s"><block s="reportLessThan"><block var="a"/><block var="b"/></block></custom-block></custom-block></block></script></block-definition><block-definition s="XOR %&apos;a&apos; $≠-1-255-255-0 %&apos;b&apos;" type="predicate" category="operators"><comment x="0" y="0" w="190" collapsed="false">Reports 0 if its inputs are equal;&#xD;reports 1 if its inputs are not equal.&#xD;The inputs can have any non-list values.&#xD;(Lists are hyperized.)  If the inputs are&#xD;Booleans (True/False or 1/0), this is&#xD;also the exclusive-or function.</comment><header></header><code></code><translations></translations><inputs><input type="%s"></input><input type="%s"></input></inputs><script><block s="doReport"><custom-block s="%s scalar %s %s"><block var="a"/><l>≠</l><block var="b"/></custom-block></block></script></block-definition><block-definition s="zero? %&apos;n&apos;" type="predicate" category="other"><comment x="0" y="0" w="202.66666666666666" collapsed="true">reports True iff the input is 0 or False.</comment><header></header><code></code><translations></translations><inputs><input type="%n"></input></inputs><script><block s="doReport"><block s="reportListContainsItem"><block s="reportNewList"><list><l>0</l><block s="reportBoolean"><l><bool>false</bool></l></block></list></block><block var="n"/></block></block></script></block-definition><block-definition s="truth %&apos;n&apos;" type="predicate" category="other"><comment x="0" y="0" w="198.66666666666666" collapsed="false">Reports a Snap! Boolean False if the input&#xD;is False or 0; reports True otherwise.</comment><header></header><code></code><translations></translations><inputs><input type="%s"></input></inputs><script><block s="doReport"><block s="reportIfElse"><block s="reportIsA"><block var="n"/><l><option>Boolean</option></l></block><block var="n"/><block s="reportNot"><block s="reportEquals"><block var="n"/><l>0</l></block></block></block></block></script></block-definition><block-definition s="make scalar %&apos;value&apos;" type="reporter" category="operators"><header></header><code></code><translations></translations><inputs><input type="%l"></input></inputs><script><block s="doIf"><custom-block s="scalar? %s"><block var="value"/></custom-block><script><block s="doReport"><custom-block s="scalar-value helper %s"><block var="value"/></custom-block></block></script></block><custom-block s="error %txt"><block s="reportJoinWords"><list><l>Make scalar called with non-singleton input </l><block var="value"/></list></block></custom-block></script></block-definition><block-definition s="$⍳-1.5-255-255-0 %&apos;n&apos;" type="reporter" category="lists"><comment x="0" y="0" w="290.6666666666667" collapsed="false">If the input is a positive integer, reports a list of the numbers&#xD;from 1 to that input.  (If the input is 0, reports an empty list.)&#xD;&#xD;If the input is a list of positive integers, reports an array with&#xD;the shape specified by the input (as in ⍴ reshape) in which&#xD;each item is a list of the indices of that item in the array&#xD;(so technically the shape has one more dimension&#xD;than the input, whose size is the size of the input).</comment><header></header><code></code><translations></translations><inputs><input type="%n"></input></inputs><script><block s="doIfElse"><block s="reportIsA"><block var="n"/><l><option>list</option></l></block><script><block s="doIfElse"><block s="reportEquals"><custom-block s="rank of $⍴⍴-1-255-255-0 %l"><block var="n"/></custom-block><l>1</l></block><script><block s="doIfElse"><custom-block s="zero? %n"><custom-block s="combine in rows (reduce by column vectors) %repRing $/-1-255-255-0 %l"><block s="reifyReporter"><autolambda><block s="reportProduct"><l></l><l></l></block></autolambda><list></list></block><block var="n"/></custom-block></custom-block><script><block s="doReport"><block s="reportNewList"><list></list></block></block></script><script><block s="doReport"><custom-block s="reshape helper %l %l"><block var="n"/><custom-block s="crossproduct %mult%l"><block s="reportMap"><block s="reifyReporter"><autolambda><custom-block s="$⍳-1.5-255-255-0 %n"><l></l></custom-block></autolambda><list></list></block><block var="n"/></block></custom-block></custom-block></block></script></block></script><script><custom-block s="error %txt"><l>Input to ⍳ can&apos;t be a list of lists.</l></custom-block></script></block></script><script><block s="doReport"><block s="reportIfElse"><custom-block s="zero? %n"><block var="n"/></custom-block><block s="reportNewList"><list></list></block><block s="reportNumbers"><l>1</l><block var="n"/></block></block></block></script></block></script></block-definition><block-definition s="where in %&apos;vector&apos; is $⍳-1.5-255-255-0 %&apos;items&apos;" type="reporter" category="lists"><comment x="0" y="0" w="334.6666666666667" collapsed="false">If the rank of the left input is one more than the rank of the right input,&#xD;reports the index of the right input in the left input, or if not found,&#xD;reports one more than the length of the left input.&#xD;&#xD;If the rank of the left input is equal to the rank of the right input,&#xD;reports a vector of the indices of the items of the right input&#xD;in the left input (mapping this function over the right input).&#xD;&#xD;If the rank of the left input is more than that of the right input by 2 or more,&#xD;reports a vector, the location of the right input in the left in each dimension.&#xD;&#xD;It is an error if the rank of the left input is less than that of the right input.</comment><header></header><code></code><translations></translations><inputs><input type="%l"></input><input type="%s"></input></inputs><script><block s="doDeclareVariables"><list><l>result</l></list></block><block s="doIf"><block s="reportLessThan"><custom-block s="rank of $⍴⍴-1-255-255-0 %l"><block var="vector"/></custom-block><custom-block s="rank of $⍴⍴-1-255-255-0 %l"><block var="items"/></custom-block></block><script><custom-block s="error %txt"><l>Left input to ⍳ must have greater or equal rank to right input.</l></custom-block></script></block><block s="doIf"><block s="reportEquals"><custom-block s="rank of $⍴⍴-1-255-255-0 %l"><block var="vector"/></custom-block><custom-block s="rank of $⍴⍴-1-255-255-0 %l"><block var="items"/></custom-block></block><script><block s="doReport"><block s="reportMap"><block s="reifyReporter"><autolambda><custom-block s="where in %l is $⍳-1.5-255-255-0 %s"><block var="vector"/><l></l></custom-block></autolambda><list></list></block><block var="items"/></block></block></script></block><block s="doIf"><block s="reportEquals"><custom-block s="rank of $⍴⍴-1-255-255-0 %l"><block var="vector"/></custom-block><block s="reportSum"><custom-block s="rank of $⍴⍴-1-255-255-0 %l"><block var="items"/></custom-block><l>1</l></block></block><script><block s="doSetVar"><l>result</l><block s="reportListIndex"><block var="items"/><block var="vector"/></block></block><block s="doReport"><block s="reportIfElse"><custom-block s="zero? %n"><block var="result"/></custom-block><block s="reportSum"><block s="reportListLength"><block var="vector"/></block><l>1</l></block><block var="result"/></block></block></script></block><block s="doSetVar"><l>result</l><block s="reportFindFirst"><block s="reifyPredicate"><autolambda><custom-block s="%l deep contains %s"><l/><block var="items"/></custom-block></autolambda><list></list></block><block var="vector"/></block></block><block s="doIf"><block s="reportEquals"><block var="result"/><l></l></block><script><block s="doReport"><block s="reportSum"><custom-block s="shape of $⍴-1-255-255-0 %l"><block var="vector"/></custom-block><l>1</l></block></block></script></block><block s="doReport"><block s="reportCONS"><block s="reportListIndex"><block var="result"/><block var="vector"/></block><custom-block s="flatten (ravel) $,-1-255-255-0 %l"><custom-block s="where in %l is $⍳-1.5-255-255-0 %s"><block var="result"/><block var="items"/></custom-block></custom-block></block></block></script></block-definition><block-definition s="crossproduct %&apos;lists&apos;" type="reporter" category="lists"><comment x="0" y="0" w="305.3333333333333" collapsed="false">This isn&apos;t an APL function, although it&apos;s related to the outer product.&#xD;&#xD;It takes any number of lists, and reports a list of all possible tuples with one item from each of the lists.  The length of the result is the product of the lengths of the inputs.</comment><header></header><code></code><translations></translations><inputs><input type="%mult%l"></input></inputs><script><block s="doIfElse"><block s="reportListIsEmpty"><block var="lists"/></block><script><block s="doReport"><block s="reportNewList"><list><block s="reportNewList"><list></list></block></list></block></block></script><script><block s="doDeclareVariables"><list><l>small</l></list></block><block s="doSetVar"><l>small</l><custom-block s="crossproduct %mult%l"><block s="reportCDR"><block var="lists"/></block></custom-block></block><block s="doReport"><block s="reportConcatenatedLists"><block s="reportMap"><block s="reifyReporter"><autolambda><block s="reportMap"><block s="reifyReporter"><autolambda><block s="reportCONS"><block var="newitem"/><l/></block></autolambda><list></list></block><block var="small"/></block></autolambda><list><l>newitem</l></list></block><block s="reportListItem"><l>1</l><block var="lists"/></block></block></block></block></script></block></script></block-definition><block-definition s="%&apos;array&apos; deep contains %&apos;value&apos;" type="reporter" category="other"><header></header><code></code><translations></translations><inputs><input type="%l"></input><input type="%s"></input></inputs><script><block s="doIf"><block s="reportNot"><block s="reportIsA"><block var="array"/><l><option>list</option></l></block></block><script><block s="doReport"><block s="reportBoolean"><l><bool>false</bool></l></block></block></script></block><block s="doIf"><block s="reportListContainsItem"><block var="array"/><block var="value"/></block><script><block s="doReport"><block s="reportBoolean"><l><bool>true</bool></l></block></block></script></block><block s="doReport"><custom-block s="combine in rows (reduce by column vectors) %repRing $/-1-255-255-0 %l"><block s="reifyReporter"><autolambda><block s="reportOr"><l/><l/></block></autolambda><list></list></block><block s="reportMap"><block s="reifyReporter"><autolambda><custom-block s="%l deep contains %s"><l/><block var="value"/></custom-block></autolambda><list></list></block><block var="array"/></block></custom-block></block></script></block-definition><block-definition s="which of %&apos;items&apos; $ϵ-1-255-255-0 contained in %&apos;array&apos;" type="reporter" category="lists"><comment x="0" y="0" w="214.66666666666666" collapsed="false">Reports an array of Booleans the same shape&#xD;as the left input, indicating which of the atoms&#xD;in the left input appear anywhere in the right&#xD;input.  &#xD;(The structure of the right input doesn&apos;t matter.)</comment><header></header><code></code><translations></translations><inputs><input type="%s"></input><input type="%l"></input></inputs><script><block s="doIfElse"><block s="reportIsA"><block var="items"/><l><option>list</option></l></block><script><block s="doReport"><block s="reportMap"><block s="reifyReporter"><autolambda><custom-block s="which of %s $ϵ-1-255-255-0 contained in %l"><l></l><block var="array"/></custom-block></autolambda><list></list></block><block var="items"/></block></block></script><script><block s="doReport"><block s="reportListContainsItem"><custom-block s="flatten (ravel) $,-1-255-255-0 %l"><block var="array"/></custom-block><block var="items"/></block></block></script></block></script></block-definition><block-definition s="catenate %&apos;left&apos; $,-1-255-255-0 %&apos;right&apos;" type="reporter" category="lists"><comment x="0" y="0" w="190.66666666666666" collapsed="false">Like append, but:&#xD;&#xD;A scalar input is treated as an array the same shape as the other input except that the last item of the shape is 1.&#xD;&#xD;If the two inputs are of different ranks,&#xD;the function is mapped over the larger ranked input.&#xD;&#xD;Catenate adds new columns, by appending to each row.</comment><header></header><code></code><translations></translations><inputs><input type="%s"></input><input type="%s"></input></inputs><script><block s="doIf"><block s="reportNot"><block s="reportIsA"><block var="left"/><l><option>list</option></l></block></block><script><block s="doIfElse"><block s="reportGreaterThan"><custom-block s="rank of $⍴⍴-1-255-255-0 %l"><block var="right"/></custom-block><l>1</l></block><script><block s="doSetVar"><l>left</l><custom-block s="reshape as %l $⍴-1-255-255-0 items of %l"><block s="reportConcatenatedLists"><list><custom-block s="drop %n $↓-1-255-255-0 from %l"><l>-1</l><custom-block s="shape of $⍴-1-255-255-0 %l"><block var="right"/></custom-block></custom-block><block s="reportNewList"><list><l>1</l></list></block></list></block><block s="reportNewList"><list><block var="left"/></list></block></custom-block></block></script><script><block s="doSetVar"><l>left</l><block s="reportNewList"><list><block var="left"/></list></block></block></script></block></script></block><block s="doIf"><block s="reportNot"><block s="reportIsA"><block var="right"/><l><option>list</option></l></block></block><script><block s="doIfElse"><block s="reportGreaterThan"><custom-block s="rank of $⍴⍴-1-255-255-0 %l"><block var="left"/></custom-block><l>1</l></block><script><block s="doSetVar"><l>right</l><custom-block s="reshape as %l $⍴-1-255-255-0 items of %l"><block s="reportConcatenatedLists"><list><custom-block s="drop %n $↓-1-255-255-0 from %l"><l>-1</l><custom-block s="shape of $⍴-1-255-255-0 %l"><block var="left"/></custom-block></custom-block><block s="reportNewList"><list><l>1</l></list></block></list></block><block s="reportNewList"><list><block var="right"/></list></block></custom-block></block></script><script><block s="doSetVar"><l>right</l><block s="reportNewList"><list><block var="right"/></list></block></block></script></block></script></block><block s="doIf"><block s="reportEquals"><custom-block s="rank of $⍴⍴-1-255-255-0 %l"><block var="left"/></custom-block><custom-block s="rank of $⍴⍴-1-255-255-0 %l"><block var="right"/></custom-block></block><script><block s="doIfElse"><block s="reportEquals"><custom-block s="rank of $⍴⍴-1-255-255-0 %l"><block var="left"/></custom-block><l>1</l></block><script><block s="doReport"><block s="reportConcatenatedLists"><list><block var="left"/><block var="right"/></list></block></block></script><script><block s="doReport"><custom-block s="multimap %repRing %mult%l"><block s="reifyReporter"><autolambda><custom-block s="catenate %s $,-1-255-255-0 %s"><l></l><l></l></custom-block></autolambda><list></list></block><list><block var="left"/><block var="right"/></list></custom-block></block></script></block></script></block><block s="doIfElse"><block s="reportLessThan"><custom-block s="rank of $⍴⍴-1-255-255-0 %l"><block var="left"/></custom-block><custom-block s="rank of $⍴⍴-1-255-255-0 %l"><block var="right"/></custom-block></block><script><block s="doReport"><block s="reportMap"><block s="reifyReporter"><autolambda><custom-block s="catenate %s $,-1-255-255-0 %s"><block var="left"/><l></l></custom-block></autolambda><list></list></block><block var="right"/></block></block></script><script><block s="doReport"><block s="reportMap"><block s="reifyReporter"><autolambda><custom-block s="catenate %s $,-1-255-255-0 %s"><l></l><block var="right"/></custom-block></autolambda><list></list></block><block var="left"/></block></block></script></block></script></block-definition><block-definition s="scalar value %&apos;value&apos;" type="reporter" category="lists"><comment x="0" y="0" w="221.33333333333334" collapsed="false">If the input is a nesting of length=1 lists, which&#xD;APL treats as a scalar (the innermost item)&#xD;for many purposes, report that innermost scalar.&#xD;Otherwise, report the input as is.&#xD;&#xD;Exposing this block for users is important because Snap! /does not/ treat such a nesting&#xD;as a scalar, so you might need to use this in&#xD;translating an APL program to Snap!.&#xD;(But the functions in the APL library already use&#xD;this block as needed.)</comment><header></header><code></code><translations></translations><inputs><input type="%s"></input></inputs><script><block s="doReport"><block s="reportIfElse"><custom-block s="scalar? %s"><block var="value"/></custom-block><custom-block s="scalar-value helper %s"><block var="value"/></custom-block><block var="value"/></block></block></script></block-definition><block-definition s="grade up $⍋-1.5-255-255-0 %&apos;array&apos;" type="reporter" category="lists"><comment x="0" y="0" w="190.66666666666666" collapsed="false">Reports a vector of indices of the items of the input, in order of the values of the items, so that&#xD;&#xD;item (grade up (foo)) of (foo)&#xD;&#xD;reports the items in sorted order, smallest to largest.  For a matrix, sorts the rows based on their first items, or if those are equal, based on their second items, etc.</comment><header></header><code></code><translations></translations><inputs><input type="%l"></input></inputs><script><block s="doReport"><block s="reportMap"><block s="reifyReporter"><autolambda><block s="reportListItem"><l><option>last</option></l><l/></block></autolambda><list></list></block><custom-block s="sort %l ordering with %predRing"><custom-block s="multimap %repRing %mult%l"><block s="reifyReporter"><autolambda><custom-block s="catenate %s $,-1-255-255-0 %s"><l></l><l></l></custom-block></autolambda><list></list></block><list><block var="array"/><custom-block s="$⍳-1.5-255-255-0 %n"><block s="reportListLength"><block var="array"/></block></custom-block></list></custom-block><block s="reifyPredicate"><autolambda><custom-block s="sort helper %l %l"><l/><l/></custom-block></autolambda><list></list></block></custom-block></block></block></script></block-definition><block-definition s="sort helper %&apos;rowA&apos; %&apos;rowB&apos;" type="reporter" category="other"><comment x="0" y="0" w="166" collapsed="false">Compares two vectors for sorting.&#xD;Compare first items; if those are equal compare second items; etc.</comment><header></header><code></code><translations></translations><inputs><input type="%l"></input><input type="%l"></input></inputs><script><block s="doIf"><block s="reportListIsEmpty"><block var="rowA"/></block><script><block s="doReport"><block s="reportBoolean"><l><bool>true</bool></l></block></block></script></block><block s="doIf"><block s="reportListIsEmpty"><block var="rowB"/></block><script><block s="doReport"><block s="reportBoolean"><l><bool>false</bool></l></block></block></script></block><block s="doIf"><block s="reportLessThan"><block s="reportListItem"><l>1</l><block var="rowA"/></block><block s="reportListItem"><l>1</l><block var="rowB"/></block></block><script><block s="doReport"><block s="reportBoolean"><l><bool>true</bool></l></block></block></script></block><block s="doIf"><block s="reportGreaterThan"><block s="reportListItem"><l>1</l><block var="rowA"/></block><block s="reportListItem"><l>1</l><block var="rowB"/></block></block><script><block s="doReport"><block s="reportBoolean"><l><bool>false</bool></l></block></block></script></block><block s="doReport"><custom-block s="sort helper %l %l"><block s="reportCDR"><block var="rowA"/></block><block s="reportCDR"><block var="rowB"/></block></custom-block></block></script></block-definition><block-definition s="grade down $⍒-1.5-255-255-0 %&apos;array&apos;" type="reporter" category="lists"><comment x="0" y="0" w="190.66666666666666" collapsed="false">Reports a vector of indices of the items of the input, in order of the values of the items, so that&#xD;&#xD;item (grade down (foo)) of (foo)&#xD;&#xD;reports the items in sorted order, largest to smallest.  For a matrix, sorts the rows based on their first items, or if those are equal, based on their second items, etc.</comment><header></header><code></code><translations></translations><inputs><input type="%l"></input></inputs><script><block s="doReport"><block s="reportMap"><block s="reifyReporter"><autolambda><block s="reportListItem"><l><option>last</option></l><l/></block></autolambda><list></list></block><custom-block s="sort %l ordering with %predRing"><custom-block s="multimap %repRing %mult%l"><block s="reifyReporter"><autolambda><custom-block s="catenate %s $,-1-255-255-0 %s"><l></l><l></l></custom-block></autolambda><list></list></block><list><block var="array"/><custom-block s="$⍳-1.5-255-255-0 %n"><block s="reportListLength"><block var="array"/></block></custom-block></list></custom-block><block s="reifyPredicate"><autolambda><custom-block s="NOT $&#126;-1-255-255-0 %s"><custom-block s="sort helper %l %l"><l/><l/></custom-block></custom-block></autolambda><list></list></block></custom-block></block></block></script></block-definition><block-definition s="select rows (compress columns) %&apos;Booleans&apos; $/-1-255-255-0 %&apos;array&apos;" type="reporter" category="lists"><comment x="0" y="0" w="210.66666666666666" collapsed="false">The left input must be a vector of Booleans&#xD;(either Snap! form or APL form); the right input must be an array whose first dimension is equal to the length of the left input.  The block reports an array of the same rank as the right input, containing only those items (rows, for a matrix) for which the corresponding Boolean is True (or 1).</comment><header></header><code></code><translations></translations><inputs><input type="%l"></input><input type="%l"></input></inputs><script><block s="doReport"><custom-block s="rowize vector %l"><block s="reportMap"><block s="reifyReporter"><autolambda><block s="reportCDR"><l/></block></autolambda><list></list></block><block s="reportKeep"><block s="reifyPredicate"><autolambda><custom-block s="truth %s"><block s="reportListItem"><l>1</l><l/></block></custom-block></autolambda><list></list></block><custom-block s="multimap %repRing %mult%l"><block s="reifyReporter"><autolambda><custom-block s="catenate %s $,-1-255-255-0 %s"><l></l><l></l></custom-block></autolambda><list></list></block><list><block var="Booleans"/><block var="array"/></list></custom-block></block></block></custom-block></block></script></block-definition><block-definition s="rowize vector %&apos;vec&apos;" type="reporter" category="other"><header></header><code></code><translations></translations><inputs><input type="%l"></input></inputs><script><block s="doReport"><block s="reportIfElse"><block s="reportAnd"><block s="reportEquals"><custom-block s="rank of $⍴⍴-1-255-255-0 %l"><block var="vec"/></custom-block><l>2</l></block><block s="reportEquals"><block s="reportListItem"><l>2</l><custom-block s="shape of $⍴-1-255-255-0 %l"><block var="vec"/></custom-block></block><l>1</l></block></block><block s="reportMap"><block s="reifyReporter"><autolambda><block s="reportListItem"><l>1</l><l/></block></autolambda><list></list></block><block var="vec"/></block><block var="vec"/></block></block></script></block-definition><block-definition s="select columns (compress rows) %&apos;bool&apos; $⌿-1.5-255-255-0 %&apos;array&apos;" type="reporter" category="lists"><comment x="0" y="0" w="219.33333333333334" collapsed="false">The left input must be a vector of Booleans&#xD;(either Snap! form or APL form); the right input must be an array whose last dimension is equal to the length of the left input.  The block reports an array of the same rank as the right input, containing only those items (columns, for a matrix) for which the corresponding Boolean is True (or 1).</comment><header></header><code></code><translations></translations><inputs><input type="%l"></input><input type="%l"></input></inputs><script><block s="doReport"><custom-block s="columnwise %repRing %l"><block s="reifyReporter"><autolambda><custom-block s="select rows (compress columns) %l $/-1-255-255-0 %l"><block var="bool"/><l/></custom-block></autolambda><list></list></block><block var="array"/></custom-block></block></script></block-definition><block-definition s="columnwise %&apos;function&apos; %&apos;data&apos;" type="reporter" category="control"><comment x="0" y="0" w="212" collapsed="false">Turns a row-wise (in Lisp terminology) function&#xD;into a column-wise one.</comment><header></header><code></code><translations></translations><inputs><input type="%repRing"></input><input type="%l"></input></inputs><script><block s="doReport"><custom-block s="rowize vector %l"><custom-block s="transpose $⍉-1.5-255-255-0 %l"><block s="evaluate"><block var="function"/><list><custom-block s="transpose $⍉-1.5-255-255-0 %l"><block var="data"/></custom-block></list></block></custom-block></custom-block></block></script></block-definition><block-definition s="reverse column order (row contents) $⏀-1-255-255-0 %&apos;array&apos;" type="reporter" category="lists"><comment x="0" y="0" w="206" collapsed="false">Reverses the order of the columns of the input, which is a reflection through a vertical axis, as the ⏀ symbol suggests.</comment><header></header><code></code><translations></translations><inputs><input type="%l"></input></inputs><script><block s="doReport"><custom-block s="columnwise %repRing %l"><block s="reifyReporter"><autolambda><custom-block s="reverse row order (column contents) $⦵-1.5-255-255-0 %l"><l/></custom-block></autolambda><list></list></block><block var="array"/></custom-block></block></script></block-definition><block-definition s="combine in columns (reduce by row vectors) %&apos;function&apos; $⌿-1.5-255-255-0 %&apos;array&apos;" type="reporter" category="lists"><comment x="0" y="0" w="285.3333333333333" collapsed="false">This function has two names because there are two ways&#xD;to understand it.&#xD;&#xD;Lisp way:  A matrix is a list of rows.  This block turns it into a list of columns, and combines the numbers in each column, producing one value for the entire column.&#xD;&#xD;APL way:  A matrix is made of vectors.  This block takes each row as a vector, and does vector arithmetic on the rows, producing one row as the result.</comment><header></header><code></code><translations></translations><inputs><input type="%repRing"></input><input type="%l"></input></inputs><script><block s="doReport"><custom-block s="columnwise %repRing %l"><block s="reifyReporter"><autolambda><custom-block s="combine in rows (reduce by column vectors) %repRing $/-1-255-255-0 %l"><block var="function"/><l/></custom-block></autolambda><list></list></block><block var="array"/></custom-block></block></script></block-definition><block-definition s="catenate vertically %&apos;left&apos; $⍪-1.5-255-255-0 %&apos;right&apos;" type="reporter" category="lists"><comment x="0" y="0" w="190.66666666666666" collapsed="false">Like append, but:&#xD;&#xD;A scalar input is treated as a vector&#xD;of length 1.&#xD;&#xD;If the two inputs are of different ranks,&#xD;the function is mapped over the larger ranked input.&#xD;&#xD;Catenate vertically adds new rows, by appending to each column.</comment><header></header><code></code><translations></translations><inputs><input type="%s"></input><input type="%s"></input></inputs><script><block s="doIf"><block s="reportNot"><block s="reportIsA"><block var="left"/><l><option>list</option></l></block></block><script><block s="doIfElse"><block s="reportGreaterThan"><custom-block s="rank of $⍴⍴-1-255-255-0 %l"><block var="right"/></custom-block><l>1</l></block><script><block s="doSetVar"><l>left</l><custom-block s="reshape as %l $⍴-1-255-255-0 items of %l"><block s="reportConcatenatedLists"><list><block s="reportNewList"><list><l>1</l></list></block><custom-block s="drop %n $↓-1-255-255-0 from %l"><l>1</l><custom-block s="shape of $⍴-1-255-255-0 %l"><block var="right"/></custom-block></custom-block></list></block><block s="reportNewList"><list><block var="left"/></list></block></custom-block></block></script><script><block s="doSetVar"><l>left</l><block s="reportNewList"><list><block var="left"/></list></block></block></script></block></script></block><block s="doIf"><block s="reportNot"><block s="reportIsA"><block var="right"/><l><option>list</option></l></block></block><script><block s="doIfElse"><block s="reportGreaterThan"><custom-block s="rank of $⍴⍴-1-255-255-0 %l"><block var="left"/></custom-block><l>1</l></block><script><block s="doSetVar"><l>right</l><custom-block s="reshape as %l $⍴-1-255-255-0 items of %l"><block s="reportConcatenatedLists"><list><block s="reportNewList"><list><l>1</l></list></block><custom-block s="drop %n $↓-1-255-255-0 from %l"><l>1</l><custom-block s="shape of $⍴-1-255-255-0 %l"><block var="left"/></custom-block></custom-block></list></block><block s="reportNewList"><list><block var="right"/></list></block></custom-block></block></script><script><block s="doSetVar"><l>right</l><block s="reportNewList"><list><block var="right"/></list></block></block></script></block></script></block><block s="doIf"><block s="reportEquals"><custom-block s="rank of $⍴⍴-1-255-255-0 %l"><block var="left"/></custom-block><custom-block s="rank of $⍴⍴-1-255-255-0 %l"><block var="right"/></custom-block></block><script><block s="doIfElse"><block s="reportEquals"><custom-block s="rank of $⍴⍴-1-255-255-0 %l"><block var="left"/></custom-block><l>1</l></block><script><block s="doReport"><block s="reportConcatenatedLists"><list><block var="left"/><block var="right"/></list></block></block></script><script><block s="doReport"><custom-block s="transpose $⍉-1.5-255-255-0 %l"><custom-block s="catenate %s $,-1-255-255-0 %s"><custom-block s="transpose $⍉-1.5-255-255-0 %l"><block var="left"/></custom-block><custom-block s="transpose $⍉-1.5-255-255-0 %l"><block var="right"/></custom-block></custom-block></custom-block></block></script></block></script></block><block s="doIfElse"><block s="reportLessThan"><custom-block s="rank of $⍴⍴-1-255-255-0 %l"><block var="left"/></custom-block><custom-block s="rank of $⍴⍴-1-255-255-0 %l"><block var="right"/></custom-block></block><script><block s="doReport"><block s="reportMap"><block s="reifyReporter"><autolambda><custom-block s="catenate %s $,-1-255-255-0 %s"><block var="left"/><l></l></custom-block></autolambda><list></list></block><block var="right"/></block></block></script><script><block s="doReport"><block s="reportMap"><block s="reifyReporter"><autolambda><custom-block s="catenate %s $,-1-255-255-0 %s"><l></l><block var="right"/></custom-block></autolambda><list></list></block><block var="left"/></block></block></script></block></script><scripts><script x="254" y="497.7777777777774"><custom-block s="multimap %repRing %mult%l"><block s="reifyReporter"><script></script><list></list></block><list><l/><l/></list></custom-block></script></scripts></block-definition><block-definition s="%&apos;a&apos; scalar join %&apos;b&apos;" type="reporter" category="operators"><comment x="0" y="0" w="219.33333333333334" collapsed="false">A hyperblock version of JOIN.  The regular JOIN isn&apos;t hyperized because it can accept a list as input, representing it as text.</comment><header></header><code></code><translations></translations><inputs><input type="%s"></input><input type="%s"></input></inputs><script><block s="doReport"><block s="evaluate"><custom-block s="scalar -&gt; hyper %repRing"><block s="reifyReporter"><autolambda><block s="reportJoinWords"><list><l></l><l></l></list></block></autolambda><list></list></block></custom-block><list><block var="a"/><block var="b"/></list></block></block></script></block-definition><block-definition s="take %&apos;howmany&apos; $↑-1-255-255-0 from %&apos;array&apos;" type="reporter" category="lists"><comment x="0" y="0" w="272" collapsed="false">A positive left input selects the first n items of the right input.&#xD;A negative left input selects the last abs(n) items&#xD;of the right input.&#xD;&#xD;If the right input is a matrix, a numeric left input selects rows;&#xD;the left input may also be a two-item vector, in which case&#xD;the first number is applied to the rows&#xD;and the second number is applied to the columns.&#xD;Similarly for higher-dimension arrays. </comment><header></header><code></code><translations></translations><inputs><input type="%n"></input><input type="%l"></input></inputs><script><block s="doIf"><block s="reportIsA"><block var="howmany"/><l><option>number</option></l></block><script><block s="doReport"><block s="reportIfElse"><block s="reportLessThan"><block var="howmany"/><l>0</l></block><block s="reportListItem"><block s="reportSum"><custom-block s="$⍳-1.5-255-255-0 %n"><block s="reportMonadic"><l><option>abs</option></l><block var="howmany"/></block></custom-block><block s="reportSum"><block s="reportListLength"><block var="array"/></block><block var="howmany"/></block></block><block var="array"/></block><block s="reportListItem"><custom-block s="$⍳-1.5-255-255-0 %n"><block var="howmany"/></custom-block><block var="array"/></block></block></block></script></block><block s="doIf"><block s="reportGreaterThan"><custom-block s="rank of $⍴⍴-1-255-255-0 %l"><block var="howmany"/></custom-block><l>1</l></block><script><custom-block s="error %txt"><l>Left input to take can&apos;t be a matrix.</l></custom-block></script></block><block s="doIf"><block s="reportGreaterThan"><block s="reportListLength"><block var="howmany"/></block><custom-block s="rank of $⍴⍴-1-255-255-0 %l"><block var="array"/></custom-block></block><script><custom-block s="error %txt"><l>Length of item vector &gt; rank of array in take.</l></custom-block></script></block><block s="doReport"><block s="reportListItem"><custom-block s="reverse row order (column contents) $⦵-1.5-255-255-0 %l"><block s="reportMap"><block s="reifyReporter"><autolambda><block s="reportIfElse"><block s="reportLessThan"><block var="value"/><l>0</l></block><block s="reportSum"><custom-block s="$⍳-1.5-255-255-0 %n"><block s="reportMonadic"><l><option>abs</option></l><block var="value"/></block></custom-block><block s="reportSum"><block s="reportListItem"><block var="index"/><custom-block s="shape of $⍴-1-255-255-0 %l"><block var="array"/></custom-block></block><block var="value"/></block></block><custom-block s="$⍳-1.5-255-255-0 %n"><block var="value"/></custom-block></block></autolambda><list><l>value</l><l>index</l></list></block><block var="howmany"/></block></custom-block><block var="array"/></block></block></script></block-definition><block-definition s="drop %&apos;howmany&apos; $↓-1-255-255-0 from %&apos;array&apos;" type="reporter" category="lists"><comment x="0" y="0" w="306" collapsed="false">A positive left input selects all but the first n items of the right input.&#xD;A negative left input selects all but the last abs(n) items&#xD;of the right input.&#xD;&#xD;If the right input is a matrix, a numeric left input selects rows;&#xD;the left input may also be a two-item vector, in which case&#xD;the first number is applied to the rows&#xD;and the second number is applied to the columns.&#xD;Similarly for higher-dimension arrays. </comment><header></header><code></code><translations></translations><inputs><input type="%n"></input><input type="%l"></input></inputs><script><block s="doIf"><block s="reportIsA"><block var="howmany"/><l><option>number</option></l></block><script><block s="doReport"><custom-block s="take %n $↑-1-255-255-0 from %l"><block s="reportProduct"><block s="reportMonadic"><l><option>neg</option></l><custom-block s="signum $×-1-255-255-0 %n"><block var="howmany"/></custom-block></block><block s="reportDifference"><block s="reportListLength"><block var="array"/></block><block s="reportMonadic"><l><option>abs</option></l><block var="howmany"/></block></block></block><block var="array"/></custom-block></block></script></block><block s="doReport"><custom-block s="take %n $↑-1-255-255-0 from %l"><block s="reportMap"><block s="reifyReporter"><autolambda><block s="reportIfElse"><block s="reportLessThan"><block var="value"/><l>0</l></block><block s="reportSum"><block s="reportListItem"><block var="index"/><custom-block s="shape of $⍴-1-255-255-0 %l"><block var="array"/></custom-block></block><block var="value"/></block><block s="reportDifference"><block var="value"/><block s="reportListItem"><block var="index"/><custom-block s="shape of $⍴-1-255-255-0 %l"><block var="array"/></custom-block></block></block></block></autolambda><list><l>value</l><l>index</l></list></block><block var="howmany"/></block><block var="array"/></custom-block></block></script></block-definition><block-definition s="reshape helper %&apos;shape&apos; %&apos;data&apos;" type="reporter" category="other"><header></header><code></code><translations></translations><inputs><input type="%l"></input><input type="%l"></input></inputs><script><block s="doIf"><block s="reportListIsEmpty"><block var="shape"/></block><script><block s="doReport"><block s="reportNewList"><list></list></block></block></script></block><block s="doIf"><block s="reportEquals"><block s="reportCombine"><block var="shape"/><block s="reifyReporter"><autolambda><block s="reportProduct"><l></l><l></l></block></autolambda><list></list></block></block><l>0</l></block><script><block s="doReport"><block s="reportNewList"><list></list></block></block></script></block><block s="doDeclareVariables"><list><l>partial</l></list></block><block s="doSetVar"><l>partial</l><block s="reportNewList"><list></list></block></block><block s="doIfElse"><block s="reportListIsEmpty"><block s="reportCDR"><block var="shape"/></block></block><script><block s="doRepeat"><block s="reportListItem"><l>1</l><block var="shape"/></block><script><block s="doAddToList"><block s="reportListItem"><l>1</l><block var="data"/></block><block var="partial"/></block><block s="doSetVar"><l>data</l><block s="reportConcatenatedLists"><list><block s="reportCDR"><block var="data"/></block><block s="reportNewList"><list><block s="reportListItem"><l>1</l><block var="data"/></block></list></block></list></block></block></script></block></script><script><block s="doRepeat"><block s="reportListItem"><l>1</l><block var="shape"/></block><script><block s="doAddToList"><custom-block s="reshape helper %l %l"><block s="reportCDR"><block var="shape"/></block><block var="data"/></custom-block><block var="partial"/></block><block s="doRepeat"><block s="reportModulus"><block s="reportCombine"><block s="reportCDR"><block var="shape"/></block><block s="reifyReporter"><autolambda><block s="reportProduct"><l></l><l></l></block></autolambda><list></list></block></block><block s="reportListLength"><block var="data"/></block></block><script><block s="doSetVar"><l>data</l><block s="reportConcatenatedLists"><list><block s="reportCDR"><block var="data"/></block><block s="reportNewList"><list><block s="reportListItem"><l>1</l><block var="data"/></block></list></block></list></block></block></script></block></script></block></script></block><block s="doReport"><block var="partial"/></block></script></block-definition><block-definition s="deep map %&apos;function&apos; %&apos;atom?&apos; %&apos;data&apos;" type="reporter" category="other"><comment x="0" y="0" w="320.6666666666667" collapsed="false">Applies the function to each &quot;atom&quot; of the data.  What&apos;s an atom?&#xD;Something for which the predicate input reports true.</comment><header></header><code></code><translations></translations><inputs><input type="%repRing"></input><input type="%predRing"></input><input type="%l"></input></inputs><script><block s="doIf"><custom-block s="truth %s"><block s="evaluate"><block var="atom?"/><list><block var="data"/></list></block></custom-block><script><block s="doReport"><block s="evaluate"><block var="function"/><list><block var="data"/></list></block></block></script></block><block s="doReport"><block s="reportMap"><block s="reifyReporter"><autolambda><custom-block s="deep map %repRing %predRing %l"><block var="function"/><block var="atom?"/><l/></custom-block></autolambda><list></list></block><block var="data"/></block></block></script></block-definition><block-definition s="nth item 1 %&apos;n&apos; %&apos;data&apos;" type="reporter" category="other"><header></header><code></code><translations></translations><inputs><input type="%n"></input><input type="%l"></input></inputs><script><block s="doIf"><block s="reportEquals"><block var="n"/><l>0</l></block><script><block s="doReport"><block var="data"/></block></script></block><block s="doReport"><custom-block s="nth item 1 %n %l"><block s="reportDifference"><block var="n"/><l>1</l></block><block s="reportListItem"><l>1</l><block var="data"/></block></custom-block></block></script></block-definition><block-definition s="reverse %&apos;data&apos;" type="reporter" category="lists"><comment x="0" y="0" w="223" collapsed="false">Reports a new list containing the items of the input list, but in the opposite order.</comment><header></header><code></code><translations>ca:capgira _&#xD;</translations><inputs><input type="%l"></input></inputs><script><block s="doDeclareVariables"><list><l>helper</l></list></block><block s="doSetVar"><l>helper</l><block s="reifyScript"><script><block s="doIf"><block s="reportEquals"><block var="input"/><block s="reportNewList"><list></list></block></block><script><block s="doReport"><block var="result"/></block></script></block><block s="doReport"><block s="evaluate"><block var="helper"/><list><block s="reportCDR"><block var="input"/></block><block s="reportCONS"><block s="reportListItem"><l>1</l><block var="input"/></block><block var="result"/></block></list></block></block></script><list><l>input</l><l>result</l></list></block></block><block s="doWarp"><script><block s="doReport"><block s="evaluate"><block var="helper"/><list><block var="data"/><block s="reportNewList"><list></list></block></list></block></block></script></block></script></block-definition><block-definition s="remove duplicates from %&apos;data&apos;" type="reporter" category="lists"><comment x="0" y="0" w="209" collapsed="false">Reports a new list whose items are the same as in the input list, except that if two or more equal items appear in the input list, only the last one is kept in the result.</comment><header></header><code></code><translations>ca:elimina els duplicats de _&#xD;</translations><inputs><input type="%l"></input></inputs><script><block s="doWarp"><script><block s="doIf"><block s="reportEquals"><block var="data"/><block s="reportNewList"><list></list></block></block><script><block s="doReport"><block s="reportNewList"><list></list></block></block></script></block><block s="doIfElse"><block s="reportListContainsItem"><block s="reportCDR"><block var="data"/></block><block s="reportListItem"><l>1</l><block var="data"/></block></block><script><block s="doReport"><custom-block s="remove duplicates from %l"><block s="reportCDR"><block var="data"/></block></custom-block></block></script><script><block s="doReport"><block s="reportCONS"><block s="reportListItem"><l>1</l><block var="data"/></block><custom-block s="remove duplicates from %l"><block s="reportCDR"><block var="data"/></block></custom-block></block></block></script></block></script></block></script></block-definition><block-definition s="sort %&apos;data&apos; ordering with %&apos;function&apos;" type="reporter" category="lists"><comment x="0" y="0" w="161.14285714285708" collapsed="false">Reports a sorted version of the list in its first input slot, using the comparison function in the second input slot.  For a list of numbers, using &lt; as the comparison function will sort from low to high; using &gt; will sort from high to low.</comment><header></header><code></code><translations>ca:ordena _ segons criteri _&#xD;</translations><inputs><input type="%l"></input><input type="%predRing"></input></inputs><script><block s="doDeclareVariables"><list><l>even items</l><l>odd items</l><l>merge</l><l>split</l><l>copy of data</l><l>id</l></list></block><block s="doSetVar"><l>id</l><block s="reifyScript"><script><block s="doReport"><l></l></block></script><list></list></block></block><block s="doSetVar"><l>copy of data</l><block s="reportMap"><block var="id"/><block var="data"/></block></block><block s="doSetVar"><l>split</l><block s="reifyScript"><script><block s="doSetVar"><l>even items</l><block s="reportNewList"><list></list></block></block><block s="doSetVar"><l>odd items</l><block s="reportNewList"><list></list></block></block><block s="doUntil"><block s="reportListIsEmpty"><block var="copy of data"/></block><script><block s="doAddToList"><block s="reportListItem"><l>1</l><block var="copy of data"/></block><block var="odd items"/></block><block s="doDeleteFromList"><l>1</l><block var="copy of data"/></block><block s="doIf"><block s="reportNot"><block s="reportListIsEmpty"><block var="copy of data"/></block></block><script><block s="doAddToList"><block s="reportListItem"><l>1</l><block var="copy of data"/></block><block var="even items"/></block><block s="doDeleteFromList"><l>1</l><block var="copy of data"/></block></script></block></script></block></script><list></list></block></block><block s="doSetVar"><l>merge</l><block s="reifyScript"><script><block s="doIf"><block s="reportEquals"><block var="#1"/><block s="reportNewList"><list></list></block></block><script><block s="doReport"><block var="#2"/></block></script></block><block s="doIf"><block s="reportEquals"><block var="#2"/><block s="reportNewList"><list></list></block></block><script><block s="doReport"><block var="#1"/></block></script></block><block s="doIfElse"><block s="evaluate"><block var="function"/><list><block s="reportListItem"><l>1</l><block var="#1"/></block><block s="reportListItem"><l>1</l><block var="#2"/></block></list></block><script><block s="doReport"><block s="reportCONS"><block s="reportListItem"><l>1</l><block var="#1"/></block><block s="evaluate"><block var="merge"/><list><block s="reportCDR"><block var="#1"/></block><block var="#2"/></list></block></block></block></script><script><block s="doReport"><block s="reportCONS"><block s="reportListItem"><l>1</l><block var="#2"/></block><block s="evaluate"><block var="merge"/><list><block var="#1"/><block s="reportCDR"><block var="#2"/></block></list></block></block></block></script></block></script><list><l>#1</l><l>#2</l></list></block></block><block s="doIf"><block s="reportEquals"><block var="data"/><block s="reportNewList"><list></list></block></block><script><block s="doReport"><block s="reportNewList"><list></list></block></block></script></block><block s="doIf"><block s="reportEquals"><block s="reportCDR"><block var="data"/></block><block s="reportNewList"><list></list></block></block><script><block s="doReport"><block var="data"/></block></script></block><block s="doRun"><block var="split"/><list></list></block><block s="doReport"><block s="evaluate"><block var="merge"/><list><custom-block s="sort %l ordering with %predRing"><block var="odd items"/><block var="function"/></custom-block><custom-block s="sort %l ordering with %predRing"><block var="even items"/><block var="function"/></custom-block></list></block></block></script></block-definition><block-definition s="assoc %&apos;key&apos; %&apos;a-list&apos;" type="reporter" category="lists"><comment x="0" y="0" w="289.3333333333333" collapsed="false">The second input is an &quot;association list,&quot; a list of two-item lists.  Each of those smaller lists has a &quot;key&quot; as its first item and a &quot;value&quot; as its second.  ASSOC reports the first key-value pair in the association list whose key matches the first input.</comment><header></header><code></code><translations>ca:associació _ _&#xD;</translations><inputs><input type="%s"></input><input type="%l"></input></inputs><script><block s="doIf"><block s="reportEquals"><block var="a-list"/><block s="reportNewList"><list></list></block></block><script><block s="doReport"><block s="reportNewList"><list></list></block></block></script></block><block s="doIf"><block s="reportEquals"><block var="key"/><block s="reportListItem"><l>1</l><block s="reportListItem"><l>1</l><block var="a-list"/></block></block></block><script><block s="doReport"><block s="reportListItem"><l>1</l><block var="a-list"/></block></block></script></block><block s="doReport"><custom-block s="assoc %s %l"><block var="key"/><block s="reportCDR"><block var="a-list"/></block></custom-block></block></script></block-definition><block-definition s="%&apos;#&apos; for each %&apos;item&apos; of %&apos;data&apos; %&apos;action&apos;" type="command" category="lists"><comment x="0" y="0" w="228.57142857142858" collapsed="false">This block carries out the given script for each item of the given list, like the primitive FOR EACH.&#xD;&#xD;What&apos;s different is that it provides the # variable, which will contain the item number in the list of each item in turn, 1 while processing item 1, and so on.</comment><header></header><code></code><translations>ca:_ per cada _ de _ _&#xD;</translations><inputs><input type="%upvar"></input><input type="%upvar"></input><input type="%l"></input><input type="%ca"></input></inputs><script><block s="doSetVar"><l>#</l><l>1</l></block><block s="doUntil"><block s="reportListIsEmpty"><block var="data"/></block><script><block s="doSetVar"><l>item</l><block s="reportListItem"><l>1</l><block var="data"/></block></block><block s="doRun"><block var="action"/><list><block s="reportListItem"><l>1</l><block var="data"/></block></list></block><block s="doSetVar"><l>data</l><block s="reportCDR"><block var="data"/></block></block><block s="doChangeVar"><l>#</l><l>1</l></block></script></block></script></block-definition><block-definition s="multimap %&apos;function&apos; over %&apos;lists&apos;" type="reporter" category="lists"><comment x="0" y="0" w="267.3333333333333" collapsed="false">Takes as input a function of N inputs and N lists.&#xD;The function is called with item 1 of all the lists as its inputs, with item 2 of all the lists as its inputs, and so on.  (The lists should all be the same length.)</comment><header></header><code></code><translations></translations><inputs><input type="%repRing"></input><input type="%mult%l"></input></inputs><script><block s="doReport"><block s="reportMap"><block s="reifyReporter"><autolambda><block s="evaluate"><block var="function"/><custom-block s="%s"><l></l></custom-block></block></autolambda><list></list></block><custom-block s="zip %mult%l"><block var="lists"/></custom-block></block></block></script></block-definition><block-definition s="zip %&apos;lists&apos;" type="reporter" category="lists"><comment x="0" y="0" w="192" collapsed="false">ZIP takes any number of lists as inputs.  The lists should all be the same length.  ZIP reports a list of lists in which the first item is a list of all the first items, the second item is a list of all the second items, etc.&#xD;Viewing the inputs as the rows of a matrix, ZIP reports its transpose.</comment><header></header><code></code><translations></translations><inputs><input type="%mult%l"></input></inputs><script><block s="doIf"><block s="reportListIsEmpty"><block s="reportListItem"><l>1</l><block var="lists"/></block></block><script><block s="doReport"><block s="reportNewList"><list></list></block></block></script></block><block s="doReport"><block s="reportCONS"><block s="reportMap"><block s="reifyReporter"><autolambda><block s="reportListItem"><l>1</l><l/></block></autolambda><list></list></block><block var="lists"/></block><custom-block s="zip %mult%l"><block s="reportMap"><block s="reifyReporter"><autolambda><block s="reportCDR"><l/></block></autolambda><list></list></block><block var="lists"/></block></custom-block></block></block></script></block-definition><block-definition s="catch %&apos;tag&apos; %&apos;value&apos;" type="reporter" category="control"><header></header><code></code><translations>de:fange _ _&#xD;ca:agafa _ _&#xD;es:atrapar _ _&#xD;fr:attrape _ _&#xD;pt:captura _ _&#xD;</translations><inputs><input type="%upvar"></input><input type="%anyUE"></input></inputs><script><block s="doCallCC"><block s="reifyScript"><script><block s="doSetVar"><l>tag</l><block var="cont"/></block><block s="doReport"><block s="evaluate"><block var="value"/><list></list></block></block></script><list><l>cont</l></list></block></block></script></block-definition><block-definition s="throw %&apos;tag&apos; %&apos;value&apos;" type="command" category="control"><header></header><code></code><translations>de:wirf _ _&#xD;ca:llança _ _&#xD;es:lanzar _ _&#xD;fr:lance _ _&#xD;pt:lança _ _&#xD;</translations><inputs><input type="%s">catchtag</input><input type="%s"></input></inputs><script><block s="doRun"><block var="tag"/><list><block var="value"/></list></block></script></block-definition><block-definition s="if %&apos;test&apos; do %&apos;action&apos; and pause all $pause-1-255-220-0" type="command" category="control"><comment x="0" y="0" w="263.3333333333333" collapsed="false">This is a breakpoint block, to be used in debugging.&#xD;The Boolean input specifies the condition under which&#xD;the program should pause.  (Use True for an unconditional breakpoint.)  The intent is that the script should have&#xD;SHOW VARIABLE blocks for the process&apos;s local variables.&#xD;After the pause, this block automatically hides all temporary variables.</comment><header></header><code></code><translations>de:falls _ dann _ und pause $pause-1-255-220-0&#xD;ca:si _ fes _ i atura-ho tot $pause-1-255-220-0&#xD;es:si _ haz _ y páralo todo $pause-1-255-220-0&#xD;fr:si _ faire _ et mettre tout en pause $pause-1-255-220-0&#xD;pt:se _ , então _ e faz pausa em tudo $pause-1-255-220-0&#xD;</translations><inputs><input type="%boolUE"></input><input type="%cs"></input></inputs><script><block s="doDeclareVariables"><list><l>breakpoint</l></list></block><block s="doIf"><block s="evaluate"><block var="test"/><list></list></block><script><block s="doSetVar"><l>breakpoint</l><block var="test"/></block><block s="doShowVar"><l>breakpoint</l></block><block s="doRun"><block var="action"/><list></list></block><block s="doPauseAll"></block><block s="doHideVar"><l></l></block></script></block></script></block-definition><block-definition s="ignore %&apos;x&apos;" type="command" category="control"><comment x="0" y="0" w="206.66666666666666" collapsed="false">This block does nothing.&#xD;Use it when you are calling a reporter&#xD;for its side effect and don&apos;t care about&#xD;its return value.</comment><header></header><code></code><translations>de:ignoriere _&#xD;ca:ignora _&#xD;es:ignorar _&#xD;fr:ignore _&#xD;pt:ignora _&#xD;</translations><inputs><input type="%s"></input></inputs></block-definition><block-definition s="cascade %&apos;num&apos; times %&apos;function&apos; %&apos;init&apos; %&apos;#&apos;" type="reporter" category="control"><comment x="0" y="0" w="138" collapsed="false">Call f(f(f(...(f(x))))) n times where the three input slots are n, f, and x from left to right.  The # variable can be used inside f to represent how many times f has been called.</comment><header></header><code></code><translations>pt:o resultado de _ invocações em cascata de _ com argumento inicial _ _&#xD;</translations><inputs><input type="%n"></input><input type="%repRing"></input><input type="%s"></input><input type="%upvar"></input></inputs><script><block s="doDeclareVariables"><list><l>result</l></list></block><block s="doSetVar"><l>result</l><block var="init"/></block><block s="doSetVar"><l>#</l><l>0</l></block><block s="doRepeat"><block var="num"/><script><block s="doChangeVar"><l>#</l><l>1</l></block><block s="doSetVar"><l>result</l><block s="evaluate"><block var="function"/><list><block var="result"/></list></block></block></script></block><block s="doReport"><block var="result"/></block></script></block-definition><block-definition s="cascade until %&apos;pred&apos; %&apos;function&apos; %&apos;init&apos; %&apos;#&apos;" type="reporter" category="control"><comment x="0" y="0" w="210.47493489583334" collapsed="false">Call f(f(f(...(f(x))))) until condition is true, where the three input slots are condition, f, and x from left to right.  The # variable can be used inside f or condition to indicate how many times f has been called.</comment><header></header><code></code><translations>pt:o resultado da invocação em cascata até que _ de _ com argumento inicial _ _&#xD;</translations><inputs><input type="%predRing"></input><input type="%repRing"></input><input type="%s"></input><input type="%upvar"></input></inputs><script><block s="doDeclareVariables"><list><l>result</l></list></block><block s="doSetVar"><l>result</l><block var="init"/></block><block s="doSetVar"><l>#</l><l>0</l></block><block s="doUntil"><block s="evaluate"><block var="pred"/><list><block var="result"/></list></block><script><block s="doChangeVar"><l>#</l><l>1</l></block><block s="doSetVar"><l>result</l><block s="evaluate"><block var="function"/><list><block var="result"/></list></block></block></script></block><block s="doReport"><block var="result"/></block></script></block-definition><block-definition s="compose %&apos;f&apos; %&apos;g&apos;" type="reporter" category="control"><comment x="0" y="0" w="151.33333333333334" collapsed="false">Returns the function x↦f(g(x)) where f and g are the two inputs.</comment><header></header><code></code><translations>pt:a composição de _ com _&#xD;</translations><inputs><input type="%repRing"></input><input type="%repRing"></input></inputs><script><block s="doReport"><block s="reifyReporter"><autolambda><block s="evaluate"><block var="f"/><list><block s="evaluate"><block var="g"/><list><l></l></list></block></list></block></autolambda><list></list></block></block></script></block-definition><block-definition s="repeat %&apos;action&apos; until %&apos;pred&apos;" type="command" category="control"><comment x="0" y="0" w="202.66666666666666" collapsed="false">Like the built-in REPEAT UNTIL block, except that the ending condition is not tested until the script has been run the first time.  So the script is run at least once.</comment><header></header><code></code><translations>pt:repete _ até que _ $loop-0.7&#xD;</translations><inputs><input type="%cs"></input><input type="%boolUE"></input></inputs><script><block s="doRun"><block var="action"/><list></list></block><block s="doUntil"><block s="evaluate"><block var="pred"/><list></list></block><script><block s="doRun"><block var="action"/><list></list></block></script></block></script></block-definition><block-definition s="repeat %&apos;action&apos; while %&apos;pred&apos;" type="command" category="control"><comment x="0" y="0" w="287.3333333333333" collapsed="false">Run the script repeatedly, as long as the given condition is true.  Runs the script at least once before testing the condition.</comment><header></header><code></code><translations>pt:repete _ enquanto _ $loop-0.7&#xD;</translations><inputs><input type="%cs"></input><input type="%boolUE"></input></inputs><script><block s="doRun"><block var="action"/><list></list></block><block s="doUntil"><block s="reportNot"><block s="evaluate"><block var="pred"/><list></list></block></block><script><block s="doRun"><block var="action"/><list></list></block></script></block></script></block-definition><block-definition s="repeat while %&apos;pred&apos; %&apos;action&apos;" type="command" category="control"><comment x="0" y="0" w="264" collapsed="false">Runs the script repeatedly, as long as the condition is true. Tests the condition before the first time the script is run.  Like the built in REPEAT UNTIL except that in this block the condition must be true, not false.</comment><header></header><code></code><translations>pt:enquanto _ , repete _ $loop-0.7&#xD;</translations><inputs><input type="%boolUE"></input><input type="%cs"></input></inputs><script><block s="doUntil"><block s="reportNot"><block s="evaluate"><block var="pred"/><list></list></block></block><script><block s="doRun"><block var="action"/><list></list></block></script></block></script></block-definition><block-definition s="repeat %&apos;num&apos; %&apos;#&apos; %&apos;action&apos;" type="command" category="control"><comment x="0" y="0" w="171" collapsed="false">Runs the script the specified number of times, like the built-in REPEAT block, but this one provides the # variable that can be used inside the script.  Try&#xD;REPEAT (200)&#xD;                MOVE (#) STEPS&#xD;   RIGHT 92&#xD;with the pen down.</comment><header></header><code></code><translations>pt:repete _ vezes _ _ $loop-0.7&#xD;</translations><inputs><input type="%n"></input><input type="%upvar"></input><input type="%cs"></input></inputs><script><block s="doSetVar"><l>#</l><l>0</l></block><block s="doRepeat"><block var="num"/><script><block s="doChangeVar"><l>#</l><l>1</l></block><block s="doRun"><block var="action"/><list></list></block></script></block></script></block-definition><block-definition s="for %&apos;i&apos; = %&apos;start&apos; step %&apos;step&apos; to %&apos;end&apos; %&apos;action&apos;" type="command" category="control"><comment x="0" y="0" w="247.33333333333334" collapsed="false">The primitive FOR block uses an implicit step of ±1 depending on which of the starting and ending values is larger.  This version allows you to provide an explicit step value.  If the sign of the step input is incompatible with the ordering of the starting and ending values, the script will not be run at all.</comment><header></header><code></code><translations>pt:para _ de _ com passo _ a _ _ $loop-0.7&#xD;</translations><inputs><input type="%upvar"></input><input type="%n">1</input><input type="%n">1</input><input type="%n">10</input><input type="%cs"></input></inputs><script><block s="doDeclareVariables"><list><l>test</l></list></block><block s="doSetVar"><l>i</l><block var="start"/></block><block s="doIfElse"><block s="reportLessThan"><block var="step"/><l>0</l></block><script><block s="doSetVar"><l>test</l><block s="reifyPredicate"><autolambda><block s="reportLessThan"><block var="i"/><block var="end"/></block></autolambda><list></list></block></block></script><script><block s="doSetVar"><l>test</l><block s="reifyPredicate"><autolambda><block s="reportGreaterThan"><block var="i"/><block var="end"/></block></autolambda><list></list></block></block></script></block><block s="doUntil"><block s="evaluate"><block var="test"/><list></list></block><script><block s="doRun"><block var="action"/><list></list></block><block s="doChangeVar"><l>i</l><block var="step"/></block></script></block></script></block-definition><block-definition s="let %&apos;a&apos; be %&apos;val&apos; in %&apos;loop&apos; %&apos;body&apos;" type="command" category="control"><comment x="0" y="0" w="238.66666666666666" collapsed="false">Provides LOOP as a function of one input that runs&#xD;the body of the LET with A set to the function input,&#xD;so the body can run itself recursively.&#xD;See COPY block in Variables for an example of use.</comment><header></header><code></code><translations>pt:tendo _ o valor inicial _ , executa _ definido como _&#xD;</translations><inputs><input type="%upvar"></input><input type="%s"></input><input type="%upvar"></input><input type="%cs"></input></inputs><script><block s="doSetVar"><l>a</l><block var="val"/></block><block s="doSetVar"><l>loop</l><block s="reifyScript"><script><block s="doSetVar"><l>a</l><block var="new value"/></block><block s="doRun"><block var="body"/><list><block var="a"/></list></block></script><list><l>new value</l></list></block></block><block s="doRun"><block var="loop"/><list><block var="a"/></list></block></script></block-definition><block-definition s="pipe %&apos;value&apos; $arrowRight %&apos;pipe&apos;" type="reporter" category="control"><comment x="0" y="0" w="339.3333333333333" collapsed="false">The inputs are a starting value and one or more monadic functions.&#xD;The first function is called with the starting value as its input.&#xD;The second function is called with the value reported by the first function as its input, and so on.  PIPE reports the value reported by the last function.  PIPE provides an alternative notation for function composition instead of the usual nesting.&#xD;&#xD;nested acronym:                                                                 &#xD;report (combine (keep items (capital-letter? ( )) from&#xD;                  (map (letter (1) of ( )) over&#xD;                                                 (sentence→list (phrase)))) using (join ( ) ( )))&#xD;&#xD;piped acronym:                                             &#xD;report (pipe (phrase) → (sentence→list ( ))&#xD;                                     (map (letter (1) of ( )) over ( ))&#xD;                                                    (keep items (capital-letter? ( )) from ( ))&#xD;                                      (combine ( ) using (join ( ) ( )))&#xD;&#xD;Some people find PIPE easier to read because the functions are called in the same order in which you read them, whereas in nested composition the innermost function is called first. </comment><header></header><code></code><translations>pt:a aplicação a _ de _&#xD;</translations><inputs><input type="%s"></input><input type="%mult%repRing"></input></inputs><script><block s="doIf"><block s="reportListIsEmpty"><block var="pipe"/></block><script><block s="doReport"><block var="value"/></block></script></block><block s="doReport"><custom-block s="pipe %s $arrowRight %mult%repRing"><block s="evaluate"><block s="reportListItem"><l>1</l><block var="pipe"/></block><list><block var="value"/></list></block><block s="reportCDR"><block var="pipe"/></block></custom-block></block></script></block-definition><block-definition s="sum %&apos;nums&apos;" type="reporter" category="operators"><comment x="0" y="0" w="202" collapsed="false">Takes any number of numbers as inputs (use the left and right arrowheads to adjust the number of input slots) and reports the result of adding them all, so&#xD;(SUM (4) (100) (8))&#xD;reports 112.</comment><header></header><code></code><translations>pt:a soma de _&#xD;</translations><inputs><input type="%mult%n"></input></inputs><script><block s="doIf"><block s="reportListIsEmpty"><block var="nums"/></block><script><block s="doReport"><l>0</l></block></script></block><block s="doReport"><block s="reportSum"><block s="reportListItem"><l>1</l><block var="nums"/></block><custom-block s="sum %mult%n"><block s="reportCDR"><block var="nums"/></block></custom-block></block></block></script></block-definition><block-definition s="product %&apos;nums&apos;" type="reporter" category="operators"><comment x="0" y="0" w="205" collapsed="false">Takes any number of numbers as inputs (use the left and right arrowheads to adjust the number of input slots) and reports the result of multiplying them all, so&#xD;(PRODUCT (4) (100) (8))&#xD;reports 3200.</comment><header></header><code></code><translations>pt:o produto de _&#xD;</translations><inputs><input type="%mult%n"></input></inputs><script><block s="doIf"><block s="reportListIsEmpty"><block var="nums"/></block><script><block s="doReport"><l>1</l></block></script></block><block s="doReport"><block s="reportProduct"><block s="reportListItem"><l>1</l><block var="nums"/></block><custom-block s="product %mult%n"><block s="reportCDR"><block var="nums"/></block></custom-block></block></block></script></block-definition><block-definition s="all of %&apos;preds&apos;" type="predicate" category="operators"><comment x="0" y="0" w="248" collapsed="false">Takes any number of Boolean (true/false) inputs (use the left and right arrowheads to adjust the number of input slots) and reports TRUE only if all of the inputs are TRUE, otherwise FALSE.  Like AND but for multiple inputs.</comment><header></header><code></code><translations>pt:todas as afirmações _ são verdadeiras&#xD;</translations><inputs><input type="%mult%boolUE"></input></inputs><script><block s="doIf"><block s="reportListIsEmpty"><block var="preds"/></block><script><block s="doReport"><block s="reportBoolean"><l><bool>true</bool></l></block></block></script></block><block s="doReport"><block s="reportAnd"><block s="evaluate"><block s="reportListItem"><l>1</l><block var="preds"/></block><list></list></block><custom-block s="all of %mult%boolUE"><block s="reportCDR"><block var="preds"/></block></custom-block></block></block></script></block-definition><block-definition s="any of %&apos;preds&apos;" type="predicate" category="operators"><comment x="0" y="0" w="240" collapsed="false">Takes any number of Boolean (true/false) inputs (use the left and right arrowheads to adjust the number of input slots) and reports TRUE if at least one input is TRUE, otherwise FALSE.</comment><header></header><code></code><translations>pt:alguma das afirmações _ é verdadeira&#xD;</translations><inputs><input type="%mult%boolUE"></input></inputs><script><block s="doIf"><block s="reportListIsEmpty"><block var="preds"/></block><script><block s="doReport"><block s="reportBoolean"><l><bool>false</bool></l></block></block></script></block><block s="doReport"><block s="reportOr"><block s="evaluate"><block s="reportListItem"><l>1</l><block var="preds"/></block><list></list></block><custom-block s="any of %mult%boolUE"><block s="reportCDR"><block var="preds"/></block></custom-block></block></block></script></block-definition><block-definition s="USE BIGNUMS %&apos;bool&apos;" type="command" category="operators"><comment x="0" y="0" w="303.3333333333333" collapsed="false">call with True to turn on the entire Scheme numeric tower, including infinite-precision integers, exact rationals, and complex numbers; call with False to restore native JavaScript arithmetic.</comment><header></header><code></code><translations>pt:altera utilização de aritmética do Scheme para _&#xD;</translations><inputs><input type="%b"></input></inputs><script><block s="doDeclareVariables"><list><l>isDone</l></list></block><block s="doSetVar"><l>isDone</l><block s="evaluate"><block s="reportJSFunction"><list><l>useBigNums</l></list><l>var done = false;&#xD;&#xD;function initialize (callback) {&#xD;    var bigScript = document.createElement(&apos;script&apos;);&#xD;    bigScript.src = &apos;//snap.berkeley.edu/snap/libraries/biginteger.js&apos;;&#xD;    bigScript.onload = loadScheme;&#xD;    document.head.appendChild(bigScript);&#xD;&#xD;    function loadScheme () {&#xD;        var schemeScript = document.createElement(&apos;script&apos;);&#xD;        schemeScript.src = &apos;//snap.berkeley.edu/snap/libraries/schemeNumber.js&apos;;&#xD;        schemeScript.onload = finish;&#xD;        document.head.appendChild(schemeScript);&#xD;    }&#xD;&#xD;    function finish () {&#xD;        makeGlobalObject();&#xD;        callback();&#xD;    }&#xD;}&#xD;&#xD;function makeGlobalObject () {&#xD;    window.bigNumbers = {&#xD;        originalEvaluate: InputSlotMorph.prototype.evaluate,&#xD;        originalChangeVar: VariableFrame.prototype.changeVar,&#xD;        originalPrims: {&#xD;            reportBasicSum: Process.prototype.reportBasicSum,&#xD;            reportBasicDifference: Process.prototype.reportBasicDifference,&#xD;            reportBasicProduct: Process.prototype.reportBasicProduct,&#xD;            reportBasicQuotient: Process.prototype.reportBasicQuotient,&#xD;            reportBasicPower: Process.prototype.reportBasicPower,&#xD;            reportBasicModulus: Process.prototype.reportBasicModulus,&#xD;            reportBasicRandom: Process.prototype.reportBasicRandom,&#xD;            reportBasicLessThan: Process.prototype.reportBasicLessThan,&#xD;            reportBasicGreaterThan: Process.prototype.reportBasicGreaterThan,&#xD;            reportEquals: Process.prototype.reportEquals,&#xD;            reportIsIdentical: Process.prototype.reportIsIdentical,&#xD;            reportMonadic: Process.prototype.reportMonadic&#xD;        }&#xD;    };&#xD;}&#xD;&#xD;function loadBlocks () {&#xD;    var fn = SchemeNumber.fn;&#xD;    var originalPrims = window.bigNumbers.originalPrims;&#xD;    if (useBigNums) {&#xD;        InputSlotMorph.prototype.evaluate = function () {&#xD;            var contents = this.contents();&#xD;            if (this.constant) {&#xD;                return this.constant;&#xD;            }&#xD;            if (this.isNumeric) {&#xD;                return parseNumber(contents.text || &apos;0&apos;);&#xD;            }&#xD;            return contents.text;&#xD;        };&#xD;        VariableFrame.prototype.changeVar = function (name, delta, sender) {&#xD;            var frame = this.find(name),&#xD;                value,&#xD;                newValue;&#xD;            if (frame) {&#xD;                value = parseNumber(frame.vars[name].value);&#xD;                newValue = Number.isNaN(value) ? delta : fn[&apos;+&apos;](value, parseNumber(delta));&#xD;                if (sender instanceof SpriteMorph &amp;&amp;&#xD;                        (frame.owner instanceof SpriteMorph) &amp;&amp;&#xD;                        (sender !== frame.owner)) {&#xD;                    sender.shadowVar(name, newValue);&#xD;                } else {&#xD;                    frame.vars[name].value = newValue;&#xD;                }&#xD;&#xD;            }&#xD;        };&#xD;        Object.assign(Process.prototype, {&#xD;            reportBasicSum: function (a, b) {&#xD;                a = parseNumber(a);&#xD;                b = parseNumber(b);&#xD;                if (Number.isNaN(a) || Number.isNaN(b)) return NaN;&#xD;                return fn[&apos;+&apos;](a, b);&#xD;            },&#xD;            reportBasicDifference: function (a, b) {&#xD;                a = parseNumber(a);&#xD;                b = parseNumber(b);&#xD;                if (Number.isNaN(a) || Number.isNaN(b)) return NaN;&#xD;                return fn[&apos;-&apos;](a, b);&#xD;            },&#xD;            reportBasicProduct: function (a, b) {&#xD;                a = parseNumber(a);&#xD;                b = parseNumber(b);&#xD;                if (Number.isNaN(a) || Number.isNaN(b)) return NaN;&#xD;                return fn[&apos;*&apos;](a, b);&#xD;            },&#xD;            reportBasicQuotient: function (a, b) {&#xD;                a = parseNumber(a);&#xD;                b = parseNumber(b);&#xD;                if (fn[&apos;=&apos;](b, &apos;0&apos;) &amp;&amp; !fn[&apos;=&apos;](a, &apos;0&apos;)) {&#xD;                      return (fn[&apos;&lt;&apos;](a, &apos;0&apos;) ? SchemeNumber(&apos;-inf.0&apos;) : SchemeNumber(&apos;+inf.0&apos;))&#xD;                };&#xD;                if (Number.isNaN(a) || Number.isNaN(b) || fn[&apos;=&apos;](b, &apos;0&apos;)) return NaN;&#xD;                return fn[&apos;/&apos;](a, b);&#xD;            },&#xD;            reportBasicPower: function (a, b) {&#xD;                a = parseNumber(a);&#xD;                b = parseNumber(b);&#xD;                if (Number.isNaN(a) || Number.isNaN(b)) return NaN;&#xD;                return fn[&apos;expt&apos;](a, b);&#xD;            },&#xD;            reportBasicModulus: function (a, b) {&#xD;                a = parseNumber(a);&#xD;                b = parseNumber(b);&#xD;                if (Number.isNaN(a) || Number.isNaN(b)) return NaN;&#xD;                var result = fn.mod(a, b);&#xD;                if (fn[&apos;&lt;&apos;](b, &apos;0&apos;) &amp;&amp; fn[&apos;&gt;&apos;](result, &apos;0&apos;)) {&#xD;                    result = fn[&apos;+&apos;](result, b);&#xD;                }&#xD;                return result;&#xD;            },&#xD;            reportBasicRandom: function (min, max) {&#xD;                var floor = parseNumber(min),&#xD;                    ceil = parseNumber(max);&#xD;                if (Number.isNaN(floor) || Number.isNaN(ceil)) return NaN;&#xD;                if (!fn[&apos;=&apos;](fn.mod(floor, &apos;1&apos;), &apos;0&apos;) || !fn[&apos;=&apos;](fn.mod(ceil, &apos;1&apos;), &apos;0&apos;)) {&#xD;                    // One of the numbers isn&apos;t whole. Include the decimal.&#xD;                    return fn[&apos;+&apos;](&#xD;                        fn[&apos;*&apos;](&#xD;                            Math.random(),&#xD;                            fn[&apos;-&apos;](ceil, floor)&#xD;                        ),&#xD;                        floor&#xD;                    );&#xD;                }&#xD;                return fn.floor(&#xD;                    fn[&apos;+&apos;](&#xD;                        fn[&apos;*&apos;](&#xD;                            Math.random(),&#xD;                            fn[&apos;+&apos;](&#xD;                                fn[&apos;-&apos;](ceil, floor),&#xD;                                &apos;1&apos;&#xD;                            )&#xD;                        ),&#xD;                        floor&#xD;                    )&#xD;                );&#xD;            },&#xD;            reportBasicLessThan: function (a, b) {&#xD;                a = parseNumber(a);&#xD;                b = parseNumber(b);&#xD;                if (Number.isNaN(a) || Number.isNaN(b)) return NaN;&#xD;                return fn[&apos;&lt;&apos;](a, b);&#xD;            },&#xD;            reportBasicGreaterThan: function (a, b) {&#xD;                a = parseNumber(a);&#xD;                b = parseNumber(b);&#xD;                if (Number.isNaN(a) || Number.isNaN(b)) return NaN;&#xD;                return fn[&apos;&gt;&apos;](a, b);&#xD;            },&#xD;            reportEqual: function (a, b) {&#xD;                x = parseNumber(a);&#xD;                y = parseNumber(b);&#xD;                if (Number.isNaN(x) || Number.isNaN(y)) return snapEquals(a, b);&#xD;                return fn[&apos;=&apos;](x, y);&#xD;            },&#xD;            reportIsIdentical: function (a, b) {&#xD;                x = parseNumber(a);&#xD;                y = parseNumber(b);&#xD;                if (Number.isNaN(x) || Number.isNaN(y)) return originalPrims.reportIsIdentical(a, b);&#xD;                return fn[&apos;=&apos;](x, y);&#xD;            },&#xD;            reportMonadic: function (fname, n) {&#xD;                if (this.enableHyperOps) {&#xD;                    if (n instanceof List) {&#xD;                        return n.map(each =&gt; this.reportMonadic(fname, each));&#xD;                    }&#xD;                }&#xD;&#xD;                n = parseNumber(n);&#xD;                if (Number.isNaN(n)) return NaN;&#xD;&#xD;                switch (Process.prototype.inputOption(fname)) {&#xD;                case &apos;abs&apos;:&#xD;                    return fn.abs(n);&#xD;                case &apos;neg&apos;:&#xD;                    return fn[&apos;-&apos;](n);&#xD;                case &apos;ceiling&apos;:&#xD;                    return fn.ceiling(n);&#xD;                case &apos;floor&apos;:&#xD;                    return fn.floor(n);&#xD;                case &apos;sqrt&apos;:&#xD;                    return sqrt(n);&#xD;                case &apos;sin&apos;:&#xD;                    return fn.sin(radians(n));&#xD;                case &apos;cos&apos;:&#xD;                    return fn.cos(radians(n));&#xD;                case &apos;tan&apos;:&#xD;                    return fn.tan(radians(n));&#xD;                case &apos;asin&apos;:&#xD;                    return degrees(fn.asin(n));&#xD;                case &apos;acos&apos;:&#xD;                    return degrees(fn.acos(n));&#xD;                case &apos;atan&apos;:&#xD;                    return degrees(fn.atan(n));&#xD;                case &apos;ln&apos;:&#xD;                    return fn.log(n);&#xD;                case &apos;log&apos;:&#xD;                    return fn.log(n, &apos;10&apos;);&#xD;                case &apos;lg&apos;:&#xD;                    return fn.log(n, &apos;2&apos;);&#xD;                case &apos;e^&apos;:&#xD;                    return fn.exp(n);&#xD;                case &apos;10^&apos;:&#xD;                    return fn.expt(&apos;10&apos;, n);&#xD;                case &apos;2^&apos;:&#xD;                    return fn.expt(&apos;2&apos;, n);&#xD;                default:&#xD;                    return SchemeNumber(&apos;0&apos;);&#xD;                }&#xD;            }&#xD;        });&#xD;    } else {&#xD;        InputSlotMorph.prototype.evaluate = window.bigNumbers.originalEvaluate;&#xD;        VariableFrame.prototype.changeVar = window.bigNumbers.originalChangeVar;&#xD;        Object.assign(Process.prototype, originalPrims);&#xD;    }&#xD;    done = true;&#xD;}&#xD;&#xD;function parseNumber (n) {&#xD;    var fn = SchemeNumber.fn;&#xD;    if (!fn[&apos;number?&apos;](n)) {&#xD;        n = &apos;&apos; + n;&#xD;        try {&#xD;            return parseENotation(n) || SchemeNumber(n);&#xD;        } catch (err) {&#xD;            return NaN;&#xD;        }&#xD;    }&#xD;    return n;&#xD;}&#xD;&#xD;function parseENotation (n) {&#xD;    var fn = SchemeNumber.fn;&#xD;&#xD;    var numbers = n.match(/^(-?\d+\.?\d*|-?\.\d+)e(-?\d+)$/i);&#xD;    if (!numbers) return null;&#xD;&#xD;    var coefficient = numbers[1];&#xD;    var exponent = numbers[2];&#xD;    return fn[&apos;*&apos;](&#xD;        coefficient,&#xD;        fn.expt(&apos;10&apos;, exponent)&#xD;    );&#xD;}&#xD;&#xD;function sqrt (n) {&#xD;    var fn = SchemeNumber.fn;&#xD;&#xD;    if (!fn[&apos;exact?&apos;](n) || !fn[&apos;rational?&apos;](n) || fn[&apos;&lt;&apos;](n,&apos;0&apos;)) return fn.sqrt(n);&#xD;&#xD;    var rootNumerator = fn[&apos;exact-integer-sqrt&apos;](fn.numerator(n));&#xD;    if (!fn[&apos;=&apos;](rootNumerator[1], &apos;0&apos;)) return fn.sqrt(n);&#xD;&#xD;    var rootDenominator = fn[&apos;exact-integer-sqrt&apos;](fn.denominator(n));&#xD;    if (!fn[&apos;=&apos;](rootDenominator[1], &apos;0&apos;)) return fn.sqrt(n);&#xD;&#xD;    return fn[&apos;/&apos;](rootNumerator[0], rootDenominator[0]);&#xD;}&#xD;&#xD;function isDone () {&#xD;    return done;&#xD;}&#xD;&#xD;if (window.bigNumbers) {&#xD;    loadBlocks();&#xD;} else {&#xD;    initialize(loadBlocks);&#xD;}&#xD;&#xD;return isDone;</l></block><list><block var="bool"/></list></block></block><block s="doWaitUntil"><block s="evaluate"><block var="isDone"/><list></list></block></block></script></block-definition><block-definition s="%&apos;n&apos; !" type="reporter" category="operators"><comment x="0" y="0" w="190.66666666666666" collapsed="false">The factorial function, to make very large numbers, to demo bignums.</comment><header></header><code></code><translations></translations><inputs><input type="%n"></input></inputs><script><block s="doReport"><block s="reportIfElse"><block s="reportEquals"><block var="n"/><l>0</l></block><l>1</l><block s="reportProduct"><block var="n"/><custom-block s="%n !"><block s="reportDifference"><block var="n"/><l>1</l></block></custom-block></block></block></block></script></block-definition><block-definition s="%&apos;x&apos;" type="reporter" category="operators"><comment x="0" y="0" w="234.66666666666666" collapsed="false">The identity function: reports its input.&#xD;It&apos;s useful to get things like 3/4 or 5-2i into&#xD;numeric input slots.</comment><header></header><code></code><translations></translations><inputs><input type="%s"></input></inputs><script><block s="doReport"><block var="x"/></block></script></block-definition><block-definition s="Scheme number %&apos;function&apos; of %&apos;number&apos;" type="reporter" category="operators"><comment x="0" y="0" w="300" collapsed="true">Provides Scheme arithmetic functions not in JavaScript</comment><header></header><code></code><translations>pt:_ de _&#xD;</translations><inputs><input type="%s" readonly="true"><options>number?&#xD;complex?&#xD;real?&#xD;rational?&#xD;integer?&#xD;exact?&#xD;inexact?&#xD;exact&#xD;inexact&#xD;finite?&#xD;infinite?&#xD;nan?&#xD;numerator&#xD;denominator&#xD;real-part&#xD;imag-part&#xD;magnitude&#xD;angle</options></input><input type="%s"></input></inputs><script><block s="doReport"><block s="evaluate"><block s="reportJSFunction"><list><l>which</l><l>num</l></list><l>function parseNumber (n) {&#xD;    var fn = SchemeNumber.fn;&#xD;    if (!fn[&apos;number?&apos;](n)) {&#xD;        n = &apos;&apos; + n;&#xD;        try {&#xD;            return parseENotation(n) || SchemeNumber(n);&#xD;        } catch (err) {&#xD;            return NaN;&#xD;        }&#xD;    }&#xD;    return n;&#xD;}&#xD;&#xD;function parseENotation (n) {&#xD;    var fn = SchemeNumber.fn;&#xD;&#xD;    var numbers = n.match(/^(-?\d+\.?\d*|-?\.\d+)e(-?\d+)$/i);&#xD;    if (!numbers) return null;&#xD;&#xD;    var coefficient = numbers[1];&#xD;    var exponent = numbers[2];&#xD;    return fn[&apos;*&apos;](&#xD;        coefficient,&#xD;        fn.expt(&apos;10&apos;, exponent)&#xD;    );&#xD;}&#xD;var fn=SchemeNumber.fn,&#xD;      number=parseNumber(num);&#xD;&#xD;switch (which) {&#xD;  case &apos;number?&apos;:&#xD;  case &apos;complex?&apos;:&#xD;    return (fn[&apos;number?&apos;](number));&#xD;  case &apos;real?&apos;:&#xD;    return (fn[&apos;real?&apos;](number) || fn[&apos;real-valued?&apos;](number));&#xD;  case &apos;rational?&apos;:&#xD;    return (fn[&apos;rational?&apos;](number) || (fn[&apos;=&apos;](number, fn.rationalize(number, parseNumber(&apos;1.0e-5&apos;)))));&#xD;  case &apos;integer?&apos;:&#xD;    return (fn[&apos;integer?&apos;](number) || fn[&apos;integer-valued?&apos;](number));&#xD;  case &apos;exact?&apos;:&#xD;  case &apos;inexact?&apos;:&#xD;  case &apos;finite?&apos;:&#xD;  case &apos;infinite?&apos;:&#xD;  case &apos;nan?&apos;:&#xD;  case &apos;real-part&apos;:&#xD;  case &apos;imag-part&apos;:&#xD;    return (fn[which](number));&#xD;  case &apos;magnitude&apos;:&#xD;    return (fn.magnitude(number));&#xD;  case &apos;angle&apos;:&#xD;    return (fn.angle(number));&#xD;  case &apos;numerator&apos;:&#xD;    return (fn.numerator(number));&#xD;  case &apos;denominator&apos;:&#xD;    return (fn.denominator(number));&#xD;  case &apos;exact&apos;:&#xD;    return (fn.exact(number));&#xD;case &apos;inexact&apos;:&#xD;    return (fn.inexact(number));&#xD;}</l></block><list><block var="function"/><block var="number"/></list></block></block></script></block-definition><block-definition s="cases: if %&apos;test&apos; then %&apos;result&apos; %&apos;more&apos;" type="command" category="control"><comment x="0" y="0" w="262" collapsed="false">Multi-branched conditional.&#xD;&#xD;If the first (Boolean) input is True, then the script in&#xD;the second (C-slot) input is run, and this block stops.&#xD;&#xD;Additional tests can be added by putting one or more&#xD;ELSE IF blocks in the third (variadic) Boolean slot.&#xD;Use the arrowheads to get the number of Boolean&#xD;slots you need.  Each ELSE IF block provides a Boolean&#xD;slot for a condition to test and a script slot for what to do&#xD;if the condition is True.  You can put an ELSE block in&#xD;the last Boolean input to CASES for a script to run if&#xD;all the tests turn out False.&#xD;&#xD;As soon as a condition is True, no further tests are done&#xD;and no further scripts are run.</comment><header></header><code></code><translations>pt:se _ , então _ _&#xD;</translations><inputs><input type="%b"></input><input type="%cs"></input><input type="%mult%boolUE"></input></inputs><script><block s="doIfElse"><block var="test"/><script><block s="doRun"><block var="result"/><list></list></block></script><script><custom-block s="catch %upvar %cs"><l>tag</l><script><block s="doForEach"><l>item</l><block var="more"/><script><block s="doIf"><block s="evaluate"><block var="item"/><list></list></block><script><custom-block s="throw %s"><block var="tag"/></custom-block></script></block></script></block></script></custom-block></script></block></script></block-definition><block-definition s="catch %&apos;tag&apos; %&apos;action&apos;" type="command" category="control"><header></header><code></code><translations>pt:captura _ _&#xD;</translations><inputs><input type="%upvar"></input><input type="%cs"></input></inputs><script><block s="doCallCC"><block s="reifyScript"><script><block s="doSetVar"><l>tag</l><block var="cont"/></block><block s="doRun"><block var="action"/><list></list></block></script><list><l>cont</l></list></block></block></script></block-definition><block-definition s="throw %&apos;cont&apos;" type="command" category="control"><header></header><code></code><translations>pt:lança _&#xD;</translations><inputs><input type="%s">catchtag</input></inputs><script><block s="doRun"><block var="cont"/><list></list></block></script></block-definition><block-definition s="else if %&apos;test&apos; then %&apos;action&apos;" type="predicate" category="control"><comment x="0" y="0" w="176" collapsed="false">For use with the CASES block.&#xD;See its help message.</comment><header></header><code></code><translations>pt:senão, se _ , então _&#xD;</translations><inputs><input type="%b"></input><input type="%cs"></input></inputs><script><block s="doIfElse"><block var="test"/><script><block s="doRun"><block var="action"/><list></list></block><block s="doReport"><block s="reportBoolean"><l><bool>true</bool></l></block></block></script><script><block s="doReport"><block s="reportBoolean"><l><bool>false</bool></l></block></block></script></block></script></block-definition><block-definition s="else %&apos;action&apos;" type="predicate" category="control"><comment x="0" y="0" w="176" collapsed="false">For use with the CASES block.&#xD;See its help message.</comment><header></header><code></code><translations>pt:senão, _&#xD;</translations><inputs><input type="%cs"></input></inputs><script><block s="doRun"><block var="action"/><list></list></block><block s="doReport"><block s="reportBoolean"><l><bool>true</bool></l></block></block></script></block-definition></blocks><variables><variable name="a"></variable></variables></project><media name="Hypercompact Mandelbrot (Snap Codegolf)" app="Snap! 6, https://snap.berkeley.edu" version="1"></media></snapdata>