static/js/terrain/terrain2.js @ 578872d23f06 default tip

Links
author Steve Losh <steve@stevelosh.com>
date Mon, 09 Sep 2024 10:31:31 -0400
parents d20bad4b886f
children (none)
(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})({1:[function(require,module,exports){
{
    var _ns_ = {
        id: 'demo',
        doc: void 0
    };
    var ndarray = require('ndarray');
}
var width = exports.width = 676;
var height = exports.height = 400;
var wireframe = exports.wireframe = true;
var wireframeWidth = exports.wireframeWidth = 1.2;
var terrainHeight = exports.terrainHeight = 50;
var terrainSize = exports.terrainSize = 100;
void 0;
void 0;
void 0;
var inc = exports.inc = function inc(x) {
    return x + 1;
};
var dec = exports.dec = function dec(x) {
    return x - 1;
};
void 0;
void 0;
void 0;
void 0;
void 0;
void 0;
void 0;
void 0;
var midpoint = exports.midpoint = function midpoint(a, b) {
    return (a + b) / 2;
};
var average2 = exports.average2 = function average2(a, b) {
    return (a + b) / 2;
};
var average4 = exports.average4 = function average4(a, b, c, d) {
    return (a + b + c + d) / 4;
};
var safeAverage = exports.safeAverage = function safeAverage(a, b, c, d) {
    return function () {
        var totalø1 = 0;
        var countø1 = 0;
        a ? (function () {
            totalø1 = totalø1 + a;
            return countø1 = inc(countø1);
        })() : void 0;
        b ? (function () {
            totalø1 = totalø1 + b;
            return countø1 = inc(countø1);
        })() : void 0;
        c ? (function () {
            totalø1 = totalø1 + c;
            return countø1 = inc(countø1);
        })() : void 0;
        d ? (function () {
            totalø1 = totalø1 + d;
            return countø1 = inc(countø1);
        })() : void 0;
        return totalø1 / countø1;
    }.call(this);
};
var rand = exports.rand = function rand() {
    return Math.random();
};
var randAroundZero = exports.randAroundZero = function randAroundZero(spread) {
    return spread * rand() * 2 - spread;
};
var jitter = exports.jitter = function jitter(value, spread) {
    return value + randAroundZero(spread);
};
var heightmapResolution = exports.heightmapResolution = function heightmapResolution(heightmap) {
    return heightmap.shape[0];
};
var heightmapLastIndex = exports.heightmapLastIndex = function heightmapLastIndex(heightmap) {
    return dec(heightmapResolution(heightmap));
};
var heightmapCenterIndex = exports.heightmapCenterIndex = function heightmapCenterIndex(heightmap) {
    return midpoint(0, heightmapLastIndex(heightmap));
};
var heightmapGet = exports.heightmapGet = function heightmapGet(heightmap, x, y) {
    return heightmap.get(x, y);
};
var heightmapGetSafe = exports.heightmapGetSafe = function heightmapGetSafe(heightmap, x, y) {
    return function () {
        var lastø1 = heightmapLastIndex(heightmap);
        return 0 <= x && x <= lastø1 && (0 <= y && y <= lastø1) ? (function () {
            return heightmapGet(heightmap, x, y);
        })() : void 0;
    }.call(this);
};
var heightmapSet = exports.heightmapSet = function heightmapSet(heightmap, x, y, val) {
    return heightmap.set(x, y, val);
};
var heightmapSetIfUnset = exports.heightmapSetIfUnset = function heightmapSetIfUnset(heightmap, x, y, val) {
    return 0 == heightmapGet(heightmap, x, y) ? (function () {
        return heightmapSet(heightmap, x, y, val);
    })() : void 0;
};
var normalize = exports.normalize = function normalize(heightmap) {
    return function () {
        var maxø1 = 0 - Infinity;
        var minø1 = Infinity;
        (function () {
            var array2ø1 = heightmap;
            return function () {
                var G__3ø1 = array2ø1.data.length;
                return function loop() {
                    var recur = loop;
                    var index1ø1 = 0;
                    do {
                        recur = index1ø1 < G__3ø1 ? (function () {
                            (function () {
                                var elø1 = array2ø1.data[index1ø1];
                                maxø1 < elø1 ? (function () {
                                    return maxø1 = elø1;
                                })() : void 0;
                                return minø1 > elø1 ? (function () {
                                    return minø1 = elø1;
                                })() : void 0;
                            }.call(this));
                            return loop[0] = inc(index1ø1), loop;
                        })() : void 0;
                    } while (index1ø1 = loop[0], recur === loop);
                    return recur;
                }.call(this);
            }.call(this);
        }.call(this));
        return function () {
            var spanø1 = maxø1 - minø1;
            return function () {
                var array4ø1 = heightmap;
                return function () {
                    var G__5ø1 = array4ø1.shape[0];
                    return function loop() {
                        var recur = loop;
                        var xø1 = 0;
                        do {
                            recur = xø1 < G__5ø1 ? (function () {
                                (function () {
                                    var G__6ø1 = array4ø1.shape[1];
                                    return function loop() {
                                        var recur = loop;
                                        var yø1 = 0;
                                        do {
                                            recur = yø1 < G__6ø1 ? (function () {
                                                (function () {
                                                    return heightmapSet(heightmap, xø1, yø1, (heightmapGet(heightmap, xø1, yø1) - minø1) / spanø1);
                                                })();
                                                return loop[0] = inc(yø1), loop;
                                            })() : void 0;
                                        } while (yø1 = loop[0], recur === loop);
                                        return recur;
                                    }.call(this);
                                }.call(this));
                                return loop[0] = inc(xø1), loop;
                            })() : void 0;
                        } while (xø1 = loop[0], recur === loop);
                        return recur;
                    }.call(this);
                }.call(this);
            }.call(this);
        }.call(this);
    }.call(this);
};
var makeHeightmap = exports.makeHeightmap = function makeHeightmap(exponent) {
    return function () {
        var resolutionø1 = Math.pow(2, exponent) + 1;
        return function () {
            var heightmapø1 = ndarray(new Float64Array(resolutionø1 * resolutionø1), [
                resolutionø1,
                resolutionø1
            ]);
            heightmapø1.exponent = exponent;
            heightmapø1.resolution = resolutionø1;
            heightmapø1.last = dec(resolutionø1);
            return heightmapø1;
        }.call(this);
    }.call(this);
};
var topLeftCorner = exports.topLeftCorner = function topLeftCorner(heightmap) {
    return function () {
        var centerø1 = heightmapCenterIndex(heightmap);
        return heightmap.lo(0, 0).hi(inc(centerø1), inc(centerø1));
    }.call(this);
};
var topRightCorner = exports.topRightCorner = function topRightCorner(heightmap) {
    return function () {
        var centerø1 = heightmapCenterIndex(heightmap);
        return heightmap.lo(centerø1, 0).hi(inc(centerø1), inc(centerø1));
    }.call(this);
};
var bottomLeftCorner = exports.bottomLeftCorner = function bottomLeftCorner(heightmap) {
    return function () {
        var centerø1 = heightmapCenterIndex(heightmap);
        return heightmap.lo(0, centerø1).hi(inc(centerø1), inc(centerø1));
    }.call(this);
};
var bottomRightCorner = exports.bottomRightCorner = function bottomRightCorner(heightmap) {
    return function () {
        var centerø1 = heightmapCenterIndex(heightmap);
        return heightmap.lo(centerø1, centerø1).hi(inc(centerø1), inc(centerø1));
    }.call(this);
};
var mpdInitCorners = exports.mpdInitCorners = function mpdInitCorners(heightmap) {
    return function () {
        var lastø1 = heightmapLastIndex(heightmap);
        heightmapSet(heightmap, 0, 0, rand());
        heightmapSet(heightmap, 0, lastø1, rand());
        heightmapSet(heightmap, lastø1, 0, rand());
        return heightmapSet(heightmap, lastø1, lastø1, rand());
    }.call(this);
};
var mpdDisplace = exports.mpdDisplace = function mpdDisplace(heightmap, spread, spreadReduction) {
    return function () {
        var lastø1 = heightmapLastIndex(heightmap);
        var cø1 = midpoint(0, lastø1);
        var bottomLeftø1 = heightmapGet(heightmap, 0, 0);
        var bottomRightø1 = heightmapGet(heightmap, lastø1, 0);
        var topLeftø1 = heightmapGet(heightmap, 0, lastø1);
        var topRightø1 = heightmapGet(heightmap, lastø1, lastø1);
        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);
        var nextSpreadø1 = spread * spreadReduction;
        heightmapSetIfUnset(heightmap, cø1, 0, jitter(bottomø1, spread));
        heightmapSetIfUnset(heightmap, cø1, lastø1, jitter(topø1, spread));
        heightmapSetIfUnset(heightmap, 0, cø1, jitter(leftø1, spread));
        heightmapSetIfUnset(heightmap, lastø1, cø1, jitter(rightø1, spread));
        heightmapSetIfUnset(heightmap, cø1, cø1, jitter(centerø1, spread));
        return !(3 == heightmapResolution(heightmap)) ? (function () {
            heightmapSetIfUnset(heightmap, cø1, 0, jitter(bottomø1, spread));
            heightmapSetIfUnset(heightmap, cø1, lastø1, jitter(topø1, spread));
            heightmapSetIfUnset(heightmap, 0, cø1, jitter(leftø1, spread));
            heightmapSetIfUnset(heightmap, lastø1, cø1, jitter(rightø1, spread));
            heightmapSetIfUnset(heightmap, cø1, cø1, jitter(centerø1, spread));
            mpdDisplace(topLeftCorner(heightmap), nextSpreadø1, spreadReduction);
            mpdDisplace(topRightCorner(heightmap), nextSpreadø1, spreadReduction);
            mpdDisplace(bottomLeftCorner(heightmap), nextSpreadø1, spreadReduction);
            return mpdDisplace(bottomRightCorner(heightmap), nextSpreadø1, spreadReduction);
        })() : void 0;
    }.call(this);
};
var midpointDisplacement = exports.midpointDisplacement = function midpointDisplacement(heightmap) {
    return function () {
        var initialSpreadø1 = 0.3;
        var spreadReductionø1 = 0.55;
        mpdInitCorners(heightmap);
        mpdDisplace(heightmap, initialSpreadø1, spreadReductionø1);
        return normalize(heightmap);
    }.call(this);
};
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 resolutionø1 = heightmap.shape[0];
        var geometryø1 = new THREE.PlaneGeometry(terrainSize, terrainSize, resolutionø1 - 1, resolutionø1 - 1);
        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 loop() {
        var recur = loop;
        var iø1 = 0;
        do {
            recur = iø1 < geometry.vertices.length ? (function () {
                geometry.vertices[iø1].z = terrainHeight * heightmap.data[iø1];
                return loop[0] = iø1 + 1, loop;
            })() : void 0;
        } while (iø1 = loop[0], recur === loop);
        return recur;
    }.call(this));
    geometry.computeVertexNormals();
    return geometry;
};
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 geometry = void 0;
    var plane = void 0;
    scene.add(makeDirectionalLight());
    scene.add(new THREE.AmbientLight(16777215, 0.05));
    var refresh = function refresh() {
        return function () {
            var heightmapø1 = makeHeightmap(6);
            console.log('Generating terrain...');
            (function () {
                var G__7ø1 = new Date().getTime();
                var G__9ø1 = (function () {
                    return midpointDisplacement(heightmapø1);
                })();
                var G__8ø1 = new Date().getTime();
                console.log('Elapsed time: ' + (G__8ø1 - G__7ø1) + 'ms.');
                return G__9ø1;
            }.call(this));
            console.log('Rebuilding geometry...');
            (function () {
                var G__10ø1 = new Date().getTime();
                var G__12ø1 = (function () {
                    geometry = makeGeometry(heightmapø1);
                    return updateGeometry(geometry, heightmapø1);
                })();
                var G__11ø1 = new Date().getTime();
                console.log('Elapsed time: ' + (G__11ø1 - G__10ø1) + 'ms.');
                return G__12ø1;
            }.call(this));
            console.log('Rebuilding plane...');
            return function () {
                var G__13ø1 = new Date().getTime();
                var G__15ø1 = (function () {
                    scene.remove(plane);
                    plane = makePlane(geometry);
                    return scene.add(plane);
                })();
                var G__14ø1 = new Date().getTime();
                console.log('Elapsed time: ' + (G__14ø1 - G__13ø1) + 'ms.');
                return G__15ø1;
            }.call(this);
        }.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);
    };
    refresh();
    render();
    return void 0;
};
var run = exports.run = function run() {
    return makeFinal('demo-final');
};
$(run);


},{"ndarray":4}],2:[function(require,module,exports){
"use strict"

function iota(n) {
  var result = new Array(n)
  for(var i=0; i<n; ++i) {
    result[i] = i
  }
  return result
}

module.exports = iota
},{}],3:[function(require,module,exports){
/**
 * Determine if an object is Buffer
 *
 * Author:   Feross Aboukhadijeh <feross@feross.org> <http://feross.org>
 * License:  MIT
 *
 * `npm install is-buffer`
 */

module.exports = function (obj) {
  return !!(obj != null &&
    (obj._isBuffer || // For Safari 5-7 (missing Object.prototype.constructor)
      (obj.constructor &&
      typeof obj.constructor.isBuffer === 'function' &&
      obj.constructor.isBuffer(obj))
    ))
}

},{}],4:[function(require,module,exports){
var iota = require("iota-array")
var isBuffer = require("is-buffer")

var hasTypedArrays  = ((typeof Float64Array) !== "undefined")

function compare1st(a, b) {
  return a[0] - b[0]
}

function order() {
  var stride = this.stride
  var terms = new Array(stride.length)
  var i
  for(i=0; i<terms.length; ++i) {
    terms[i] = [Math.abs(stride[i]), i]
  }
  terms.sort(compare1st)
  var result = new Array(terms.length)
  for(i=0; i<result.length; ++i) {
    result[i] = terms[i][1]
  }
  return result
}

function compileConstructor(dtype, dimension) {
  var className = ["View", dimension, "d", dtype].join("")
  if(dimension < 0) {
    className = "View_Nil" + dtype
  }
  var useGetters = (dtype === "generic")

  if(dimension === -1) {
    //Special case for trivial arrays
    var code =
      "function "+className+"(a){this.data=a;};\
var proto="+className+".prototype;\
proto.dtype='"+dtype+"';\
proto.index=function(){return -1};\
proto.size=0;\
proto.dimension=-1;\
proto.shape=proto.stride=proto.order=[];\
proto.lo=proto.hi=proto.transpose=proto.step=\
function(){return new "+className+"(this.data);};\
proto.get=proto.set=function(){};\
proto.pick=function(){return null};\
return function construct_"+className+"(a){return new "+className+"(a);}"
    var procedure = new Function(code)
    return procedure()
  } else if(dimension === 0) {
    //Special case for 0d arrays
    var code =
      "function "+className+"(a,d) {\
this.data = a;\
this.offset = d\
};\
var proto="+className+".prototype;\
proto.dtype='"+dtype+"';\
proto.index=function(){return this.offset};\
proto.dimension=0;\
proto.size=1;\
proto.shape=\
proto.stride=\
proto.order=[];\
proto.lo=\
proto.hi=\
proto.transpose=\
proto.step=function "+className+"_copy() {\
return new "+className+"(this.data,this.offset)\
};\
proto.pick=function "+className+"_pick(){\
return TrivialArray(this.data);\
};\
proto.valueOf=proto.get=function "+className+"_get(){\
return "+(useGetters ? "this.data.get(this.offset)" : "this.data[this.offset]")+
"};\
proto.set=function "+className+"_set(v){\
return "+(useGetters ? "this.data.set(this.offset,v)" : "this.data[this.offset]=v")+"\
};\
return function construct_"+className+"(a,b,c,d){return new "+className+"(a,d)}"
    var procedure = new Function("TrivialArray", code)
    return procedure(CACHED_CONSTRUCTORS[dtype][0])
  }

  var code = ["'use strict'"]

  //Create constructor for view
  var indices = iota(dimension)
  var args = indices.map(function(i) { return "i"+i })
  var index_str = "this.offset+" + indices.map(function(i) {
        return "this.stride[" + i + "]*i" + i
      }).join("+")
  var shapeArg = indices.map(function(i) {
      return "b"+i
    }).join(",")
  var strideArg = indices.map(function(i) {
      return "c"+i
    }).join(",")
  code.push(
    "function "+className+"(a," + shapeArg + "," + strideArg + ",d){this.data=a",
      "this.shape=[" + shapeArg + "]",
      "this.stride=[" + strideArg + "]",
      "this.offset=d|0}",
    "var proto="+className+".prototype",
    "proto.dtype='"+dtype+"'",
    "proto.dimension="+dimension)

  //view.size:
  code.push("Object.defineProperty(proto,'size',{get:function "+className+"_size(){\
return "+indices.map(function(i) { return "this.shape["+i+"]" }).join("*"),
"}})")

  //view.order:
  if(dimension === 1) {
    code.push("proto.order=[0]")
  } else {
    code.push("Object.defineProperty(proto,'order',{get:")
    if(dimension < 4) {
      code.push("function "+className+"_order(){")
      if(dimension === 2) {
        code.push("return (Math.abs(this.stride[0])>Math.abs(this.stride[1]))?[1,0]:[0,1]}})")
      } else if(dimension === 3) {
        code.push(
"var s0=Math.abs(this.stride[0]),s1=Math.abs(this.stride[1]),s2=Math.abs(this.stride[2]);\
if(s0>s1){\
if(s1>s2){\
return [2,1,0];\
}else if(s0>s2){\
return [1,2,0];\
}else{\
return [1,0,2];\
}\
}else if(s0>s2){\
return [2,0,1];\
}else if(s2>s1){\
return [0,1,2];\
}else{\
return [0,2,1];\
}}})")
      }
    } else {
      code.push("ORDER})")
    }
  }

  //view.set(i0, ..., v):
  code.push(
"proto.set=function "+className+"_set("+args.join(",")+",v){")
  if(useGetters) {
    code.push("return this.data.set("+index_str+",v)}")
  } else {
    code.push("return this.data["+index_str+"]=v}")
  }

  //view.get(i0, ...):
  code.push("proto.get=function "+className+"_get("+args.join(",")+"){")
  if(useGetters) {
    code.push("return this.data.get("+index_str+")}")
  } else {
    code.push("return this.data["+index_str+"]}")
  }

  //view.index:
  code.push(
    "proto.index=function "+className+"_index(", args.join(), "){return "+index_str+"}")

  //view.hi():
  code.push("proto.hi=function "+className+"_hi("+args.join(",")+"){return new "+className+"(this.data,"+
    indices.map(function(i) {
      return ["(typeof i",i,"!=='number'||i",i,"<0)?this.shape[", i, "]:i", i,"|0"].join("")
    }).join(",")+","+
    indices.map(function(i) {
      return "this.stride["+i + "]"
    }).join(",")+",this.offset)}")

  //view.lo():
  var a_vars = indices.map(function(i) { return "a"+i+"=this.shape["+i+"]" })
  var c_vars = indices.map(function(i) { return "c"+i+"=this.stride["+i+"]" })
  code.push("proto.lo=function "+className+"_lo("+args.join(",")+"){var b=this.offset,d=0,"+a_vars.join(",")+","+c_vars.join(","))
  for(var i=0; i<dimension; ++i) {
    code.push(
"if(typeof i"+i+"==='number'&&i"+i+">=0){\
d=i"+i+"|0;\
b+=c"+i+"*d;\
a"+i+"-=d}")
  }
  code.push("return new "+className+"(this.data,"+
    indices.map(function(i) {
      return "a"+i
    }).join(",")+","+
    indices.map(function(i) {
      return "c"+i
    }).join(",")+",b)}")

  //view.step():
  code.push("proto.step=function "+className+"_step("+args.join(",")+"){var "+
    indices.map(function(i) {
      return "a"+i+"=this.shape["+i+"]"
    }).join(",")+","+
    indices.map(function(i) {
      return "b"+i+"=this.stride["+i+"]"
    }).join(",")+",c=this.offset,d=0,ceil=Math.ceil")
  for(var i=0; i<dimension; ++i) {
    code.push(
"if(typeof i"+i+"==='number'){\
d=i"+i+"|0;\
if(d<0){\
c+=b"+i+"*(a"+i+"-1);\
a"+i+"=ceil(-a"+i+"/d)\
}else{\
a"+i+"=ceil(a"+i+"/d)\
}\
b"+i+"*=d\
}")
  }
  code.push("return new "+className+"(this.data,"+
    indices.map(function(i) {
      return "a" + i
    }).join(",")+","+
    indices.map(function(i) {
      return "b" + i
    }).join(",")+",c)}")

  //view.transpose():
  var tShape = new Array(dimension)
  var tStride = new Array(dimension)
  for(var i=0; i<dimension; ++i) {
    tShape[i] = "a[i"+i+"]"
    tStride[i] = "b[i"+i+"]"
  }
  code.push("proto.transpose=function "+className+"_transpose("+args+"){"+
    args.map(function(n,idx) { return n + "=(" + n + "===undefined?" + idx + ":" + n + "|0)"}).join(";"),
    "var a=this.shape,b=this.stride;return new "+className+"(this.data,"+tShape.join(",")+","+tStride.join(",")+",this.offset)}")

  //view.pick():
  code.push("proto.pick=function "+className+"_pick("+args+"){var a=[],b=[],c=this.offset")
  for(var i=0; i<dimension; ++i) {
    code.push("if(typeof i"+i+"==='number'&&i"+i+">=0){c=(c+this.stride["+i+"]*i"+i+")|0}else{a.push(this.shape["+i+"]);b.push(this.stride["+i+"])}")
  }
  code.push("var ctor=CTOR_LIST[a.length+1];return ctor(this.data,a,b,c)}")

  //Add return statement
  code.push("return function construct_"+className+"(data,shape,stride,offset){return new "+className+"(data,"+
    indices.map(function(i) {
      return "shape["+i+"]"
    }).join(",")+","+
    indices.map(function(i) {
      return "stride["+i+"]"
    }).join(",")+",offset)}")

  //Compile procedure
  var procedure = new Function("CTOR_LIST", "ORDER", code.join("\n"))
  return procedure(CACHED_CONSTRUCTORS[dtype], order)
}

function arrayDType(data) {
  if(isBuffer(data)) {
    return "buffer"
  }
  if(hasTypedArrays) {
    switch(Object.prototype.toString.call(data)) {
      case "[object Float64Array]":
        return "float64"
      case "[object Float32Array]":
        return "float32"
      case "[object Int8Array]":
        return "int8"
      case "[object Int16Array]":
        return "int16"
      case "[object Int32Array]":
        return "int32"
      case "[object Uint8Array]":
        return "uint8"
      case "[object Uint16Array]":
        return "uint16"
      case "[object Uint32Array]":
        return "uint32"
      case "[object Uint8ClampedArray]":
        return "uint8_clamped"
    }
  }
  if(Array.isArray(data)) {
    return "array"
  }
  return "generic"
}

var CACHED_CONSTRUCTORS = {
  "float32":[],
  "float64":[],
  "int8":[],
  "int16":[],
  "int32":[],
  "uint8":[],
  "uint16":[],
  "uint32":[],
  "array":[],
  "uint8_clamped":[],
  "buffer":[],
  "generic":[]
}

;(function() {
  for(var id in CACHED_CONSTRUCTORS) {
    CACHED_CONSTRUCTORS[id].push(compileConstructor(id, -1))
  }
});

function wrappedNDArrayCtor(data, shape, stride, offset) {
  if(data === undefined) {
    var ctor = CACHED_CONSTRUCTORS.array[0]
    return ctor([])
  } else if(typeof data === "number") {
    data = [data]
  }
  if(shape === undefined) {
    shape = [ data.length ]
  }
  var d = shape.length
  if(stride === undefined) {
    stride = new Array(d)
    for(var i=d-1, sz=1; i>=0; --i) {
      stride[i] = sz
      sz *= shape[i]
    }
  }
  if(offset === undefined) {
    offset = 0
    for(var i=0; i<d; ++i) {
      if(stride[i] < 0) {
        offset -= (shape[i]-1)*stride[i]
      }
    }
  }
  var dtype = arrayDType(data)
  var ctor_list = CACHED_CONSTRUCTORS[dtype]
  while(ctor_list.length <= d+1) {
    ctor_list.push(compileConstructor(dtype, ctor_list.length-1))
  }
  var ctor = ctor_list[d+1]
  return ctor(data, shape, stride, offset)
}

module.exports = wrappedNDArrayCtor

},{"iota-array":2,"is-buffer":3}]},{},[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","node_modules/iota-array/iota.js","node_modules/is-buffer/index.js","node_modules/ndarray/ndarray.js"],"names":[],"mappings":"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AN,SAAM,GAAN,GACE;AAAA,WAAC,SAAD,CAAY,YAAZ;AAAA,CADF,C;AAGC,CAAD,CAAG,GAAH;;;;ACpXA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACVA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","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})","(ns demo\n  (:require [ndarray]))\n\n; 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 when-not [condition & body]\n  `(when (not ~condition)\n     ~@body))\n\n(defmacro -> [& operations]\n  (reduce\n    (fn [form operation]\n      (cons (first operation)\n            (cons form (rest operation))))\n    (first operations)\n    (rest operations)))\n\n\n(defn inc [x]\n  (+ x 1))\n\n(defn dec [x]\n  (- x 1))\n\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 (inc ~varname)))))))\n\n(defmacro do-stride [varnames start-form end-form stride-form & body]\n  (let [stride (gensym \"stride\")\n        start (gensym \"start\")\n        end (gensym \"end\")\n        build (fn build [vars]\n                (if (empty? vars)\n                  `(do ~@body)\n                  (let [varname (first vars)]\n                    `(loop [~varname ~start]\n                       (when (< ~varname ~end)\n                         ~(build (rest vars))\n                         (recur (+ ~varname ~stride)))))))]\n    ; Fix the numbers once outside the nested loops,\n    ; and then build the guts.\n    `(let [~start ~start-form\n           ~end ~end-form\n           ~stride ~stride-form]\n       ~(build varnames))))\n\n\n(defmacro do-ndarray [vars array-form & body]\n  (let [array-var (gensym \"array\")\n        build (fn build [vars n]\n                (if (empty? vars)\n                  `(do ~@body)\n                  `(do-times ~(first vars) (aget (.-shape ~array-var) ~n)\n                     ~(build (rest vars) (inc n)))))]\n    `(let [~array-var ~array-form]\n       ~(build vars 0))))\n\n(defmacro do-ndarray-el [element array-form & body]\n  (let [index (gensym \"index\")\n        array (gensym \"array\")]\n    `(let [~array ~array-form]\n       (do-times ~index (.-length (.-data ~array))\n         (let [~element (aget (.-data ~array) ~index)]\n           ~@body)))))\n\n\n(defmacro inc! [place]\n  `(set! ~place (inc ~place)))\n\n(defmacro add! [place amount]\n  `(set! ~place (+ ~place ~amount)))\n\n\n(defmacro l [& forms]\n  `(console.log ~@forms))\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\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; Randomness ------------------------------------------------------------------\n(defn rand []\n  (Math.random))\n\n(defn rand-around-zero [spread]\n  (- (* spread (rand) 2) spread))\n\n(defn jitter [value spread]\n  (+ value (rand-around-zero spread)))\n\n\n; Heightmap Helpers -----------------------------------------------------------\n(defn heightmap-resolution [heightmap]\n  (aget heightmap.shape 0))\n\n(defn heightmap-last-index [heightmap]\n  (dec (heightmap-resolution heightmap)))\n\n(defn heightmap-center-index [heightmap]\n  (midpoint 0 (heightmap-last-index heightmap)))\n\n\n(defn heightmap-get [heightmap x y]\n  (.get heightmap x y))\n\n(defn heightmap-get-safe [heightmap x y]\n  (let [last (heightmap-last-index heightmap)]\n    (when (and (<= 0 x last)\n               (<= 0 y last))\n      (heightmap-get heightmap x y))))\n\n(defn heightmap-set! [heightmap x y val]\n  (.set heightmap x y val))\n\n(defn heightmap-set-if-unset! [heightmap x y val]\n  (when (== 0 (heightmap-get heightmap x y))\n    (heightmap-set! heightmap x y val)))\n\n\n(defn normalize [heightmap]\n  (let [max (- Infinity)\n        min Infinity]\n    (do-ndarray-el el heightmap\n      (when (< max el) (set! max el))\n      (when (> min el) (set! min el)))\n    (let [span (- max min)]\n      (do-ndarray [x y] heightmap\n        (heightmap-set! heightmap x y\n                        (/ (- (heightmap-get heightmap x y) min)\n                           span))))))\n\n\n(defn make-heightmap [exponent]\n  (let [resolution (+ (Math.pow 2 exponent) 1)]\n    (let [heightmap (ndarray (new Float64Array (* resolution resolution))\n                             [resolution resolution])]\n      (set! heightmap.exponent exponent)\n      (set! heightmap.resolution resolution)\n      (set! heightmap.last (dec resolution))\n      heightmap)))\n\n\n(defn top-left-corner [heightmap]\n  (let [center (heightmap-center-index heightmap)]\n    (-> heightmap\n      (.lo 0 0)\n      (.hi (inc center) (inc center)))))\n\n(defn top-right-corner [heightmap]\n  (let [center (heightmap-center-index heightmap)]\n    (-> heightmap\n      (.lo center 0)\n      (.hi (inc center) (inc center)))))\n\n(defn bottom-left-corner [heightmap]\n  (let [center (heightmap-center-index heightmap)]\n    (-> heightmap\n      (.lo 0 center)\n      (.hi (inc center) (inc center)))))\n\n(defn bottom-right-corner [heightmap]\n  (let [center (heightmap-center-index heightmap)]\n    (-> heightmap\n      (.lo center center)\n      (.hi (inc center) (inc center)))))\n\n\n; Midpoint Displacement -------------------------------------------------------\n(defn mpd-init-corners [heightmap]\n  (let [last (heightmap-last-index heightmap)]\n    (heightmap-set! heightmap 0    0    (rand))\n    (heightmap-set! heightmap 0    last (rand))\n    (heightmap-set! heightmap last 0    (rand))\n    (heightmap-set! heightmap last last (rand))))\n\n(defn mpd-displace [heightmap spread spread-reduction]\n  (let [last (heightmap-last-index heightmap)\n        c (midpoint 0 last)\n\n        bottom-left  (heightmap-get heightmap 0    0)\n        bottom-right (heightmap-get heightmap last 0)\n        top-left     (heightmap-get heightmap 0    last)\n        top-right    (heightmap-get heightmap last last)\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\n        next-spread (* spread spread-reduction)]\n    (heightmap-set-if-unset! heightmap c    0    (jitter bottom spread))\n    (heightmap-set-if-unset! heightmap c    last (jitter top spread))\n    (heightmap-set-if-unset! heightmap 0    c    (jitter left spread))\n    (heightmap-set-if-unset! heightmap last c    (jitter right spread))\n    (heightmap-set-if-unset! heightmap c    c    (jitter center spread))\n    (when-not (== 3 (heightmap-resolution heightmap))\n      (mpd-displace (top-left-corner heightmap) next-spread spread-reduction)\n      (mpd-displace (top-right-corner heightmap) next-spread spread-reduction)\n      (mpd-displace (bottom-left-corner heightmap) next-spread spread-reduction)\n      (mpd-displace (bottom-right-corner heightmap) next-spread spread-reduction))))\n\n(defn midpoint-displacement [heightmap]\n  (let [initial-spread 0.3 \n        spread-reduction 0.55]\n    (mpd-init-corners heightmap)\n    (mpd-displace heightmap initial-spread spread-reduction)\n    (normalize heightmap)))\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 [resolution (aget heightmap.shape 0)\n        geometry (new THREE.PlaneGeometry\n                      terrain-size\n                      terrain-size\n                      (- resolution 1)\n                      (- resolution 1))]\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\n(defn update-geometry [geometry heightmap]\n  (loop [i 0]\n    (if (< i geometry.vertices.length)\n      (do (set! (.-z (aget geometry.vertices i))\n                (* terrain-height (aget (.-data heightmap) i)))\n        (recur (+ i 1)))))\n  (geometry.computeVertexNormals)\n  geometry)\n\n\n; Main ------------------------------------------------------------------------\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\n  (def geometry)\n  (def plane)\n\n  (scene.add (make-directional-light))\n  (scene.add (new THREE.AmbientLight 0xffffff 0.05))\n\n  (defn refresh []\n    (let [heightmap (make-heightmap 6)]\n      (l \"Generating terrain...\")\n      (time (midpoint-displacement heightmap))\n\n      (l \"Rebuilding geometry...\")\n      (time\n        (set! geometry (make-geometry heightmap))\n        (update-geometry geometry heightmap))\n\n      (l \"Rebuilding plane...\")\n      (time\n        (scene.remove plane)\n        (set! plane (make-plane geometry))\n        (scene.add plane))))\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  (refresh)\n  (render)\n\n  nil)\n\n(defn run []\n  (make-final \"demo-final\"))\n\n($ run)\n\n\n; vim: lw+=do-times lw+=do-nested :\n","\"use strict\"\n\nfunction iota(n) {\n  var result = new Array(n)\n  for(var i=0; i<n; ++i) {\n    result[i] = i\n  }\n  return result\n}\n\nmodule.exports = iota","/**\n * Determine if an object is Buffer\n *\n * Author:   Feross Aboukhadijeh <feross@feross.org> <http://feross.org>\n * License:  MIT\n *\n * `npm install is-buffer`\n */\n\nmodule.exports = function (obj) {\n  return !!(obj != null &&\n    (obj._isBuffer || // For Safari 5-7 (missing Object.prototype.constructor)\n      (obj.constructor &&\n      typeof obj.constructor.isBuffer === 'function' &&\n      obj.constructor.isBuffer(obj))\n    ))\n}\n","var iota = require(\"iota-array\")\nvar isBuffer = require(\"is-buffer\")\n\nvar hasTypedArrays  = ((typeof Float64Array) !== \"undefined\")\n\nfunction compare1st(a, b) {\n  return a[0] - b[0]\n}\n\nfunction order() {\n  var stride = this.stride\n  var terms = new Array(stride.length)\n  var i\n  for(i=0; i<terms.length; ++i) {\n    terms[i] = [Math.abs(stride[i]), i]\n  }\n  terms.sort(compare1st)\n  var result = new Array(terms.length)\n  for(i=0; i<result.length; ++i) {\n    result[i] = terms[i][1]\n  }\n  return result\n}\n\nfunction compileConstructor(dtype, dimension) {\n  var className = [\"View\", dimension, \"d\", dtype].join(\"\")\n  if(dimension < 0) {\n    className = \"View_Nil\" + dtype\n  }\n  var useGetters = (dtype === \"generic\")\n\n  if(dimension === -1) {\n    //Special case for trivial arrays\n    var code =\n      \"function \"+className+\"(a){this.data=a;};\\\nvar proto=\"+className+\".prototype;\\\nproto.dtype='\"+dtype+\"';\\\nproto.index=function(){return -1};\\\nproto.size=0;\\\nproto.dimension=-1;\\\nproto.shape=proto.stride=proto.order=[];\\\nproto.lo=proto.hi=proto.transpose=proto.step=\\\nfunction(){return new \"+className+\"(this.data);};\\\nproto.get=proto.set=function(){};\\\nproto.pick=function(){return null};\\\nreturn function construct_\"+className+\"(a){return new \"+className+\"(a);}\"\n    var procedure = new Function(code)\n    return procedure()\n  } else if(dimension === 0) {\n    //Special case for 0d arrays\n    var code =\n      \"function \"+className+\"(a,d) {\\\nthis.data = a;\\\nthis.offset = d\\\n};\\\nvar proto=\"+className+\".prototype;\\\nproto.dtype='\"+dtype+\"';\\\nproto.index=function(){return this.offset};\\\nproto.dimension=0;\\\nproto.size=1;\\\nproto.shape=\\\nproto.stride=\\\nproto.order=[];\\\nproto.lo=\\\nproto.hi=\\\nproto.transpose=\\\nproto.step=function \"+className+\"_copy() {\\\nreturn new \"+className+\"(this.data,this.offset)\\\n};\\\nproto.pick=function \"+className+\"_pick(){\\\nreturn TrivialArray(this.data);\\\n};\\\nproto.valueOf=proto.get=function \"+className+\"_get(){\\\nreturn \"+(useGetters ? \"this.data.get(this.offset)\" : \"this.data[this.offset]\")+\n\"};\\\nproto.set=function \"+className+\"_set(v){\\\nreturn \"+(useGetters ? \"this.data.set(this.offset,v)\" : \"this.data[this.offset]=v\")+\"\\\n};\\\nreturn function construct_\"+className+\"(a,b,c,d){return new \"+className+\"(a,d)}\"\n    var procedure = new Function(\"TrivialArray\", code)\n    return procedure(CACHED_CONSTRUCTORS[dtype][0])\n  }\n\n  var code = [\"'use strict'\"]\n\n  //Create constructor for view\n  var indices = iota(dimension)\n  var args = indices.map(function(i) { return \"i\"+i })\n  var index_str = \"this.offset+\" + indices.map(function(i) {\n        return \"this.stride[\" + i + \"]*i\" + i\n      }).join(\"+\")\n  var shapeArg = indices.map(function(i) {\n      return \"b\"+i\n    }).join(\",\")\n  var strideArg = indices.map(function(i) {\n      return \"c\"+i\n    }).join(\",\")\n  code.push(\n    \"function \"+className+\"(a,\" + shapeArg + \",\" + strideArg + \",d){this.data=a\",\n      \"this.shape=[\" + shapeArg + \"]\",\n      \"this.stride=[\" + strideArg + \"]\",\n      \"this.offset=d|0}\",\n    \"var proto=\"+className+\".prototype\",\n    \"proto.dtype='\"+dtype+\"'\",\n    \"proto.dimension=\"+dimension)\n\n  //view.size:\n  code.push(\"Object.defineProperty(proto,'size',{get:function \"+className+\"_size(){\\\nreturn \"+indices.map(function(i) { return \"this.shape[\"+i+\"]\" }).join(\"*\"),\n\"}})\")\n\n  //view.order:\n  if(dimension === 1) {\n    code.push(\"proto.order=[0]\")\n  } else {\n    code.push(\"Object.defineProperty(proto,'order',{get:\")\n    if(dimension < 4) {\n      code.push(\"function \"+className+\"_order(){\")\n      if(dimension === 2) {\n        code.push(\"return (Math.abs(this.stride[0])>Math.abs(this.stride[1]))?[1,0]:[0,1]}})\")\n      } else if(dimension === 3) {\n        code.push(\n\"var s0=Math.abs(this.stride[0]),s1=Math.abs(this.stride[1]),s2=Math.abs(this.stride[2]);\\\nif(s0>s1){\\\nif(s1>s2){\\\nreturn [2,1,0];\\\n}else if(s0>s2){\\\nreturn [1,2,0];\\\n}else{\\\nreturn [1,0,2];\\\n}\\\n}else if(s0>s2){\\\nreturn [2,0,1];\\\n}else if(s2>s1){\\\nreturn [0,1,2];\\\n}else{\\\nreturn [0,2,1];\\\n}}})\")\n      }\n    } else {\n      code.push(\"ORDER})\")\n    }\n  }\n\n  //view.set(i0, ..., v):\n  code.push(\n\"proto.set=function \"+className+\"_set(\"+args.join(\",\")+\",v){\")\n  if(useGetters) {\n    code.push(\"return this.data.set(\"+index_str+\",v)}\")\n  } else {\n    code.push(\"return this.data[\"+index_str+\"]=v}\")\n  }\n\n  //view.get(i0, ...):\n  code.push(\"proto.get=function \"+className+\"_get(\"+args.join(\",\")+\"){\")\n  if(useGetters) {\n    code.push(\"return this.data.get(\"+index_str+\")}\")\n  } else {\n    code.push(\"return this.data[\"+index_str+\"]}\")\n  }\n\n  //view.index:\n  code.push(\n    \"proto.index=function \"+className+\"_index(\", args.join(), \"){return \"+index_str+\"}\")\n\n  //view.hi():\n  code.push(\"proto.hi=function \"+className+\"_hi(\"+args.join(\",\")+\"){return new \"+className+\"(this.data,\"+\n    indices.map(function(i) {\n      return [\"(typeof i\",i,\"!=='number'||i\",i,\"<0)?this.shape[\", i, \"]:i\", i,\"|0\"].join(\"\")\n    }).join(\",\")+\",\"+\n    indices.map(function(i) {\n      return \"this.stride[\"+i + \"]\"\n    }).join(\",\")+\",this.offset)}\")\n\n  //view.lo():\n  var a_vars = indices.map(function(i) { return \"a\"+i+\"=this.shape[\"+i+\"]\" })\n  var c_vars = indices.map(function(i) { return \"c\"+i+\"=this.stride[\"+i+\"]\" })\n  code.push(\"proto.lo=function \"+className+\"_lo(\"+args.join(\",\")+\"){var b=this.offset,d=0,\"+a_vars.join(\",\")+\",\"+c_vars.join(\",\"))\n  for(var i=0; i<dimension; ++i) {\n    code.push(\n\"if(typeof i\"+i+\"==='number'&&i\"+i+\">=0){\\\nd=i\"+i+\"|0;\\\nb+=c\"+i+\"*d;\\\na\"+i+\"-=d}\")\n  }\n  code.push(\"return new \"+className+\"(this.data,\"+\n    indices.map(function(i) {\n      return \"a\"+i\n    }).join(\",\")+\",\"+\n    indices.map(function(i) {\n      return \"c\"+i\n    }).join(\",\")+\",b)}\")\n\n  //view.step():\n  code.push(\"proto.step=function \"+className+\"_step(\"+args.join(\",\")+\"){var \"+\n    indices.map(function(i) {\n      return \"a\"+i+\"=this.shape[\"+i+\"]\"\n    }).join(\",\")+\",\"+\n    indices.map(function(i) {\n      return \"b\"+i+\"=this.stride[\"+i+\"]\"\n    }).join(\",\")+\",c=this.offset,d=0,ceil=Math.ceil\")\n  for(var i=0; i<dimension; ++i) {\n    code.push(\n\"if(typeof i\"+i+\"==='number'){\\\nd=i\"+i+\"|0;\\\nif(d<0){\\\nc+=b\"+i+\"*(a\"+i+\"-1);\\\na\"+i+\"=ceil(-a\"+i+\"/d)\\\n}else{\\\na\"+i+\"=ceil(a\"+i+\"/d)\\\n}\\\nb\"+i+\"*=d\\\n}\")\n  }\n  code.push(\"return new \"+className+\"(this.data,\"+\n    indices.map(function(i) {\n      return \"a\" + i\n    }).join(\",\")+\",\"+\n    indices.map(function(i) {\n      return \"b\" + i\n    }).join(\",\")+\",c)}\")\n\n  //view.transpose():\n  var tShape = new Array(dimension)\n  var tStride = new Array(dimension)\n  for(var i=0; i<dimension; ++i) {\n    tShape[i] = \"a[i\"+i+\"]\"\n    tStride[i] = \"b[i\"+i+\"]\"\n  }\n  code.push(\"proto.transpose=function \"+className+\"_transpose(\"+args+\"){\"+\n    args.map(function(n,idx) { return n + \"=(\" + n + \"===undefined?\" + idx + \":\" + n + \"|0)\"}).join(\";\"),\n    \"var a=this.shape,b=this.stride;return new \"+className+\"(this.data,\"+tShape.join(\",\")+\",\"+tStride.join(\",\")+\",this.offset)}\")\n\n  //view.pick():\n  code.push(\"proto.pick=function \"+className+\"_pick(\"+args+\"){var a=[],b=[],c=this.offset\")\n  for(var i=0; i<dimension; ++i) {\n    code.push(\"if(typeof i\"+i+\"==='number'&&i\"+i+\">=0){c=(c+this.stride[\"+i+\"]*i\"+i+\")|0}else{a.push(this.shape[\"+i+\"]);b.push(this.stride[\"+i+\"])}\")\n  }\n  code.push(\"var ctor=CTOR_LIST[a.length+1];return ctor(this.data,a,b,c)}\")\n\n  //Add return statement\n  code.push(\"return function construct_\"+className+\"(data,shape,stride,offset){return new \"+className+\"(data,\"+\n    indices.map(function(i) {\n      return \"shape[\"+i+\"]\"\n    }).join(\",\")+\",\"+\n    indices.map(function(i) {\n      return \"stride[\"+i+\"]\"\n    }).join(\",\")+\",offset)}\")\n\n  //Compile procedure\n  var procedure = new Function(\"CTOR_LIST\", \"ORDER\", code.join(\"\\n\"))\n  return procedure(CACHED_CONSTRUCTORS[dtype], order)\n}\n\nfunction arrayDType(data) {\n  if(isBuffer(data)) {\n    return \"buffer\"\n  }\n  if(hasTypedArrays) {\n    switch(Object.prototype.toString.call(data)) {\n      case \"[object Float64Array]\":\n        return \"float64\"\n      case \"[object Float32Array]\":\n        return \"float32\"\n      case \"[object Int8Array]\":\n        return \"int8\"\n      case \"[object Int16Array]\":\n        return \"int16\"\n      case \"[object Int32Array]\":\n        return \"int32\"\n      case \"[object Uint8Array]\":\n        return \"uint8\"\n      case \"[object Uint16Array]\":\n        return \"uint16\"\n      case \"[object Uint32Array]\":\n        return \"uint32\"\n      case \"[object Uint8ClampedArray]\":\n        return \"uint8_clamped\"\n    }\n  }\n  if(Array.isArray(data)) {\n    return \"array\"\n  }\n  return \"generic\"\n}\n\nvar CACHED_CONSTRUCTORS = {\n  \"float32\":[],\n  \"float64\":[],\n  \"int8\":[],\n  \"int16\":[],\n  \"int32\":[],\n  \"uint8\":[],\n  \"uint16\":[],\n  \"uint32\":[],\n  \"array\":[],\n  \"uint8_clamped\":[],\n  \"buffer\":[],\n  \"generic\":[]\n}\n\n;(function() {\n  for(var id in CACHED_CONSTRUCTORS) {\n    CACHED_CONSTRUCTORS[id].push(compileConstructor(id, -1))\n  }\n});\n\nfunction wrappedNDArrayCtor(data, shape, stride, offset) {\n  if(data === undefined) {\n    var ctor = CACHED_CONSTRUCTORS.array[0]\n    return ctor([])\n  } else if(typeof data === \"number\") {\n    data = [data]\n  }\n  if(shape === undefined) {\n    shape = [ data.length ]\n  }\n  var d = shape.length\n  if(stride === undefined) {\n    stride = new Array(d)\n    for(var i=d-1, sz=1; i>=0; --i) {\n      stride[i] = sz\n      sz *= shape[i]\n    }\n  }\n  if(offset === undefined) {\n    offset = 0\n    for(var i=0; i<d; ++i) {\n      if(stride[i] < 0) {\n        offset -= (shape[i]-1)*stride[i]\n      }\n    }\n  }\n  var dtype = arrayDType(data)\n  var ctor_list = CACHED_CONSTRUCTORS[dtype]\n  while(ctor_list.length <= d+1) {\n    ctor_list.push(compileConstructor(dtype, ctor_list.length-1))\n  }\n  var ctor = ctor_list[d+1]\n  return ctor(data, shape, stride, offset)\n}\n\nmodule.exports = wrappedNDArrayCtor\n"]}