<snapdata remixID="9174792"><project name="takeshi iteration 3" app="Snap! 5.4, http://snap.berkeley.edu" version="1"><notes></notes><thumbnail>data:image/png;base64,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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" codify="false" inheritance="true" sublistIDs="false" scheduled="false" id="1"><pentrails>data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAeAAAAFoCAYAAACPNyggAAAOhUlEQVR4Xu3VwQkAAAjEMN1/abewn7jAQRC64wgQIECAAIF3gX1fNEiAAAECBAiMAHsCAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQIHLFxAWmhEwHPAAAAAElFTkSuQmCC</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="0" y="0" heading="90" scale="1" volume="100" pan="0" rotation="1" draggable="true" costume="0" color="80,80,80,1" pen="tip" id="8"><costumes><list struct="atomic" id="9"></list></costumes><sounds><list struct="atomic" id="10"></list></sounds><blocks></blocks><variables></variables><scripts><script x="20" y="20"><block s="receiveKey"><l><option>s</option></l></block><block s="doSetVar"><l>grades</l><block s="reportNewList"><list><l>75</l><l>80</l><l>72</l><l>94</l><l>78</l><l>83</l><l>88</l><l>90</l><l>76</l><l>80</l><l>84</l><l>3266</l><l>81725</l><l>36692</l></list></block></block><custom-block s="USE BIGNUMS %b"><block s="reportBoolean"><l><bool>true</bool></l></block></custom-block></script><script x="20" y="123"><custom-block s="get the product using the combine function %l"><block var="grades"/></custom-block></script><script x="20" y="157"><custom-block s="get the product using for loop %l"><block var="grades"/></custom-block></script><script x="20" y="191"><custom-block s="get the product using recursion %l"><block var="grades"/></custom-block></script></scripts></sprite><watcher var="grades" style="normal" x="0.5" y="-3" color="243,118,29" extX="136" extY="119"/></sprites></stage><hidden></hidden><headers></headers><code></code><blocks><block-definition s="get the product using the combine function %&apos;input-list&apos;" type="reporter" category="other"><header></header><code></code><translations></translations><inputs><input type="%l"></input></inputs><script><block s="doReport"><block s="reportCombine"><block var="input-list"/><block s="reifyReporter"><autolambda><block s="reportProduct"><l></l><l></l></block></autolambda><list></list></block></block></block></script></block-definition><block-definition s="get the product using for loop %&apos;input-list&apos;" type="reporter" category="other"><header></header><code></code><translations></translations><inputs><input type="%l"></input></inputs><script><block s="doDeclareVariables"><list><l>product</l></list></block><block s="doSetVar"><l>product</l><l>1</l></block><block s="doForEach"><l>item</l><block var="input-list"/><script><block s="doSetVar"><l>product</l><block s="reportProduct"><block var="product"/><block var="item"/></block></block></script></block><block s="doReport"><block var="product"/></block></script></block-definition><block-definition s="get the product using recursion %&apos;input-list&apos;" type="reporter" category="other"><header></header><code></code><translations></translations><inputs><input type="%l"></input></inputs><script><block s="doDeclareVariables"><list><l>item1</l></list></block><block s="doReport"><l></l></block></script><scripts><script x="713.4068848933823" y="314.62745398039215"><custom-block s="get the product using recursion %l"><block s="reportCDR"><block var="input-list"/></block></custom-block></script></scripts></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/snapsource/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/snapsource/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;            reportSum: Process.prototype.reportSum,&#xD;            reportDifference: Process.prototype.reportDifference,&#xD;            reportProduct: Process.prototype.reportProduct,&#xD;            reportQuotient: Process.prototype.reportQuotient,&#xD;            reportPower: Process.prototype.reportPower,&#xD;            reportModulus: Process.prototype.reportModulus,&#xD;            reportRandom: Process.prototype.reportRandom,&#xD;            reportLessThan: Process.prototype.reportLessThan,&#xD;            reportGreaterThan: Process.prototype.reportGreaterThan,&#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 = value !== value ? delta : 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;            reportSum: function (a, b) {&#xD;                a = parseNumber(a);&#xD;                b = parseNumber(b);&#xD;                if (a !== a || b !== b) return NaN;&#xD;                return fn[&apos;+&apos;](a, b);&#xD;            },&#xD;            reportDifference: function (a, b) {&#xD;                a = parseNumber(a);&#xD;                b = parseNumber(b);&#xD;                if (a !== a || b !== b) return NaN;&#xD;                return fn[&apos;-&apos;](a, b);&#xD;            },&#xD;            reportProduct: function (a, b) {&#xD;                a = parseNumber(a);&#xD;                b = parseNumber(b);&#xD;                if (a !== a || b !== b) return NaN;&#xD;                return fn[&apos;*&apos;](a, b);&#xD;            },&#xD;            reportQuotient: 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 (a !== a || b !== b || fn[&apos;=&apos;](b, &apos;0&apos;)) return SchemeNumber(&apos;+nan.0&apos;);&#xD;                return fn[&apos;/&apos;](a, b);&#xD;            },&#xD;            reportPower: function (a, b) {&#xD;                a = parseNumber(a);&#xD;                b = parseNumber(b);&#xD;                if (a !== a || b !== b) return NaN;&#xD;                return fn[&apos;expt&apos;](a, b);&#xD;            },&#xD;            reportModulus: function (a, b) {&#xD;                a = parseNumber(a);&#xD;                b = parseNumber(b);&#xD;                if (a !== a || b !== 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;            reportRandom: function (min, max) {&#xD;                var floor = parseNumber(min),&#xD;                    ceil = parseNumber(max);&#xD;                if (floor !== floor || ceil !== 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;            reportLessThan: function (a, b) {&#xD;                a = parseNumber(a);&#xD;                b = parseNumber(b);&#xD;                if (a !== a || b !== b) return NaN;&#xD;                return fn[&apos;&lt;&apos;](a, b);&#xD;            },&#xD;            reportGreaterThan: function (a, b) {&#xD;                a = parseNumber(a);&#xD;                b = parseNumber(b);&#xD;                if (a !== a || b !== b) return NaN;&#xD;                return fn[&apos;&gt;&apos;](a, b);&#xD;            },&#xD;            reportGreaterThan: function (a, b) {&#xD;                a = parseNumber(a);&#xD;                b = parseNumber(b);&#xD;                if (a !== a || b !== 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 (x !== x || y !== 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 (x !== x || y !== y) return originalPrims.reportIsIdentical(a, b);&#xD;                return fn[&apos;=&apos;](x, y);&#xD;            },&#xD;            reportMonadic: function (fname, n) {&#xD;                n = parseNumber(n);&#xD;                if (n !== n) return NaN;&#xD;&#xD;                switch (Process.prototype.inputOption(fname)) {&#xD;                case &apos;abs&apos;:&#xD;                    return fn.abs(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;e^&apos;:&#xD;                    return fn.exp(n);&#xD;                case &apos;10^&apos;:&#xD;                    return fn.expt(&apos;10&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"><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"><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></blocks><variables><variable name="grades"><list struct="atomic" id="162">75,80,72,94,78,83,88,90,76,80,84,3266,81725,36692</list></variable></variables></project><media name="takeshi iteration 3" app="Snap! 5.4, http://snap.berkeley.edu" version="1"></media></snapdata>