(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o elø1 ? (function () { return minø1 = elø1; })() : void 0; }.call(this)); return loop[0] = 1 + iø1, loop; })() : void 0; } while (iø1 = loop[0], recur === loop); return recur; }.call(this); }.call(this)); return function () { var spanø1 = maxø1 - minø1; return function () { var G__2ø1 = hm.length; return function loop() { var recur = loop; var iø1 = 0; do { recur = iø1 < G__2ø1 ? (function () { hm[iø1] = (hm[iø1] - minø1) / spanø1; return loop[0] = 1 + iø1, loop; })() : void 0; } while (iø1 = loop[0], recur === loop); return recur; }.call(this); }.call(this); }.call(this); }.call(this); }; var zeroHeightmap = exports.zeroHeightmap = function zeroHeightmap(heightmap) { (function () { var G__3ø1 = heightmap.length; return function loop() { var recur = loop; var iø1 = 0; do { recur = iø1 < G__3ø1 ? (function () { heightmap[iø1] = 0; return loop[0] = 1 + iø1, loop; })() : void 0; } while (iø1 = loop[0], recur === loop); return recur; }.call(this); }.call(this)); return heightmap; }; var makeHeightmap = exports.makeHeightmap = function makeHeightmap(exponent) { return function () { var resolutionø1 = 1 + Math.pow(2, exponent); l('Creating ' + resolutionø1 + ' by ' + resolutionø1 + ' heightmap...'); var heightmap = new Array(resolutionø1 * resolutionø1); heightmap.resolution = resolutionø1; heightmap.exponent = exponent; heightmap.last = resolutionø1 - 1; return zeroHeightmap(heightmap); }.call(this); }; var randomNoise = exports.randomNoise = function randomNoise(heightmap) { return function () { var G__4ø1 = heightmap.length; return function loop() { var recur = loop; var iø1 = 0; do { recur = iø1 < G__4ø1 ? (function () { heightmap[iø1] = rand(); return loop[0] = 1 + iø1, loop; })() : void 0; } while (iø1 = loop[0], recur === loop); return recur; }.call(this); }.call(this); }; var mpdInitCorners = exports.mpdInitCorners = function mpdInitCorners(heightmap) { heightmap[0 * heightmap.resolution + 0] = rand(); heightmap[heightmap.last * heightmap.resolution + 0] = rand(); heightmap[0 * heightmap.resolution + heightmap.last] = rand(); return heightmap[heightmap.last * heightmap.resolution + heightmap.last] = rand(); }; var mpdDisplace = exports.mpdDisplace = function mpdDisplace(heightmap, lx, rx, by, ty, spread) { return function () { var cxø1 = midpoint(lx, rx); var cyø1 = midpoint(by, ty); var bottomLeftø1 = heightmap[by * heightmap.resolution + lx]; var bottomRightø1 = heightmap[by * heightmap.resolution + rx]; var topLeftø1 = heightmap[ty * heightmap.resolution + lx]; var topRightø1 = heightmap[ty * heightmap.resolution + rx]; var topø1 = average2(topLeftø1, topRightø1); var leftø1 = average2(bottomLeftø1, topLeftø1); var bottomø1 = average2(bottomLeftø1, bottomRightø1); var rightø1 = average2(bottomRightø1, topRightø1); var centerø1 = average4(topø1, leftø1, bottomø1, rightø1); heightmap[by * heightmap.resolution + cxø1] = jitter(bottomø1, spread); heightmap[ty * heightmap.resolution + cxø1] = jitter(topø1, spread); heightmap[cyø1 * heightmap.resolution + lx] = jitter(leftø1, spread); heightmap[cyø1 * heightmap.resolution + rx] = jitter(rightø1, spread); return heightmap[cyø1 * heightmap.resolution + cxø1] = jitter(centerø1, spread); }.call(this); }; var midpointDisplacement = exports.midpointDisplacement = function midpointDisplacement(heightmap) { mpdInitCorners(heightmap); (function loop() { var recur = loop; var iterø1 = 0; var spreadø1 = 0.3; do { recur = iterø1 < heightmap.exponent ? (function () { (function () { var chunksø1 = Math.pow(2, iterø1); var chunkWidthø1 = (heightmap.resolution - 1) / chunksø1; return function () { var G__5ø1 = chunksø1; return function () { var G__6ø1 = G__5ø1; return function loop() { var recur = loop; var xchunkø1 = 0; do { recur = xchunkø1 < G__6ø1 ? (function () { (function () { var G__7ø1 = G__5ø1; return function loop() { var recur = loop; var ychunkø1 = 0; do { recur = ychunkø1 < G__7ø1 ? (function () { (function () { var leftXø1 = chunkWidthø1 * xchunkø1; var rightXø1 = leftXø1 + chunkWidthø1; var bottomYø1 = chunkWidthø1 * ychunkø1; var topYø1 = bottomYø1 + chunkWidthø1; return mpdDisplace(heightmap, leftXø1, rightXø1, bottomYø1, topYø1, spreadø1); }.call(this)); return loop[0] = 1 + ychunkø1, loop; })() : void 0; } while (ychunkø1 = loop[0], recur === loop); return recur; }.call(this); }.call(this)); return loop[0] = 1 + xchunkø1, loop; })() : void 0; } while (xchunkø1 = loop[0], recur === loop); return recur; }.call(this); }.call(this); }.call(this); }.call(this)); return loop[0] = 1 + iterø1, loop[1] = spreadø1 * 0.5, loop; })() : void 0; } while (iterø1 = loop[0], spreadø1 = loop[1], recur === loop); return recur; }.call(this)); return normalize(heightmap); }; var midpointDisplacementFinal = exports.midpointDisplacementFinal = function midpointDisplacementFinal(heightmap) { mpdInitCorners(heightmap); (function loop() { var recur = loop; var iterø1 = 0; var spreadø1 = 0 + $('#input-starting-spread').val(); do { recur = iterø1 < heightmap.exponent ? (function () { (function () { var chunksø1 = Math.pow(2, iterø1); var chunkWidthø1 = (heightmap.resolution - 1) / chunksø1; return function () { var G__8ø1 = chunksø1; return function () { var G__9ø1 = G__8ø1; return function loop() { var recur = loop; var xchunkø1 = 0; do { recur = xchunkø1 < G__9ø1 ? (function () { (function () { var G__10ø1 = G__8ø1; return function loop() { var recur = loop; var ychunkø1 = 0; do { recur = ychunkø1 < G__10ø1 ? (function () { (function () { var leftXø1 = chunkWidthø1 * xchunkø1; var rightXø1 = leftXø1 + chunkWidthø1; var bottomYø1 = chunkWidthø1 * ychunkø1; var topYø1 = bottomYø1 + chunkWidthø1; return mpdDisplace(heightmap, leftXø1, rightXø1, bottomYø1, topYø1, spreadø1); }.call(this)); return loop[0] = 1 + ychunkø1, loop; })() : void 0; } while (ychunkø1 = loop[0], recur === loop); return recur; }.call(this); }.call(this)); return loop[0] = 1 + xchunkø1, loop; })() : void 0; } while (xchunkø1 = loop[0], recur === loop); return recur; }.call(this); }.call(this); }.call(this); }.call(this)); return loop[0] = 1 + iterø1, loop[1] = spreadø1 * (0 + $('#input-spread-reduction').val()), loop; })() : void 0; } while (iterø1 = loop[0], spreadø1 = loop[1], recur === loop); return recur; }.call(this)); return normalize(heightmap); }; var mpdDisplaceD2 = exports.mpdDisplaceD2 = function mpdDisplaceD2(heightmap, lx, rx, by, ty, spread) { return function () { var cxø1 = midpoint(lx, rx); var cyø1 = midpoint(by, ty); var bottomLeftø1 = heightmap[by * heightmap.resolution + lx]; var bottomRightø1 = heightmap[by * heightmap.resolution + rx]; var topLeftø1 = heightmap[ty * heightmap.resolution + lx]; var topRightø1 = heightmap[ty * heightmap.resolution + rx]; var topø1 = average2(topLeftø1, topRightø1); var leftø1 = average2(bottomLeftø1, topLeftø1); var bottomø1 = average2(bottomLeftø1, bottomRightø1); var rightø1 = average2(bottomRightø1, topRightø1); heightmap[by * heightmap.resolution + cxø1] = jitter(bottomø1, spread); heightmap[ty * heightmap.resolution + cxø1] = jitter(topø1, spread); heightmap[cyø1 * heightmap.resolution + lx] = jitter(leftø1, spread); return heightmap[cyø1 * heightmap.resolution + rx] = jitter(rightø1, spread); }.call(this); }; var midpointDisplacementD1 = exports.midpointDisplacementD1 = function midpointDisplacementD1(heightmap) { return mpdInitCorners(heightmap); }; var midpointDisplacementD2 = exports.midpointDisplacementD2 = function midpointDisplacementD2(heightmap) { mpdInitCorners(heightmap); return mpdDisplaceD2(heightmap, 0, heightmap.last, 0, heightmap.last, 0.1); }; var midpointDisplacementD3 = exports.midpointDisplacementD3 = function midpointDisplacementD3(heightmap) { mpdInitCorners(heightmap); return mpdDisplace(heightmap, 0, heightmap.last, 0, heightmap.last, 0.1); }; var makeDirectionalLight = exports.makeDirectionalLight = function makeDirectionalLight() { return function () { var lightø1 = new THREE.DirectionalLight(16777215, 1); lightø1.position.set(100, 0, 150); return lightø1; }.call(this); }; var makeCamera = exports.makeCamera = function makeCamera() { return function () { var cameraø1 = new THREE.PerspectiveCamera(55, width / height, 0.1, 1000); cameraø1.position.set(0, -100, 150); return cameraø1; }.call(this); }; var makeRenderer = exports.makeRenderer = function makeRenderer() { return function () { var rendererø1 = new THREE.WebGLRenderer({ 'antialias': false }); rendererø1.setClearColor(16777215); rendererø1.setSize(width, height); rendererø1.setPixelRatio(2); return rendererø1; }.call(this); }; var makeGeometry = exports.makeGeometry = function makeGeometry(heightmap) { return function () { var geometryø1 = new THREE.PlaneGeometry(terrainSize, terrainSize, heightmap.resolution - 1, heightmap.resolution - 1); geometryø1.dynamic = true; return geometryø1; }.call(this); }; var makeControls = exports.makeControls = function makeControls(camera, renderer) { return function () { var controlsø1 = new THREE.TrackballControls(camera, renderer.domElement); controlsø1.rotateSpeed = 1.4; controlsø1.zoomSpeed = 0.5; controlsø1.staticMoving = true; controlsø1.dynamicDampingFactor = 0.3; return controlsø1; }.call(this); }; var makePlane = exports.makePlane = function makePlane(geometry) { return function () { var materialø1 = new THREE.MeshLambertMaterial({ 'wireframe': wireframe, 'wireframeLinewidth': wireframeWidth, 'color': 47872 }); return new THREE.Mesh(geometry, materialø1); }.call(this); }; var attachToDom = exports.attachToDom = function attachToDom(renderer, elName, refreshFn) { return function () { var containerø1 = document.getElementById(elName); var settingsø1 = document.createElement('div'); var refreshButtonø1 = document.createElement('button'); var buttonTextø1 = document.createTextNode('Refresh'); var cancelScrollø1 = function (e) { return e.preventDefault(); }; refreshButtonø1.onclick = refreshFn; renderer.domElement.onmousewheel = cancelScrollø1; renderer.domElement.addEventListener('MozMousePixelScroll', cancelScrollø1, false); refreshButtonø1.appendChild(buttonTextø1); containerø1.appendChild(renderer.domElement); containerø1.appendChild(settingsø1); return settingsø1.appendChild(refreshButtonø1); }.call(this); }; var updateGeometry = exports.updateGeometry = function updateGeometry(geometry, heightmap) { (function () { var G__11ø1 = geometry.vertices.length; return function loop() { var recur = loop; var iø1 = 0; do { recur = iø1 < G__11ø1 ? (function () { geometry.vertices[iø1].z = terrainHeight * heightmap[iø1]; return loop[0] = 1 + iø1, loop; })() : void 0; } while (iø1 = loop[0], recur === loop); return recur; }.call(this); }.call(this)); geometry.verticesNeedUpdate = true; geometry.computeFaceNormals(); geometry.computeVertexNormals(); geometry.computeMorphNormals(); return geometry; }; var makeDemo = exports.makeDemo = function makeDemo(elementId, algorithm, size) { var scene = new THREE.Scene(); scene.add(new THREE.AxisHelper(100)); var clock = new THREE.Clock(); var camera = makeCamera(); var renderer = makeRenderer(); var geometry = makeGeometry(makeHeightmap(size)); scene.add(makeDirectionalLight()); scene.add(new THREE.AmbientLight(16777215, 0.05)); scene.add(makePlane(geometry)); var refresh = function refresh() { l('Refreshing ========================================'); return function () { var heightmapø1 = makeHeightmap(size); l('Generating terrain...'); (function () { var G__12ø1 = new Date().getTime(); var G__14ø1 = (function () { return algorithm(heightmapø1); })(); var G__13ø1 = new Date().getTime(); l('Elapsed time: ' + (G__13ø1 - G__12ø1) + 'ms.'); return G__14ø1; }.call(this)); l('Refreshing geometry...'); (function () { var G__15ø1 = new Date().getTime(); var G__17ø1 = (function () { return updateGeometry(geometry, heightmapø1); })(); var G__16ø1 = new Date().getTime(); l('Elapsed time: ' + (G__16ø1 - G__15ø1) + 'ms.'); return G__17ø1; }.call(this)); return l('Done!'); }.call(this); }; attachToDom(renderer, elementId, refresh); var controls = makeControls(camera, renderer); var render = function render() { return function () { var deltaø1 = clock.getDelta(); requestAnimationFrame(render); controls.update(deltaø1); return renderer.render(scene, camera); }.call(this); }; render(); return void 0; }; var makeFinal = exports.makeFinal = function makeFinal(elementId) { var scene = new THREE.Scene(); scene.add(new THREE.AxisHelper(100)); var clock = new THREE.Clock(); var camera = makeCamera(); var renderer = makeRenderer(); var heightmap = makeHeightmap($('#input-exponent').val()); var geometry = makeGeometry(heightmap); var plane = makePlane(geometry); scene.add(makeDirectionalLight()); scene.add(new THREE.AmbientLight(16777215, 0.05)); scene.add(plane); var refresh = function refresh() { l('Refreshing ========================================'); scene.remove(plane); heightmap = makeHeightmap($('#input-exponent').val()); geometry = makeGeometry(heightmap); plane = makePlane(geometry); scene.add(plane); l('Generating terrain...'); (function () { var G__18ø1 = new Date().getTime(); var G__20ø1 = (function () { return midpointDisplacementFinal(heightmap); })(); var G__19ø1 = new Date().getTime(); l('Elapsed time: ' + (G__19ø1 - G__18ø1) + 'ms.'); return G__20ø1; }.call(this)); l('Refreshing geometry...'); (function () { var G__21ø1 = new Date().getTime(); var G__23ø1 = (function () { return updateGeometry(geometry, heightmap); })(); var G__22ø1 = new Date().getTime(); l('Elapsed time: ' + (G__22ø1 - G__21ø1) + 'ms.'); return G__23ø1; }.call(this)); return l('Done!'); }; attachToDom(renderer, elementId, refresh); var controls = makeControls(camera, renderer); var render = function render() { return function () { var deltaø1 = clock.getDelta(); requestAnimationFrame(render); controls.update(deltaø1); return renderer.render(scene, camera); }.call(this); }; render(); return void 0; }; var run = exports.run = function run() { makeDemo('demo-random', randomNoise, 7); makeDemo('demo-mpd-1', midpointDisplacementD1, 2); makeDemo('demo-mpd-2', midpointDisplacementD2, 2); makeDemo('demo-mpd-3', midpointDisplacementD3, 2); makeDemo('demo-mpd-4', midpointDisplacement, 3); return makeFinal('demo-final'); }; $(run); },{}]},{},[1]) //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../usr/local/lib/node_modules/browserify/node_modules/browser-pack/_prelude.js","media/js/wisp/anonymous.wisp"],"names":[],"mappings":"AAAA;ACCA,IAAK,KAAA,GAAA,OAAA,CAAA,KAAA,GAAM,GAAX;AACA,IAAK,MAAA,GAAA,OAAA,CAAA,MAAA,GAAO,GAAZ,CADA;AAEA,IAAK,SAAA,GAAA,OAAA,CAAA,SAAA,G,IAAL,CAFA;AAGA,IAAK,cAAA,GAAA,OAAA,CAAA,cAAA,GAAgB,GAArB,CAHA;AAIA,IAAK,aAAA,GAAA,OAAA,CAAA,aAAA,GAAe,EAApB,CAJA;AAKA,IAAK,WAAA,GAAA,OAAA,CAAA,WAAA,GAAa,GAAlB,CALA;OAAA;OAAA;OAAA;OAAA;OAAA;OAAA;AA2CA,IAAM,CAAA,GAAA,OAAA,CAAA,CAAA,GAAN,SAAM,CAAN,CAAS,CAAT,EACE;AAAA,WAAC,OAAA,CAAQ,GAAT,CAAa,CAAb;AAAA,CADF,CA3CA;AA+CA,IAAM,QAAA,GAAA,OAAA,CAAA,QAAA,GAAN,SAAM,QAAN,CAAgB,CAAhB,EAAkB,CAAlB,EACE;AAAA,WAAG,CAAG,CAAH,GAAK,CAAL,CAAH,GAAW,CAAX;AAAA,CADF,CA/CA;AAkDA,IAAM,QAAA,GAAA,OAAA,CAAA,QAAA,GAAN,SAAM,QAAN,CAAgB,CAAhB,EAAkB,CAAlB,EACE;AAAA,WAAG,CAAG,CAAH,GAAK,CAAL,CAAH,GAAW,CAAX;AAAA,CADF,CAlDA;AAqDA,IAAM,QAAA,GAAA,OAAA,CAAA,QAAA,GAAN,SAAM,QAAN,CAAgB,CAAhB,EAAkB,CAAlB,EAAoB,CAApB,EAAsB,CAAtB,EACE;AAAA,WAAG,CAAG,C,GAAE,C,GAAE,CAAP,GAAS,CAAT,CAAH,GAAe,CAAf;AAAA,CADF,CArDA;AAwDA,IAAM,WAAA,GAAA,OAAA,CAAA,WAAA,GAAN,SAAM,WAAN,CAAoB,CAApB,EAAsB,CAAtB,EAAwB,CAAxB,EAA0B,CAA1B,EACE;AAAA,W,YAAM;AAAA,YAAA,O,GAAM,CAAN;AAAA,QAAQ,IAAA,O,GAAM,CAAN,CAAR;AAAA,QACE,CAAN,G,aAAQ;AAAA,YAAM,OAAN,GAAM,O,GAAM,CAAZ;AAAA,YAAe,OAAM,OAAN,GAAM,O,IAAN,CAAf;AAAA,S,CAAA,EAAR,G,MAAA,CADI;AAAA,QAEE,CAAN,G,aAAQ;AAAA,YAAM,OAAN,GAAM,O,GAAM,CAAZ;AAAA,YAAe,OAAM,OAAN,GAAM,O,IAAN,CAAf;AAAA,S,CAAA,EAAR,G,MAAA,CAFI;AAAA,QAGE,CAAN,G,aAAQ;AAAA,YAAM,OAAN,GAAM,O,GAAM,CAAZ;AAAA,YAAe,OAAM,OAAN,GAAM,O,IAAN,CAAf;AAAA,S,CAAA,EAAR,G,MAAA,CAHI;AAAA,QAIE,CAAN,G,aAAQ;AAAA,YAAM,OAAN,GAAM,O,GAAM,CAAZ;AAAA,YAAe,OAAM,OAAN,GAAM,O,IAAN,CAAf;AAAA,S,CAAA,EAAR,G,MAAA,CAJI;AAAA,QAKJ,OAAG,OAAH,GAAS,OAAT,CALI;AAAA,K,KAAN,C,IAAA;AAAA,CADF,CAxDA;AAiEA,IAAM,IAAA,GAAA,OAAA,CAAA,IAAA,GAAN,SAAM,IAAN,GACE;AAAA,WAAC,IAAA,CAAK,MAAN;AAAA,CADF,CAjEA;AAoEA,IAAM,cAAA,GAAA,OAAA,CAAA,cAAA,GAAN,SAAM,cAAN,CAAwB,MAAxB,EACE;AAAA,WAAM,M,GAAQ,IAAD,EAAV,GAAiB,CAApB,GAAuB,MAAvB;AAAA,CADF,CApEA;AAwEA,IAAM,MAAA,GAAA,OAAA,CAAA,MAAA,GAAN,SAAM,MAAN,CAAc,KAAd,EAAoB,MAApB,EACE;AAAA,WAAG,KAAH,GAAU,cAAD,CAAkB,MAAlB,CAAT;AAAA,CADF,CAxEA;OAAA;AAgFA,IAAM,gBAAA,GAAA,OAAA,CAAA,gBAAA,GAAN,SAAM,gBAAN,CAA0B,EAA1B,EAA6B,CAA7B,EAA+B,CAA/B,EACE;AAAA,WAAe,C,IAAE,CAAN,IAAM,C,IAAE,EAAA,CAAG,IAAhB,IACK,CAAI,C,IAAE,CAAN,IAAM,C,IAAE,EAAA,CAAG,IAAX,CADX,G,aAEE;AAAA,eAAe,EAAf,CAAoB,C,GAAL,E,cAAG,CAAlB;AAAA,K,CAAA,EAFF,G,MAAA;AAAA,CADF,CAhFA;OAAA;AAyFA,IAAM,SAAA,GAAA,OAAA,CAAA,SAAA,GAAN,SAAM,SAAN,CAAiB,EAAjB,EACE;AAAA,W,YAAM;AAAA,YAAA,K,IAAI,GAAG,QAAP;AAAA,QACA,IAAA,K,GAAI,QAAJ,CADA;AAAA,QAEJ,C;yBAAY,EAAA,CAAG,M;;;oBAAL,G;;4BAAA,G;wBACR,C,YAAM;AAAA,gCAAA,I,GAAS,EAAN,CAAS,GAAT,CAAH;AAAA,4BACK,KAAH,GAAO,IAAb,G,aAAiB;AAAA,uCAAM,KAAN,GAAU,IAAV;AAAA,6B,CAAA,EAAjB,G,MAAA,CADI;AAAA,4BAEJ,OAAS,KAAH,GAAO,IAAb,G,aAAiB;AAAA,uCAAM,KAAN,GAAU,IAAV;AAAA,6B,CAAA,EAAjB,G,MAAA,CAFI;AAAA,yB,KAAN,C,IAAA,G;6CADQ,G;;yBAAA,G;;;cAAV,C,IAAA,GAFI;AAAA,QAMJ,O,YAAM;AAAA,gBAAA,M,GAAQ,KAAH,GAAO,KAAZ;AAAA,YACJ,O;6BAAY,EAAA,CAAG,M;;;wBAAL,G;;gCAAA,G;4BACI,EAAN,CAAS,GAAT,CAAN,GACK,CAAS,EAAN,CAAS,GAAT,CAAH,GAAe,KAAf,CAAH,GACG,MAFL,C;iDADQ,G;;6BAAA,G;;;kBAAV,C,IAAA,EADI;AAAA,S,KAAN,C,IAAA,EANI;AAAA,K,KAAN,C,IAAA;AAAA,CADF,CAzFA;AAsGA,IAAM,aAAA,GAAA,OAAA,CAAA,aAAA,GAAN,SAAM,aAAN,CAAsB,SAAtB,EACE;AAAA,K;qBAAY,SAAA,CAAU,M;;;gBAAZ,G;;wBAAA,G;oBACI,SAAN,CAAgB,GAAhB,CAAN,GAAyB,CAAzB,C;yCADQ,G;;qBAAA,G;;;UAAV,C,IAAA;AAAA,IAEA,OAAA,SAAA,CAFA;AAAA,CADF,CAtGA;AA2GA,IAAM,aAAA,GAAA,OAAA,CAAA,aAAA,GAAN,SAAM,aAAN,CAAsB,QAAtB,EACE;AAAA,W,YAAM;AAAA,YAAA,Y,GAAc,CAAH,GAAM,IAAA,CAAK,GAAN,CAAU,CAAV,EAAY,QAAZ,CAAhB;AAAA,QACH,CAAD,CAAM,W,GAAY,Y,GAAW,M,GAAO,YAAjC,GAA4C,eAA/C,EADI;AAAA,QAEJ,IAAK,SAAA,GACH,IAAK,KAAL,CAAc,YAAH,GAAc,YAAzB,CADF,CAFI;AAAA,QAIE,SAAA,CAAU,UAAhB,GAA2B,YAA3B,CAJI;AAAA,QAKE,SAAA,CAAU,QAAhB,GAAyB,QAAzB,CALI;AAAA,QAME,SAAA,CAAU,IAAhB,GAAwB,YAAH,GAAc,CAAnC,CANI;AAAA,QAOJ,OAAC,aAAD,CAAgB,SAAhB,EAPI;AAAA,K,KAAN,C,IAAA;AAAA,CADF,CA3GA;AAuHA,IAAM,WAAA,GAAA,OAAA,CAAA,WAAA,GAAN,SAAM,WAAN,CAAoB,SAApB,EACE;AAAA,W;qBAAY,SAAA,CAAU,M;;;gBAAZ,G;;wBAAA,G;oBACI,SAAN,CAAgB,GAAhB,CAAN,GAA0B,IAAD,EAAzB,C;yCADQ,G;;qBAAA,G;;;UAAV,C,IAAA;AAAA,CADF,CAvHA;AA6HA,IAAM,cAAA,GAAA,OAAA,CAAA,cAAA,GAAN,SAAM,cAAN,CAAwB,SAAxB,EACE;AAAA,IAAgB,S,CAAY,C,GAAZ,S,cAAU,C,CAA1B,GAA+B,IAAD,EAA9B;AAAA,IACgB,S,CAAY,SAAA,CAAU,I,GAAtB,S,cAAU,C,CAA1B,GAA4C,IAAD,EAA3C,CADA;AAAA,IAEgB,S,CAAyB,C,GAAzB,S,cAAU,SAAA,CAAU,I,CAApC,GAA4C,IAAD,EAA3C,CAFA;AAAA,IAGA,OAAgB,S,CAAyB,SAAA,CAAU,I,GAAnC,S,cAAU,SAAA,CAAU,I,CAApC,GAAyD,IAAD,EAAxD,CAHA;AAAA,CADF,CA7HA;AAmIA,IAAM,WAAA,GAAA,OAAA,CAAA,WAAA,GAAN,SAAM,WAAN,CAAoB,SAApB,EAA8B,EAA9B,EAAiC,EAAjC,EAAoC,EAApC,EAAuC,EAAvC,EAA0C,MAA1C,EACE;AAAA,W,YAAM;AAAA,YAAA,I,GAAI,QAAD,CAAU,EAAV,EAAa,EAAb,CAAH;AAAA,QACA,IAAA,I,GAAI,QAAD,CAAU,EAAV,EAAa,EAAb,CAAH,CADA;AAAA,QAGA,IAAA,Y,GAA2B,SAAf,CAA4B,E,GAAb,S,cAAU,EAAzB,CAAZ,CAHA;AAAA,QAIA,IAAA,a,GAA4B,SAAf,CAA4B,E,GAAb,S,cAAU,EAAzB,CAAb,CAJA;AAAA,QAKA,IAAA,S,GAAwB,SAAf,CAA4B,E,GAAb,S,cAAU,EAAzB,CAAT,CALA;AAAA,QAMA,IAAA,U,GAAyB,SAAf,CAA4B,E,GAAb,S,cAAU,EAAzB,CAAV,CANA;AAAA,QAQA,IAAA,K,GAAK,QAAD,CAAU,SAAV,EAAmB,UAAnB,CAAJ,CARA;AAAA,QASA,IAAA,M,GAAM,QAAD,CAAU,YAAV,EAAsB,SAAtB,CAAL,CATA;AAAA,QAUA,IAAA,Q,GAAQ,QAAD,CAAU,YAAV,EAAsB,aAAtB,CAAP,CAVA;AAAA,QAWA,IAAA,O,GAAO,QAAD,CAAU,aAAV,EAAuB,UAAvB,CAAN,CAXA;AAAA,QAYA,IAAA,Q,GAAQ,QAAD,CAAU,KAAV,EAAc,MAAd,EAAmB,QAAnB,EAA0B,OAA1B,CAAP,CAZA;AAAA,QAaY,S,CAAa,E,GAAb,S,cAAU,I,CAA1B,GAAiC,MAAD,CAAQ,QAAR,EAAe,MAAf,CAAhC,CAbI;AAAA,QAcY,S,CAAa,E,GAAb,S,cAAU,I,CAA1B,GAAiC,MAAD,CAAQ,KAAR,EAAY,MAAZ,CAAhC,CAdI;AAAA,QAeY,S,CAAa,I,GAAb,S,cAAU,E,CAA1B,GAAiC,MAAD,CAAQ,MAAR,EAAa,MAAb,CAAhC,CAfI;AAAA,QAgBY,S,CAAa,I,GAAb,S,cAAU,E,CAA1B,GAAiC,MAAD,CAAQ,OAAR,EAAc,MAAd,CAAhC,CAhBI;AAAA,QAiBJ,OAAgB,S,CAAa,I,GAAb,S,cAAU,I,CAA1B,GAAiC,MAAD,CAAQ,QAAR,EAAe,MAAf,CAAhC,CAjBI;AAAA,K,KAAN,C,IAAA;AAAA,CADF,CAnIA;AAuJA,IAAM,oBAAA,GAAA,OAAA,CAAA,oBAAA,GAAN,SAAM,oBAAN,CAA6B,SAA7B,EACE;AAAA,IAAC,cAAD,CAAkB,SAAlB;AAAA,IAEA,C;;QAAO,IAAA,M,GAAK,CAAL,C;QACA,IAAA,Q,GAAO,GAAP,C;;oBACI,MAAH,GAAQ,SAAA,CAAU,QAAxB,G,aACE;AAAA,iB,YAAM;AAAA,wBAAA,Q,GAAQ,IAAA,CAAK,GAAN,CAAU,CAAV,EAAY,MAAZ,CAAP;AAAA,oBACA,IAAA,Y,GAAe,CAAG,SAAA,CAAU,UAAb,GAAwB,CAAxB,CAAH,GAA8B,QAA1C,CADA;AAAA,oBAEJ,O;qCAAyB,Q;;;;;oCAAd,Q;;4CAAA,Q;;;;;oDAAO,Q;;4DAAA,Q;wDAChB,C,YAAM;AAAA,gEAAA,O,GAAU,YAAH,GAAe,QAAtB;AAAA,4DACA,IAAA,Q,GAAW,OAAH,GAAU,YAAlB,CADA;AAAA,4DAEA,IAAA,S,GAAY,YAAH,GAAe,QAAxB,CAFA;AAAA,4DAGA,IAAA,M,GAAS,SAAH,GAAY,YAAlB,CAHA;AAAA,4DAIJ,OAAC,WAAD,CAAc,SAAd,EAAwB,OAAxB,EAA+B,QAA/B,EAAuC,SAAvC,EAAgD,MAAhD,EAAsD,QAAtD,EAJI;AAAA,yD,KAAN,C,IAAA,G;6EADgB,Q;;yDAAA,Q;;;;6DAAP,Q;;yCAAA,Q;;;;0BAAX,C,IAAA,EAFI;AAAA,iB,KAAN,C,IAAA;AAAA,gBAQA,O,UAAU,CAAH,GAAK,MAAZ,E,UAAqB,QAAH,GAAU,GAA5B,E,IAAA,CARA;AAAA,a,CAAA,EADF,G;iBAFK,M,YACA,Q;;UADP,C,IAAA,GAFA;AAAA,IAcA,OAAC,SAAD,CAAW,SAAX,EAdA;AAAA,CADF,CAvJA;AAyKA,IAAM,yBAAA,GAAA,OAAA,CAAA,yBAAA,GAAN,SAAM,yBAAN,CAAmC,SAAnC,EACE;AAAA,IAAC,cAAD,CAAkB,SAAlB;AAAA,IAEA,C;;QAAO,IAAA,M,GAAK,CAAL,C;QACA,IAAA,Q,GAAU,CAAH,GAAY,CAAD,CAAG,wBAAH,CAAL,CAAC,GAAF,EAAZ,C;;oBACI,MAAH,GAAQ,SAAA,CAAU,QAAxB,G,aACE;AAAA,iB,YAAM;AAAA,wBAAA,Q,GAAQ,IAAA,CAAK,GAAN,CAAU,CAAV,EAAY,MAAZ,CAAP;AAAA,oBACA,IAAA,Y,GAAe,CAAG,SAAA,CAAU,UAAb,GAAwB,CAAxB,CAAH,GAA8B,QAA1C,CADA;AAAA,oBAEJ,O;qCAAyB,Q;;;;;oCAAd,Q;;4CAAA,Q;;;;;oDAAO,Q;;4DAAA,Q;wDAChB,C,YAAM;AAAA,gEAAA,O,GAAU,YAAH,GAAe,QAAtB;AAAA,4DACA,IAAA,Q,GAAW,OAAH,GAAU,YAAlB,CADA;AAAA,4DAEA,IAAA,S,GAAY,YAAH,GAAe,QAAxB,CAFA;AAAA,4DAGA,IAAA,M,GAAS,SAAH,GAAY,YAAlB,CAHA;AAAA,4DAIJ,OAAC,WAAD,CAAc,SAAd,EAAwB,OAAxB,EAA+B,QAA/B,EAAuC,SAAvC,EAAgD,MAAhD,EAAsD,QAAtD,EAJI;AAAA,yD,KAAN,C,IAAA,G;6EADgB,Q;;yDAAA,Q;;;;6DAAP,Q;;yCAAA,Q;;;;0BAAX,C,IAAA,EAFI;AAAA,iB,KAAN,C,IAAA;AAAA,gBAQA,O,UAAU,CAAH,GAAK,MAAZ,E,UAAqB,QAAH,GACG,CAAG,CAAH,GAAY,CAAD,CAAG,yBAAH,CAAL,CAAC,GAAF,EAAL,CADrB,E,IAAA,CARA;AAAA,a,CAAA,EADF,G;iBAFK,M,YACA,Q;;UADP,C,IAAA,GAFA;AAAA,IAeA,OAAC,SAAD,CAAW,SAAX,EAfA;AAAA,CADF,CAzKA;AA4LA,IAAM,aAAA,GAAA,OAAA,CAAA,aAAA,GAAN,SAAM,aAAN,CAAuB,SAAvB,EAAiC,EAAjC,EAAoC,EAApC,EAAuC,EAAvC,EAA0C,EAA1C,EAA6C,MAA7C,EACE;AAAA,W,YAAM;AAAA,YAAA,I,GAAI,QAAD,CAAU,EAAV,EAAa,EAAb,CAAH;AAAA,QACA,IAAA,I,GAAI,QAAD,CAAU,EAAV,EAAa,EAAb,CAAH,CADA;AAAA,QAGA,IAAA,Y,GAA2B,SAAf,CAA4B,E,GAAb,S,cAAU,EAAzB,CAAZ,CAHA;AAAA,QAIA,IAAA,a,GAA4B,SAAf,CAA4B,E,GAAb,S,cAAU,EAAzB,CAAb,CAJA;AAAA,QAKA,IAAA,S,GAAwB,SAAf,CAA4B,E,GAAb,S,cAAU,EAAzB,CAAT,CALA;AAAA,QAMA,IAAA,U,GAAyB,SAAf,CAA4B,E,GAAb,S,cAAU,EAAzB,CAAV,CANA;AAAA,QAQA,IAAA,K,GAAK,QAAD,CAAU,SAAV,EAAmB,UAAnB,CAAJ,CARA;AAAA,QASA,IAAA,M,GAAM,QAAD,CAAU,YAAV,EAAsB,SAAtB,CAAL,CATA;AAAA,QAUA,IAAA,Q,GAAQ,QAAD,CAAU,YAAV,EAAsB,aAAtB,CAAP,CAVA;AAAA,QAWA,IAAA,O,GAAO,QAAD,CAAU,aAAV,EAAuB,UAAvB,CAAN,CAXA;AAAA,QAYY,S,CAAa,E,GAAb,S,cAAU,I,CAA1B,GAAiC,MAAD,CAAQ,QAAR,EAAe,MAAf,CAAhC,CAZI;AAAA,QAaY,S,CAAa,E,GAAb,S,cAAU,I,CAA1B,GAAiC,MAAD,CAAQ,KAAR,EAAY,MAAZ,CAAhC,CAbI;AAAA,QAcY,S,CAAa,I,GAAb,S,cAAU,E,CAA1B,GAAiC,MAAD,CAAQ,MAAR,EAAa,MAAb,CAAhC,CAdI;AAAA,QAeJ,OAAgB,S,CAAa,I,GAAb,S,cAAU,E,CAA1B,GAAiC,MAAD,CAAQ,OAAR,EAAc,MAAd,CAAhC,CAfI;AAAA,K,KAAN,C,IAAA;AAAA,CADF,CA5LA;AA8MA,IAAM,sBAAA,GAAA,OAAA,CAAA,sBAAA,GAAN,SAAM,sBAAN,CAAgC,SAAhC,EACE;AAAA,WAAC,cAAD,CAAkB,SAAlB;AAAA,CADF,CA9MA;AAiNA,IAAM,sBAAA,GAAA,OAAA,CAAA,sBAAA,GAAN,SAAM,sBAAN,CAAgC,SAAhC,EACE;AAAA,IAAC,cAAD,CAAkB,SAAlB;AAAA,IACA,OAAC,aAAD,CAAiB,SAAjB,EACiB,CADjB,EACmB,SAAA,CAAU,IAD7B,EAEiB,CAFjB,EAEmB,SAAA,CAAU,IAF7B,EAGiB,GAHjB,EADA;AAAA,CADF,CAjNA;AAwNA,IAAM,sBAAA,GAAA,OAAA,CAAA,sBAAA,GAAN,SAAM,sBAAN,CAAgC,SAAhC,EACE;AAAA,IAAC,cAAD,CAAkB,SAAlB;AAAA,IACA,OAAC,WAAD,CAAc,SAAd,EACc,CADd,EACgB,SAAA,CAAU,IAD1B,EAEc,CAFd,EAEgB,SAAA,CAAU,IAF1B,EAGc,GAHd,EADA;AAAA,CADF,CAxNA;AAkOA,IAAM,oBAAA,GAAA,OAAA,CAAA,oBAAA,GAAN,SAAM,oBAAN,GACE;AAAA,W,YAAM;AAAA,YAAA,O,GAAM,IAAK,KAAA,CAAM,gBAAX,CAA4B,QAA5B,EAAqC,CAArC,CAAN;AAAA,QACH,OAAA,CAAM,YAAP,CAAoB,GAApB,EAAwB,CAAxB,EAA0B,GAA1B,EADI;AAAA,QAEJ,OAAA,OAAA,CAFI;AAAA,K,KAAN,C,IAAA;AAAA,CADF,CAlOA;AAuOA,IAAM,UAAA,GAAA,OAAA,CAAA,UAAA,GAAN,SAAM,UAAN,GACE;AAAA,W,YAAM;AAAA,YAAA,Q,GAAO,IAAK,KAAA,CAAM,iBAAX,CACK,EADL,EAEQ,KAAH,GAAS,MAFd,EAGK,GAHL,EAIK,IAJL,CAAP;AAAA,QAKH,QAAA,CAAO,YAAR,CAAqB,CAArB,EAAuB,C,GAAvB,EAA4B,GAA5B,EALI;AAAA,QAMJ,OAAA,QAAA,CANI;AAAA,K,KAAN,C,IAAA;AAAA,CADF,CAvOA;AAgPA,IAAM,YAAA,GAAA,OAAA,CAAA,YAAA,GAAN,SAAM,YAAN,GACE;AAAA,W,YAAM;AAAA,YAAA,U,GAAS,IAAK,KAAA,CAAM,aAAX,CAAyB,E,kBAAA,EAAzB,CAAT;AAAA,QACH,UAAA,CAAS,aAAV,CAAwB,QAAxB,EADI;AAAA,QAEH,UAAA,CAAS,OAAV,CAAkB,KAAlB,EAAwB,MAAxB,EAFI;AAAA,QAGH,UAAA,CAAS,aAAV,CAAwB,CAAxB,EAHI;AAAA,QAIJ,OAAA,UAAA,CAJI;AAAA,K,KAAN,C,IAAA;AAAA,CADF,CAhPA;AAuPA,IAAM,YAAA,GAAA,OAAA,CAAA,YAAA,GAAN,SAAM,YAAN,CAAqB,SAArB,EACE;AAAA,W,YAAM;AAAA,YAAA,U,GAAS,IAAK,KAAA,CAAM,aAAX,CACK,WADL,EAEK,WAFL,EAGQ,SAAA,CAAU,UAAb,GAAwB,CAH7B,EAIQ,SAAA,CAAU,UAAb,GAAwB,CAJ7B,CAAT;AAAA,QAKE,UAAA,CAAS,OAAf,G,IAAA,CALI;AAAA,QAMJ,OAAA,UAAA,CANI;AAAA,K,KAAN,C,IAAA;AAAA,CADF,CAvPA;AAgQA,IAAM,YAAA,GAAA,OAAA,CAAA,YAAA,GAAN,SAAM,YAAN,CAAqB,MAArB,EAA4B,QAA5B,EACE;AAAA,W,YAAM;AAAA,YAAA,U,GAAS,IAAK,KAAA,CAAM,iBAAX,CAA6B,MAA7B,EAAoC,QAAA,CAAS,UAA7C,CAAT;AAAA,QACE,UAAA,CAAS,WAAf,GAA2B,GAA3B,CADI;AAAA,QAEE,UAAA,CAAS,SAAf,GAAyB,GAAzB,CAFI;AAAA,QAGE,UAAA,CAAS,YAAf,G,IAAA,CAHI;AAAA,QAIE,UAAA,CAAS,oBAAf,GAAoC,GAApC,CAJI;AAAA,QAKJ,OAAA,UAAA,CALI;AAAA,K,KAAN,C,IAAA;AAAA,CADF,CAhQA;AAwQA,IAAM,SAAA,GAAA,OAAA,CAAA,SAAA,GAAN,SAAM,SAAN,CAAkB,QAAlB,EACE;AAAA,W,YAAM;AAAA,YAAA,U,GAAS,IAAK,KAAA,CAAM,mBAAX,CACK;AAAA,Y,aAAY,SAAZ;AAAA,Y,sBACqB,cADrB;AAAA,Y,SAEQ,KAFR;AAAA,SADL,CAAT;AAAA,QAIJ,WAAK,KAAA,CAAM,IAAX,CAAgB,QAAhB,EAAyB,UAAzB,EAJI;AAAA,K,KAAN,C,IAAA;AAAA,CADF,CAxQA;AAgRA,IAAM,WAAA,GAAA,OAAA,CAAA,WAAA,GAAN,SAAM,WAAN,CAAqB,QAArB,EAA8B,MAA9B,EAAsC,SAAtC,EACE;AAAA,W,YAAM;AAAA,YAAA,W,GAAW,QAAA,CAAS,cAAV,CAAyB,MAAzB,CAAV;AAAA,QACA,IAAA,U,GAAU,QAAA,CAAS,aAAV,CAAwB,KAAxB,CAAT,CADA;AAAA,QAEA,IAAA,e,GAAgB,QAAA,CAAS,aAAV,CAAwB,QAAxB,CAAf,CAFA;AAAA,QAGA,IAAA,Y,GAAa,QAAA,CAAS,cAAV,CAAyB,SAAzB,CAAZ,CAHA;AAAA,QAIA,IAAA,c,GAAc,UAAK,CAAL,EAAQ;AAAA,mBAAiB,CAAhB,CAAC,cAAF;AAAA,SAAtB,CAJA;AAAA,QAKE,eAAA,CAAe,OAArB,GAA6B,SAA7B,CALI;AAAA,QAME,QAAA,CAAS,uBAAf,GAAuC,cAAvC,CANI;AAAA,QAOH,QAAA,CAAS,2BAAV,CAAsC,qBAAtC,EAA4D,cAA5D,E,KAAA,EAPI;AAAA,QAQU,eAAb,CAAC,WAAF,CAA6B,YAA7B,EARI;AAAA,QASU,WAAb,CAAC,WAAF,CAAwB,QAAA,CAAS,UAAjC,EATI;AAAA,QAUU,WAAb,CAAC,WAAF,CAAwB,UAAxB,EAVI;AAAA,QAWJ,OAAc,UAAb,CAAC,WAAF,CAAuB,eAAvB,EAXI;AAAA,K,KAAN,C,IAAA;AAAA,CADF,CAhRA;AA8RA,IAAM,cAAA,GAAA,OAAA,CAAA,cAAA,GAAN,SAAM,cAAN,CAAuB,QAAvB,EAAgC,SAAhC,EACE;AAAA,K;sBAAY,QAAA,CAAS,e;;;gBAAX,G;;wBAAA,G;oBACS,QAAA,CAAS,QAAf,CAAwB,GAAxB,CAAL,CAAG,CAAT,GACK,aAAH,GAAwB,SAAN,CAAgB,GAAhB,CADpB,C;yCADQ,G;;qBAAA,G;;;UAAV,C,IAAA;AAAA,IAGM,QAAA,CAAS,kBAAf,G,IAAA,CAHA;AAAA,IAIC,QAAA,CAAS,kBAAV,GAJA;AAAA,IAKC,QAAA,CAAS,oBAAV,GALA;AAAA,IAMC,QAAA,CAAS,mBAAV,GANA;AAAA,IAOA,OAAA,QAAA,CAPA;AAAA,CADF,CA9RA;AA0SA,IAAM,QAAA,GAAA,OAAA,CAAA,QAAA,GAAN,SAAM,QAAN,CAAiB,SAAjB,EAA4B,SAA5B,EAAsC,IAAtC,E;IACE,IAAK,KAAA,GAAM,IAAK,KAAA,CAAM,KAAX,EAAX,C;IACC,KAAA,CAAM,GAAP,CAAW,IAAK,KAAA,CAAM,UAAX,CAAsB,GAAtB,CAAX,E;IAEA,IAAK,KAAA,GAAM,IAAK,KAAA,CAAM,KAAX,EAAX,C;IACA,IAAK,MAAA,GAAQ,UAAD,EAAZ,C;IACA,IAAK,QAAA,GAAU,YAAD,EAAd,C;IACA,IAAK,QAAA,GAAU,YAAD,CAAgB,aAAD,CAAgB,IAAhB,CAAf,CAAd,C;IAEC,KAAA,CAAM,GAAP,CAAY,oBAAD,EAAX,E;IACC,KAAA,CAAM,GAAP,CAAW,IAAK,KAAA,CAAM,YAAX,CAAwB,QAAxB,EAAiC,IAAjC,CAAX,E;IACC,KAAA,CAAM,GAAP,CAAY,SAAD,CAAY,QAAZ,CAAX,E;IAEA,IAAM,OAAA,GAAN,SAAM,OAAN,GACE;AAAA,QAAC,CAAD,CAAG,qDAAH;AAAA,QACA,O,YAAM;AAAA,gBAAA,W,GAAW,aAAD,CAAgB,IAAhB,CAAV;AAAA,YACH,CAAD,CAAG,uBAAH,EADI;AAAA,YAEJ,C;;2CAAM;AAAA,2BAAC,SAAD,CAAW,WAAX;AAAA,iB,CAAA,E;;;;kBAAN,C,IAAA,GAFI;AAAA,YAGH,CAAD,CAAG,wBAAH,EAHI;AAAA,YAIJ,C;;2CAAM;AAAA,2BAAC,cAAD,CAAiB,QAAjB,EAA0B,WAA1B;AAAA,iB,CAAA,E;;;;kBAAN,C,IAAA,GAJI;AAAA,YAKJ,OAAC,CAAD,CAAG,OAAH,EALI;AAAA,S,KAAN,C,IAAA,EADA;AAAA,KADF,C;IASC,WAAD,CAAe,QAAf,EAAwB,SAAxB,EAAmC,OAAnC,E;IACA,IAAK,QAAA,GAAU,YAAD,CAAe,MAAf,EAAsB,QAAtB,CAAd,C;IAEA,IAAM,MAAA,GAAN,SAAM,MAAN,GACE;AAAA,e,YAAM;AAAA,gBAAA,O,GAAO,KAAA,CAAM,QAAP,EAAN;AAAA,YACH,qBAAD,CAAuB,MAAvB,EADI;AAAA,YAEK,QAAR,CAAC,MAAF,CAAkB,OAAlB,EAFI;AAAA,YAGJ,OAAC,QAAA,CAAS,MAAV,CAAiB,KAAjB,EAAuB,MAAvB,EAHI;AAAA,S,KAAN,C,IAAA;AAAA,KADF,C;IAMC,MAAD,G;;CA/BF,CA1SA;AA6UA,IAAM,SAAA,GAAA,OAAA,CAAA,SAAA,GAAN,SAAM,SAAN,CAAkB,SAAlB,E;IACE,IAAK,KAAA,GAAM,IAAK,KAAA,CAAM,KAAX,EAAX,C;IACC,KAAA,CAAM,GAAP,CAAW,IAAK,KAAA,CAAM,UAAX,CAAsB,GAAtB,CAAX,E;IAEA,IAAK,KAAA,GAAM,IAAK,KAAA,CAAM,KAAX,EAAX,C;IACA,IAAK,MAAA,GAAQ,UAAD,EAAZ,C;IACA,IAAK,QAAA,GAAU,YAAD,EAAd,C;IACA,IAAK,SAAA,GAAW,aAAD,CAAuB,CAAD,CAAG,iBAAH,CAAL,CAAC,GAAF,EAAhB,CAAf,C;IACA,IAAK,QAAA,GAAU,YAAD,CAAe,SAAf,CAAd,C;IACA,IAAK,KAAA,GAAO,SAAD,CAAY,QAAZ,CAAX,C;IAEC,KAAA,CAAM,GAAP,CAAY,oBAAD,EAAX,E;IACC,KAAA,CAAM,GAAP,CAAW,IAAK,KAAA,CAAM,YAAX,CAAwB,QAAxB,EAAiC,IAAjC,CAAX,E;IACC,KAAA,CAAM,GAAP,CAAW,KAAX,E;IAEA,IAAM,OAAA,GAAN,SAAM,OAAN,GACE;AAAA,QAAC,CAAD,CAAG,qDAAH;AAAA,QACC,KAAA,CAAM,MAAP,CAAc,KAAd,EADA;AAAA,QAEM,SAAN,GAAiB,aAAD,CAAuB,CAAD,CAAG,iBAAH,CAAL,CAAC,GAAF,EAAhB,CAAhB,CAFA;AAAA,QAGM,QAAN,GAAgB,YAAD,CAAe,SAAf,CAAf,CAHA;AAAA,QAIM,KAAN,GAAa,SAAD,CAAY,QAAZ,CAAZ,CAJA;AAAA,QAKC,KAAA,CAAM,GAAP,CAAW,KAAX,EALA;AAAA,QAMC,CAAD,CAAG,uBAAH,EANA;AAAA,QAOA,C;;uCAAM;AAAA,uBAAC,yBAAD,CAA6B,SAA7B;AAAA,a,CAAA,E;;;;cAAN,C,IAAA,GAPA;AAAA,QAQC,CAAD,CAAG,wBAAH,EARA;AAAA,QASA,C;;uCAAM;AAAA,uBAAC,cAAD,CAAiB,QAAjB,EAA0B,SAA1B;AAAA,a,CAAA,E;;;;cAAN,C,IAAA,GATA;AAAA,QAUA,OAAC,CAAD,CAAG,OAAH,EAVA;AAAA,KADF,C;IAaC,WAAD,CAAe,QAAf,EAAwB,SAAxB,EAAmC,OAAnC,E;IACA,IAAK,QAAA,GAAU,YAAD,CAAe,MAAf,EAAsB,QAAtB,CAAd,C;IAEA,IAAM,MAAA,GAAN,SAAM,MAAN,GACE;AAAA,e,YAAM;AAAA,gBAAA,O,GAAO,KAAA,CAAM,QAAP,EAAN;AAAA,YACH,qBAAD,CAAuB,MAAvB,EADI;AAAA,YAEK,QAAR,CAAC,MAAF,CAAkB,OAAlB,EAFI;AAAA,YAGJ,OAAC,QAAA,CAAS,MAAV,CAAiB,KAAjB,EAAuB,MAAvB,EAHI;AAAA,S,KAAN,C,IAAA;AAAA,KADF,C;IAMC,MAAD,G;;CArCF,CA7UA;AAuXA,IAAM,GAAA,GAAA,OAAA,CAAA,GAAA,GAAN,SAAM,GAAN,GACE;AAAA,IAAC,QAAD,CAAW,aAAX,EAAyB,WAAzB,EAAsC,CAAtC;AAAA,IACC,QAAD,CAAW,YAAX,EAAwB,sBAAxB,EAAiD,CAAjD,EADA;AAAA,IAEC,QAAD,CAAW,YAAX,EAAwB,sBAAxB,EAAiD,CAAjD,EAFA;AAAA,IAGC,QAAD,CAAW,YAAX,EAAwB,sBAAxB,EAAiD,CAAjD,EAHA;AAAA,IAIC,QAAD,CAAW,YAAX,EAAwB,oBAAxB,EAA8C,CAA9C,EAJA;AAAA,IAKA,OAAC,SAAD,CAAY,YAAZ,EALA;AAAA,CADF,CAvXA;AAmYC,CAAD,CAAG,GAAH","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","; Constants -------------------------------------------------------------------\n(def width 610)\n(def height 400)\n(def wireframe true)\n(def wireframe-width 1.2)\n(def terrain-height 50)\n(def terrain-size 100)\n\n; General Utilities -----------------------------------------------------------\n(defmacro when [condition & body]\n  `(if ~condition\n     (do ~@body)))\n\n(defmacro do-times [varname limit & body]\n  (let [end (gensym)]\n    `(let [~end ~limit]\n       (loop [~varname 0]\n         (when (< ~varname ~end)\n           ~@body\n           (recur (+ 1 ~varname)))))))\n\n(defmacro do-nested [xname yname width & body]\n  (let [iterations (gensym)]\n    `(let [~iterations ~width]\n       (do-times ~xname ~iterations\n         (do-times ~yname ~iterations\n           ~@body)))))\n\n(defmacro inc! [place]\n  `(set! ~place (+ ~place 1)))\n\n(defmacro add! [place amount]\n  `(set! ~place (+ ~place ~amount)))\n\n(defmacro time [& body]\n  (let [start (gensym)\n        end (gensym)\n        result (gensym)]\n    `(let [~start (.getTime (new Date))\n           ~result (do ~@body)\n           ~end (.getTime (new Date))]\n       (l (+ \"Elapsed time: \" (- ~end ~start) \"ms.\"))\n       ~result)))\n\n(defn l [v]\n  (console.log v))\n\n\n(defn midpoint [a b]\n  (/ (+ a b) 2))\n\n(defn average2 [a b]\n  (/ (+ a b) 2))\n\n(defn average4 [a b c d]\n  (/ (+ a b c d) 4))\n\n(defn safe-average [a b c d]\n  (let [total 0 count 0]\n    (when a (add! total a) (inc! count))\n    (when b (add! total b) (inc! count))\n    (when c (add! total c) (inc! count))\n    (when d (add! total d) (inc! count))\n    (/ total count)))\n\n\n(defn rand []\n  (Math.random))\n\n(defn rand-around-zero [spread]\n  (- (* spread (rand) 2) spread))\n\n\n(defn jitter [value spread]\n  (+ value (rand-around-zero spread)))\n\n\n; Heightmap Helpers -----------------------------------------------------------\n(defmacro heightmap-get [hm x y]\n  `(aget ~hm (+ (* ~y (.-resolution ~hm)) ~x)))\n\n(defn heightmap-get-safe [hm x y]\n  (when (and (<= 0 x hm.last)\n             (<= 0 y hm.last))\n    (heightmap-get hm x y)))\n\n(defmacro heightmap-set! [hm x y val]\n  `(set! (heightmap-get ~hm ~x ~y) ~val))\n\n\n(defn normalize [hm]\n  (let [max (- Infinity)\n        min Infinity]\n    (do-times i hm.length\n      (let [el (aget hm i)]\n        (when (< max el) (set! max el))\n        (when (> min el) (set! min el))))\n    (let [span (- max min)]\n      (do-times i hm.length\n        (set! (aget hm i)\n          (/ (- (aget hm i) min)\n             span))))))\n\n(defn zero-heightmap [heightmap]\n  (do-times i heightmap.length\n    (set! (aget heightmap i) 0.0))\n  heightmap)\n\n(defn make-heightmap [exponent]\n  (let [resolution (+ 1 (Math.pow 2 exponent))]\n    (l (+ \"Creating \" resolution \" by \" resolution \" heightmap...\"))\n    (def heightmap\n      (new Array (* resolution resolution)))\n    (set! heightmap.resolution resolution)\n    (set! heightmap.exponent exponent)\n    (set! heightmap.last (- resolution 1))\n    (zero-heightmap heightmap)))\n\n\n; Random Noise ----------------------------------------------------------------\n(defn random-noise [heightmap]\n  (do-times i heightmap.length\n    (set! (aget heightmap i) (rand))))\n\n\n; Midpoint Displacement -------------------------------------------------------\n(defn mpd-init-corners [heightmap]\n  (heightmap-set! heightmap 0 0 (rand))\n  (heightmap-set! heightmap 0 heightmap.last (rand))\n  (heightmap-set! heightmap heightmap.last 0 (rand))\n  (heightmap-set! heightmap heightmap.last heightmap.last (rand)))\n\n(defn mpd-displace [heightmap lx rx by ty spread]\n  (let [cx (midpoint lx rx)\n        cy (midpoint by ty)\n\n        bottom-left (heightmap-get heightmap lx by)\n        bottom-right (heightmap-get heightmap rx by)\n        top-left (heightmap-get heightmap lx ty)\n        top-right (heightmap-get heightmap rx ty)\n\n        top (average2 top-left top-right)\n        left (average2 bottom-left top-left)\n        bottom (average2 bottom-left bottom-right)\n        right (average2 bottom-right top-right)\n        center (average4 top left bottom right)]\n    (heightmap-set! heightmap cx by (jitter bottom spread))\n    (heightmap-set! heightmap cx ty (jitter top spread))\n    (heightmap-set! heightmap lx cy (jitter left spread))\n    (heightmap-set! heightmap rx cy (jitter right spread))\n    (heightmap-set! heightmap cx cy (jitter center spread))))\n\n(defn midpoint-displacement [heightmap]\n  (mpd-init-corners heightmap)\n  ; (mpd-displace heightmap 0 heightmap.last 0 heightmap.last 0.1)\n  (loop [iter 0\n         spread 0.3]\n    (when (< iter heightmap.exponent)\n      (let [chunks (Math.pow 2 iter)\n            chunk-width (/ (- heightmap.resolution 1) chunks)]\n        (do-nested xchunk ychunk chunks\n          (let [left-x (* chunk-width xchunk)\n                right-x (+ left-x chunk-width)\n                bottom-y (* chunk-width ychunk)\n                top-y (+ bottom-y chunk-width)]\n            (mpd-displace heightmap left-x right-x bottom-y top-y spread))))\n      (recur (+ 1 iter) (* spread 0.5))))\n  (normalize heightmap))\n\n\n(defn midpoint-displacement-final [heightmap]\n  (mpd-init-corners heightmap)\n  ; (let [spread ])\n  (loop [iter 0\n         spread (+ 0 (.val ($ \"#input-starting-spread\")))]\n    (when (< iter heightmap.exponent)\n      (let [chunks (Math.pow 2 iter)\n            chunk-width (/ (- heightmap.resolution 1) chunks)]\n        (do-nested xchunk ychunk chunks\n          (let [left-x (* chunk-width xchunk)\n                right-x (+ left-x chunk-width)\n                bottom-y (* chunk-width ychunk)\n                top-y (+ bottom-y chunk-width)]\n            (mpd-displace heightmap left-x right-x bottom-y top-y spread))))\n      (recur (+ 1 iter) (* spread\n                           (+ 0 (.val ($ \"#input-spread-reduction\")))))))\n  (normalize heightmap))\n\n\n(defn mpd-displace-d2 [heightmap lx rx by ty spread]\n  (let [cx (midpoint lx rx)\n        cy (midpoint by ty)\n\n        bottom-left (heightmap-get heightmap lx by)\n        bottom-right (heightmap-get heightmap rx by)\n        top-left (heightmap-get heightmap lx ty)\n        top-right (heightmap-get heightmap rx ty)\n\n        top (average2 top-left top-right)\n        left (average2 bottom-left top-left)\n        bottom (average2 bottom-left bottom-right)\n        right (average2 bottom-right top-right)]\n    (heightmap-set! heightmap cx by (jitter bottom spread))\n    (heightmap-set! heightmap cx ty (jitter top spread))\n    (heightmap-set! heightmap lx cy (jitter left spread))\n    (heightmap-set! heightmap rx cy (jitter right spread))))\n\n(defn midpoint-displacement-d1 [heightmap]\n  (mpd-init-corners heightmap))\n\n(defn midpoint-displacement-d2 [heightmap]\n  (mpd-init-corners heightmap)\n  (mpd-displace-d2 heightmap\n                   0 heightmap.last\n                   0 heightmap.last\n                   0.1))\n\n(defn midpoint-displacement-d3 [heightmap]\n  (mpd-init-corners heightmap)\n  (mpd-displace heightmap\n                0 heightmap.last\n                0 heightmap.last\n                0.1))\n\n\n\n; Three.js Helpers ------------------------------------------------------------\n(defn make-directional-light []\n  (let [light (new THREE.DirectionalLight 0xffffff 1)]\n    (light.position.set 100 0 150)\n    light))\n\n(defn make-camera []\n  (let [camera (new THREE.PerspectiveCamera\n                    55,\n                    (/ width height)\n                    0.1,\n                    1000)]\n    (camera.position.set 0 -100 150)\n    camera))\n\n(defn make-renderer []\n  (let [renderer (new THREE.WebGLRenderer {:antialias false})]\n    (renderer.setClearColor 0xffffff)\n    (renderer.setSize width height)\n    (renderer.setPixelRatio 2)\n    renderer))\n\n(defn make-geometry [heightmap]\n  (let [geometry (new THREE.PlaneGeometry\n                      terrain-size\n                      terrain-size\n                      (- heightmap.resolution 1)\n                      (- heightmap.resolution 1))]\n    (set! geometry.dynamic true)\n    geometry))\n\n(defn make-controls [camera renderer]\n  (let [controls (new THREE.TrackballControls camera renderer.domElement)]\n    (set! controls.rotateSpeed 1.4)\n    (set! controls.zoomSpeed 0.5)\n    (set! controls.staticMoving true)\n    (set! controls.dynamicDampingFactor 0.3)\n    controls))\n\n(defn make-plane [geometry]\n  (let [material (new THREE.MeshLambertMaterial\n                      {:wireframe wireframe\n                       :wireframeLinewidth wireframe-width\n                       :color 0x00bb00})]\n    (new THREE.Mesh geometry material)))\n\n\n(defn attach-to-dom [renderer el-name refresh-fn]\n  (let [container (document.getElementById el-name)\n        settings (document.createElement \"div\")\n        refresh-button (document.createElement \"button\")\n        button-text (document.createTextNode \"Refresh\")\n        cancel-scroll (fn [e] (.preventDefault e))]\n    (set! refresh-button.onclick refresh-fn)\n    (set! renderer.domElement.onmousewheel cancel-scroll)\n    (renderer.domElement.addEventListener \"MozMousePixelScroll\" cancel-scroll false)\n    (.appendChild refresh-button button-text)\n    (.appendChild container renderer.domElement)\n    (.appendChild container settings)\n    (.appendChild settings refresh-button)))\n\n(defn update-geometry [geometry heightmap]\n  (do-times i geometry.vertices.length\n    (set! (.-z (aget geometry.vertices i))\n      (* terrain-height (aget heightmap i))))\n  (set! geometry.verticesNeedUpdate true)\n  (geometry.computeFaceNormals)\n  (geometry.computeVertexNormals)\n  (geometry.computeMorphNormals)\n  geometry)\n\n\n; Main ------------------------------------------------------------------------\n(defn make-demo [element-id algorithm size]\n  (def scene (new THREE.Scene))\n  (scene.add (new THREE.AxisHelper 100))\n\n  (def clock (new THREE.Clock))\n  (def camera (make-camera))\n  (def renderer (make-renderer))\n  (def geometry (make-geometry (make-heightmap size)))\n\n  (scene.add (make-directional-light))\n  (scene.add (new THREE.AmbientLight 0xffffff 0.05))\n  (scene.add (make-plane geometry))\n\n  (defn refresh []\n    (l \"Refreshing ========================================\")\n    (let [heightmap (make-heightmap size)]\n      (l \"Generating terrain...\")\n      (time (algorithm heightmap))\n      (l \"Refreshing geometry...\")\n      (time (update-geometry geometry heightmap))\n      (l \"Done!\")))\n\n  (attach-to-dom renderer element-id refresh)\n  (def controls (make-controls camera renderer))\n\n  (defn render []\n    (let [delta (clock.getDelta)]\n      (requestAnimationFrame render)\n      (.update controls delta)\n      (renderer.render scene camera)))\n\n  (render)\n\n  nil)\n\n(defn make-final [element-id]\n  (def scene (new THREE.Scene))\n  (scene.add (new THREE.AxisHelper 100))\n\n  (def clock (new THREE.Clock))\n  (def camera (make-camera))\n  (def renderer (make-renderer))\n  (def heightmap (make-heightmap (.val ($ \"#input-exponent\"))))\n  (def geometry (make-geometry heightmap))\n  (def plane (make-plane geometry))\n\n  (scene.add (make-directional-light))\n  (scene.add (new THREE.AmbientLight 0xffffff 0.05))\n  (scene.add plane)\n\n  (defn refresh []\n    (l \"Refreshing ========================================\")\n    (scene.remove plane)\n    (set! heightmap (make-heightmap (.val ($ \"#input-exponent\"))))\n    (set! geometry (make-geometry heightmap))\n    (set! plane (make-plane geometry))\n    (scene.add plane)\n    (l \"Generating terrain...\")\n    (time (midpoint-displacement-final heightmap))\n    (l \"Refreshing geometry...\")\n    (time (update-geometry geometry heightmap))\n    (l \"Done!\"))\n\n  (attach-to-dom renderer element-id refresh)\n  (def controls (make-controls camera renderer))\n\n  (defn render []\n    (let [delta (clock.getDelta)]\n      (requestAnimationFrame render)\n      (.update controls delta)\n      (renderer.render scene camera)))\n\n  (render)\n\n  nil)\n\n\n(defn run []\n  (make-demo \"demo-random\" random-noise 7)\n  (make-demo \"demo-mpd-1\" midpoint-displacement-d1 2)\n  (make-demo \"demo-mpd-2\" midpoint-displacement-d2 2)\n  (make-demo \"demo-mpd-3\" midpoint-displacement-d3 2)\n  (make-demo \"demo-mpd-4\" midpoint-displacement 3)\n  (make-final \"demo-final\")\n  ; (make-demo \"demo-midpoint\" midpoint-displacement)\n  ; (make-demo \"demo-diamond\" diamond-square)\n\n  )\n\n($ run)\n\n\n; vim: lw+=do-times lw+=do-nested :\n"]}