{ "version": 3, "sources": ["../../node_modules/.pnpm/inherits@2.0.4/node_modules/inherits/inherits_browser.js", "../../node_modules/.pnpm/events@1.1.1/node_modules/events/events.js", "../../node_modules/.pnpm/right-now@1.0.0/node_modules/right-now/browser.js", "../../node_modules/.pnpm/performance-now@2.1.0/node_modules/performance-now/lib/src/performance-now.coffee", "../../node_modules/.pnpm/raf@3.4.1/node_modules/raf/index.js", "../../node_modules/.pnpm/raf-loop@1.1.3/node_modules/raf-loop/index.js", "../../node_modules/.pnpm/dct@0.1.0/node_modules/dct/src/dct.js", "../../node_modules/.pnpm/dct@0.1.0/node_modules/dct/index.js", "../../node_modules/.pnpm/fftjs@0.0.4/node_modules/fftjs/dist/utils.js", "../../node_modules/.pnpm/fftjs@0.0.4/node_modules/fftjs/dist/fft.js", "../../node_modules/.pnpm/meyda@5.6.2/node_modules/meyda/node_modules/tslib/tslib.es6.js", "../../node_modules/.pnpm/meyda@5.6.2/node_modules/src/windowing.ts", "../../node_modules/.pnpm/meyda@5.6.2/node_modules/src/utilities.ts", "../../node_modules/.pnpm/meyda@5.6.2/node_modules/src/extractors/extractorUtilities.ts", "../../node_modules/.pnpm/meyda@5.6.2/node_modules/src/extractors/loudness.ts", "../../node_modules/.pnpm/meyda@5.6.2/node_modules/src/extractors/powerSpectrum.ts", "../../node_modules/.pnpm/meyda@5.6.2/node_modules/src/extractors/melBands.ts", "../../node_modules/.pnpm/meyda@5.6.2/node_modules/src/featureExtractors.ts", "../../node_modules/.pnpm/meyda@5.6.2/node_modules/src/extractors/chroma.ts", "../../node_modules/.pnpm/meyda@5.6.2/node_modules/src/extractors/energy.ts", "../../node_modules/.pnpm/meyda@5.6.2/node_modules/src/extractors/mfcc.ts", "../../node_modules/.pnpm/meyda@5.6.2/node_modules/src/extractors/perceptualSharpness.ts", "../../node_modules/.pnpm/meyda@5.6.2/node_modules/src/extractors/perceptualSpread.ts", "../../node_modules/.pnpm/meyda@5.6.2/node_modules/src/extractors/rms.ts", "../../node_modules/.pnpm/meyda@5.6.2/node_modules/src/extractors/spectralCentroid.ts", "../../node_modules/.pnpm/meyda@5.6.2/node_modules/src/extractors/spectralCrest.ts", "../../node_modules/.pnpm/meyda@5.6.2/node_modules/src/extractors/spectralFlatness.ts", "../../node_modules/.pnpm/meyda@5.6.2/node_modules/src/extractors/spectralFlux.ts", "../../node_modules/.pnpm/meyda@5.6.2/node_modules/src/extractors/spectralKurtosis.ts", "../../node_modules/.pnpm/meyda@5.6.2/node_modules/src/extractors/spectralRolloff.ts", "../../node_modules/.pnpm/meyda@5.6.2/node_modules/src/extractors/spectralSkewness.ts", "../../node_modules/.pnpm/meyda@5.6.2/node_modules/src/extractors/spectralSlope.ts", "../../node_modules/.pnpm/meyda@5.6.2/node_modules/src/extractors/spectralSpread.ts", "../../node_modules/.pnpm/meyda@5.6.2/node_modules/src/extractors/zcr.ts", "../../node_modules/.pnpm/meyda@5.6.2/node_modules/src/meyda-wa.ts", "../../node_modules/.pnpm/meyda@5.6.2/node_modules/src/main.ts", "../../node_modules/.pnpm/regl@1.7.0/node_modules/regl/dist/regl.js", "../../node_modules/.pnpm/hydra-synth@1.3.29/node_modules/hydra-synth/src/output.js", "../../node_modules/.pnpm/hydra-synth@1.3.29/node_modules/hydra-synth/src/hydra-synth.js", "../../node_modules/.pnpm/hydra-synth@1.3.29/node_modules/hydra-synth/src/lib/webcam.js", "../../node_modules/.pnpm/hydra-synth@1.3.29/node_modules/hydra-synth/src/lib/screenmedia.js", "../../node_modules/.pnpm/hydra-synth@1.3.29/node_modules/hydra-synth/src/hydra-source.js", "../../node_modules/.pnpm/hydra-synth@1.3.29/node_modules/hydra-synth/src/lib/mouse-event.js", "../../node_modules/.pnpm/hydra-synth@1.3.29/node_modules/hydra-synth/src/lib/mouse.js", "../../node_modules/.pnpm/hydra-synth@1.3.29/node_modules/hydra-synth/src/lib/audio.js", "../../node_modules/.pnpm/hydra-synth@1.3.29/node_modules/hydra-synth/src/lib/video-recorder.js", "../../node_modules/.pnpm/hydra-synth@1.3.29/node_modules/hydra-synth/src/lib/easing-functions.js", "../../node_modules/.pnpm/hydra-synth@1.3.29/node_modules/hydra-synth/src/lib/array-utils.js", "../../node_modules/.pnpm/hydra-synth@1.3.29/node_modules/hydra-synth/src/lib/sandbox.js", "../../node_modules/.pnpm/hydra-synth@1.3.29/node_modules/hydra-synth/src/eval-sandbox.js", "../../node_modules/.pnpm/hydra-synth@1.3.29/node_modules/hydra-synth/src/format-arguments.js", "../../node_modules/.pnpm/hydra-synth@1.3.29/node_modules/hydra-synth/src/generate-glsl.js", "../../node_modules/.pnpm/hydra-synth@1.3.29/node_modules/hydra-synth/src/glsl/utility-functions.js", "../../node_modules/.pnpm/hydra-synth@1.3.29/node_modules/hydra-synth/src/glsl-source.js", "../../node_modules/.pnpm/hydra-synth@1.3.29/node_modules/hydra-synth/src/glsl/glsl-functions.js", "../../node_modules/.pnpm/hydra-synth@1.3.29/node_modules/hydra-synth/src/generator-factory.js", "../../_packs/hydra_index.js"], "sourcesContent": ["if (typeof Object.create === 'function') {\n // implementation from standard node.js 'util' module\n module.exports = function inherits(ctor, superCtor) {\n if (superCtor) {\n ctor.super_ = superCtor\n ctor.prototype = Object.create(superCtor.prototype, {\n constructor: {\n value: ctor,\n enumerable: false,\n writable: true,\n configurable: true\n }\n })\n }\n };\n} else {\n // old school shim for old browsers\n module.exports = function inherits(ctor, superCtor) {\n if (superCtor) {\n ctor.super_ = superCtor\n var TempCtor = function () {}\n TempCtor.prototype = superCtor.prototype\n ctor.prototype = new TempCtor()\n ctor.prototype.constructor = ctor\n }\n }\n}\n", "// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nfunction EventEmitter() {\n this._events = this._events || {};\n this._maxListeners = this._maxListeners || undefined;\n}\nmodule.exports = EventEmitter;\n\n// Backwards-compat with node 0.10.x\nEventEmitter.EventEmitter = EventEmitter;\n\nEventEmitter.prototype._events = undefined;\nEventEmitter.prototype._maxListeners = undefined;\n\n// By default EventEmitters will print a warning if more than 10 listeners are\n// added to it. This is a useful default which helps finding memory leaks.\nEventEmitter.defaultMaxListeners = 10;\n\n// Obviously not all Emitters should be limited to 10. This function allows\n// that to be increased. Set to zero for unlimited.\nEventEmitter.prototype.setMaxListeners = function(n) {\n if (!isNumber(n) || n < 0 || isNaN(n))\n throw TypeError('n must be a positive number');\n this._maxListeners = n;\n return this;\n};\n\nEventEmitter.prototype.emit = function(type) {\n var er, handler, len, args, i, listeners;\n\n if (!this._events)\n this._events = {};\n\n // If there is no 'error' event listener then throw.\n if (type === 'error') {\n if (!this._events.error ||\n (isObject(this._events.error) && !this._events.error.length)) {\n er = arguments[1];\n if (er instanceof Error) {\n throw er; // Unhandled 'error' event\n } else {\n // At least give some kind of context to the user\n var err = new Error('Uncaught, unspecified \"error\" event. (' + er + ')');\n err.context = er;\n throw err;\n }\n }\n }\n\n handler = this._events[type];\n\n if (isUndefined(handler))\n return false;\n\n if (isFunction(handler)) {\n switch (arguments.length) {\n // fast cases\n case 1:\n handler.call(this);\n break;\n case 2:\n handler.call(this, arguments[1]);\n break;\n case 3:\n handler.call(this, arguments[1], arguments[2]);\n break;\n // slower\n default:\n args = Array.prototype.slice.call(arguments, 1);\n handler.apply(this, args);\n }\n } else if (isObject(handler)) {\n args = Array.prototype.slice.call(arguments, 1);\n listeners = handler.slice();\n len = listeners.length;\n for (i = 0; i < len; i++)\n listeners[i].apply(this, args);\n }\n\n return true;\n};\n\nEventEmitter.prototype.addListener = function(type, listener) {\n var m;\n\n if (!isFunction(listener))\n throw TypeError('listener must be a function');\n\n if (!this._events)\n this._events = {};\n\n // To avoid recursion in the case that type === \"newListener\"! Before\n // adding it to the listeners, first emit \"newListener\".\n if (this._events.newListener)\n this.emit('newListener', type,\n isFunction(listener.listener) ?\n listener.listener : listener);\n\n if (!this._events[type])\n // Optimize the case of one listener. Don't need the extra array object.\n this._events[type] = listener;\n else if (isObject(this._events[type]))\n // If we've already got an array, just append.\n this._events[type].push(listener);\n else\n // Adding the second element, need to change to array.\n this._events[type] = [this._events[type], listener];\n\n // Check for listener leak\n if (isObject(this._events[type]) && !this._events[type].warned) {\n if (!isUndefined(this._maxListeners)) {\n m = this._maxListeners;\n } else {\n m = EventEmitter.defaultMaxListeners;\n }\n\n if (m && m > 0 && this._events[type].length > m) {\n this._events[type].warned = true;\n console.error('(node) warning: possible EventEmitter memory ' +\n 'leak detected. %d listeners added. ' +\n 'Use emitter.setMaxListeners() to increase limit.',\n this._events[type].length);\n if (typeof console.trace === 'function') {\n // not supported in IE 10\n console.trace();\n }\n }\n }\n\n return this;\n};\n\nEventEmitter.prototype.on = EventEmitter.prototype.addListener;\n\nEventEmitter.prototype.once = function(type, listener) {\n if (!isFunction(listener))\n throw TypeError('listener must be a function');\n\n var fired = false;\n\n function g() {\n this.removeListener(type, g);\n\n if (!fired) {\n fired = true;\n listener.apply(this, arguments);\n }\n }\n\n g.listener = listener;\n this.on(type, g);\n\n return this;\n};\n\n// emits a 'removeListener' event iff the listener was removed\nEventEmitter.prototype.removeListener = function(type, listener) {\n var list, position, length, i;\n\n if (!isFunction(listener))\n throw TypeError('listener must be a function');\n\n if (!this._events || !this._events[type])\n return this;\n\n list = this._events[type];\n length = list.length;\n position = -1;\n\n if (list === listener ||\n (isFunction(list.listener) && list.listener === listener)) {\n delete this._events[type];\n if (this._events.removeListener)\n this.emit('removeListener', type, listener);\n\n } else if (isObject(list)) {\n for (i = length; i-- > 0;) {\n if (list[i] === listener ||\n (list[i].listener && list[i].listener === listener)) {\n position = i;\n break;\n }\n }\n\n if (position < 0)\n return this;\n\n if (list.length === 1) {\n list.length = 0;\n delete this._events[type];\n } else {\n list.splice(position, 1);\n }\n\n if (this._events.removeListener)\n this.emit('removeListener', type, listener);\n }\n\n return this;\n};\n\nEventEmitter.prototype.removeAllListeners = function(type) {\n var key, listeners;\n\n if (!this._events)\n return this;\n\n // not listening for removeListener, no need to emit\n if (!this._events.removeListener) {\n if (arguments.length === 0)\n this._events = {};\n else if (this._events[type])\n delete this._events[type];\n return this;\n }\n\n // emit removeListener for all listeners on all events\n if (arguments.length === 0) {\n for (key in this._events) {\n if (key === 'removeListener') continue;\n this.removeAllListeners(key);\n }\n this.removeAllListeners('removeListener');\n this._events = {};\n return this;\n }\n\n listeners = this._events[type];\n\n if (isFunction(listeners)) {\n this.removeListener(type, listeners);\n } else if (listeners) {\n // LIFO order\n while (listeners.length)\n this.removeListener(type, listeners[listeners.length - 1]);\n }\n delete this._events[type];\n\n return this;\n};\n\nEventEmitter.prototype.listeners = function(type) {\n var ret;\n if (!this._events || !this._events[type])\n ret = [];\n else if (isFunction(this._events[type]))\n ret = [this._events[type]];\n else\n ret = this._events[type].slice();\n return ret;\n};\n\nEventEmitter.prototype.listenerCount = function(type) {\n if (this._events) {\n var evlistener = this._events[type];\n\n if (isFunction(evlistener))\n return 1;\n else if (evlistener)\n return evlistener.length;\n }\n return 0;\n};\n\nEventEmitter.listenerCount = function(emitter, type) {\n return emitter.listenerCount(type);\n};\n\nfunction isFunction(arg) {\n return typeof arg === 'function';\n}\n\nfunction isNumber(arg) {\n return typeof arg === 'number';\n}\n\nfunction isObject(arg) {\n return typeof arg === 'object' && arg !== null;\n}\n\nfunction isUndefined(arg) {\n return arg === void 0;\n}\n", "module.exports =\n global.performance &&\n global.performance.now ? function now() {\n return performance.now()\n } : Date.now || function now() {\n return +new Date\n }\n", null, "var now = require('performance-now')\n , root = typeof window === 'undefined' ? global : window\n , vendors = ['moz', 'webkit']\n , suffix = 'AnimationFrame'\n , raf = root['request' + suffix]\n , caf = root['cancel' + suffix] || root['cancelRequest' + suffix]\n\nfor(var i = 0; !raf && i < vendors.length; i++) {\n raf = root[vendors[i] + 'Request' + suffix]\n caf = root[vendors[i] + 'Cancel' + suffix]\n || root[vendors[i] + 'CancelRequest' + suffix]\n}\n\n// Some versions of FF have rAF but not cAF\nif(!raf || !caf) {\n var last = 0\n , id = 0\n , queue = []\n , frameDuration = 1000 / 60\n\n raf = function(callback) {\n if(queue.length === 0) {\n var _now = now()\n , next = Math.max(0, frameDuration - (_now - last))\n last = next + _now\n setTimeout(function() {\n var cp = queue.slice(0)\n // Clear queue here to prevent\n // callbacks from appending listeners\n // to the current frame's queue\n queue.length = 0\n for(var i = 0; i < cp.length; i++) {\n if(!cp[i].cancelled) {\n try{\n cp[i].callback(last)\n } catch(e) {\n setTimeout(function() { throw e }, 0)\n }\n }\n }\n }, Math.round(next))\n }\n queue.push({\n handle: ++id,\n callback: callback,\n cancelled: false\n })\n return id\n }\n\n caf = function(handle) {\n for(var i = 0; i < queue.length; i++) {\n if(queue[i].handle === handle) {\n queue[i].cancelled = true\n }\n }\n }\n}\n\nmodule.exports = function(fn) {\n // Wrap in a new function to prevent\n // `cancel` potentially being assigned\n // to the native rAF function\n return raf.call(root, fn)\n}\nmodule.exports.cancel = function() {\n caf.apply(root, arguments)\n}\nmodule.exports.polyfill = function(object) {\n if (!object) {\n object = root;\n }\n object.requestAnimationFrame = raf\n object.cancelAnimationFrame = caf\n}\n", "var inherits = require('inherits')\nvar EventEmitter = require('events').EventEmitter\nvar now = require('right-now')\nvar raf = require('raf')\n\nmodule.exports = Engine\nfunction Engine(fn) {\n if (!(this instanceof Engine)) \n return new Engine(fn)\n this.running = false\n this.last = now()\n this._frame = 0\n this._tick = this.tick.bind(this)\n\n if (fn)\n this.on('tick', fn)\n}\n\ninherits(Engine, EventEmitter)\n\nEngine.prototype.start = function() {\n if (this.running) \n return\n this.running = true\n this.last = now()\n this._frame = raf(this._tick)\n return this\n}\n\nEngine.prototype.stop = function() {\n this.running = false\n if (this._frame !== 0)\n raf.cancel(this._frame)\n this._frame = 0\n return this\n}\n\nEngine.prototype.tick = function() {\n this._frame = raf(this._tick)\n var time = now()\n var dt = time - this.last\n this.emit('tick', dt)\n this.last = time\n}", "/*===========================================================================*\\\n * Discrete Cosine Transform\n *\n * (c) Vail Systems. Joshua Jung and Ben Bryan. 2015\n *\n * This code is not designed to be highly optimized but as an educational\n * tool to understand the Mel-scale and its related coefficients used in\n * human speech analysis.\n\\*===========================================================================*/\nvar cosMap = null;\n\n// Builds a cosine map for the given input size. This allows multiple input sizes to be memoized automagically\n// if you want to run the DCT over and over.\nvar memoizeCosines = function(N) {\n cosMap = cosMap || {};\n cosMap[N] = new Array(N*N);\n\n var PI_N = Math.PI / N;\n\n for (var k = 0; k < N; k++) {\n for (var n = 0; n < N; n++) {\n cosMap[N][n + (k * N)] = Math.cos(PI_N * (n + 0.5) * k);\n }\n }\n};\n\nfunction dct(signal, scale) {\n var L = signal.length;\n scale = scale || 2;\n\n if (!cosMap || !cosMap[L]) memoizeCosines(L);\n\n var coefficients = signal.map(function () {return 0;});\n\n return coefficients.map(function (__, ix) {\n return scale * signal.reduce(function (prev, cur, ix_, arr) {\n return prev + (cur * cosMap[L][ix_ + (ix * L)]);\n }, 0);\n });\n};\n\nmodule.exports = dct;\n", "module.exports = require('./src/dct.js');\n", "'use strict';\n\n// memoization of the reversal of different lengths.\n\nfunction _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }\n\nvar memoizedReversal = {};\nvar memoizedZeroBuffers = {};\n\nvar constructComplexArray = function constructComplexArray(signal) {\n var complexSignal = {};\n\n complexSignal.real = signal.real === undefined ? signal.slice() : signal.real.slice();\n\n var bufferSize = complexSignal.real.length;\n\n if (memoizedZeroBuffers[bufferSize] === undefined) {\n memoizedZeroBuffers[bufferSize] = Array.apply(null, Array(bufferSize)).map(Number.prototype.valueOf, 0);\n }\n\n complexSignal.imag = memoizedZeroBuffers[bufferSize].slice();\n\n return complexSignal;\n};\n\nvar bitReverseArray = function bitReverseArray(N) {\n if (memoizedReversal[N] === undefined) {\n var maxBinaryLength = (N - 1).toString(2).length; //get the binary length of the largest index.\n var templateBinary = '0'.repeat(maxBinaryLength); //create a template binary of that length.\n var reversed = {};\n for (var n = 0; n < N; n++) {\n var currBinary = n.toString(2); //get binary value of current index.\n\n //prepend zeros from template to current binary. This makes binary values of all indices have the same length.\n currBinary = templateBinary.substr(currBinary.length) + currBinary;\n\n currBinary = [].concat(_toConsumableArray(currBinary)).reverse().join(''); //reverse\n reversed[n] = parseInt(currBinary, 2); //convert to decimal\n }\n memoizedReversal[N] = reversed; //save\n }\n return memoizedReversal[N];\n};\n\n// complex multiplication\nvar multiply = function multiply(a, b) {\n return {\n 'real': a.real * b.real - a.imag * b.imag,\n 'imag': a.real * b.imag + a.imag * b.real\n };\n};\n\n// complex addition\nvar add = function add(a, b) {\n return {\n 'real': a.real + b.real,\n 'imag': a.imag + b.imag\n };\n};\n\n// complex subtraction\nvar subtract = function subtract(a, b) {\n return {\n 'real': a.real - b.real,\n 'imag': a.imag - b.imag\n };\n};\n\n// euler's identity e^x = cos(x) + sin(x)\nvar euler = function euler(kn, N) {\n var x = -2 * Math.PI * kn / N;\n return { 'real': Math.cos(x), 'imag': Math.sin(x) };\n};\n\n// complex conjugate\nvar conj = function conj(a) {\n a.imag *= -1;\n return a;\n};\n\nmodule.exports = {\n bitReverseArray: bitReverseArray,\n multiply: multiply,\n add: add,\n subtract: subtract,\n euler: euler,\n conj: conj,\n constructComplexArray: constructComplexArray\n};", "'use strict';\n\nvar utils = require('./utils');\n\n// real to complex fft\nvar fft = function fft(signal) {\n\n var complexSignal = {};\n\n if (signal.real === undefined || signal.imag === undefined) {\n complexSignal = utils.constructComplexArray(signal);\n } else {\n complexSignal.real = signal.real.slice();\n complexSignal.imag = signal.imag.slice();\n }\n\n var N = complexSignal.real.length;\n var logN = Math.log2(N);\n\n if (Math.round(logN) != logN) throw new Error('Input size must be a power of 2.');\n\n if (complexSignal.real.length != complexSignal.imag.length) {\n throw new Error('Real and imaginary components must have the same length.');\n }\n\n var bitReversedIndices = utils.bitReverseArray(N);\n\n // sort array\n var ordered = {\n 'real': [],\n 'imag': []\n };\n\n for (var i = 0; i < N; i++) {\n ordered.real[bitReversedIndices[i]] = complexSignal.real[i];\n ordered.imag[bitReversedIndices[i]] = complexSignal.imag[i];\n }\n\n for (var _i = 0; _i < N; _i++) {\n complexSignal.real[_i] = ordered.real[_i];\n complexSignal.imag[_i] = ordered.imag[_i];\n }\n // iterate over the number of stages\n for (var n = 1; n <= logN; n++) {\n var currN = Math.pow(2, n);\n\n // find twiddle factors\n for (var k = 0; k < currN / 2; k++) {\n var twiddle = utils.euler(k, currN);\n\n // on each block of FT, implement the butterfly diagram\n for (var m = 0; m < N / currN; m++) {\n var currEvenIndex = currN * m + k;\n var currOddIndex = currN * m + k + currN / 2;\n\n var currEvenIndexSample = {\n 'real': complexSignal.real[currEvenIndex],\n 'imag': complexSignal.imag[currEvenIndex]\n };\n var currOddIndexSample = {\n 'real': complexSignal.real[currOddIndex],\n 'imag': complexSignal.imag[currOddIndex]\n };\n\n var odd = utils.multiply(twiddle, currOddIndexSample);\n\n var subtractionResult = utils.subtract(currEvenIndexSample, odd);\n complexSignal.real[currOddIndex] = subtractionResult.real;\n complexSignal.imag[currOddIndex] = subtractionResult.imag;\n\n var additionResult = utils.add(odd, currEvenIndexSample);\n complexSignal.real[currEvenIndex] = additionResult.real;\n complexSignal.imag[currEvenIndex] = additionResult.imag;\n }\n }\n }\n\n return complexSignal;\n};\n\n// complex to real ifft\nvar ifft = function ifft(signal) {\n\n if (signal.real === undefined || signal.imag === undefined) {\n throw new Error(\"IFFT only accepts a complex input.\");\n }\n\n var N = signal.real.length;\n\n var complexSignal = {\n 'real': [],\n 'imag': []\n };\n\n //take complex conjugate in order to be able to use the regular FFT for IFFT\n for (var i = 0; i < N; i++) {\n var currentSample = {\n 'real': signal.real[i],\n 'imag': signal.imag[i]\n };\n\n var conjugateSample = utils.conj(currentSample);\n complexSignal.real[i] = conjugateSample.real;\n complexSignal.imag[i] = conjugateSample.imag;\n }\n\n //compute\n var X = fft(complexSignal);\n\n //normalize\n complexSignal.real = X.real.map(function (val) {\n return val / N;\n });\n\n complexSignal.imag = X.imag.map(function (val) {\n return val / N;\n });\n\n return complexSignal;\n};\n\nmodule.exports = {\n fft: fft,\n ifft: ifft\n};", "/******************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n if (typeof b !== \"function\" && b !== null)\r\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __esDecorate(ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {\r\n function accept(f) { if (f !== void 0 && typeof f !== \"function\") throw new TypeError(\"Function expected\"); return f; }\r\n var kind = contextIn.kind, key = kind === \"getter\" ? \"get\" : kind === \"setter\" ? \"set\" : \"value\";\r\n var target = !descriptorIn && ctor ? contextIn[\"static\"] ? ctor : ctor.prototype : null;\r\n var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});\r\n var _, done = false;\r\n for (var i = decorators.length - 1; i >= 0; i--) {\r\n var context = {};\r\n for (var p in contextIn) context[p] = p === \"access\" ? {} : contextIn[p];\r\n for (var p in contextIn.access) context.access[p] = contextIn.access[p];\r\n context.addInitializer = function (f) { if (done) throw new TypeError(\"Cannot add initializers after decoration has completed\"); extraInitializers.push(accept(f || null)); };\r\n var result = (0, decorators[i])(kind === \"accessor\" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);\r\n if (kind === \"accessor\") {\r\n if (result === void 0) continue;\r\n if (result === null || typeof result !== \"object\") throw new TypeError(\"Object expected\");\r\n if (_ = accept(result.get)) descriptor.get = _;\r\n if (_ = accept(result.set)) descriptor.set = _;\r\n if (_ = accept(result.init)) initializers.unshift(_);\r\n }\r\n else if (_ = accept(result)) {\r\n if (kind === \"field\") initializers.unshift(_);\r\n else descriptor[key] = _;\r\n }\r\n }\r\n if (target) Object.defineProperty(target, contextIn.name, descriptor);\r\n done = true;\r\n};\r\n\r\nexport function __runInitializers(thisArg, initializers, value) {\r\n var useValue = arguments.length > 2;\r\n for (var i = 0; i < initializers.length; i++) {\r\n value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);\r\n }\r\n return useValue ? value : void 0;\r\n};\r\n\r\nexport function __propKey(x) {\r\n return typeof x === \"symbol\" ? x : \"\".concat(x);\r\n};\r\n\r\nexport function __setFunctionName(f, name, prefix) {\r\n if (typeof name === \"symbol\") name = name.description ? \"[\".concat(name.description, \"]\") : \"\";\r\n return Object.defineProperty(f, \"name\", { configurable: true, value: prefix ? \"\".concat(prefix, \" \", name) : name });\r\n};\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (g && (g = 0, op[0] && (_ = 0)), _) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n var desc = Object.getOwnPropertyDescriptor(m, k);\r\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\r\n desc = { enumerable: true, get: function() { return m[k]; } };\r\n }\r\n Object.defineProperty(o, k2, desc);\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n if (ar || !(i in from)) {\r\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n ar[i] = from[i];\r\n }\r\n }\r\n return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: false } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n\r\nexport function __classPrivateFieldIn(state, receiver) {\r\n if (receiver === null || (typeof receiver !== \"object\" && typeof receiver !== \"function\")) throw new TypeError(\"Cannot use 'in' operator on non-object\");\r\n return typeof state === \"function\" ? receiver === state : state.has(receiver);\r\n}\r\n\r\nexport default {\r\n __extends,\r\n __assign,\r\n __rest,\r\n __decorate,\r\n __param,\r\n __metadata,\r\n __awaiter,\r\n __generator,\r\n __createBinding,\r\n __exportStar,\r\n __values,\r\n __read,\r\n __spread,\r\n __spreadArrays,\r\n __spreadArray,\r\n __await,\r\n __asyncGenerator,\r\n __asyncDelegator,\r\n __asyncValues,\r\n __makeTemplateObject,\r\n __importStar,\r\n __importDefault,\r\n __classPrivateFieldGet,\r\n __classPrivateFieldSet,\r\n __classPrivateFieldIn,\r\n};\r\n", "export function blackman(size) {\n let blackmanBuffer = new Float32Array(size);\n let coeff1 = (2 * Math.PI) / (size - 1);\n let coeff2 = 2 * coeff1;\n\n //According to http://uk.mathworks.com/help/signal/ref/blackman.html\n //first half of the window\n for (let i = 0; i < size / 2; i++) {\n blackmanBuffer[i] =\n 0.42 - 0.5 * Math.cos(i * coeff1) + 0.08 * Math.cos(i * coeff2);\n }\n\n //second half of the window\n for (let i = Math.ceil(size / 2); i > 0; i--) {\n blackmanBuffer[size - i] = blackmanBuffer[i - 1];\n }\n\n return blackmanBuffer;\n}\n\nexport function sine(size) {\n let coeff = Math.PI / (size - 1);\n let sineBuffer = new Float32Array(size);\n\n for (let i = 0; i < size; i++) {\n sineBuffer[i] = Math.sin(coeff * i);\n }\n\n return sineBuffer;\n}\n\nexport function hanning(size) {\n let hanningBuffer = new Float32Array(size);\n for (let i = 0; i < size; i++) {\n // According to the R documentation\n // http://ugrad.stat.ubc.ca/R/library/e1071/html/hanning.window.html\n hanningBuffer[i] = 0.5 - 0.5 * Math.cos((2 * Math.PI * i) / (size - 1));\n }\n\n return hanningBuffer;\n}\n\nexport function hamming(size) {\n let hammingBuffer = new Float32Array(size);\n for (let i = 0; i < size; i++) {\n //According to http://uk.mathworks.com/help/signal/ref/hamming.html\n hammingBuffer[i] = 0.54 - 0.46 * Math.cos(2 * Math.PI * (i / size - 1));\n }\n\n return hammingBuffer;\n}\n", "import * as windowing from \"./windowing\";\n\nlet windows = {};\n\nexport function isPowerOfTwo(num) {\n while (num % 2 === 0 && num > 1) {\n num /= 2;\n }\n\n return num === 1;\n}\n\nexport function error(message) {\n throw new Error(\"Meyda: \" + message);\n}\n\nexport function pointwiseBufferMult(a, b) {\n let c: number[] = [];\n for (let i = 0; i < Math.min(a.length, b.length); i++) {\n c[i] = a[i] * b[i];\n }\n\n return c;\n}\n\nexport function applyWindow(signal, windowname) {\n if (windowname !== \"rect\") {\n if (windowname === \"\" || !windowname) windowname = \"hanning\";\n if (!windows[windowname]) windows[windowname] = {};\n\n if (!windows[windowname][signal.length]) {\n try {\n windows[windowname][signal.length] = windowing[windowname](\n signal.length\n );\n } catch (e) {\n throw new Error(\"Invalid windowing function\");\n }\n }\n\n signal = pointwiseBufferMult(signal, windows[windowname][signal.length]);\n }\n\n return signal;\n}\n\nexport function createBarkScale(length, sampleRate, bufferSize): Float32Array {\n let barkScale = new Float32Array(length);\n\n for (var i = 0; i < barkScale.length; i++) {\n barkScale[i] = (i * sampleRate) / bufferSize;\n barkScale[i] =\n 13 * Math.atan(barkScale[i] / 1315.8) +\n 3.5 * Math.atan(Math.pow(barkScale[i] / 7518, 2));\n }\n\n return barkScale;\n}\n\nexport function typedToArray(t) {\n // utility to convert typed arrays to normal arrays\n return Array.prototype.slice.call(t);\n}\n\nexport function arrayToTyped(t) {\n // utility to convert arrays to typed F32 arrays\n return Float32Array.from(t);\n}\n\nexport function _normalize(num, range) {\n return num / range;\n}\n\nexport function normalize(a, range) {\n return a.map(function (n) {\n return _normalize(n, range);\n });\n}\n\nexport function normalizeToOne(a) {\n var max = Math.max.apply(null, a);\n\n return a.map(function (n) {\n return n / max;\n });\n}\n\nexport function mean(a) {\n return (\n a.reduce(function (prev, cur) {\n return prev + cur;\n }) / a.length\n );\n}\n\nfunction _melToFreq(melValue) {\n var freqValue = 700 * (Math.exp(melValue / 1125) - 1);\n return freqValue;\n}\n\nfunction _freqToMel(freqValue) {\n var melValue = 1125 * Math.log(1 + freqValue / 700);\n return melValue;\n}\n\nexport function melToFreq(mV) {\n return _melToFreq(mV);\n}\n\nexport function freqToMel(fV) {\n return _freqToMel(fV);\n}\n\nexport function createMelFilterBank(\n numFilters: number,\n sampleRate: number,\n bufferSize: number\n): number[][] {\n //the +2 is the upper and lower limits\n let melValues = new Float32Array(numFilters + 2);\n let melValuesInFreq = new Float32Array(numFilters + 2);\n\n //Generate limits in Hz - from 0 to the nyquist.\n let lowerLimitFreq = 0;\n let upperLimitFreq = sampleRate / 2;\n\n //Convert the limits to Mel\n let lowerLimitMel = _freqToMel(lowerLimitFreq);\n let upperLimitMel = _freqToMel(upperLimitFreq);\n\n //Find the range\n let range = upperLimitMel - lowerLimitMel;\n\n //Find the range as part of the linear interpolation\n let valueToAdd = range / (numFilters + 1);\n\n let fftBinsOfFreq: number[] = new Array(numFilters + 2);\n\n for (let i = 0; i < melValues.length; i++) {\n // Initialising the mel frequencies\n // They're a linear interpolation between the lower and upper limits.\n melValues[i] = i * valueToAdd;\n\n // Convert back to Hz\n melValuesInFreq[i] = _melToFreq(melValues[i]);\n\n // Find the corresponding bins\n fftBinsOfFreq[i] = Math.floor(\n ((bufferSize + 1) * melValuesInFreq[i]) / sampleRate\n );\n }\n\n var filterBank: number[][] = new Array(numFilters);\n for (let j = 0; j < filterBank.length; j++) {\n // Create a two dimensional array of size numFilters * (buffersize/2)+1\n // pre-populating the arrays with 0s.\n filterBank[j] = new Array(bufferSize / 2 + 1).fill(0);\n\n //creating the lower and upper slopes for each bin\n for (let i = fftBinsOfFreq[j]; i < fftBinsOfFreq[j + 1]; i++) {\n filterBank[j][i] =\n (i - fftBinsOfFreq[j]) / (fftBinsOfFreq[j + 1] - fftBinsOfFreq[j]);\n }\n\n for (let i = fftBinsOfFreq[j + 1]; i < fftBinsOfFreq[j + 2]; i++) {\n filterBank[j][i] =\n (fftBinsOfFreq[j + 2] - i) /\n (fftBinsOfFreq[j + 2] - fftBinsOfFreq[j + 1]);\n }\n }\n\n return filterBank;\n}\n\nexport function hzToOctaves(freq, A440) {\n return Math.log2((16 * freq) / A440);\n}\n\nexport function normalizeByColumn(a) {\n var emptyRow = a[0].map(() => 0);\n var colDenominators = a\n .reduce((acc, row) => {\n row.forEach((cell, j) => {\n acc[j] += Math.pow(cell, 2);\n });\n return acc;\n }, emptyRow)\n .map(Math.sqrt);\n return a.map((row, i) => row.map((v, j) => v / (colDenominators[j] || 1)));\n}\n\nexport function createChromaFilterBank(\n numFilters,\n sampleRate,\n bufferSize,\n centerOctave = 5,\n octaveWidth = 2,\n baseC = true,\n A440 = 440\n) {\n var numOutputBins = Math.floor(bufferSize / 2) + 1;\n\n var frequencyBins = new Array(bufferSize)\n .fill(0)\n .map(\n (_, i) => numFilters * hzToOctaves((sampleRate * i) / bufferSize, A440)\n );\n\n // Set a value for the 0 Hz bin that is 1.5 octaves below bin 1\n // (so chroma is 50% rotated from bin 1, and bin width is broad)\n frequencyBins[0] = frequencyBins[1] - 1.5 * numFilters;\n\n var binWidthBins = frequencyBins\n .slice(1)\n .map((v, i) => Math.max(v - frequencyBins[i]), 1)\n .concat([1]);\n\n var halfNumFilters = Math.round(numFilters / 2);\n\n var filterPeaks = new Array(numFilters)\n .fill(0)\n .map((_, i) =>\n frequencyBins.map(\n (frq) =>\n ((10 * numFilters + halfNumFilters + frq - i) % numFilters) -\n halfNumFilters\n )\n );\n\n var weights = filterPeaks.map((row, i) =>\n row.map((_, j) =>\n Math.exp(-0.5 * Math.pow((2 * filterPeaks[i][j]) / binWidthBins[j], 2))\n )\n );\n\n weights = normalizeByColumn(weights);\n\n if (octaveWidth) {\n var octaveWeights = frequencyBins.map((v) =>\n Math.exp(\n -0.5 * Math.pow((v / numFilters - centerOctave) / octaveWidth, 2)\n )\n );\n weights = weights.map((row) =>\n row.map((cell, j) => cell * octaveWeights[j])\n );\n }\n\n if (baseC) {\n weights = [...weights.slice(3), ...weights.slice(0, 3)];\n }\n\n return weights.map((row) => row.slice(0, numOutputBins));\n}\n\nexport function frame(buffer, frameLength, hopLength) {\n if (buffer.length < frameLength) {\n throw new Error(\"Buffer is too short for frame length\");\n }\n if (hopLength < 1) {\n throw new Error(\"Hop length cannot be less that 1\");\n }\n if (frameLength < 1) {\n throw new Error(\"Frame length cannot be less that 1\");\n }\n\n const numFrames = 1 + Math.floor((buffer.length - frameLength) / hopLength);\n\n return new Array(numFrames)\n .fill(0)\n .map((_, i) => buffer.slice(i * hopLength, i * hopLength + frameLength));\n}\n", "export function mu(i: number, amplitudeSpect: Float32Array): number {\n var numerator = 0;\n var denominator = 0;\n for (var k = 0; k < amplitudeSpect.length; k++) {\n numerator += Math.pow(k, i) * Math.abs(amplitudeSpect[k]);\n denominator += amplitudeSpect[k];\n }\n return numerator / denominator;\n}\n", "export default function ({\n ampSpectrum,\n barkScale,\n numberOfBarkBands = 24,\n}: {\n ampSpectrum: Float32Array;\n barkScale: Float32Array;\n numberOfBarkBands?: number;\n}): {\n specific: Float32Array;\n total: number;\n} {\n if (typeof ampSpectrum !== \"object\" || typeof barkScale !== \"object\") {\n throw new TypeError();\n }\n\n var NUM_BARK_BANDS = numberOfBarkBands;\n var specific = new Float32Array(NUM_BARK_BANDS);\n var total = 0;\n var normalisedSpectrum = ampSpectrum;\n var bbLimits = new Int32Array(NUM_BARK_BANDS + 1);\n\n bbLimits[0] = 0;\n var currentBandEnd =\n barkScale[normalisedSpectrum.length - 1] / NUM_BARK_BANDS;\n var currentBand = 1;\n for (let i = 0; i < normalisedSpectrum.length; i++) {\n while (barkScale[i] > currentBandEnd) {\n bbLimits[currentBand++] = i;\n currentBandEnd =\n (currentBand * barkScale[normalisedSpectrum.length - 1]) /\n NUM_BARK_BANDS;\n }\n }\n\n bbLimits[NUM_BARK_BANDS] = normalisedSpectrum.length - 1;\n\n //process\n\n for (let i = 0; i < NUM_BARK_BANDS; i++) {\n let sum = 0;\n for (let j = bbLimits[i]; j < bbLimits[i + 1]; j++) {\n sum += normalisedSpectrum[j];\n }\n\n specific[i] = Math.pow(sum, 0.23);\n }\n\n //get total loudness\n for (let i = 0; i < specific.length; i++) {\n total += specific[i];\n }\n\n return {\n specific: specific,\n total: total,\n };\n}\n", "export default function ({\n ampSpectrum,\n}: {\n ampSpectrum: Float32Array;\n}): Float32Array {\n if (typeof ampSpectrum !== \"object\") {\n throw new TypeError();\n }\n\n var powerSpectrum = new Float32Array(ampSpectrum.length);\n for (var i = 0; i < powerSpectrum.length; i++) {\n powerSpectrum[i] = Math.pow(ampSpectrum[i], 2);\n }\n\n return powerSpectrum;\n}\n", "import extractPowerSpectrum from \"./powerSpectrum\";\n\nexport default function ({\n ampSpectrum,\n melFilterBank,\n bufferSize,\n}: {\n ampSpectrum: Float32Array;\n melFilterBank: number[][];\n bufferSize: number;\n}): number[] {\n if (typeof ampSpectrum !== \"object\") {\n throw new TypeError(\"Valid ampSpectrum is required to generate melBands\");\n }\n if (typeof melFilterBank !== \"object\") {\n throw new TypeError(\"Valid melFilterBank is required to generate melBands\");\n }\n\n let powSpec = extractPowerSpectrum({ ampSpectrum });\n let numFilters = melFilterBank.length;\n let filtered: Float32Array[] = Array(numFilters);\n let loggedMelBands: Float32Array = new Float32Array(numFilters);\n\n for (let i = 0; i < loggedMelBands.length; i++) {\n filtered[i] = new Float32Array(bufferSize / 2);\n loggedMelBands[i] = 0;\n for (let j = 0; j < bufferSize / 2; j++) {\n //point-wise multiplication between power spectrum and filterbanks.\n filtered[i][j] = melFilterBank[i][j] * powSpec[j];\n\n //summing up all of the coefficients into one array\n loggedMelBands[i] += filtered[i][j];\n }\n\n //log each coefficient.\n loggedMelBands[i] = Math.log(loggedMelBands[i] + 1);\n }\n return Array.prototype.slice.call(loggedMelBands);\n}\n", "import rms from \"./extractors/rms\";\nimport energy from \"./extractors/energy\";\nimport spectralSlope from \"./extractors/spectralSlope\";\nimport spectralCentroid from \"./extractors/spectralCentroid\";\nimport spectralRolloff from \"./extractors/spectralRolloff\";\nimport spectralFlatness from \"./extractors/spectralFlatness\";\nimport spectralSpread from \"./extractors/spectralSpread\";\nimport spectralSkewness from \"./extractors/spectralSkewness\";\nimport spectralKurtosis from \"./extractors/spectralKurtosis\";\nimport zcr from \"./extractors/zcr\";\nimport loudness from \"./extractors/loudness\";\nimport perceptualSpread from \"./extractors/perceptualSpread\";\nimport perceptualSharpness from \"./extractors/perceptualSharpness\";\nimport mfcc from \"./extractors/mfcc\";\nimport chroma from \"./extractors/chroma\";\nimport powerSpectrum from \"./extractors/powerSpectrum\";\nimport spectralFlux from \"./extractors/spectralFlux\";\nimport spectralCrest from \"./extractors/spectralCrest\";\nimport melBands from \"./extractors/melBands\";\n\nlet buffer = function (args) {\n return args.signal;\n};\n\nlet complexSpectrum = function (args) {\n return args.complexSpectrum;\n};\n\nlet amplitudeSpectrum = function (args) {\n return args.ampSpectrum;\n};\n\nexport {\n buffer,\n rms,\n energy,\n complexSpectrum,\n spectralSlope,\n spectralCentroid,\n spectralRolloff,\n spectralFlatness,\n spectralSpread,\n spectralSkewness,\n spectralKurtosis,\n amplitudeSpectrum,\n zcr,\n loudness,\n perceptualSpread,\n perceptualSharpness,\n powerSpectrum,\n mfcc,\n chroma,\n spectralFlux,\n spectralCrest,\n melBands\n};\n", "export default function ({\n ampSpectrum,\n chromaFilterBank,\n}: {\n ampSpectrum: Float32Array;\n chromaFilterBank: number[][];\n}): number[] {\n if (typeof ampSpectrum !== \"object\") {\n throw new TypeError(\"Valid ampSpectrum is required to generate chroma\");\n }\n if (typeof chromaFilterBank !== \"object\") {\n throw new TypeError(\n \"Valid chromaFilterBank is required to generate chroma\"\n );\n }\n\n var chromagram = chromaFilterBank.map((row, i) =>\n ampSpectrum.reduce((acc, v, j) => acc + v * row[j], 0)\n );\n var maxVal = Math.max(...chromagram);\n\n return maxVal ? chromagram.map((v) => v / maxVal) : chromagram;\n}\n", "export default function ({ signal }: { signal: Float32Array }): number {\n if (typeof signal !== \"object\") {\n throw new TypeError();\n }\n\n var energy = 0;\n for (var i = 0; i < signal.length; i++) {\n energy += Math.pow(Math.abs(signal[i]), 2);\n }\n\n return energy;\n}\n", "import extractMelBands from \"./melBands\";\nimport dct from \"dct\";\n\nexport default function ({\n ampSpectrum,\n melFilterBank,\n numberOfMFCCCoefficients,\n bufferSize,\n}: {\n ampSpectrum: Float32Array;\n melFilterBank: number[][];\n numberOfMFCCCoefficients: number;\n bufferSize: number;\n}): number[] {\n // Tutorial from:\n // http://practicalcryptography.com/miscellaneous/machine-learning\n // /guide-mel-frequency-cepstral-coefficients-mfccs/\n // @ts-ignore\n\n let _numberOfMFCCCoefficients = Math.min(\n 40,\n Math.max(1, numberOfMFCCCoefficients || 13)\n );\n\n let numFilters = melFilterBank.length;\n if (numFilters < _numberOfMFCCCoefficients) {\n throw new Error(\n \"Insufficient filter bank for requested number of coefficients\"\n );\n }\n const loggedMelBandsArray = extractMelBands({\n ampSpectrum,\n melFilterBank,\n bufferSize,\n });\n let mfccs: number[] = dct(loggedMelBandsArray).slice(\n 0,\n _numberOfMFCCCoefficients\n );\n\n return mfccs;\n}\n", "import loudness from \"./loudness\";\n\nexport default function ({\n ampSpectrum,\n barkScale,\n}: {\n ampSpectrum: Float32Array;\n barkScale: Float32Array;\n}): number {\n var loudnessValue = loudness({ ampSpectrum, barkScale });\n var spec = loudnessValue.specific;\n var output = 0;\n\n for (var i = 0; i < spec.length; i++) {\n if (i < 15) {\n output += (i + 1) * spec[i + 1];\n } else {\n output += 0.066 * Math.exp(0.171 * (i + 1));\n }\n }\n\n output *= 0.11 / loudnessValue.total;\n\n return output;\n}\n", "import loudness from \"./loudness\";\n\nexport default function ({\n ampSpectrum,\n barkScale,\n}: {\n ampSpectrum: Float32Array;\n barkScale: Float32Array;\n}): number {\n var loudnessValue = loudness({ ampSpectrum, barkScale });\n\n var max = 0;\n for (var i = 0; i < loudnessValue.specific.length; i++) {\n if (loudnessValue.specific[i] > max) {\n max = loudnessValue.specific[i];\n }\n }\n\n var spread = Math.pow((loudnessValue.total - max) / loudnessValue.total, 2);\n\n return spread;\n}\n", "export default function ({ signal }: { signal: Float32Array }): number {\n // Keeping this bad runtime typecheck for consistency\n if (typeof signal !== \"object\") {\n throw new TypeError();\n }\n\n var rms = 0;\n for (var i = 0; i < signal.length; i++) {\n rms += Math.pow(signal[i], 2);\n }\n\n rms = rms / signal.length;\n rms = Math.sqrt(rms);\n\n return rms;\n}\n", "import { mu } from \"./extractorUtilities\";\n\nexport default function ({\n ampSpectrum,\n}: {\n ampSpectrum: Float32Array;\n}): number {\n if (typeof ampSpectrum !== \"object\") {\n throw new TypeError();\n }\n\n return mu(1, ampSpectrum);\n}\n", "export default function ({\n ampSpectrum,\n}: {\n ampSpectrum: Float32Array;\n}): number {\n if (typeof ampSpectrum !== \"object\") {\n throw new TypeError();\n }\n\n var rms = 0;\n var peak = -Infinity;\n\n ampSpectrum.forEach((x) => {\n rms += Math.pow(x, 2);\n peak = x > peak ? x : peak;\n });\n\n rms = rms / ampSpectrum.length;\n rms = Math.sqrt(rms);\n\n return peak / rms;\n}\n", "export default function ({\n ampSpectrum,\n}: {\n ampSpectrum: Float32Array;\n}): number {\n if (typeof ampSpectrum !== \"object\") {\n throw new TypeError();\n }\n\n var numerator = 0;\n var denominator = 0;\n for (var i = 0; i < ampSpectrum.length; i++) {\n numerator += Math.log(ampSpectrum[i]);\n denominator += ampSpectrum[i];\n }\n\n return (\n (Math.exp(numerator / ampSpectrum.length) * ampSpectrum.length) /\n denominator\n );\n}\n", "// This file isn't being typechecked at all because there are major issues with it.\n// See #852 for details. Once that's merged, this file should be typechecked.\n// @ts-nocheck\nexport default function ({\n signal,\n previousSignal,\n bufferSize,\n}: {\n signal: Float32Array;\n previousSignal: Float32Array;\n bufferSize: number;\n}): number {\n if (typeof signal !== \"object\" || typeof previousSignal != \"object\") {\n throw new TypeError();\n }\n\n let sf = 0;\n for (let i = -(bufferSize / 2); i < signal.length / 2 - 1; i++) {\n x = Math.abs(signal[i]) - Math.abs(previousSignal[i]);\n sf += (x + Math.abs(x)) / 2;\n }\n\n return sf;\n}\n", "import { mu } from \"./extractorUtilities\";\n\nexport default function ({\n ampSpectrum,\n}: {\n ampSpectrum: Float32Array;\n}): number {\n if (typeof ampSpectrum !== \"object\") {\n throw new TypeError();\n }\n\n var ampspec = ampSpectrum;\n var mu1 = mu(1, ampspec);\n var mu2 = mu(2, ampspec);\n var mu3 = mu(3, ampspec);\n var mu4 = mu(4, ampspec);\n var numerator = -3 * Math.pow(mu1, 4) + 6 * mu1 * mu2 - 4 * mu1 * mu3 + mu4;\n var denominator = Math.pow(Math.sqrt(mu2 - Math.pow(mu1, 2)), 4);\n return numerator / denominator;\n}\n", "export default function ({\n ampSpectrum,\n sampleRate,\n}: {\n ampSpectrum: Float32Array;\n sampleRate: number;\n}): number {\n if (typeof ampSpectrum !== \"object\") {\n throw new TypeError();\n }\n\n var ampspec = ampSpectrum;\n\n //calculate nyquist bin\n var nyqBin = sampleRate / (2 * (ampspec.length - 1));\n var ec = 0;\n for (var i = 0; i < ampspec.length; i++) {\n ec += ampspec[i];\n }\n\n var threshold = 0.99 * ec;\n var n = ampspec.length - 1;\n while (ec > threshold && n >= 0) {\n ec -= ampspec[n];\n --n;\n }\n\n return (n + 1) * nyqBin;\n}\n", "import { mu } from \"./extractorUtilities\";\n\nexport default function ({\n ampSpectrum,\n}: {\n ampSpectrum: Float32Array;\n}): number {\n if (typeof ampSpectrum !== \"object\") {\n throw new TypeError();\n }\n\n var mu1 = mu(1, ampSpectrum);\n var mu2 = mu(2, ampSpectrum);\n var mu3 = mu(3, ampSpectrum);\n var numerator = 2 * Math.pow(mu1, 3) - 3 * mu1 * mu2 + mu3;\n var denominator = Math.pow(Math.sqrt(mu2 - Math.pow(mu1, 2)), 3);\n return numerator / denominator;\n}\n", "export default function ({\n ampSpectrum,\n sampleRate,\n bufferSize,\n}: {\n ampSpectrum: Float32Array;\n sampleRate: number;\n bufferSize: number;\n}): number {\n if (typeof ampSpectrum !== \"object\") {\n throw new TypeError();\n }\n\n //linear regression\n let ampSum = 0;\n let freqSum = 0;\n let freqs = new Float32Array(ampSpectrum.length);\n let powFreqSum = 0;\n let ampFreqSum = 0;\n\n for (var i = 0; i < ampSpectrum.length; i++) {\n ampSum += ampSpectrum[i];\n let curFreq = (i * sampleRate) / bufferSize;\n freqs[i] = curFreq;\n powFreqSum += curFreq * curFreq;\n freqSum += curFreq;\n ampFreqSum += curFreq * ampSpectrum[i];\n }\n\n return (\n (ampSpectrum.length * ampFreqSum - freqSum * ampSum) /\n (ampSum * (powFreqSum - Math.pow(freqSum, 2)))\n );\n}\n", "import { mu } from \"./extractorUtilities\";\n\nexport default function ({\n ampSpectrum,\n}: {\n ampSpectrum: Float32Array;\n}): number {\n if (typeof ampSpectrum !== \"object\") {\n throw new TypeError();\n }\n\n return Math.sqrt(mu(2, ampSpectrum) - Math.pow(mu(1, ampSpectrum), 2));\n}\n", "export default function ({ signal }: { signal: Float32Array }): number {\n if (typeof signal !== \"object\") {\n throw new TypeError();\n }\n\n var zcr = 0;\n for (var i = 1; i < signal.length; i++) {\n if (\n (signal[i - 1] >= 0 && signal[i] < 0) ||\n (signal[i - 1] < 0 && signal[i] >= 0)\n ) {\n zcr++;\n }\n }\n\n return zcr;\n}\n", "import * as utilities from \"./utilities\";\nimport * as featureExtractors from \"./featureExtractors\";\nimport type {\n MeydaAudioFeature,\n MeydaWindowingFunction,\n MeydaFeaturesObject,\n} from \"./main\";\n\n/**\n * MeydaAnalyzerOptions\n */\nexport interface MeydaAnalyzerOptions {\n /**\n * The Audio Context for the MeydaAnalyzer to operate in.\n */\n audioContext: AudioContext;\n /**\n * The Audio Node for Meyda to listen to.\n */\n source: AudioNode;\n /**\n * The size of the buffer.\n */\n bufferSize: number;\n /**\n * The number of samples between the start of each buffer.\n */\n hopSize?: number | undefined;\n /**\n * The number of samples per second in the audioContext.\n */\n sampleRate?: number | undefined;\n /**\n * Pass `true` to start feature extraction immediately\n */\n startImmediately?: boolean | undefined;\n /**\n * The channel from the input node to listen to\n */\n channel?: number | undefined;\n /**\n * The Windowing Function to apply to the signal before transformation to the frequency domain.\n */\n windowingFunction?: MeydaWindowingFunction | undefined;\n /**\n * What feature extractors to return to the callback.\n */\n featureExtractors?:\n | MeydaAudioFeature\n | ReadonlyArray\n | undefined;\n inputs?: number | undefined;\n outputs?: number | undefined;\n /**\n * The number of mfcc coefficients to calculate for each buffer.\n */\n numberOfMFCCCoefficients?: number | undefined;\n /**\n * The number of bark bands to calculate for use in feature extractors.\n */\n numberOfBarkBands?: number | undefined;\n /**\n * The callback to receive your audio features. Will be called once for each buffer of input audio.\n */\n callback?: ((features: Partial) => void) | undefined;\n}\n\n/**\n * Meyda's interface to the Web Audio API. MeydaAnalyzer abstracts an API on\n * top of the Web Audio API's ScriptProcessorNode, running the Meyda audio\n * feature extractors inside that context.\n *\n * MeydaAnalyzer's constructor should not be called directly - MeydaAnalyzer\n * objects should be generated using the {@link createMeydaAnalyzer}\n * factory function in the main Meyda class.\n *\n * Options are of type {@link MeydaAnalyzerOptions}.\n *\n * @example\n * ```javascript\n * const analyzer = Meyda.createMeydaAnalyzer({\n * \"audioContext\": audioContext,\n * \"source\": source,\n * \"bufferSize\": 512,\n * \"featureExtractors\": [\"rms\"],\n * \"inputs\": 2,\n * \"numberOfMFCCCoefficients\": 20\n * \"callback\": features => {\n * levelRangeElement.value = features.rms;\n * }\n * });\n * ```\n */\nexport class MeydaAnalyzer {\n /** @hidden */\n _m: any;\n\n /** @hidden */\n constructor(options: MeydaAnalyzerOptions, _this) {\n this._m = _this;\n if (!options.audioContext) {\n throw this._m.errors.noAC;\n } else if (\n options.bufferSize &&\n !utilities.isPowerOfTwo(options.bufferSize)\n ) {\n throw this._m._errors.notPow2;\n } else if (!options.source) {\n throw this._m._errors.noSource;\n }\n\n this._m.audioContext = options.audioContext;\n\n // TODO: validate options\n this._m.bufferSize = options.bufferSize || this._m.bufferSize || 256;\n this._m.hopSize = options.hopSize || this._m.hopSize || this._m.bufferSize;\n this._m.sampleRate =\n options.sampleRate || this._m.audioContext.sampleRate || 44100;\n this._m.callback = options.callback;\n this._m.windowingFunction = options.windowingFunction || \"hanning\";\n this._m.featureExtractors = featureExtractors;\n this._m.EXTRACTION_STARTED = options.startImmediately || false;\n this._m.channel = typeof options.channel === \"number\" ? options.channel : 0;\n this._m.inputs = options.inputs || 1;\n this._m.outputs = options.outputs || 1;\n this._m.numberOfMFCCCoefficients =\n options.numberOfMFCCCoefficients ||\n this._m.numberOfMFCCCoefficients ||\n 13;\n this._m.numberOfBarkBands =\n options.numberOfBarkBands || this._m.numberOfBarkBands || 24;\n\n //create nodes\n this._m.spn = this._m.audioContext.createScriptProcessor(\n this._m.bufferSize,\n this._m.inputs,\n this._m.outputs\n );\n this._m.spn.connect(this._m.audioContext.destination);\n\n this._m._featuresToExtract = options.featureExtractors || [];\n\n //always recalculate BS and MFB when a new Meyda analyzer is created.\n this._m.barkScale = utilities.createBarkScale(\n this._m.bufferSize,\n this._m.sampleRate,\n this._m.bufferSize\n );\n this._m.melFilterBank = utilities.createMelFilterBank(\n Math.max(this._m.melBands, this._m.numberOfMFCCCoefficients),\n this._m.sampleRate,\n this._m.bufferSize\n );\n\n this._m.inputData = null;\n this._m.previousInputData = null;\n\n this._m.frame = null;\n this._m.previousFrame = null;\n\n this.setSource(options.source);\n\n this._m.spn.onaudioprocess = (e) => {\n var buffer;\n if (this._m.inputData !== null) {\n this._m.previousInputData = this._m.inputData;\n }\n\n this._m.inputData = e.inputBuffer.getChannelData(this._m.channel);\n\n if (!this._m.previousInputData) {\n buffer = this._m.inputData;\n } else {\n buffer = new Float32Array(\n this._m.previousInputData.length +\n this._m.inputData.length -\n this._m.hopSize\n );\n buffer.set(this._m.previousInputData.slice(this._m.hopSize));\n buffer.set(\n this._m.inputData,\n this._m.previousInputData.length - this._m.hopSize\n );\n }\n\n var frames = utilities.frame(buffer, this._m.bufferSize, this._m.hopSize);\n\n frames.forEach((f) => {\n this._m.frame = f;\n\n var features = this._m.extract(\n this._m._featuresToExtract,\n this._m.frame,\n this._m.previousFrame\n );\n\n // call callback if applicable\n if (\n typeof this._m.callback === \"function\" &&\n this._m.EXTRACTION_STARTED\n ) {\n this._m.callback(features);\n }\n\n this._m.previousFrame = this._m.frame;\n });\n };\n }\n\n /**\n * Start feature extraction\n * The audio features will be passed to the callback function that was defined\n * in the MeydaOptions that were passed to the factory when constructing the\n * MeydaAnalyzer.\n * @param {(string|Array.)} [features]\n * Change the features that Meyda is extracting. Defaults to the features that\n * were set upon construction in the options parameter.\n * @example\n * ```javascript\n * analyzer.start('chroma');\n * ```\n */\n start(features?: MeydaAudioFeature | ReadonlyArray): void {\n this._m._featuresToExtract = features || this._m._featuresToExtract;\n this._m.EXTRACTION_STARTED = true;\n }\n\n /**\n * Stop feature extraction.\n * @example\n * ```javascript\n * analyzer.stop();\n * ```\n */\n stop(): void {\n this._m.EXTRACTION_STARTED = false;\n }\n\n /**\n * Set the Audio Node for Meyda to listen to.\n * @param {AudioNode} source - The Audio Node for Meyda to listen to\n * @example\n * ```javascript\n * analyzer.setSource(audioSourceNode);\n * ```\n */\n setSource(source: AudioNode): void {\n this._m.source && this._m.source.disconnect(this._m.spn);\n this._m.source = source;\n this._m.source.connect(this._m.spn);\n }\n\n /**\n * Set the channel of the audio node for Meyda to listen to\n * @param {number} channel - the index of the channel on the input audio node\n * for Meyda to listen to.\n * @example\n * ```javascript\n * analyzer.setChannel(0);\n * ```\n */\n setChannel(channel: number) {\n if (channel <= this._m.inputs) {\n this._m.channel = channel;\n } else {\n console.error(\n `Channel ${channel} does not exist. Make sure you've provided a value for 'inputs' that is greater than ${channel} when instantiating the MeydaAnalyzer`\n );\n }\n }\n\n /**\n * Get a set of features from the current frame.\n * @param {(string|Array.)} [features]\n * Change the features that Meyda is extracting\n * @example\n * ```javascript\n * analyzer.get('spectralFlatness');\n * ```\n */\n get(\n features?: MeydaAudioFeature | ReadonlyArray\n ): Partial | null {\n if (this._m.inputData) {\n return this._m.extract(\n features || this._m._featuresToExtract,\n this._m.inputData,\n this._m.previousInputData\n );\n } else {\n return null;\n }\n }\n}\n", "/**\n * This file contains the default export for Meyda, you probably want to check\n * out {@link default}\n *\n * @module Meyda\n */\n\nimport * as utilities from \"./utilities\";\nimport * as extractors from \"./featureExtractors\";\nimport { fft } from \"fftjs\";\nimport { MeydaAnalyzer, MeydaAnalyzerOptions } from \"./meyda-wa\";\nexport interface MeydaFeaturesObject {\n amplitudeSpectrum: Float32Array;\n buffer: number[];\n chroma: number[];\n complexSpectrum: {\n real: number[];\n imag: number[];\n };\n energy: number;\n loudness: {\n specific: Float32Array;\n total: number;\n };\n mfcc: number[];\n perceptualSharpness: number;\n perceptualSpread: number;\n powerSpectrum: Float32Array;\n rms: number;\n spectralCentroid: number;\n spectralFlatness: number;\n spectralKurtosis: number;\n spectralRolloff: number;\n spectralSkewness: number;\n spectralSlope: number;\n spectralSpread: number;\n spectralCrest: number;\n zcr: number;\n}\n\nexport type MeydaWindowingFunction =\n | \"blackman\"\n | \"sine\"\n | \"hanning\"\n | \"hamming\";\n\nexport type MeydaAudioFeature =\n | \"amplitudeSpectrum\"\n | \"chroma\"\n | \"complexSpectrum\"\n | \"energy\"\n | \"loudness\"\n | \"mfcc\"\n | \"perceptualSharpness\"\n | \"perceptualSpread\"\n | \"powerSpectrum\"\n | \"rms\"\n | \"spectralCentroid\"\n | \"spectralFlatness\"\n | \"spectralFlux\"\n | \"spectralKurtosis\"\n | \"spectralRolloff\"\n | \"spectralSkewness\"\n | \"spectralSlope\"\n | \"spectralSpread\"\n | \"spectralCrest\"\n | \"zcr\"\n | \"buffer\"\n | \"melBands\";\n\n/**\n * A type representing an audio signal. In general it should be an array of\n * numbers that is sliceable. Float32Array is assignable here, and we generally\n * expect that most signals will be in this format.\n */\nexport type MeydaSignal = SliceableArrayLike | Float32Array;\n\nexport interface SliceableArrayLike extends ArrayLike {\n slice(start: number, end: number): SliceableArrayLike;\n}\n\n/**\n * Meyda is a library for extracting audio features from an audio signal.\n *\n * The primary entry points are {@link extract} for audio feature extraction on\n * raw signals you have in memory, and {@link createMeydaAnalyzer}, which\n * provides a {@link MeydaAnalyzer} object that can be used to extract features\n * on a Web Audio API AudioNode. The latter is only supported on web targets,\n * though if you're using the Web Audio API in a non-web target, we'd love to\n * hear from you.\n *\n * We also expose {@link listAvailableFeatureExtractors} which returns a list of the\n * available feature extractors, and {@link windowing}, which lets you apply\n * a windowing function to your signal outside of Meyda.\n *\n * We existed long before esmodules, so our backwards compatible API may seem\n * unusual. We export a default object, with read/write fields that control\n * various parameters of the audio feature extraction process. We're working on\n * a new interface, check out [#257](https://github.com/meyda/meyda/issues/257)\n * for more information.\n */\ninterface Meyda {\n /**\n * Meyda stores a reference to the relevant audio context here for use inside\n * the Web Audio API.\n */\n audioContext: AudioContext | null;\n /**\n * Meyda keeps an internal ScriptProcessorNode in which it runs audio feature\n * extraction. The ScriptProcessorNode is stored in this member variable.\n * @hidden\n */\n spn: ScriptProcessorNode | null;\n /**\n * The length of each buffer that Meyda will extract audio on. When recieving\n * input via the Web Audio API, the Script Processor Node chunks incoming audio\n * into arrays of this length. Longer buffers allow for more precision in the\n * frequency domain, but increase the amount of time it takes for Meyda to\n * output a set of audio features for the buffer. You can calculate how many\n * sets of audio features Meyda will output per second by dividing the\n * buffer size by the sample rate. If you're using Meyda for visualisation,\n * make sure that you're collecting audio features at a rate that's faster\n * than or equal to the video frame rate you expect.\n */\n bufferSize: number;\n /**\n * The number of samples per second of the incoming audio. This affects\n * feature extraction outside of the context of the Web Audio API, and must be\n * set accurately - otherwise calculations will be off.\n */\n sampleRate: number;\n /**\n * The number of Mel bands to use in the Mel Frequency Cepstral Co-efficients\n * feature extractor\n */\n melBands: number;\n /**\n * The number of bands to divide the spectrum into for the Chroma feature\n * extractor. 12 is the standard number of semitones per octave in the western\n * music tradition, but Meyda can use an arbitrary number of bands, which\n * can be useful for microtonal music.\n */\n chromaBands: number;\n /**\n * A function you can provide that will be called for each buffer that Meyda\n * receives from its source node\n * @hidden\n */\n callback: ((features: Partial) => void | null) | null;\n /**\n * Specify the windowing function to apply to the buffer before the\n * transformation from the time domain to the frequency domain is performed\n *\n * The default windowing function is the hanning window.\n */\n windowingFunction: string;\n featureExtractors: any;\n /** @hidden */\n EXTRACTION_STARTED: boolean;\n /**\n * The number of MFCC co-efficients that the MFCC feature extractor should return\n */\n numberOfMFCCCoefficients: number;\n /**\n * The number of bark bands that the loudness feature extractor should return\n */\n numberOfBarkBands: number;\n /** @hidden */\n _featuresToExtract: string[];\n /**\n * Apply a windowing function to a signal\n */\n windowing: (\n signal: MeydaSignal,\n windowname?: MeydaWindowingFunction\n ) => MeydaSignal;\n /** @hidden */\n _errors: { [key: string]: Error };\n /**\n * @summary\n * Create a MeydaAnalyzer\n *\n * A factory function for creating a MeydaAnalyzer, the interface for using\n * Meyda in the context of Web Audio.\n *\n * @example\n * ```javascript\n * const analyzer = Meyda.createMeydaAnalyzer({\n * \"audioContext\": audioContext,\n * \"source\": source,\n * \"bufferSize\": 512,\n * \"featureExtractors\": [\"rms\"],\n * \"inputs\": 2,\n * \"callback\": features => {\n * levelRangeElement.value = features.rms;\n * }\n * });\n * ```\n */\n createMeydaAnalyzer: (MeydaAnalyzerOptions) => MeydaAnalyzer;\n /**\n * List available audio feature extractors. Return format provides the key to\n * be used in selecting the extractor in the extract methods\n */\n listAvailableFeatureExtractors: () => MeydaAudioFeature[];\n /**\n * Extract an audio feature from a buffer\n *\n * Unless `meyda.windowingFunction` is set otherwise, `extract` will\n * internally apply a hanning window to the buffer prior to conversion into\n * the frequency domain.\n *\n * @param {(string|Array.)} feature - the feature you want to extract\n * @param {Array.} signal\n * An array of numbers that represents the signal. It should be of length\n * `meyda.bufferSize`\n * @param {Array.} [previousSignal] - the previous buffer\n * @returns {object} Features\n * @example\n * ```javascript\n * meyda.bufferSize = 2048;\n * const features = meyda.extract(['zcr', 'spectralCentroid'], signal);\n * ```\n *\n * Aside: yes, you need to modify the value of a field of the default export\n * of the package to change the buffer size. We realise this now seems not\n * a good practice. See [this issue](https://github.com/meyda/meyda/issues/257)\n * to track our progress on implementing a more modern API.\n */\n extract: (\n feature: MeydaAudioFeature | MeydaAudioFeature[],\n signal: MeydaSignal,\n previousSignal?: MeydaSignal\n ) => Partial | null;\n}\n\nconst Meyda: Meyda = {\n audioContext: null,\n spn: null,\n bufferSize: 512,\n sampleRate: 44100,\n melBands: 26,\n chromaBands: 12,\n callback: null,\n windowingFunction: \"hanning\",\n featureExtractors: extractors,\n EXTRACTION_STARTED: false,\n numberOfMFCCCoefficients: 13,\n numberOfBarkBands: 24,\n _featuresToExtract: [],\n windowing: utilities.applyWindow,\n /** @hidden */\n _errors: {\n notPow2: new Error(\n \"Meyda: Buffer size must be a power of 2, e.g. 64 or 512\"\n ),\n featureUndef: new Error(\"Meyda: No features defined.\"),\n invalidFeatureFmt: new Error(\"Meyda: Invalid feature format\"),\n invalidInput: new Error(\"Meyda: Invalid input.\"),\n noAC: new Error(\"Meyda: No AudioContext specified.\"),\n noSource: new Error(\"Meyda: No source node specified.\"),\n },\n\n /**\n * @summary\n * Create a MeydaAnalyzer\n *\n * A factory function for creating a MeydaAnalyzer, the interface for using\n * Meyda in the context of Web Audio.\n *\n * ```javascript\n * const analyzer = Meyda.createMeydaAnalyzer({\n * \"audioContext\": audioContext,\n * \"source\": source,\n * \"bufferSize\": 512,\n * \"featureExtractors\": [\"rms\"],\n * \"inputs\": 2,\n * \"callback\": features => {\n * levelRangeElement.value = features.rms;\n * }\n * });\n * ```\n */\n createMeydaAnalyzer,\n /**\n * List available audio feature extractors. Return format provides the key to\n * be used in selecting the extractor in the extract methods\n */\n listAvailableFeatureExtractors,\n /**\n * Extract an audio feature from a buffer\n *\n * Unless `meyda.windowingFunction` is set otherwise, `extract` will\n * internally apply a hanning window to the buffer prior to conversion into\n * the frequency domain.\n *\n * ```javascript\n * meyda.bufferSize = 2048;\n * const features = meyda.extract(['zcr', 'spectralCentroid'], signal);\n * ```\n */\n extract: function (feature, signal, previousSignal) {\n if (!signal) throw this._errors.invalidInput;\n else if (typeof signal != \"object\") throw this._errors.invalidInput;\n else if (!feature) throw this._errors.featureUndef;\n else if (!utilities.isPowerOfTwo(signal.length)) throw this._errors.notPow2;\n\n if (\n typeof this.barkScale == \"undefined\" ||\n this.barkScale.length != this.bufferSize\n ) {\n this.barkScale = utilities.createBarkScale(\n this.bufferSize,\n this.sampleRate,\n this.bufferSize\n );\n }\n\n // Recalculate mel bank if buffer length changed\n if (\n typeof this.melFilterBank == \"undefined\" ||\n this.barkScale.length != this.bufferSize ||\n this.melFilterBank.length != this.melBands\n ) {\n this.melFilterBank = utilities.createMelFilterBank(\n Math.max(this.melBands, this.numberOfMFCCCoefficients),\n this.sampleRate,\n this.bufferSize\n );\n }\n\n // Recalculate chroma bank if buffer length changed\n if (\n typeof this.chromaFilterBank == \"undefined\" ||\n this.chromaFilterBank.length != this.chromaBands\n ) {\n this.chromaFilterBank = utilities.createChromaFilterBank(\n this.chromaBands,\n this.sampleRate,\n this.bufferSize\n );\n }\n\n if (\"buffer\" in signal && typeof signal.buffer == \"undefined\") {\n //signal is a normal array, convert to F32A\n this.signal = utilities.arrayToTyped(signal);\n } else {\n this.signal = signal;\n }\n\n let preparedSignal = prepareSignalWithSpectrum(\n signal,\n this.windowingFunction,\n this.bufferSize\n );\n\n this.signal = preparedSignal.windowedSignal;\n this.complexSpectrum = preparedSignal.complexSpectrum;\n this.ampSpectrum = preparedSignal.ampSpectrum;\n\n if (previousSignal) {\n let preparedSignal = prepareSignalWithSpectrum(\n previousSignal,\n this.windowingFunction,\n this.bufferSize\n );\n\n this.previousSignal = preparedSignal.windowedSignal;\n this.previousComplexSpectrum = preparedSignal.complexSpectrum;\n this.previousAmpSpectrum = preparedSignal.ampSpectrum;\n }\n\n const extract = (feature) => {\n return this.featureExtractors[feature]({\n ampSpectrum: this.ampSpectrum,\n chromaFilterBank: this.chromaFilterBank,\n complexSpectrum: this.complexSpectrum,\n signal: this.signal,\n bufferSize: this.bufferSize,\n sampleRate: this.sampleRate,\n barkScale: this.barkScale,\n melFilterBank: this.melFilterBank,\n previousSignal: this.previousSignal,\n previousAmpSpectrum: this.previousAmpSpectrum,\n previousComplexSpectrum: this.previousComplexSpectrum,\n numberOfMFCCCoefficients: this.numberOfMFCCCoefficients,\n numberOfBarkBands: this.numberOfBarkBands,\n });\n };\n\n if (typeof feature === \"object\") {\n return feature.reduce(\n (acc, el) =>\n Object.assign({}, acc, {\n [el]: extract(el),\n }),\n {}\n );\n } else if (typeof feature === \"string\") {\n return extract(feature);\n } else {\n throw this._errors.invalidFeatureFmt;\n }\n },\n};\n\nvar prepareSignalWithSpectrum = function (\n signal,\n windowingFunction,\n bufferSize\n) {\n var preparedSignal: any = {};\n\n if (typeof signal.buffer == \"undefined\") {\n //signal is a normal array, convert to F32A\n preparedSignal.signal = utilities.arrayToTyped(signal);\n } else {\n preparedSignal.signal = signal;\n }\n\n preparedSignal.windowedSignal = utilities.applyWindow(\n preparedSignal.signal,\n windowingFunction\n );\n\n preparedSignal.complexSpectrum = fft(preparedSignal.windowedSignal);\n preparedSignal.ampSpectrum = new Float32Array(bufferSize / 2);\n for (var i = 0; i < bufferSize / 2; i++) {\n preparedSignal.ampSpectrum[i] = Math.sqrt(\n Math.pow(preparedSignal.complexSpectrum.real[i], 2) +\n Math.pow(preparedSignal.complexSpectrum.imag[i], 2)\n );\n }\n\n return preparedSignal;\n};\n\nexport default Meyda;\n\n/**\n * List available audio feature extractors. Return format provides the key to\n * be used in selecting the extractor in the extract methods\n */\nfunction listAvailableFeatureExtractors(): MeydaAudioFeature[] {\n return Object.keys(this.featureExtractors) as MeydaAudioFeature[];\n}\n\n/**\n * Create a MeydaAnalyzer\n *\n * A factory function for creating a MeydaAnalyzer, the interface for using\n * Meyda in the context of Web Audio.\n *\n * ```javascript\n * const analyzer = Meyda.createMeydaAnalyzer({\n * \"audioContext\": audioContext,\n * \"source\": source,\n * \"bufferSize\": 512,\n * \"featureExtractors\": [\"rms\"],\n * \"inputs\": 2,\n * \"callback\": features => {\n * levelRangeElement.value = features.rms;\n * }\n * });\n * ```\n */\nfunction createMeydaAnalyzer(options) {\n return new MeydaAnalyzer(options, Object.assign({}, Meyda));\n}\n\n/**\n * Apply a windowing function to a signal\n */\nfunction windowing(\n signal: MeydaSignal,\n windowname: MeydaWindowingFunction\n): MeydaSignal {\n return utilities.applyWindow(signal, windowname);\n}\n\n// @ts-ignore\nif (typeof window !== \"undefined\") window.Meyda = Meyda;\n", "(function (global, factory) {\n typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :\n typeof define === 'function' && define.amd ? define(factory) :\n (global.createREGL = factory());\n}(this, (function () { 'use strict';\n\nvar isTypedArray = function (x) {\n return (\n x instanceof Uint8Array ||\n x instanceof Uint16Array ||\n x instanceof Uint32Array ||\n x instanceof Int8Array ||\n x instanceof Int16Array ||\n x instanceof Int32Array ||\n x instanceof Float32Array ||\n x instanceof Float64Array ||\n x instanceof Uint8ClampedArray\n )\n}\n\nvar extend = function (base, opts) {\n var keys = Object.keys(opts)\n for (var i = 0; i < keys.length; ++i) {\n base[keys[i]] = opts[keys[i]]\n }\n return base\n}\n\n// Error checking and parameter validation.\n//\n// Statements for the form `check.someProcedure(...)` get removed by\n// a browserify transform for optimized/minified bundles.\n//\n/* globals atob */\nvar endl = '\\n'\n\n// only used for extracting shader names. if atob not present, then errors\n// will be slightly crappier\nfunction decodeB64 (str) {\n if (typeof atob !== 'undefined') {\n return atob(str)\n }\n return 'base64:' + str\n}\n\nfunction raise (message) {\n var error = new Error('(regl) ' + message)\n console.error(error)\n throw error\n}\n\nfunction check (pred, message) {\n if (!pred) {\n raise(message)\n }\n}\n\nfunction encolon (message) {\n if (message) {\n return ': ' + message\n }\n return ''\n}\n\nfunction checkParameter (param, possibilities, message) {\n if (!(param in possibilities)) {\n raise('unknown parameter (' + param + ')' + encolon(message) +\n '. possible values: ' + Object.keys(possibilities).join())\n }\n}\n\nfunction checkIsTypedArray (data, message) {\n if (!isTypedArray(data)) {\n raise(\n 'invalid parameter type' + encolon(message) +\n '. must be a typed array')\n }\n}\n\nfunction standardTypeEh (value, type) {\n switch (type) {\n case 'number': return typeof value === 'number'\n case 'object': return typeof value === 'object'\n case 'string': return typeof value === 'string'\n case 'boolean': return typeof value === 'boolean'\n case 'function': return typeof value === 'function'\n case 'undefined': return typeof value === 'undefined'\n case 'symbol': return typeof value === 'symbol'\n }\n}\n\nfunction checkTypeOf (value, type, message) {\n if (!standardTypeEh(value, type)) {\n raise(\n 'invalid parameter type' + encolon(message) +\n '. expected ' + type + ', got ' + (typeof value))\n }\n}\n\nfunction checkNonNegativeInt (value, message) {\n if (!((value >= 0) &&\n ((value | 0) === value))) {\n raise('invalid parameter type, (' + value + ')' + encolon(message) +\n '. must be a nonnegative integer')\n }\n}\n\nfunction checkOneOf (value, list, message) {\n if (list.indexOf(value) < 0) {\n raise('invalid value' + encolon(message) + '. must be one of: ' + list)\n }\n}\n\nvar constructorKeys = [\n 'gl',\n 'canvas',\n 'container',\n 'attributes',\n 'pixelRatio',\n 'extensions',\n 'optionalExtensions',\n 'profile',\n 'onDone'\n]\n\nfunction checkConstructor (obj) {\n Object.keys(obj).forEach(function (key) {\n if (constructorKeys.indexOf(key) < 0) {\n raise('invalid regl constructor argument \"' + key + '\". must be one of ' + constructorKeys)\n }\n })\n}\n\nfunction leftPad (str, n) {\n str = str + ''\n while (str.length < n) {\n str = ' ' + str\n }\n return str\n}\n\nfunction ShaderFile () {\n this.name = 'unknown'\n this.lines = []\n this.index = {}\n this.hasErrors = false\n}\n\nfunction ShaderLine (number, line) {\n this.number = number\n this.line = line\n this.errors = []\n}\n\nfunction ShaderError (fileNumber, lineNumber, message) {\n this.file = fileNumber\n this.line = lineNumber\n this.message = message\n}\n\nfunction guessCommand () {\n var error = new Error()\n var stack = (error.stack || error).toString()\n var pat = /compileProcedure.*\\n\\s*at.*\\((.*)\\)/.exec(stack)\n if (pat) {\n return pat[1]\n }\n var pat2 = /compileProcedure.*\\n\\s*at\\s+(.*)(\\n|$)/.exec(stack)\n if (pat2) {\n return pat2[1]\n }\n return 'unknown'\n}\n\nfunction guessCallSite () {\n var error = new Error()\n var stack = (error.stack || error).toString()\n var pat = /at REGLCommand.*\\n\\s+at.*\\((.*)\\)/.exec(stack)\n if (pat) {\n return pat[1]\n }\n var pat2 = /at REGLCommand.*\\n\\s+at\\s+(.*)\\n/.exec(stack)\n if (pat2) {\n return pat2[1]\n }\n return 'unknown'\n}\n\nfunction parseSource (source, command) {\n var lines = source.split('\\n')\n var lineNumber = 1\n var fileNumber = 0\n var files = {\n unknown: new ShaderFile(),\n 0: new ShaderFile()\n }\n files.unknown.name = files[0].name = command || guessCommand()\n files.unknown.lines.push(new ShaderLine(0, ''))\n for (var i = 0; i < lines.length; ++i) {\n var line = lines[i]\n var parts = /^\\s*#\\s*(\\w+)\\s+(.+)\\s*$/.exec(line)\n if (parts) {\n switch (parts[1]) {\n case 'line':\n var lineNumberInfo = /(\\d+)(\\s+\\d+)?/.exec(parts[2])\n if (lineNumberInfo) {\n lineNumber = lineNumberInfo[1] | 0\n if (lineNumberInfo[2]) {\n fileNumber = lineNumberInfo[2] | 0\n if (!(fileNumber in files)) {\n files[fileNumber] = new ShaderFile()\n }\n }\n }\n break\n case 'define':\n var nameInfo = /SHADER_NAME(_B64)?\\s+(.*)$/.exec(parts[2])\n if (nameInfo) {\n files[fileNumber].name = (nameInfo[1]\n ? decodeB64(nameInfo[2])\n : nameInfo[2])\n }\n break\n }\n }\n files[fileNumber].lines.push(new ShaderLine(lineNumber++, line))\n }\n Object.keys(files).forEach(function (fileNumber) {\n var file = files[fileNumber]\n file.lines.forEach(function (line) {\n file.index[line.number] = line\n })\n })\n return files\n}\n\nfunction parseErrorLog (errLog) {\n var result = []\n errLog.split('\\n').forEach(function (errMsg) {\n if (errMsg.length < 5) {\n return\n }\n var parts = /^ERROR:\\s+(\\d+):(\\d+):\\s*(.*)$/.exec(errMsg)\n if (parts) {\n result.push(new ShaderError(\n parts[1] | 0,\n parts[2] | 0,\n parts[3].trim()))\n } else if (errMsg.length > 0) {\n result.push(new ShaderError('unknown', 0, errMsg))\n }\n })\n return result\n}\n\nfunction annotateFiles (files, errors) {\n errors.forEach(function (error) {\n var file = files[error.file]\n if (file) {\n var line = file.index[error.line]\n if (line) {\n line.errors.push(error)\n file.hasErrors = true\n return\n }\n }\n files.unknown.hasErrors = true\n files.unknown.lines[0].errors.push(error)\n })\n}\n\nfunction checkShaderError (gl, shader, source, type, command) {\n if (!gl.getShaderParameter(shader, gl.COMPILE_STATUS)) {\n var errLog = gl.getShaderInfoLog(shader)\n var typeName = type === gl.FRAGMENT_SHADER ? 'fragment' : 'vertex'\n checkCommandType(source, 'string', typeName + ' shader source must be a string', command)\n var files = parseSource(source, command)\n var errors = parseErrorLog(errLog)\n annotateFiles(files, errors)\n\n Object.keys(files).forEach(function (fileNumber) {\n var file = files[fileNumber]\n if (!file.hasErrors) {\n return\n }\n\n var strings = ['']\n var styles = ['']\n\n function push (str, style) {\n strings.push(str)\n styles.push(style || '')\n }\n\n push('file number ' + fileNumber + ': ' + file.name + '\\n', 'color:red;text-decoration:underline;font-weight:bold')\n\n file.lines.forEach(function (line) {\n if (line.errors.length > 0) {\n push(leftPad(line.number, 4) + '| ', 'background-color:yellow; font-weight:bold')\n push(line.line + endl, 'color:red; background-color:yellow; font-weight:bold')\n\n // try to guess token\n var offset = 0\n line.errors.forEach(function (error) {\n var message = error.message\n var token = /^\\s*'(.*)'\\s*:\\s*(.*)$/.exec(message)\n if (token) {\n var tokenPat = token[1]\n message = token[2]\n switch (tokenPat) {\n case 'assign':\n tokenPat = '='\n break\n }\n offset = Math.max(line.line.indexOf(tokenPat, offset), 0)\n } else {\n offset = 0\n }\n\n push(leftPad('| ', 6))\n push(leftPad('^^^', offset + 3) + endl, 'font-weight:bold')\n push(leftPad('| ', 6))\n push(message + endl, 'font-weight:bold')\n })\n push(leftPad('| ', 6) + endl)\n } else {\n push(leftPad(line.number, 4) + '| ')\n push(line.line + endl, 'color:red')\n }\n })\n if (typeof document !== 'undefined' && !window.chrome) {\n styles[0] = strings.join('%c')\n console.log.apply(console, styles)\n } else {\n console.log(strings.join(''))\n }\n })\n\n check.raise('Error compiling ' + typeName + ' shader, ' + files[0].name)\n }\n}\n\nfunction checkLinkError (gl, program, fragShader, vertShader, command) {\n if (!gl.getProgramParameter(program, gl.LINK_STATUS)) {\n var errLog = gl.getProgramInfoLog(program)\n var fragParse = parseSource(fragShader, command)\n var vertParse = parseSource(vertShader, command)\n\n var header = 'Error linking program with vertex shader, \"' +\n vertParse[0].name + '\", and fragment shader \"' + fragParse[0].name + '\"'\n\n if (typeof document !== 'undefined') {\n console.log('%c' + header + endl + '%c' + errLog,\n 'color:red;text-decoration:underline;font-weight:bold',\n 'color:red')\n } else {\n console.log(header + endl + errLog)\n }\n check.raise(header)\n }\n}\n\nfunction saveCommandRef (object) {\n object._commandRef = guessCommand()\n}\n\nfunction saveDrawCommandInfo (opts, uniforms, attributes, stringStore) {\n saveCommandRef(opts)\n\n function id (str) {\n if (str) {\n return stringStore.id(str)\n }\n return 0\n }\n opts._fragId = id(opts.static.frag)\n opts._vertId = id(opts.static.vert)\n\n function addProps (dict, set) {\n Object.keys(set).forEach(function (u) {\n dict[stringStore.id(u)] = true\n })\n }\n\n var uniformSet = opts._uniformSet = {}\n addProps(uniformSet, uniforms.static)\n addProps(uniformSet, uniforms.dynamic)\n\n var attributeSet = opts._attributeSet = {}\n addProps(attributeSet, attributes.static)\n addProps(attributeSet, attributes.dynamic)\n\n opts._hasCount = (\n 'count' in opts.static ||\n 'count' in opts.dynamic ||\n 'elements' in opts.static ||\n 'elements' in opts.dynamic)\n}\n\nfunction commandRaise (message, command) {\n var callSite = guessCallSite()\n raise(message +\n ' in command ' + (command || guessCommand()) +\n (callSite === 'unknown' ? '' : ' called from ' + callSite))\n}\n\nfunction checkCommand (pred, message, command) {\n if (!pred) {\n commandRaise(message, command || guessCommand())\n }\n}\n\nfunction checkParameterCommand (param, possibilities, message, command) {\n if (!(param in possibilities)) {\n commandRaise(\n 'unknown parameter (' + param + ')' + encolon(message) +\n '. possible values: ' + Object.keys(possibilities).join(),\n command || guessCommand())\n }\n}\n\nfunction checkCommandType (value, type, message, command) {\n if (!standardTypeEh(value, type)) {\n commandRaise(\n 'invalid parameter type' + encolon(message) +\n '. expected ' + type + ', got ' + (typeof value),\n command || guessCommand())\n }\n}\n\nfunction checkOptional (block) {\n block()\n}\n\nfunction checkFramebufferFormat (attachment, texFormats, rbFormats) {\n if (attachment.texture) {\n checkOneOf(\n attachment.texture._texture.internalformat,\n texFormats,\n 'unsupported texture format for attachment')\n } else {\n checkOneOf(\n attachment.renderbuffer._renderbuffer.format,\n rbFormats,\n 'unsupported renderbuffer format for attachment')\n }\n}\n\nvar GL_CLAMP_TO_EDGE = 0x812F\n\nvar GL_NEAREST = 0x2600\nvar GL_NEAREST_MIPMAP_NEAREST = 0x2700\nvar GL_LINEAR_MIPMAP_NEAREST = 0x2701\nvar GL_NEAREST_MIPMAP_LINEAR = 0x2702\nvar GL_LINEAR_MIPMAP_LINEAR = 0x2703\n\nvar GL_BYTE = 5120\nvar GL_UNSIGNED_BYTE = 5121\nvar GL_SHORT = 5122\nvar GL_UNSIGNED_SHORT = 5123\nvar GL_INT = 5124\nvar GL_UNSIGNED_INT = 5125\nvar GL_FLOAT = 5126\n\nvar GL_UNSIGNED_SHORT_4_4_4_4 = 0x8033\nvar GL_UNSIGNED_SHORT_5_5_5_1 = 0x8034\nvar GL_UNSIGNED_SHORT_5_6_5 = 0x8363\nvar GL_UNSIGNED_INT_24_8_WEBGL = 0x84FA\n\nvar GL_HALF_FLOAT_OES = 0x8D61\n\nvar TYPE_SIZE = {}\n\nTYPE_SIZE[GL_BYTE] =\nTYPE_SIZE[GL_UNSIGNED_BYTE] = 1\n\nTYPE_SIZE[GL_SHORT] =\nTYPE_SIZE[GL_UNSIGNED_SHORT] =\nTYPE_SIZE[GL_HALF_FLOAT_OES] =\nTYPE_SIZE[GL_UNSIGNED_SHORT_5_6_5] =\nTYPE_SIZE[GL_UNSIGNED_SHORT_4_4_4_4] =\nTYPE_SIZE[GL_UNSIGNED_SHORT_5_5_5_1] = 2\n\nTYPE_SIZE[GL_INT] =\nTYPE_SIZE[GL_UNSIGNED_INT] =\nTYPE_SIZE[GL_FLOAT] =\nTYPE_SIZE[GL_UNSIGNED_INT_24_8_WEBGL] = 4\n\nfunction pixelSize (type, channels) {\n if (type === GL_UNSIGNED_SHORT_5_5_5_1 ||\n type === GL_UNSIGNED_SHORT_4_4_4_4 ||\n type === GL_UNSIGNED_SHORT_5_6_5) {\n return 2\n } else if (type === GL_UNSIGNED_INT_24_8_WEBGL) {\n return 4\n } else {\n return TYPE_SIZE[type] * channels\n }\n}\n\nfunction isPow2 (v) {\n return !(v & (v - 1)) && (!!v)\n}\n\nfunction checkTexture2D (info, mipData, limits) {\n var i\n var w = mipData.width\n var h = mipData.height\n var c = mipData.channels\n\n // Check texture shape\n check(w > 0 && w <= limits.maxTextureSize &&\n h > 0 && h <= limits.maxTextureSize,\n 'invalid texture shape')\n\n // check wrap mode\n if (info.wrapS !== GL_CLAMP_TO_EDGE || info.wrapT !== GL_CLAMP_TO_EDGE) {\n check(isPow2(w) && isPow2(h),\n 'incompatible wrap mode for texture, both width and height must be power of 2')\n }\n\n if (mipData.mipmask === 1) {\n if (w !== 1 && h !== 1) {\n check(\n info.minFilter !== GL_NEAREST_MIPMAP_NEAREST &&\n info.minFilter !== GL_NEAREST_MIPMAP_LINEAR &&\n info.minFilter !== GL_LINEAR_MIPMAP_NEAREST &&\n info.minFilter !== GL_LINEAR_MIPMAP_LINEAR,\n 'min filter requires mipmap')\n }\n } else {\n // texture must be power of 2\n check(isPow2(w) && isPow2(h),\n 'texture must be a square power of 2 to support mipmapping')\n check(mipData.mipmask === (w << 1) - 1,\n 'missing or incomplete mipmap data')\n }\n\n if (mipData.type === GL_FLOAT) {\n if (limits.extensions.indexOf('oes_texture_float_linear') < 0) {\n check(info.minFilter === GL_NEAREST && info.magFilter === GL_NEAREST,\n 'filter not supported, must enable oes_texture_float_linear')\n }\n check(!info.genMipmaps,\n 'mipmap generation not supported with float textures')\n }\n\n // check image complete\n var mipimages = mipData.images\n for (i = 0; i < 16; ++i) {\n if (mipimages[i]) {\n var mw = w >> i\n var mh = h >> i\n check(mipData.mipmask & (1 << i), 'missing mipmap data')\n\n var img = mipimages[i]\n\n check(\n img.width === mw &&\n img.height === mh,\n 'invalid shape for mip images')\n\n check(\n img.format === mipData.format &&\n img.internalformat === mipData.internalformat &&\n img.type === mipData.type,\n 'incompatible type for mip image')\n\n if (img.compressed) {\n // TODO: check size for compressed images\n } else if (img.data) {\n // check(img.data.byteLength === mw * mh *\n // Math.max(pixelSize(img.type, c), img.unpackAlignment),\n var rowSize = Math.ceil(pixelSize(img.type, c) * mw / img.unpackAlignment) * img.unpackAlignment\n check(img.data.byteLength === rowSize * mh,\n 'invalid data for image, buffer size is inconsistent with image format')\n } else if (img.element) {\n // TODO: check element can be loaded\n } else if (img.copy) {\n // TODO: check compatible format and type\n }\n } else if (!info.genMipmaps) {\n check((mipData.mipmask & (1 << i)) === 0, 'extra mipmap data')\n }\n }\n\n if (mipData.compressed) {\n check(!info.genMipmaps,\n 'mipmap generation for compressed images not supported')\n }\n}\n\nfunction checkTextureCube (texture, info, faces, limits) {\n var w = texture.width\n var h = texture.height\n var c = texture.channels\n\n // Check texture shape\n check(\n w > 0 && w <= limits.maxTextureSize && h > 0 && h <= limits.maxTextureSize,\n 'invalid texture shape')\n check(\n w === h,\n 'cube map must be square')\n check(\n info.wrapS === GL_CLAMP_TO_EDGE && info.wrapT === GL_CLAMP_TO_EDGE,\n 'wrap mode not supported by cube map')\n\n for (var i = 0; i < faces.length; ++i) {\n var face = faces[i]\n check(\n face.width === w && face.height === h,\n 'inconsistent cube map face shape')\n\n if (info.genMipmaps) {\n check(!face.compressed,\n 'can not generate mipmap for compressed textures')\n check(face.mipmask === 1,\n 'can not specify mipmaps and generate mipmaps')\n } else {\n // TODO: check mip and filter mode\n }\n\n var mipmaps = face.images\n for (var j = 0; j < 16; ++j) {\n var img = mipmaps[j]\n if (img) {\n var mw = w >> j\n var mh = h >> j\n check(face.mipmask & (1 << j), 'missing mipmap data')\n check(\n img.width === mw &&\n img.height === mh,\n 'invalid shape for mip images')\n check(\n img.format === texture.format &&\n img.internalformat === texture.internalformat &&\n img.type === texture.type,\n 'incompatible type for mip image')\n\n if (img.compressed) {\n // TODO: check size for compressed images\n } else if (img.data) {\n check(img.data.byteLength === mw * mh *\n Math.max(pixelSize(img.type, c), img.unpackAlignment),\n 'invalid data for image, buffer size is inconsistent with image format')\n } else if (img.element) {\n // TODO: check element can be loaded\n } else if (img.copy) {\n // TODO: check compatible format and type\n }\n }\n }\n }\n}\n\nvar check$1 = extend(check, {\n optional: checkOptional,\n raise: raise,\n commandRaise: commandRaise,\n command: checkCommand,\n parameter: checkParameter,\n commandParameter: checkParameterCommand,\n constructor: checkConstructor,\n type: checkTypeOf,\n commandType: checkCommandType,\n isTypedArray: checkIsTypedArray,\n nni: checkNonNegativeInt,\n oneOf: checkOneOf,\n shaderError: checkShaderError,\n linkError: checkLinkError,\n callSite: guessCallSite,\n saveCommandRef: saveCommandRef,\n saveDrawInfo: saveDrawCommandInfo,\n framebufferFormat: checkFramebufferFormat,\n guessCommand: guessCommand,\n texture2D: checkTexture2D,\n textureCube: checkTextureCube\n});\n\nvar VARIABLE_COUNTER = 0\n\nvar DYN_FUNC = 0\nvar DYN_CONSTANT = 5\nvar DYN_ARRAY = 6\n\nfunction DynamicVariable (type, data) {\n this.id = (VARIABLE_COUNTER++)\n this.type = type\n this.data = data\n}\n\nfunction escapeStr (str) {\n return str.replace(/\\\\/g, '\\\\\\\\').replace(/\"/g, '\\\\\"')\n}\n\nfunction splitParts (str) {\n if (str.length === 0) {\n return []\n }\n\n var firstChar = str.charAt(0)\n var lastChar = str.charAt(str.length - 1)\n\n if (str.length > 1 &&\n firstChar === lastChar &&\n (firstChar === '\"' || firstChar === \"'\")) {\n return ['\"' + escapeStr(str.substr(1, str.length - 2)) + '\"']\n }\n\n var parts = /\\[(false|true|null|\\d+|'[^']*'|\"[^\"]*\")\\]/.exec(str)\n if (parts) {\n return (\n splitParts(str.substr(0, parts.index))\n .concat(splitParts(parts[1]))\n .concat(splitParts(str.substr(parts.index + parts[0].length)))\n )\n }\n\n var subparts = str.split('.')\n if (subparts.length === 1) {\n return ['\"' + escapeStr(str) + '\"']\n }\n\n var result = []\n for (var i = 0; i < subparts.length; ++i) {\n result = result.concat(splitParts(subparts[i]))\n }\n return result\n}\n\nfunction toAccessorString (str) {\n return '[' + splitParts(str).join('][') + ']'\n}\n\nfunction defineDynamic (type, data) {\n return new DynamicVariable(type, toAccessorString(data + ''))\n}\n\nfunction isDynamic (x) {\n return (typeof x === 'function' && !x._reglType) || (x instanceof DynamicVariable)\n}\n\nfunction unbox (x, path) {\n if (typeof x === 'function') {\n return new DynamicVariable(DYN_FUNC, x)\n } else if (typeof x === 'number' || typeof x === 'boolean') {\n return new DynamicVariable(DYN_CONSTANT, x)\n } else if (Array.isArray(x)) {\n return new DynamicVariable(DYN_ARRAY, x.map((y, i) => unbox(y, path + '[' + i + ']')))\n } else if (x instanceof DynamicVariable) {\n return x\n }\n check$1(false, 'invalid option type in uniform ' + path)\n}\n\nvar dynamic = {\n DynamicVariable: DynamicVariable,\n define: defineDynamic,\n isDynamic: isDynamic,\n unbox: unbox,\n accessor: toAccessorString\n};\n\n/* globals requestAnimationFrame, cancelAnimationFrame */\nvar raf = {\n next: typeof requestAnimationFrame === 'function'\n ? function (cb) { return requestAnimationFrame(cb) }\n : function (cb) { return setTimeout(cb, 16) },\n cancel: typeof cancelAnimationFrame === 'function'\n ? function (raf) { return cancelAnimationFrame(raf) }\n : clearTimeout\n};\n\n/* globals performance */\nvar clock = (typeof performance !== 'undefined' && performance.now)\n ? function () { return performance.now() }\n : function () { return +(new Date()) };\n\nfunction createStringStore () {\n var stringIds = { '': 0 }\n var stringValues = ['']\n return {\n id: function (str) {\n var result = stringIds[str]\n if (result) {\n return result\n }\n result = stringIds[str] = stringValues.length\n stringValues.push(str)\n return result\n },\n\n str: function (id) {\n return stringValues[id]\n }\n }\n}\n\n// Context and canvas creation helper functions\nfunction createCanvas (element, onDone, pixelRatio) {\n var canvas = document.createElement('canvas')\n extend(canvas.style, {\n border: 0,\n margin: 0,\n padding: 0,\n top: 0,\n left: 0\n })\n element.appendChild(canvas)\n\n if (element === document.body) {\n canvas.style.position = 'absolute'\n extend(element.style, {\n margin: 0,\n padding: 0\n })\n }\n\n function resize () {\n var w = window.innerWidth\n var h = window.innerHeight\n if (element !== document.body) {\n var bounds = element.getBoundingClientRect()\n w = bounds.right - bounds.left\n h = bounds.bottom - bounds.top\n }\n canvas.width = pixelRatio * w\n canvas.height = pixelRatio * h\n extend(canvas.style, {\n width: w + 'px',\n height: h + 'px'\n })\n }\n\n var resizeObserver\n if (element !== document.body && typeof ResizeObserver === 'function') {\n // ignore 'ResizeObserver' is not defined\n // eslint-disable-next-line\n resizeObserver = new ResizeObserver(function () {\n // setTimeout to avoid flicker\n setTimeout(resize)\n })\n resizeObserver.observe(element)\n } else {\n window.addEventListener('resize', resize, false)\n }\n\n function onDestroy () {\n if (resizeObserver) {\n resizeObserver.disconnect()\n } else {\n window.removeEventListener('resize', resize)\n }\n element.removeChild(canvas)\n }\n\n resize()\n\n return {\n canvas: canvas,\n onDestroy: onDestroy\n }\n}\n\nfunction createContext (canvas, contextAttributes) {\n function get (name) {\n try {\n return canvas.getContext(name, contextAttributes)\n } catch (e) {\n return null\n }\n }\n return (\n get('webgl') ||\n get('experimental-webgl') ||\n get('webgl-experimental')\n )\n}\n\nfunction isHTMLElement (obj) {\n return (\n typeof obj.nodeName === 'string' &&\n typeof obj.appendChild === 'function' &&\n typeof obj.getBoundingClientRect === 'function'\n )\n}\n\nfunction isWebGLContext (obj) {\n return (\n typeof obj.drawArrays === 'function' ||\n typeof obj.drawElements === 'function'\n )\n}\n\nfunction parseExtensions (input) {\n if (typeof input === 'string') {\n return input.split()\n }\n check$1(Array.isArray(input), 'invalid extension array')\n return input\n}\n\nfunction getElement (desc) {\n if (typeof desc === 'string') {\n check$1(typeof document !== 'undefined', 'not supported outside of DOM')\n return document.querySelector(desc)\n }\n return desc\n}\n\nfunction parseArgs (args_) {\n var args = args_ || {}\n var element, container, canvas, gl\n var contextAttributes = {}\n var extensions = []\n var optionalExtensions = []\n var pixelRatio = (typeof window === 'undefined' ? 1 : window.devicePixelRatio)\n var profile = false\n var onDone = function (err) {\n if (err) {\n check$1.raise(err)\n }\n }\n var onDestroy = function () {}\n if (typeof args === 'string') {\n check$1(\n typeof document !== 'undefined',\n 'selector queries only supported in DOM enviroments')\n element = document.querySelector(args)\n check$1(element, 'invalid query string for element')\n } else if (typeof args === 'object') {\n if (isHTMLElement(args)) {\n element = args\n } else if (isWebGLContext(args)) {\n gl = args\n canvas = gl.canvas\n } else {\n check$1.constructor(args)\n if ('gl' in args) {\n gl = args.gl\n } else if ('canvas' in args) {\n canvas = getElement(args.canvas)\n } else if ('container' in args) {\n container = getElement(args.container)\n }\n if ('attributes' in args) {\n contextAttributes = args.attributes\n check$1.type(contextAttributes, 'object', 'invalid context attributes')\n }\n if ('extensions' in args) {\n extensions = parseExtensions(args.extensions)\n }\n if ('optionalExtensions' in args) {\n optionalExtensions = parseExtensions(args.optionalExtensions)\n }\n if ('onDone' in args) {\n check$1.type(\n args.onDone, 'function',\n 'invalid or missing onDone callback')\n onDone = args.onDone\n }\n if ('profile' in args) {\n profile = !!args.profile\n }\n if ('pixelRatio' in args) {\n pixelRatio = +args.pixelRatio\n check$1(pixelRatio > 0, 'invalid pixel ratio')\n }\n }\n } else {\n check$1.raise('invalid arguments to regl')\n }\n\n if (element) {\n if (element.nodeName.toLowerCase() === 'canvas') {\n canvas = element\n } else {\n container = element\n }\n }\n\n if (!gl) {\n if (!canvas) {\n check$1(\n typeof document !== 'undefined',\n 'must manually specify webgl context outside of DOM environments')\n var result = createCanvas(container || document.body, onDone, pixelRatio)\n if (!result) {\n return null\n }\n canvas = result.canvas\n onDestroy = result.onDestroy\n }\n // workaround for chromium bug, premultiplied alpha value is platform dependent\n if (contextAttributes.premultipliedAlpha === undefined) contextAttributes.premultipliedAlpha = true\n gl = createContext(canvas, contextAttributes)\n }\n\n if (!gl) {\n onDestroy()\n onDone('webgl not supported, try upgrading your browser or graphics drivers http://get.webgl.org')\n return null\n }\n\n return {\n gl: gl,\n canvas: canvas,\n container: container,\n extensions: extensions,\n optionalExtensions: optionalExtensions,\n pixelRatio: pixelRatio,\n profile: profile,\n onDone: onDone,\n onDestroy: onDestroy\n }\n}\n\nfunction createExtensionCache (gl, config) {\n var extensions = {}\n\n function tryLoadExtension (name_) {\n check$1.type(name_, 'string', 'extension name must be string')\n var name = name_.toLowerCase()\n var ext\n try {\n ext = extensions[name] = gl.getExtension(name)\n } catch (e) {}\n return !!ext\n }\n\n for (var i = 0; i < config.extensions.length; ++i) {\n var name = config.extensions[i]\n if (!tryLoadExtension(name)) {\n config.onDestroy()\n config.onDone('\"' + name + '\" extension is not supported by the current WebGL context, try upgrading your system or a different browser')\n return null\n }\n }\n\n config.optionalExtensions.forEach(tryLoadExtension)\n\n return {\n extensions: extensions,\n restore: function () {\n Object.keys(extensions).forEach(function (name) {\n if (extensions[name] && !tryLoadExtension(name)) {\n throw new Error('(regl): error restoring extension ' + name)\n }\n })\n }\n }\n}\n\nfunction loop (n, f) {\n var result = Array(n)\n for (var i = 0; i < n; ++i) {\n result[i] = f(i)\n }\n return result\n}\n\nvar GL_BYTE$1 = 5120\nvar GL_UNSIGNED_BYTE$2 = 5121\nvar GL_SHORT$1 = 5122\nvar GL_UNSIGNED_SHORT$1 = 5123\nvar GL_INT$1 = 5124\nvar GL_UNSIGNED_INT$1 = 5125\nvar GL_FLOAT$2 = 5126\n\nfunction nextPow16 (v) {\n for (var i = 16; i <= (1 << 28); i *= 16) {\n if (v <= i) {\n return i\n }\n }\n return 0\n}\n\nfunction log2 (v) {\n var r, shift\n r = (v > 0xFFFF) << 4\n v >>>= r\n shift = (v > 0xFF) << 3\n v >>>= shift; r |= shift\n shift = (v > 0xF) << 2\n v >>>= shift; r |= shift\n shift = (v > 0x3) << 1\n v >>>= shift; r |= shift\n return r | (v >> 1)\n}\n\nfunction createPool () {\n var bufferPool = loop(8, function () {\n return []\n })\n\n function alloc (n) {\n var sz = nextPow16(n)\n var bin = bufferPool[log2(sz) >> 2]\n if (bin.length > 0) {\n return bin.pop()\n }\n return new ArrayBuffer(sz)\n }\n\n function free (buf) {\n bufferPool[log2(buf.byteLength) >> 2].push(buf)\n }\n\n function allocType (type, n) {\n var result = null\n switch (type) {\n case GL_BYTE$1:\n result = new Int8Array(alloc(n), 0, n)\n break\n case GL_UNSIGNED_BYTE$2:\n result = new Uint8Array(alloc(n), 0, n)\n break\n case GL_SHORT$1:\n result = new Int16Array(alloc(2 * n), 0, n)\n break\n case GL_UNSIGNED_SHORT$1:\n result = new Uint16Array(alloc(2 * n), 0, n)\n break\n case GL_INT$1:\n result = new Int32Array(alloc(4 * n), 0, n)\n break\n case GL_UNSIGNED_INT$1:\n result = new Uint32Array(alloc(4 * n), 0, n)\n break\n case GL_FLOAT$2:\n result = new Float32Array(alloc(4 * n), 0, n)\n break\n default:\n return null\n }\n if (result.length !== n) {\n return result.subarray(0, n)\n }\n return result\n }\n\n function freeType (array) {\n free(array.buffer)\n }\n\n return {\n alloc: alloc,\n free: free,\n allocType: allocType,\n freeType: freeType\n }\n}\n\nvar pool = createPool()\n\n// zero pool for initial zero data\npool.zero = createPool()\n\nvar GL_SUBPIXEL_BITS = 0x0D50\nvar GL_RED_BITS = 0x0D52\nvar GL_GREEN_BITS = 0x0D53\nvar GL_BLUE_BITS = 0x0D54\nvar GL_ALPHA_BITS = 0x0D55\nvar GL_DEPTH_BITS = 0x0D56\nvar GL_STENCIL_BITS = 0x0D57\n\nvar GL_ALIASED_POINT_SIZE_RANGE = 0x846D\nvar GL_ALIASED_LINE_WIDTH_RANGE = 0x846E\n\nvar GL_MAX_TEXTURE_SIZE = 0x0D33\nvar GL_MAX_VIEWPORT_DIMS = 0x0D3A\nvar GL_MAX_VERTEX_ATTRIBS = 0x8869\nvar GL_MAX_VERTEX_UNIFORM_VECTORS = 0x8DFB\nvar GL_MAX_VARYING_VECTORS = 0x8DFC\nvar GL_MAX_COMBINED_TEXTURE_IMAGE_UNITS = 0x8B4D\nvar GL_MAX_VERTEX_TEXTURE_IMAGE_UNITS = 0x8B4C\nvar GL_MAX_TEXTURE_IMAGE_UNITS = 0x8872\nvar GL_MAX_FRAGMENT_UNIFORM_VECTORS = 0x8DFD\nvar GL_MAX_CUBE_MAP_TEXTURE_SIZE = 0x851C\nvar GL_MAX_RENDERBUFFER_SIZE = 0x84E8\n\nvar GL_VENDOR = 0x1F00\nvar GL_RENDERER = 0x1F01\nvar GL_VERSION = 0x1F02\nvar GL_SHADING_LANGUAGE_VERSION = 0x8B8C\n\nvar GL_MAX_TEXTURE_MAX_ANISOTROPY_EXT = 0x84FF\n\nvar GL_MAX_COLOR_ATTACHMENTS_WEBGL = 0x8CDF\nvar GL_MAX_DRAW_BUFFERS_WEBGL = 0x8824\n\nvar GL_TEXTURE_2D = 0x0DE1\nvar GL_TEXTURE_CUBE_MAP = 0x8513\nvar GL_TEXTURE_CUBE_MAP_POSITIVE_X = 0x8515\nvar GL_TEXTURE0 = 0x84C0\nvar GL_RGBA = 0x1908\nvar GL_FLOAT$1 = 0x1406\nvar GL_UNSIGNED_BYTE$1 = 0x1401\nvar GL_FRAMEBUFFER = 0x8D40\nvar GL_FRAMEBUFFER_COMPLETE = 0x8CD5\nvar GL_COLOR_ATTACHMENT0 = 0x8CE0\nvar GL_COLOR_BUFFER_BIT$1 = 0x4000\n\nvar wrapLimits = function (gl, extensions) {\n var maxAnisotropic = 1\n if (extensions.ext_texture_filter_anisotropic) {\n maxAnisotropic = gl.getParameter(GL_MAX_TEXTURE_MAX_ANISOTROPY_EXT)\n }\n\n var maxDrawbuffers = 1\n var maxColorAttachments = 1\n if (extensions.webgl_draw_buffers) {\n maxDrawbuffers = gl.getParameter(GL_MAX_DRAW_BUFFERS_WEBGL)\n maxColorAttachments = gl.getParameter(GL_MAX_COLOR_ATTACHMENTS_WEBGL)\n }\n\n // detect if reading float textures is available (Safari doesn't support)\n var readFloat = !!extensions.oes_texture_float\n if (readFloat) {\n var readFloatTexture = gl.createTexture()\n gl.bindTexture(GL_TEXTURE_2D, readFloatTexture)\n gl.texImage2D(GL_TEXTURE_2D, 0, GL_RGBA, 1, 1, 0, GL_RGBA, GL_FLOAT$1, null)\n\n var fbo = gl.createFramebuffer()\n gl.bindFramebuffer(GL_FRAMEBUFFER, fbo)\n gl.framebufferTexture2D(GL_FRAMEBUFFER, GL_COLOR_ATTACHMENT0, GL_TEXTURE_2D, readFloatTexture, 0)\n gl.bindTexture(GL_TEXTURE_2D, null)\n\n if (gl.checkFramebufferStatus(GL_FRAMEBUFFER) !== GL_FRAMEBUFFER_COMPLETE) readFloat = false\n\n else {\n gl.viewport(0, 0, 1, 1)\n gl.clearColor(1.0, 0.0, 0.0, 1.0)\n gl.clear(GL_COLOR_BUFFER_BIT$1)\n var pixels = pool.allocType(GL_FLOAT$1, 4)\n gl.readPixels(0, 0, 1, 1, GL_RGBA, GL_FLOAT$1, pixels)\n\n if (gl.getError()) readFloat = false\n else {\n gl.deleteFramebuffer(fbo)\n gl.deleteTexture(readFloatTexture)\n\n readFloat = pixels[0] === 1.0\n }\n\n pool.freeType(pixels)\n }\n }\n\n // detect non power of two cube textures support (IE doesn't support)\n var isIE = typeof navigator !== 'undefined' && (/MSIE/.test(navigator.userAgent) || /Trident\\//.test(navigator.appVersion) || /Edge/.test(navigator.userAgent))\n\n var npotTextureCube = true\n\n if (!isIE) {\n var cubeTexture = gl.createTexture()\n var data = pool.allocType(GL_UNSIGNED_BYTE$1, 36)\n gl.activeTexture(GL_TEXTURE0)\n gl.bindTexture(GL_TEXTURE_CUBE_MAP, cubeTexture)\n gl.texImage2D(GL_TEXTURE_CUBE_MAP_POSITIVE_X, 0, GL_RGBA, 3, 3, 0, GL_RGBA, GL_UNSIGNED_BYTE$1, data)\n pool.freeType(data)\n gl.bindTexture(GL_TEXTURE_CUBE_MAP, null)\n gl.deleteTexture(cubeTexture)\n npotTextureCube = !gl.getError()\n }\n\n return {\n // drawing buffer bit depth\n colorBits: [\n gl.getParameter(GL_RED_BITS),\n gl.getParameter(GL_GREEN_BITS),\n gl.getParameter(GL_BLUE_BITS),\n gl.getParameter(GL_ALPHA_BITS)\n ],\n depthBits: gl.getParameter(GL_DEPTH_BITS),\n stencilBits: gl.getParameter(GL_STENCIL_BITS),\n subpixelBits: gl.getParameter(GL_SUBPIXEL_BITS),\n\n // supported extensions\n extensions: Object.keys(extensions).filter(function (ext) {\n return !!extensions[ext]\n }),\n\n // max aniso samples\n maxAnisotropic: maxAnisotropic,\n\n // max draw buffers\n maxDrawbuffers: maxDrawbuffers,\n maxColorAttachments: maxColorAttachments,\n\n // point and line size ranges\n pointSizeDims: gl.getParameter(GL_ALIASED_POINT_SIZE_RANGE),\n lineWidthDims: gl.getParameter(GL_ALIASED_LINE_WIDTH_RANGE),\n maxViewportDims: gl.getParameter(GL_MAX_VIEWPORT_DIMS),\n maxCombinedTextureUnits: gl.getParameter(GL_MAX_COMBINED_TEXTURE_IMAGE_UNITS),\n maxCubeMapSize: gl.getParameter(GL_MAX_CUBE_MAP_TEXTURE_SIZE),\n maxRenderbufferSize: gl.getParameter(GL_MAX_RENDERBUFFER_SIZE),\n maxTextureUnits: gl.getParameter(GL_MAX_TEXTURE_IMAGE_UNITS),\n maxTextureSize: gl.getParameter(GL_MAX_TEXTURE_SIZE),\n maxAttributes: gl.getParameter(GL_MAX_VERTEX_ATTRIBS),\n maxVertexUniforms: gl.getParameter(GL_MAX_VERTEX_UNIFORM_VECTORS),\n maxVertexTextureUnits: gl.getParameter(GL_MAX_VERTEX_TEXTURE_IMAGE_UNITS),\n maxVaryingVectors: gl.getParameter(GL_MAX_VARYING_VECTORS),\n maxFragmentUniforms: gl.getParameter(GL_MAX_FRAGMENT_UNIFORM_VECTORS),\n\n // vendor info\n glsl: gl.getParameter(GL_SHADING_LANGUAGE_VERSION),\n renderer: gl.getParameter(GL_RENDERER),\n vendor: gl.getParameter(GL_VENDOR),\n version: gl.getParameter(GL_VERSION),\n\n // quirks\n readFloat: readFloat,\n npotTextureCube: npotTextureCube\n }\n}\n\nfunction isNDArrayLike (obj) {\n return (\n !!obj &&\n typeof obj === 'object' &&\n Array.isArray(obj.shape) &&\n Array.isArray(obj.stride) &&\n typeof obj.offset === 'number' &&\n obj.shape.length === obj.stride.length &&\n (Array.isArray(obj.data) ||\n isTypedArray(obj.data)))\n}\n\nvar values = function (obj) {\n return Object.keys(obj).map(function (key) { return obj[key] })\n}\n\nvar flattenUtils = {\n shape: arrayShape$1,\n flatten: flattenArray\n};\n\nfunction flatten1D (array, nx, out) {\n for (var i = 0; i < nx; ++i) {\n out[i] = array[i]\n }\n}\n\nfunction flatten2D (array, nx, ny, out) {\n var ptr = 0\n for (var i = 0; i < nx; ++i) {\n var row = array[i]\n for (var j = 0; j < ny; ++j) {\n out[ptr++] = row[j]\n }\n }\n}\n\nfunction flatten3D (array, nx, ny, nz, out, ptr_) {\n var ptr = ptr_\n for (var i = 0; i < nx; ++i) {\n var row = array[i]\n for (var j = 0; j < ny; ++j) {\n var col = row[j]\n for (var k = 0; k < nz; ++k) {\n out[ptr++] = col[k]\n }\n }\n }\n}\n\nfunction flattenRec (array, shape, level, out, ptr) {\n var stride = 1\n for (var i = level + 1; i < shape.length; ++i) {\n stride *= shape[i]\n }\n var n = shape[level]\n if (shape.length - level === 4) {\n var nx = shape[level + 1]\n var ny = shape[level + 2]\n var nz = shape[level + 3]\n for (i = 0; i < n; ++i) {\n flatten3D(array[i], nx, ny, nz, out, ptr)\n ptr += stride\n }\n } else {\n for (i = 0; i < n; ++i) {\n flattenRec(array[i], shape, level + 1, out, ptr)\n ptr += stride\n }\n }\n}\n\nfunction flattenArray (array, shape, type, out_) {\n var sz = 1\n if (shape.length) {\n for (var i = 0; i < shape.length; ++i) {\n sz *= shape[i]\n }\n } else {\n sz = 0\n }\n var out = out_ || pool.allocType(type, sz)\n switch (shape.length) {\n case 0:\n break\n case 1:\n flatten1D(array, shape[0], out)\n break\n case 2:\n flatten2D(array, shape[0], shape[1], out)\n break\n case 3:\n flatten3D(array, shape[0], shape[1], shape[2], out, 0)\n break\n default:\n flattenRec(array, shape, 0, out, 0)\n }\n return out\n}\n\nfunction arrayShape$1 (array_) {\n var shape = []\n for (var array = array_; array.length; array = array[0]) {\n shape.push(array.length)\n }\n return shape\n}\n\nvar arrayTypes = {\n\t\"[object Int8Array]\": 5120,\n\t\"[object Int16Array]\": 5122,\n\t\"[object Int32Array]\": 5124,\n\t\"[object Uint8Array]\": 5121,\n\t\"[object Uint8ClampedArray]\": 5121,\n\t\"[object Uint16Array]\": 5123,\n\t\"[object Uint32Array]\": 5125,\n\t\"[object Float32Array]\": 5126,\n\t\"[object Float64Array]\": 5121,\n\t\"[object ArrayBuffer]\": 5121\n};\n\nvar int8 = 5120;\nvar int16 = 5122;\nvar int32 = 5124;\nvar uint8 = 5121;\nvar uint16 = 5123;\nvar uint32 = 5125;\nvar float = 5126;\nvar float32 = 5126;\nvar glTypes = {\n\tint8: int8,\n\tint16: int16,\n\tint32: int32,\n\tuint8: uint8,\n\tuint16: uint16,\n\tuint32: uint32,\n\tfloat: float,\n\tfloat32: float32\n};\n\nvar dynamic$1 = 35048;\nvar stream = 35040;\nvar usageTypes = {\n\tdynamic: dynamic$1,\n\tstream: stream,\n\t\"static\": 35044\n};\n\nvar arrayFlatten = flattenUtils.flatten\nvar arrayShape = flattenUtils.shape\n\nvar GL_STATIC_DRAW = 0x88E4\nvar GL_STREAM_DRAW = 0x88E0\n\nvar GL_UNSIGNED_BYTE$3 = 5121\nvar GL_FLOAT$3 = 5126\n\nvar DTYPES_SIZES = []\nDTYPES_SIZES[5120] = 1 // int8\nDTYPES_SIZES[5122] = 2 // int16\nDTYPES_SIZES[5124] = 4 // int32\nDTYPES_SIZES[5121] = 1 // uint8\nDTYPES_SIZES[5123] = 2 // uint16\nDTYPES_SIZES[5125] = 4 // uint32\nDTYPES_SIZES[5126] = 4 // float32\n\nfunction typedArrayCode (data) {\n return arrayTypes[Object.prototype.toString.call(data)] | 0\n}\n\nfunction copyArray (out, inp) {\n for (var i = 0; i < inp.length; ++i) {\n out[i] = inp[i]\n }\n}\n\nfunction transpose (\n result, data, shapeX, shapeY, strideX, strideY, offset) {\n var ptr = 0\n for (var i = 0; i < shapeX; ++i) {\n for (var j = 0; j < shapeY; ++j) {\n result[ptr++] = data[strideX * i + strideY * j + offset]\n }\n }\n}\n\nfunction wrapBufferState (gl, stats, config, destroyBuffer) {\n var bufferCount = 0\n var bufferSet = {}\n\n function REGLBuffer (type) {\n this.id = bufferCount++\n this.buffer = gl.createBuffer()\n this.type = type\n this.usage = GL_STATIC_DRAW\n this.byteLength = 0\n this.dimension = 1\n this.dtype = GL_UNSIGNED_BYTE$3\n\n this.persistentData = null\n\n if (config.profile) {\n this.stats = { size: 0 }\n }\n }\n\n REGLBuffer.prototype.bind = function () {\n gl.bindBuffer(this.type, this.buffer)\n }\n\n REGLBuffer.prototype.destroy = function () {\n destroy(this)\n }\n\n var streamPool = []\n\n function createStream (type, data) {\n var buffer = streamPool.pop()\n if (!buffer) {\n buffer = new REGLBuffer(type)\n }\n buffer.bind()\n initBufferFromData(buffer, data, GL_STREAM_DRAW, 0, 1, false)\n return buffer\n }\n\n function destroyStream (stream$$1) {\n streamPool.push(stream$$1)\n }\n\n function initBufferFromTypedArray (buffer, data, usage) {\n buffer.byteLength = data.byteLength\n gl.bufferData(buffer.type, data, usage)\n }\n\n function initBufferFromData (buffer, data, usage, dtype, dimension, persist) {\n var shape\n buffer.usage = usage\n if (Array.isArray(data)) {\n buffer.dtype = dtype || GL_FLOAT$3\n if (data.length > 0) {\n var flatData\n if (Array.isArray(data[0])) {\n shape = arrayShape(data)\n var dim = 1\n for (var i = 1; i < shape.length; ++i) {\n dim *= shape[i]\n }\n buffer.dimension = dim\n flatData = arrayFlatten(data, shape, buffer.dtype)\n initBufferFromTypedArray(buffer, flatData, usage)\n if (persist) {\n buffer.persistentData = flatData\n } else {\n pool.freeType(flatData)\n }\n } else if (typeof data[0] === 'number') {\n buffer.dimension = dimension\n var typedData = pool.allocType(buffer.dtype, data.length)\n copyArray(typedData, data)\n initBufferFromTypedArray(buffer, typedData, usage)\n if (persist) {\n buffer.persistentData = typedData\n } else {\n pool.freeType(typedData)\n }\n } else if (isTypedArray(data[0])) {\n buffer.dimension = data[0].length\n buffer.dtype = dtype || typedArrayCode(data[0]) || GL_FLOAT$3\n flatData = arrayFlatten(\n data,\n [data.length, data[0].length],\n buffer.dtype)\n initBufferFromTypedArray(buffer, flatData, usage)\n if (persist) {\n buffer.persistentData = flatData\n } else {\n pool.freeType(flatData)\n }\n } else {\n check$1.raise('invalid buffer data')\n }\n }\n } else if (isTypedArray(data)) {\n buffer.dtype = dtype || typedArrayCode(data)\n buffer.dimension = dimension\n initBufferFromTypedArray(buffer, data, usage)\n if (persist) {\n buffer.persistentData = new Uint8Array(new Uint8Array(data.buffer))\n }\n } else if (isNDArrayLike(data)) {\n shape = data.shape\n var stride = data.stride\n var offset = data.offset\n\n var shapeX = 0\n var shapeY = 0\n var strideX = 0\n var strideY = 0\n if (shape.length === 1) {\n shapeX = shape[0]\n shapeY = 1\n strideX = stride[0]\n strideY = 0\n } else if (shape.length === 2) {\n shapeX = shape[0]\n shapeY = shape[1]\n strideX = stride[0]\n strideY = stride[1]\n } else {\n check$1.raise('invalid shape')\n }\n\n buffer.dtype = dtype || typedArrayCode(data.data) || GL_FLOAT$3\n buffer.dimension = shapeY\n\n var transposeData = pool.allocType(buffer.dtype, shapeX * shapeY)\n transpose(transposeData,\n data.data,\n shapeX, shapeY,\n strideX, strideY,\n offset)\n initBufferFromTypedArray(buffer, transposeData, usage)\n if (persist) {\n buffer.persistentData = transposeData\n } else {\n pool.freeType(transposeData)\n }\n } else if (data instanceof ArrayBuffer) {\n buffer.dtype = GL_UNSIGNED_BYTE$3\n buffer.dimension = dimension\n initBufferFromTypedArray(buffer, data, usage)\n if (persist) {\n buffer.persistentData = new Uint8Array(new Uint8Array(data))\n }\n } else {\n check$1.raise('invalid buffer data')\n }\n }\n\n function destroy (buffer) {\n stats.bufferCount--\n\n // remove attribute link\n destroyBuffer(buffer)\n\n var handle = buffer.buffer\n check$1(handle, 'buffer must not be deleted already')\n gl.deleteBuffer(handle)\n buffer.buffer = null\n delete bufferSet[buffer.id]\n }\n\n function createBuffer (options, type, deferInit, persistent) {\n stats.bufferCount++\n\n var buffer = new REGLBuffer(type)\n bufferSet[buffer.id] = buffer\n\n function reglBuffer (options) {\n var usage = GL_STATIC_DRAW\n var data = null\n var byteLength = 0\n var dtype = 0\n var dimension = 1\n if (Array.isArray(options) ||\n isTypedArray(options) ||\n isNDArrayLike(options) ||\n options instanceof ArrayBuffer) {\n data = options\n } else if (typeof options === 'number') {\n byteLength = options | 0\n } else if (options) {\n check$1.type(\n options, 'object',\n 'buffer arguments must be an object, a number or an array')\n\n if ('data' in options) {\n check$1(\n data === null ||\n Array.isArray(data) ||\n isTypedArray(data) ||\n isNDArrayLike(data),\n 'invalid data for buffer')\n data = options.data\n }\n\n if ('usage' in options) {\n check$1.parameter(options.usage, usageTypes, 'invalid buffer usage')\n usage = usageTypes[options.usage]\n }\n\n if ('type' in options) {\n check$1.parameter(options.type, glTypes, 'invalid buffer type')\n dtype = glTypes[options.type]\n }\n\n if ('dimension' in options) {\n check$1.type(options.dimension, 'number', 'invalid dimension')\n dimension = options.dimension | 0\n }\n\n if ('length' in options) {\n check$1.nni(byteLength, 'buffer length must be a nonnegative integer')\n byteLength = options.length | 0\n }\n }\n\n buffer.bind()\n if (!data) {\n // #475\n if (byteLength) gl.bufferData(buffer.type, byteLength, usage)\n buffer.dtype = dtype || GL_UNSIGNED_BYTE$3\n buffer.usage = usage\n buffer.dimension = dimension\n buffer.byteLength = byteLength\n } else {\n initBufferFromData(buffer, data, usage, dtype, dimension, persistent)\n }\n\n if (config.profile) {\n buffer.stats.size = buffer.byteLength * DTYPES_SIZES[buffer.dtype]\n }\n\n return reglBuffer\n }\n\n function setSubData (data, offset) {\n check$1(offset + data.byteLength <= buffer.byteLength,\n 'invalid buffer subdata call, buffer is too small. ' + ' Can\\'t write data of size ' + data.byteLength + ' starting from offset ' + offset + ' to a buffer of size ' + buffer.byteLength)\n\n gl.bufferSubData(buffer.type, offset, data)\n }\n\n function subdata (data, offset_) {\n var offset = (offset_ || 0) | 0\n var shape\n buffer.bind()\n if (isTypedArray(data) || data instanceof ArrayBuffer) {\n setSubData(data, offset)\n } else if (Array.isArray(data)) {\n if (data.length > 0) {\n if (typeof data[0] === 'number') {\n var converted = pool.allocType(buffer.dtype, data.length)\n copyArray(converted, data)\n setSubData(converted, offset)\n pool.freeType(converted)\n } else if (Array.isArray(data[0]) || isTypedArray(data[0])) {\n shape = arrayShape(data)\n var flatData = arrayFlatten(data, shape, buffer.dtype)\n setSubData(flatData, offset)\n pool.freeType(flatData)\n } else {\n check$1.raise('invalid buffer data')\n }\n }\n } else if (isNDArrayLike(data)) {\n shape = data.shape\n var stride = data.stride\n\n var shapeX = 0\n var shapeY = 0\n var strideX = 0\n var strideY = 0\n if (shape.length === 1) {\n shapeX = shape[0]\n shapeY = 1\n strideX = stride[0]\n strideY = 0\n } else if (shape.length === 2) {\n shapeX = shape[0]\n shapeY = shape[1]\n strideX = stride[0]\n strideY = stride[1]\n } else {\n check$1.raise('invalid shape')\n }\n var dtype = Array.isArray(data.data)\n ? buffer.dtype\n : typedArrayCode(data.data)\n\n var transposeData = pool.allocType(dtype, shapeX * shapeY)\n transpose(transposeData,\n data.data,\n shapeX, shapeY,\n strideX, strideY,\n data.offset)\n setSubData(transposeData, offset)\n pool.freeType(transposeData)\n } else {\n check$1.raise('invalid data for buffer subdata')\n }\n return reglBuffer\n }\n\n if (!deferInit) {\n reglBuffer(options)\n }\n\n reglBuffer._reglType = 'buffer'\n reglBuffer._buffer = buffer\n reglBuffer.subdata = subdata\n if (config.profile) {\n reglBuffer.stats = buffer.stats\n }\n reglBuffer.destroy = function () { destroy(buffer) }\n\n return reglBuffer\n }\n\n function restoreBuffers () {\n values(bufferSet).forEach(function (buffer) {\n buffer.buffer = gl.createBuffer()\n gl.bindBuffer(buffer.type, buffer.buffer)\n gl.bufferData(\n buffer.type, buffer.persistentData || buffer.byteLength, buffer.usage)\n })\n }\n\n if (config.profile) {\n stats.getTotalBufferSize = function () {\n var total = 0\n // TODO: Right now, the streams are not part of the total count.\n Object.keys(bufferSet).forEach(function (key) {\n total += bufferSet[key].stats.size\n })\n return total\n }\n }\n\n return {\n create: createBuffer,\n\n createStream: createStream,\n destroyStream: destroyStream,\n\n clear: function () {\n values(bufferSet).forEach(destroy)\n streamPool.forEach(destroy)\n },\n\n getBuffer: function (wrapper) {\n if (wrapper && wrapper._buffer instanceof REGLBuffer) {\n return wrapper._buffer\n }\n return null\n },\n\n restore: restoreBuffers,\n\n _initBuffer: initBufferFromData\n }\n}\n\nvar points = 0;\nvar point = 0;\nvar lines = 1;\nvar line = 1;\nvar triangles = 4;\nvar triangle = 4;\nvar primTypes = {\n\tpoints: points,\n\tpoint: point,\n\tlines: lines,\n\tline: line,\n\ttriangles: triangles,\n\ttriangle: triangle,\n\t\"line loop\": 2,\n\t\"line strip\": 3,\n\t\"triangle strip\": 5,\n\t\"triangle fan\": 6\n};\n\nvar GL_POINTS = 0\nvar GL_LINES = 1\nvar GL_TRIANGLES = 4\n\nvar GL_BYTE$2 = 5120\nvar GL_UNSIGNED_BYTE$4 = 5121\nvar GL_SHORT$2 = 5122\nvar GL_UNSIGNED_SHORT$2 = 5123\nvar GL_INT$2 = 5124\nvar GL_UNSIGNED_INT$2 = 5125\n\nvar GL_ELEMENT_ARRAY_BUFFER = 34963\n\nvar GL_STREAM_DRAW$1 = 0x88E0\nvar GL_STATIC_DRAW$1 = 0x88E4\n\nfunction wrapElementsState (gl, extensions, bufferState, stats) {\n var elementSet = {}\n var elementCount = 0\n\n var elementTypes = {\n 'uint8': GL_UNSIGNED_BYTE$4,\n 'uint16': GL_UNSIGNED_SHORT$2\n }\n\n if (extensions.oes_element_index_uint) {\n elementTypes.uint32 = GL_UNSIGNED_INT$2\n }\n\n function REGLElementBuffer (buffer) {\n this.id = elementCount++\n elementSet[this.id] = this\n this.buffer = buffer\n this.primType = GL_TRIANGLES\n this.vertCount = 0\n this.type = 0\n }\n\n REGLElementBuffer.prototype.bind = function () {\n this.buffer.bind()\n }\n\n var bufferPool = []\n\n function createElementStream (data) {\n var result = bufferPool.pop()\n if (!result) {\n result = new REGLElementBuffer(bufferState.create(\n null,\n GL_ELEMENT_ARRAY_BUFFER,\n true,\n false)._buffer)\n }\n initElements(result, data, GL_STREAM_DRAW$1, -1, -1, 0, 0)\n return result\n }\n\n function destroyElementStream (elements) {\n bufferPool.push(elements)\n }\n\n function initElements (\n elements,\n data,\n usage,\n prim,\n count,\n byteLength,\n type) {\n elements.buffer.bind()\n var dtype\n if (data) {\n var predictedType = type\n if (!type && (\n !isTypedArray(data) ||\n (isNDArrayLike(data) && !isTypedArray(data.data)))) {\n predictedType = extensions.oes_element_index_uint\n ? GL_UNSIGNED_INT$2\n : GL_UNSIGNED_SHORT$2\n }\n bufferState._initBuffer(\n elements.buffer,\n data,\n usage,\n predictedType,\n 3)\n } else {\n gl.bufferData(GL_ELEMENT_ARRAY_BUFFER, byteLength, usage)\n elements.buffer.dtype = dtype || GL_UNSIGNED_BYTE$4\n elements.buffer.usage = usage\n elements.buffer.dimension = 3\n elements.buffer.byteLength = byteLength\n }\n\n dtype = type\n if (!type) {\n switch (elements.buffer.dtype) {\n case GL_UNSIGNED_BYTE$4:\n case GL_BYTE$2:\n dtype = GL_UNSIGNED_BYTE$4\n break\n\n case GL_UNSIGNED_SHORT$2:\n case GL_SHORT$2:\n dtype = GL_UNSIGNED_SHORT$2\n break\n\n case GL_UNSIGNED_INT$2:\n case GL_INT$2:\n dtype = GL_UNSIGNED_INT$2\n break\n\n default:\n check$1.raise('unsupported type for element array')\n }\n elements.buffer.dtype = dtype\n }\n elements.type = dtype\n\n // Check oes_element_index_uint extension\n check$1(\n dtype !== GL_UNSIGNED_INT$2 ||\n !!extensions.oes_element_index_uint,\n '32 bit element buffers not supported, enable oes_element_index_uint first')\n\n // try to guess default primitive type and arguments\n var vertCount = count\n if (vertCount < 0) {\n vertCount = elements.buffer.byteLength\n if (dtype === GL_UNSIGNED_SHORT$2) {\n vertCount >>= 1\n } else if (dtype === GL_UNSIGNED_INT$2) {\n vertCount >>= 2\n }\n }\n elements.vertCount = vertCount\n\n // try to guess primitive type from cell dimension\n var primType = prim\n if (prim < 0) {\n primType = GL_TRIANGLES\n var dimension = elements.buffer.dimension\n if (dimension === 1) primType = GL_POINTS\n if (dimension === 2) primType = GL_LINES\n if (dimension === 3) primType = GL_TRIANGLES\n }\n elements.primType = primType\n }\n\n function destroyElements (elements) {\n stats.elementsCount--\n\n check$1(elements.buffer !== null, 'must not double destroy elements')\n delete elementSet[elements.id]\n elements.buffer.destroy()\n elements.buffer = null\n }\n\n function createElements (options, persistent) {\n var buffer = bufferState.create(null, GL_ELEMENT_ARRAY_BUFFER, true)\n var elements = new REGLElementBuffer(buffer._buffer)\n stats.elementsCount++\n\n function reglElements (options) {\n if (!options) {\n buffer()\n elements.primType = GL_TRIANGLES\n elements.vertCount = 0\n elements.type = GL_UNSIGNED_BYTE$4\n } else if (typeof options === 'number') {\n buffer(options)\n elements.primType = GL_TRIANGLES\n elements.vertCount = options | 0\n elements.type = GL_UNSIGNED_BYTE$4\n } else {\n var data = null\n var usage = GL_STATIC_DRAW$1\n var primType = -1\n var vertCount = -1\n var byteLength = 0\n var dtype = 0\n if (Array.isArray(options) ||\n isTypedArray(options) ||\n isNDArrayLike(options)) {\n data = options\n } else {\n check$1.type(options, 'object', 'invalid arguments for elements')\n if ('data' in options) {\n data = options.data\n check$1(\n Array.isArray(data) ||\n isTypedArray(data) ||\n isNDArrayLike(data),\n 'invalid data for element buffer')\n }\n if ('usage' in options) {\n check$1.parameter(\n options.usage,\n usageTypes,\n 'invalid element buffer usage')\n usage = usageTypes[options.usage]\n }\n if ('primitive' in options) {\n check$1.parameter(\n options.primitive,\n primTypes,\n 'invalid element buffer primitive')\n primType = primTypes[options.primitive]\n }\n if ('count' in options) {\n check$1(\n typeof options.count === 'number' && options.count >= 0,\n 'invalid vertex count for elements')\n vertCount = options.count | 0\n }\n if ('type' in options) {\n check$1.parameter(\n options.type,\n elementTypes,\n 'invalid buffer type')\n dtype = elementTypes[options.type]\n }\n if ('length' in options) {\n byteLength = options.length | 0\n } else {\n byteLength = vertCount\n if (dtype === GL_UNSIGNED_SHORT$2 || dtype === GL_SHORT$2) {\n byteLength *= 2\n } else if (dtype === GL_UNSIGNED_INT$2 || dtype === GL_INT$2) {\n byteLength *= 4\n }\n }\n }\n initElements(\n elements,\n data,\n usage,\n primType,\n vertCount,\n byteLength,\n dtype)\n }\n\n return reglElements\n }\n\n reglElements(options)\n\n reglElements._reglType = 'elements'\n reglElements._elements = elements\n reglElements.subdata = function (data, offset) {\n buffer.subdata(data, offset)\n return reglElements\n }\n reglElements.destroy = function () {\n destroyElements(elements)\n }\n\n return reglElements\n }\n\n return {\n create: createElements,\n createStream: createElementStream,\n destroyStream: destroyElementStream,\n getElements: function (elements) {\n if (typeof elements === 'function' &&\n elements._elements instanceof REGLElementBuffer) {\n return elements._elements\n }\n return null\n },\n clear: function () {\n values(elementSet).forEach(destroyElements)\n }\n }\n}\n\nvar FLOAT = new Float32Array(1)\nvar INT = new Uint32Array(FLOAT.buffer)\n\nvar GL_UNSIGNED_SHORT$4 = 5123\n\nfunction convertToHalfFloat (array) {\n var ushorts = pool.allocType(GL_UNSIGNED_SHORT$4, array.length)\n\n for (var i = 0; i < array.length; ++i) {\n if (isNaN(array[i])) {\n ushorts[i] = 0xffff\n } else if (array[i] === Infinity) {\n ushorts[i] = 0x7c00\n } else if (array[i] === -Infinity) {\n ushorts[i] = 0xfc00\n } else {\n FLOAT[0] = array[i]\n var x = INT[0]\n\n var sgn = (x >>> 31) << 15\n var exp = ((x << 1) >>> 24) - 127\n var frac = (x >> 13) & ((1 << 10) - 1)\n\n if (exp < -24) {\n // round non-representable denormals to 0\n ushorts[i] = sgn\n } else if (exp < -14) {\n // handle denormals\n var s = -14 - exp\n ushorts[i] = sgn + ((frac + (1 << 10)) >> s)\n } else if (exp > 15) {\n // round overflow to +/- Infinity\n ushorts[i] = sgn + 0x7c00\n } else {\n // otherwise convert directly\n ushorts[i] = sgn + ((exp + 15) << 10) + frac\n }\n }\n }\n\n return ushorts\n}\n\nfunction isArrayLike (s) {\n return Array.isArray(s) || isTypedArray(s)\n}\n\nvar isPow2$1 = function (v) {\n return !(v & (v - 1)) && (!!v)\n}\n\nvar GL_COMPRESSED_TEXTURE_FORMATS = 0x86A3\n\nvar GL_TEXTURE_2D$1 = 0x0DE1\nvar GL_TEXTURE_CUBE_MAP$1 = 0x8513\nvar GL_TEXTURE_CUBE_MAP_POSITIVE_X$1 = 0x8515\n\nvar GL_RGBA$1 = 0x1908\nvar GL_ALPHA = 0x1906\nvar GL_RGB = 0x1907\nvar GL_LUMINANCE = 0x1909\nvar GL_LUMINANCE_ALPHA = 0x190A\n\nvar GL_RGBA4 = 0x8056\nvar GL_RGB5_A1 = 0x8057\nvar GL_RGB565 = 0x8D62\n\nvar GL_UNSIGNED_SHORT_4_4_4_4$1 = 0x8033\nvar GL_UNSIGNED_SHORT_5_5_5_1$1 = 0x8034\nvar GL_UNSIGNED_SHORT_5_6_5$1 = 0x8363\nvar GL_UNSIGNED_INT_24_8_WEBGL$1 = 0x84FA\n\nvar GL_DEPTH_COMPONENT = 0x1902\nvar GL_DEPTH_STENCIL = 0x84F9\n\nvar GL_SRGB_EXT = 0x8C40\nvar GL_SRGB_ALPHA_EXT = 0x8C42\n\nvar GL_HALF_FLOAT_OES$1 = 0x8D61\n\nvar GL_COMPRESSED_RGB_S3TC_DXT1_EXT = 0x83F0\nvar GL_COMPRESSED_RGBA_S3TC_DXT1_EXT = 0x83F1\nvar GL_COMPRESSED_RGBA_S3TC_DXT3_EXT = 0x83F2\nvar GL_COMPRESSED_RGBA_S3TC_DXT5_EXT = 0x83F3\n\nvar GL_COMPRESSED_RGB_ATC_WEBGL = 0x8C92\nvar GL_COMPRESSED_RGBA_ATC_EXPLICIT_ALPHA_WEBGL = 0x8C93\nvar GL_COMPRESSED_RGBA_ATC_INTERPOLATED_ALPHA_WEBGL = 0x87EE\n\nvar GL_COMPRESSED_RGB_PVRTC_4BPPV1_IMG = 0x8C00\nvar GL_COMPRESSED_RGB_PVRTC_2BPPV1_IMG = 0x8C01\nvar GL_COMPRESSED_RGBA_PVRTC_4BPPV1_IMG = 0x8C02\nvar GL_COMPRESSED_RGBA_PVRTC_2BPPV1_IMG = 0x8C03\n\nvar GL_COMPRESSED_RGB_ETC1_WEBGL = 0x8D64\n\nvar GL_UNSIGNED_BYTE$5 = 0x1401\nvar GL_UNSIGNED_SHORT$3 = 0x1403\nvar GL_UNSIGNED_INT$3 = 0x1405\nvar GL_FLOAT$4 = 0x1406\n\nvar GL_TEXTURE_WRAP_S = 0x2802\nvar GL_TEXTURE_WRAP_T = 0x2803\n\nvar GL_REPEAT = 0x2901\nvar GL_CLAMP_TO_EDGE$1 = 0x812F\nvar GL_MIRRORED_REPEAT = 0x8370\n\nvar GL_TEXTURE_MAG_FILTER = 0x2800\nvar GL_TEXTURE_MIN_FILTER = 0x2801\n\nvar GL_NEAREST$1 = 0x2600\nvar GL_LINEAR = 0x2601\nvar GL_NEAREST_MIPMAP_NEAREST$1 = 0x2700\nvar GL_LINEAR_MIPMAP_NEAREST$1 = 0x2701\nvar GL_NEAREST_MIPMAP_LINEAR$1 = 0x2702\nvar GL_LINEAR_MIPMAP_LINEAR$1 = 0x2703\n\nvar GL_GENERATE_MIPMAP_HINT = 0x8192\nvar GL_DONT_CARE = 0x1100\nvar GL_FASTEST = 0x1101\nvar GL_NICEST = 0x1102\n\nvar GL_TEXTURE_MAX_ANISOTROPY_EXT = 0x84FE\n\nvar GL_UNPACK_ALIGNMENT = 0x0CF5\nvar GL_UNPACK_FLIP_Y_WEBGL = 0x9240\nvar GL_UNPACK_PREMULTIPLY_ALPHA_WEBGL = 0x9241\nvar GL_UNPACK_COLORSPACE_CONVERSION_WEBGL = 0x9243\n\nvar GL_BROWSER_DEFAULT_WEBGL = 0x9244\n\nvar GL_TEXTURE0$1 = 0x84C0\n\nvar MIPMAP_FILTERS = [\n GL_NEAREST_MIPMAP_NEAREST$1,\n GL_NEAREST_MIPMAP_LINEAR$1,\n GL_LINEAR_MIPMAP_NEAREST$1,\n GL_LINEAR_MIPMAP_LINEAR$1\n]\n\nvar CHANNELS_FORMAT = [\n 0,\n GL_LUMINANCE,\n GL_LUMINANCE_ALPHA,\n GL_RGB,\n GL_RGBA$1\n]\n\nvar FORMAT_CHANNELS = {}\nFORMAT_CHANNELS[GL_LUMINANCE] =\nFORMAT_CHANNELS[GL_ALPHA] =\nFORMAT_CHANNELS[GL_DEPTH_COMPONENT] = 1\nFORMAT_CHANNELS[GL_DEPTH_STENCIL] =\nFORMAT_CHANNELS[GL_LUMINANCE_ALPHA] = 2\nFORMAT_CHANNELS[GL_RGB] =\nFORMAT_CHANNELS[GL_SRGB_EXT] = 3\nFORMAT_CHANNELS[GL_RGBA$1] =\nFORMAT_CHANNELS[GL_SRGB_ALPHA_EXT] = 4\n\nfunction objectName (str) {\n return '[object ' + str + ']'\n}\n\nvar CANVAS_CLASS = objectName('HTMLCanvasElement')\nvar OFFSCREENCANVAS_CLASS = objectName('OffscreenCanvas')\nvar CONTEXT2D_CLASS = objectName('CanvasRenderingContext2D')\nvar BITMAP_CLASS = objectName('ImageBitmap')\nvar IMAGE_CLASS = objectName('HTMLImageElement')\nvar VIDEO_CLASS = objectName('HTMLVideoElement')\n\nvar PIXEL_CLASSES = Object.keys(arrayTypes).concat([\n CANVAS_CLASS,\n OFFSCREENCANVAS_CLASS,\n CONTEXT2D_CLASS,\n BITMAP_CLASS,\n IMAGE_CLASS,\n VIDEO_CLASS\n])\n\n// for every texture type, store\n// the size in bytes.\nvar TYPE_SIZES = []\nTYPE_SIZES[GL_UNSIGNED_BYTE$5] = 1\nTYPE_SIZES[GL_FLOAT$4] = 4\nTYPE_SIZES[GL_HALF_FLOAT_OES$1] = 2\n\nTYPE_SIZES[GL_UNSIGNED_SHORT$3] = 2\nTYPE_SIZES[GL_UNSIGNED_INT$3] = 4\n\nvar FORMAT_SIZES_SPECIAL = []\nFORMAT_SIZES_SPECIAL[GL_RGBA4] = 2\nFORMAT_SIZES_SPECIAL[GL_RGB5_A1] = 2\nFORMAT_SIZES_SPECIAL[GL_RGB565] = 2\nFORMAT_SIZES_SPECIAL[GL_DEPTH_STENCIL] = 4\n\nFORMAT_SIZES_SPECIAL[GL_COMPRESSED_RGB_S3TC_DXT1_EXT] = 0.5\nFORMAT_SIZES_SPECIAL[GL_COMPRESSED_RGBA_S3TC_DXT1_EXT] = 0.5\nFORMAT_SIZES_SPECIAL[GL_COMPRESSED_RGBA_S3TC_DXT3_EXT] = 1\nFORMAT_SIZES_SPECIAL[GL_COMPRESSED_RGBA_S3TC_DXT5_EXT] = 1\n\nFORMAT_SIZES_SPECIAL[GL_COMPRESSED_RGB_ATC_WEBGL] = 0.5\nFORMAT_SIZES_SPECIAL[GL_COMPRESSED_RGBA_ATC_EXPLICIT_ALPHA_WEBGL] = 1\nFORMAT_SIZES_SPECIAL[GL_COMPRESSED_RGBA_ATC_INTERPOLATED_ALPHA_WEBGL] = 1\n\nFORMAT_SIZES_SPECIAL[GL_COMPRESSED_RGB_PVRTC_4BPPV1_IMG] = 0.5\nFORMAT_SIZES_SPECIAL[GL_COMPRESSED_RGB_PVRTC_2BPPV1_IMG] = 0.25\nFORMAT_SIZES_SPECIAL[GL_COMPRESSED_RGBA_PVRTC_4BPPV1_IMG] = 0.5\nFORMAT_SIZES_SPECIAL[GL_COMPRESSED_RGBA_PVRTC_2BPPV1_IMG] = 0.25\n\nFORMAT_SIZES_SPECIAL[GL_COMPRESSED_RGB_ETC1_WEBGL] = 0.5\n\nfunction isNumericArray (arr) {\n return (\n Array.isArray(arr) &&\n (arr.length === 0 ||\n typeof arr[0] === 'number'))\n}\n\nfunction isRectArray (arr) {\n if (!Array.isArray(arr)) {\n return false\n }\n var width = arr.length\n if (width === 0 || !isArrayLike(arr[0])) {\n return false\n }\n return true\n}\n\nfunction classString (x) {\n return Object.prototype.toString.call(x)\n}\n\nfunction isCanvasElement (object) {\n return classString(object) === CANVAS_CLASS\n}\n\nfunction isOffscreenCanvas (object) {\n return classString(object) === OFFSCREENCANVAS_CLASS\n}\n\nfunction isContext2D (object) {\n return classString(object) === CONTEXT2D_CLASS\n}\n\nfunction isBitmap (object) {\n return classString(object) === BITMAP_CLASS\n}\n\nfunction isImageElement (object) {\n return classString(object) === IMAGE_CLASS\n}\n\nfunction isVideoElement (object) {\n return classString(object) === VIDEO_CLASS\n}\n\nfunction isPixelData (object) {\n if (!object) {\n return false\n }\n var className = classString(object)\n if (PIXEL_CLASSES.indexOf(className) >= 0) {\n return true\n }\n return (\n isNumericArray(object) ||\n isRectArray(object) ||\n isNDArrayLike(object))\n}\n\nfunction typedArrayCode$1 (data) {\n return arrayTypes[Object.prototype.toString.call(data)] | 0\n}\n\nfunction convertData (result, data) {\n var n = data.length\n switch (result.type) {\n case GL_UNSIGNED_BYTE$5:\n case GL_UNSIGNED_SHORT$3:\n case GL_UNSIGNED_INT$3:\n case GL_FLOAT$4:\n var converted = pool.allocType(result.type, n)\n converted.set(data)\n result.data = converted\n break\n\n case GL_HALF_FLOAT_OES$1:\n result.data = convertToHalfFloat(data)\n break\n\n default:\n check$1.raise('unsupported texture type, must specify a typed array')\n }\n}\n\nfunction preConvert (image, n) {\n return pool.allocType(\n image.type === GL_HALF_FLOAT_OES$1\n ? GL_FLOAT$4\n : image.type, n)\n}\n\nfunction postConvert (image, data) {\n if (image.type === GL_HALF_FLOAT_OES$1) {\n image.data = convertToHalfFloat(data)\n pool.freeType(data)\n } else {\n image.data = data\n }\n}\n\nfunction transposeData (image, array, strideX, strideY, strideC, offset) {\n var w = image.width\n var h = image.height\n var c = image.channels\n var n = w * h * c\n var data = preConvert(image, n)\n\n var p = 0\n for (var i = 0; i < h; ++i) {\n for (var j = 0; j < w; ++j) {\n for (var k = 0; k < c; ++k) {\n data[p++] = array[strideX * j + strideY * i + strideC * k + offset]\n }\n }\n }\n\n postConvert(image, data)\n}\n\nfunction getTextureSize (format, type, width, height, isMipmap, isCube) {\n var s\n if (typeof FORMAT_SIZES_SPECIAL[format] !== 'undefined') {\n // we have a special array for dealing with weird color formats such as RGB5A1\n s = FORMAT_SIZES_SPECIAL[format]\n } else {\n s = FORMAT_CHANNELS[format] * TYPE_SIZES[type]\n }\n\n if (isCube) {\n s *= 6\n }\n\n if (isMipmap) {\n // compute the total size of all the mipmaps.\n var total = 0\n\n var w = width\n while (w >= 1) {\n // we can only use mipmaps on a square image,\n // so we can simply use the width and ignore the height:\n total += s * w * w\n w /= 2\n }\n return total\n } else {\n return s * width * height\n }\n}\n\nfunction createTextureSet (\n gl, extensions, limits, reglPoll, contextState, stats, config) {\n // -------------------------------------------------------\n // Initialize constants and parameter tables here\n // -------------------------------------------------------\n var mipmapHint = {\n \"don't care\": GL_DONT_CARE,\n 'dont care': GL_DONT_CARE,\n 'nice': GL_NICEST,\n 'fast': GL_FASTEST\n }\n\n var wrapModes = {\n 'repeat': GL_REPEAT,\n 'clamp': GL_CLAMP_TO_EDGE$1,\n 'mirror': GL_MIRRORED_REPEAT\n }\n\n var magFilters = {\n 'nearest': GL_NEAREST$1,\n 'linear': GL_LINEAR\n }\n\n var minFilters = extend({\n 'mipmap': GL_LINEAR_MIPMAP_LINEAR$1,\n 'nearest mipmap nearest': GL_NEAREST_MIPMAP_NEAREST$1,\n 'linear mipmap nearest': GL_LINEAR_MIPMAP_NEAREST$1,\n 'nearest mipmap linear': GL_NEAREST_MIPMAP_LINEAR$1,\n 'linear mipmap linear': GL_LINEAR_MIPMAP_LINEAR$1\n }, magFilters)\n\n var colorSpace = {\n 'none': 0,\n 'browser': GL_BROWSER_DEFAULT_WEBGL\n }\n\n var textureTypes = {\n 'uint8': GL_UNSIGNED_BYTE$5,\n 'rgba4': GL_UNSIGNED_SHORT_4_4_4_4$1,\n 'rgb565': GL_UNSIGNED_SHORT_5_6_5$1,\n 'rgb5 a1': GL_UNSIGNED_SHORT_5_5_5_1$1\n }\n\n var textureFormats = {\n 'alpha': GL_ALPHA,\n 'luminance': GL_LUMINANCE,\n 'luminance alpha': GL_LUMINANCE_ALPHA,\n 'rgb': GL_RGB,\n 'rgba': GL_RGBA$1,\n 'rgba4': GL_RGBA4,\n 'rgb5 a1': GL_RGB5_A1,\n 'rgb565': GL_RGB565\n }\n\n var compressedTextureFormats = {}\n\n if (extensions.ext_srgb) {\n textureFormats.srgb = GL_SRGB_EXT\n textureFormats.srgba = GL_SRGB_ALPHA_EXT\n }\n\n if (extensions.oes_texture_float) {\n textureTypes.float32 = textureTypes.float = GL_FLOAT$4\n }\n\n if (extensions.oes_texture_half_float) {\n textureTypes['float16'] = textureTypes['half float'] = GL_HALF_FLOAT_OES$1\n }\n\n if (extensions.webgl_depth_texture) {\n extend(textureFormats, {\n 'depth': GL_DEPTH_COMPONENT,\n 'depth stencil': GL_DEPTH_STENCIL\n })\n\n extend(textureTypes, {\n 'uint16': GL_UNSIGNED_SHORT$3,\n 'uint32': GL_UNSIGNED_INT$3,\n 'depth stencil': GL_UNSIGNED_INT_24_8_WEBGL$1\n })\n }\n\n if (extensions.webgl_compressed_texture_s3tc) {\n extend(compressedTextureFormats, {\n 'rgb s3tc dxt1': GL_COMPRESSED_RGB_S3TC_DXT1_EXT,\n 'rgba s3tc dxt1': GL_COMPRESSED_RGBA_S3TC_DXT1_EXT,\n 'rgba s3tc dxt3': GL_COMPRESSED_RGBA_S3TC_DXT3_EXT,\n 'rgba s3tc dxt5': GL_COMPRESSED_RGBA_S3TC_DXT5_EXT\n })\n }\n\n if (extensions.webgl_compressed_texture_atc) {\n extend(compressedTextureFormats, {\n 'rgb atc': GL_COMPRESSED_RGB_ATC_WEBGL,\n 'rgba atc explicit alpha': GL_COMPRESSED_RGBA_ATC_EXPLICIT_ALPHA_WEBGL,\n 'rgba atc interpolated alpha': GL_COMPRESSED_RGBA_ATC_INTERPOLATED_ALPHA_WEBGL\n })\n }\n\n if (extensions.webgl_compressed_texture_pvrtc) {\n extend(compressedTextureFormats, {\n 'rgb pvrtc 4bppv1': GL_COMPRESSED_RGB_PVRTC_4BPPV1_IMG,\n 'rgb pvrtc 2bppv1': GL_COMPRESSED_RGB_PVRTC_2BPPV1_IMG,\n 'rgba pvrtc 4bppv1': GL_COMPRESSED_RGBA_PVRTC_4BPPV1_IMG,\n 'rgba pvrtc 2bppv1': GL_COMPRESSED_RGBA_PVRTC_2BPPV1_IMG\n })\n }\n\n if (extensions.webgl_compressed_texture_etc1) {\n compressedTextureFormats['rgb etc1'] = GL_COMPRESSED_RGB_ETC1_WEBGL\n }\n\n // Copy over all texture formats\n var supportedCompressedFormats = Array.prototype.slice.call(\n gl.getParameter(GL_COMPRESSED_TEXTURE_FORMATS))\n Object.keys(compressedTextureFormats).forEach(function (name) {\n var format = compressedTextureFormats[name]\n if (supportedCompressedFormats.indexOf(format) >= 0) {\n textureFormats[name] = format\n }\n })\n\n var supportedFormats = Object.keys(textureFormats)\n limits.textureFormats = supportedFormats\n\n // associate with every format string its\n // corresponding GL-value.\n var textureFormatsInvert = []\n Object.keys(textureFormats).forEach(function (key) {\n var val = textureFormats[key]\n textureFormatsInvert[val] = key\n })\n\n // associate with every type string its\n // corresponding GL-value.\n var textureTypesInvert = []\n Object.keys(textureTypes).forEach(function (key) {\n var val = textureTypes[key]\n textureTypesInvert[val] = key\n })\n\n var magFiltersInvert = []\n Object.keys(magFilters).forEach(function (key) {\n var val = magFilters[key]\n magFiltersInvert[val] = key\n })\n\n var minFiltersInvert = []\n Object.keys(minFilters).forEach(function (key) {\n var val = minFilters[key]\n minFiltersInvert[val] = key\n })\n\n var wrapModesInvert = []\n Object.keys(wrapModes).forEach(function (key) {\n var val = wrapModes[key]\n wrapModesInvert[val] = key\n })\n\n // colorFormats[] gives the format (channels) associated to an\n // internalformat\n var colorFormats = supportedFormats.reduce(function (color, key) {\n var glenum = textureFormats[key]\n if (glenum === GL_LUMINANCE ||\n glenum === GL_ALPHA ||\n glenum === GL_LUMINANCE ||\n glenum === GL_LUMINANCE_ALPHA ||\n glenum === GL_DEPTH_COMPONENT ||\n glenum === GL_DEPTH_STENCIL ||\n (extensions.ext_srgb &&\n (glenum === GL_SRGB_EXT ||\n glenum === GL_SRGB_ALPHA_EXT))) {\n color[glenum] = glenum\n } else if (glenum === GL_RGB5_A1 || key.indexOf('rgba') >= 0) {\n color[glenum] = GL_RGBA$1\n } else {\n color[glenum] = GL_RGB\n }\n return color\n }, {})\n\n function TexFlags () {\n // format info\n this.internalformat = GL_RGBA$1\n this.format = GL_RGBA$1\n this.type = GL_UNSIGNED_BYTE$5\n this.compressed = false\n\n // pixel storage\n this.premultiplyAlpha = false\n this.flipY = false\n this.unpackAlignment = 1\n this.colorSpace = GL_BROWSER_DEFAULT_WEBGL\n\n // shape info\n this.width = 0\n this.height = 0\n this.channels = 0\n }\n\n function copyFlags (result, other) {\n result.internalformat = other.internalformat\n result.format = other.format\n result.type = other.type\n result.compressed = other.compressed\n\n result.premultiplyAlpha = other.premultiplyAlpha\n result.flipY = other.flipY\n result.unpackAlignment = other.unpackAlignment\n result.colorSpace = other.colorSpace\n\n result.width = other.width\n result.height = other.height\n result.channels = other.channels\n }\n\n function parseFlags (flags, options) {\n if (typeof options !== 'object' || !options) {\n return\n }\n\n if ('premultiplyAlpha' in options) {\n check$1.type(options.premultiplyAlpha, 'boolean',\n 'invalid premultiplyAlpha')\n flags.premultiplyAlpha = options.premultiplyAlpha\n }\n\n if ('flipY' in options) {\n check$1.type(options.flipY, 'boolean',\n 'invalid texture flip')\n flags.flipY = options.flipY\n }\n\n if ('alignment' in options) {\n check$1.oneOf(options.alignment, [1, 2, 4, 8],\n 'invalid texture unpack alignment')\n flags.unpackAlignment = options.alignment\n }\n\n if ('colorSpace' in options) {\n check$1.parameter(options.colorSpace, colorSpace,\n 'invalid colorSpace')\n flags.colorSpace = colorSpace[options.colorSpace]\n }\n\n if ('type' in options) {\n var type = options.type\n check$1(extensions.oes_texture_float ||\n !(type === 'float' || type === 'float32'),\n 'you must enable the OES_texture_float extension in order to use floating point textures.')\n check$1(extensions.oes_texture_half_float ||\n !(type === 'half float' || type === 'float16'),\n 'you must enable the OES_texture_half_float extension in order to use 16-bit floating point textures.')\n check$1(extensions.webgl_depth_texture ||\n !(type === 'uint16' || type === 'uint32' || type === 'depth stencil'),\n 'you must enable the WEBGL_depth_texture extension in order to use depth/stencil textures.')\n check$1.parameter(type, textureTypes,\n 'invalid texture type')\n flags.type = textureTypes[type]\n }\n\n var w = flags.width\n var h = flags.height\n var c = flags.channels\n var hasChannels = false\n if ('shape' in options) {\n check$1(Array.isArray(options.shape) && options.shape.length >= 2,\n 'shape must be an array')\n w = options.shape[0]\n h = options.shape[1]\n if (options.shape.length === 3) {\n c = options.shape[2]\n check$1(c > 0 && c <= 4, 'invalid number of channels')\n hasChannels = true\n }\n check$1(w >= 0 && w <= limits.maxTextureSize, 'invalid width')\n check$1(h >= 0 && h <= limits.maxTextureSize, 'invalid height')\n } else {\n if ('radius' in options) {\n w = h = options.radius\n check$1(w >= 0 && w <= limits.maxTextureSize, 'invalid radius')\n }\n if ('width' in options) {\n w = options.width\n check$1(w >= 0 && w <= limits.maxTextureSize, 'invalid width')\n }\n if ('height' in options) {\n h = options.height\n check$1(h >= 0 && h <= limits.maxTextureSize, 'invalid height')\n }\n if ('channels' in options) {\n c = options.channels\n check$1(c > 0 && c <= 4, 'invalid number of channels')\n hasChannels = true\n }\n }\n flags.width = w | 0\n flags.height = h | 0\n flags.channels = c | 0\n\n var hasFormat = false\n if ('format' in options) {\n var formatStr = options.format\n check$1(extensions.webgl_depth_texture ||\n !(formatStr === 'depth' || formatStr === 'depth stencil'),\n 'you must enable the WEBGL_depth_texture extension in order to use depth/stencil textures.')\n check$1.parameter(formatStr, textureFormats,\n 'invalid texture format')\n var internalformat = flags.internalformat = textureFormats[formatStr]\n flags.format = colorFormats[internalformat]\n if (formatStr in textureTypes) {\n if (!('type' in options)) {\n flags.type = textureTypes[formatStr]\n }\n }\n if (formatStr in compressedTextureFormats) {\n flags.compressed = true\n }\n hasFormat = true\n }\n\n // Reconcile channels and format\n if (!hasChannels && hasFormat) {\n flags.channels = FORMAT_CHANNELS[flags.format]\n } else if (hasChannels && !hasFormat) {\n if (flags.channels !== CHANNELS_FORMAT[flags.format]) {\n flags.format = flags.internalformat = CHANNELS_FORMAT[flags.channels]\n }\n } else if (hasFormat && hasChannels) {\n check$1(\n flags.channels === FORMAT_CHANNELS[flags.format],\n 'number of channels inconsistent with specified format')\n }\n }\n\n function setFlags (flags) {\n gl.pixelStorei(GL_UNPACK_FLIP_Y_WEBGL, flags.flipY)\n gl.pixelStorei(GL_UNPACK_PREMULTIPLY_ALPHA_WEBGL, flags.premultiplyAlpha)\n gl.pixelStorei(GL_UNPACK_COLORSPACE_CONVERSION_WEBGL, flags.colorSpace)\n gl.pixelStorei(GL_UNPACK_ALIGNMENT, flags.unpackAlignment)\n }\n\n // -------------------------------------------------------\n // Tex image data\n // -------------------------------------------------------\n function TexImage () {\n TexFlags.call(this)\n\n this.xOffset = 0\n this.yOffset = 0\n\n // data\n this.data = null\n this.needsFree = false\n\n // html element\n this.element = null\n\n // copyTexImage info\n this.needsCopy = false\n }\n\n function parseImage (image, options) {\n var data = null\n if (isPixelData(options)) {\n data = options\n } else if (options) {\n check$1.type(options, 'object', 'invalid pixel data type')\n parseFlags(image, options)\n if ('x' in options) {\n image.xOffset = options.x | 0\n }\n if ('y' in options) {\n image.yOffset = options.y | 0\n }\n if (isPixelData(options.data)) {\n data = options.data\n }\n }\n\n check$1(\n !image.compressed ||\n data instanceof Uint8Array,\n 'compressed texture data must be stored in a uint8array')\n\n if (options.copy) {\n check$1(!data, 'can not specify copy and data field for the same texture')\n var viewW = contextState.viewportWidth\n var viewH = contextState.viewportHeight\n image.width = image.width || (viewW - image.xOffset)\n image.height = image.height || (viewH - image.yOffset)\n image.needsCopy = true\n check$1(image.xOffset >= 0 && image.xOffset < viewW &&\n image.yOffset >= 0 && image.yOffset < viewH &&\n image.width > 0 && image.width <= viewW &&\n image.height > 0 && image.height <= viewH,\n 'copy texture read out of bounds')\n } else if (!data) {\n image.width = image.width || 1\n image.height = image.height || 1\n image.channels = image.channels || 4\n } else if (isTypedArray(data)) {\n image.channels = image.channels || 4\n image.data = data\n if (!('type' in options) && image.type === GL_UNSIGNED_BYTE$5) {\n image.type = typedArrayCode$1(data)\n }\n } else if (isNumericArray(data)) {\n image.channels = image.channels || 4\n convertData(image, data)\n image.alignment = 1\n image.needsFree = true\n } else if (isNDArrayLike(data)) {\n var array = data.data\n if (!Array.isArray(array) && image.type === GL_UNSIGNED_BYTE$5) {\n image.type = typedArrayCode$1(array)\n }\n var shape = data.shape\n var stride = data.stride\n var shapeX, shapeY, shapeC, strideX, strideY, strideC\n if (shape.length === 3) {\n shapeC = shape[2]\n strideC = stride[2]\n } else {\n check$1(shape.length === 2, 'invalid ndarray pixel data, must be 2 or 3D')\n shapeC = 1\n strideC = 1\n }\n shapeX = shape[0]\n shapeY = shape[1]\n strideX = stride[0]\n strideY = stride[1]\n image.alignment = 1\n image.width = shapeX\n image.height = shapeY\n image.channels = shapeC\n image.format = image.internalformat = CHANNELS_FORMAT[shapeC]\n image.needsFree = true\n transposeData(image, array, strideX, strideY, strideC, data.offset)\n } else if (isCanvasElement(data) || isOffscreenCanvas(data) || isContext2D(data)) {\n if (isCanvasElement(data) || isOffscreenCanvas(data)) {\n image.element = data\n } else {\n image.element = data.canvas\n }\n image.width = image.element.width\n image.height = image.element.height\n image.channels = 4\n } else if (isBitmap(data)) {\n image.element = data\n image.width = data.width\n image.height = data.height\n image.channels = 4\n } else if (isImageElement(data)) {\n image.element = data\n image.width = data.naturalWidth\n image.height = data.naturalHeight\n image.channels = 4\n } else if (isVideoElement(data)) {\n image.element = data\n image.width = data.videoWidth\n image.height = data.videoHeight\n image.channels = 4\n } else if (isRectArray(data)) {\n var w = image.width || data[0].length\n var h = image.height || data.length\n var c = image.channels\n if (isArrayLike(data[0][0])) {\n c = c || data[0][0].length\n } else {\n c = c || 1\n }\n var arrayShape = flattenUtils.shape(data)\n var n = 1\n for (var dd = 0; dd < arrayShape.length; ++dd) {\n n *= arrayShape[dd]\n }\n var allocData = preConvert(image, n)\n flattenUtils.flatten(data, arrayShape, '', allocData)\n postConvert(image, allocData)\n image.alignment = 1\n image.width = w\n image.height = h\n image.channels = c\n image.format = image.internalformat = CHANNELS_FORMAT[c]\n image.needsFree = true\n }\n\n if (image.type === GL_FLOAT$4) {\n check$1(limits.extensions.indexOf('oes_texture_float') >= 0,\n 'oes_texture_float extension not enabled')\n } else if (image.type === GL_HALF_FLOAT_OES$1) {\n check$1(limits.extensions.indexOf('oes_texture_half_float') >= 0,\n 'oes_texture_half_float extension not enabled')\n }\n\n // do compressed texture validation here.\n }\n\n function setImage (info, target, miplevel) {\n var element = info.element\n var data = info.data\n var internalformat = info.internalformat\n var format = info.format\n var type = info.type\n var width = info.width\n var height = info.height\n\n setFlags(info)\n\n if (element) {\n gl.texImage2D(target, miplevel, format, format, type, element)\n } else if (info.compressed) {\n gl.compressedTexImage2D(target, miplevel, internalformat, width, height, 0, data)\n } else if (info.needsCopy) {\n reglPoll()\n gl.copyTexImage2D(\n target, miplevel, format, info.xOffset, info.yOffset, width, height, 0)\n } else {\n gl.texImage2D(target, miplevel, format, width, height, 0, format, type, data || null)\n }\n }\n\n function setSubImage (info, target, x, y, miplevel) {\n var element = info.element\n var data = info.data\n var internalformat = info.internalformat\n var format = info.format\n var type = info.type\n var width = info.width\n var height = info.height\n\n setFlags(info)\n\n if (element) {\n gl.texSubImage2D(\n target, miplevel, x, y, format, type, element)\n } else if (info.compressed) {\n gl.compressedTexSubImage2D(\n target, miplevel, x, y, internalformat, width, height, data)\n } else if (info.needsCopy) {\n reglPoll()\n gl.copyTexSubImage2D(\n target, miplevel, x, y, info.xOffset, info.yOffset, width, height)\n } else {\n gl.texSubImage2D(\n target, miplevel, x, y, width, height, format, type, data)\n }\n }\n\n // texImage pool\n var imagePool = []\n\n function allocImage () {\n return imagePool.pop() || new TexImage()\n }\n\n function freeImage (image) {\n if (image.needsFree) {\n pool.freeType(image.data)\n }\n TexImage.call(image)\n imagePool.push(image)\n }\n\n // -------------------------------------------------------\n // Mip map\n // -------------------------------------------------------\n function MipMap () {\n TexFlags.call(this)\n\n this.genMipmaps = false\n this.mipmapHint = GL_DONT_CARE\n this.mipmask = 0\n this.images = Array(16)\n }\n\n function parseMipMapFromShape (mipmap, width, height) {\n var img = mipmap.images[0] = allocImage()\n mipmap.mipmask = 1\n img.width = mipmap.width = width\n img.height = mipmap.height = height\n img.channels = mipmap.channels = 4\n }\n\n function parseMipMapFromObject (mipmap, options) {\n var imgData = null\n if (isPixelData(options)) {\n imgData = mipmap.images[0] = allocImage()\n copyFlags(imgData, mipmap)\n parseImage(imgData, options)\n mipmap.mipmask = 1\n } else {\n parseFlags(mipmap, options)\n if (Array.isArray(options.mipmap)) {\n var mipData = options.mipmap\n for (var i = 0; i < mipData.length; ++i) {\n imgData = mipmap.images[i] = allocImage()\n copyFlags(imgData, mipmap)\n imgData.width >>= i\n imgData.height >>= i\n parseImage(imgData, mipData[i])\n mipmap.mipmask |= (1 << i)\n }\n } else {\n imgData = mipmap.images[0] = allocImage()\n copyFlags(imgData, mipmap)\n parseImage(imgData, options)\n mipmap.mipmask = 1\n }\n }\n copyFlags(mipmap, mipmap.images[0])\n\n // For textures of the compressed format WEBGL_compressed_texture_s3tc\n // we must have that\n //\n // \"When level equals zero width and height must be a multiple of 4.\n // When level is greater than 0 width and height must be 0, 1, 2 or a multiple of 4. \"\n //\n // but we do not yet support having multiple mipmap levels for compressed textures,\n // so we only test for level zero.\n\n if (\n mipmap.compressed &&\n (\n mipmap.internalformat === GL_COMPRESSED_RGB_S3TC_DXT1_EXT ||\n mipmap.internalformat === GL_COMPRESSED_RGBA_S3TC_DXT1_EXT ||\n mipmap.internalformat === GL_COMPRESSED_RGBA_S3TC_DXT3_EXT ||\n mipmap.internalformat === GL_COMPRESSED_RGBA_S3TC_DXT5_EXT\n )\n ) {\n check$1(mipmap.width % 4 === 0 && mipmap.height % 4 === 0,\n 'for compressed texture formats, mipmap level 0 must have width and height that are a multiple of 4')\n }\n }\n\n function setMipMap (mipmap, target) {\n var images = mipmap.images\n for (var i = 0; i < images.length; ++i) {\n if (!images[i]) {\n return\n }\n setImage(images[i], target, i)\n }\n }\n\n var mipPool = []\n\n function allocMipMap () {\n var result = mipPool.pop() || new MipMap()\n TexFlags.call(result)\n result.mipmask = 0\n for (var i = 0; i < 16; ++i) {\n result.images[i] = null\n }\n return result\n }\n\n function freeMipMap (mipmap) {\n var images = mipmap.images\n for (var i = 0; i < images.length; ++i) {\n if (images[i]) {\n freeImage(images[i])\n }\n images[i] = null\n }\n mipPool.push(mipmap)\n }\n\n // -------------------------------------------------------\n // Tex info\n // -------------------------------------------------------\n function TexInfo () {\n this.minFilter = GL_NEAREST$1\n this.magFilter = GL_NEAREST$1\n\n this.wrapS = GL_CLAMP_TO_EDGE$1\n this.wrapT = GL_CLAMP_TO_EDGE$1\n\n this.anisotropic = 1\n\n this.genMipmaps = false\n this.mipmapHint = GL_DONT_CARE\n }\n\n function parseTexInfo (info, options) {\n if ('min' in options) {\n var minFilter = options.min\n check$1.parameter(minFilter, minFilters)\n info.minFilter = minFilters[minFilter]\n if (MIPMAP_FILTERS.indexOf(info.minFilter) >= 0 && !('faces' in options)) {\n info.genMipmaps = true\n }\n }\n\n if ('mag' in options) {\n var magFilter = options.mag\n check$1.parameter(magFilter, magFilters)\n info.magFilter = magFilters[magFilter]\n }\n\n var wrapS = info.wrapS\n var wrapT = info.wrapT\n if ('wrap' in options) {\n var wrap = options.wrap\n if (typeof wrap === 'string') {\n check$1.parameter(wrap, wrapModes)\n wrapS = wrapT = wrapModes[wrap]\n } else if (Array.isArray(wrap)) {\n check$1.parameter(wrap[0], wrapModes)\n check$1.parameter(wrap[1], wrapModes)\n wrapS = wrapModes[wrap[0]]\n wrapT = wrapModes[wrap[1]]\n }\n } else {\n if ('wrapS' in options) {\n var optWrapS = options.wrapS\n check$1.parameter(optWrapS, wrapModes)\n wrapS = wrapModes[optWrapS]\n }\n if ('wrapT' in options) {\n var optWrapT = options.wrapT\n check$1.parameter(optWrapT, wrapModes)\n wrapT = wrapModes[optWrapT]\n }\n }\n info.wrapS = wrapS\n info.wrapT = wrapT\n\n if ('anisotropic' in options) {\n var anisotropic = options.anisotropic\n check$1(typeof anisotropic === 'number' &&\n anisotropic >= 1 && anisotropic <= limits.maxAnisotropic,\n 'aniso samples must be between 1 and ')\n info.anisotropic = options.anisotropic\n }\n\n if ('mipmap' in options) {\n var hasMipMap = false\n switch (typeof options.mipmap) {\n case 'string':\n check$1.parameter(options.mipmap, mipmapHint,\n 'invalid mipmap hint')\n info.mipmapHint = mipmapHint[options.mipmap]\n info.genMipmaps = true\n hasMipMap = true\n break\n\n case 'boolean':\n hasMipMap = info.genMipmaps = options.mipmap\n break\n\n case 'object':\n check$1(Array.isArray(options.mipmap), 'invalid mipmap type')\n info.genMipmaps = false\n hasMipMap = true\n break\n\n default:\n check$1.raise('invalid mipmap type')\n }\n if (hasMipMap && !('min' in options)) {\n info.minFilter = GL_NEAREST_MIPMAP_NEAREST$1\n }\n }\n }\n\n function setTexInfo (info, target) {\n gl.texParameteri(target, GL_TEXTURE_MIN_FILTER, info.minFilter)\n gl.texParameteri(target, GL_TEXTURE_MAG_FILTER, info.magFilter)\n gl.texParameteri(target, GL_TEXTURE_WRAP_S, info.wrapS)\n gl.texParameteri(target, GL_TEXTURE_WRAP_T, info.wrapT)\n if (extensions.ext_texture_filter_anisotropic) {\n gl.texParameteri(target, GL_TEXTURE_MAX_ANISOTROPY_EXT, info.anisotropic)\n }\n if (info.genMipmaps) {\n gl.hint(GL_GENERATE_MIPMAP_HINT, info.mipmapHint)\n gl.generateMipmap(target)\n }\n }\n\n // -------------------------------------------------------\n // Full texture object\n // -------------------------------------------------------\n var textureCount = 0\n var textureSet = {}\n var numTexUnits = limits.maxTextureUnits\n var textureUnits = Array(numTexUnits).map(function () {\n return null\n })\n\n function REGLTexture (target) {\n TexFlags.call(this)\n this.mipmask = 0\n this.internalformat = GL_RGBA$1\n\n this.id = textureCount++\n\n this.refCount = 1\n\n this.target = target\n this.texture = gl.createTexture()\n\n this.unit = -1\n this.bindCount = 0\n\n this.texInfo = new TexInfo()\n\n if (config.profile) {\n this.stats = { size: 0 }\n }\n }\n\n function tempBind (texture) {\n gl.activeTexture(GL_TEXTURE0$1)\n gl.bindTexture(texture.target, texture.texture)\n }\n\n function tempRestore () {\n var prev = textureUnits[0]\n if (prev) {\n gl.bindTexture(prev.target, prev.texture)\n } else {\n gl.bindTexture(GL_TEXTURE_2D$1, null)\n }\n }\n\n function destroy (texture) {\n var handle = texture.texture\n check$1(handle, 'must not double destroy texture')\n var unit = texture.unit\n var target = texture.target\n if (unit >= 0) {\n gl.activeTexture(GL_TEXTURE0$1 + unit)\n gl.bindTexture(target, null)\n textureUnits[unit] = null\n }\n gl.deleteTexture(handle)\n texture.texture = null\n texture.params = null\n texture.pixels = null\n texture.refCount = 0\n delete textureSet[texture.id]\n stats.textureCount--\n }\n\n extend(REGLTexture.prototype, {\n bind: function () {\n var texture = this\n texture.bindCount += 1\n var unit = texture.unit\n if (unit < 0) {\n for (var i = 0; i < numTexUnits; ++i) {\n var other = textureUnits[i]\n if (other) {\n if (other.bindCount > 0) {\n continue\n }\n other.unit = -1\n }\n textureUnits[i] = texture\n unit = i\n break\n }\n if (unit >= numTexUnits) {\n check$1.raise('insufficient number of texture units')\n }\n if (config.profile && stats.maxTextureUnits < (unit + 1)) {\n stats.maxTextureUnits = unit + 1 // +1, since the units are zero-based\n }\n texture.unit = unit\n gl.activeTexture(GL_TEXTURE0$1 + unit)\n gl.bindTexture(texture.target, texture.texture)\n }\n return unit\n },\n\n unbind: function () {\n this.bindCount -= 1\n },\n\n decRef: function () {\n if (--this.refCount <= 0) {\n destroy(this)\n }\n }\n })\n\n function createTexture2D (a, b) {\n var texture = new REGLTexture(GL_TEXTURE_2D$1)\n textureSet[texture.id] = texture\n stats.textureCount++\n\n function reglTexture2D (a, b) {\n var texInfo = texture.texInfo\n TexInfo.call(texInfo)\n var mipData = allocMipMap()\n\n if (typeof a === 'number') {\n if (typeof b === 'number') {\n parseMipMapFromShape(mipData, a | 0, b | 0)\n } else {\n parseMipMapFromShape(mipData, a | 0, a | 0)\n }\n } else if (a) {\n check$1.type(a, 'object', 'invalid arguments to regl.texture')\n parseTexInfo(texInfo, a)\n parseMipMapFromObject(mipData, a)\n } else {\n // empty textures get assigned a default shape of 1x1\n parseMipMapFromShape(mipData, 1, 1)\n }\n\n if (texInfo.genMipmaps) {\n mipData.mipmask = (mipData.width << 1) - 1\n }\n texture.mipmask = mipData.mipmask\n\n copyFlags(texture, mipData)\n\n check$1.texture2D(texInfo, mipData, limits)\n texture.internalformat = mipData.internalformat\n\n reglTexture2D.width = mipData.width\n reglTexture2D.height = mipData.height\n\n tempBind(texture)\n setMipMap(mipData, GL_TEXTURE_2D$1)\n setTexInfo(texInfo, GL_TEXTURE_2D$1)\n tempRestore()\n\n freeMipMap(mipData)\n\n if (config.profile) {\n texture.stats.size = getTextureSize(\n texture.internalformat,\n texture.type,\n mipData.width,\n mipData.height,\n texInfo.genMipmaps,\n false)\n }\n reglTexture2D.format = textureFormatsInvert[texture.internalformat]\n reglTexture2D.type = textureTypesInvert[texture.type]\n\n reglTexture2D.mag = magFiltersInvert[texInfo.magFilter]\n reglTexture2D.min = minFiltersInvert[texInfo.minFilter]\n\n reglTexture2D.wrapS = wrapModesInvert[texInfo.wrapS]\n reglTexture2D.wrapT = wrapModesInvert[texInfo.wrapT]\n\n return reglTexture2D\n }\n\n function subimage (image, x_, y_, level_) {\n check$1(!!image, 'must specify image data')\n\n var x = x_ | 0\n var y = y_ | 0\n var level = level_ | 0\n\n var imageData = allocImage()\n copyFlags(imageData, texture)\n imageData.width = 0\n imageData.height = 0\n parseImage(imageData, image)\n imageData.width = imageData.width || ((texture.width >> level) - x)\n imageData.height = imageData.height || ((texture.height >> level) - y)\n\n check$1(\n texture.type === imageData.type &&\n texture.format === imageData.format &&\n texture.internalformat === imageData.internalformat,\n 'incompatible format for texture.subimage')\n check$1(\n x >= 0 && y >= 0 &&\n x + imageData.width <= texture.width &&\n y + imageData.height <= texture.height,\n 'texture.subimage write out of bounds')\n check$1(\n texture.mipmask & (1 << level),\n 'missing mipmap data')\n check$1(\n imageData.data || imageData.element || imageData.needsCopy,\n 'missing image data')\n\n tempBind(texture)\n setSubImage(imageData, GL_TEXTURE_2D$1, x, y, level)\n tempRestore()\n\n freeImage(imageData)\n\n return reglTexture2D\n }\n\n function resize (w_, h_) {\n var w = w_ | 0\n var h = (h_ | 0) || w\n if (w === texture.width && h === texture.height) {\n return reglTexture2D\n }\n\n reglTexture2D.width = texture.width = w\n reglTexture2D.height = texture.height = h\n\n tempBind(texture)\n\n for (var i = 0; texture.mipmask >> i; ++i) {\n var _w = w >> i\n var _h = h >> i\n if (!_w || !_h) break\n gl.texImage2D(\n GL_TEXTURE_2D$1,\n i,\n texture.format,\n _w,\n _h,\n 0,\n texture.format,\n texture.type,\n null)\n }\n tempRestore()\n\n // also, recompute the texture size.\n if (config.profile) {\n texture.stats.size = getTextureSize(\n texture.internalformat,\n texture.type,\n w,\n h,\n false,\n false)\n }\n\n return reglTexture2D\n }\n\n reglTexture2D(a, b)\n\n reglTexture2D.subimage = subimage\n reglTexture2D.resize = resize\n reglTexture2D._reglType = 'texture2d'\n reglTexture2D._texture = texture\n if (config.profile) {\n reglTexture2D.stats = texture.stats\n }\n reglTexture2D.destroy = function () {\n texture.decRef()\n }\n\n return reglTexture2D\n }\n\n function createTextureCube (a0, a1, a2, a3, a4, a5) {\n var texture = new REGLTexture(GL_TEXTURE_CUBE_MAP$1)\n textureSet[texture.id] = texture\n stats.cubeCount++\n\n var faces = new Array(6)\n\n function reglTextureCube (a0, a1, a2, a3, a4, a5) {\n var i\n var texInfo = texture.texInfo\n TexInfo.call(texInfo)\n for (i = 0; i < 6; ++i) {\n faces[i] = allocMipMap()\n }\n\n if (typeof a0 === 'number' || !a0) {\n var s = (a0 | 0) || 1\n for (i = 0; i < 6; ++i) {\n parseMipMapFromShape(faces[i], s, s)\n }\n } else if (typeof a0 === 'object') {\n if (a1) {\n parseMipMapFromObject(faces[0], a0)\n parseMipMapFromObject(faces[1], a1)\n parseMipMapFromObject(faces[2], a2)\n parseMipMapFromObject(faces[3], a3)\n parseMipMapFromObject(faces[4], a4)\n parseMipMapFromObject(faces[5], a5)\n } else {\n parseTexInfo(texInfo, a0)\n parseFlags(texture, a0)\n if ('faces' in a0) {\n var faceInput = a0.faces\n check$1(Array.isArray(faceInput) && faceInput.length === 6,\n 'cube faces must be a length 6 array')\n for (i = 0; i < 6; ++i) {\n check$1(typeof faceInput[i] === 'object' && !!faceInput[i],\n 'invalid input for cube map face')\n copyFlags(faces[i], texture)\n parseMipMapFromObject(faces[i], faceInput[i])\n }\n } else {\n for (i = 0; i < 6; ++i) {\n parseMipMapFromObject(faces[i], a0)\n }\n }\n }\n } else {\n check$1.raise('invalid arguments to cube map')\n }\n\n copyFlags(texture, faces[0])\n\n if (!limits.npotTextureCube) {\n check$1(isPow2$1(texture.width) && isPow2$1(texture.height), 'your browser does not support non power or two texture dimensions')\n }\n\n if (texInfo.genMipmaps) {\n texture.mipmask = (faces[0].width << 1) - 1\n } else {\n texture.mipmask = faces[0].mipmask\n }\n\n check$1.textureCube(texture, texInfo, faces, limits)\n texture.internalformat = faces[0].internalformat\n\n reglTextureCube.width = faces[0].width\n reglTextureCube.height = faces[0].height\n\n tempBind(texture)\n for (i = 0; i < 6; ++i) {\n setMipMap(faces[i], GL_TEXTURE_CUBE_MAP_POSITIVE_X$1 + i)\n }\n setTexInfo(texInfo, GL_TEXTURE_CUBE_MAP$1)\n tempRestore()\n\n if (config.profile) {\n texture.stats.size = getTextureSize(\n texture.internalformat,\n texture.type,\n reglTextureCube.width,\n reglTextureCube.height,\n texInfo.genMipmaps,\n true)\n }\n\n reglTextureCube.format = textureFormatsInvert[texture.internalformat]\n reglTextureCube.type = textureTypesInvert[texture.type]\n\n reglTextureCube.mag = magFiltersInvert[texInfo.magFilter]\n reglTextureCube.min = minFiltersInvert[texInfo.minFilter]\n\n reglTextureCube.wrapS = wrapModesInvert[texInfo.wrapS]\n reglTextureCube.wrapT = wrapModesInvert[texInfo.wrapT]\n\n for (i = 0; i < 6; ++i) {\n freeMipMap(faces[i])\n }\n\n return reglTextureCube\n }\n\n function subimage (face, image, x_, y_, level_) {\n check$1(!!image, 'must specify image data')\n check$1(typeof face === 'number' && face === (face | 0) &&\n face >= 0 && face < 6, 'invalid face')\n\n var x = x_ | 0\n var y = y_ | 0\n var level = level_ | 0\n\n var imageData = allocImage()\n copyFlags(imageData, texture)\n imageData.width = 0\n imageData.height = 0\n parseImage(imageData, image)\n imageData.width = imageData.width || ((texture.width >> level) - x)\n imageData.height = imageData.height || ((texture.height >> level) - y)\n\n check$1(\n texture.type === imageData.type &&\n texture.format === imageData.format &&\n texture.internalformat === imageData.internalformat,\n 'incompatible format for texture.subimage')\n check$1(\n x >= 0 && y >= 0 &&\n x + imageData.width <= texture.width &&\n y + imageData.height <= texture.height,\n 'texture.subimage write out of bounds')\n check$1(\n texture.mipmask & (1 << level),\n 'missing mipmap data')\n check$1(\n imageData.data || imageData.element || imageData.needsCopy,\n 'missing image data')\n\n tempBind(texture)\n setSubImage(imageData, GL_TEXTURE_CUBE_MAP_POSITIVE_X$1 + face, x, y, level)\n tempRestore()\n\n freeImage(imageData)\n\n return reglTextureCube\n }\n\n function resize (radius_) {\n var radius = radius_ | 0\n if (radius === texture.width) {\n return\n }\n\n reglTextureCube.width = texture.width = radius\n reglTextureCube.height = texture.height = radius\n\n tempBind(texture)\n for (var i = 0; i < 6; ++i) {\n for (var j = 0; texture.mipmask >> j; ++j) {\n gl.texImage2D(\n GL_TEXTURE_CUBE_MAP_POSITIVE_X$1 + i,\n j,\n texture.format,\n radius >> j,\n radius >> j,\n 0,\n texture.format,\n texture.type,\n null)\n }\n }\n tempRestore()\n\n if (config.profile) {\n texture.stats.size = getTextureSize(\n texture.internalformat,\n texture.type,\n reglTextureCube.width,\n reglTextureCube.height,\n false,\n true)\n }\n\n return reglTextureCube\n }\n\n reglTextureCube(a0, a1, a2, a3, a4, a5)\n\n reglTextureCube.subimage = subimage\n reglTextureCube.resize = resize\n reglTextureCube._reglType = 'textureCube'\n reglTextureCube._texture = texture\n if (config.profile) {\n reglTextureCube.stats = texture.stats\n }\n reglTextureCube.destroy = function () {\n texture.decRef()\n }\n\n return reglTextureCube\n }\n\n // Called when regl is destroyed\n function destroyTextures () {\n for (var i = 0; i < numTexUnits; ++i) {\n gl.activeTexture(GL_TEXTURE0$1 + i)\n gl.bindTexture(GL_TEXTURE_2D$1, null)\n textureUnits[i] = null\n }\n values(textureSet).forEach(destroy)\n\n stats.cubeCount = 0\n stats.textureCount = 0\n }\n\n if (config.profile) {\n stats.getTotalTextureSize = function () {\n var total = 0\n Object.keys(textureSet).forEach(function (key) {\n total += textureSet[key].stats.size\n })\n return total\n }\n }\n\n function restoreTextures () {\n for (var i = 0; i < numTexUnits; ++i) {\n var tex = textureUnits[i]\n if (tex) {\n tex.bindCount = 0\n tex.unit = -1\n textureUnits[i] = null\n }\n }\n\n values(textureSet).forEach(function (texture) {\n texture.texture = gl.createTexture()\n gl.bindTexture(texture.target, texture.texture)\n for (var i = 0; i < 32; ++i) {\n if ((texture.mipmask & (1 << i)) === 0) {\n continue\n }\n if (texture.target === GL_TEXTURE_2D$1) {\n gl.texImage2D(GL_TEXTURE_2D$1,\n i,\n texture.internalformat,\n texture.width >> i,\n texture.height >> i,\n 0,\n texture.internalformat,\n texture.type,\n null)\n } else {\n for (var j = 0; j < 6; ++j) {\n gl.texImage2D(GL_TEXTURE_CUBE_MAP_POSITIVE_X$1 + j,\n i,\n texture.internalformat,\n texture.width >> i,\n texture.height >> i,\n 0,\n texture.internalformat,\n texture.type,\n null)\n }\n }\n }\n setTexInfo(texture.texInfo, texture.target)\n })\n }\n\n function refreshTextures () {\n for (var i = 0; i < numTexUnits; ++i) {\n var tex = textureUnits[i]\n if (tex) {\n tex.bindCount = 0\n tex.unit = -1\n textureUnits[i] = null\n }\n gl.activeTexture(GL_TEXTURE0$1 + i)\n gl.bindTexture(GL_TEXTURE_2D$1, null)\n gl.bindTexture(GL_TEXTURE_CUBE_MAP$1, null)\n }\n }\n\n return {\n create2D: createTexture2D,\n createCube: createTextureCube,\n clear: destroyTextures,\n getTexture: function (wrapper) {\n return null\n },\n restore: restoreTextures,\n refresh: refreshTextures\n }\n}\n\nvar GL_RENDERBUFFER = 0x8D41\n\nvar GL_RGBA4$1 = 0x8056\nvar GL_RGB5_A1$1 = 0x8057\nvar GL_RGB565$1 = 0x8D62\nvar GL_DEPTH_COMPONENT16 = 0x81A5\nvar GL_STENCIL_INDEX8 = 0x8D48\nvar GL_DEPTH_STENCIL$1 = 0x84F9\n\nvar GL_SRGB8_ALPHA8_EXT = 0x8C43\n\nvar GL_RGBA32F_EXT = 0x8814\n\nvar GL_RGBA16F_EXT = 0x881A\nvar GL_RGB16F_EXT = 0x881B\n\nvar FORMAT_SIZES = []\n\nFORMAT_SIZES[GL_RGBA4$1] = 2\nFORMAT_SIZES[GL_RGB5_A1$1] = 2\nFORMAT_SIZES[GL_RGB565$1] = 2\n\nFORMAT_SIZES[GL_DEPTH_COMPONENT16] = 2\nFORMAT_SIZES[GL_STENCIL_INDEX8] = 1\nFORMAT_SIZES[GL_DEPTH_STENCIL$1] = 4\n\nFORMAT_SIZES[GL_SRGB8_ALPHA8_EXT] = 4\nFORMAT_SIZES[GL_RGBA32F_EXT] = 16\nFORMAT_SIZES[GL_RGBA16F_EXT] = 8\nFORMAT_SIZES[GL_RGB16F_EXT] = 6\n\nfunction getRenderbufferSize (format, width, height) {\n return FORMAT_SIZES[format] * width * height\n}\n\nvar wrapRenderbuffers = function (gl, extensions, limits, stats, config) {\n var formatTypes = {\n 'rgba4': GL_RGBA4$1,\n 'rgb565': GL_RGB565$1,\n 'rgb5 a1': GL_RGB5_A1$1,\n 'depth': GL_DEPTH_COMPONENT16,\n 'stencil': GL_STENCIL_INDEX8,\n 'depth stencil': GL_DEPTH_STENCIL$1\n }\n\n if (extensions.ext_srgb) {\n formatTypes['srgba'] = GL_SRGB8_ALPHA8_EXT\n }\n\n if (extensions.ext_color_buffer_half_float) {\n formatTypes['rgba16f'] = GL_RGBA16F_EXT\n formatTypes['rgb16f'] = GL_RGB16F_EXT\n }\n\n if (extensions.webgl_color_buffer_float) {\n formatTypes['rgba32f'] = GL_RGBA32F_EXT\n }\n\n var formatTypesInvert = []\n Object.keys(formatTypes).forEach(function (key) {\n var val = formatTypes[key]\n formatTypesInvert[val] = key\n })\n\n var renderbufferCount = 0\n var renderbufferSet = {}\n\n function REGLRenderbuffer (renderbuffer) {\n this.id = renderbufferCount++\n this.refCount = 1\n\n this.renderbuffer = renderbuffer\n\n this.format = GL_RGBA4$1\n this.width = 0\n this.height = 0\n\n if (config.profile) {\n this.stats = { size: 0 }\n }\n }\n\n REGLRenderbuffer.prototype.decRef = function () {\n if (--this.refCount <= 0) {\n destroy(this)\n }\n }\n\n function destroy (rb) {\n var handle = rb.renderbuffer\n check$1(handle, 'must not double destroy renderbuffer')\n gl.bindRenderbuffer(GL_RENDERBUFFER, null)\n gl.deleteRenderbuffer(handle)\n rb.renderbuffer = null\n rb.refCount = 0\n delete renderbufferSet[rb.id]\n stats.renderbufferCount--\n }\n\n function createRenderbuffer (a, b) {\n var renderbuffer = new REGLRenderbuffer(gl.createRenderbuffer())\n renderbufferSet[renderbuffer.id] = renderbuffer\n stats.renderbufferCount++\n\n function reglRenderbuffer (a, b) {\n var w = 0\n var h = 0\n var format = GL_RGBA4$1\n\n if (typeof a === 'object' && a) {\n var options = a\n if ('shape' in options) {\n var shape = options.shape\n check$1(Array.isArray(shape) && shape.length >= 2,\n 'invalid renderbuffer shape')\n w = shape[0] | 0\n h = shape[1] | 0\n } else {\n if ('radius' in options) {\n w = h = options.radius | 0\n }\n if ('width' in options) {\n w = options.width | 0\n }\n if ('height' in options) {\n h = options.height | 0\n }\n }\n if ('format' in options) {\n check$1.parameter(options.format, formatTypes,\n 'invalid renderbuffer format')\n format = formatTypes[options.format]\n }\n } else if (typeof a === 'number') {\n w = a | 0\n if (typeof b === 'number') {\n h = b | 0\n } else {\n h = w\n }\n } else if (!a) {\n w = h = 1\n } else {\n check$1.raise('invalid arguments to renderbuffer constructor')\n }\n\n // check shape\n check$1(\n w > 0 && h > 0 &&\n w <= limits.maxRenderbufferSize && h <= limits.maxRenderbufferSize,\n 'invalid renderbuffer size')\n\n if (w === renderbuffer.width &&\n h === renderbuffer.height &&\n format === renderbuffer.format) {\n return\n }\n\n reglRenderbuffer.width = renderbuffer.width = w\n reglRenderbuffer.height = renderbuffer.height = h\n renderbuffer.format = format\n\n gl.bindRenderbuffer(GL_RENDERBUFFER, renderbuffer.renderbuffer)\n gl.renderbufferStorage(GL_RENDERBUFFER, format, w, h)\n\n check$1(\n gl.getError() === 0,\n 'invalid render buffer format')\n\n if (config.profile) {\n renderbuffer.stats.size = getRenderbufferSize(renderbuffer.format, renderbuffer.width, renderbuffer.height)\n }\n reglRenderbuffer.format = formatTypesInvert[renderbuffer.format]\n\n return reglRenderbuffer\n }\n\n function resize (w_, h_) {\n var w = w_ | 0\n var h = (h_ | 0) || w\n\n if (w === renderbuffer.width && h === renderbuffer.height) {\n return reglRenderbuffer\n }\n\n // check shape\n check$1(\n w > 0 && h > 0 &&\n w <= limits.maxRenderbufferSize && h <= limits.maxRenderbufferSize,\n 'invalid renderbuffer size')\n\n reglRenderbuffer.width = renderbuffer.width = w\n reglRenderbuffer.height = renderbuffer.height = h\n\n gl.bindRenderbuffer(GL_RENDERBUFFER, renderbuffer.renderbuffer)\n gl.renderbufferStorage(GL_RENDERBUFFER, renderbuffer.format, w, h)\n\n check$1(\n gl.getError() === 0,\n 'invalid render buffer format')\n\n // also, recompute size.\n if (config.profile) {\n renderbuffer.stats.size = getRenderbufferSize(\n renderbuffer.format, renderbuffer.width, renderbuffer.height)\n }\n\n return reglRenderbuffer\n }\n\n reglRenderbuffer(a, b)\n\n reglRenderbuffer.resize = resize\n reglRenderbuffer._reglType = 'renderbuffer'\n reglRenderbuffer._renderbuffer = renderbuffer\n if (config.profile) {\n reglRenderbuffer.stats = renderbuffer.stats\n }\n reglRenderbuffer.destroy = function () {\n renderbuffer.decRef()\n }\n\n return reglRenderbuffer\n }\n\n if (config.profile) {\n stats.getTotalRenderbufferSize = function () {\n var total = 0\n Object.keys(renderbufferSet).forEach(function (key) {\n total += renderbufferSet[key].stats.size\n })\n return total\n }\n }\n\n function restoreRenderbuffers () {\n values(renderbufferSet).forEach(function (rb) {\n rb.renderbuffer = gl.createRenderbuffer()\n gl.bindRenderbuffer(GL_RENDERBUFFER, rb.renderbuffer)\n gl.renderbufferStorage(GL_RENDERBUFFER, rb.format, rb.width, rb.height)\n })\n gl.bindRenderbuffer(GL_RENDERBUFFER, null)\n }\n\n return {\n create: createRenderbuffer,\n clear: function () {\n values(renderbufferSet).forEach(destroy)\n },\n restore: restoreRenderbuffers\n }\n}\n\n// We store these constants so that the minifier can inline them\nvar GL_FRAMEBUFFER$1 = 0x8D40\nvar GL_RENDERBUFFER$1 = 0x8D41\n\nvar GL_TEXTURE_2D$2 = 0x0DE1\nvar GL_TEXTURE_CUBE_MAP_POSITIVE_X$2 = 0x8515\n\nvar GL_COLOR_ATTACHMENT0$1 = 0x8CE0\nvar GL_DEPTH_ATTACHMENT = 0x8D00\nvar GL_STENCIL_ATTACHMENT = 0x8D20\nvar GL_DEPTH_STENCIL_ATTACHMENT = 0x821A\n\nvar GL_FRAMEBUFFER_COMPLETE$1 = 0x8CD5\nvar GL_FRAMEBUFFER_INCOMPLETE_ATTACHMENT = 0x8CD6\nvar GL_FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT = 0x8CD7\nvar GL_FRAMEBUFFER_INCOMPLETE_DIMENSIONS = 0x8CD9\nvar GL_FRAMEBUFFER_UNSUPPORTED = 0x8CDD\n\nvar GL_HALF_FLOAT_OES$2 = 0x8D61\nvar GL_UNSIGNED_BYTE$6 = 0x1401\nvar GL_FLOAT$5 = 0x1406\n\nvar GL_RGB$1 = 0x1907\nvar GL_RGBA$2 = 0x1908\n\nvar GL_DEPTH_COMPONENT$1 = 0x1902\n\nvar colorTextureFormatEnums = [\n GL_RGB$1,\n GL_RGBA$2\n]\n\n// for every texture format, store\n// the number of channels\nvar textureFormatChannels = []\ntextureFormatChannels[GL_RGBA$2] = 4\ntextureFormatChannels[GL_RGB$1] = 3\n\n// for every texture type, store\n// the size in bytes.\nvar textureTypeSizes = []\ntextureTypeSizes[GL_UNSIGNED_BYTE$6] = 1\ntextureTypeSizes[GL_FLOAT$5] = 4\ntextureTypeSizes[GL_HALF_FLOAT_OES$2] = 2\n\nvar GL_RGBA4$2 = 0x8056\nvar GL_RGB5_A1$2 = 0x8057\nvar GL_RGB565$2 = 0x8D62\nvar GL_DEPTH_COMPONENT16$1 = 0x81A5\nvar GL_STENCIL_INDEX8$1 = 0x8D48\nvar GL_DEPTH_STENCIL$2 = 0x84F9\n\nvar GL_SRGB8_ALPHA8_EXT$1 = 0x8C43\n\nvar GL_RGBA32F_EXT$1 = 0x8814\n\nvar GL_RGBA16F_EXT$1 = 0x881A\nvar GL_RGB16F_EXT$1 = 0x881B\n\nvar colorRenderbufferFormatEnums = [\n GL_RGBA4$2,\n GL_RGB5_A1$2,\n GL_RGB565$2,\n GL_SRGB8_ALPHA8_EXT$1,\n GL_RGBA16F_EXT$1,\n GL_RGB16F_EXT$1,\n GL_RGBA32F_EXT$1\n]\n\nvar statusCode = {}\nstatusCode[GL_FRAMEBUFFER_COMPLETE$1] = 'complete'\nstatusCode[GL_FRAMEBUFFER_INCOMPLETE_ATTACHMENT] = 'incomplete attachment'\nstatusCode[GL_FRAMEBUFFER_INCOMPLETE_DIMENSIONS] = 'incomplete dimensions'\nstatusCode[GL_FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT] = 'incomplete, missing attachment'\nstatusCode[GL_FRAMEBUFFER_UNSUPPORTED] = 'unsupported'\n\nfunction wrapFBOState (\n gl,\n extensions,\n limits,\n textureState,\n renderbufferState,\n stats) {\n var framebufferState = {\n cur: null,\n next: null,\n dirty: false,\n setFBO: null\n }\n\n var colorTextureFormats = ['rgba']\n var colorRenderbufferFormats = ['rgba4', 'rgb565', 'rgb5 a1']\n\n if (extensions.ext_srgb) {\n colorRenderbufferFormats.push('srgba')\n }\n\n if (extensions.ext_color_buffer_half_float) {\n colorRenderbufferFormats.push('rgba16f', 'rgb16f')\n }\n\n if (extensions.webgl_color_buffer_float) {\n colorRenderbufferFormats.push('rgba32f')\n }\n\n var colorTypes = ['uint8']\n if (extensions.oes_texture_half_float) {\n colorTypes.push('half float', 'float16')\n }\n if (extensions.oes_texture_float) {\n colorTypes.push('float', 'float32')\n }\n\n function FramebufferAttachment (target, texture, renderbuffer) {\n this.target = target\n this.texture = texture\n this.renderbuffer = renderbuffer\n\n var w = 0\n var h = 0\n if (texture) {\n w = texture.width\n h = texture.height\n } else if (renderbuffer) {\n w = renderbuffer.width\n h = renderbuffer.height\n }\n this.width = w\n this.height = h\n }\n\n function decRef (attachment) {\n if (attachment) {\n if (attachment.texture) {\n attachment.texture._texture.decRef()\n }\n if (attachment.renderbuffer) {\n attachment.renderbuffer._renderbuffer.decRef()\n }\n }\n }\n\n function incRefAndCheckShape (attachment, width, height) {\n if (!attachment) {\n return\n }\n if (attachment.texture) {\n var texture = attachment.texture._texture\n var tw = Math.max(1, texture.width)\n var th = Math.max(1, texture.height)\n check$1(tw === width && th === height,\n 'inconsistent width/height for supplied texture')\n texture.refCount += 1\n } else {\n var renderbuffer = attachment.renderbuffer._renderbuffer\n check$1(\n renderbuffer.width === width && renderbuffer.height === height,\n 'inconsistent width/height for renderbuffer')\n renderbuffer.refCount += 1\n }\n }\n\n function attach (location, attachment) {\n if (attachment) {\n if (attachment.texture) {\n gl.framebufferTexture2D(\n GL_FRAMEBUFFER$1,\n location,\n attachment.target,\n attachment.texture._texture.texture,\n 0)\n } else {\n gl.framebufferRenderbuffer(\n GL_FRAMEBUFFER$1,\n location,\n GL_RENDERBUFFER$1,\n attachment.renderbuffer._renderbuffer.renderbuffer)\n }\n }\n }\n\n function parseAttachment (attachment) {\n var target = GL_TEXTURE_2D$2\n var texture = null\n var renderbuffer = null\n\n var data = attachment\n if (typeof attachment === 'object') {\n data = attachment.data\n if ('target' in attachment) {\n target = attachment.target | 0\n }\n }\n\n check$1.type(data, 'function', 'invalid attachment data')\n\n var type = data._reglType\n if (type === 'texture2d') {\n texture = data\n check$1(target === GL_TEXTURE_2D$2)\n } else if (type === 'textureCube') {\n texture = data\n check$1(\n target >= GL_TEXTURE_CUBE_MAP_POSITIVE_X$2 &&\n target < GL_TEXTURE_CUBE_MAP_POSITIVE_X$2 + 6,\n 'invalid cube map target')\n } else if (type === 'renderbuffer') {\n renderbuffer = data\n target = GL_RENDERBUFFER$1\n } else {\n check$1.raise('invalid regl object for attachment')\n }\n\n return new FramebufferAttachment(target, texture, renderbuffer)\n }\n\n function allocAttachment (\n width,\n height,\n isTexture,\n format,\n type) {\n if (isTexture) {\n var texture = textureState.create2D({\n width: width,\n height: height,\n format: format,\n type: type\n })\n texture._texture.refCount = 0\n return new FramebufferAttachment(GL_TEXTURE_2D$2, texture, null)\n } else {\n var rb = renderbufferState.create({\n width: width,\n height: height,\n format: format\n })\n rb._renderbuffer.refCount = 0\n return new FramebufferAttachment(GL_RENDERBUFFER$1, null, rb)\n }\n }\n\n function unwrapAttachment (attachment) {\n return attachment && (attachment.texture || attachment.renderbuffer)\n }\n\n function resizeAttachment (attachment, w, h) {\n if (attachment) {\n if (attachment.texture) {\n attachment.texture.resize(w, h)\n } else if (attachment.renderbuffer) {\n attachment.renderbuffer.resize(w, h)\n }\n attachment.width = w\n attachment.height = h\n }\n }\n\n var framebufferCount = 0\n var framebufferSet = {}\n\n function REGLFramebuffer () {\n this.id = framebufferCount++\n framebufferSet[this.id] = this\n\n this.framebuffer = gl.createFramebuffer()\n this.width = 0\n this.height = 0\n\n this.colorAttachments = []\n this.depthAttachment = null\n this.stencilAttachment = null\n this.depthStencilAttachment = null\n }\n\n function decFBORefs (framebuffer) {\n framebuffer.colorAttachments.forEach(decRef)\n decRef(framebuffer.depthAttachment)\n decRef(framebuffer.stencilAttachment)\n decRef(framebuffer.depthStencilAttachment)\n }\n\n function destroy (framebuffer) {\n var handle = framebuffer.framebuffer\n check$1(handle, 'must not double destroy framebuffer')\n gl.deleteFramebuffer(handle)\n framebuffer.framebuffer = null\n stats.framebufferCount--\n delete framebufferSet[framebuffer.id]\n }\n\n function updateFramebuffer (framebuffer) {\n var i\n\n gl.bindFramebuffer(GL_FRAMEBUFFER$1, framebuffer.framebuffer)\n var colorAttachments = framebuffer.colorAttachments\n for (i = 0; i < colorAttachments.length; ++i) {\n attach(GL_COLOR_ATTACHMENT0$1 + i, colorAttachments[i])\n }\n for (i = colorAttachments.length; i < limits.maxColorAttachments; ++i) {\n gl.framebufferTexture2D(\n GL_FRAMEBUFFER$1,\n GL_COLOR_ATTACHMENT0$1 + i,\n GL_TEXTURE_2D$2,\n null,\n 0)\n }\n\n gl.framebufferTexture2D(\n GL_FRAMEBUFFER$1,\n GL_DEPTH_STENCIL_ATTACHMENT,\n GL_TEXTURE_2D$2,\n null,\n 0)\n gl.framebufferTexture2D(\n GL_FRAMEBUFFER$1,\n GL_DEPTH_ATTACHMENT,\n GL_TEXTURE_2D$2,\n null,\n 0)\n gl.framebufferTexture2D(\n GL_FRAMEBUFFER$1,\n GL_STENCIL_ATTACHMENT,\n GL_TEXTURE_2D$2,\n null,\n 0)\n\n attach(GL_DEPTH_ATTACHMENT, framebuffer.depthAttachment)\n attach(GL_STENCIL_ATTACHMENT, framebuffer.stencilAttachment)\n attach(GL_DEPTH_STENCIL_ATTACHMENT, framebuffer.depthStencilAttachment)\n\n // Check status code\n var status = gl.checkFramebufferStatus(GL_FRAMEBUFFER$1)\n if (!gl.isContextLost() && status !== GL_FRAMEBUFFER_COMPLETE$1) {\n check$1.raise('framebuffer configuration not supported, status = ' +\n statusCode[status])\n }\n\n gl.bindFramebuffer(GL_FRAMEBUFFER$1, framebufferState.next ? framebufferState.next.framebuffer : null)\n framebufferState.cur = framebufferState.next\n\n // FIXME: Clear error code here. This is a work around for a bug in\n // headless-gl\n gl.getError()\n }\n\n function createFBO (a0, a1) {\n var framebuffer = new REGLFramebuffer()\n stats.framebufferCount++\n\n function reglFramebuffer (a, b) {\n var i\n\n check$1(framebufferState.next !== framebuffer,\n 'can not update framebuffer which is currently in use')\n\n var width = 0\n var height = 0\n\n var needsDepth = true\n var needsStencil = true\n\n var colorBuffer = null\n var colorTexture = true\n var colorFormat = 'rgba'\n var colorType = 'uint8'\n var colorCount = 1\n\n var depthBuffer = null\n var stencilBuffer = null\n var depthStencilBuffer = null\n var depthStencilTexture = false\n\n if (typeof a === 'number') {\n width = a | 0\n height = (b | 0) || width\n } else if (!a) {\n width = height = 1\n } else {\n check$1.type(a, 'object', 'invalid arguments for framebuffer')\n var options = a\n\n if ('shape' in options) {\n var shape = options.shape\n check$1(Array.isArray(shape) && shape.length >= 2,\n 'invalid shape for framebuffer')\n width = shape[0]\n height = shape[1]\n } else {\n if ('radius' in options) {\n width = height = options.radius\n }\n if ('width' in options) {\n width = options.width\n }\n if ('height' in options) {\n height = options.height\n }\n }\n\n if ('color' in options ||\n 'colors' in options) {\n colorBuffer =\n options.color ||\n options.colors\n if (Array.isArray(colorBuffer)) {\n check$1(\n colorBuffer.length === 1 || extensions.webgl_draw_buffers,\n 'multiple render targets not supported')\n }\n }\n\n if (!colorBuffer) {\n if ('colorCount' in options) {\n colorCount = options.colorCount | 0\n check$1(colorCount > 0, 'invalid color buffer count')\n }\n\n if ('colorTexture' in options) {\n colorTexture = !!options.colorTexture\n colorFormat = 'rgba4'\n }\n\n if ('colorType' in options) {\n colorType = options.colorType\n if (!colorTexture) {\n if (colorType === 'half float' || colorType === 'float16') {\n check$1(extensions.ext_color_buffer_half_float,\n 'you must enable EXT_color_buffer_half_float to use 16-bit render buffers')\n colorFormat = 'rgba16f'\n } else if (colorType === 'float' || colorType === 'float32') {\n check$1(extensions.webgl_color_buffer_float,\n 'you must enable WEBGL_color_buffer_float in order to use 32-bit floating point renderbuffers')\n colorFormat = 'rgba32f'\n }\n } else {\n check$1(extensions.oes_texture_float ||\n !(colorType === 'float' || colorType === 'float32'),\n 'you must enable OES_texture_float in order to use floating point framebuffer objects')\n check$1(extensions.oes_texture_half_float ||\n !(colorType === 'half float' || colorType === 'float16'),\n 'you must enable OES_texture_half_float in order to use 16-bit floating point framebuffer objects')\n }\n check$1.oneOf(colorType, colorTypes, 'invalid color type')\n }\n\n if ('colorFormat' in options) {\n colorFormat = options.colorFormat\n if (colorTextureFormats.indexOf(colorFormat) >= 0) {\n colorTexture = true\n } else if (colorRenderbufferFormats.indexOf(colorFormat) >= 0) {\n colorTexture = false\n } else {\n if (colorTexture) {\n check$1.oneOf(\n options.colorFormat, colorTextureFormats,\n 'invalid color format for texture')\n } else {\n check$1.oneOf(\n options.colorFormat, colorRenderbufferFormats,\n 'invalid color format for renderbuffer')\n }\n }\n }\n }\n\n if ('depthTexture' in options || 'depthStencilTexture' in options) {\n depthStencilTexture = !!(options.depthTexture ||\n options.depthStencilTexture)\n check$1(!depthStencilTexture || extensions.webgl_depth_texture,\n 'webgl_depth_texture extension not supported')\n }\n\n if ('depth' in options) {\n if (typeof options.depth === 'boolean') {\n needsDepth = options.depth\n } else {\n depthBuffer = options.depth\n needsStencil = false\n }\n }\n\n if ('stencil' in options) {\n if (typeof options.stencil === 'boolean') {\n needsStencil = options.stencil\n } else {\n stencilBuffer = options.stencil\n needsDepth = false\n }\n }\n\n if ('depthStencil' in options) {\n if (typeof options.depthStencil === 'boolean') {\n needsDepth = needsStencil = options.depthStencil\n } else {\n depthStencilBuffer = options.depthStencil\n needsDepth = false\n needsStencil = false\n }\n }\n }\n\n // parse attachments\n var colorAttachments = null\n var depthAttachment = null\n var stencilAttachment = null\n var depthStencilAttachment = null\n\n // Set up color attachments\n if (Array.isArray(colorBuffer)) {\n colorAttachments = colorBuffer.map(parseAttachment)\n } else if (colorBuffer) {\n colorAttachments = [parseAttachment(colorBuffer)]\n } else {\n colorAttachments = new Array(colorCount)\n for (i = 0; i < colorCount; ++i) {\n colorAttachments[i] = allocAttachment(\n width,\n height,\n colorTexture,\n colorFormat,\n colorType)\n }\n }\n\n check$1(extensions.webgl_draw_buffers || colorAttachments.length <= 1,\n 'you must enable the WEBGL_draw_buffers extension in order to use multiple color buffers.')\n check$1(colorAttachments.length <= limits.maxColorAttachments,\n 'too many color attachments, not supported')\n\n width = width || colorAttachments[0].width\n height = height || colorAttachments[0].height\n\n if (depthBuffer) {\n depthAttachment = parseAttachment(depthBuffer)\n } else if (needsDepth && !needsStencil) {\n depthAttachment = allocAttachment(\n width,\n height,\n depthStencilTexture,\n 'depth',\n 'uint32')\n }\n\n if (stencilBuffer) {\n stencilAttachment = parseAttachment(stencilBuffer)\n } else if (needsStencil && !needsDepth) {\n stencilAttachment = allocAttachment(\n width,\n height,\n false,\n 'stencil',\n 'uint8')\n }\n\n if (depthStencilBuffer) {\n depthStencilAttachment = parseAttachment(depthStencilBuffer)\n } else if (!depthBuffer && !stencilBuffer && needsStencil && needsDepth) {\n depthStencilAttachment = allocAttachment(\n width,\n height,\n depthStencilTexture,\n 'depth stencil',\n 'depth stencil')\n }\n\n check$1(\n (!!depthBuffer) + (!!stencilBuffer) + (!!depthStencilBuffer) <= 1,\n 'invalid framebuffer configuration, can specify exactly one depth/stencil attachment')\n\n var commonColorAttachmentSize = null\n\n for (i = 0; i < colorAttachments.length; ++i) {\n incRefAndCheckShape(colorAttachments[i], width, height)\n check$1(!colorAttachments[i] ||\n (colorAttachments[i].texture &&\n colorTextureFormatEnums.indexOf(colorAttachments[i].texture._texture.format) >= 0) ||\n (colorAttachments[i].renderbuffer &&\n colorRenderbufferFormatEnums.indexOf(colorAttachments[i].renderbuffer._renderbuffer.format) >= 0),\n 'framebuffer color attachment ' + i + ' is invalid')\n\n if (colorAttachments[i] && colorAttachments[i].texture) {\n var colorAttachmentSize =\n textureFormatChannels[colorAttachments[i].texture._texture.format] *\n textureTypeSizes[colorAttachments[i].texture._texture.type]\n\n if (commonColorAttachmentSize === null) {\n commonColorAttachmentSize = colorAttachmentSize\n } else {\n // We need to make sure that all color attachments have the same number of bitplanes\n // (that is, the same numer of bits per pixel)\n // This is required by the GLES2.0 standard. See the beginning of Chapter 4 in that document.\n check$1(commonColorAttachmentSize === colorAttachmentSize,\n 'all color attachments much have the same number of bits per pixel.')\n }\n }\n }\n incRefAndCheckShape(depthAttachment, width, height)\n check$1(!depthAttachment ||\n (depthAttachment.texture &&\n depthAttachment.texture._texture.format === GL_DEPTH_COMPONENT$1) ||\n (depthAttachment.renderbuffer &&\n depthAttachment.renderbuffer._renderbuffer.format === GL_DEPTH_COMPONENT16$1),\n 'invalid depth attachment for framebuffer object')\n incRefAndCheckShape(stencilAttachment, width, height)\n check$1(!stencilAttachment ||\n (stencilAttachment.renderbuffer &&\n stencilAttachment.renderbuffer._renderbuffer.format === GL_STENCIL_INDEX8$1),\n 'invalid stencil attachment for framebuffer object')\n incRefAndCheckShape(depthStencilAttachment, width, height)\n check$1(!depthStencilAttachment ||\n (depthStencilAttachment.texture &&\n depthStencilAttachment.texture._texture.format === GL_DEPTH_STENCIL$2) ||\n (depthStencilAttachment.renderbuffer &&\n depthStencilAttachment.renderbuffer._renderbuffer.format === GL_DEPTH_STENCIL$2),\n 'invalid depth-stencil attachment for framebuffer object')\n\n // decrement references\n decFBORefs(framebuffer)\n\n framebuffer.width = width\n framebuffer.height = height\n\n framebuffer.colorAttachments = colorAttachments\n framebuffer.depthAttachment = depthAttachment\n framebuffer.stencilAttachment = stencilAttachment\n framebuffer.depthStencilAttachment = depthStencilAttachment\n\n reglFramebuffer.color = colorAttachments.map(unwrapAttachment)\n reglFramebuffer.depth = unwrapAttachment(depthAttachment)\n reglFramebuffer.stencil = unwrapAttachment(stencilAttachment)\n reglFramebuffer.depthStencil = unwrapAttachment(depthStencilAttachment)\n\n reglFramebuffer.width = framebuffer.width\n reglFramebuffer.height = framebuffer.height\n\n updateFramebuffer(framebuffer)\n\n return reglFramebuffer\n }\n\n function resize (w_, h_) {\n check$1(framebufferState.next !== framebuffer,\n 'can not resize a framebuffer which is currently in use')\n\n var w = Math.max(w_ | 0, 1)\n var h = Math.max((h_ | 0) || w, 1)\n if (w === framebuffer.width && h === framebuffer.height) {\n return reglFramebuffer\n }\n\n // resize all buffers\n var colorAttachments = framebuffer.colorAttachments\n for (var i = 0; i < colorAttachments.length; ++i) {\n resizeAttachment(colorAttachments[i], w, h)\n }\n resizeAttachment(framebuffer.depthAttachment, w, h)\n resizeAttachment(framebuffer.stencilAttachment, w, h)\n resizeAttachment(framebuffer.depthStencilAttachment, w, h)\n\n framebuffer.width = reglFramebuffer.width = w\n framebuffer.height = reglFramebuffer.height = h\n\n updateFramebuffer(framebuffer)\n\n return reglFramebuffer\n }\n\n reglFramebuffer(a0, a1)\n\n return extend(reglFramebuffer, {\n resize: resize,\n _reglType: 'framebuffer',\n _framebuffer: framebuffer,\n destroy: function () {\n destroy(framebuffer)\n decFBORefs(framebuffer)\n },\n use: function (block) {\n framebufferState.setFBO({\n framebuffer: reglFramebuffer\n }, block)\n }\n })\n }\n\n function createCubeFBO (options) {\n var faces = Array(6)\n\n function reglFramebufferCube (a) {\n var i\n\n check$1(faces.indexOf(framebufferState.next) < 0,\n 'can not update framebuffer which is currently in use')\n\n var params = {\n color: null\n }\n\n var radius = 0\n\n var colorBuffer = null\n var colorFormat = 'rgba'\n var colorType = 'uint8'\n var colorCount = 1\n\n if (typeof a === 'number') {\n radius = a | 0\n } else if (!a) {\n radius = 1\n } else {\n check$1.type(a, 'object', 'invalid arguments for framebuffer')\n var options = a\n\n if ('shape' in options) {\n var shape = options.shape\n check$1(\n Array.isArray(shape) && shape.length >= 2,\n 'invalid shape for framebuffer')\n check$1(\n shape[0] === shape[1],\n 'cube framebuffer must be square')\n radius = shape[0]\n } else {\n if ('radius' in options) {\n radius = options.radius | 0\n }\n if ('width' in options) {\n radius = options.width | 0\n if ('height' in options) {\n check$1(options.height === radius, 'must be square')\n }\n } else if ('height' in options) {\n radius = options.height | 0\n }\n }\n\n if ('color' in options ||\n 'colors' in options) {\n colorBuffer =\n options.color ||\n options.colors\n if (Array.isArray(colorBuffer)) {\n check$1(\n colorBuffer.length === 1 || extensions.webgl_draw_buffers,\n 'multiple render targets not supported')\n }\n }\n\n if (!colorBuffer) {\n if ('colorCount' in options) {\n colorCount = options.colorCount | 0\n check$1(colorCount > 0, 'invalid color buffer count')\n }\n\n if ('colorType' in options) {\n check$1.oneOf(\n options.colorType, colorTypes,\n 'invalid color type')\n colorType = options.colorType\n }\n\n if ('colorFormat' in options) {\n colorFormat = options.colorFormat\n check$1.oneOf(\n options.colorFormat, colorTextureFormats,\n 'invalid color format for texture')\n }\n }\n\n if ('depth' in options) {\n params.depth = options.depth\n }\n\n if ('stencil' in options) {\n params.stencil = options.stencil\n }\n\n if ('depthStencil' in options) {\n params.depthStencil = options.depthStencil\n }\n }\n\n var colorCubes\n if (colorBuffer) {\n if (Array.isArray(colorBuffer)) {\n colorCubes = []\n for (i = 0; i < colorBuffer.length; ++i) {\n colorCubes[i] = colorBuffer[i]\n }\n } else {\n colorCubes = [ colorBuffer ]\n }\n } else {\n colorCubes = Array(colorCount)\n var cubeMapParams = {\n radius: radius,\n format: colorFormat,\n type: colorType\n }\n for (i = 0; i < colorCount; ++i) {\n colorCubes[i] = textureState.createCube(cubeMapParams)\n }\n }\n\n // Check color cubes\n params.color = Array(colorCubes.length)\n for (i = 0; i < colorCubes.length; ++i) {\n var cube = colorCubes[i]\n check$1(\n typeof cube === 'function' && cube._reglType === 'textureCube',\n 'invalid cube map')\n radius = radius || cube.width\n check$1(\n cube.width === radius && cube.height === radius,\n 'invalid cube map shape')\n params.color[i] = {\n target: GL_TEXTURE_CUBE_MAP_POSITIVE_X$2,\n data: colorCubes[i]\n }\n }\n\n for (i = 0; i < 6; ++i) {\n for (var j = 0; j < colorCubes.length; ++j) {\n params.color[j].target = GL_TEXTURE_CUBE_MAP_POSITIVE_X$2 + i\n }\n // reuse depth-stencil attachments across all cube maps\n if (i > 0) {\n params.depth = faces[0].depth\n params.stencil = faces[0].stencil\n params.depthStencil = faces[0].depthStencil\n }\n if (faces[i]) {\n (faces[i])(params)\n } else {\n faces[i] = createFBO(params)\n }\n }\n\n return extend(reglFramebufferCube, {\n width: radius,\n height: radius,\n color: colorCubes\n })\n }\n\n function resize (radius_) {\n var i\n var radius = radius_ | 0\n check$1(radius > 0 && radius <= limits.maxCubeMapSize,\n 'invalid radius for cube fbo')\n\n if (radius === reglFramebufferCube.width) {\n return reglFramebufferCube\n }\n\n var colors = reglFramebufferCube.color\n for (i = 0; i < colors.length; ++i) {\n colors[i].resize(radius)\n }\n\n for (i = 0; i < 6; ++i) {\n faces[i].resize(radius)\n }\n\n reglFramebufferCube.width = reglFramebufferCube.height = radius\n\n return reglFramebufferCube\n }\n\n reglFramebufferCube(options)\n\n return extend(reglFramebufferCube, {\n faces: faces,\n resize: resize,\n _reglType: 'framebufferCube',\n destroy: function () {\n faces.forEach(function (f) {\n f.destroy()\n })\n }\n })\n }\n\n function restoreFramebuffers () {\n framebufferState.cur = null\n framebufferState.next = null\n framebufferState.dirty = true\n values(framebufferSet).forEach(function (fb) {\n fb.framebuffer = gl.createFramebuffer()\n updateFramebuffer(fb)\n })\n }\n\n return extend(framebufferState, {\n getFramebuffer: function (object) {\n if (typeof object === 'function' && object._reglType === 'framebuffer') {\n var fbo = object._framebuffer\n if (fbo instanceof REGLFramebuffer) {\n return fbo\n }\n }\n return null\n },\n create: createFBO,\n createCube: createCubeFBO,\n clear: function () {\n values(framebufferSet).forEach(destroy)\n },\n restore: restoreFramebuffers\n })\n}\n\nvar GL_FLOAT$6 = 5126\nvar GL_ARRAY_BUFFER$1 = 34962\n\nfunction AttributeRecord () {\n this.state = 0\n\n this.x = 0.0\n this.y = 0.0\n this.z = 0.0\n this.w = 0.0\n\n this.buffer = null\n this.size = 0\n this.normalized = false\n this.type = GL_FLOAT$6\n this.offset = 0\n this.stride = 0\n this.divisor = 0\n}\n\nfunction wrapAttributeState (\n gl,\n extensions,\n limits,\n stats,\n bufferState) {\n var NUM_ATTRIBUTES = limits.maxAttributes\n var attributeBindings = new Array(NUM_ATTRIBUTES)\n for (var i = 0; i < NUM_ATTRIBUTES; ++i) {\n attributeBindings[i] = new AttributeRecord()\n }\n var vaoCount = 0\n var vaoSet = {}\n\n var state = {\n Record: AttributeRecord,\n scope: {},\n state: attributeBindings,\n currentVAO: null,\n targetVAO: null,\n restore: extVAO() ? restoreVAO : function () {},\n createVAO: createVAO,\n getVAO: getVAO,\n destroyBuffer: destroyBuffer,\n setVAO: extVAO() ? setVAOEXT : setVAOEmulated,\n clear: extVAO() ? destroyVAOEXT : function () {}\n }\n\n function destroyBuffer (buffer) {\n for (var i = 0; i < attributeBindings.length; ++i) {\n var record = attributeBindings[i]\n if (record.buffer === buffer) {\n gl.disableVertexAttribArray(i)\n record.buffer = null\n }\n }\n }\n\n function extVAO () {\n return extensions.oes_vertex_array_object\n }\n\n function extInstanced () {\n return extensions.angle_instanced_arrays\n }\n\n function getVAO (vao) {\n if (typeof vao === 'function' && vao._vao) {\n return vao._vao\n }\n return null\n }\n\n function setVAOEXT (vao) {\n if (vao === state.currentVAO) {\n return\n }\n var ext = extVAO()\n if (vao) {\n ext.bindVertexArrayOES(vao.vao)\n } else {\n ext.bindVertexArrayOES(null)\n }\n state.currentVAO = vao\n }\n\n function setVAOEmulated (vao) {\n if (vao === state.currentVAO) {\n return\n }\n if (vao) {\n vao.bindAttrs()\n } else {\n var exti = extInstanced()\n for (var i = 0; i < attributeBindings.length; ++i) {\n var binding = attributeBindings[i]\n if (binding.buffer) {\n gl.enableVertexAttribArray(i)\n gl.vertexAttribPointer(i, binding.size, binding.type, binding.normalized, binding.stride, binding.offfset)\n if (exti && binding.divisor) {\n exti.vertexAttribDivisorANGLE(i, binding.divisor)\n }\n } else {\n gl.disableVertexAttribArray(i)\n gl.vertexAttrib4f(i, binding.x, binding.y, binding.z, binding.w)\n }\n }\n }\n state.currentVAO = vao\n }\n\n function destroyVAOEXT () {\n values(vaoSet).forEach(function (vao) {\n vao.destroy()\n })\n }\n\n function REGLVAO () {\n this.id = ++vaoCount\n this.attributes = []\n var extension = extVAO()\n if (extension) {\n this.vao = extension.createVertexArrayOES()\n } else {\n this.vao = null\n }\n vaoSet[this.id] = this\n this.buffers = []\n }\n\n REGLVAO.prototype.bindAttrs = function () {\n var exti = extInstanced()\n var attributes = this.attributes\n for (var i = 0; i < attributes.length; ++i) {\n var attr = attributes[i]\n if (attr.buffer) {\n gl.enableVertexAttribArray(i)\n gl.bindBuffer(GL_ARRAY_BUFFER$1, attr.buffer.buffer)\n gl.vertexAttribPointer(i, attr.size, attr.type, attr.normalized, attr.stride, attr.offset)\n if (exti && attr.divisor) {\n exti.vertexAttribDivisorANGLE(i, attr.divisor)\n }\n } else {\n gl.disableVertexAttribArray(i)\n gl.vertexAttrib4f(i, attr.x, attr.y, attr.z, attr.w)\n }\n }\n for (var j = attributes.length; j < NUM_ATTRIBUTES; ++j) {\n gl.disableVertexAttribArray(j)\n }\n }\n\n REGLVAO.prototype.refresh = function () {\n var ext = extVAO()\n if (ext) {\n ext.bindVertexArrayOES(this.vao)\n this.bindAttrs()\n state.currentVAO = this\n }\n }\n\n REGLVAO.prototype.destroy = function () {\n if (this.vao) {\n var extension = extVAO()\n if (this === state.currentVAO) {\n state.currentVAO = null\n extension.bindVertexArrayOES(null)\n }\n extension.deleteVertexArrayOES(this.vao)\n this.vao = null\n }\n if (vaoSet[this.id]) {\n delete vaoSet[this.id]\n stats.vaoCount -= 1\n }\n }\n\n function restoreVAO () {\n var ext = extVAO()\n if (ext) {\n values(vaoSet).forEach(function (vao) {\n vao.refresh()\n })\n }\n }\n\n function createVAO (_attr) {\n var vao = new REGLVAO()\n stats.vaoCount += 1\n\n function updateVAO (attributes) {\n check$1(Array.isArray(attributes), 'arguments to vertex array constructor must be an array')\n check$1(attributes.length < NUM_ATTRIBUTES, 'too many attributes')\n check$1(attributes.length > 0, 'must specify at least one attribute')\n\n var bufUpdated = {}\n var nattributes = vao.attributes\n nattributes.length = attributes.length\n for (var i = 0; i < attributes.length; ++i) {\n var spec = attributes[i]\n var rec = nattributes[i] = new AttributeRecord()\n var data = spec.data || spec\n if (Array.isArray(data) || isTypedArray(data) || isNDArrayLike(data)) {\n var buf\n if (vao.buffers[i]) {\n buf = vao.buffers[i]\n if (isTypedArray(data) && buf._buffer.byteLength >= data.byteLength) {\n buf.subdata(data)\n } else {\n buf.destroy()\n vao.buffers[i] = null\n }\n }\n if (!vao.buffers[i]) {\n buf = vao.buffers[i] = bufferState.create(spec, GL_ARRAY_BUFFER$1, false, true)\n }\n rec.buffer = bufferState.getBuffer(buf)\n rec.size = rec.buffer.dimension | 0\n rec.normalized = false\n rec.type = rec.buffer.dtype\n rec.offset = 0\n rec.stride = 0\n rec.divisor = 0\n rec.state = 1\n bufUpdated[i] = 1\n } else if (bufferState.getBuffer(spec)) {\n rec.buffer = bufferState.getBuffer(spec)\n rec.size = rec.buffer.dimension | 0\n rec.normalized = false\n rec.type = rec.buffer.dtype\n rec.offset = 0\n rec.stride = 0\n rec.divisor = 0\n rec.state = 1\n } else if (bufferState.getBuffer(spec.buffer)) {\n rec.buffer = bufferState.getBuffer(spec.buffer)\n rec.size = ((+spec.size) || rec.buffer.dimension) | 0\n rec.normalized = !!spec.normalized || false\n if ('type' in spec) {\n check$1.parameter(spec.type, glTypes, 'invalid buffer type')\n rec.type = glTypes[spec.type]\n } else {\n rec.type = rec.buffer.dtype\n }\n rec.offset = (spec.offset || 0) | 0\n rec.stride = (spec.stride || 0) | 0\n rec.divisor = (spec.divisor || 0) | 0\n rec.state = 1\n\n check$1(rec.size >= 1 && rec.size <= 4, 'size must be between 1 and 4')\n check$1(rec.offset >= 0, 'invalid offset')\n check$1(rec.stride >= 0 && rec.stride <= 255, 'stride must be between 0 and 255')\n check$1(rec.divisor >= 0, 'divisor must be positive')\n check$1(!rec.divisor || !!extensions.angle_instanced_arrays, 'ANGLE_instanced_arrays must be enabled to use divisor')\n } else if ('x' in spec) {\n check$1(i > 0, 'first attribute must not be a constant')\n rec.x = +spec.x || 0\n rec.y = +spec.y || 0\n rec.z = +spec.z || 0\n rec.w = +spec.w || 0\n rec.state = 2\n } else {\n check$1(false, 'invalid attribute spec for location ' + i)\n }\n }\n\n // retire unused buffers\n for (var j = 0; j < vao.buffers.length; ++j) {\n if (!bufUpdated[j] && vao.buffers[j]) {\n vao.buffers[j].destroy()\n vao.buffers[j] = null\n }\n }\n\n vao.refresh()\n return updateVAO\n }\n\n updateVAO.destroy = function () {\n for (var j = 0; j < vao.buffers.length; ++j) {\n if (vao.buffers[j]) {\n vao.buffers[j].destroy()\n }\n }\n vao.buffers.length = 0\n vao.destroy()\n }\n\n updateVAO._vao = vao\n updateVAO._reglType = 'vao'\n\n return updateVAO(_attr)\n }\n\n return state\n}\n\nvar GL_FRAGMENT_SHADER = 35632\nvar GL_VERTEX_SHADER = 35633\n\nvar GL_ACTIVE_UNIFORMS = 0x8B86\nvar GL_ACTIVE_ATTRIBUTES = 0x8B89\n\nfunction wrapShaderState (gl, stringStore, stats, config) {\n // ===================================================\n // glsl compilation and linking\n // ===================================================\n var fragShaders = {}\n var vertShaders = {}\n\n function ActiveInfo (name, id, location, info) {\n this.name = name\n this.id = id\n this.location = location\n this.info = info\n }\n\n function insertActiveInfo (list, info) {\n for (var i = 0; i < list.length; ++i) {\n if (list[i].id === info.id) {\n list[i].location = info.location\n return\n }\n }\n list.push(info)\n }\n\n function getShader (type, id, command) {\n var cache = type === GL_FRAGMENT_SHADER ? fragShaders : vertShaders\n var shader = cache[id]\n\n if (!shader) {\n var source = stringStore.str(id)\n shader = gl.createShader(type)\n gl.shaderSource(shader, source)\n gl.compileShader(shader)\n check$1.shaderError(gl, shader, source, type, command)\n cache[id] = shader\n }\n\n return shader\n }\n\n // ===================================================\n // program linking\n // ===================================================\n var programCache = {}\n var programList = []\n\n var PROGRAM_COUNTER = 0\n\n function REGLProgram (fragId, vertId) {\n this.id = PROGRAM_COUNTER++\n this.fragId = fragId\n this.vertId = vertId\n this.program = null\n this.uniforms = []\n this.attributes = []\n this.refCount = 1\n\n if (config.profile) {\n this.stats = {\n uniformsCount: 0,\n attributesCount: 0\n }\n }\n }\n\n function linkProgram (desc, command, attributeLocations) {\n var i, info\n\n // -------------------------------\n // compile & link\n // -------------------------------\n var fragShader = getShader(GL_FRAGMENT_SHADER, desc.fragId)\n var vertShader = getShader(GL_VERTEX_SHADER, desc.vertId)\n\n var program = desc.program = gl.createProgram()\n gl.attachShader(program, fragShader)\n gl.attachShader(program, vertShader)\n if (attributeLocations) {\n for (i = 0; i < attributeLocations.length; ++i) {\n var binding = attributeLocations[i]\n gl.bindAttribLocation(program, binding[0], binding[1])\n }\n }\n\n gl.linkProgram(program)\n check$1.linkError(\n gl,\n program,\n stringStore.str(desc.fragId),\n stringStore.str(desc.vertId),\n command)\n\n // -------------------------------\n // grab uniforms\n // -------------------------------\n var numUniforms = gl.getProgramParameter(program, GL_ACTIVE_UNIFORMS)\n if (config.profile) {\n desc.stats.uniformsCount = numUniforms\n }\n var uniforms = desc.uniforms\n for (i = 0; i < numUniforms; ++i) {\n info = gl.getActiveUniform(program, i)\n if (info) {\n if (info.size > 1) {\n for (var j = 0; j < info.size; ++j) {\n var name = info.name.replace('[0]', '[' + j + ']')\n insertActiveInfo(uniforms, new ActiveInfo(\n name,\n stringStore.id(name),\n gl.getUniformLocation(program, name),\n info))\n }\n } else {\n insertActiveInfo(uniforms, new ActiveInfo(\n info.name,\n stringStore.id(info.name),\n gl.getUniformLocation(program, info.name),\n info))\n }\n }\n }\n\n // -------------------------------\n // grab attributes\n // -------------------------------\n var numAttributes = gl.getProgramParameter(program, GL_ACTIVE_ATTRIBUTES)\n if (config.profile) {\n desc.stats.attributesCount = numAttributes\n }\n\n var attributes = desc.attributes\n for (i = 0; i < numAttributes; ++i) {\n info = gl.getActiveAttrib(program, i)\n if (info) {\n insertActiveInfo(attributes, new ActiveInfo(\n info.name,\n stringStore.id(info.name),\n gl.getAttribLocation(program, info.name),\n info))\n }\n }\n }\n\n if (config.profile) {\n stats.getMaxUniformsCount = function () {\n var m = 0\n programList.forEach(function (desc) {\n if (desc.stats.uniformsCount > m) {\n m = desc.stats.uniformsCount\n }\n })\n return m\n }\n\n stats.getMaxAttributesCount = function () {\n var m = 0\n programList.forEach(function (desc) {\n if (desc.stats.attributesCount > m) {\n m = desc.stats.attributesCount\n }\n })\n return m\n }\n }\n\n function restoreShaders () {\n fragShaders = {}\n vertShaders = {}\n for (var i = 0; i < programList.length; ++i) {\n linkProgram(programList[i], null, programList[i].attributes.map(function (info) {\n return [info.location, info.name]\n }))\n }\n }\n\n return {\n clear: function () {\n var deleteShader = gl.deleteShader.bind(gl)\n values(fragShaders).forEach(deleteShader)\n fragShaders = {}\n values(vertShaders).forEach(deleteShader)\n vertShaders = {}\n\n programList.forEach(function (desc) {\n gl.deleteProgram(desc.program)\n })\n programList.length = 0\n programCache = {}\n\n stats.shaderCount = 0\n },\n\n program: function (vertId, fragId, command, attribLocations) {\n check$1.command(vertId >= 0, 'missing vertex shader', command)\n check$1.command(fragId >= 0, 'missing fragment shader', command)\n\n var cache = programCache[fragId]\n if (!cache) {\n cache = programCache[fragId] = {}\n }\n var prevProgram = cache[vertId]\n if (prevProgram) {\n prevProgram.refCount++\n if (!attribLocations) {\n return prevProgram\n }\n }\n var program = new REGLProgram(fragId, vertId)\n stats.shaderCount++\n linkProgram(program, command, attribLocations)\n if (!prevProgram) {\n cache[vertId] = program\n }\n programList.push(program)\n return extend(program, {\n destroy: function () {\n program.refCount--\n if (program.refCount <= 0) {\n gl.deleteProgram(program.program)\n var idx = programList.indexOf(program)\n programList.splice(idx, 1)\n stats.shaderCount--\n }\n // no program is linked to this vert anymore\n if (cache[program.vertId].refCount <= 0) {\n gl.deleteShader(vertShaders[program.vertId])\n delete vertShaders[program.vertId]\n delete programCache[program.fragId][program.vertId]\n }\n // no program is linked to this frag anymore\n if (!Object.keys(programCache[program.fragId]).length) {\n gl.deleteShader(fragShaders[program.fragId])\n delete fragShaders[program.fragId]\n delete programCache[program.fragId]\n }\n }\n })\n },\n\n restore: restoreShaders,\n\n shader: getShader,\n\n frag: -1,\n vert: -1\n }\n}\n\nvar GL_RGBA$3 = 6408\nvar GL_UNSIGNED_BYTE$7 = 5121\nvar GL_PACK_ALIGNMENT = 0x0D05\nvar GL_FLOAT$7 = 0x1406 // 5126\n\nfunction wrapReadPixels (\n gl,\n framebufferState,\n reglPoll,\n context,\n glAttributes,\n extensions,\n limits) {\n function readPixelsImpl (input) {\n var type\n if (framebufferState.next === null) {\n check$1(\n glAttributes.preserveDrawingBuffer,\n 'you must create a webgl context with \"preserveDrawingBuffer\":true in order to read pixels from the drawing buffer')\n type = GL_UNSIGNED_BYTE$7\n } else {\n check$1(\n framebufferState.next.colorAttachments[0].texture !== null,\n 'You cannot read from a renderbuffer')\n type = framebufferState.next.colorAttachments[0].texture._texture.type\n\n if (extensions.oes_texture_float) {\n check$1(\n type === GL_UNSIGNED_BYTE$7 || type === GL_FLOAT$7,\n 'Reading from a framebuffer is only allowed for the types \\'uint8\\' and \\'float\\'')\n\n if (type === GL_FLOAT$7) {\n check$1(limits.readFloat, 'Reading \\'float\\' values is not permitted in your browser. For a fallback, please see: https://www.npmjs.com/package/glsl-read-float')\n }\n } else {\n check$1(\n type === GL_UNSIGNED_BYTE$7,\n 'Reading from a framebuffer is only allowed for the type \\'uint8\\'')\n }\n }\n\n var x = 0\n var y = 0\n var width = context.framebufferWidth\n var height = context.framebufferHeight\n var data = null\n\n if (isTypedArray(input)) {\n data = input\n } else if (input) {\n check$1.type(input, 'object', 'invalid arguments to regl.read()')\n x = input.x | 0\n y = input.y | 0\n check$1(\n x >= 0 && x < context.framebufferWidth,\n 'invalid x offset for regl.read')\n check$1(\n y >= 0 && y < context.framebufferHeight,\n 'invalid y offset for regl.read')\n width = (input.width || (context.framebufferWidth - x)) | 0\n height = (input.height || (context.framebufferHeight - y)) | 0\n data = input.data || null\n }\n\n // sanity check input.data\n if (data) {\n if (type === GL_UNSIGNED_BYTE$7) {\n check$1(\n data instanceof Uint8Array,\n 'buffer must be \\'Uint8Array\\' when reading from a framebuffer of type \\'uint8\\'')\n } else if (type === GL_FLOAT$7) {\n check$1(\n data instanceof Float32Array,\n 'buffer must be \\'Float32Array\\' when reading from a framebuffer of type \\'float\\'')\n }\n }\n\n check$1(\n width > 0 && width + x <= context.framebufferWidth,\n 'invalid width for read pixels')\n check$1(\n height > 0 && height + y <= context.framebufferHeight,\n 'invalid height for read pixels')\n\n // Update WebGL state\n reglPoll()\n\n // Compute size\n var size = width * height * 4\n\n // Allocate data\n if (!data) {\n if (type === GL_UNSIGNED_BYTE$7) {\n data = new Uint8Array(size)\n } else if (type === GL_FLOAT$7) {\n data = data || new Float32Array(size)\n }\n }\n\n // Type check\n check$1.isTypedArray(data, 'data buffer for regl.read() must be a typedarray')\n check$1(data.byteLength >= size, 'data buffer for regl.read() too small')\n\n // Run read pixels\n gl.pixelStorei(GL_PACK_ALIGNMENT, 4)\n gl.readPixels(x, y, width, height, GL_RGBA$3,\n type,\n data)\n\n return data\n }\n\n function readPixelsFBO (options) {\n var result\n framebufferState.setFBO({\n framebuffer: options.framebuffer\n }, function () {\n result = readPixelsImpl(options)\n })\n return result\n }\n\n function readPixels (options) {\n if (!options || !('framebuffer' in options)) {\n return readPixelsImpl(options)\n } else {\n return readPixelsFBO(options)\n }\n }\n\n return readPixels\n}\n\nfunction slice (x) {\n return Array.prototype.slice.call(x)\n}\n\nfunction join (x) {\n return slice(x).join('')\n}\n\nfunction createEnvironment () {\n // Unique variable id counter\n var varCounter = 0\n\n // Linked values are passed from this scope into the generated code block\n // Calling link() passes a value into the generated scope and returns\n // the variable name which it is bound to\n var linkedNames = []\n var linkedValues = []\n function link (value) {\n for (var i = 0; i < linkedValues.length; ++i) {\n if (linkedValues[i] === value) {\n return linkedNames[i]\n }\n }\n\n var name = 'g' + (varCounter++)\n linkedNames.push(name)\n linkedValues.push(value)\n return name\n }\n\n // create a code block\n function block () {\n var code = []\n function push () {\n code.push.apply(code, slice(arguments))\n }\n\n var vars = []\n function def () {\n var name = 'v' + (varCounter++)\n vars.push(name)\n\n if (arguments.length > 0) {\n code.push(name, '=')\n code.push.apply(code, slice(arguments))\n code.push(';')\n }\n\n return name\n }\n\n return extend(push, {\n def: def,\n toString: function () {\n return join([\n (vars.length > 0 ? 'var ' + vars.join(',') + ';' : ''),\n join(code)\n ])\n }\n })\n }\n\n function scope () {\n var entry = block()\n var exit = block()\n\n var entryToString = entry.toString\n var exitToString = exit.toString\n\n function save (object, prop) {\n exit(object, prop, '=', entry.def(object, prop), ';')\n }\n\n return extend(function () {\n entry.apply(entry, slice(arguments))\n }, {\n def: entry.def,\n entry: entry,\n exit: exit,\n save: save,\n set: function (object, prop, value) {\n save(object, prop)\n entry(object, prop, '=', value, ';')\n },\n toString: function () {\n return entryToString() + exitToString()\n }\n })\n }\n\n function conditional () {\n var pred = join(arguments)\n var thenBlock = scope()\n var elseBlock = scope()\n\n var thenToString = thenBlock.toString\n var elseToString = elseBlock.toString\n\n return extend(thenBlock, {\n then: function () {\n thenBlock.apply(thenBlock, slice(arguments))\n return this\n },\n else: function () {\n elseBlock.apply(elseBlock, slice(arguments))\n return this\n },\n toString: function () {\n var elseClause = elseToString()\n if (elseClause) {\n elseClause = 'else{' + elseClause + '}'\n }\n return join([\n 'if(', pred, '){',\n thenToString(),\n '}', elseClause\n ])\n }\n })\n }\n\n // procedure list\n var globalBlock = block()\n var procedures = {}\n function proc (name, count) {\n var args = []\n function arg () {\n var name = 'a' + args.length\n args.push(name)\n return name\n }\n\n count = count || 0\n for (var i = 0; i < count; ++i) {\n arg()\n }\n\n var body = scope()\n var bodyToString = body.toString\n\n var result = procedures[name] = extend(body, {\n arg: arg,\n toString: function () {\n return join([\n 'function(', args.join(), '){',\n bodyToString(),\n '}'\n ])\n }\n })\n\n return result\n }\n\n function compile () {\n var code = ['\"use strict\";',\n globalBlock,\n 'return {']\n Object.keys(procedures).forEach(function (name) {\n code.push('\"', name, '\":', procedures[name].toString(), ',')\n })\n code.push('}')\n var src = join(code)\n .replace(/;/g, ';\\n')\n .replace(/}/g, '}\\n')\n .replace(/{/g, '{\\n')\n var proc = Function.apply(null, linkedNames.concat(src))\n return proc.apply(null, linkedValues)\n }\n\n return {\n global: globalBlock,\n link: link,\n block: block,\n proc: proc,\n scope: scope,\n cond: conditional,\n compile: compile\n }\n}\n\n// \"cute\" names for vector components\nvar CUTE_COMPONENTS = 'xyzw'.split('')\n\nvar GL_UNSIGNED_BYTE$8 = 5121\n\nvar ATTRIB_STATE_POINTER = 1\nvar ATTRIB_STATE_CONSTANT = 2\n\nvar DYN_FUNC$1 = 0\nvar DYN_PROP$1 = 1\nvar DYN_CONTEXT$1 = 2\nvar DYN_STATE$1 = 3\nvar DYN_THUNK = 4\nvar DYN_CONSTANT$1 = 5\nvar DYN_ARRAY$1 = 6\n\nvar S_DITHER = 'dither'\nvar S_BLEND_ENABLE = 'blend.enable'\nvar S_BLEND_COLOR = 'blend.color'\nvar S_BLEND_EQUATION = 'blend.equation'\nvar S_BLEND_FUNC = 'blend.func'\nvar S_DEPTH_ENABLE = 'depth.enable'\nvar S_DEPTH_FUNC = 'depth.func'\nvar S_DEPTH_RANGE = 'depth.range'\nvar S_DEPTH_MASK = 'depth.mask'\nvar S_COLOR_MASK = 'colorMask'\nvar S_CULL_ENABLE = 'cull.enable'\nvar S_CULL_FACE = 'cull.face'\nvar S_FRONT_FACE = 'frontFace'\nvar S_LINE_WIDTH = 'lineWidth'\nvar S_POLYGON_OFFSET_ENABLE = 'polygonOffset.enable'\nvar S_POLYGON_OFFSET_OFFSET = 'polygonOffset.offset'\nvar S_SAMPLE_ALPHA = 'sample.alpha'\nvar S_SAMPLE_ENABLE = 'sample.enable'\nvar S_SAMPLE_COVERAGE = 'sample.coverage'\nvar S_STENCIL_ENABLE = 'stencil.enable'\nvar S_STENCIL_MASK = 'stencil.mask'\nvar S_STENCIL_FUNC = 'stencil.func'\nvar S_STENCIL_OPFRONT = 'stencil.opFront'\nvar S_STENCIL_OPBACK = 'stencil.opBack'\nvar S_SCISSOR_ENABLE = 'scissor.enable'\nvar S_SCISSOR_BOX = 'scissor.box'\nvar S_VIEWPORT = 'viewport'\n\nvar S_PROFILE = 'profile'\n\nvar S_FRAMEBUFFER = 'framebuffer'\nvar S_VERT = 'vert'\nvar S_FRAG = 'frag'\nvar S_ELEMENTS = 'elements'\nvar S_PRIMITIVE = 'primitive'\nvar S_COUNT = 'count'\nvar S_OFFSET = 'offset'\nvar S_INSTANCES = 'instances'\nvar S_VAO = 'vao'\n\nvar SUFFIX_WIDTH = 'Width'\nvar SUFFIX_HEIGHT = 'Height'\n\nvar S_FRAMEBUFFER_WIDTH = S_FRAMEBUFFER + SUFFIX_WIDTH\nvar S_FRAMEBUFFER_HEIGHT = S_FRAMEBUFFER + SUFFIX_HEIGHT\nvar S_VIEWPORT_WIDTH = S_VIEWPORT + SUFFIX_WIDTH\nvar S_VIEWPORT_HEIGHT = S_VIEWPORT + SUFFIX_HEIGHT\nvar S_DRAWINGBUFFER = 'drawingBuffer'\nvar S_DRAWINGBUFFER_WIDTH = S_DRAWINGBUFFER + SUFFIX_WIDTH\nvar S_DRAWINGBUFFER_HEIGHT = S_DRAWINGBUFFER + SUFFIX_HEIGHT\n\nvar NESTED_OPTIONS = [\n S_BLEND_FUNC,\n S_BLEND_EQUATION,\n S_STENCIL_FUNC,\n S_STENCIL_OPFRONT,\n S_STENCIL_OPBACK,\n S_SAMPLE_COVERAGE,\n S_VIEWPORT,\n S_SCISSOR_BOX,\n S_POLYGON_OFFSET_OFFSET\n]\n\nvar GL_ARRAY_BUFFER$2 = 34962\nvar GL_ELEMENT_ARRAY_BUFFER$1 = 34963\n\nvar GL_FRAGMENT_SHADER$1 = 35632\nvar GL_VERTEX_SHADER$1 = 35633\n\nvar GL_TEXTURE_2D$3 = 0x0DE1\nvar GL_TEXTURE_CUBE_MAP$2 = 0x8513\n\nvar GL_CULL_FACE = 0x0B44\nvar GL_BLEND = 0x0BE2\nvar GL_DITHER = 0x0BD0\nvar GL_STENCIL_TEST = 0x0B90\nvar GL_DEPTH_TEST = 0x0B71\nvar GL_SCISSOR_TEST = 0x0C11\nvar GL_POLYGON_OFFSET_FILL = 0x8037\nvar GL_SAMPLE_ALPHA_TO_COVERAGE = 0x809E\nvar GL_SAMPLE_COVERAGE = 0x80A0\n\nvar GL_FLOAT$8 = 5126\nvar GL_FLOAT_VEC2 = 35664\nvar GL_FLOAT_VEC3 = 35665\nvar GL_FLOAT_VEC4 = 35666\nvar GL_INT$3 = 5124\nvar GL_INT_VEC2 = 35667\nvar GL_INT_VEC3 = 35668\nvar GL_INT_VEC4 = 35669\nvar GL_BOOL = 35670\nvar GL_BOOL_VEC2 = 35671\nvar GL_BOOL_VEC3 = 35672\nvar GL_BOOL_VEC4 = 35673\nvar GL_FLOAT_MAT2 = 35674\nvar GL_FLOAT_MAT3 = 35675\nvar GL_FLOAT_MAT4 = 35676\nvar GL_SAMPLER_2D = 35678\nvar GL_SAMPLER_CUBE = 35680\n\nvar GL_TRIANGLES$1 = 4\n\nvar GL_FRONT = 1028\nvar GL_BACK = 1029\nvar GL_CW = 0x0900\nvar GL_CCW = 0x0901\nvar GL_MIN_EXT = 0x8007\nvar GL_MAX_EXT = 0x8008\nvar GL_ALWAYS = 519\nvar GL_KEEP = 7680\nvar GL_ZERO = 0\nvar GL_ONE = 1\nvar GL_FUNC_ADD = 0x8006\nvar GL_LESS = 513\n\nvar GL_FRAMEBUFFER$2 = 0x8D40\nvar GL_COLOR_ATTACHMENT0$2 = 0x8CE0\n\nvar blendFuncs = {\n '0': 0,\n '1': 1,\n 'zero': 0,\n 'one': 1,\n 'src color': 768,\n 'one minus src color': 769,\n 'src alpha': 770,\n 'one minus src alpha': 771,\n 'dst color': 774,\n 'one minus dst color': 775,\n 'dst alpha': 772,\n 'one minus dst alpha': 773,\n 'constant color': 32769,\n 'one minus constant color': 32770,\n 'constant alpha': 32771,\n 'one minus constant alpha': 32772,\n 'src alpha saturate': 776\n}\n\n// There are invalid values for srcRGB and dstRGB. See:\n// https://www.khronos.org/registry/webgl/specs/1.0/#6.13\n// https://github.com/KhronosGroup/WebGL/blob/0d3201f5f7ec3c0060bc1f04077461541f1987b9/conformance-suites/1.0.3/conformance/misc/webgl-specific.html#L56\nvar invalidBlendCombinations = [\n 'constant color, constant alpha',\n 'one minus constant color, constant alpha',\n 'constant color, one minus constant alpha',\n 'one minus constant color, one minus constant alpha',\n 'constant alpha, constant color',\n 'constant alpha, one minus constant color',\n 'one minus constant alpha, constant color',\n 'one minus constant alpha, one minus constant color'\n]\n\nvar compareFuncs = {\n 'never': 512,\n 'less': 513,\n '<': 513,\n 'equal': 514,\n '=': 514,\n '==': 514,\n '===': 514,\n 'lequal': 515,\n '<=': 515,\n 'greater': 516,\n '>': 516,\n 'notequal': 517,\n '!=': 517,\n '!==': 517,\n 'gequal': 518,\n '>=': 518,\n 'always': 519\n}\n\nvar stencilOps = {\n '0': 0,\n 'zero': 0,\n 'keep': 7680,\n 'replace': 7681,\n 'increment': 7682,\n 'decrement': 7683,\n 'increment wrap': 34055,\n 'decrement wrap': 34056,\n 'invert': 5386\n}\n\nvar shaderType = {\n 'frag': GL_FRAGMENT_SHADER$1,\n 'vert': GL_VERTEX_SHADER$1\n}\n\nvar orientationType = {\n 'cw': GL_CW,\n 'ccw': GL_CCW\n}\n\nfunction isBufferArgs (x) {\n return Array.isArray(x) ||\n isTypedArray(x) ||\n isNDArrayLike(x)\n}\n\n// Make sure viewport is processed first\nfunction sortState (state) {\n return state.sort(function (a, b) {\n if (a === S_VIEWPORT) {\n return -1\n } else if (b === S_VIEWPORT) {\n return 1\n }\n return (a < b) ? -1 : 1\n })\n}\n\nfunction Declaration (thisDep, contextDep, propDep, append) {\n this.thisDep = thisDep\n this.contextDep = contextDep\n this.propDep = propDep\n this.append = append\n}\n\nfunction isStatic (decl) {\n return decl && !(decl.thisDep || decl.contextDep || decl.propDep)\n}\n\nfunction createStaticDecl (append) {\n return new Declaration(false, false, false, append)\n}\n\nfunction createDynamicDecl (dyn, append) {\n var type = dyn.type\n if (type === DYN_FUNC$1) {\n var numArgs = dyn.data.length\n return new Declaration(\n true,\n numArgs >= 1,\n numArgs >= 2,\n append)\n } else if (type === DYN_THUNK) {\n var data = dyn.data\n return new Declaration(\n data.thisDep,\n data.contextDep,\n data.propDep,\n append)\n } else if (type === DYN_CONSTANT$1) {\n return new Declaration(\n false,\n false,\n false,\n append)\n } else if (type === DYN_ARRAY$1) {\n var thisDep = false\n var contextDep = false\n var propDep = false\n for (var i = 0; i < dyn.data.length; ++i) {\n var subDyn = dyn.data[i]\n if (subDyn.type === DYN_PROP$1) {\n propDep = true\n } else if (subDyn.type === DYN_CONTEXT$1) {\n contextDep = true\n } else if (subDyn.type === DYN_STATE$1) {\n thisDep = true\n } else if (subDyn.type === DYN_FUNC$1) {\n thisDep = true\n var subArgs = subDyn.data\n if (subArgs >= 1) {\n contextDep = true\n }\n if (subArgs >= 2) {\n propDep = true\n }\n } else if (subDyn.type === DYN_THUNK) {\n thisDep = thisDep || subDyn.data.thisDep\n contextDep = contextDep || subDyn.data.contextDep\n propDep = propDep || subDyn.data.propDep\n }\n }\n return new Declaration(\n thisDep,\n contextDep,\n propDep,\n append)\n } else {\n return new Declaration(\n type === DYN_STATE$1,\n type === DYN_CONTEXT$1,\n type === DYN_PROP$1,\n append)\n }\n}\n\nvar SCOPE_DECL = new Declaration(false, false, false, function () {})\n\nfunction reglCore (\n gl,\n stringStore,\n extensions,\n limits,\n bufferState,\n elementState,\n textureState,\n framebufferState,\n uniformState,\n attributeState,\n shaderState,\n drawState,\n contextState,\n timer,\n config) {\n var AttributeRecord = attributeState.Record\n\n var blendEquations = {\n 'add': 32774,\n 'subtract': 32778,\n 'reverse subtract': 32779\n }\n if (extensions.ext_blend_minmax) {\n blendEquations.min = GL_MIN_EXT\n blendEquations.max = GL_MAX_EXT\n }\n\n var extInstancing = extensions.angle_instanced_arrays\n var extDrawBuffers = extensions.webgl_draw_buffers\n\n // ===================================================\n // ===================================================\n // WEBGL STATE\n // ===================================================\n // ===================================================\n var currentState = {\n dirty: true,\n profile: config.profile\n }\n var nextState = {}\n var GL_STATE_NAMES = []\n var GL_FLAGS = {}\n var GL_VARIABLES = {}\n\n function propName (name) {\n return name.replace('.', '_')\n }\n\n function stateFlag (sname, cap, init) {\n var name = propName(sname)\n GL_STATE_NAMES.push(sname)\n nextState[name] = currentState[name] = !!init\n GL_FLAGS[name] = cap\n }\n\n function stateVariable (sname, func, init) {\n var name = propName(sname)\n GL_STATE_NAMES.push(sname)\n if (Array.isArray(init)) {\n currentState[name] = init.slice()\n nextState[name] = init.slice()\n } else {\n currentState[name] = nextState[name] = init\n }\n GL_VARIABLES[name] = func\n }\n\n // Dithering\n stateFlag(S_DITHER, GL_DITHER)\n\n // Blending\n stateFlag(S_BLEND_ENABLE, GL_BLEND)\n stateVariable(S_BLEND_COLOR, 'blendColor', [0, 0, 0, 0])\n stateVariable(S_BLEND_EQUATION, 'blendEquationSeparate',\n [GL_FUNC_ADD, GL_FUNC_ADD])\n stateVariable(S_BLEND_FUNC, 'blendFuncSeparate',\n [GL_ONE, GL_ZERO, GL_ONE, GL_ZERO])\n\n // Depth\n stateFlag(S_DEPTH_ENABLE, GL_DEPTH_TEST, true)\n stateVariable(S_DEPTH_FUNC, 'depthFunc', GL_LESS)\n stateVariable(S_DEPTH_RANGE, 'depthRange', [0, 1])\n stateVariable(S_DEPTH_MASK, 'depthMask', true)\n\n // Color mask\n stateVariable(S_COLOR_MASK, S_COLOR_MASK, [true, true, true, true])\n\n // Face culling\n stateFlag(S_CULL_ENABLE, GL_CULL_FACE)\n stateVariable(S_CULL_FACE, 'cullFace', GL_BACK)\n\n // Front face orientation\n stateVariable(S_FRONT_FACE, S_FRONT_FACE, GL_CCW)\n\n // Line width\n stateVariable(S_LINE_WIDTH, S_LINE_WIDTH, 1)\n\n // Polygon offset\n stateFlag(S_POLYGON_OFFSET_ENABLE, GL_POLYGON_OFFSET_FILL)\n stateVariable(S_POLYGON_OFFSET_OFFSET, 'polygonOffset', [0, 0])\n\n // Sample coverage\n stateFlag(S_SAMPLE_ALPHA, GL_SAMPLE_ALPHA_TO_COVERAGE)\n stateFlag(S_SAMPLE_ENABLE, GL_SAMPLE_COVERAGE)\n stateVariable(S_SAMPLE_COVERAGE, 'sampleCoverage', [1, false])\n\n // Stencil\n stateFlag(S_STENCIL_ENABLE, GL_STENCIL_TEST)\n stateVariable(S_STENCIL_MASK, 'stencilMask', -1)\n stateVariable(S_STENCIL_FUNC, 'stencilFunc', [GL_ALWAYS, 0, -1])\n stateVariable(S_STENCIL_OPFRONT, 'stencilOpSeparate',\n [GL_FRONT, GL_KEEP, GL_KEEP, GL_KEEP])\n stateVariable(S_STENCIL_OPBACK, 'stencilOpSeparate',\n [GL_BACK, GL_KEEP, GL_KEEP, GL_KEEP])\n\n // Scissor\n stateFlag(S_SCISSOR_ENABLE, GL_SCISSOR_TEST)\n stateVariable(S_SCISSOR_BOX, 'scissor',\n [0, 0, gl.drawingBufferWidth, gl.drawingBufferHeight])\n\n // Viewport\n stateVariable(S_VIEWPORT, S_VIEWPORT,\n [0, 0, gl.drawingBufferWidth, gl.drawingBufferHeight])\n\n // ===================================================\n // ===================================================\n // ENVIRONMENT\n // ===================================================\n // ===================================================\n var sharedState = {\n gl: gl,\n context: contextState,\n strings: stringStore,\n next: nextState,\n current: currentState,\n draw: drawState,\n elements: elementState,\n buffer: bufferState,\n shader: shaderState,\n attributes: attributeState.state,\n vao: attributeState,\n uniforms: uniformState,\n framebuffer: framebufferState,\n extensions: extensions,\n\n timer: timer,\n isBufferArgs: isBufferArgs\n }\n\n var sharedConstants = {\n primTypes: primTypes,\n compareFuncs: compareFuncs,\n blendFuncs: blendFuncs,\n blendEquations: blendEquations,\n stencilOps: stencilOps,\n glTypes: glTypes,\n orientationType: orientationType\n }\n\n check$1.optional(function () {\n sharedState.isArrayLike = isArrayLike\n })\n\n if (extDrawBuffers) {\n sharedConstants.backBuffer = [GL_BACK]\n sharedConstants.drawBuffer = loop(limits.maxDrawbuffers, function (i) {\n if (i === 0) {\n return [0]\n }\n return loop(i, function (j) {\n return GL_COLOR_ATTACHMENT0$2 + j\n })\n })\n }\n\n var drawCallCounter = 0\n function createREGLEnvironment () {\n var env = createEnvironment()\n var link = env.link\n var global = env.global\n env.id = drawCallCounter++\n\n env.batchId = '0'\n\n // link shared state\n var SHARED = link(sharedState)\n var shared = env.shared = {\n props: 'a0'\n }\n Object.keys(sharedState).forEach(function (prop) {\n shared[prop] = global.def(SHARED, '.', prop)\n })\n\n // Inject runtime assertion stuff for debug builds\n check$1.optional(function () {\n env.CHECK = link(check$1)\n env.commandStr = check$1.guessCommand()\n env.command = link(env.commandStr)\n env.assert = function (block, pred, message) {\n block(\n 'if(!(', pred, '))',\n this.CHECK, '.commandRaise(', link(message), ',', this.command, ');')\n }\n\n sharedConstants.invalidBlendCombinations = invalidBlendCombinations\n })\n\n // Copy GL state variables over\n var nextVars = env.next = {}\n var currentVars = env.current = {}\n Object.keys(GL_VARIABLES).forEach(function (variable) {\n if (Array.isArray(currentState[variable])) {\n nextVars[variable] = global.def(shared.next, '.', variable)\n currentVars[variable] = global.def(shared.current, '.', variable)\n }\n })\n\n // Initialize shared constants\n var constants = env.constants = {}\n Object.keys(sharedConstants).forEach(function (name) {\n constants[name] = global.def(JSON.stringify(sharedConstants[name]))\n })\n\n // Helper function for calling a block\n env.invoke = function (block, x) {\n switch (x.type) {\n case DYN_FUNC$1:\n var argList = [\n 'this',\n shared.context,\n shared.props,\n env.batchId\n ]\n return block.def(\n link(x.data), '.call(',\n argList.slice(0, Math.max(x.data.length + 1, 4)),\n ')')\n case DYN_PROP$1:\n return block.def(shared.props, x.data)\n case DYN_CONTEXT$1:\n return block.def(shared.context, x.data)\n case DYN_STATE$1:\n return block.def('this', x.data)\n case DYN_THUNK:\n x.data.append(env, block)\n return x.data.ref\n case DYN_CONSTANT$1:\n return x.data.toString()\n case DYN_ARRAY$1:\n return x.data.map(function (y) {\n return env.invoke(block, y)\n })\n }\n }\n\n env.attribCache = {}\n\n var scopeAttribs = {}\n env.scopeAttrib = function (name) {\n var id = stringStore.id(name)\n if (id in scopeAttribs) {\n return scopeAttribs[id]\n }\n var binding = attributeState.scope[id]\n if (!binding) {\n binding = attributeState.scope[id] = new AttributeRecord()\n }\n var result = scopeAttribs[id] = link(binding)\n return result\n }\n\n return env\n }\n\n // ===================================================\n // ===================================================\n // PARSING\n // ===================================================\n // ===================================================\n function parseProfile (options) {\n var staticOptions = options.static\n var dynamicOptions = options.dynamic\n\n var profileEnable\n if (S_PROFILE in staticOptions) {\n var value = !!staticOptions[S_PROFILE]\n profileEnable = createStaticDecl(function (env, scope) {\n return value\n })\n profileEnable.enable = value\n } else if (S_PROFILE in dynamicOptions) {\n var dyn = dynamicOptions[S_PROFILE]\n profileEnable = createDynamicDecl(dyn, function (env, scope) {\n return env.invoke(scope, dyn)\n })\n }\n\n return profileEnable\n }\n\n function parseFramebuffer (options, env) {\n var staticOptions = options.static\n var dynamicOptions = options.dynamic\n\n if (S_FRAMEBUFFER in staticOptions) {\n var framebuffer = staticOptions[S_FRAMEBUFFER]\n if (framebuffer) {\n framebuffer = framebufferState.getFramebuffer(framebuffer)\n check$1.command(framebuffer, 'invalid framebuffer object')\n return createStaticDecl(function (env, block) {\n var FRAMEBUFFER = env.link(framebuffer)\n var shared = env.shared\n block.set(\n shared.framebuffer,\n '.next',\n FRAMEBUFFER)\n var CONTEXT = shared.context\n block.set(\n CONTEXT,\n '.' + S_FRAMEBUFFER_WIDTH,\n FRAMEBUFFER + '.width')\n block.set(\n CONTEXT,\n '.' + S_FRAMEBUFFER_HEIGHT,\n FRAMEBUFFER + '.height')\n return FRAMEBUFFER\n })\n } else {\n return createStaticDecl(function (env, scope) {\n var shared = env.shared\n scope.set(\n shared.framebuffer,\n '.next',\n 'null')\n var CONTEXT = shared.context\n scope.set(\n CONTEXT,\n '.' + S_FRAMEBUFFER_WIDTH,\n CONTEXT + '.' + S_DRAWINGBUFFER_WIDTH)\n scope.set(\n CONTEXT,\n '.' + S_FRAMEBUFFER_HEIGHT,\n CONTEXT + '.' + S_DRAWINGBUFFER_HEIGHT)\n return 'null'\n })\n }\n } else if (S_FRAMEBUFFER in dynamicOptions) {\n var dyn = dynamicOptions[S_FRAMEBUFFER]\n return createDynamicDecl(dyn, function (env, scope) {\n var FRAMEBUFFER_FUNC = env.invoke(scope, dyn)\n var shared = env.shared\n var FRAMEBUFFER_STATE = shared.framebuffer\n var FRAMEBUFFER = scope.def(\n FRAMEBUFFER_STATE, '.getFramebuffer(', FRAMEBUFFER_FUNC, ')')\n\n check$1.optional(function () {\n env.assert(scope,\n '!' + FRAMEBUFFER_FUNC + '||' + FRAMEBUFFER,\n 'invalid framebuffer object')\n })\n\n scope.set(\n FRAMEBUFFER_STATE,\n '.next',\n FRAMEBUFFER)\n var CONTEXT = shared.context\n scope.set(\n CONTEXT,\n '.' + S_FRAMEBUFFER_WIDTH,\n FRAMEBUFFER + '?' + FRAMEBUFFER + '.width:' +\n CONTEXT + '.' + S_DRAWINGBUFFER_WIDTH)\n scope.set(\n CONTEXT,\n '.' + S_FRAMEBUFFER_HEIGHT,\n FRAMEBUFFER +\n '?' + FRAMEBUFFER + '.height:' +\n CONTEXT + '.' + S_DRAWINGBUFFER_HEIGHT)\n return FRAMEBUFFER\n })\n } else {\n return null\n }\n }\n\n function parseViewportScissor (options, framebuffer, env) {\n var staticOptions = options.static\n var dynamicOptions = options.dynamic\n\n function parseBox (param) {\n if (param in staticOptions) {\n var box = staticOptions[param]\n check$1.commandType(box, 'object', 'invalid ' + param, env.commandStr)\n\n var isStatic = true\n var x = box.x | 0\n var y = box.y | 0\n var w, h\n if ('width' in box) {\n w = box.width | 0\n check$1.command(w >= 0, 'invalid ' + param, env.commandStr)\n } else {\n isStatic = false\n }\n if ('height' in box) {\n h = box.height | 0\n check$1.command(h >= 0, 'invalid ' + param, env.commandStr)\n } else {\n isStatic = false\n }\n\n return new Declaration(\n !isStatic && framebuffer && framebuffer.thisDep,\n !isStatic && framebuffer && framebuffer.contextDep,\n !isStatic && framebuffer && framebuffer.propDep,\n function (env, scope) {\n var CONTEXT = env.shared.context\n var BOX_W = w\n if (!('width' in box)) {\n BOX_W = scope.def(CONTEXT, '.', S_FRAMEBUFFER_WIDTH, '-', x)\n }\n var BOX_H = h\n if (!('height' in box)) {\n BOX_H = scope.def(CONTEXT, '.', S_FRAMEBUFFER_HEIGHT, '-', y)\n }\n return [x, y, BOX_W, BOX_H]\n })\n } else if (param in dynamicOptions) {\n var dynBox = dynamicOptions[param]\n var result = createDynamicDecl(dynBox, function (env, scope) {\n var BOX = env.invoke(scope, dynBox)\n\n check$1.optional(function () {\n env.assert(scope,\n BOX + '&&typeof ' + BOX + '===\"object\"',\n 'invalid ' + param)\n })\n\n var CONTEXT = env.shared.context\n var BOX_X = scope.def(BOX, '.x|0')\n var BOX_Y = scope.def(BOX, '.y|0')\n var BOX_W = scope.def(\n '\"width\" in ', BOX, '?', BOX, '.width|0:',\n '(', CONTEXT, '.', S_FRAMEBUFFER_WIDTH, '-', BOX_X, ')')\n var BOX_H = scope.def(\n '\"height\" in ', BOX, '?', BOX, '.height|0:',\n '(', CONTEXT, '.', S_FRAMEBUFFER_HEIGHT, '-', BOX_Y, ')')\n\n check$1.optional(function () {\n env.assert(scope,\n BOX_W + '>=0&&' +\n BOX_H + '>=0',\n 'invalid ' + param)\n })\n\n return [BOX_X, BOX_Y, BOX_W, BOX_H]\n })\n if (framebuffer) {\n result.thisDep = result.thisDep || framebuffer.thisDep\n result.contextDep = result.contextDep || framebuffer.contextDep\n result.propDep = result.propDep || framebuffer.propDep\n }\n return result\n } else if (framebuffer) {\n return new Declaration(\n framebuffer.thisDep,\n framebuffer.contextDep,\n framebuffer.propDep,\n function (env, scope) {\n var CONTEXT = env.shared.context\n return [\n 0, 0,\n scope.def(CONTEXT, '.', S_FRAMEBUFFER_WIDTH),\n scope.def(CONTEXT, '.', S_FRAMEBUFFER_HEIGHT)]\n })\n } else {\n return null\n }\n }\n\n var viewport = parseBox(S_VIEWPORT)\n\n if (viewport) {\n var prevViewport = viewport\n viewport = new Declaration(\n viewport.thisDep,\n viewport.contextDep,\n viewport.propDep,\n function (env, scope) {\n var VIEWPORT = prevViewport.append(env, scope)\n var CONTEXT = env.shared.context\n scope.set(\n CONTEXT,\n '.' + S_VIEWPORT_WIDTH,\n VIEWPORT[2])\n scope.set(\n CONTEXT,\n '.' + S_VIEWPORT_HEIGHT,\n VIEWPORT[3])\n return VIEWPORT\n })\n }\n\n return {\n viewport: viewport,\n scissor_box: parseBox(S_SCISSOR_BOX)\n }\n }\n\n function parseAttribLocations (options, attributes) {\n var staticOptions = options.static\n var staticProgram =\n typeof staticOptions[S_FRAG] === 'string' &&\n typeof staticOptions[S_VERT] === 'string'\n if (staticProgram) {\n if (Object.keys(attributes.dynamic).length > 0) {\n return null\n }\n var staticAttributes = attributes.static\n var sAttributes = Object.keys(staticAttributes)\n if (sAttributes.length > 0 && typeof staticAttributes[sAttributes[0]] === 'number') {\n var bindings = []\n for (var i = 0; i < sAttributes.length; ++i) {\n check$1(typeof staticAttributes[sAttributes[i]] === 'number', 'must specify all vertex attribute locations when using vaos')\n bindings.push([staticAttributes[sAttributes[i]] | 0, sAttributes[i]])\n }\n return bindings\n }\n }\n return null\n }\n\n function parseProgram (options, env, attribLocations) {\n var staticOptions = options.static\n var dynamicOptions = options.dynamic\n\n function parseShader (name) {\n if (name in staticOptions) {\n var id = stringStore.id(staticOptions[name])\n check$1.optional(function () {\n shaderState.shader(shaderType[name], id, check$1.guessCommand())\n })\n var result = createStaticDecl(function () {\n return id\n })\n result.id = id\n return result\n } else if (name in dynamicOptions) {\n var dyn = dynamicOptions[name]\n return createDynamicDecl(dyn, function (env, scope) {\n var str = env.invoke(scope, dyn)\n var id = scope.def(env.shared.strings, '.id(', str, ')')\n check$1.optional(function () {\n scope(\n env.shared.shader, '.shader(',\n shaderType[name], ',',\n id, ',',\n env.command, ');')\n })\n return id\n })\n }\n return null\n }\n\n var frag = parseShader(S_FRAG)\n var vert = parseShader(S_VERT)\n\n var program = null\n var progVar\n if (isStatic(frag) && isStatic(vert)) {\n program = shaderState.program(vert.id, frag.id, null, attribLocations)\n progVar = createStaticDecl(function (env, scope) {\n return env.link(program)\n })\n } else {\n progVar = new Declaration(\n (frag && frag.thisDep) || (vert && vert.thisDep),\n (frag && frag.contextDep) || (vert && vert.contextDep),\n (frag && frag.propDep) || (vert && vert.propDep),\n function (env, scope) {\n var SHADER_STATE = env.shared.shader\n var fragId\n if (frag) {\n fragId = frag.append(env, scope)\n } else {\n fragId = scope.def(SHADER_STATE, '.', S_FRAG)\n }\n var vertId\n if (vert) {\n vertId = vert.append(env, scope)\n } else {\n vertId = scope.def(SHADER_STATE, '.', S_VERT)\n }\n var progDef = SHADER_STATE + '.program(' + vertId + ',' + fragId\n check$1.optional(function () {\n progDef += ',' + env.command\n })\n return scope.def(progDef + ')')\n })\n }\n\n return {\n frag: frag,\n vert: vert,\n progVar: progVar,\n program: program\n }\n }\n\n function parseDraw (options, env) {\n var staticOptions = options.static\n var dynamicOptions = options.dynamic\n\n function parseElements () {\n if (S_ELEMENTS in staticOptions) {\n var elements = staticOptions[S_ELEMENTS]\n if (isBufferArgs(elements)) {\n elements = elementState.getElements(elementState.create(elements, true))\n } else if (elements) {\n elements = elementState.getElements(elements)\n check$1.command(elements, 'invalid elements', env.commandStr)\n }\n var result = createStaticDecl(function (env, scope) {\n if (elements) {\n var result = env.link(elements)\n env.ELEMENTS = result\n return result\n }\n env.ELEMENTS = null\n return null\n })\n result.value = elements\n return result\n } else if (S_ELEMENTS in dynamicOptions) {\n var dyn = dynamicOptions[S_ELEMENTS]\n return createDynamicDecl(dyn, function (env, scope) {\n var shared = env.shared\n\n var IS_BUFFER_ARGS = shared.isBufferArgs\n var ELEMENT_STATE = shared.elements\n\n var elementDefn = env.invoke(scope, dyn)\n var elements = scope.def('null')\n var elementStream = scope.def(IS_BUFFER_ARGS, '(', elementDefn, ')')\n\n var ifte = env.cond(elementStream)\n .then(elements, '=', ELEMENT_STATE, '.createStream(', elementDefn, ');')\n .else(elements, '=', ELEMENT_STATE, '.getElements(', elementDefn, ');')\n\n check$1.optional(function () {\n env.assert(ifte.else,\n '!' + elementDefn + '||' + elements,\n 'invalid elements')\n })\n\n scope.entry(ifte)\n scope.exit(\n env.cond(elementStream)\n .then(ELEMENT_STATE, '.destroyStream(', elements, ');'))\n\n env.ELEMENTS = elements\n\n return elements\n })\n }\n\n return null\n }\n\n var elements = parseElements()\n\n function parsePrimitive () {\n if (S_PRIMITIVE in staticOptions) {\n var primitive = staticOptions[S_PRIMITIVE]\n check$1.commandParameter(primitive, primTypes, 'invalid primitve', env.commandStr)\n return createStaticDecl(function (env, scope) {\n return primTypes[primitive]\n })\n } else if (S_PRIMITIVE in dynamicOptions) {\n var dynPrimitive = dynamicOptions[S_PRIMITIVE]\n return createDynamicDecl(dynPrimitive, function (env, scope) {\n var PRIM_TYPES = env.constants.primTypes\n var prim = env.invoke(scope, dynPrimitive)\n check$1.optional(function () {\n env.assert(scope,\n prim + ' in ' + PRIM_TYPES,\n 'invalid primitive, must be one of ' + Object.keys(primTypes))\n })\n return scope.def(PRIM_TYPES, '[', prim, ']')\n })\n } else if (elements) {\n if (isStatic(elements)) {\n if (elements.value) {\n return createStaticDecl(function (env, scope) {\n return scope.def(env.ELEMENTS, '.primType')\n })\n } else {\n return createStaticDecl(function () {\n return GL_TRIANGLES$1\n })\n }\n } else {\n return new Declaration(\n elements.thisDep,\n elements.contextDep,\n elements.propDep,\n function (env, scope) {\n var elements = env.ELEMENTS\n return scope.def(elements, '?', elements, '.primType:', GL_TRIANGLES$1)\n })\n }\n }\n return null\n }\n\n function parseParam (param, isOffset) {\n if (param in staticOptions) {\n var value = staticOptions[param] | 0\n check$1.command(!isOffset || value >= 0, 'invalid ' + param, env.commandStr)\n return createStaticDecl(function (env, scope) {\n if (isOffset) {\n env.OFFSET = value\n }\n return value\n })\n } else if (param in dynamicOptions) {\n var dynValue = dynamicOptions[param]\n return createDynamicDecl(dynValue, function (env, scope) {\n var result = env.invoke(scope, dynValue)\n if (isOffset) {\n env.OFFSET = result\n check$1.optional(function () {\n env.assert(scope,\n result + '>=0',\n 'invalid ' + param)\n })\n }\n return result\n })\n } else if (isOffset && elements) {\n return createStaticDecl(function (env, scope) {\n env.OFFSET = '0'\n return 0\n })\n }\n return null\n }\n\n var OFFSET = parseParam(S_OFFSET, true)\n\n function parseVertCount () {\n if (S_COUNT in staticOptions) {\n var count = staticOptions[S_COUNT] | 0\n check$1.command(\n typeof count === 'number' && count >= 0, 'invalid vertex count', env.commandStr)\n return createStaticDecl(function () {\n return count\n })\n } else if (S_COUNT in dynamicOptions) {\n var dynCount = dynamicOptions[S_COUNT]\n return createDynamicDecl(dynCount, function (env, scope) {\n var result = env.invoke(scope, dynCount)\n check$1.optional(function () {\n env.assert(scope,\n 'typeof ' + result + '===\"number\"&&' +\n result + '>=0&&' +\n result + '===(' + result + '|0)',\n 'invalid vertex count')\n })\n return result\n })\n } else if (elements) {\n if (isStatic(elements)) {\n if (elements) {\n if (OFFSET) {\n return new Declaration(\n OFFSET.thisDep,\n OFFSET.contextDep,\n OFFSET.propDep,\n function (env, scope) {\n var result = scope.def(\n env.ELEMENTS, '.vertCount-', env.OFFSET)\n\n check$1.optional(function () {\n env.assert(scope,\n result + '>=0',\n 'invalid vertex offset/element buffer too small')\n })\n\n return result\n })\n } else {\n return createStaticDecl(function (env, scope) {\n return scope.def(env.ELEMENTS, '.vertCount')\n })\n }\n } else {\n var result = createStaticDecl(function () {\n return -1\n })\n check$1.optional(function () {\n result.MISSING = true\n })\n return result\n }\n } else {\n var variable = new Declaration(\n elements.thisDep || OFFSET.thisDep,\n elements.contextDep || OFFSET.contextDep,\n elements.propDep || OFFSET.propDep,\n function (env, scope) {\n var elements = env.ELEMENTS\n if (env.OFFSET) {\n return scope.def(elements, '?', elements, '.vertCount-',\n env.OFFSET, ':-1')\n }\n return scope.def(elements, '?', elements, '.vertCount:-1')\n })\n check$1.optional(function () {\n variable.DYNAMIC = true\n })\n return variable\n }\n }\n return null\n }\n\n return {\n elements: elements,\n primitive: parsePrimitive(),\n count: parseVertCount(),\n instances: parseParam(S_INSTANCES, false),\n offset: OFFSET\n }\n }\n\n function parseGLState (options, env) {\n var staticOptions = options.static\n var dynamicOptions = options.dynamic\n\n var STATE = {}\n\n GL_STATE_NAMES.forEach(function (prop) {\n var param = propName(prop)\n\n function parseParam (parseStatic, parseDynamic) {\n if (prop in staticOptions) {\n var value = parseStatic(staticOptions[prop])\n STATE[param] = createStaticDecl(function () {\n return value\n })\n } else if (prop in dynamicOptions) {\n var dyn = dynamicOptions[prop]\n STATE[param] = createDynamicDecl(dyn, function (env, scope) {\n return parseDynamic(env, scope, env.invoke(scope, dyn))\n })\n }\n }\n\n switch (prop) {\n case S_CULL_ENABLE:\n case S_BLEND_ENABLE:\n case S_DITHER:\n case S_STENCIL_ENABLE:\n case S_DEPTH_ENABLE:\n case S_SCISSOR_ENABLE:\n case S_POLYGON_OFFSET_ENABLE:\n case S_SAMPLE_ALPHA:\n case S_SAMPLE_ENABLE:\n case S_DEPTH_MASK:\n return parseParam(\n function (value) {\n check$1.commandType(value, 'boolean', prop, env.commandStr)\n return value\n },\n function (env, scope, value) {\n check$1.optional(function () {\n env.assert(scope,\n 'typeof ' + value + '===\"boolean\"',\n 'invalid flag ' + prop, env.commandStr)\n })\n return value\n })\n\n case S_DEPTH_FUNC:\n return parseParam(\n function (value) {\n check$1.commandParameter(value, compareFuncs, 'invalid ' + prop, env.commandStr)\n return compareFuncs[value]\n },\n function (env, scope, value) {\n var COMPARE_FUNCS = env.constants.compareFuncs\n check$1.optional(function () {\n env.assert(scope,\n value + ' in ' + COMPARE_FUNCS,\n 'invalid ' + prop + ', must be one of ' + Object.keys(compareFuncs))\n })\n return scope.def(COMPARE_FUNCS, '[', value, ']')\n })\n\n case S_DEPTH_RANGE:\n return parseParam(\n function (value) {\n check$1.command(\n isArrayLike(value) &&\n value.length === 2 &&\n typeof value[0] === 'number' &&\n typeof value[1] === 'number' &&\n value[0] <= value[1],\n 'depth range is 2d array',\n env.commandStr)\n return value\n },\n function (env, scope, value) {\n check$1.optional(function () {\n env.assert(scope,\n env.shared.isArrayLike + '(' + value + ')&&' +\n value + '.length===2&&' +\n 'typeof ' + value + '[0]===\"number\"&&' +\n 'typeof ' + value + '[1]===\"number\"&&' +\n value + '[0]<=' + value + '[1]',\n 'depth range must be a 2d array')\n })\n\n var Z_NEAR = scope.def('+', value, '[0]')\n var Z_FAR = scope.def('+', value, '[1]')\n return [Z_NEAR, Z_FAR]\n })\n\n case S_BLEND_FUNC:\n return parseParam(\n function (value) {\n check$1.commandType(value, 'object', 'blend.func', env.commandStr)\n var srcRGB = ('srcRGB' in value ? value.srcRGB : value.src)\n var srcAlpha = ('srcAlpha' in value ? value.srcAlpha : value.src)\n var dstRGB = ('dstRGB' in value ? value.dstRGB : value.dst)\n var dstAlpha = ('dstAlpha' in value ? value.dstAlpha : value.dst)\n check$1.commandParameter(srcRGB, blendFuncs, param + '.srcRGB', env.commandStr)\n check$1.commandParameter(srcAlpha, blendFuncs, param + '.srcAlpha', env.commandStr)\n check$1.commandParameter(dstRGB, blendFuncs, param + '.dstRGB', env.commandStr)\n check$1.commandParameter(dstAlpha, blendFuncs, param + '.dstAlpha', env.commandStr)\n\n check$1.command(\n (invalidBlendCombinations.indexOf(srcRGB + ', ' + dstRGB) === -1),\n 'unallowed blending combination (srcRGB, dstRGB) = (' + srcRGB + ', ' + dstRGB + ')', env.commandStr)\n\n return [\n blendFuncs[srcRGB],\n blendFuncs[dstRGB],\n blendFuncs[srcAlpha],\n blendFuncs[dstAlpha]\n ]\n },\n function (env, scope, value) {\n var BLEND_FUNCS = env.constants.blendFuncs\n\n check$1.optional(function () {\n env.assert(scope,\n value + '&&typeof ' + value + '===\"object\"',\n 'invalid blend func, must be an object')\n })\n\n function read (prefix, suffix) {\n var func = scope.def(\n '\"', prefix, suffix, '\" in ', value,\n '?', value, '.', prefix, suffix,\n ':', value, '.', prefix)\n\n check$1.optional(function () {\n env.assert(scope,\n func + ' in ' + BLEND_FUNCS,\n 'invalid ' + prop + '.' + prefix + suffix + ', must be one of ' + Object.keys(blendFuncs))\n })\n\n return func\n }\n\n var srcRGB = read('src', 'RGB')\n var dstRGB = read('dst', 'RGB')\n\n check$1.optional(function () {\n var INVALID_BLEND_COMBINATIONS = env.constants.invalidBlendCombinations\n\n env.assert(scope,\n INVALID_BLEND_COMBINATIONS +\n '.indexOf(' + srcRGB + '+\", \"+' + dstRGB + ') === -1 ',\n 'unallowed blending combination for (srcRGB, dstRGB)'\n )\n })\n\n var SRC_RGB = scope.def(BLEND_FUNCS, '[', srcRGB, ']')\n var SRC_ALPHA = scope.def(BLEND_FUNCS, '[', read('src', 'Alpha'), ']')\n var DST_RGB = scope.def(BLEND_FUNCS, '[', dstRGB, ']')\n var DST_ALPHA = scope.def(BLEND_FUNCS, '[', read('dst', 'Alpha'), ']')\n\n return [SRC_RGB, DST_RGB, SRC_ALPHA, DST_ALPHA]\n })\n\n case S_BLEND_EQUATION:\n return parseParam(\n function (value) {\n if (typeof value === 'string') {\n check$1.commandParameter(value, blendEquations, 'invalid ' + prop, env.commandStr)\n return [\n blendEquations[value],\n blendEquations[value]\n ]\n } else if (typeof value === 'object') {\n check$1.commandParameter(\n value.rgb, blendEquations, prop + '.rgb', env.commandStr)\n check$1.commandParameter(\n value.alpha, blendEquations, prop + '.alpha', env.commandStr)\n return [\n blendEquations[value.rgb],\n blendEquations[value.alpha]\n ]\n } else {\n check$1.commandRaise('invalid blend.equation', env.commandStr)\n }\n },\n function (env, scope, value) {\n var BLEND_EQUATIONS = env.constants.blendEquations\n\n var RGB = scope.def()\n var ALPHA = scope.def()\n\n var ifte = env.cond('typeof ', value, '===\"string\"')\n\n check$1.optional(function () {\n function checkProp (block, name, value) {\n env.assert(block,\n value + ' in ' + BLEND_EQUATIONS,\n 'invalid ' + name + ', must be one of ' + Object.keys(blendEquations))\n }\n checkProp(ifte.then, prop, value)\n\n env.assert(ifte.else,\n value + '&&typeof ' + value + '===\"object\"',\n 'invalid ' + prop)\n checkProp(ifte.else, prop + '.rgb', value + '.rgb')\n checkProp(ifte.else, prop + '.alpha', value + '.alpha')\n })\n\n ifte.then(\n RGB, '=', ALPHA, '=', BLEND_EQUATIONS, '[', value, '];')\n ifte.else(\n RGB, '=', BLEND_EQUATIONS, '[', value, '.rgb];',\n ALPHA, '=', BLEND_EQUATIONS, '[', value, '.alpha];')\n\n scope(ifte)\n\n return [RGB, ALPHA]\n })\n\n case S_BLEND_COLOR:\n return parseParam(\n function (value) {\n check$1.command(\n isArrayLike(value) &&\n value.length === 4,\n 'blend.color must be a 4d array', env.commandStr)\n return loop(4, function (i) {\n return +value[i]\n })\n },\n function (env, scope, value) {\n check$1.optional(function () {\n env.assert(scope,\n env.shared.isArrayLike + '(' + value + ')&&' +\n value + '.length===4',\n 'blend.color must be a 4d array')\n })\n return loop(4, function (i) {\n return scope.def('+', value, '[', i, ']')\n })\n })\n\n case S_STENCIL_MASK:\n return parseParam(\n function (value) {\n check$1.commandType(value, 'number', param, env.commandStr)\n return value | 0\n },\n function (env, scope, value) {\n check$1.optional(function () {\n env.assert(scope,\n 'typeof ' + value + '===\"number\"',\n 'invalid stencil.mask')\n })\n return scope.def(value, '|0')\n })\n\n case S_STENCIL_FUNC:\n return parseParam(\n function (value) {\n check$1.commandType(value, 'object', param, env.commandStr)\n var cmp = value.cmp || 'keep'\n var ref = value.ref || 0\n var mask = 'mask' in value ? value.mask : -1\n check$1.commandParameter(cmp, compareFuncs, prop + '.cmp', env.commandStr)\n check$1.commandType(ref, 'number', prop + '.ref', env.commandStr)\n check$1.commandType(mask, 'number', prop + '.mask', env.commandStr)\n return [\n compareFuncs[cmp],\n ref,\n mask\n ]\n },\n function (env, scope, value) {\n var COMPARE_FUNCS = env.constants.compareFuncs\n check$1.optional(function () {\n function assert () {\n env.assert(scope,\n Array.prototype.join.call(arguments, ''),\n 'invalid stencil.func')\n }\n assert(value + '&&typeof ', value, '===\"object\"')\n assert('!(\"cmp\" in ', value, ')||(',\n value, '.cmp in ', COMPARE_FUNCS, ')')\n })\n var cmp = scope.def(\n '\"cmp\" in ', value,\n '?', COMPARE_FUNCS, '[', value, '.cmp]',\n ':', GL_KEEP)\n var ref = scope.def(value, '.ref|0')\n var mask = scope.def(\n '\"mask\" in ', value,\n '?', value, '.mask|0:-1')\n return [cmp, ref, mask]\n })\n\n case S_STENCIL_OPFRONT:\n case S_STENCIL_OPBACK:\n return parseParam(\n function (value) {\n check$1.commandType(value, 'object', param, env.commandStr)\n var fail = value.fail || 'keep'\n var zfail = value.zfail || 'keep'\n var zpass = value.zpass || 'keep'\n check$1.commandParameter(fail, stencilOps, prop + '.fail', env.commandStr)\n check$1.commandParameter(zfail, stencilOps, prop + '.zfail', env.commandStr)\n check$1.commandParameter(zpass, stencilOps, prop + '.zpass', env.commandStr)\n return [\n prop === S_STENCIL_OPBACK ? GL_BACK : GL_FRONT,\n stencilOps[fail],\n stencilOps[zfail],\n stencilOps[zpass]\n ]\n },\n function (env, scope, value) {\n var STENCIL_OPS = env.constants.stencilOps\n\n check$1.optional(function () {\n env.assert(scope,\n value + '&&typeof ' + value + '===\"object\"',\n 'invalid ' + prop)\n })\n\n function read (name) {\n check$1.optional(function () {\n env.assert(scope,\n '!(\"' + name + '\" in ' + value + ')||' +\n '(' + value + '.' + name + ' in ' + STENCIL_OPS + ')',\n 'invalid ' + prop + '.' + name + ', must be one of ' + Object.keys(stencilOps))\n })\n\n return scope.def(\n '\"', name, '\" in ', value,\n '?', STENCIL_OPS, '[', value, '.', name, ']:',\n GL_KEEP)\n }\n\n return [\n prop === S_STENCIL_OPBACK ? GL_BACK : GL_FRONT,\n read('fail'),\n read('zfail'),\n read('zpass')\n ]\n })\n\n case S_POLYGON_OFFSET_OFFSET:\n return parseParam(\n function (value) {\n check$1.commandType(value, 'object', param, env.commandStr)\n var factor = value.factor | 0\n var units = value.units | 0\n check$1.commandType(factor, 'number', param + '.factor', env.commandStr)\n check$1.commandType(units, 'number', param + '.units', env.commandStr)\n return [factor, units]\n },\n function (env, scope, value) {\n check$1.optional(function () {\n env.assert(scope,\n value + '&&typeof ' + value + '===\"object\"',\n 'invalid ' + prop)\n })\n\n var FACTOR = scope.def(value, '.factor|0')\n var UNITS = scope.def(value, '.units|0')\n\n return [FACTOR, UNITS]\n })\n\n case S_CULL_FACE:\n return parseParam(\n function (value) {\n var face = 0\n if (value === 'front') {\n face = GL_FRONT\n } else if (value === 'back') {\n face = GL_BACK\n }\n check$1.command(!!face, param, env.commandStr)\n return face\n },\n function (env, scope, value) {\n check$1.optional(function () {\n env.assert(scope,\n value + '===\"front\"||' +\n value + '===\"back\"',\n 'invalid cull.face')\n })\n return scope.def(value, '===\"front\"?', GL_FRONT, ':', GL_BACK)\n })\n\n case S_LINE_WIDTH:\n return parseParam(\n function (value) {\n check$1.command(\n typeof value === 'number' &&\n value >= limits.lineWidthDims[0] &&\n value <= limits.lineWidthDims[1],\n 'invalid line width, must be a positive number between ' +\n limits.lineWidthDims[0] + ' and ' + limits.lineWidthDims[1], env.commandStr)\n return value\n },\n function (env, scope, value) {\n check$1.optional(function () {\n env.assert(scope,\n 'typeof ' + value + '===\"number\"&&' +\n value + '>=' + limits.lineWidthDims[0] + '&&' +\n value + '<=' + limits.lineWidthDims[1],\n 'invalid line width')\n })\n\n return value\n })\n\n case S_FRONT_FACE:\n return parseParam(\n function (value) {\n check$1.commandParameter(value, orientationType, param, env.commandStr)\n return orientationType[value]\n },\n function (env, scope, value) {\n check$1.optional(function () {\n env.assert(scope,\n value + '===\"cw\"||' +\n value + '===\"ccw\"',\n 'invalid frontFace, must be one of cw,ccw')\n })\n return scope.def(value + '===\"cw\"?' + GL_CW + ':' + GL_CCW)\n })\n\n case S_COLOR_MASK:\n return parseParam(\n function (value) {\n check$1.command(\n isArrayLike(value) && value.length === 4,\n 'color.mask must be length 4 array', env.commandStr)\n return value.map(function (v) { return !!v })\n },\n function (env, scope, value) {\n check$1.optional(function () {\n env.assert(scope,\n env.shared.isArrayLike + '(' + value + ')&&' +\n value + '.length===4',\n 'invalid color.mask')\n })\n return loop(4, function (i) {\n return '!!' + value + '[' + i + ']'\n })\n })\n\n case S_SAMPLE_COVERAGE:\n return parseParam(\n function (value) {\n check$1.command(typeof value === 'object' && value, param, env.commandStr)\n var sampleValue = 'value' in value ? value.value : 1\n var sampleInvert = !!value.invert\n check$1.command(\n typeof sampleValue === 'number' &&\n sampleValue >= 0 && sampleValue <= 1,\n 'sample.coverage.value must be a number between 0 and 1', env.commandStr)\n return [sampleValue, sampleInvert]\n },\n function (env, scope, value) {\n check$1.optional(function () {\n env.assert(scope,\n value + '&&typeof ' + value + '===\"object\"',\n 'invalid sample.coverage')\n })\n var VALUE = scope.def(\n '\"value\" in ', value, '?+', value, '.value:1')\n var INVERT = scope.def('!!', value, '.invert')\n return [VALUE, INVERT]\n })\n }\n })\n\n return STATE\n }\n\n function parseUniforms (uniforms, env) {\n var staticUniforms = uniforms.static\n var dynamicUniforms = uniforms.dynamic\n\n var UNIFORMS = {}\n\n Object.keys(staticUniforms).forEach(function (name) {\n var value = staticUniforms[name]\n var result\n if (typeof value === 'number' ||\n typeof value === 'boolean') {\n result = createStaticDecl(function () {\n return value\n })\n } else if (typeof value === 'function') {\n var reglType = value._reglType\n if (reglType === 'texture2d' ||\n reglType === 'textureCube') {\n result = createStaticDecl(function (env) {\n return env.link(value)\n })\n } else if (reglType === 'framebuffer' ||\n reglType === 'framebufferCube') {\n check$1.command(value.color.length > 0,\n 'missing color attachment for framebuffer sent to uniform \"' + name + '\"', env.commandStr)\n result = createStaticDecl(function (env) {\n return env.link(value.color[0])\n })\n } else {\n check$1.commandRaise('invalid data for uniform \"' + name + '\"', env.commandStr)\n }\n } else if (isArrayLike(value)) {\n result = createStaticDecl(function (env) {\n var ITEM = env.global.def('[',\n loop(value.length, function (i) {\n check$1.command(\n typeof value[i] === 'number' ||\n typeof value[i] === 'boolean',\n 'invalid uniform ' + name, env.commandStr)\n return value[i]\n }), ']')\n return ITEM\n })\n } else {\n check$1.commandRaise('invalid or missing data for uniform \"' + name + '\"', env.commandStr)\n }\n result.value = value\n UNIFORMS[name] = result\n })\n\n Object.keys(dynamicUniforms).forEach(function (key) {\n var dyn = dynamicUniforms[key]\n UNIFORMS[key] = createDynamicDecl(dyn, function (env, scope) {\n return env.invoke(scope, dyn)\n })\n })\n\n return UNIFORMS\n }\n\n function parseAttributes (attributes, env) {\n var staticAttributes = attributes.static\n var dynamicAttributes = attributes.dynamic\n\n var attributeDefs = {}\n\n Object.keys(staticAttributes).forEach(function (attribute) {\n var value = staticAttributes[attribute]\n var id = stringStore.id(attribute)\n\n var record = new AttributeRecord()\n if (isBufferArgs(value)) {\n record.state = ATTRIB_STATE_POINTER\n record.buffer = bufferState.getBuffer(\n bufferState.create(value, GL_ARRAY_BUFFER$2, false, true))\n record.type = 0\n } else {\n var buffer = bufferState.getBuffer(value)\n if (buffer) {\n record.state = ATTRIB_STATE_POINTER\n record.buffer = buffer\n record.type = 0\n } else {\n check$1.command(typeof value === 'object' && value,\n 'invalid data for attribute ' + attribute, env.commandStr)\n if ('constant' in value) {\n var constant = value.constant\n record.buffer = 'null'\n record.state = ATTRIB_STATE_CONSTANT\n if (typeof constant === 'number') {\n record.x = constant\n } else {\n check$1.command(\n isArrayLike(constant) &&\n constant.length > 0 &&\n constant.length <= 4,\n 'invalid constant for attribute ' + attribute, env.commandStr)\n CUTE_COMPONENTS.forEach(function (c, i) {\n if (i < constant.length) {\n record[c] = constant[i]\n }\n })\n }\n } else {\n if (isBufferArgs(value.buffer)) {\n buffer = bufferState.getBuffer(\n bufferState.create(value.buffer, GL_ARRAY_BUFFER$2, false, true))\n } else {\n buffer = bufferState.getBuffer(value.buffer)\n }\n check$1.command(!!buffer, 'missing buffer for attribute \"' + attribute + '\"', env.commandStr)\n\n var offset = value.offset | 0\n check$1.command(offset >= 0,\n 'invalid offset for attribute \"' + attribute + '\"', env.commandStr)\n\n var stride = value.stride | 0\n check$1.command(stride >= 0 && stride < 256,\n 'invalid stride for attribute \"' + attribute + '\", must be integer betweeen [0, 255]', env.commandStr)\n\n var size = value.size | 0\n check$1.command(!('size' in value) || (size > 0 && size <= 4),\n 'invalid size for attribute \"' + attribute + '\", must be 1,2,3,4', env.commandStr)\n\n var normalized = !!value.normalized\n\n var type = 0\n if ('type' in value) {\n check$1.commandParameter(\n value.type, glTypes,\n 'invalid type for attribute ' + attribute, env.commandStr)\n type = glTypes[value.type]\n }\n\n var divisor = value.divisor | 0\n if ('divisor' in value) {\n check$1.command(divisor === 0 || extInstancing,\n 'cannot specify divisor for attribute \"' + attribute + '\", instancing not supported', env.commandStr)\n check$1.command(divisor >= 0,\n 'invalid divisor for attribute \"' + attribute + '\"', env.commandStr)\n }\n\n check$1.optional(function () {\n var command = env.commandStr\n\n var VALID_KEYS = [\n 'buffer',\n 'offset',\n 'divisor',\n 'normalized',\n 'type',\n 'size',\n 'stride'\n ]\n\n Object.keys(value).forEach(function (prop) {\n check$1.command(\n VALID_KEYS.indexOf(prop) >= 0,\n 'unknown parameter \"' + prop + '\" for attribute pointer \"' + attribute + '\" (valid parameters are ' + VALID_KEYS + ')',\n command)\n })\n })\n\n record.buffer = buffer\n record.state = ATTRIB_STATE_POINTER\n record.size = size\n record.normalized = normalized\n record.type = type || buffer.dtype\n record.offset = offset\n record.stride = stride\n record.divisor = divisor\n }\n }\n }\n\n attributeDefs[attribute] = createStaticDecl(function (env, scope) {\n var cache = env.attribCache\n if (id in cache) {\n return cache[id]\n }\n var result = {\n isStream: false\n }\n Object.keys(record).forEach(function (key) {\n result[key] = record[key]\n })\n if (record.buffer) {\n result.buffer = env.link(record.buffer)\n result.type = result.type || (result.buffer + '.dtype')\n }\n cache[id] = result\n return result\n })\n })\n\n Object.keys(dynamicAttributes).forEach(function (attribute) {\n var dyn = dynamicAttributes[attribute]\n\n function appendAttributeCode (env, block) {\n var VALUE = env.invoke(block, dyn)\n\n var shared = env.shared\n var constants = env.constants\n\n var IS_BUFFER_ARGS = shared.isBufferArgs\n var BUFFER_STATE = shared.buffer\n\n // Perform validation on attribute\n check$1.optional(function () {\n env.assert(block,\n VALUE + '&&(typeof ' + VALUE + '===\"object\"||typeof ' +\n VALUE + '===\"function\")&&(' +\n IS_BUFFER_ARGS + '(' + VALUE + ')||' +\n BUFFER_STATE + '.getBuffer(' + VALUE + ')||' +\n BUFFER_STATE + '.getBuffer(' + VALUE + '.buffer)||' +\n IS_BUFFER_ARGS + '(' + VALUE + '.buffer)||' +\n '(\"constant\" in ' + VALUE +\n '&&(typeof ' + VALUE + '.constant===\"number\"||' +\n shared.isArrayLike + '(' + VALUE + '.constant))))',\n 'invalid dynamic attribute \"' + attribute + '\"')\n })\n\n // allocate names for result\n var result = {\n isStream: block.def(false)\n }\n var defaultRecord = new AttributeRecord()\n defaultRecord.state = ATTRIB_STATE_POINTER\n Object.keys(defaultRecord).forEach(function (key) {\n result[key] = block.def('' + defaultRecord[key])\n })\n\n var BUFFER = result.buffer\n var TYPE = result.type\n block(\n 'if(', IS_BUFFER_ARGS, '(', VALUE, ')){',\n result.isStream, '=true;',\n BUFFER, '=', BUFFER_STATE, '.createStream(', GL_ARRAY_BUFFER$2, ',', VALUE, ');',\n TYPE, '=', BUFFER, '.dtype;',\n '}else{',\n BUFFER, '=', BUFFER_STATE, '.getBuffer(', VALUE, ');',\n 'if(', BUFFER, '){',\n TYPE, '=', BUFFER, '.dtype;',\n '}else if(\"constant\" in ', VALUE, '){',\n result.state, '=', ATTRIB_STATE_CONSTANT, ';',\n 'if(typeof ' + VALUE + '.constant === \"number\"){',\n result[CUTE_COMPONENTS[0]], '=', VALUE, '.constant;',\n CUTE_COMPONENTS.slice(1).map(function (n) {\n return result[n]\n }).join('='), '=0;',\n '}else{',\n CUTE_COMPONENTS.map(function (name, i) {\n return (\n result[name] + '=' + VALUE + '.constant.length>' + i +\n '?' + VALUE + '.constant[' + i + ']:0;'\n )\n }).join(''),\n '}}else{',\n 'if(', IS_BUFFER_ARGS, '(', VALUE, '.buffer)){',\n BUFFER, '=', BUFFER_STATE, '.createStream(', GL_ARRAY_BUFFER$2, ',', VALUE, '.buffer);',\n '}else{',\n BUFFER, '=', BUFFER_STATE, '.getBuffer(', VALUE, '.buffer);',\n '}',\n TYPE, '=\"type\" in ', VALUE, '?',\n constants.glTypes, '[', VALUE, '.type]:', BUFFER, '.dtype;',\n result.normalized, '=!!', VALUE, '.normalized;')\n function emitReadRecord (name) {\n block(result[name], '=', VALUE, '.', name, '|0;')\n }\n emitReadRecord('size')\n emitReadRecord('offset')\n emitReadRecord('stride')\n emitReadRecord('divisor')\n\n block('}}')\n\n block.exit(\n 'if(', result.isStream, '){',\n BUFFER_STATE, '.destroyStream(', BUFFER, ');',\n '}')\n\n return result\n }\n\n attributeDefs[attribute] = createDynamicDecl(dyn, appendAttributeCode)\n })\n\n return attributeDefs\n }\n\n function parseVAO (options, env) {\n var staticOptions = options.static\n var dynamicOptions = options.dynamic\n if (S_VAO in staticOptions) {\n var vao = staticOptions[S_VAO]\n if (vao !== null && attributeState.getVAO(vao) === null) {\n vao = attributeState.createVAO(vao)\n }\n return createStaticDecl(function (env) {\n return env.link(attributeState.getVAO(vao))\n })\n } else if (S_VAO in dynamicOptions) {\n var dyn = dynamicOptions[S_VAO]\n return createDynamicDecl(dyn, function (env, scope) {\n var vaoRef = env.invoke(scope, dyn)\n return scope.def(env.shared.vao + '.getVAO(' + vaoRef + ')')\n })\n }\n return null\n }\n\n function parseContext (context) {\n var staticContext = context.static\n var dynamicContext = context.dynamic\n var result = {}\n\n Object.keys(staticContext).forEach(function (name) {\n var value = staticContext[name]\n result[name] = createStaticDecl(function (env, scope) {\n if (typeof value === 'number' || typeof value === 'boolean') {\n return '' + value\n } else {\n return env.link(value)\n }\n })\n })\n\n Object.keys(dynamicContext).forEach(function (name) {\n var dyn = dynamicContext[name]\n result[name] = createDynamicDecl(dyn, function (env, scope) {\n return env.invoke(scope, dyn)\n })\n })\n\n return result\n }\n\n function parseArguments (options, attributes, uniforms, context, env) {\n var staticOptions = options.static\n var dynamicOptions = options.dynamic\n\n check$1.optional(function () {\n var KEY_NAMES = [\n S_FRAMEBUFFER,\n S_VERT,\n S_FRAG,\n S_ELEMENTS,\n S_PRIMITIVE,\n S_OFFSET,\n S_COUNT,\n S_INSTANCES,\n S_PROFILE,\n S_VAO\n ].concat(GL_STATE_NAMES)\n\n function checkKeys (dict) {\n Object.keys(dict).forEach(function (key) {\n check$1.command(\n KEY_NAMES.indexOf(key) >= 0,\n 'unknown parameter \"' + key + '\"',\n env.commandStr)\n })\n }\n\n checkKeys(staticOptions)\n checkKeys(dynamicOptions)\n })\n\n var attribLocations = parseAttribLocations(options, attributes)\n\n var framebuffer = parseFramebuffer(options, env)\n var viewportAndScissor = parseViewportScissor(options, framebuffer, env)\n var draw = parseDraw(options, env)\n var state = parseGLState(options, env)\n var shader = parseProgram(options, env, attribLocations)\n\n function copyBox (name) {\n var defn = viewportAndScissor[name]\n if (defn) {\n state[name] = defn\n }\n }\n copyBox(S_VIEWPORT)\n copyBox(propName(S_SCISSOR_BOX))\n\n var dirty = Object.keys(state).length > 0\n\n var result = {\n framebuffer: framebuffer,\n draw: draw,\n shader: shader,\n state: state,\n dirty: dirty,\n scopeVAO: null,\n drawVAO: null,\n useVAO: false,\n attributes: {}\n }\n\n result.profile = parseProfile(options, env)\n result.uniforms = parseUniforms(uniforms, env)\n result.drawVAO = result.scopeVAO = parseVAO(options, env)\n // special case: check if we can statically allocate a vertex array object for this program\n if (!result.drawVAO && shader.program && !attribLocations && extensions.angle_instanced_arrays) {\n var useVAO = true\n var staticBindings = shader.program.attributes.map(function (attr) {\n var binding = attributes.static[attr]\n useVAO = useVAO && !!binding\n return binding\n })\n if (useVAO && staticBindings.length > 0) {\n var vao = attributeState.getVAO(attributeState.createVAO(staticBindings))\n result.drawVAO = new Declaration(null, null, null, function (env, scope) {\n return env.link(vao)\n })\n result.useVAO = true\n }\n }\n if (attribLocations) {\n result.useVAO = true\n } else {\n result.attributes = parseAttributes(attributes, env)\n }\n result.context = parseContext(context, env)\n return result\n }\n\n // ===================================================\n // ===================================================\n // COMMON UPDATE FUNCTIONS\n // ===================================================\n // ===================================================\n function emitContext (env, scope, context) {\n var shared = env.shared\n var CONTEXT = shared.context\n\n var contextEnter = env.scope()\n\n Object.keys(context).forEach(function (name) {\n scope.save(CONTEXT, '.' + name)\n var defn = context[name]\n var value = defn.append(env, scope)\n if (Array.isArray(value)) {\n contextEnter(CONTEXT, '.', name, '=[', value.join(), '];')\n } else {\n contextEnter(CONTEXT, '.', name, '=', value, ';')\n }\n })\n\n scope(contextEnter)\n }\n\n // ===================================================\n // ===================================================\n // COMMON DRAWING FUNCTIONS\n // ===================================================\n // ===================================================\n function emitPollFramebuffer (env, scope, framebuffer, skipCheck) {\n var shared = env.shared\n\n var GL = shared.gl\n var FRAMEBUFFER_STATE = shared.framebuffer\n var EXT_DRAW_BUFFERS\n if (extDrawBuffers) {\n EXT_DRAW_BUFFERS = scope.def(shared.extensions, '.webgl_draw_buffers')\n }\n\n var constants = env.constants\n\n var DRAW_BUFFERS = constants.drawBuffer\n var BACK_BUFFER = constants.backBuffer\n\n var NEXT\n if (framebuffer) {\n NEXT = framebuffer.append(env, scope)\n } else {\n NEXT = scope.def(FRAMEBUFFER_STATE, '.next')\n }\n\n if (!skipCheck) {\n scope('if(', NEXT, '!==', FRAMEBUFFER_STATE, '.cur){')\n }\n scope(\n 'if(', NEXT, '){',\n GL, '.bindFramebuffer(', GL_FRAMEBUFFER$2, ',', NEXT, '.framebuffer);')\n if (extDrawBuffers) {\n scope(EXT_DRAW_BUFFERS, '.drawBuffersWEBGL(',\n DRAW_BUFFERS, '[', NEXT, '.colorAttachments.length]);')\n }\n scope('}else{',\n GL, '.bindFramebuffer(', GL_FRAMEBUFFER$2, ',null);')\n if (extDrawBuffers) {\n scope(EXT_DRAW_BUFFERS, '.drawBuffersWEBGL(', BACK_BUFFER, ');')\n }\n scope(\n '}',\n FRAMEBUFFER_STATE, '.cur=', NEXT, ';')\n if (!skipCheck) {\n scope('}')\n }\n }\n\n function emitPollState (env, scope, args) {\n var shared = env.shared\n\n var GL = shared.gl\n\n var CURRENT_VARS = env.current\n var NEXT_VARS = env.next\n var CURRENT_STATE = shared.current\n var NEXT_STATE = shared.next\n\n var block = env.cond(CURRENT_STATE, '.dirty')\n\n GL_STATE_NAMES.forEach(function (prop) {\n var param = propName(prop)\n if (param in args.state) {\n return\n }\n\n var NEXT, CURRENT\n if (param in NEXT_VARS) {\n NEXT = NEXT_VARS[param]\n CURRENT = CURRENT_VARS[param]\n var parts = loop(currentState[param].length, function (i) {\n return block.def(NEXT, '[', i, ']')\n })\n block(env.cond(parts.map(function (p, i) {\n return p + '!==' + CURRENT + '[' + i + ']'\n }).join('||'))\n .then(\n GL, '.', GL_VARIABLES[param], '(', parts, ');',\n parts.map(function (p, i) {\n return CURRENT + '[' + i + ']=' + p\n }).join(';'), ';'))\n } else {\n NEXT = block.def(NEXT_STATE, '.', param)\n var ifte = env.cond(NEXT, '!==', CURRENT_STATE, '.', param)\n block(ifte)\n if (param in GL_FLAGS) {\n ifte(\n env.cond(NEXT)\n .then(GL, '.enable(', GL_FLAGS[param], ');')\n .else(GL, '.disable(', GL_FLAGS[param], ');'),\n CURRENT_STATE, '.', param, '=', NEXT, ';')\n } else {\n ifte(\n GL, '.', GL_VARIABLES[param], '(', NEXT, ');',\n CURRENT_STATE, '.', param, '=', NEXT, ';')\n }\n }\n })\n if (Object.keys(args.state).length === 0) {\n block(CURRENT_STATE, '.dirty=false;')\n }\n scope(block)\n }\n\n function emitSetOptions (env, scope, options, filter) {\n var shared = env.shared\n var CURRENT_VARS = env.current\n var CURRENT_STATE = shared.current\n var GL = shared.gl\n sortState(Object.keys(options)).forEach(function (param) {\n var defn = options[param]\n if (filter && !filter(defn)) {\n return\n }\n var variable = defn.append(env, scope)\n if (GL_FLAGS[param]) {\n var flag = GL_FLAGS[param]\n if (isStatic(defn)) {\n if (variable) {\n scope(GL, '.enable(', flag, ');')\n } else {\n scope(GL, '.disable(', flag, ');')\n }\n } else {\n scope(env.cond(variable)\n .then(GL, '.enable(', flag, ');')\n .else(GL, '.disable(', flag, ');'))\n }\n scope(CURRENT_STATE, '.', param, '=', variable, ';')\n } else if (isArrayLike(variable)) {\n var CURRENT = CURRENT_VARS[param]\n scope(\n GL, '.', GL_VARIABLES[param], '(', variable, ');',\n variable.map(function (v, i) {\n return CURRENT + '[' + i + ']=' + v\n }).join(';'), ';')\n } else {\n scope(\n GL, '.', GL_VARIABLES[param], '(', variable, ');',\n CURRENT_STATE, '.', param, '=', variable, ';')\n }\n })\n }\n\n function injectExtensions (env, scope) {\n if (extInstancing) {\n env.instancing = scope.def(\n env.shared.extensions, '.angle_instanced_arrays')\n }\n }\n\n function emitProfile (env, scope, args, useScope, incrementCounter) {\n var shared = env.shared\n var STATS = env.stats\n var CURRENT_STATE = shared.current\n var TIMER = shared.timer\n var profileArg = args.profile\n\n function perfCounter () {\n if (typeof performance === 'undefined') {\n return 'Date.now()'\n } else {\n return 'performance.now()'\n }\n }\n\n var CPU_START, QUERY_COUNTER\n function emitProfileStart (block) {\n CPU_START = scope.def()\n block(CPU_START, '=', perfCounter(), ';')\n if (typeof incrementCounter === 'string') {\n block(STATS, '.count+=', incrementCounter, ';')\n } else {\n block(STATS, '.count++;')\n }\n if (timer) {\n if (useScope) {\n QUERY_COUNTER = scope.def()\n block(QUERY_COUNTER, '=', TIMER, '.getNumPendingQueries();')\n } else {\n block(TIMER, '.beginQuery(', STATS, ');')\n }\n }\n }\n\n function emitProfileEnd (block) {\n block(STATS, '.cpuTime+=', perfCounter(), '-', CPU_START, ';')\n if (timer) {\n if (useScope) {\n block(TIMER, '.pushScopeStats(',\n QUERY_COUNTER, ',',\n TIMER, '.getNumPendingQueries(),',\n STATS, ');')\n } else {\n block(TIMER, '.endQuery();')\n }\n }\n }\n\n function scopeProfile (value) {\n var prev = scope.def(CURRENT_STATE, '.profile')\n scope(CURRENT_STATE, '.profile=', value, ';')\n scope.exit(CURRENT_STATE, '.profile=', prev, ';')\n }\n\n var USE_PROFILE\n if (profileArg) {\n if (isStatic(profileArg)) {\n if (profileArg.enable) {\n emitProfileStart(scope)\n emitProfileEnd(scope.exit)\n scopeProfile('true')\n } else {\n scopeProfile('false')\n }\n return\n }\n USE_PROFILE = profileArg.append(env, scope)\n scopeProfile(USE_PROFILE)\n } else {\n USE_PROFILE = scope.def(CURRENT_STATE, '.profile')\n }\n\n var start = env.block()\n emitProfileStart(start)\n scope('if(', USE_PROFILE, '){', start, '}')\n var end = env.block()\n emitProfileEnd(end)\n scope.exit('if(', USE_PROFILE, '){', end, '}')\n }\n\n function emitAttributes (env, scope, args, attributes, filter) {\n var shared = env.shared\n\n function typeLength (x) {\n switch (x) {\n case GL_FLOAT_VEC2:\n case GL_INT_VEC2:\n case GL_BOOL_VEC2:\n return 2\n case GL_FLOAT_VEC3:\n case GL_INT_VEC3:\n case GL_BOOL_VEC3:\n return 3\n case GL_FLOAT_VEC4:\n case GL_INT_VEC4:\n case GL_BOOL_VEC4:\n return 4\n default:\n return 1\n }\n }\n\n function emitBindAttribute (ATTRIBUTE, size, record) {\n var GL = shared.gl\n\n var LOCATION = scope.def(ATTRIBUTE, '.location')\n var BINDING = scope.def(shared.attributes, '[', LOCATION, ']')\n\n var STATE = record.state\n var BUFFER = record.buffer\n var CONST_COMPONENTS = [\n record.x,\n record.y,\n record.z,\n record.w\n ]\n\n var COMMON_KEYS = [\n 'buffer',\n 'normalized',\n 'offset',\n 'stride'\n ]\n\n function emitBuffer () {\n scope(\n 'if(!', BINDING, '.buffer){',\n GL, '.enableVertexAttribArray(', LOCATION, ');}')\n\n var TYPE = record.type\n var SIZE\n if (!record.size) {\n SIZE = size\n } else {\n SIZE = scope.def(record.size, '||', size)\n }\n\n scope('if(',\n BINDING, '.type!==', TYPE, '||',\n BINDING, '.size!==', SIZE, '||',\n COMMON_KEYS.map(function (key) {\n return BINDING + '.' + key + '!==' + record[key]\n }).join('||'),\n '){',\n GL, '.bindBuffer(', GL_ARRAY_BUFFER$2, ',', BUFFER, '.buffer);',\n GL, '.vertexAttribPointer(', [\n LOCATION,\n SIZE,\n TYPE,\n record.normalized,\n record.stride,\n record.offset\n ], ');',\n BINDING, '.type=', TYPE, ';',\n BINDING, '.size=', SIZE, ';',\n COMMON_KEYS.map(function (key) {\n return BINDING + '.' + key + '=' + record[key] + ';'\n }).join(''),\n '}')\n\n if (extInstancing) {\n var DIVISOR = record.divisor\n scope(\n 'if(', BINDING, '.divisor!==', DIVISOR, '){',\n env.instancing, '.vertexAttribDivisorANGLE(', [LOCATION, DIVISOR], ');',\n BINDING, '.divisor=', DIVISOR, ';}')\n }\n }\n\n function emitConstant () {\n scope(\n 'if(', BINDING, '.buffer){',\n GL, '.disableVertexAttribArray(', LOCATION, ');',\n BINDING, '.buffer=null;',\n '}if(', CUTE_COMPONENTS.map(function (c, i) {\n return BINDING + '.' + c + '!==' + CONST_COMPONENTS[i]\n }).join('||'), '){',\n GL, '.vertexAttrib4f(', LOCATION, ',', CONST_COMPONENTS, ');',\n CUTE_COMPONENTS.map(function (c, i) {\n return BINDING + '.' + c + '=' + CONST_COMPONENTS[i] + ';'\n }).join(''),\n '}')\n }\n\n if (STATE === ATTRIB_STATE_POINTER) {\n emitBuffer()\n } else if (STATE === ATTRIB_STATE_CONSTANT) {\n emitConstant()\n } else {\n scope('if(', STATE, '===', ATTRIB_STATE_POINTER, '){')\n emitBuffer()\n scope('}else{')\n emitConstant()\n scope('}')\n }\n }\n\n attributes.forEach(function (attribute) {\n var name = attribute.name\n var arg = args.attributes[name]\n var record\n if (arg) {\n if (!filter(arg)) {\n return\n }\n record = arg.append(env, scope)\n } else {\n if (!filter(SCOPE_DECL)) {\n return\n }\n var scopeAttrib = env.scopeAttrib(name)\n check$1.optional(function () {\n env.assert(scope,\n scopeAttrib + '.state',\n 'missing attribute ' + name)\n })\n record = {}\n Object.keys(new AttributeRecord()).forEach(function (key) {\n record[key] = scope.def(scopeAttrib, '.', key)\n })\n }\n emitBindAttribute(\n env.link(attribute), typeLength(attribute.info.type), record)\n })\n }\n\n function emitUniforms (env, scope, args, uniforms, filter) {\n var shared = env.shared\n var GL = shared.gl\n\n var infix\n for (var i = 0; i < uniforms.length; ++i) {\n var uniform = uniforms[i]\n var name = uniform.name\n var type = uniform.info.type\n var arg = args.uniforms[name]\n var UNIFORM = env.link(uniform)\n var LOCATION = UNIFORM + '.location'\n\n var VALUE\n if (arg) {\n if (!filter(arg)) {\n continue\n }\n if (isStatic(arg)) {\n var value = arg.value\n check$1.command(\n value !== null && typeof value !== 'undefined',\n 'missing uniform \"' + name + '\"', env.commandStr)\n if (type === GL_SAMPLER_2D || type === GL_SAMPLER_CUBE) {\n check$1.command(\n typeof value === 'function' &&\n ((type === GL_SAMPLER_2D &&\n (value._reglType === 'texture2d' ||\n value._reglType === 'framebuffer')) ||\n (type === GL_SAMPLER_CUBE &&\n (value._reglType === 'textureCube' ||\n value._reglType === 'framebufferCube'))),\n 'invalid texture for uniform ' + name, env.commandStr)\n var TEX_VALUE = env.link(value._texture || value.color[0]._texture)\n scope(GL, '.uniform1i(', LOCATION, ',', TEX_VALUE + '.bind());')\n scope.exit(TEX_VALUE, '.unbind();')\n } else if (\n type === GL_FLOAT_MAT2 ||\n type === GL_FLOAT_MAT3 ||\n type === GL_FLOAT_MAT4) {\n check$1.optional(function () {\n check$1.command(isArrayLike(value),\n 'invalid matrix for uniform ' + name, env.commandStr)\n check$1.command(\n (type === GL_FLOAT_MAT2 && value.length === 4) ||\n (type === GL_FLOAT_MAT3 && value.length === 9) ||\n (type === GL_FLOAT_MAT4 && value.length === 16),\n 'invalid length for matrix uniform ' + name, env.commandStr)\n })\n var MAT_VALUE = env.global.def('new Float32Array([' +\n Array.prototype.slice.call(value) + '])')\n var dim = 2\n if (type === GL_FLOAT_MAT3) {\n dim = 3\n } else if (type === GL_FLOAT_MAT4) {\n dim = 4\n }\n scope(\n GL, '.uniformMatrix', dim, 'fv(',\n LOCATION, ',false,', MAT_VALUE, ');')\n } else {\n switch (type) {\n case GL_FLOAT$8:\n check$1.commandType(value, 'number', 'uniform ' + name, env.commandStr)\n infix = '1f'\n break\n case GL_FLOAT_VEC2:\n check$1.command(\n isArrayLike(value) && value.length === 2,\n 'uniform ' + name, env.commandStr)\n infix = '2f'\n break\n case GL_FLOAT_VEC3:\n check$1.command(\n isArrayLike(value) && value.length === 3,\n 'uniform ' + name, env.commandStr)\n infix = '3f'\n break\n case GL_FLOAT_VEC4:\n check$1.command(\n isArrayLike(value) && value.length === 4,\n 'uniform ' + name, env.commandStr)\n infix = '4f'\n break\n case GL_BOOL:\n check$1.commandType(value, 'boolean', 'uniform ' + name, env.commandStr)\n infix = '1i'\n break\n case GL_INT$3:\n check$1.commandType(value, 'number', 'uniform ' + name, env.commandStr)\n infix = '1i'\n break\n case GL_BOOL_VEC2:\n check$1.command(\n isArrayLike(value) && value.length === 2,\n 'uniform ' + name, env.commandStr)\n infix = '2i'\n break\n case GL_INT_VEC2:\n check$1.command(\n isArrayLike(value) && value.length === 2,\n 'uniform ' + name, env.commandStr)\n infix = '2i'\n break\n case GL_BOOL_VEC3:\n check$1.command(\n isArrayLike(value) && value.length === 3,\n 'uniform ' + name, env.commandStr)\n infix = '3i'\n break\n case GL_INT_VEC3:\n check$1.command(\n isArrayLike(value) && value.length === 3,\n 'uniform ' + name, env.commandStr)\n infix = '3i'\n break\n case GL_BOOL_VEC4:\n check$1.command(\n isArrayLike(value) && value.length === 4,\n 'uniform ' + name, env.commandStr)\n infix = '4i'\n break\n case GL_INT_VEC4:\n check$1.command(\n isArrayLike(value) && value.length === 4,\n 'uniform ' + name, env.commandStr)\n infix = '4i'\n break\n }\n scope(GL, '.uniform', infix, '(', LOCATION, ',',\n isArrayLike(value) ? Array.prototype.slice.call(value) : value,\n ');')\n }\n continue\n } else {\n VALUE = arg.append(env, scope)\n }\n } else {\n if (!filter(SCOPE_DECL)) {\n continue\n }\n VALUE = scope.def(shared.uniforms, '[', stringStore.id(name), ']')\n }\n\n if (type === GL_SAMPLER_2D) {\n check$1(!Array.isArray(VALUE), 'must specify a scalar prop for textures')\n scope(\n 'if(', VALUE, '&&', VALUE, '._reglType===\"framebuffer\"){',\n VALUE, '=', VALUE, '.color[0];',\n '}')\n } else if (type === GL_SAMPLER_CUBE) {\n check$1(!Array.isArray(VALUE), 'must specify a scalar prop for cube maps')\n scope(\n 'if(', VALUE, '&&', VALUE, '._reglType===\"framebufferCube\"){',\n VALUE, '=', VALUE, '.color[0];',\n '}')\n }\n\n // perform type validation\n check$1.optional(function () {\n function emitCheck (pred, message) {\n env.assert(scope, pred,\n 'bad data or missing for uniform \"' + name + '\". ' + message)\n }\n\n function checkType (type) {\n check$1(!Array.isArray(VALUE), 'must not specify an array type for uniform')\n emitCheck(\n 'typeof ' + VALUE + '===\"' + type + '\"',\n 'invalid type, expected ' + type)\n }\n\n function checkVector (n, type) {\n if (Array.isArray(VALUE)) {\n check$1(VALUE.length === n, 'must have length ' + n)\n } else {\n emitCheck(\n shared.isArrayLike + '(' + VALUE + ')&&' + VALUE + '.length===' + n,\n 'invalid vector, should have length ' + n, env.commandStr)\n }\n }\n\n function checkTexture (target) {\n check$1(!Array.isArray(VALUE), 'must not specify a value type')\n emitCheck(\n 'typeof ' + VALUE + '===\"function\"&&' +\n VALUE + '._reglType===\"texture' +\n (target === GL_TEXTURE_2D$3 ? '2d' : 'Cube') + '\"',\n 'invalid texture type', env.commandStr)\n }\n\n switch (type) {\n case GL_INT$3:\n checkType('number')\n break\n case GL_INT_VEC2:\n checkVector(2, 'number')\n break\n case GL_INT_VEC3:\n checkVector(3, 'number')\n break\n case GL_INT_VEC4:\n checkVector(4, 'number')\n break\n case GL_FLOAT$8:\n checkType('number')\n break\n case GL_FLOAT_VEC2:\n checkVector(2, 'number')\n break\n case GL_FLOAT_VEC3:\n checkVector(3, 'number')\n break\n case GL_FLOAT_VEC4:\n checkVector(4, 'number')\n break\n case GL_BOOL:\n checkType('boolean')\n break\n case GL_BOOL_VEC2:\n checkVector(2, 'boolean')\n break\n case GL_BOOL_VEC3:\n checkVector(3, 'boolean')\n break\n case GL_BOOL_VEC4:\n checkVector(4, 'boolean')\n break\n case GL_FLOAT_MAT2:\n checkVector(4, 'number')\n break\n case GL_FLOAT_MAT3:\n checkVector(9, 'number')\n break\n case GL_FLOAT_MAT4:\n checkVector(16, 'number')\n break\n case GL_SAMPLER_2D:\n checkTexture(GL_TEXTURE_2D$3)\n break\n case GL_SAMPLER_CUBE:\n checkTexture(GL_TEXTURE_CUBE_MAP$2)\n break\n }\n })\n\n var unroll = 1\n switch (type) {\n case GL_SAMPLER_2D:\n case GL_SAMPLER_CUBE:\n var TEX = scope.def(VALUE, '._texture')\n scope(GL, '.uniform1i(', LOCATION, ',', TEX, '.bind());')\n scope.exit(TEX, '.unbind();')\n continue\n\n case GL_INT$3:\n case GL_BOOL:\n infix = '1i'\n break\n\n case GL_INT_VEC2:\n case GL_BOOL_VEC2:\n infix = '2i'\n unroll = 2\n break\n\n case GL_INT_VEC3:\n case GL_BOOL_VEC3:\n infix = '3i'\n unroll = 3\n break\n\n case GL_INT_VEC4:\n case GL_BOOL_VEC4:\n infix = '4i'\n unroll = 4\n break\n\n case GL_FLOAT$8:\n infix = '1f'\n break\n\n case GL_FLOAT_VEC2:\n infix = '2f'\n unroll = 2\n break\n\n case GL_FLOAT_VEC3:\n infix = '3f'\n unroll = 3\n break\n\n case GL_FLOAT_VEC4:\n infix = '4f'\n unroll = 4\n break\n\n case GL_FLOAT_MAT2:\n infix = 'Matrix2fv'\n break\n\n case GL_FLOAT_MAT3:\n infix = 'Matrix3fv'\n break\n\n case GL_FLOAT_MAT4:\n infix = 'Matrix4fv'\n break\n }\n\n scope(GL, '.uniform', infix, '(', LOCATION, ',')\n if (infix.charAt(0) === 'M') {\n var matSize = Math.pow(type - GL_FLOAT_MAT2 + 2, 2)\n var STORAGE = env.global.def('new Float32Array(', matSize, ')')\n if (Array.isArray(VALUE)) {\n scope(\n 'false,(',\n loop(matSize, function (i) {\n return STORAGE + '[' + i + ']=' + VALUE[i]\n }), ',', STORAGE, ')')\n } else {\n scope(\n 'false,(Array.isArray(', VALUE, ')||', VALUE, ' instanceof Float32Array)?', VALUE, ':(',\n loop(matSize, function (i) {\n return STORAGE + '[' + i + ']=' + VALUE + '[' + i + ']'\n }), ',', STORAGE, ')')\n }\n } else if (unroll > 1) {\n scope(loop(unroll, function (i) {\n return Array.isArray(VALUE) ? VALUE[i] : VALUE + '[' + i + ']'\n }))\n } else {\n check$1(!Array.isArray(VALUE), 'uniform value must not be an array')\n scope(VALUE)\n }\n scope(');')\n }\n }\n\n function emitDraw (env, outer, inner, args) {\n var shared = env.shared\n var GL = shared.gl\n var DRAW_STATE = shared.draw\n\n var drawOptions = args.draw\n\n function emitElements () {\n var defn = drawOptions.elements\n var ELEMENTS\n var scope = outer\n if (defn) {\n if ((defn.contextDep && args.contextDynamic) || defn.propDep) {\n scope = inner\n }\n ELEMENTS = defn.append(env, scope)\n } else {\n ELEMENTS = scope.def(DRAW_STATE, '.', S_ELEMENTS)\n }\n if (ELEMENTS) {\n scope(\n 'if(' + ELEMENTS + ')' +\n GL + '.bindBuffer(' + GL_ELEMENT_ARRAY_BUFFER$1 + ',' + ELEMENTS + '.buffer.buffer);')\n }\n return ELEMENTS\n }\n\n function emitCount () {\n var defn = drawOptions.count\n var COUNT\n var scope = outer\n if (defn) {\n if ((defn.contextDep && args.contextDynamic) || defn.propDep) {\n scope = inner\n }\n COUNT = defn.append(env, scope)\n check$1.optional(function () {\n if (defn.MISSING) {\n env.assert(outer, 'false', 'missing vertex count')\n }\n if (defn.DYNAMIC) {\n env.assert(scope, COUNT + '>=0', 'missing vertex count')\n }\n })\n } else {\n COUNT = scope.def(DRAW_STATE, '.', S_COUNT)\n check$1.optional(function () {\n env.assert(scope, COUNT + '>=0', 'missing vertex count')\n })\n }\n return COUNT\n }\n\n var ELEMENTS = emitElements()\n function emitValue (name) {\n var defn = drawOptions[name]\n if (defn) {\n if ((defn.contextDep && args.contextDynamic) || defn.propDep) {\n return defn.append(env, inner)\n } else {\n return defn.append(env, outer)\n }\n } else {\n return outer.def(DRAW_STATE, '.', name)\n }\n }\n\n var PRIMITIVE = emitValue(S_PRIMITIVE)\n var OFFSET = emitValue(S_OFFSET)\n\n var COUNT = emitCount()\n if (typeof COUNT === 'number') {\n if (COUNT === 0) {\n return\n }\n } else {\n inner('if(', COUNT, '){')\n inner.exit('}')\n }\n\n var INSTANCES, EXT_INSTANCING\n if (extInstancing) {\n INSTANCES = emitValue(S_INSTANCES)\n EXT_INSTANCING = env.instancing\n }\n\n var ELEMENT_TYPE = ELEMENTS + '.type'\n\n var elementsStatic = drawOptions.elements && isStatic(drawOptions.elements)\n\n function emitInstancing () {\n function drawElements () {\n inner(EXT_INSTANCING, '.drawElementsInstancedANGLE(', [\n PRIMITIVE,\n COUNT,\n ELEMENT_TYPE,\n OFFSET + '<<((' + ELEMENT_TYPE + '-' + GL_UNSIGNED_BYTE$8 + ')>>1)',\n INSTANCES\n ], ');')\n }\n\n function drawArrays () {\n inner(EXT_INSTANCING, '.drawArraysInstancedANGLE(',\n [PRIMITIVE, OFFSET, COUNT, INSTANCES], ');')\n }\n\n if (ELEMENTS) {\n if (!elementsStatic) {\n inner('if(', ELEMENTS, '){')\n drawElements()\n inner('}else{')\n drawArrays()\n inner('}')\n } else {\n drawElements()\n }\n } else {\n drawArrays()\n }\n }\n\n function emitRegular () {\n function drawElements () {\n inner(GL + '.drawElements(' + [\n PRIMITIVE,\n COUNT,\n ELEMENT_TYPE,\n OFFSET + '<<((' + ELEMENT_TYPE + '-' + GL_UNSIGNED_BYTE$8 + ')>>1)'\n ] + ');')\n }\n\n function drawArrays () {\n inner(GL + '.drawArrays(' + [PRIMITIVE, OFFSET, COUNT] + ');')\n }\n\n if (ELEMENTS) {\n if (!elementsStatic) {\n inner('if(', ELEMENTS, '){')\n drawElements()\n inner('}else{')\n drawArrays()\n inner('}')\n } else {\n drawElements()\n }\n } else {\n drawArrays()\n }\n }\n\n if (extInstancing && (typeof INSTANCES !== 'number' || INSTANCES >= 0)) {\n if (typeof INSTANCES === 'string') {\n inner('if(', INSTANCES, '>0){')\n emitInstancing()\n inner('}else if(', INSTANCES, '<0){')\n emitRegular()\n inner('}')\n } else {\n emitInstancing()\n }\n } else {\n emitRegular()\n }\n }\n\n function createBody (emitBody, parentEnv, args, program, count) {\n var env = createREGLEnvironment()\n var scope = env.proc('body', count)\n check$1.optional(function () {\n env.commandStr = parentEnv.commandStr\n env.command = env.link(parentEnv.commandStr)\n })\n if (extInstancing) {\n env.instancing = scope.def(\n env.shared.extensions, '.angle_instanced_arrays')\n }\n emitBody(env, scope, args, program)\n return env.compile().body\n }\n\n // ===================================================\n // ===================================================\n // DRAW PROC\n // ===================================================\n // ===================================================\n function emitDrawBody (env, draw, args, program) {\n injectExtensions(env, draw)\n if (args.useVAO) {\n if (args.drawVAO) {\n draw(env.shared.vao, '.setVAO(', args.drawVAO.append(env, draw), ');')\n } else {\n draw(env.shared.vao, '.setVAO(', env.shared.vao, '.targetVAO);')\n }\n } else {\n draw(env.shared.vao, '.setVAO(null);')\n emitAttributes(env, draw, args, program.attributes, function () {\n return true\n })\n }\n emitUniforms(env, draw, args, program.uniforms, function () {\n return true\n })\n emitDraw(env, draw, draw, args)\n }\n\n function emitDrawProc (env, args) {\n var draw = env.proc('draw', 1)\n\n injectExtensions(env, draw)\n\n emitContext(env, draw, args.context)\n emitPollFramebuffer(env, draw, args.framebuffer)\n\n emitPollState(env, draw, args)\n emitSetOptions(env, draw, args.state)\n\n emitProfile(env, draw, args, false, true)\n\n var program = args.shader.progVar.append(env, draw)\n draw(env.shared.gl, '.useProgram(', program, '.program);')\n\n if (args.shader.program) {\n emitDrawBody(env, draw, args, args.shader.program)\n } else {\n draw(env.shared.vao, '.setVAO(null);')\n var drawCache = env.global.def('{}')\n var PROG_ID = draw.def(program, '.id')\n var CACHED_PROC = draw.def(drawCache, '[', PROG_ID, ']')\n draw(\n env.cond(CACHED_PROC)\n .then(CACHED_PROC, '.call(this,a0);')\n .else(\n CACHED_PROC, '=', drawCache, '[', PROG_ID, ']=',\n env.link(function (program) {\n return createBody(emitDrawBody, env, args, program, 1)\n }), '(', program, ');',\n CACHED_PROC, '.call(this,a0);'))\n }\n\n if (Object.keys(args.state).length > 0) {\n draw(env.shared.current, '.dirty=true;')\n }\n }\n\n // ===================================================\n // ===================================================\n // BATCH PROC\n // ===================================================\n // ===================================================\n\n function emitBatchDynamicShaderBody (env, scope, args, program) {\n env.batchId = 'a1'\n\n injectExtensions(env, scope)\n\n function all () {\n return true\n }\n\n emitAttributes(env, scope, args, program.attributes, all)\n emitUniforms(env, scope, args, program.uniforms, all)\n emitDraw(env, scope, scope, args)\n }\n\n function emitBatchBody (env, scope, args, program) {\n injectExtensions(env, scope)\n\n var contextDynamic = args.contextDep\n\n var BATCH_ID = scope.def()\n var PROP_LIST = 'a0'\n var NUM_PROPS = 'a1'\n var PROPS = scope.def()\n env.shared.props = PROPS\n env.batchId = BATCH_ID\n\n var outer = env.scope()\n var inner = env.scope()\n\n scope(\n outer.entry,\n 'for(', BATCH_ID, '=0;', BATCH_ID, '<', NUM_PROPS, ';++', BATCH_ID, '){',\n PROPS, '=', PROP_LIST, '[', BATCH_ID, '];',\n inner,\n '}',\n outer.exit)\n\n function isInnerDefn (defn) {\n return ((defn.contextDep && contextDynamic) || defn.propDep)\n }\n\n function isOuterDefn (defn) {\n return !isInnerDefn(defn)\n }\n\n if (args.needsContext) {\n emitContext(env, inner, args.context)\n }\n if (args.needsFramebuffer) {\n emitPollFramebuffer(env, inner, args.framebuffer)\n }\n emitSetOptions(env, inner, args.state, isInnerDefn)\n\n if (args.profile && isInnerDefn(args.profile)) {\n emitProfile(env, inner, args, false, true)\n }\n\n if (!program) {\n var progCache = env.global.def('{}')\n var PROGRAM = args.shader.progVar.append(env, inner)\n var PROG_ID = inner.def(PROGRAM, '.id')\n var CACHED_PROC = inner.def(progCache, '[', PROG_ID, ']')\n inner(\n env.shared.gl, '.useProgram(', PROGRAM, '.program);',\n 'if(!', CACHED_PROC, '){',\n CACHED_PROC, '=', progCache, '[', PROG_ID, ']=',\n env.link(function (program) {\n return createBody(\n emitBatchDynamicShaderBody, env, args, program, 2)\n }), '(', PROGRAM, ');}',\n CACHED_PROC, '.call(this,a0[', BATCH_ID, '],', BATCH_ID, ');')\n } else {\n if (args.useVAO) {\n if (args.drawVAO) {\n if (isInnerDefn(args.drawVAO)) {\n // vao is a prop\n inner(env.shared.vao, '.setVAO(', args.drawVAO.append(env, inner), ');')\n } else {\n // vao is invariant\n outer(env.shared.vao, '.setVAO(', args.drawVAO.append(env, outer), ');')\n }\n } else {\n // scoped vao binding\n outer(env.shared.vao, '.setVAO(', env.shared.vao, '.targetVAO);')\n }\n } else {\n outer(env.shared.vao, '.setVAO(null);')\n emitAttributes(env, outer, args, program.attributes, isOuterDefn)\n emitAttributes(env, inner, args, program.attributes, isInnerDefn)\n }\n emitUniforms(env, outer, args, program.uniforms, isOuterDefn)\n emitUniforms(env, inner, args, program.uniforms, isInnerDefn)\n emitDraw(env, outer, inner, args)\n }\n }\n\n function emitBatchProc (env, args) {\n var batch = env.proc('batch', 2)\n env.batchId = '0'\n\n injectExtensions(env, batch)\n\n // Check if any context variables depend on props\n var contextDynamic = false\n var needsContext = true\n Object.keys(args.context).forEach(function (name) {\n contextDynamic = contextDynamic || args.context[name].propDep\n })\n if (!contextDynamic) {\n emitContext(env, batch, args.context)\n needsContext = false\n }\n\n // framebuffer state affects framebufferWidth/height context vars\n var framebuffer = args.framebuffer\n var needsFramebuffer = false\n if (framebuffer) {\n if (framebuffer.propDep) {\n contextDynamic = needsFramebuffer = true\n } else if (framebuffer.contextDep && contextDynamic) {\n needsFramebuffer = true\n }\n if (!needsFramebuffer) {\n emitPollFramebuffer(env, batch, framebuffer)\n }\n } else {\n emitPollFramebuffer(env, batch, null)\n }\n\n // viewport is weird because it can affect context vars\n if (args.state.viewport && args.state.viewport.propDep) {\n contextDynamic = true\n }\n\n function isInnerDefn (defn) {\n return (defn.contextDep && contextDynamic) || defn.propDep\n }\n\n // set webgl options\n emitPollState(env, batch, args)\n emitSetOptions(env, batch, args.state, function (defn) {\n return !isInnerDefn(defn)\n })\n\n if (!args.profile || !isInnerDefn(args.profile)) {\n emitProfile(env, batch, args, false, 'a1')\n }\n\n // Save these values to args so that the batch body routine can use them\n args.contextDep = contextDynamic\n args.needsContext = needsContext\n args.needsFramebuffer = needsFramebuffer\n\n // determine if shader is dynamic\n var progDefn = args.shader.progVar\n if ((progDefn.contextDep && contextDynamic) || progDefn.propDep) {\n emitBatchBody(\n env,\n batch,\n args,\n null)\n } else {\n var PROGRAM = progDefn.append(env, batch)\n batch(env.shared.gl, '.useProgram(', PROGRAM, '.program);')\n if (args.shader.program) {\n emitBatchBody(\n env,\n batch,\n args,\n args.shader.program)\n } else {\n batch(env.shared.vao, '.setVAO(null);')\n var batchCache = env.global.def('{}')\n var PROG_ID = batch.def(PROGRAM, '.id')\n var CACHED_PROC = batch.def(batchCache, '[', PROG_ID, ']')\n batch(\n env.cond(CACHED_PROC)\n .then(CACHED_PROC, '.call(this,a0,a1);')\n .else(\n CACHED_PROC, '=', batchCache, '[', PROG_ID, ']=',\n env.link(function (program) {\n return createBody(emitBatchBody, env, args, program, 2)\n }), '(', PROGRAM, ');',\n CACHED_PROC, '.call(this,a0,a1);'))\n }\n }\n\n if (Object.keys(args.state).length > 0) {\n batch(env.shared.current, '.dirty=true;')\n }\n }\n\n // ===================================================\n // ===================================================\n // SCOPE COMMAND\n // ===================================================\n // ===================================================\n function emitScopeProc (env, args) {\n var scope = env.proc('scope', 3)\n env.batchId = 'a2'\n\n var shared = env.shared\n var CURRENT_STATE = shared.current\n\n emitContext(env, scope, args.context)\n\n if (args.framebuffer) {\n args.framebuffer.append(env, scope)\n }\n\n sortState(Object.keys(args.state)).forEach(function (name) {\n var defn = args.state[name]\n var value = defn.append(env, scope)\n if (isArrayLike(value)) {\n value.forEach(function (v, i) {\n scope.set(env.next[name], '[' + i + ']', v)\n })\n } else {\n scope.set(shared.next, '.' + name, value)\n }\n })\n\n emitProfile(env, scope, args, true, true)\n\n ;[S_ELEMENTS, S_OFFSET, S_COUNT, S_INSTANCES, S_PRIMITIVE].forEach(\n function (opt) {\n var variable = args.draw[opt]\n if (!variable) {\n return\n }\n scope.set(shared.draw, '.' + opt, '' + variable.append(env, scope))\n })\n\n Object.keys(args.uniforms).forEach(function (opt) {\n var value = args.uniforms[opt].append(env, scope)\n if (Array.isArray(value)) {\n value = '[' + value.join() + ']'\n }\n scope.set(\n shared.uniforms,\n '[' + stringStore.id(opt) + ']',\n value)\n })\n\n Object.keys(args.attributes).forEach(function (name) {\n var record = args.attributes[name].append(env, scope)\n var scopeAttrib = env.scopeAttrib(name)\n Object.keys(new AttributeRecord()).forEach(function (prop) {\n scope.set(scopeAttrib, '.' + prop, record[prop])\n })\n })\n\n if (args.scopeVAO) {\n scope.set(shared.vao, '.targetVAO', args.scopeVAO.append(env, scope))\n }\n\n function saveShader (name) {\n var shader = args.shader[name]\n if (shader) {\n scope.set(shared.shader, '.' + name, shader.append(env, scope))\n }\n }\n saveShader(S_VERT)\n saveShader(S_FRAG)\n\n if (Object.keys(args.state).length > 0) {\n scope(CURRENT_STATE, '.dirty=true;')\n scope.exit(CURRENT_STATE, '.dirty=true;')\n }\n\n scope('a1(', env.shared.context, ',a0,', env.batchId, ');')\n }\n\n function isDynamicObject (object) {\n if (typeof object !== 'object' || isArrayLike(object)) {\n return\n }\n var props = Object.keys(object)\n for (var i = 0; i < props.length; ++i) {\n if (dynamic.isDynamic(object[props[i]])) {\n return true\n }\n }\n return false\n }\n\n function splatObject (env, options, name) {\n var object = options.static[name]\n if (!object || !isDynamicObject(object)) {\n return\n }\n\n var globals = env.global\n var keys = Object.keys(object)\n var thisDep = false\n var contextDep = false\n var propDep = false\n var objectRef = env.global.def('{}')\n keys.forEach(function (key) {\n var value = object[key]\n if (dynamic.isDynamic(value)) {\n if (typeof value === 'function') {\n value = object[key] = dynamic.unbox(value)\n }\n var deps = createDynamicDecl(value, null)\n thisDep = thisDep || deps.thisDep\n propDep = propDep || deps.propDep\n contextDep = contextDep || deps.contextDep\n } else {\n globals(objectRef, '.', key, '=')\n switch (typeof value) {\n case 'number':\n globals(value)\n break\n case 'string':\n globals('\"', value, '\"')\n break\n case 'object':\n if (Array.isArray(value)) {\n globals('[', value.join(), ']')\n }\n break\n default:\n globals(env.link(value))\n break\n }\n globals(';')\n }\n })\n\n function appendBlock (env, block) {\n keys.forEach(function (key) {\n var value = object[key]\n if (!dynamic.isDynamic(value)) {\n return\n }\n var ref = env.invoke(block, value)\n block(objectRef, '.', key, '=', ref, ';')\n })\n }\n\n options.dynamic[name] = new dynamic.DynamicVariable(DYN_THUNK, {\n thisDep: thisDep,\n contextDep: contextDep,\n propDep: propDep,\n ref: objectRef,\n append: appendBlock\n })\n delete options.static[name]\n }\n\n // ===========================================================================\n // ===========================================================================\n // MAIN DRAW COMMAND\n // ===========================================================================\n // ===========================================================================\n function compileCommand (options, attributes, uniforms, context, stats) {\n var env = createREGLEnvironment()\n\n // link stats, so that we can easily access it in the program.\n env.stats = env.link(stats)\n\n // splat options and attributes to allow for dynamic nested properties\n Object.keys(attributes.static).forEach(function (key) {\n splatObject(env, attributes, key)\n })\n NESTED_OPTIONS.forEach(function (name) {\n splatObject(env, options, name)\n })\n\n var args = parseArguments(options, attributes, uniforms, context, env)\n\n emitDrawProc(env, args)\n emitScopeProc(env, args)\n emitBatchProc(env, args)\n\n return extend(env.compile(), {\n destroy: function () {\n args.shader.program.destroy()\n }\n })\n }\n\n // ===========================================================================\n // ===========================================================================\n // POLL / REFRESH\n // ===========================================================================\n // ===========================================================================\n return {\n next: nextState,\n current: currentState,\n procs: (function () {\n var env = createREGLEnvironment()\n var poll = env.proc('poll')\n var refresh = env.proc('refresh')\n var common = env.block()\n poll(common)\n refresh(common)\n\n var shared = env.shared\n var GL = shared.gl\n var NEXT_STATE = shared.next\n var CURRENT_STATE = shared.current\n\n common(CURRENT_STATE, '.dirty=false;')\n\n emitPollFramebuffer(env, poll)\n emitPollFramebuffer(env, refresh, null, true)\n\n // Refresh updates all attribute state changes\n var INSTANCING\n if (extInstancing) {\n INSTANCING = env.link(extInstancing)\n }\n\n // update vertex array bindings\n if (extensions.oes_vertex_array_object) {\n refresh(env.link(extensions.oes_vertex_array_object), '.bindVertexArrayOES(null);')\n }\n for (var i = 0; i < limits.maxAttributes; ++i) {\n var BINDING = refresh.def(shared.attributes, '[', i, ']')\n var ifte = env.cond(BINDING, '.buffer')\n ifte.then(\n GL, '.enableVertexAttribArray(', i, ');',\n GL, '.bindBuffer(',\n GL_ARRAY_BUFFER$2, ',',\n BINDING, '.buffer.buffer);',\n GL, '.vertexAttribPointer(',\n i, ',',\n BINDING, '.size,',\n BINDING, '.type,',\n BINDING, '.normalized,',\n BINDING, '.stride,',\n BINDING, '.offset);'\n ).else(\n GL, '.disableVertexAttribArray(', i, ');',\n GL, '.vertexAttrib4f(',\n i, ',',\n BINDING, '.x,',\n BINDING, '.y,',\n BINDING, '.z,',\n BINDING, '.w);',\n BINDING, '.buffer=null;')\n refresh(ifte)\n if (extInstancing) {\n refresh(\n INSTANCING, '.vertexAttribDivisorANGLE(',\n i, ',',\n BINDING, '.divisor);')\n }\n }\n refresh(\n env.shared.vao, '.currentVAO=null;',\n env.shared.vao, '.setVAO(', env.shared.vao, '.targetVAO);')\n\n Object.keys(GL_FLAGS).forEach(function (flag) {\n var cap = GL_FLAGS[flag]\n var NEXT = common.def(NEXT_STATE, '.', flag)\n var block = env.block()\n block('if(', NEXT, '){',\n GL, '.enable(', cap, ')}else{',\n GL, '.disable(', cap, ')}',\n CURRENT_STATE, '.', flag, '=', NEXT, ';')\n refresh(block)\n poll(\n 'if(', NEXT, '!==', CURRENT_STATE, '.', flag, '){',\n block,\n '}')\n })\n\n Object.keys(GL_VARIABLES).forEach(function (name) {\n var func = GL_VARIABLES[name]\n var init = currentState[name]\n var NEXT, CURRENT\n var block = env.block()\n block(GL, '.', func, '(')\n if (isArrayLike(init)) {\n var n = init.length\n NEXT = env.global.def(NEXT_STATE, '.', name)\n CURRENT = env.global.def(CURRENT_STATE, '.', name)\n block(\n loop(n, function (i) {\n return NEXT + '[' + i + ']'\n }), ');',\n loop(n, function (i) {\n return CURRENT + '[' + i + ']=' + NEXT + '[' + i + '];'\n }).join(''))\n poll(\n 'if(', loop(n, function (i) {\n return NEXT + '[' + i + ']!==' + CURRENT + '[' + i + ']'\n }).join('||'), '){',\n block,\n '}')\n } else {\n NEXT = common.def(NEXT_STATE, '.', name)\n CURRENT = common.def(CURRENT_STATE, '.', name)\n block(\n NEXT, ');',\n CURRENT_STATE, '.', name, '=', NEXT, ';')\n poll(\n 'if(', NEXT, '!==', CURRENT, '){',\n block,\n '}')\n }\n refresh(block)\n })\n\n return env.compile()\n })(),\n compile: compileCommand\n }\n}\n\nfunction stats () {\n return {\n vaoCount: 0,\n bufferCount: 0,\n elementsCount: 0,\n framebufferCount: 0,\n shaderCount: 0,\n textureCount: 0,\n cubeCount: 0,\n renderbufferCount: 0,\n maxTextureUnits: 0\n }\n}\n\nvar GL_QUERY_RESULT_EXT = 0x8866\nvar GL_QUERY_RESULT_AVAILABLE_EXT = 0x8867\nvar GL_TIME_ELAPSED_EXT = 0x88BF\n\nvar createTimer = function (gl, extensions) {\n if (!extensions.ext_disjoint_timer_query) {\n return null\n }\n\n // QUERY POOL BEGIN\n var queryPool = []\n function allocQuery () {\n return queryPool.pop() || extensions.ext_disjoint_timer_query.createQueryEXT()\n }\n function freeQuery (query) {\n queryPool.push(query)\n }\n // QUERY POOL END\n\n var pendingQueries = []\n function beginQuery (stats) {\n var query = allocQuery()\n extensions.ext_disjoint_timer_query.beginQueryEXT(GL_TIME_ELAPSED_EXT, query)\n pendingQueries.push(query)\n pushScopeStats(pendingQueries.length - 1, pendingQueries.length, stats)\n }\n\n function endQuery () {\n extensions.ext_disjoint_timer_query.endQueryEXT(GL_TIME_ELAPSED_EXT)\n }\n\n //\n // Pending stats pool.\n //\n function PendingStats () {\n this.startQueryIndex = -1\n this.endQueryIndex = -1\n this.sum = 0\n this.stats = null\n }\n var pendingStatsPool = []\n function allocPendingStats () {\n return pendingStatsPool.pop() || new PendingStats()\n }\n function freePendingStats (pendingStats) {\n pendingStatsPool.push(pendingStats)\n }\n // Pending stats pool end\n\n var pendingStats = []\n function pushScopeStats (start, end, stats) {\n var ps = allocPendingStats()\n ps.startQueryIndex = start\n ps.endQueryIndex = end\n ps.sum = 0\n ps.stats = stats\n pendingStats.push(ps)\n }\n\n // we should call this at the beginning of the frame,\n // in order to update gpuTime\n var timeSum = []\n var queryPtr = []\n function update () {\n var ptr, i\n\n var n = pendingQueries.length\n if (n === 0) {\n return\n }\n\n // Reserve space\n queryPtr.length = Math.max(queryPtr.length, n + 1)\n timeSum.length = Math.max(timeSum.length, n + 1)\n timeSum[0] = 0\n queryPtr[0] = 0\n\n // Update all pending timer queries\n var queryTime = 0\n ptr = 0\n for (i = 0; i < pendingQueries.length; ++i) {\n var query = pendingQueries[i]\n if (extensions.ext_disjoint_timer_query.getQueryObjectEXT(query, GL_QUERY_RESULT_AVAILABLE_EXT)) {\n queryTime += extensions.ext_disjoint_timer_query.getQueryObjectEXT(query, GL_QUERY_RESULT_EXT)\n freeQuery(query)\n } else {\n pendingQueries[ptr++] = query\n }\n timeSum[i + 1] = queryTime\n queryPtr[i + 1] = ptr\n }\n pendingQueries.length = ptr\n\n // Update all pending stat queries\n ptr = 0\n for (i = 0; i < pendingStats.length; ++i) {\n var stats = pendingStats[i]\n var start = stats.startQueryIndex\n var end = stats.endQueryIndex\n stats.sum += timeSum[end] - timeSum[start]\n var startPtr = queryPtr[start]\n var endPtr = queryPtr[end]\n if (endPtr === startPtr) {\n stats.stats.gpuTime += stats.sum / 1e6\n freePendingStats(stats)\n } else {\n stats.startQueryIndex = startPtr\n stats.endQueryIndex = endPtr\n pendingStats[ptr++] = stats\n }\n }\n pendingStats.length = ptr\n }\n\n return {\n beginQuery: beginQuery,\n endQuery: endQuery,\n pushScopeStats: pushScopeStats,\n update: update,\n getNumPendingQueries: function () {\n return pendingQueries.length\n },\n clear: function () {\n queryPool.push.apply(queryPool, pendingQueries)\n for (var i = 0; i < queryPool.length; i++) {\n extensions.ext_disjoint_timer_query.deleteQueryEXT(queryPool[i])\n }\n pendingQueries.length = 0\n queryPool.length = 0\n },\n restore: function () {\n pendingQueries.length = 0\n queryPool.length = 0\n }\n }\n}\n\nvar GL_COLOR_BUFFER_BIT = 16384\nvar GL_DEPTH_BUFFER_BIT = 256\nvar GL_STENCIL_BUFFER_BIT = 1024\n\nvar GL_ARRAY_BUFFER = 34962\n\nvar CONTEXT_LOST_EVENT = 'webglcontextlost'\nvar CONTEXT_RESTORED_EVENT = 'webglcontextrestored'\n\nvar DYN_PROP = 1\nvar DYN_CONTEXT = 2\nvar DYN_STATE = 3\n\nfunction find (haystack, needle) {\n for (var i = 0; i < haystack.length; ++i) {\n if (haystack[i] === needle) {\n return i\n }\n }\n return -1\n}\n\nfunction wrapREGL (args) {\n var config = parseArgs(args)\n if (!config) {\n return null\n }\n\n var gl = config.gl\n var glAttributes = gl.getContextAttributes()\n var contextLost = gl.isContextLost()\n\n var extensionState = createExtensionCache(gl, config)\n if (!extensionState) {\n return null\n }\n\n var stringStore = createStringStore()\n var stats$$1 = stats()\n var extensions = extensionState.extensions\n var timer = createTimer(gl, extensions)\n\n var START_TIME = clock()\n var WIDTH = gl.drawingBufferWidth\n var HEIGHT = gl.drawingBufferHeight\n\n var contextState = {\n tick: 0,\n time: 0,\n viewportWidth: WIDTH,\n viewportHeight: HEIGHT,\n framebufferWidth: WIDTH,\n framebufferHeight: HEIGHT,\n drawingBufferWidth: WIDTH,\n drawingBufferHeight: HEIGHT,\n pixelRatio: config.pixelRatio\n }\n var uniformState = {}\n var drawState = {\n elements: null,\n primitive: 4, // GL_TRIANGLES\n count: -1,\n offset: 0,\n instances: -1\n }\n\n var limits = wrapLimits(gl, extensions)\n var bufferState = wrapBufferState(\n gl,\n stats$$1,\n config,\n destroyBuffer)\n var attributeState = wrapAttributeState(\n gl,\n extensions,\n limits,\n stats$$1,\n bufferState)\n function destroyBuffer (buffer) {\n return attributeState.destroyBuffer(buffer)\n }\n var elementState = wrapElementsState(gl, extensions, bufferState, stats$$1)\n var shaderState = wrapShaderState(gl, stringStore, stats$$1, config)\n var textureState = createTextureSet(\n gl,\n extensions,\n limits,\n function () { core.procs.poll() },\n contextState,\n stats$$1,\n config)\n var renderbufferState = wrapRenderbuffers(gl, extensions, limits, stats$$1, config)\n var framebufferState = wrapFBOState(\n gl,\n extensions,\n limits,\n textureState,\n renderbufferState,\n stats$$1)\n var core = reglCore(\n gl,\n stringStore,\n extensions,\n limits,\n bufferState,\n elementState,\n textureState,\n framebufferState,\n uniformState,\n attributeState,\n shaderState,\n drawState,\n contextState,\n timer,\n config)\n var readPixels = wrapReadPixels(\n gl,\n framebufferState,\n core.procs.poll,\n contextState,\n glAttributes, extensions, limits)\n\n var nextState = core.next\n var canvas = gl.canvas\n\n var rafCallbacks = []\n var lossCallbacks = []\n var restoreCallbacks = []\n var destroyCallbacks = [config.onDestroy]\n\n var activeRAF = null\n function handleRAF () {\n if (rafCallbacks.length === 0) {\n if (timer) {\n timer.update()\n }\n activeRAF = null\n return\n }\n\n // schedule next animation frame\n activeRAF = raf.next(handleRAF)\n\n // poll for changes\n poll()\n\n // fire a callback for all pending rafs\n for (var i = rafCallbacks.length - 1; i >= 0; --i) {\n var cb = rafCallbacks[i]\n if (cb) {\n cb(contextState, null, 0)\n }\n }\n\n // flush all pending webgl calls\n gl.flush()\n\n // poll GPU timers *after* gl.flush so we don't delay command dispatch\n if (timer) {\n timer.update()\n }\n }\n\n function startRAF () {\n if (!activeRAF && rafCallbacks.length > 0) {\n activeRAF = raf.next(handleRAF)\n }\n }\n\n function stopRAF () {\n if (activeRAF) {\n raf.cancel(handleRAF)\n activeRAF = null\n }\n }\n\n function handleContextLoss (event) {\n event.preventDefault()\n\n // set context lost flag\n contextLost = true\n\n // pause request animation frame\n stopRAF()\n\n // lose context\n lossCallbacks.forEach(function (cb) {\n cb()\n })\n }\n\n function handleContextRestored (event) {\n // clear error code\n gl.getError()\n\n // clear context lost flag\n contextLost = false\n\n // refresh state\n extensionState.restore()\n shaderState.restore()\n bufferState.restore()\n textureState.restore()\n renderbufferState.restore()\n framebufferState.restore()\n attributeState.restore()\n if (timer) {\n timer.restore()\n }\n\n // refresh state\n core.procs.refresh()\n\n // restart RAF\n startRAF()\n\n // restore context\n restoreCallbacks.forEach(function (cb) {\n cb()\n })\n }\n\n if (canvas) {\n canvas.addEventListener(CONTEXT_LOST_EVENT, handleContextLoss, false)\n canvas.addEventListener(CONTEXT_RESTORED_EVENT, handleContextRestored, false)\n }\n\n function destroy () {\n rafCallbacks.length = 0\n stopRAF()\n\n if (canvas) {\n canvas.removeEventListener(CONTEXT_LOST_EVENT, handleContextLoss)\n canvas.removeEventListener(CONTEXT_RESTORED_EVENT, handleContextRestored)\n }\n\n shaderState.clear()\n framebufferState.clear()\n renderbufferState.clear()\n textureState.clear()\n elementState.clear()\n bufferState.clear()\n attributeState.clear()\n\n if (timer) {\n timer.clear()\n }\n\n destroyCallbacks.forEach(function (cb) {\n cb()\n })\n }\n\n function compileProcedure (options) {\n check$1(!!options, 'invalid args to regl({...})')\n check$1.type(options, 'object', 'invalid args to regl({...})')\n\n function flattenNestedOptions (options) {\n var result = extend({}, options)\n delete result.uniforms\n delete result.attributes\n delete result.context\n delete result.vao\n\n if ('stencil' in result && result.stencil.op) {\n result.stencil.opBack = result.stencil.opFront = result.stencil.op\n delete result.stencil.op\n }\n\n function merge (name) {\n if (name in result) {\n var child = result[name]\n delete result[name]\n Object.keys(child).forEach(function (prop) {\n result[name + '.' + prop] = child[prop]\n })\n }\n }\n merge('blend')\n merge('depth')\n merge('cull')\n merge('stencil')\n merge('polygonOffset')\n merge('scissor')\n merge('sample')\n\n if ('vao' in options) {\n result.vao = options.vao\n }\n\n return result\n }\n\n function separateDynamic (object, useArrays) {\n var staticItems = {}\n var dynamicItems = {}\n Object.keys(object).forEach(function (option) {\n var value = object[option]\n if (dynamic.isDynamic(value)) {\n dynamicItems[option] = dynamic.unbox(value, option)\n return\n } else if (useArrays && Array.isArray(value)) {\n for (var i = 0; i < value.length; ++i) {\n if (dynamic.isDynamic(value[i])) {\n dynamicItems[option] = dynamic.unbox(value, option)\n return\n }\n }\n }\n staticItems[option] = value\n })\n return {\n dynamic: dynamicItems,\n static: staticItems\n }\n }\n\n // Treat context variables separate from other dynamic variables\n var context = separateDynamic(options.context || {}, true)\n var uniforms = separateDynamic(options.uniforms || {}, true)\n var attributes = separateDynamic(options.attributes || {}, false)\n var opts = separateDynamic(flattenNestedOptions(options), false)\n\n var stats$$1 = {\n gpuTime: 0.0,\n cpuTime: 0.0,\n count: 0\n }\n\n var compiled = core.compile(opts, attributes, uniforms, context, stats$$1)\n\n var draw = compiled.draw\n var batch = compiled.batch\n var scope = compiled.scope\n\n // FIXME: we should modify code generation for batch commands so this\n // isn't necessary\n var EMPTY_ARRAY = []\n function reserve (count) {\n while (EMPTY_ARRAY.length < count) {\n EMPTY_ARRAY.push(null)\n }\n return EMPTY_ARRAY\n }\n\n function REGLCommand (args, body) {\n var i\n if (contextLost) {\n check$1.raise('context lost')\n }\n if (typeof args === 'function') {\n return scope.call(this, null, args, 0)\n } else if (typeof body === 'function') {\n if (typeof args === 'number') {\n for (i = 0; i < args; ++i) {\n scope.call(this, null, body, i)\n }\n } else if (Array.isArray(args)) {\n for (i = 0; i < args.length; ++i) {\n scope.call(this, args[i], body, i)\n }\n } else {\n return scope.call(this, args, body, 0)\n }\n } else if (typeof args === 'number') {\n if (args > 0) {\n return batch.call(this, reserve(args | 0), args | 0)\n }\n } else if (Array.isArray(args)) {\n if (args.length) {\n return batch.call(this, args, args.length)\n }\n } else {\n return draw.call(this, args)\n }\n }\n\n return extend(REGLCommand, {\n stats: stats$$1,\n destroy: function () {\n compiled.destroy()\n }\n })\n }\n\n var setFBO = framebufferState.setFBO = compileProcedure({\n framebuffer: dynamic.define.call(null, DYN_PROP, 'framebuffer')\n })\n\n function clearImpl (_, options) {\n var clearFlags = 0\n core.procs.poll()\n\n var c = options.color\n if (c) {\n gl.clearColor(+c[0] || 0, +c[1] || 0, +c[2] || 0, +c[3] || 0)\n clearFlags |= GL_COLOR_BUFFER_BIT\n }\n if ('depth' in options) {\n gl.clearDepth(+options.depth)\n clearFlags |= GL_DEPTH_BUFFER_BIT\n }\n if ('stencil' in options) {\n gl.clearStencil(options.stencil | 0)\n clearFlags |= GL_STENCIL_BUFFER_BIT\n }\n\n check$1(!!clearFlags, 'called regl.clear with no buffer specified')\n gl.clear(clearFlags)\n }\n\n function clear (options) {\n check$1(\n typeof options === 'object' && options,\n 'regl.clear() takes an object as input')\n if ('framebuffer' in options) {\n if (options.framebuffer &&\n options.framebuffer_reglType === 'framebufferCube') {\n for (var i = 0; i < 6; ++i) {\n setFBO(extend({\n framebuffer: options.framebuffer.faces[i]\n }, options), clearImpl)\n }\n } else {\n setFBO(options, clearImpl)\n }\n } else {\n clearImpl(null, options)\n }\n }\n\n function frame (cb) {\n check$1.type(cb, 'function', 'regl.frame() callback must be a function')\n rafCallbacks.push(cb)\n\n function cancel () {\n // FIXME: should we check something other than equals cb here?\n // what if a user calls frame twice with the same callback...\n //\n var i = find(rafCallbacks, cb)\n check$1(i >= 0, 'cannot cancel a frame twice')\n function pendingCancel () {\n var index = find(rafCallbacks, pendingCancel)\n rafCallbacks[index] = rafCallbacks[rafCallbacks.length - 1]\n rafCallbacks.length -= 1\n if (rafCallbacks.length <= 0) {\n stopRAF()\n }\n }\n rafCallbacks[i] = pendingCancel\n }\n\n startRAF()\n\n return {\n cancel: cancel\n }\n }\n\n // poll viewport\n function pollViewport () {\n var viewport = nextState.viewport\n var scissorBox = nextState.scissor_box\n viewport[0] = viewport[1] = scissorBox[0] = scissorBox[1] = 0\n contextState.viewportWidth =\n contextState.framebufferWidth =\n contextState.drawingBufferWidth =\n viewport[2] =\n scissorBox[2] = gl.drawingBufferWidth\n contextState.viewportHeight =\n contextState.framebufferHeight =\n contextState.drawingBufferHeight =\n viewport[3] =\n scissorBox[3] = gl.drawingBufferHeight\n }\n\n function poll () {\n contextState.tick += 1\n contextState.time = now()\n pollViewport()\n core.procs.poll()\n }\n\n function refresh () {\n textureState.refresh()\n pollViewport()\n core.procs.refresh()\n if (timer) {\n timer.update()\n }\n }\n\n function now () {\n return (clock() - START_TIME) / 1000.0\n }\n\n refresh()\n\n function addListener (event, callback) {\n check$1.type(callback, 'function', 'listener callback must be a function')\n\n var callbacks\n switch (event) {\n case 'frame':\n return frame(callback)\n case 'lost':\n callbacks = lossCallbacks\n break\n case 'restore':\n callbacks = restoreCallbacks\n break\n case 'destroy':\n callbacks = destroyCallbacks\n break\n default:\n check$1.raise('invalid event, must be one of frame,lost,restore,destroy')\n }\n\n callbacks.push(callback)\n return {\n cancel: function () {\n for (var i = 0; i < callbacks.length; ++i) {\n if (callbacks[i] === callback) {\n callbacks[i] = callbacks[callbacks.length - 1]\n callbacks.pop()\n return\n }\n }\n }\n }\n }\n\n var regl = extend(compileProcedure, {\n // Clear current FBO\n clear: clear,\n\n // Short cuts for dynamic variables\n prop: dynamic.define.bind(null, DYN_PROP),\n context: dynamic.define.bind(null, DYN_CONTEXT),\n this: dynamic.define.bind(null, DYN_STATE),\n\n // executes an empty draw command\n draw: compileProcedure({}),\n\n // Resources\n buffer: function (options) {\n return bufferState.create(options, GL_ARRAY_BUFFER, false, false)\n },\n elements: function (options) {\n return elementState.create(options, false)\n },\n texture: textureState.create2D,\n cube: textureState.createCube,\n renderbuffer: renderbufferState.create,\n framebuffer: framebufferState.create,\n framebufferCube: framebufferState.createCube,\n vao: attributeState.createVAO,\n\n // Expose context attributes\n attributes: glAttributes,\n\n // Frame rendering\n frame: frame,\n on: addListener,\n\n // System limits\n limits: limits,\n hasExtension: function (name) {\n return limits.extensions.indexOf(name.toLowerCase()) >= 0\n },\n\n // Read pixels\n read: readPixels,\n\n // Destroy regl and all associated resources\n destroy: destroy,\n\n // Direct GL state manipulation\n _gl: gl,\n _refresh: refresh,\n\n poll: function () {\n poll()\n if (timer) {\n timer.update()\n }\n },\n\n // Current time\n now: now,\n\n // regl Statistics Information\n stats: stats$$1\n })\n\n config.onDone(null, regl)\n\n return regl\n}\n\nreturn wrapREGL;\n\n})));\n//# sourceMappingURL=regl.js.map\n", "//const transforms = require('./glsl-transforms.js')\n\nvar Output = function ({ regl, precision, label = \"\", width, height}) {\n this.regl = regl\n this.precision = precision\n this.label = label\n this.positionBuffer = this.regl.buffer([\n [-2, 0],\n [0, -2],\n [2, 2]\n ])\n\n this.draw = () => {}\n this.init()\n this.pingPongIndex = 0\n\n // for each output, create two fbos for pingponging\n this.fbos = (Array(2)).fill().map(() => this.regl.framebuffer({\n color: this.regl.texture({\n mag: 'nearest',\n width: width,\n height: height,\n format: 'rgba'\n }),\n depthStencil: false\n }))\n\n // array containing render passes\n// this.passes = []\n}\n\nOutput.prototype.resize = function(width, height) {\n this.fbos.forEach((fbo) => {\n fbo.resize(width, height)\n })\n// console.log(this)\n}\n\n\nOutput.prototype.getCurrent = function () {\n return this.fbos[this.pingPongIndex]\n}\n\nOutput.prototype.getTexture = function () {\n var index = this.pingPongIndex ? 0 : 1\n return this.fbos[index]\n}\n\nOutput.prototype.init = function () {\n// console.log('clearing')\n this.transformIndex = 0\n this.fragHeader = `\n precision ${this.precision} float;\n\n uniform float time;\n varying vec2 uv;\n `\n\n this.fragBody = ``\n\n this.vert = `\n precision ${this.precision} float;\n attribute vec2 position;\n varying vec2 uv;\n\n void main () {\n uv = position;\n gl_Position = vec4(2.0 * position - 1.0, 0, 1);\n }`\n\n this.attributes = {\n position: this.positionBuffer\n }\n this.uniforms = {\n time: this.regl.prop('time'),\n resolution: this.regl.prop('resolution')\n }\n\n this.frag = `\n ${this.fragHeader}\n\n void main () {\n vec4 c = vec4(0, 0, 0, 0);\n vec2 st = uv;\n ${this.fragBody}\n gl_FragColor = c;\n }\n `\n return this\n}\n\n\nOutput.prototype.render = function (passes) {\n let pass = passes[0]\n //console.log('pass', pass, this.pingPongIndex)\n var self = this\n var uniforms = Object.assign(pass.uniforms, { prevBuffer: () => {\n //var index = this.pingPongIndex ? 0 : 1\n // var index = self.pingPong[(passIndex+1)%2]\n // console.log('ping pong', self.pingPongIndex)\n return self.fbos[self.pingPongIndex]\n }\n })\n\n self.draw = self.regl({\n frag: pass.frag,\n vert: self.vert,\n attributes: self.attributes,\n uniforms: uniforms,\n count: 3,\n framebuffer: () => {\n self.pingPongIndex = self.pingPongIndex ? 0 : 1\n return self.fbos[self.pingPongIndex]\n }\n })\n}\n\n\nOutput.prototype.tick = function (props) {\n// console.log(props)\n this.draw(props)\n}\n\nexport default Output\n", "\nimport Output from './output.js'\nimport loop from 'raf-loop'\nimport Source from './hydra-source.js'\nimport MouseTools from './lib/mouse.js'\nimport Audio from './lib/audio.js'\nimport VidRecorder from './lib/video-recorder.js'\nimport ArrayUtils from './lib/array-utils.js'\n// import strudel from './lib/strudel.js'\nimport Sandbox from './eval-sandbox.js'\nimport Generator from './generator-factory.js'\nimport regl from 'regl'\n// const window = global.window\n\n\n\nconst Mouse = MouseTools()\n// to do: add ability to pass in certain uniforms and transforms\nclass HydraRenderer {\n\n constructor ({\n pb = null,\n width = 1280,\n height = 720,\n numSources = 4,\n numOutputs = 4,\n makeGlobal = true,\n autoLoop = true,\n detectAudio = true,\n enableStreamCapture = true,\n canvas,\n precision,\n extendTransforms = {} // add your own functions on init\n } = {}) {\n\n ArrayUtils.init()\n\n this.pb = pb\n\n this.width = width\n this.height = height\n this.renderAll = false\n this.detectAudio = detectAudio\n\n this._initCanvas(canvas)\n\n //global.window.test = 'hi'\n // object that contains all properties that will be made available on the global context and during local evaluation\n this.synth = {\n time: 0,\n bpm: 30,\n width: this.width,\n height: this.height,\n fps: undefined,\n stats: {\n fps: 0\n },\n speed: 1,\n mouse: Mouse,\n render: this._render.bind(this),\n setResolution: this.setResolution.bind(this),\n update: (dt) => {},// user defined update function\n hush: this.hush.bind(this),\n tick: this.tick.bind(this)\n }\n\n if (makeGlobal) window.loadScript = this.loadScript\n\n\n this.timeSinceLastUpdate = 0\n this._time = 0 // for internal use, only to use for deciding when to render frames\n\n // only allow valid precision options\n let precisionOptions = ['lowp','mediump','highp']\n if(precision && precisionOptions.includes(precision.toLowerCase())) {\n this.precision = precision.toLowerCase()\n //\n // if(!precisionValid){\n // console.warn('[hydra-synth warning]\\nConstructor was provided an invalid floating point precision value of \"' + precision + '\". Using default value of \"mediump\" instead.')\n // }\n } else {\n let isIOS =\n (/iPad|iPhone|iPod/.test(navigator.platform) ||\n (navigator.platform === 'MacIntel' && navigator.maxTouchPoints > 1)) &&\n !window.MSStream;\n this.precision = isIOS ? 'highp' : 'mediump'\n }\n\n\n\n this.extendTransforms = extendTransforms\n\n // boolean to store when to save screenshot\n this.saveFrame = false\n\n // if stream capture is enabled, this object contains the capture stream\n this.captureStream = null\n\n this.generator = undefined\n\n this._initRegl()\n this._initOutputs(numOutputs)\n this._initSources(numSources)\n this._generateGlslTransforms()\n\n this.synth.screencap = () => {\n this.saveFrame = true\n }\n\n if (enableStreamCapture) {\n try {\n this.captureStream = this.canvas.captureStream(25)\n // to do: enable capture stream of specific sources and outputs\n this.synth.vidRecorder = new VidRecorder(this.captureStream)\n } catch (e) {\n console.warn('[hydra-synth warning]\\nnew MediaSource() is not currently supported on iOS.')\n console.error(e)\n }\n }\n\n if(detectAudio) this._initAudio()\n\n if(autoLoop) loop(this.tick.bind(this)).start()\n\n // final argument is properties that the user can set, all others are treated as read-only\n this.sandbox = new Sandbox(this.synth, makeGlobal, ['speed', 'update', 'bpm', 'fps'])\n }\n\n eval(code) {\n this.sandbox.eval(code)\n }\n\n getScreenImage(callback) {\n this.imageCallback = callback\n this.saveFrame = true\n }\n\n hush() {\n this.s.forEach((source) => {\n source.clear()\n })\n this.o.forEach((output) => {\n this.synth.solid(0, 0, 0, 0).out(output)\n })\n this.synth.render(this.o[0])\n // this.synth.update = (dt) => {}\n this.sandbox.set('update', (dt) => {})\n }\n\n loadScript(url = \"\") {\n const p = new Promise((res, rej) => {\n var script = document.createElement(\"script\");\n script.onload = function () {\n console.log(`loaded script ${url}`);\n res();\n };\n script.onerror = (err) => {\n console.log(`error loading script ${url}`, \"log-error\");\n res()\n };\n script.src = url;\n document.head.appendChild(script);\n });\n return p;\n }\n\n setResolution(width, height) {\n // console.log(width, height)\n this.canvas.width = width\n this.canvas.height = height\n this.width = width // is this necessary?\n this.height = height // ?\n this.sandbox.set('width', width)\n this.sandbox.set('height', height)\n console.log(this.width)\n this.o.forEach((output) => {\n output.resize(width, height)\n })\n this.s.forEach((source) => {\n source.resize(width, height)\n })\n this.regl._refresh()\n console.log(this.canvas.width)\n }\n\n canvasToImage (callback) {\n const a = document.createElement('a')\n a.style.display = 'none'\n\n let d = new Date()\n a.download = `hydra-${d.getFullYear()}-${d.getMonth() + 1}-${d.getDate()}-${d.getHours()}.${d.getMinutes()}.${d.getSeconds()}.png`\n document.body.appendChild(a)\n var self = this\n this.canvas.toBlob( (blob) => {\n if(self.imageCallback){\n self.imageCallback(blob)\n delete self.imageCallback\n } else {\n a.href = URL.createObjectURL(blob)\n console.log(a.href)\n a.click()\n }\n }, 'image/png')\n setTimeout(() => {\n document.body.removeChild(a);\n window.URL.revokeObjectURL(a.href);\n }, 300);\n }\n\n _initAudio () {\n const that = this\n this.synth.a = new Audio({\n numBins: 4,\n parentEl: this.canvas.parentNode\n // changeListener: ({audio}) => {\n // that.a = audio.bins.map((_, index) =>\n // (scale = 1, offset = 0) => () => (audio.fft[index] * scale + offset)\n // )\n //\n // if (that.makeGlobal) {\n // that.a.forEach((a, index) => {\n // const aname = `a${index}`\n // window[aname] = a\n // })\n // }\n // }\n })\n }\n\n // create main output canvas and add to screen\n _initCanvas (canvas) {\n if (canvas) {\n this.canvas = canvas\n this.width = canvas.width\n this.height = canvas.height\n } else {\n this.canvas = document.createElement('canvas')\n this.canvas.width = this.width\n this.canvas.height = this.height\n this.canvas.style.width = '100%'\n this.canvas.style.height = '100%'\n this.canvas.style.imageRendering = 'pixelated'\n document.body.appendChild(this.canvas)\n }\n }\n\n _initRegl () {\n this.regl = regl({\n // profile: true,\n canvas: this.canvas,\n pixelRatio: 1//,\n // extensions: [\n // 'oes_texture_half_float',\n // 'oes_texture_half_float_linear'\n // ],\n // optionalExtensions: [\n // 'oes_texture_float',\n // 'oes_texture_float_linear'\n //]\n })\n\n // This clears the color buffer to black and the depth buffer to 1\n this.regl.clear({\n color: [0, 0, 0, 1]\n })\n\n this.renderAll = this.regl({\n frag: `\n precision ${this.precision} float;\n varying vec2 uv;\n uniform sampler2D tex0;\n uniform sampler2D tex1;\n uniform sampler2D tex2;\n uniform sampler2D tex3;\n\n void main () {\n vec2 st = vec2(1.0 - uv.x, uv.y);\n st*= vec2(2);\n vec2 q = floor(st).xy*(vec2(2.0, 1.0));\n int quad = int(q.x) + int(q.y);\n st.x += step(1., mod(st.y,2.0));\n st.y += step(1., mod(st.x,2.0));\n st = fract(st);\n if(quad==0){\n gl_FragColor = texture2D(tex0, st);\n } else if(quad==1){\n gl_FragColor = texture2D(tex1, st);\n } else if (quad==2){\n gl_FragColor = texture2D(tex2, st);\n } else {\n gl_FragColor = texture2D(tex3, st);\n }\n\n }\n `,\n vert: `\n precision ${this.precision} float;\n attribute vec2 position;\n varying vec2 uv;\n\n void main () {\n uv = position;\n gl_Position = vec4(1.0 - 2.0 * position, 0, 1);\n }`,\n attributes: {\n position: [\n [-2, 0],\n [0, -2],\n [2, 2]\n ]\n },\n uniforms: {\n tex0: this.regl.prop('tex0'),\n tex1: this.regl.prop('tex1'),\n tex2: this.regl.prop('tex2'),\n tex3: this.regl.prop('tex3')\n },\n count: 3,\n depth: { enable: false }\n })\n\n this.renderFbo = this.regl({\n frag: `\n precision ${this.precision} float;\n varying vec2 uv;\n uniform vec2 resolution;\n uniform sampler2D tex0;\n\n void main () {\n gl_FragColor = texture2D(tex0, vec2(1.0 - uv.x, uv.y));\n }\n `,\n vert: `\n precision ${this.precision} float;\n attribute vec2 position;\n varying vec2 uv;\n\n void main () {\n uv = position;\n gl_Position = vec4(1.0 - 2.0 * position, 0, 1);\n }`,\n attributes: {\n position: [\n [-2, 0],\n [0, -2],\n [2, 2]\n ]\n },\n uniforms: {\n tex0: this.regl.prop('tex0'),\n resolution: this.regl.prop('resolution')\n },\n count: 3,\n depth: { enable: false }\n })\n }\n\n _initOutputs (numOutputs) {\n const self = this\n this.o = (Array(numOutputs)).fill().map((el, index) => {\n var o = new Output({\n regl: this.regl,\n width: this.width,\n height: this.height,\n precision: this.precision,\n label: `o${index}`\n })\n // o.render()\n o.id = index\n self.synth['o'+index] = o\n return o\n })\n\n // set default output\n this.output = this.o[0]\n }\n\n _initSources (numSources) {\n this.s = []\n for(var i = 0; i < numSources; i++) {\n this.createSource(i)\n }\n }\n\n createSource (i) {\n let s = new Source({regl: this.regl, pb: this.pb, width: this.width, height: this.height, label: `s${i}`})\n this.synth['s' + this.s.length] = s\n this.s.push(s)\n return s\n }\n\n _generateGlslTransforms () {\n var self = this\n this.generator = new Generator({\n defaultOutput: this.o[0],\n defaultUniforms: this.o[0].uniforms,\n extendTransforms: this.extendTransforms,\n changeListener: ({type, method, synth}) => {\n if (type === 'add') {\n self.synth[method] = synth.generators[method]\n if(self.sandbox) self.sandbox.add(method)\n } else if (type === 'remove') {\n // what to do here? dangerously deleting window methods\n //delete window[method]\n }\n // }\n }\n })\n this.synth.setFunction = this.generator.setFunction.bind(this.generator)\n }\n\n _render (output) {\n if (output) {\n this.output = output\n this.isRenderingAll = false\n } else {\n this.isRenderingAll = true\n }\n }\n\n // dt in ms\n tick (dt, uniforms) {\n this.sandbox.tick()\n if(this.detectAudio === true) this.synth.a.tick()\n // let updateInterval = 1000/this.synth.fps // ms\n this.sandbox.set('time', this.synth.time += dt * 0.001 * this.synth.speed)\n this.timeSinceLastUpdate += dt\n if(!this.synth.fps || this.timeSinceLastUpdate >= 1000/this.synth.fps) {\n // console.log(1000/this.timeSinceLastUpdate)\n this.synth.stats.fps = Math.ceil(1000/this.timeSinceLastUpdate)\n if(this.synth.update) {\n try { this.synth.update(this.timeSinceLastUpdate) } catch (e) { console.log(e) }\n }\n // console.log(this.synth.speed, this.synth.time)\n for (let i = 0; i < this.s.length; i++) {\n this.s[i].tick(this.synth.time)\n }\n // console.log(this.canvas.width, this.canvas.height)\n for (let i = 0; i < this.o.length; i++) {\n this.o[i].tick({\n time: this.synth.time,\n mouse: this.synth.mouse,\n bpm: this.synth.bpm,\n resolution: [this.canvas.width, this.canvas.height]\n })\n }\n if (this.isRenderingAll) {\n this.renderAll({\n tex0: this.o[0].getCurrent(),\n tex1: this.o[1].getCurrent(),\n tex2: this.o[2].getCurrent(),\n tex3: this.o[3].getCurrent(),\n resolution: [this.canvas.width, this.canvas.height]\n })\n } else {\n\n this.renderFbo({\n tex0: this.output.getCurrent(),\n resolution: [this.canvas.width, this.canvas.height]\n })\n }\n this.timeSinceLastUpdate = 0\n }\n if(this.saveFrame === true) {\n this.canvasToImage()\n this.saveFrame = false\n }\n // this.regl.poll()\n }\n\n\n}\n\nexport default HydraRenderer\n", "//const enumerateDevices = require('enumerate-devices')\n\nexport default function (deviceId) {\n return navigator.mediaDevices.enumerateDevices()\n .then(devices => devices.filter(devices => devices.kind === 'videoinput'))\n .then(cameras => {\n let constraints = { audio: false, video: true}\n if (cameras[deviceId]) {\n constraints['video'] = {\n deviceId: { exact: cameras[deviceId].deviceId }\n }\n }\n // console.log(cameras)\n return window.navigator.mediaDevices.getUserMedia(constraints)\n })\n .then(stream => {\n const video = document.createElement('video')\n video.setAttribute('autoplay', '')\n video.setAttribute('muted', '')\n video.setAttribute('playsinline', '')\n // video.src = window.URL.createObjectURL(stream)\n video.srcObject = stream\n return new Promise((resolve, reject) => {\n video.addEventListener('loadedmetadata', () => {\n video.play().then(() => resolve({video: video}))\n })\n })\n })\n .catch(console.log.bind(console))\n}\n", "\nexport default function (options) {\n return new Promise(function(resolve, reject) {\n // async function startCapture(displayMediaOptions) {\n navigator.mediaDevices.getDisplayMedia(options).then((stream) => {\n const video = document.createElement('video')\n video.srcObject = stream\n video.addEventListener('loadedmetadata', () => {\n video.play()\n resolve({video: video})\n })\n }).catch((err) => reject(err))\n })\n}\n", "import Webcam from './lib/webcam.js'\nimport Screen from './lib/screenmedia.js'\n\nclass HydraSource {\n constructor ({ regl, width, height, pb, label = \"\"}) {\n this.label = label\n this.regl = regl\n this.src = null\n this.dynamic = true\n this.width = width\n this.height = height\n this.tex = this.regl.texture({\n // shape: [width, height]\n shape: [ 1, 1 ]\n })\n this.pb = pb\n }\n\n init (opts, params) {\n if ('src' in opts) {\n this.src = opts.src\n this.tex = this.regl.texture({ data: this.src, ...params })\n }\n if ('dynamic' in opts) this.dynamic = opts.dynamic\n }\n\n initCam (index, params) {\n const self = this\n Webcam(index)\n .then(response => {\n self.src = response.video\n self.dynamic = true\n self.tex = self.regl.texture({ data: self.src, ...params })\n })\n .catch(err => console.log('could not get camera', err))\n }\n\n initVideo (url = '', params) {\n // const self = this\n const vid = document.createElement('video')\n vid.crossOrigin = 'anonymous'\n vid.autoplay = true\n vid.loop = true\n vid.muted = true // mute in order to load without user interaction\n const onload = vid.addEventListener('loadeddata', () => {\n this.src = vid\n vid.play()\n this.tex = this.regl.texture({ data: this.src, ...params})\n this.dynamic = true\n })\n vid.src = url\n }\n\n initImage (url = '', params) {\n const img = document.createElement('img')\n img.crossOrigin = 'anonymous'\n img.src = url\n img.onload = () => {\n this.src = img\n this.dynamic = false\n this.tex = this.regl.texture({ data: this.src, ...params})\n }\n }\n\n initStream (streamName, params) {\n // console.log(\"initing stream!\", streamName)\n let self = this\n if (streamName && this.pb) {\n this.pb.initSource(streamName)\n\n this.pb.on('got video', function (nick, video) {\n if (nick === streamName) {\n self.src = video\n self.dynamic = true\n self.tex = self.regl.texture({ data: self.src, ...params})\n }\n })\n }\n }\n\n // index only relevant in atom-hydra + desktop apps\n initScreen (index = 0, params) {\n const self = this\n Screen()\n .then(function (response) {\n self.src = response.video\n self.tex = self.regl.texture({ data: self.src, ...params})\n self.dynamic = true\n // console.log(\"received screen input\")\n })\n .catch(err => console.log('could not get screen', err))\n }\n\n resize (width, height) {\n this.width = width\n this.height = height\n }\n\n clear () {\n if (this.src && this.src.srcObject) {\n if (this.src.srcObject.getTracks) {\n this.src.srcObject.getTracks().forEach(track => track.stop())\n }\n }\n this.src = null\n this.tex = this.regl.texture({ shape: [ 1, 1 ] })\n }\n\n tick (time) {\n // console.log(this.src, this.tex.width, this.tex.height)\n if (this.src !== null && this.dynamic === true) {\n if (this.src.videoWidth && this.src.videoWidth !== this.tex.width) {\n console.log(\n this.src.videoWidth,\n this.src.videoHeight,\n this.tex.width,\n this.tex.height\n )\n this.tex.resize(this.src.videoWidth, this.src.videoHeight)\n }\n\n if (this.src.width && this.src.width !== this.tex.width) {\n this.tex.resize(this.src.width, this.src.height)\n }\n\n this.tex.subimage(this.src)\n }\n }\n\n getTexture () {\n return this.tex\n }\n}\n\nexport default HydraSource\n", "// https://github.com/mikolalysenko/mouse-event\n\nconst mouse = {}\n\nfunction mouseButtons(ev) {\n if(typeof ev === 'object') {\n if('buttons' in ev) {\n return ev.buttons\n } else if('which' in ev) {\n var b = ev.which\n if(b === 2) {\n return 4\n } else if(b === 3) {\n return 2\n } else if(b > 0) {\n return 1<<(b-1)\n }\n } else if('button' in ev) {\n var b = ev.button\n if(b === 1) {\n return 4\n } else if(b === 2) {\n return 2\n } else if(b >= 0) {\n return 1< {\n // console.log(\"beat\")\n }\n\n this.canvas = document.createElement('canvas')\n this.canvas.width = 100\n this.canvas.height = 80\n this.canvas.style.width = \"100px\"\n this.canvas.style.height = \"80px\"\n this.canvas.style.position = 'absolute'\n this.canvas.style.right = '0px'\n this.canvas.style.bottom = '0px'\n parentEl.appendChild(this.canvas)\n\n this.isDrawing = isDrawing\n this.ctx = this.canvas.getContext('2d')\n this.ctx.fillStyle=\"#DFFFFF\"\n this.ctx.strokeStyle=\"#0ff\"\n this.ctx.lineWidth=0.5\n if(window.navigator.mediaDevices) {\n window.navigator.mediaDevices.getUserMedia({video: false, audio: true})\n .then((stream) => {\n // console.log('got mic stream', stream)\n this.stream = stream\n this.context = new AudioContext()\n // this.context = new AudioContext()\n let audio_stream = this.context.createMediaStreamSource(stream)\n\n // console.log(this.context)\n this.meyda = Meyda.createMeydaAnalyzer({\n audioContext: this.context,\n source: audio_stream,\n featureExtractors: [\n 'loudness',\n // 'perceptualSpread',\n // 'perceptualSharpness',\n // 'spectralCentroid'\n ]\n })\n })\n .catch((err) => console.log('ERROR', err))\n }\n }\n\n detectBeat (level) {\n //console.log(level, this.beat._cutoff)\n if (level > this.beat._cutoff && level > this.beat.threshold) {\n this.onBeat()\n this.beat._cutoff = level *1.2\n this.beat._framesSinceBeat = 0\n } else {\n if (this.beat._framesSinceBeat <= this.beat.holdFrames){\n this.beat._framesSinceBeat ++;\n } else {\n this.beat._cutoff *= this.beat.decay\n this.beat._cutoff = Math.max( this.beat._cutoff, this.beat.threshold);\n }\n }\n }\n\n tick() {\n if(this.meyda){\n var features = this.meyda.get()\n if(features && features !== null){\n this.vol = features.loudness.total\n this.detectBeat(this.vol)\n // reduce loudness array to number of bins\n const reducer = (accumulator, currentValue) => accumulator + currentValue;\n let spacing = Math.floor(features.loudness.specific.length/this.bins.length)\n this.prevBins = this.bins.slice(0)\n this.bins = this.bins.map((bin, index) => {\n return features.loudness.specific.slice(index * spacing, (index + 1)*spacing).reduce(reducer)\n }).map((bin, index) => {\n // map to specified range\n\n // return (bin * (1.0 - this.smooth) + this.prevBins[index] * this.smooth)\n return (bin * (1.0 - this.settings[index].smooth) + this.prevBins[index] * this.settings[index].smooth)\n })\n // var y = this.canvas.height - scale*this.settings[index].cutoff\n // this.ctx.beginPath()\n // this.ctx.moveTo(index*spacing, y)\n // this.ctx.lineTo((index+1)*spacing, y)\n // this.ctx.stroke()\n //\n // var yMax = this.canvas.height - scale*(this.settings[index].scale + this.settings[index].cutoff)\n this.fft = this.bins.map((bin, index) => (\n // Math.max(0, (bin - this.cutoff) / (this.max - this.cutoff))\n Math.max(0, (bin - this.settings[index].cutoff)/this.settings[index].scale)\n ))\n if(this.isDrawing) this.draw()\n }\n }\n }\n\n setCutoff (cutoff) {\n this.cutoff = cutoff\n this.settings = this.settings.map((el) => {\n el.cutoff = cutoff\n return el\n })\n }\n\n setSmooth (smooth) {\n this.smooth = smooth\n this.settings = this.settings.map((el) => {\n el.smooth = smooth\n return el\n })\n }\n\n setBins (numBins) {\n this.bins = Array(numBins).fill(0)\n this.prevBins = Array(numBins).fill(0)\n this.fft = Array(numBins).fill(0)\n this.settings = Array(numBins).fill(0).map(() => ({\n cutoff: this.cutoff,\n scale: this.scale,\n smooth: this.smooth\n }))\n // to do: what to do in non-global mode?\n this.bins.forEach((bin, index) => {\n window['a' + index] = (scale = 1, offset = 0) => () => (a.fft[index] * scale + offset)\n })\n // console.log(this.settings)\n }\n\n setScale(scale){\n this.scale = scale\n this.settings = this.settings.map((el) => {\n el.scale = scale\n return el\n })\n }\n\n setMax(max) {\n this.max = max\n console.log('set max is deprecated')\n }\n hide() {\n this.isDrawing = false\n this.canvas.style.display = 'none'\n }\n\n show() {\n this.isDrawing = true\n this.canvas.style.display = 'block'\n\n }\n\n draw () {\n this.ctx.clearRect(0, 0, this.canvas.width, this.canvas.height)\n var spacing = this.canvas.width / this.bins.length\n var scale = this.canvas.height / (this.max * 2)\n // console.log(this.bins)\n this.bins.forEach((bin, index) => {\n\n var height = bin * scale\n\n this.ctx.fillRect(index * spacing, this.canvas.height - height, spacing, height)\n\n // console.log(this.settings[index])\n var y = this.canvas.height - scale*this.settings[index].cutoff\n this.ctx.beginPath()\n this.ctx.moveTo(index*spacing, y)\n this.ctx.lineTo((index+1)*spacing, y)\n this.ctx.stroke()\n\n var yMax = this.canvas.height - scale*(this.settings[index].scale + this.settings[index].cutoff)\n this.ctx.beginPath()\n this.ctx.moveTo(index*spacing, yMax)\n this.ctx.lineTo((index+1)*spacing, yMax)\n this.ctx.stroke()\n })\n\n\n /*var y = this.canvas.height - scale*this.cutoff\n this.ctx.beginPath()\n this.ctx.moveTo(0, y)\n this.ctx.lineTo(this.canvas.width, y)\n this.ctx.stroke()\n var yMax = this.canvas.height - scale*this.max\n this.ctx.beginPath()\n this.ctx.moveTo(0, yMax)\n this.ctx.lineTo(this.canvas.width, yMax)\n this.ctx.stroke()*/\n }\n}\n\nexport default Audio\n", "class VideoRecorder {\n constructor(stream) {\n this.mediaSource = new MediaSource()\n this.stream = stream\n\n // testing using a recording as input\n this.output = document.createElement('video')\n this.output.autoplay = true\n this.output.loop = true\n\n let self = this\n this.mediaSource.addEventListener('sourceopen', () => {\n console.log('MediaSource opened');\n self.sourceBuffer = self.mediaSource.addSourceBuffer('video/webm; codecs=\"vp8\"');\n console.log('Source buffer: ', sourceBuffer);\n })\n }\n\n start() {\n // let options = {mimeType: 'video/webm'};\n\n// let options = {mimeType: 'video/webm;codecs=h264'};\n let options = {mimeType: 'video/webm;codecs=vp9'};\n\n this.recordedBlobs = []\n try {\n this.mediaRecorder = new MediaRecorder(this.stream, options)\n } catch (e0) {\n console.log('Unable to create MediaRecorder with options Object: ', e0)\n try {\n options = {mimeType: 'video/webm,codecs=vp9'}\n this.mediaRecorder = new MediaRecorder(this.stream, options)\n } catch (e1) {\n console.log('Unable to create MediaRecorder with options Object: ', e1)\n try {\n options = 'video/vp8' // Chrome 47\n this.mediaRecorder = new MediaRecorder(this.stream, options)\n } catch (e2) {\n alert('MediaRecorder is not supported by this browser.\\n\\n' +\n 'Try Firefox 29 or later, or Chrome 47 or later, ' +\n 'with Enable experimental Web Platform features enabled from chrome://flags.')\n console.error('Exception while creating MediaRecorder:', e2)\n return\n }\n }\n }\n console.log('Created MediaRecorder', this.mediaRecorder, 'with options', options);\n this.mediaRecorder.onstop = this._handleStop.bind(this)\n this.mediaRecorder.ondataavailable = this._handleDataAvailable.bind(this)\n this.mediaRecorder.start(100) // collect 100ms of data\n console.log('MediaRecorder started', this.mediaRecorder)\n }\n\n \n stop(){\n this.mediaRecorder.stop()\n }\n\n _handleStop() {\n //const superBuffer = new Blob(recordedBlobs, {type: 'video/webm'})\n // const blob = new Blob(this.recordedBlobs, {type: 'video/webm;codecs=h264'})\n const blob = new Blob(this.recordedBlobs, {type: this.mediaRecorder.mimeType})\n const url = window.URL.createObjectURL(blob)\n this.output.src = url\n\n const a = document.createElement('a')\n a.style.display = 'none'\n a.href = url\n let d = new Date()\n a.download = `hydra-${d.getFullYear()}-${d.getMonth() + 1}-${d.getDate()}-${d.getHours()}.${d.getMinutes()}.${d.getSeconds()}.webm`\n document.body.appendChild(a)\n a.click()\n setTimeout(() => {\n document.body.removeChild(a);\n window.URL.revokeObjectURL(url);\n }, 300);\n }\n\n _handleDataAvailable(event) {\n if (event.data && event.data.size > 0) {\n this.recordedBlobs.push(event.data);\n }\n }\n}\n\nexport default VideoRecorder\n", "// from https://gist.github.com/gre/1650294\n\nexport default {\n // no easing, no acceleration\n linear: function (t) { return t },\n // accelerating from zero velocity\n easeInQuad: function (t) { return t*t },\n // decelerating to zero velocity\n easeOutQuad: function (t) { return t*(2-t) },\n // acceleration until halfway, then deceleration\n easeInOutQuad: function (t) { return t<.5 ? 2*t*t : -1+(4-2*t)*t },\n // accelerating from zero velocity\n easeInCubic: function (t) { return t*t*t },\n // decelerating to zero velocity\n easeOutCubic: function (t) { return (--t)*t*t+1 },\n // acceleration until halfway, then deceleration\n easeInOutCubic: function (t) { return t<.5 ? 4*t*t*t : (t-1)*(2*t-2)*(2*t-2)+1 },\n // accelerating from zero velocity\n easeInQuart: function (t) { return t*t*t*t },\n // decelerating to zero velocity\n easeOutQuart: function (t) { return 1-(--t)*t*t*t },\n // acceleration until halfway, then deceleration\n easeInOutQuart: function (t) { return t<.5 ? 8*t*t*t*t : 1-8*(--t)*t*t*t },\n // accelerating from zero velocity\n easeInQuint: function (t) { return t*t*t*t*t },\n // decelerating to zero velocity\n easeOutQuint: function (t) { return 1+(--t)*t*t*t*t },\n // acceleration until halfway, then deceleration\n easeInOutQuint: function (t) { return t<.5 ? 16*t*t*t*t*t : 1+16*(--t)*t*t*t*t },\n // sin shape\n sin: function (t) { return (1 + Math.sin(Math.PI*t-Math.PI/2))/2 }\n}\n", "// WIP utils for working with arrays\n// Possibly should be integrated with lfo extension, etc.\n// to do: transform time rather than array values, similar to working with coordinates in hydra\n\nimport easing from './easing-functions.js'\n\nvar map = (num, in_min, in_max, out_min, out_max) => {\n return (num - in_min) * (out_max - out_min) / (in_max - in_min) + out_min;\n}\n\nexport default {\n init: () => {\n\n Array.prototype.fast = function(speed = 1) {\n this._speed = speed\n return this\n }\n\n Array.prototype.smooth = function(smooth = 1) {\n this._smooth = smooth\n return this\n }\n\n Array.prototype.ease = function(ease = 'linear') {\n if (typeof ease == 'function') {\n this._smooth = 1\n this._ease = ease\n }\n else if (easing[ease]){\n this._smooth = 1\n this._ease = easing[ease]\n }\n return this\n }\n\n Array.prototype.offset = function(offset = 0.5) {\n this._offset = offset%1.0\n return this\n }\n\n // Array.prototype.bounce = function() {\n // this.modifiers.bounce = true\n // return this\n // }\n\n Array.prototype.fit = function(low = 0, high =1) {\n let lowest = Math.min(...this)\n let highest = Math.max(...this)\n var newArr = this.map((num) => map(num, lowest, highest, low, high))\n newArr._speed = this._speed\n newArr._smooth = this._smooth\n newArr._ease = this._ease\n return newArr\n }\n },\n\n getValue: (arr = []) => ({time, bpm}) =>{\n let speed = arr._speed ? arr._speed : 1\n let smooth = arr._smooth ? arr._smooth : 0\n let index = time * speed * (bpm / 60) + (arr._offset || 0)\n\n if (smooth!==0) {\n let ease = arr._ease ? arr._ease : easing['linear']\n let _index = index - (smooth / 2)\n let currValue = arr[Math.floor(_index % (arr.length))]\n let nextValue = arr[Math.floor((_index + 1) % (arr.length))]\n let t = Math.min((_index%1)/smooth,1)\n return ease(t) * (nextValue - currValue) + currValue\n }\n else {\n const val = arr[Math.floor(index % (arr.length))]\n return arr[Math.floor(index % (arr.length))]\n }\n }\n}\n", "// attempt custom evaluation sandbox for hydra functions\n// for now, just avoids polluting the global namespace\n// should probably be replaced with an abstract syntax tree\n\nexport default (parent) => {\n var initialCode = ``\n\n var sandbox = createSandbox(initialCode)\n\n var addToContext = (name, object) => {\n initialCode += `\n var ${name} = ${object}\n `\n sandbox = createSandbox(initialCode)\n }\n\n\n return {\n addToContext: addToContext,\n eval: (code) => sandbox.eval(code)\n }\n\n function createSandbox (initial) {\n globalThis.eval(initial)\n // optional params\n var localEval = function (code) {\n globalThis.eval(code)\n }\n\n // API/data for end-user\n return {\n eval: localEval\n }\n }\n}\n", "// handles code evaluation and attaching relevant objects to global and evaluation contexts\n\nimport Sandbox from './lib/sandbox.js'\nimport ArrayUtils from './lib/array-utils.js'\n\nclass EvalSandbox {\n constructor(parent, makeGlobal, userProps = []) {\n this.makeGlobal = makeGlobal\n this.sandbox = Sandbox(parent)\n this.parent = parent\n var properties = Object.keys(parent)\n properties.forEach((property) => this.add(property))\n this.userProps = userProps\n }\n\n add(name) {\n if(this.makeGlobal) window[name] = this.parent[name]\n // this.sandbox.addToContext(name, `parent.${name}`)\n }\n\n// sets on window as well as synth object if global (not needed for objects, which can be set directly)\n\n set(property, value) {\n if(this.makeGlobal) {\n window[property] = value\n }\n this.parent[property] = value\n }\n\n tick() {\n if(this.makeGlobal) {\n this.userProps.forEach((property) => {\n this.parent[property] = window[property]\n })\n // this.parent.speed = window.speed\n } else {\n\n }\n }\n\n eval(code) {\n this.sandbox.eval(code)\n }\n}\n\nexport default EvalSandbox\n", "import arrayUtils from './lib/array-utils.js'\n\n// [WIP] how to treat different dimensions (?)\nconst DEFAULT_CONVERSIONS = {\n float: {\n 'vec4': { name: 'sum', args: [[1, 1, 1, 1]] },\n 'vec2': { name: 'sum', args: [[1, 1]] }\n }\n}\n\nfunction fillArrayWithDefaults(arr, len) {\n // fill the array with default values if it's too short\n while (arr.length < len) {\n if (arr.length === 3) { // push a 1 as the default for .a in vec4\n arr.push(1.0)\n } else {\n arr.push(0.0)\n }\n }\n return arr.slice(0, len)\n}\n\nconst ensure_decimal_dot = (val) => {\n val = val.toString()\n if (val.indexOf('.') < 0) {\n val += '.'\n }\n return val\n}\n\n\n\nexport default function formatArguments(transform, startIndex, synthContext) {\n const defaultArgs = transform.transform.inputs\n const userArgs = transform.userArgs\n const { generators } = transform.synth\n const { src } = generators // depends on synth having src() function\n return defaultArgs.map((input, index) => {\n const typedArg = {\n value: input.default,\n type: input.type, //\n isUniform: false,\n name: input.name,\n vecLen: 0\n // generateGlsl: null // function for creating glsl\n }\n\n if (typedArg.type === 'float') typedArg.value = ensure_decimal_dot(input.default)\n if (input.type.startsWith('vec')) {\n try {\n typedArg.vecLen = Number.parseInt(input.type.substr(3))\n } catch (e) {\n console.log(`Error determining length of vector input type ${input.type} (${input.name})`)\n }\n }\n\n // if user has input something for this argument\n if (userArgs.length > index) {\n typedArg.value = userArgs[index]\n // do something if a composite or transform\n\n if (typeof userArgs[index] === 'function') {\n // if (typedArg.vecLen > 0) { // expected input is a vector, not a scalar\n // typedArg.value = (context, props, batchId) => (fillArrayWithDefaults(userArgs[index](props), typedArg.vecLen))\n // } else {\n typedArg.value = (context, props, batchId) => {\n try {\n const val = userArgs[index](props)\n if(typeof val === 'number') {\n return val\n } else {\n console.warn('function does not return a number', userArgs[index])\n }\n return input.default\n } catch (e) {\n console.warn('ERROR', e)\n return input.default\n }\n }\n // }\n\n typedArg.isUniform = true\n } else if (userArgs[index].constructor === Array) {\n // if (typedArg.vecLen > 0) { // expected input is a vector, not a scalar\n // typedArg.isUniform = true\n // typedArg.value = fillArrayWithDefaults(typedArg.value, typedArg.vecLen)\n // } else {\n // console.log(\"is Array\")\n // filter out values that are not a number\n // const filteredArray = userArgs[index].filter((val) => typeof val === 'number')\n // typedArg.value = (context, props, batchId) => arrayUtils.getValue(filteredArray)(props)\n typedArg.value = (context, props, batchId) => arrayUtils.getValue(userArgs[index])(props)\n typedArg.isUniform = true\n // }\n } \n }\n\n if (startIndex < 0) {\n } else {\n if (typedArg.value && typedArg.value.transforms) {\n const final_transform = typedArg.value.transforms[typedArg.value.transforms.length - 1]\n\n if (final_transform.transform.glsl_return_type !== input.type) {\n const defaults = DEFAULT_CONVERSIONS[input.type]\n if (typeof defaults !== 'undefined') {\n const default_def = defaults[final_transform.transform.glsl_return_type]\n if (typeof default_def !== 'undefined') {\n const { name, args } = default_def\n typedArg.value = typedArg.value[name](...args)\n }\n }\n }\n\n typedArg.isUniform = false\n } else if (typedArg.type === 'float' && typeof typedArg.value === 'number') {\n typedArg.value = ensure_decimal_dot(typedArg.value)\n } else if (typedArg.type.startsWith('vec') && typeof typedArg.value === 'object' && Array.isArray(typedArg.value)) {\n typedArg.isUniform = false\n typedArg.value = `${typedArg.type}(${typedArg.value.map(ensure_decimal_dot).join(', ')})`\n } else if (input.type === 'sampler2D') {\n // typedArg.tex = typedArg.value\n var x = typedArg.value\n typedArg.value = () => (x.getTexture())\n typedArg.isUniform = true\n } else {\n // if passing in a texture reference, when function asks for vec4, convert to vec4\n if (typedArg.value.getTexture && input.type === 'vec4') {\n var x1 = typedArg.value\n typedArg.value = src(x1)\n typedArg.isUniform = false\n }\n }\n\n // add tp uniform array if is a function that will pass in a different value on each render frame,\n // or a texture/ external source\n\n if (typedArg.isUniform) {\n typedArg.name += startIndex\n // shaderParams.uniforms.push(typedArg)\n }\n }\n return typedArg\n })\n}\n\n", "import formatArguments from './format-arguments.js'\n\n// Add extra functionality to Array.prototype for generating sequences in time\nimport arrayUtils from './lib/array-utils.js'\n\n\n\n// converts a tree of javascript functions to a shader\nexport default function (transforms) {\n var shaderParams = {\n uniforms: [], // list of uniforms used in shader\n glslFunctions: [], // list of functions used in shader\n fragColor: ''\n }\n\n var gen = generateGlsl(transforms, shaderParams)('st')\n shaderParams.fragColor = gen\n // remove uniforms with duplicate names\n let uniforms = {}\n shaderParams.uniforms.forEach((uniform) => uniforms[uniform.name] = uniform)\n shaderParams.uniforms = Object.values(uniforms)\n return shaderParams\n\n}\n\n\n// recursive function for generating shader string from object containing functions and user arguments. Order of functions in string depends on type of function\n// to do: improve variable names\nfunction generateGlsl (transforms, shaderParams) {\n // transform function that outputs a shader string corresponding to gl_FragColor\n var fragColor = () => ''\n // var uniforms = []\n // var glslFunctions = []\n transforms.forEach((transform) => {\n var inputs = formatArguments(transform, shaderParams.uniforms.length)\n inputs.forEach((input) => {\n if(input.isUniform) shaderParams.uniforms.push(input)\n })\n\n // add new glsl function to running list of functions\n if(!contains(transform, shaderParams.glslFunctions)) shaderParams.glslFunctions.push(transform)\n\n // current function for generating frag color shader code\n var f0 = fragColor\n if (transform.transform.type === 'src') {\n fragColor = (uv) => `${shaderString(uv, transform.name, inputs, shaderParams)}`\n } else if (transform.transform.type === 'coord') {\n fragColor = (uv) => `${f0(`${shaderString(uv, transform.name, inputs, shaderParams)}`)}`\n } else if (transform.transform.type === 'color') {\n fragColor = (uv) => `${shaderString(`${f0(uv)}`, transform.name, inputs, shaderParams)}`\n } else if (transform.transform.type === 'combine') {\n // combining two generated shader strings (i.e. for blend, mult, add funtions)\n var f1 = inputs[0].value && inputs[0].value.transforms ?\n (uv) => `${generateGlsl(inputs[0].value.transforms, shaderParams)(uv)}` :\n (inputs[0].isUniform ? () => inputs[0].name : () => inputs[0].value)\n fragColor = (uv) => `${shaderString(`${f0(uv)}, ${f1(uv)}`, transform.name, inputs.slice(1), shaderParams)}`\n } else if (transform.transform.type === 'combineCoord') {\n // combining two generated shader strings (i.e. for modulate functions)\n var f1 = inputs[0].value && inputs[0].value.transforms ?\n (uv) => `${generateGlsl(inputs[0].value.transforms, shaderParams)(uv)}` :\n (inputs[0].isUniform ? () => inputs[0].name : () => inputs[0].value)\n fragColor = (uv) => `${f0(`${shaderString(`${uv}, ${f1(uv)}`, transform.name, inputs.slice(1), shaderParams)}`)}`\n\n\n }\n })\n// console.log(fragColor)\n // break;\n return fragColor\n}\n\n// assembles a shader string containing the arguments and the function name, i.e. 'osc(uv, frequency)'\nfunction shaderString (uv, method, inputs, shaderParams) {\n const str = inputs.map((input) => {\n if (input.isUniform) {\n return input.name\n } else if (input.value && input.value.transforms) {\n // this by definition needs to be a generator, hence we start with 'st' as the initial value for generating the glsl fragment\n return `${generateGlsl(input.value.transforms, shaderParams)('st')}`\n }\n return input.value\n }).reduce((p, c) => `${p}, ${c}`, '')\n\n return `${method}(${uv}${str})`\n}\n\n// merge two arrays and remove duplicates\nfunction mergeArrays (a, b) {\n return a.concat(b.filter(function (item) {\n return a.indexOf(item) < 0;\n }))\n}\n\n// check whether array\nfunction contains(object, arr) {\n for(var i = 0; i < arr.length; i++){\n if(object.name == arr[i].name) return true\n }\n return false\n}\n\n\n\n", "// functions that are only used within other functions\n\nexport default {\n _luminance: {\n type: 'util',\n glsl: `float _luminance(vec3 rgb){\n const vec3 W = vec3(0.2125, 0.7154, 0.0721);\n return dot(rgb, W);\n }`\n },\n _noise: {\n type: 'util',\n glsl: `\n //\tSimplex 3D Noise\n //\tby Ian McEwan, Ashima Arts\n vec4 permute(vec4 x){return mod(((x*34.0)+1.0)*x, 289.0);}\n vec4 taylorInvSqrt(vec4 r){return 1.79284291400159 - 0.85373472095314 * r;}\n\n float _noise(vec3 v){\n const vec2 C = vec2(1.0/6.0, 1.0/3.0) ;\n const vec4 D = vec4(0.0, 0.5, 1.0, 2.0);\n\n // First corner\n vec3 i = floor(v + dot(v, C.yyy) );\n vec3 x0 = v - i + dot(i, C.xxx) ;\n\n // Other corners\n vec3 g = step(x0.yzx, x0.xyz);\n vec3 l = 1.0 - g;\n vec3 i1 = min( g.xyz, l.zxy );\n vec3 i2 = max( g.xyz, l.zxy );\n\n // x0 = x0 - 0. + 0.0 * C\n vec3 x1 = x0 - i1 + 1.0 * C.xxx;\n vec3 x2 = x0 - i2 + 2.0 * C.xxx;\n vec3 x3 = x0 - 1. + 3.0 * C.xxx;\n\n // Permutations\n i = mod(i, 289.0 );\n vec4 p = permute( permute( permute(\n i.z + vec4(0.0, i1.z, i2.z, 1.0 ))\n + i.y + vec4(0.0, i1.y, i2.y, 1.0 ))\n + i.x + vec4(0.0, i1.x, i2.x, 1.0 ));\n\n // Gradients\n // ( N*N points uniformly over a square, mapped onto an octahedron.)\n float n_ = 1.0/7.0; // N=7\n vec3 ns = n_ * D.wyz - D.xzx;\n\n vec4 j = p - 49.0 * floor(p * ns.z *ns.z); // mod(p,N*N)\n\n vec4 x_ = floor(j * ns.z);\n vec4 y_ = floor(j - 7.0 * x_ ); // mod(j,N)\n\n vec4 x = x_ *ns.x + ns.yyyy;\n vec4 y = y_ *ns.x + ns.yyyy;\n vec4 h = 1.0 - abs(x) - abs(y);\n\n vec4 b0 = vec4( x.xy, y.xy );\n vec4 b1 = vec4( x.zw, y.zw );\n\n vec4 s0 = floor(b0)*2.0 + 1.0;\n vec4 s1 = floor(b1)*2.0 + 1.0;\n vec4 sh = -step(h, vec4(0.0));\n\n vec4 a0 = b0.xzyw + s0.xzyw*sh.xxyy ;\n vec4 a1 = b1.xzyw + s1.xzyw*sh.zzww ;\n\n vec3 p0 = vec3(a0.xy,h.x);\n vec3 p1 = vec3(a0.zw,h.y);\n vec3 p2 = vec3(a1.xy,h.z);\n vec3 p3 = vec3(a1.zw,h.w);\n\n //Normalise gradients\n vec4 norm = taylorInvSqrt(vec4(dot(p0,p0), dot(p1,p1), dot(p2, p2), dot(p3,p3)));\n p0 *= norm.x;\n p1 *= norm.y;\n p2 *= norm.z;\n p3 *= norm.w;\n\n // Mix final noise value\n vec4 m = max(0.6 - vec4(dot(x0,x0), dot(x1,x1), dot(x2,x2), dot(x3,x3)), 0.0);\n m = m * m;\n return 42.0 * dot( m*m, vec4( dot(p0,x0), dot(p1,x1),\n dot(p2,x2), dot(p3,x3) ) );\n }\n `\n },\n\n\n _rgbToHsv: {\n type: 'util',\n glsl: `vec3 _rgbToHsv(vec3 c){\n vec4 K = vec4(0.0, -1.0 / 3.0, 2.0 / 3.0, -1.0);\n vec4 p = mix(vec4(c.bg, K.wz), vec4(c.gb, K.xy), step(c.b, c.g));\n vec4 q = mix(vec4(p.xyw, c.r), vec4(c.r, p.yzx), step(p.x, c.r));\n\n float d = q.x - min(q.w, q.y);\n float e = 1.0e-10;\n return vec3(abs(q.z + (q.w - q.y) / (6.0 * d + e)), d / (q.x + e), q.x);\n }`\n },\n _hsvToRgb: {\n type: 'util',\n glsl: `vec3 _hsvToRgb(vec3 c){\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n }`\n }\n}\n", "import generateGlsl from './generate-glsl.js'\n// const formatArguments = require('./glsl-utils.js').formatArguments\n\n// const glslTransforms = require('./glsl/composable-glsl-functions.js')\nimport utilityGlsl from './glsl/utility-functions.js'\n\nvar GlslSource = function (obj) {\n this.transforms = []\n this.transforms.push(obj)\n this.defaultOutput = obj.defaultOutput\n this.synth = obj.synth\n this.type = 'GlslSource'\n this.defaultUniforms = obj.defaultUniforms\n return this\n}\n\nGlslSource.prototype.addTransform = function (obj) {\n this.transforms.push(obj)\n}\n\nGlslSource.prototype.out = function (_output) {\n var output = _output || this.defaultOutput\n var glsl = this.glsl(output)\n this.synth.currentFunctions = []\n // output.renderPasses(glsl)\n if(output) try{\n output.render(glsl)\n } catch (error) {\n console.log('shader could not compile', error)\n }\n}\n\nGlslSource.prototype.glsl = function () {\n //var output = _output || this.defaultOutput\n var self = this\n // uniforms included in all shaders\n// this.defaultUniforms = output.uniforms\n var passes = []\n var transforms = []\n// console.log('output', output)\n this.transforms.forEach((transform) => {\n if(transform.transform.type === 'renderpass'){\n // if (transforms.length > 0) passes.push(this.compile(transforms, output))\n // transforms = []\n // var uniforms = {}\n // const inputs = formatArguments(transform, -1)\n // inputs.forEach((uniform) => { uniforms[uniform.name] = uniform.value })\n //\n // passes.push({\n // frag: transform.transform.frag,\n // uniforms: Object.assign({}, self.defaultUniforms, uniforms)\n // })\n // transforms.push({name: 'prev', transform: glslTransforms['prev'], synth: this.synth})\n console.warn('no support for renderpass')\n } else {\n transforms.push(transform)\n }\n })\n\n if (transforms.length > 0) passes.push(this.compile(transforms))\n\n return passes\n}\n\nGlslSource.prototype.compile = function (transforms) {\n var shaderInfo = generateGlsl(transforms, this.synth)\n var uniforms = {}\n shaderInfo.uniforms.forEach((uniform) => { uniforms[uniform.name] = uniform.value })\n\n var frag = `\n precision ${this.defaultOutput.precision} float;\n ${Object.values(shaderInfo.uniforms).map((uniform) => {\n let type = uniform.type\n switch (uniform.type) {\n case 'texture':\n type = 'sampler2D'\n break\n }\n return `\n uniform ${type} ${uniform.name};`\n }).join('')}\n uniform float time;\n uniform vec2 resolution;\n varying vec2 uv;\n uniform sampler2D prevBuffer;\n\n ${Object.values(utilityGlsl).map((transform) => {\n // console.log(transform.glsl)\n return `\n ${transform.glsl}\n `\n }).join('')}\n\n ${shaderInfo.glslFunctions.map((transform) => {\n return `\n ${transform.transform.glsl}\n `\n }).join('')}\n\n void main () {\n vec4 c = vec4(1, 0, 0, 1);\n vec2 st = gl_FragCoord.xy/resolution.xy;\n gl_FragColor = ${shaderInfo.fragColor};\n }\n `\n\n return {\n frag: frag,\n uniforms: Object.assign({}, this.defaultUniforms, uniforms)\n }\n\n}\n\nexport default GlslSource\n", "/*\nFormat for adding functions to hydra. For each entry in this file, hydra automatically generates a glsl function and javascript function with the same name. You can also ass functions dynamically using setFunction(object).\n\n{\n name: 'osc', // name that will be used to access function in js as well as in glsl\n type: 'src', // can be 'src', 'color', 'combine', 'combineCoords'. see below for more info\n inputs: [\n {\n name: 'freq',\n type: 'float',\n default: 0.2\n },\n {\n name: 'sync',\n type: 'float',\n default: 0.1\n },\n {\n name: 'offset',\n type: 'float',\n default: 0.0\n }\n ],\n glsl: `\n vec2 st = _st;\n float r = sin((st.x-offset*2/freq+time*sync)*freq)*0.5 + 0.5;\n float g = sin((st.x+time*sync)*freq)*0.5 + 0.5;\n float b = sin((st.x+offset/freq+time*sync)*freq)*0.5 + 0.5;\n return vec4(r, g, b, 1.0);\n `\n}\n\n// The above code generates the glsl function:\n`vec4 osc(vec2 _st, float freq, float sync, float offset){\n vec2 st = _st;\n float r = sin((st.x-offset*2/freq+time*sync)*freq)*0.5 + 0.5;\n float g = sin((st.x+time*sync)*freq)*0.5 + 0.5;\n float b = sin((st.x+offset/freq+time*sync)*freq)*0.5 + 0.5;\n return vec4(r, g, b, 1.0);\n}`\n\n\nTypes and default arguments for hydra functions.\nThe value in the 'type' field lets the parser know which type the function will be returned as well as default arguments.\n\nconst types = {\n 'src': {\n returnType: 'vec4',\n args: ['vec2 _st']\n },\n 'coord': {\n returnType: 'vec2',\n args: ['vec2 _st']\n },\n 'color': {\n returnType: 'vec4',\n args: ['vec4 _c0']\n },\n 'combine': {\n returnType: 'vec4',\n args: ['vec4 _c0', 'vec4 _c1']\n },\n 'combineCoord': {\n returnType: 'vec2',\n args: ['vec2 _st', 'vec4 _c0']\n }\n}\n\n*/\n\nexport default () => [\n {\n name: 'noise',\n type: 'src',\n inputs: [\n {\n type: 'float',\n name: 'scale',\n default: 10,\n },\n{\n type: 'float',\n name: 'offset',\n default: 0.1,\n }\n ],\n glsl:\n` return vec4(vec3(_noise(vec3(_st*scale, offset*time))), 1.0);`\n},\n{\n name: 'voronoi',\n type: 'src',\n inputs: [\n {\n type: 'float',\n name: 'scale',\n default: 5,\n },\n{\n type: 'float',\n name: 'speed',\n default: 0.3,\n },\n{\n type: 'float',\n name: 'blending',\n default: 0.3,\n }\n ],\n glsl:\n` vec3 color = vec3(.0);\n // Scale\n _st *= scale;\n // Tile the space\n vec2 i_st = floor(_st);\n vec2 f_st = fract(_st);\n float m_dist = 10.; // minimun distance\n vec2 m_point; // minimum point\n for (int j=-1; j<=1; j++ ) {\n for (int i=-1; i<=1; i++ ) {\n vec2 neighbor = vec2(float(i),float(j));\n vec2 p = i_st + neighbor;\n vec2 point = fract(sin(vec2(dot(p,vec2(127.1,311.7)),dot(p,vec2(269.5,183.3))))*43758.5453);\n point = 0.5 + 0.5*sin(time*speed + 6.2831*point);\n vec2 diff = neighbor + point - f_st;\n float dist = length(diff);\n if( dist < m_dist ) {\n m_dist = dist;\n m_point = point;\n }\n }\n }\n // Assign a color using the closest point position\n color += dot(m_point,vec2(.3,.6));\n color *= 1.0 - blending*m_dist;\n return vec4(color, 1.0);`\n},\n{\n name: 'osc',\n type: 'src',\n inputs: [\n {\n type: 'float',\n name: 'frequency',\n default: 60,\n },\n{\n type: 'float',\n name: 'sync',\n default: 0.1,\n },\n{\n type: 'float',\n name: 'offset',\n default: 0,\n }\n ],\n glsl:\n` vec2 st = _st;\n float r = sin((st.x-offset/frequency+time*sync)*frequency)*0.5 + 0.5;\n float g = sin((st.x+time*sync)*frequency)*0.5 + 0.5;\n float b = sin((st.x+offset/frequency+time*sync)*frequency)*0.5 + 0.5;\n return vec4(r, g, b, 1.0);`\n},\n{\n name: 'shape',\n type: 'src',\n inputs: [\n {\n type: 'float',\n name: 'sides',\n default: 3,\n },\n{\n type: 'float',\n name: 'radius',\n default: 0.3,\n },\n{\n type: 'float',\n name: 'smoothing',\n default: 0.01,\n }\n ],\n glsl:\n` vec2 st = _st * 2. - 1.;\n // Angle and radius from the current pixel\n float a = atan(st.x,st.y)+3.1416;\n float r = (2.*3.1416)/sides;\n float d = cos(floor(.5+a/r)*r-a)*length(st);\n return vec4(vec3(1.0-smoothstep(radius,radius + smoothing + 0.0000001,d)), 1.0);`\n},\n{\n name: 'gradient',\n type: 'src',\n inputs: [\n {\n type: 'float',\n name: 'speed',\n default: 0,\n }\n ],\n glsl:\n` return vec4(_st, sin(time*speed), 1.0);`\n},\n{\n name: 'src',\n type: 'src',\n inputs: [\n {\n type: 'sampler2D',\n name: 'tex',\n default: NaN,\n }\n ],\n glsl:\n` // vec2 uv = gl_FragCoord.xy/vec2(1280., 720.);\n return texture2D(tex, fract(_st));`\n},\n{\n name: 'solid',\n type: 'src',\n inputs: [\n {\n type: 'float',\n name: 'r',\n default: 0,\n },\n{\n type: 'float',\n name: 'g',\n default: 0,\n },\n{\n type: 'float',\n name: 'b',\n default: 0,\n },\n{\n type: 'float',\n name: 'a',\n default: 1,\n }\n ],\n glsl:\n` return vec4(r, g, b, a);`\n},\n{\n name: 'rotate',\n type: 'coord',\n inputs: [\n {\n type: 'float',\n name: 'angle',\n default: 10,\n },\n{\n type: 'float',\n name: 'speed',\n default: 0,\n }\n ],\n glsl:\n` vec2 xy = _st - vec2(0.5);\n float ang = angle + speed *time;\n xy = mat2(cos(ang),-sin(ang), sin(ang),cos(ang))*xy;\n xy += 0.5;\n return xy;`\n},\n{\n name: 'scale',\n type: 'coord',\n inputs: [\n {\n type: 'float',\n name: 'amount',\n default: 1.5,\n },\n{\n type: 'float',\n name: 'xMult',\n default: 1,\n },\n{\n type: 'float',\n name: 'yMult',\n default: 1,\n },\n{\n type: 'float',\n name: 'offsetX',\n default: 0.5,\n },\n{\n type: 'float',\n name: 'offsetY',\n default: 0.5,\n }\n ],\n glsl:\n` vec2 xy = _st - vec2(offsetX, offsetY);\n xy*=(1.0/vec2(amount*xMult, amount*yMult));\n xy+=vec2(offsetX, offsetY);\n return xy;\n `\n},\n{\n name: 'pixelate',\n type: 'coord',\n inputs: [\n {\n type: 'float',\n name: 'pixelX',\n default: 20,\n },\n{\n type: 'float',\n name: 'pixelY',\n default: 20,\n }\n ],\n glsl:\n` vec2 xy = vec2(pixelX, pixelY);\n return (floor(_st * xy) + 0.5)/xy;`\n},\n{\n name: 'posterize',\n type: 'color',\n inputs: [\n {\n type: 'float',\n name: 'bins',\n default: 3,\n },\n{\n type: 'float',\n name: 'gamma',\n default: 0.6,\n }\n ],\n glsl:\n` vec4 c2 = pow(_c0, vec4(gamma));\n c2 *= vec4(bins);\n c2 = floor(c2);\n c2/= vec4(bins);\n c2 = pow(c2, vec4(1.0/gamma));\n return vec4(c2.xyz, _c0.a);`\n},\n{\n name: 'shift',\n type: 'color',\n inputs: [\n {\n type: 'float',\n name: 'r',\n default: 0.5,\n },\n{\n type: 'float',\n name: 'g',\n default: 0,\n },\n{\n type: 'float',\n name: 'b',\n default: 0,\n },\n{\n type: 'float',\n name: 'a',\n default: 0,\n }\n ],\n glsl:\n` vec4 c2 = vec4(_c0);\n c2.r = fract(c2.r + r);\n c2.g = fract(c2.g + g);\n c2.b = fract(c2.b + b);\n c2.a = fract(c2.a + a);\n return vec4(c2.rgba);`\n},\n{\n name: 'repeat',\n type: 'coord',\n inputs: [\n {\n type: 'float',\n name: 'repeatX',\n default: 3,\n },\n{\n type: 'float',\n name: 'repeatY',\n default: 3,\n },\n{\n type: 'float',\n name: 'offsetX',\n default: 0,\n },\n{\n type: 'float',\n name: 'offsetY',\n default: 0,\n }\n ],\n glsl:\n` vec2 st = _st * vec2(repeatX, repeatY);\n st.x += step(1., mod(st.y,2.0)) * offsetX;\n st.y += step(1., mod(st.x,2.0)) * offsetY;\n return fract(st);`\n},\n{\n name: 'modulateRepeat',\n type: 'combineCoord',\n inputs: [\n {\n type: 'float',\n name: 'repeatX',\n default: 3,\n },\n{\n type: 'float',\n name: 'repeatY',\n default: 3,\n },\n{\n type: 'float',\n name: 'offsetX',\n default: 0.5,\n },\n{\n type: 'float',\n name: 'offsetY',\n default: 0.5,\n }\n ],\n glsl:\n` vec2 st = _st * vec2(repeatX, repeatY);\n st.x += step(1., mod(st.y,2.0)) + _c0.r * offsetX;\n st.y += step(1., mod(st.x,2.0)) + _c0.g * offsetY;\n return fract(st);`\n},\n{\n name: 'repeatX',\n type: 'coord',\n inputs: [\n {\n type: 'float',\n name: 'reps',\n default: 3,\n },\n{\n type: 'float',\n name: 'offset',\n default: 0,\n }\n ],\n glsl:\n` vec2 st = _st * vec2(reps, 1.0);\n // float f = mod(_st.y,2.0);\n st.y += step(1., mod(st.x,2.0))* offset;\n return fract(st);`\n},\n{\n name: 'modulateRepeatX',\n type: 'combineCoord',\n inputs: [\n {\n type: 'float',\n name: 'reps',\n default: 3,\n },\n{\n type: 'float',\n name: 'offset',\n default: 0.5,\n }\n ],\n glsl:\n` vec2 st = _st * vec2(reps, 1.0);\n // float f = mod(_st.y,2.0);\n st.y += step(1., mod(st.x,2.0)) + _c0.r * offset;\n return fract(st);`\n},\n{\n name: 'repeatY',\n type: 'coord',\n inputs: [\n {\n type: 'float',\n name: 'reps',\n default: 3,\n },\n{\n type: 'float',\n name: 'offset',\n default: 0,\n }\n ],\n glsl:\n` vec2 st = _st * vec2(1.0, reps);\n // float f = mod(_st.y,2.0);\n st.x += step(1., mod(st.y,2.0))* offset;\n return fract(st);`\n},\n{\n name: 'modulateRepeatY',\n type: 'combineCoord',\n inputs: [\n {\n type: 'float',\n name: 'reps',\n default: 3,\n },\n{\n type: 'float',\n name: 'offset',\n default: 0.5,\n }\n ],\n glsl:\n` vec2 st = _st * vec2(reps, 1.0);\n // float f = mod(_st.y,2.0);\n st.x += step(1., mod(st.y,2.0)) + _c0.r * offset;\n return fract(st);`\n},\n{\n name: 'kaleid',\n type: 'coord',\n inputs: [\n {\n type: 'float',\n name: 'nSides',\n default: 4,\n }\n ],\n glsl:\n` vec2 st = _st;\n st -= 0.5;\n float r = length(st);\n float a = atan(st.y, st.x);\n float pi = 2.*3.1416;\n a = mod(a,pi/nSides);\n a = abs(a-pi/nSides/2.);\n return r*vec2(cos(a), sin(a));`\n},\n{\n name: 'modulateKaleid',\n type: 'combineCoord',\n inputs: [\n {\n type: 'float',\n name: 'nSides',\n default: 4,\n }\n ],\n glsl:\n` vec2 st = _st - 0.5;\n float r = length(st);\n float a = atan(st.y, st.x);\n float pi = 2.*3.1416;\n a = mod(a,pi/nSides);\n a = abs(a-pi/nSides/2.);\n return (_c0.r+r)*vec2(cos(a), sin(a));`\n},\n{\n name: 'scroll',\n type: 'coord',\n inputs: [\n {\n type: 'float',\n name: 'scrollX',\n default: 0.5,\n },\n{\n type: 'float',\n name: 'scrollY',\n default: 0.5,\n },\n{\n type: 'float',\n name: 'speedX',\n default: 0,\n },\n{\n type: 'float',\n name: 'speedY',\n default: 0,\n }\n ],\n glsl:\n`\n _st.x += scrollX + time*speedX;\n _st.y += scrollY + time*speedY;\n return fract(_st);`\n},\n{\n name: 'scrollX',\n type: 'coord',\n inputs: [\n {\n type: 'float',\n name: 'scrollX',\n default: 0.5,\n },\n{\n type: 'float',\n name: 'speed',\n default: 0,\n }\n ],\n glsl:\n` _st.x += scrollX + time*speed;\n return fract(_st);`\n},\n{\n name: 'modulateScrollX',\n type: 'combineCoord',\n inputs: [\n {\n type: 'float',\n name: 'scrollX',\n default: 0.5,\n },\n{\n type: 'float',\n name: 'speed',\n default: 0,\n }\n ],\n glsl:\n` _st.x += _c0.r*scrollX + time*speed;\n return fract(_st);`\n},\n{\n name: 'scrollY',\n type: 'coord',\n inputs: [\n {\n type: 'float',\n name: 'scrollY',\n default: 0.5,\n },\n{\n type: 'float',\n name: 'speed',\n default: 0,\n }\n ],\n glsl:\n` _st.y += scrollY + time*speed;\n return fract(_st);`\n},\n{\n name: 'modulateScrollY',\n type: 'combineCoord',\n inputs: [\n {\n type: 'float',\n name: 'scrollY',\n default: 0.5,\n },\n{\n type: 'float',\n name: 'speed',\n default: 0,\n }\n ],\n glsl:\n` _st.y += _c0.r*scrollY + time*speed;\n return fract(_st);`\n},\n{\n name: 'add',\n type: 'combine',\n inputs: [\n {\n type: 'float',\n name: 'amount',\n default: 1,\n }\n ],\n glsl:\n` return (_c0+_c1)*amount + _c0*(1.0-amount);`\n},\n{\n name: 'sub',\n type: 'combine',\n inputs: [\n {\n type: 'float',\n name: 'amount',\n default: 1,\n }\n ],\n glsl:\n` return (_c0-_c1)*amount + _c0*(1.0-amount);`\n},\n{\n name: 'layer',\n type: 'combine',\n inputs: [\n\n ],\n glsl:\n` return vec4(mix(_c0.rgb, _c1.rgb, _c1.a), clamp(_c0.a + _c1.a, 0.0, 1.0));`\n},\n{\n name: 'blend',\n type: 'combine',\n inputs: [\n {\n type: 'float',\n name: 'amount',\n default: 0.5,\n }\n ],\n glsl:\n` return _c0*(1.0-amount)+_c1*amount;`\n},\n{\n name: 'mult',\n type: 'combine',\n inputs: [\n {\n type: 'float',\n name: 'amount',\n default: 1,\n }\n ],\n glsl:\n` return _c0*(1.0-amount)+(_c0*_c1)*amount;`\n},\n{\n name: 'diff',\n type: 'combine',\n inputs: [\n\n ],\n glsl:\n` return vec4(abs(_c0.rgb-_c1.rgb), max(_c0.a, _c1.a));`\n},\n{\n name: 'modulate',\n type: 'combineCoord',\n inputs: [\n {\n type: 'float',\n name: 'amount',\n default: 0.1,\n }\n ],\n glsl:\n` // return fract(st+(_c0.xy-0.5)*amount);\n return _st + _c0.xy*amount;`\n},\n{\n name: 'modulateScale',\n type: 'combineCoord',\n inputs: [\n {\n type: 'float',\n name: 'multiple',\n default: 1,\n },\n{\n type: 'float',\n name: 'offset',\n default: 1,\n }\n ],\n glsl:\n` vec2 xy = _st - vec2(0.5);\n xy*=(1.0/vec2(offset + multiple*_c0.r, offset + multiple*_c0.g));\n xy+=vec2(0.5);\n return xy;`\n},\n{\n name: 'modulatePixelate',\n type: 'combineCoord',\n inputs: [\n {\n type: 'float',\n name: 'multiple',\n default: 10,\n },\n{\n type: 'float',\n name: 'offset',\n default: 3,\n }\n ],\n glsl:\n` vec2 xy = vec2(offset + _c0.x*multiple, offset + _c0.y*multiple);\n return (floor(_st * xy) + 0.5)/xy;`\n},\n{\n name: 'modulateRotate',\n type: 'combineCoord',\n inputs: [\n {\n type: 'float',\n name: 'multiple',\n default: 1,\n },\n{\n type: 'float',\n name: 'offset',\n default: 0,\n }\n ],\n glsl:\n` vec2 xy = _st - vec2(0.5);\n float angle = offset + _c0.x * multiple;\n xy = mat2(cos(angle),-sin(angle), sin(angle),cos(angle))*xy;\n xy += 0.5;\n return xy;`\n},\n{\n name: 'modulateHue',\n type: 'combineCoord',\n inputs: [\n {\n type: 'float',\n name: 'amount',\n default: 1,\n }\n ],\n glsl:\n` return _st + (vec2(_c0.g - _c0.r, _c0.b - _c0.g) * amount * 1.0/resolution);`\n},\n{\n name: 'invert',\n type: 'color',\n inputs: [\n {\n type: 'float',\n name: 'amount',\n default: 1,\n }\n ],\n glsl:\n` return vec4((1.0-_c0.rgb)*amount + _c0.rgb*(1.0-amount), _c0.a);`\n},\n{\n name: 'contrast',\n type: 'color',\n inputs: [\n {\n type: 'float',\n name: 'amount',\n default: 1.6,\n }\n ],\n glsl:\n` vec4 c = (_c0-vec4(0.5))*vec4(amount) + vec4(0.5);\n return vec4(c.rgb, _c0.a);`\n},\n{\n name: 'brightness',\n type: 'color',\n inputs: [\n {\n type: 'float',\n name: 'amount',\n default: 0.4,\n }\n ],\n glsl:\n` return vec4(_c0.rgb + vec3(amount), _c0.a);`\n},\n{\n name: 'mask',\n type: 'combine',\n inputs: [\n\n ],\n glsl:\n ` float a = _luminance(_c1.rgb);\n return vec4(_c0.rgb*a, a*_c0.a);`\n},\n\n{\n name: 'luma',\n type: 'color',\n inputs: [\n {\n type: 'float',\n name: 'threshold',\n default: 0.5,\n },\n{\n type: 'float',\n name: 'tolerance',\n default: 0.1,\n }\n ],\n glsl:\n` float a = smoothstep(threshold-(tolerance+0.0000001), threshold+(tolerance+0.0000001), _luminance(_c0.rgb));\n return vec4(_c0.rgb*a, a);`\n},\n{\n name: 'thresh',\n type: 'color',\n inputs: [\n {\n type: 'float',\n name: 'threshold',\n default: 0.5,\n },\n{\n type: 'float',\n name: 'tolerance',\n default: 0.04,\n }\n ],\n glsl:\n` return vec4(vec3(smoothstep(threshold-(tolerance+0.0000001), threshold+(tolerance+0.0000001), _luminance(_c0.rgb))), _c0.a);`\n},\n{\n name: 'color',\n type: 'color',\n inputs: [\n {\n type: 'float',\n name: 'r',\n default: 1,\n },\n{\n type: 'float',\n name: 'g',\n default: 1,\n },\n{\n type: 'float',\n name: 'b',\n default: 1,\n },\n{\n type: 'float',\n name: 'a',\n default: 1,\n }\n ],\n glsl:\n` vec4 c = vec4(r, g, b, a);\n vec4 pos = step(0.0, c); // detect whether negative\n // if > 0, return r * _c0\n // if < 0 return (1.0-r) * _c0\n return vec4(mix((1.0-_c0)*abs(c), c*_c0, pos));`\n},\n{\n name: 'saturate',\n type: 'color',\n inputs: [\n {\n type: 'float',\n name: 'amount',\n default: 2,\n }\n ],\n glsl:\n` const vec3 W = vec3(0.2125, 0.7154, 0.0721);\n vec3 intensity = vec3(dot(_c0.rgb, W));\n return vec4(mix(intensity, _c0.rgb, amount), _c0.a);`\n},\n{\n name: 'hue',\n type: 'color',\n inputs: [\n {\n type: 'float',\n name: 'hue',\n default: 0.4,\n }\n ],\n glsl:\n` vec3 c = _rgbToHsv(_c0.rgb);\n c.r += hue;\n // c.r = fract(c.r);\n return vec4(_hsvToRgb(c), _c0.a);`\n},\n{\n name: 'colorama',\n type: 'color',\n inputs: [\n {\n type: 'float',\n name: 'amount',\n default: 0.005,\n }\n ],\n glsl:\n` vec3 c = _rgbToHsv(_c0.rgb);\n c += vec3(amount);\n c = _hsvToRgb(c);\n c = fract(c);\n return vec4(c, _c0.a);`\n},\n{\n name: 'prev',\n type: 'src',\n inputs: [\n\n ],\n glsl:\n` return texture2D(prevBuffer, fract(_st));`\n},\n{\n name: 'sum',\n type: 'color',\n inputs: [\n {\n type: 'vec4',\n name: 'scale',\n default: 1,\n }\n ],\n glsl:\n` vec4 v = _c0 * s;\n return v.r + v.g + v.b + v.a;\n }\n float sum(vec2 _st, vec4 s) { // vec4 is not a typo, because argument type is not overloaded\n vec2 v = _st.xy * s.xy;\n return v.x + v.y;`\n},\n{\n name: 'r',\n type: 'color',\n inputs: [\n {\n type: 'float',\n name: 'scale',\n default: 1,\n },\n{\n type: 'float',\n name: 'offset',\n default: 0,\n }\n ],\n glsl:\n` return vec4(_c0.r * scale + offset);`\n},\n{\n name: 'g',\n type: 'color',\n inputs: [\n {\n type: 'float',\n name: 'scale',\n default: 1,\n },\n{\n type: 'float',\n name: 'offset',\n default: 0,\n }\n ],\n glsl:\n` return vec4(_c0.g * scale + offset);`\n},\n{\n name: 'b',\n type: 'color',\n inputs: [\n {\n type: 'float',\n name: 'scale',\n default: 1,\n },\n{\n type: 'float',\n name: 'offset',\n default: 0,\n }\n ],\n glsl:\n` return vec4(_c0.b * scale + offset);`\n},\n{\n name: 'a',\n type: 'color',\n inputs: [\n {\n type: 'float',\n name: 'scale',\n default: 1,\n },\n{\n type: 'float',\n name: 'offset',\n default: 0,\n }\n ],\n glsl:\n` return vec4(_c0.a * scale + offset);`\n}\n]\n", "import GlslSource from './glsl-source.js'\nimport glslFunctions from './glsl/glsl-functions.js'\n\nclass GeneratorFactory {\n constructor ({\n defaultUniforms,\n defaultOutput,\n extendTransforms = [],\n changeListener = (() => {})\n } = {}\n ) {\n this.defaultOutput = defaultOutput\n this.defaultUniforms = defaultUniforms\n this.changeListener = changeListener\n this.extendTransforms = extendTransforms\n this.generators = {}\n this.init()\n }\n init () {\n const functions = glslFunctions()\n this.glslTransforms = {}\n this.generators = Object.entries(this.generators).reduce((prev, [method, transform]) => {\n this.changeListener({type: 'remove', synth: this, method})\n return prev\n }, {})\n\n this.sourceClass = (() => {\n return class extends GlslSource {\n }\n })()\n\n \n\n // add user definied transforms\n if (Array.isArray(this.extendTransforms)) {\n functions.concat(this.extendTransforms)\n } else if (typeof this.extendTransforms === 'object' && this.extendTransforms.type) {\n functions.push(this.extendTransforms)\n }\n\n return functions.map((transform) => this.setFunction(transform))\n }\n\n _addMethod (method, transform) {\n const self = this\n this.glslTransforms[method] = transform\n if (transform.type === 'src') {\n const func = (...args) => new this.sourceClass({\n name: method,\n transform: transform,\n userArgs: args,\n defaultOutput: this.defaultOutput,\n defaultUniforms: this.defaultUniforms,\n synth: self\n })\n this.generators[method] = func\n this.changeListener({type: 'add', synth: this, method})\n return func\n } else {\n this.sourceClass.prototype[method] = function (...args) {\n this.transforms.push({name: method, transform: transform, userArgs: args, synth: self})\n return this\n }\n }\n return undefined\n }\n\n setFunction(obj) {\n var processedGlsl = processGlsl(obj)\n if(processedGlsl) this._addMethod(obj.name, processedGlsl)\n }\n}\n\nconst typeLookup = {\n 'src': {\n returnType: 'vec4',\n args: ['vec2 _st']\n },\n 'coord': {\n returnType: 'vec2',\n args: ['vec2 _st']\n },\n 'color': {\n returnType: 'vec4',\n args: ['vec4 _c0']\n },\n 'combine': {\n returnType: 'vec4',\n args: ['vec4 _c0', 'vec4 _c1']\n },\n 'combineCoord': {\n returnType: 'vec2',\n args: ['vec2 _st', 'vec4 _c0']\n }\n}\n// expects glsl of format\n// {\n// name: 'osc', // name that will be used to access function as well as within glsl\n// type: 'src', // can be src: vec4(vec2 _st), coord: vec2(vec2 _st), color: vec4(vec4 _c0), combine: vec4(vec4 _c0, vec4 _c1), combineCoord: vec2(vec2 _st, vec4 _c0)\n// inputs: [\n// {\n// name: 'freq',\n// type: 'float', // 'float' //, 'texture', 'vec4'\n// default: 0.2\n// },\n// {\n// name: 'sync',\n// type: 'float',\n// default: 0.1\n// },\n// {\n// name: 'offset',\n// type: 'float',\n// default: 0.0\n// }\n// ],\n // glsl: `\n // vec2 st = _st;\n // float r = sin((st.x-offset*2/freq+time*sync)*freq)*0.5 + 0.5;\n // float g = sin((st.x+time*sync)*freq)*0.5 + 0.5;\n // float b = sin((st.x+offset/freq+time*sync)*freq)*0.5 + 0.5;\n // return vec4(r, g, b, 1.0);\n // `\n// }\n\n// // generates glsl function:\n// `vec4 osc(vec2 _st, float freq, float sync, float offset){\n// vec2 st = _st;\n// float r = sin((st.x-offset*2/freq+time*sync)*freq)*0.5 + 0.5;\n// float g = sin((st.x+time*sync)*freq)*0.5 + 0.5;\n// float b = sin((st.x+offset/freq+time*sync)*freq)*0.5 + 0.5;\n// return vec4(r, g, b, 1.0);\n// }`\n\nfunction processGlsl(obj) {\n let t = typeLookup[obj.type]\n if(t) {\n let baseArgs = t.args.map((arg) => arg).join(\", \")\n // @todo: make sure this works for all input types, add validation\n let customArgs = obj.inputs.map((input) => `${input.type} ${input.name}`).join(', ')\n let args = `${baseArgs}${customArgs.length > 0 ? ', '+ customArgs: ''}`\n// console.log('args are ', args)\n\n let glslFunction =\n`\n ${t.returnType} ${obj.name}(${args}) {\n ${obj.glsl}\n }\n`\n\n // add extra input to beginning for backward combatibility @todo update compiler so this is no longer necessary\n if(obj.type === 'combine' || obj.type === 'combineCoord') obj.inputs.unshift({\n name: 'color',\n type: 'vec4'\n })\n return Object.assign({}, obj, { glsl: glslFunction})\n } else {\n console.warn(`type ${obj.type} not recognized`, obj)\n }\n\n}\n\nexport default GeneratorFactory\n", "window.global ||= window;\nimport Hydra from \"hydra-synth\";\n\nif (document.getElementById(\"index-hydra\")) {\n const isReduced = !!(\n window.matchMedia(\"(prefers-reduced-motion: reduce)\") === true\n || window.matchMedia(\"(prefers-reduced-motion: reduce)\").matches === true\n );\n\n const toggle = document.getElementById(\"toggle-hydra\");\n\n // create a new hydra-synth instance\n window.hydra = new Hydra({\n canvas: document.getElementById(\"index-hydra\"),\n detectAudio: false,\n makeGlobal: false,\n }).synth;\n\n //Glitch River\n //Flor de Fuego\n //https://flordefuego.github.io/\n window.play = function() {\n window.hydra\n .voronoi(8, 1)\n .mult(\n window.hydra\n .osc(10, 0.1, () => Math.sin(window.hydra.time) * 3)\n .saturate(3)\n .kaleid(200)\n )\n .modulate(window.hydra.o0, 0.5)\n .add(window.hydra.o0, 0.8)\n .scrollY(-0.01)\n .scale(0.99)\n .modulate(window.hydra.voronoi(8, 1), 0.008)\n .luma(0.3)\n .out();\n\n const content = toggle.innerText;\n\n toggle.innerText = toggle.dataset.content;\n toggle.dataset.content = content;\n toggle.dataset.state = \"play\";\n }\n\n window.stop = function() {\n window.hydra.solid(0, 0, 0).out();\n\n const content = toggle.innerText;\n\n toggle.innerText = toggle.dataset.content;\n toggle.dataset.content = content;\n toggle.dataset.state = \"pause\";\n }\n\n isReduced ? window.stop() : window.play();\n\n toggle.addEventListener(\"click\", function(event) {\n event.preventDefault();\n\n toggle.dataset.state == \"play\" ? window.stop() : window.play();\n });\n}\n"], "mappings": "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CA,KACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,4BA0BA,EACA,CACE,KAAM,MACN,KAAM,MACN,OAAQ,CACN,CACE,KAAM,QACN,KAAM,YACN,QAAS,EACX,EACJ,CACM,KAAM,QACN,KAAM,OACN,QAAS,EACX,EACJ,CACM,KAAM,QACN,KAAM,SACN,QAAS,CACX,CACF,EACA,KACF;AAAA;AAAA;AAAA;AAAA,8BAKA,EACA,CACE,KAAM,QACN,KAAM,MACN,OAAQ,CACN,CACE,KAAM,QACN,KAAM,QACN,QAAS,CACX,EACJ,CACM,KAAM,QACN,KAAM,SACN,QAAS,EACX,EACJ,CACM,KAAM,QACN,KAAM,YACN,QAAS,GACX,CACF,EACA,KACF;AAAA;AAAA;AAAA;AAAA;AAAA,oFAMA,EACA,CACE,KAAM,WACN,KAAM,MACN,OAAQ,CACN,CACE,KAAM,QACN,KAAM,QACN,QAAS,CACX,CACF,EACA,KACF,4CACA,EACA,CACE,KAAM,MACN,KAAM,MACN,OAAQ,CACN,CACE,KAAM,YACN,KAAM,MACN,QAAS,GACX,CACF,EACA,KACF;AAAA,sCAEA,EACA,CACE,KAAM,QACN,KAAM,MACN,OAAQ,CACN,CACE,KAAM,QACN,KAAM,IACN,QAAS,CACX,EACJ,CACM,KAAM,QACN,KAAM,IACN,QAAS,CACX,EACJ,CACM,KAAM,QACN,KAAM,IACN,QAAS,CACX,EACJ,CACM,KAAM,QACN,KAAM,IACN,QAAS,CACX,CACF,EACA,KACF,6BACA,EACA,CACE,KAAM,SACN,KAAM,QACN,OAAQ,CACN,CACE,KAAM,QACN,KAAM,QACN,QAAS,EACX,EACJ,CACM,KAAM,QACN,KAAM,QACN,QAAS,CACX,CACF,EACA,KACF;AAAA;AAAA;AAAA;AAAA,cAKA,EACA,CACE,KAAM,QACN,KAAM,QACN,OAAQ,CACN,CACE,KAAM,QACN,KAAM,SACN,QAAS,GACX,EACJ,CACM,KAAM,QACN,KAAM,QACN,QAAS,CACX,EACJ,CACM,KAAM,QACN,KAAM,QACN,QAAS,CACX,EACJ,CACM,KAAM,QACN,KAAM,UACN,QAAS,EACX,EACJ,CACM,KAAM,QACN,KAAM,UACN,QAAS,EACX,CACF,EACA,KACF;AAAA;AAAA;AAAA;AAAA,IAKA,EACA,CACE,KAAM,WACN,KAAM,QACN,OAAQ,CACN,CACE,KAAM,QACN,KAAM,SACN,QAAS,EACX,EACJ,CACM,KAAM,QACN,KAAM,SACN,QAAS,EACX,CACF,EACA,KACF;AAAA,sCAEA,EACA,CACE,KAAM,YACN,KAAM,QACN,OAAQ,CACN,CACE,KAAM,QACN,KAAM,OACN,QAAS,CACX,EACJ,CACM,KAAM,QACN,KAAM,QACN,QAAS,EACX,CACF,EACA,KACF;AAAA;AAAA;AAAA;AAAA;AAAA,+BAMA,EACA,CACE,KAAM,QACN,KAAM,QACN,OAAQ,CACN,CACE,KAAM,QACN,KAAM,IACN,QAAS,EACX,EACJ,CACM,KAAM,QACN,KAAM,IACN,QAAS,CACX,EACJ,CACM,KAAM,QACN,KAAM,IACN,QAAS,CACX,EACJ,CACM,KAAM,QACN,KAAM,IACN,QAAS,CACX,CACF,EACA,KACF;AAAA;AAAA;AAAA;AAAA;AAAA,yBAMA,EACA,CACE,KAAM,SACN,KAAM,QACN,OAAQ,CACN,CACE,KAAM,QACN,KAAM,UACN,QAAS,CACX,EACJ,CACM,KAAM,QACN,KAAM,UACN,QAAS,CACX,EACJ,CACM,KAAM,QACN,KAAM,UACN,QAAS,CACX,EACJ,CACM,KAAM,QACN,KAAM,UACN,QAAS,CACX,CACF,EACA,KACF;AAAA;AAAA;AAAA,qBAIA,EACA,CACE,KAAM,iBACN,KAAM,eACN,OAAQ,CACN,CACE,KAAM,QACN,KAAM,UACN,QAAS,CACX,EACJ,CACM,KAAM,QACN,KAAM,UACN,QAAS,CACX,EACJ,CACM,KAAM,QACN,KAAM,UACN,QAAS,EACX,EACJ,CACM,KAAM,QACN,KAAM,UACN,QAAS,EACX,CACF,EACA,KACF;AAAA;AAAA;AAAA,qBAIA,EACA,CACE,KAAM,UACN,KAAM,QACN,OAAQ,CACN,CACE,KAAM,QACN,KAAM,OACN,QAAS,CACX,EACJ,CACM,KAAM,QACN,KAAM,SACN,QAAS,CACX,CACF,EACA,KACF;AAAA;AAAA;AAAA,qBAIA,EACA,CACE,KAAM,kBACN,KAAM,eACN,OAAQ,CACN,CACE,KAAM,QACN,KAAM,OACN,QAAS,CACX,EACJ,CACM,KAAM,QACN,KAAM,SACN,QAAS,EACX,CACF,EACA,KACF;AAAA;AAAA;AAAA,qBAIA,EACA,CACE,KAAM,UACN,KAAM,QACN,OAAQ,CACN,CACE,KAAM,QACN,KAAM,OACN,QAAS,CACX,EACJ,CACM,KAAM,QACN,KAAM,SACN,QAAS,CACX,CACF,EACA,KACF;AAAA;AAAA;AAAA,qBAIA,EACA,CACE,KAAM,kBACN,KAAM,eACN,OAAQ,CACN,CACE,KAAM,QACN,KAAM,OACN,QAAS,CACX,EACJ,CACM,KAAM,QACN,KAAM,SACN,QAAS,EACX,CACF,EACA,KACF;AAAA;AAAA;AAAA,qBAIA,EACA,CACE,KAAM,SACN,KAAM,QACN,OAAQ,CACN,CACE,KAAM,QACN,KAAM,SACN,QAAS,CACX,CACF,EACA,KACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,kCAQA,EACA,CACE,KAAM,iBACN,KAAM,eACN,OAAQ,CACN,CACE,KAAM,QACN,KAAM,SACN,QAAS,CACX,CACF,EACA,KACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,0CAOA,EACA,CACE,KAAM,SACN,KAAM,QACN,OAAQ,CACN,CACE,KAAM,QACN,KAAM,UACN,QAAS,EACX,EACJ,CACM,KAAM,QACN,KAAM,UACN,QAAS,EACX,EACJ,CACM,KAAM,QACN,KAAM,SACN,QAAS,CACX,EACJ,CACM,KAAM,QACN,KAAM,SACN,QAAS,CACX,CACF,EACA,KACF;AAAA;AAAA;AAAA,sBAIA,EACA,CACE,KAAM,UACN,KAAM,QACN,OAAQ,CACN,CACE,KAAM,QACN,KAAM,UACN,QAAS,EACX,EACJ,CACM,KAAM,QACN,KAAM,QACN,QAAS,CACX,CACF,EACA,KACF;AAAA,sBAEA,EACA,CACE,KAAM,kBACN,KAAM,eACN,OAAQ,CACN,CACE,KAAM,QACN,KAAM,UACN,QAAS,EACX,EACJ,CACM,KAAM,QACN,KAAM,QACN,QAAS,CACX,CACF,EACA,KACF;AAAA,sBAEA,EACA,CACE,KAAM,UACN,KAAM,QACN,OAAQ,CACN,CACE,KAAM,QACN,KAAM,UACN,QAAS,EACX,EACJ,CACM,KAAM,QACN,KAAM,QACN,QAAS,CACX,CACF,EACA,KACF;AAAA,sBAEA,EACA,CACE,KAAM,kBACN,KAAM,eACN,OAAQ,CACN,CACE,KAAM,QACN,KAAM,UACN,QAAS,EACX,EACJ,CACM,KAAM,QACN,KAAM,QACN,QAAS,CACX,CACF,EACA,KACF;AAAA,sBAEA,EACA,CACE,KAAM,MACN,KAAM,UACN,OAAQ,CACN,CACE,KAAM,QACN,KAAM,SACN,QAAS,CACX,CACF,EACA,KACF,gDACA,EACA,CACE,KAAM,MACN,KAAM,UACN,OAAQ,CACN,CACE,KAAM,QACN,KAAM,SACN,QAAS,CACX,CACF,EACA,KACF,gDACA,EACA,CACE,KAAM,QACN,KAAM,UACN,OAAQ,CAER,EACA,KACF,+EACA,EACA,CACE,KAAM,QACN,KAAM,UACN,OAAQ,CACN,CACE,KAAM,QACN,KAAM,SACN,QAAS,EACX,CACF,EACA,KACF,wCACA,EACA,CACE,KAAM,OACN,KAAM,UACN,OAAQ,CACN,CACE,KAAM,QACN,KAAM,SACN,QAAS,CACX,CACF,EACA,KACF,8CACA,EACA,CACE,KAAM,OACN,KAAM,UACN,OAAQ,CAER,EACA,KACF,0DACA,EACA,CACE,KAAM,WACN,KAAM,eACN,OAAQ,CACN,CACE,KAAM,QACN,KAAM,SACN,QAAS,EACX,CACF,EACA,KACF;AAAA,+BAEA,EACA,CACE,KAAM,gBACN,KAAM,eACN,OAAQ,CACN,CACE,KAAM,QACN,KAAM,WACN,QAAS,CACX,EACJ,CACM,KAAM,QACN,KAAM,SACN,QAAS,CACX,CACF,EACA,KACF;AAAA;AAAA;AAAA,cAIA,EACA,CACE,KAAM,mBACN,KAAM,eACN,OAAQ,CACN,CACE,KAAM,QACN,KAAM,WACN,QAAS,EACX,EACJ,CACM,KAAM,QACN,KAAM,SACN,QAAS,CACX,CACF,EACA,KACF;AAAA,sCAEA,EACA,CACE,KAAM,iBACN,KAAM,eACN,OAAQ,CACN,CACE,KAAM,QACN,KAAM,WACN,QAAS,CACX,EACJ,CACM,KAAM,QACN,KAAM,SACN,QAAS,CACX,CACF,EACA,KACF;AAAA;AAAA;AAAA;AAAA,cAKA,EACA,CACE,KAAM,cACN,KAAM,eACN,OAAQ,CACN,CACE,KAAM,QACN,KAAM,SACN,QAAS,CACX,CACF,EACA,KACF,iFACA,EACA,CACE,KAAM,SACN,KAAM,QACN,OAAQ,CACN,CACE,KAAM,QACN,KAAM,SACN,QAAS,CACX,CACF,EACA,KACF,qEACA,EACA,CACE,KAAM,WACN,KAAM,QACN,OAAQ,CACN,CACE,KAAM,QACN,KAAM,SACN,QAAS,GACX,CACF,EACA,KACF;AAAA,8BAEA,EACA,CACE,KAAM,aACN,KAAM,QACN,OAAQ,CACN,CACE,KAAM,QACN,KAAM,SACN,QAAS,EACX,CACF,EACA,KACF,gDACA,EACA,CACE,KAAM,OACN,KAAM,UACN,OAAQ,CAER,EACA,KACA;AAAA,mCAEF,EAEA,CACE,KAAM,OACN,KAAM,QACN,OAAQ,CACN,CACE,KAAM,QACN,KAAM,YACN,QAAS,EACX,EACJ,CACM,KAAM,QACN,KAAM,YACN,QAAS,EACX,CACF,EACA,KACF;AAAA,8BAEA,EACA,CACE,KAAM,SACN,KAAM,QACN,OAAQ,CACN,CACE,KAAM,QACN,KAAM,YACN,QAAS,EACX,EACJ,CACM,KAAM,QACN,KAAM,YACN,QAAS,GACX,CACF,EACA,KACF,iIACA,EACA,CACE,KAAM,QACN,KAAM,QACN,OAAQ,CACN,CACE,KAAM,QACN,KAAM,IACN,QAAS,CACX,EACJ,CACM,KAAM,QACN,KAAM,IACN,QAAS,CACX,EACJ,CACM,KAAM,QACN,KAAM,IACN,QAAS,CACX,EACJ,CACM,KAAM,QACN,KAAM,IACN,QAAS,CACX,CACF,EACA,KACF;AAAA;AAAA;AAAA;AAAA,mDAKA,EACA,CACE,KAAM,WACN,KAAM,QACN,OAAQ,CACN,CACE,KAAM,QACN,KAAM,SACN,QAAS,CACX,CACF,EACA,KACF;AAAA;AAAA,wDAGA,EACA,CACE,KAAM,MACN,KAAM,QACN,OAAQ,CACN,CACE,KAAM,QACN,KAAM,MACN,QAAS,EACX,CACF,EACA,KACF;AAAA;AAAA;AAAA,qCAIA,EACA,CACE,KAAM,WACN,KAAM,QACN,OAAQ,CACN,CACE,KAAM,QACN,KAAM,SACN,QAAS,IACX,CACF,EACA,KACF;AAAA;AAAA;AAAA;AAAA,0BAKA,EACA,CACE,KAAM,OACN,KAAM,MACN,OAAQ,CAER,EACA,KACF,8CACA,EACA,CACE,KAAM,MACN,KAAM,QACN,OAAQ,CACN,CACE,KAAM,OACN,KAAM,QACN,QAAS,CACX,CACF,EACA,KACF;AAAA;AAAA;AAAA;AAAA;AAAA,qBAMA,EACA,CACE,KAAM,IACN,KAAM,QACN,OAAQ,CACN,CACE,KAAM,QACN,KAAM,QACN,QAAS,CACX,EACJ,CACM,KAAM,QACN,KAAM,SACN,QAAS,CACX,CACF,EACA,KACF,yCACA,EACA,CACE,KAAM,IACN,KAAM,QACN,OAAQ,CACN,CACE,KAAM,QACN,KAAM,QACN,QAAS,CACX,EACJ,CACM,KAAM,QACN,KAAM,SACN,QAAS,CACX,CACF,EACA,KACF,yCACA,EACA,CACE,KAAM,IACN,KAAM,QACN,OAAQ,CACN,CACE,KAAM,QACN,KAAM,QACN,QAAS,CACX,EACJ,CACM,KAAM,QACN,KAAM,SACN,QAAS,CACX,CACF,EACA,KACF,yCACA,EACA,CACE,KAAM,IACN,KAAM,QACN,OAAQ,CACN,CACE,KAAM,QACN,KAAM,QACN,QAAS,CACX,EACJ,CACM,KAAM,QACN,KAAM,SACN,QAAS,CACX,CACF,EACA,KACF,yCACA,CACA,ECxkCA,IAAMC,GAAN,KAAuB,CACrB,YAAa,CACT,gBAAAC,EACA,cAAAC,EACA,iBAAAC,EAAmB,CAAC,EACp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", "names": ["require_inherits_browser", "__commonJSMin", "exports", "module", "ctor", "superCtor", "TempCtor", "require_events", "__commonJSMin", "exports", "module", "EventEmitter", "n", "isNumber", "type", "er", "handler", "len", "args", "i", "listeners", "isObject", "err", "isUndefined", "isFunction", "listener", "m", "fired", "g", "list", "position", "length", "key", "ret", "evlistener", "emitter", "arg", "require_browser", "__commonJSMin", "exports", "module", "getNanoSeconds", "hrtime", "loadTime", "moduleLoadTime", "nodeLoadTime", "upTime", "module", "hr", "require_raf", "__commonJSMin", "exports", "module", "now", "root", "vendors", "suffix", "raf", "caf", "i", "last", "id", "queue", "frameDuration", "callback", "_now", "next", "cp", "e", "handle", "fn", "object", "require_raf_loop", "__commonJSMin", "exports", "module", "inherits", "EventEmitter", "now", "raf", "Engine", "fn", "time", "dt", "require_dct", "__commonJSMin", "exports", "module", "cosMap", "memoizeCosines", "N", "PI_N", "k", "n", "dct", "signal", "scale", "L", "coefficients", "__", "ix", "prev", "cur", "ix_", "arr", "require_dct", "__commonJSMin", "exports", "module", "require_utils", "__commonJSMin", "exports", "module", "_toConsumableArray", "arr", "i", "arr2", "memoizedReversal", "memoizedZeroBuffers", "constructComplexArray", "signal", "complexSignal", "bufferSize", "bitReverseArray", "N", "maxBinaryLength", "templateBinary", "reversed", "n", "currBinary", "multiply", "a", "b", "add", "subtract", "euler", "kn", "x", "conj", "require_fft", "__commonJSMin", "exports", "module", "utils", "fft", "signal", "complexSignal", "N", "logN", "bitReversedIndices", "ordered", "i", "_i", "n", "currN", "k", "twiddle", "m", "currEvenIndex", "currOddIndex", "currEvenIndexSample", "currOddIndexSample", "odd", "subtractionResult", "additionResult", "ifft", "currentSample", "conjugateSample", "X", "val", "__spreadArray", "to", "from", "pack", "arguments", "length", "ar", "i", "l", "Array", "prototype", "slice", "call", "concat", "n", "size", "blackmanBuffer", "Float32Array", "coeff1", "Math", "PI", "coeff2", "cos", "ceil", "hammingBuffer", "hanningBuffer", "coeff", "sineBuffer", "sin", "windows", "isPowerOfTwo", "num", "applyWindow", "signal", "windowname", "windowing", "Error", "a", "b", "c", "min", "createBarkScale", "sampleRate", "bufferSize", "barkScale", "atan", "pow", "arrayToTyped", "t", "_freqToMel", "freqValue", "log", "createMelFilterBank", "numFilters", "melValue", "melValues", "melValuesInFreq", "upperLimitFreq", "lowerLimitMel", "valueToAdd", "fftBinsOfFreq", "exp", "floor", "filterBank", "j", "fill", "createChromaFilterBank", "centerOctave", "octaveWidth", "baseC", "A440", "numOutputBins", "frequencyBins", "map", "_", "freq", "log2", "emptyRow", "colDenominators", "binWidthBins", "v", "max", "halfNumFilters", "round", "filterPeaks", "frq", "weights", "row", "reduce", "acc", "forEach", "cell", "sqrt", "octaveWeights", "mu", "amplitudeSpect", "numerator", "denominator", "k", "abs", "loudness", "_a", "ampSpectrum", "_b", "numberOfBarkBands", "TypeError", "NUM_BARK_BANDS", "specific", "total", "normalisedSpectrum", "bbLimits", "Int32Array", "currentBandEnd", "currentBand", "sum", "extractPowerSpectrum", "powerSpectrum", "extractMelBands", "melFilterBank", "powSpec", "filtered", "loggedMelBands", "d", "args", "chromaFilterBank", "chromagram", "maxVal", "complexSpectrum", "energy", "m", "w", "numberOfMFCCCoefficients", "_numberOfMFCCCoefficients", "loggedMelBandsArray", "dct", "loudnessValue", "spec", "output", "rms", "peak", "Infinity", "x", "previousSignal", "sf", "ampspec", "mu1", "mu2", "mu3", "mu4", "nyqBin", "ec", "threshold", "ampSum", "freqSum", "freqs", "powFreqSum", "ampFreqSum", "curFreq", "zcr", "MeydaAnalyzer", "options", "_this", "_this_1", "this", "_m", "audioContext", "errors", "noAC", "utilities.isPowerOfTwo", "_errors", "notPow2", "source", "noSource", "hopSize", "callback", "windowingFunction", "featureExtractors", "EXTRACTION_STARTED", "startImmediately", "channel", "inputs", "outputs", "spn", "createScriptProcessor", "connect", "destination", "_featuresToExtract", "utilities.createBarkScale", "utilities.createMelFilterBank", "melBands", "inputData", "previousInputData", "frame", "previousFrame", "setSource", "onaudioprocess", "e", "buffer", "inputBuffer", "getChannelData", "set", "frames", "frameLength", "hopLength", "numFrames", "f", "features", "extract", "start", "stop", "disconnect", "setChannel", "console", "error", "get", "Meyda", "chromaBands", "extractors", "utilities.applyWindow", "featureUndef", "invalidFeatureFmt", "invalidInput", "createMeydaAnalyzer", "Object", "assign", "listAvailableFeatureExtractors", "keys", "feature", "utilities.createChromaFilterBank", "utilities.arrayToTyped", "preparedSignal", "prepareSignalWithSpectrum", "windowedSignal", "preparedSignal_1", "previousComplexSpectrum", "previousAmpSpectrum", "el", "fft", "real", "imag", "window", "require_regl", "__commonJSMin", "exports", "module", "global", "factory", "isTypedArray", "x", "extend", "base", "opts", "keys", "i", "endl", "decodeB64", "str", "raise", "message", "error", "check", "pred", "encolon", "checkParameter", "param", "possibilities", "checkIsTypedArray", "data", "standardTypeEh", "value", "type", "checkTypeOf", "checkNonNegativeInt", "checkOneOf", "list", "constructorKeys", "checkConstructor", "obj", "key", "leftPad", "n", "ShaderFile", "ShaderLine", "number", "line", "ShaderError", "fileNumber", "lineNumber", "guessCommand", "stack", "pat", "pat2", "guessCallSite", "parseSource", "source", "command", "lines", "files", "parts", "lineNumberInfo", "nameInfo", "file", "parseErrorLog", "errLog", "result", "errMsg", "annotateFiles", "errors", "checkShaderError", "gl", "shader", "typeName", "checkCommandType", "strings", "styles", "push", "style", "offset", "token", "tokenPat", "checkLinkError", "program", "fragShader", "vertShader", "fragParse", "vertParse", "header", "saveCommandRef", "object", "saveDrawCommandInfo", "uniforms", "attributes", "stringStore", "id", "addProps", "dict", "set", "u", "uniformSet", "attributeSet", "commandRaise", "callSite", "checkCommand", "checkParameterCommand", "checkOptional", "block", "checkFramebufferFormat", "attachment", "texFormats", "rbFormats", "GL_CLAMP_TO_EDGE", "GL_NEAREST", "GL_NEAREST_MIPMAP_NEAREST", "GL_LINEAR_MIPMAP_NEAREST", "GL_NEAREST_MIPMAP_LINEAR", "GL_LINEAR_MIPMAP_LINEAR", "GL_BYTE", "GL_UNSIGNED_BYTE", "GL_SHORT", "GL_UNSIGNED_SHORT", "GL_INT", "GL_UNSIGNED_INT", "GL_FLOAT", "GL_UNSIGNED_SHORT_4_4_4_4", "GL_UNSIGNED_SHORT_5_5_5_1", "GL_UNSIGNED_SHORT_5_6_5", "GL_UNSIGNED_INT_24_8_WEBGL", "GL_HALF_FLOAT_OES", "TYPE_SIZE", "pixelSize", "channels", "isPow2", "v", "checkTexture2D", "info", "mipData", "limits", "w", "h", "c", "mipimages", "mw", "mh", "img", "rowSize", "checkTextureCube", "texture", "faces", "face", "mipmaps", "j", "check$1", "VARIABLE_COUNTER", "DYN_FUNC", "DYN_CONSTANT", "DYN_ARRAY", "DynamicVariable", "escapeStr", "splitParts", "firstChar", "lastChar", "subparts", "toAccessorString", "defineDynamic", "isDynamic", "unbox", "path", "y", "dynamic", "raf", "cb", "clock", "createStringStore", "stringIds", "stringValues", "createCanvas", "element", "onDone", "pixelRatio", "canvas", "resize", "bounds", "resizeObserver", "onDestroy", "createContext", "contextAttributes", "get", "name", "isHTMLElement", "isWebGLContext", "parseExtensions", "input", "getElement", "desc", "parseArgs", "args_", "args", "container", "extensions", "optionalExtensions", "profile", "err", "createExtensionCache", "config", "tryLoadExtension", "name_", "ext", "loop", "f", "GL_BYTE$1", "GL_UNSIGNED_BYTE$2", "GL_SHORT$1", "GL_UNSIGNED_SHORT$1", "GL_INT$1", "GL_UNSIGNED_INT$1", "GL_FLOAT$2", "nextPow16", "log2", "r", "shift", "createPool", "bufferPool", "alloc", "sz", "bin", "free", "buf", "allocType", "freeType", "array", "pool", "GL_SUBPIXEL_BITS", "GL_RED_BITS", "GL_GREEN_BITS", "GL_BLUE_BITS", "GL_ALPHA_BITS", "GL_DEPTH_BITS", "GL_STENCIL_BITS", "GL_ALIASED_POINT_SIZE_RANGE", "GL_ALIASED_LINE_WIDTH_RANGE", "GL_MAX_TEXTURE_SIZE", "GL_MAX_VIEWPORT_DIMS", "GL_MAX_VERTEX_ATTRIBS", "GL_MAX_VERTEX_UNIFORM_VECTORS", "GL_MAX_VARYING_VECTORS", "GL_MAX_COMBINED_TEXTURE_IMAGE_UNITS", "GL_MAX_VERTEX_TEXTURE_IMAGE_UNITS", "GL_MAX_TEXTURE_IMAGE_UNITS", "GL_MAX_FRAGMENT_UNIFORM_VECTORS", "GL_MAX_CUBE_MAP_TEXTURE_SIZE", "GL_MAX_RENDERBUFFER_SIZE", "GL_VENDOR", "GL_RENDERER", "GL_VERSION", "GL_SHADING_LANGUAGE_VERSION", "GL_MAX_TEXTURE_MAX_ANISOTROPY_EXT", "GL_MAX_COLOR_ATTACHMENTS_WEBGL", "GL_MAX_DRAW_BUFFERS_WEBGL", "GL_TEXTURE_2D", "GL_TEXTURE_CUBE_MAP", "GL_TEXTURE_CUBE_MAP_POSITIVE_X", "GL_TEXTURE0", "GL_RGBA", "GL_FLOAT$1", "GL_UNSIGNED_BYTE$1", "GL_FRAMEBUFFER", "GL_FRAMEBUFFER_COMPLETE", "GL_COLOR_ATTACHMENT0", "GL_COLOR_BUFFER_BIT$1", "wrapLimits", "maxAnisotropic", "maxDrawbuffers", "maxColorAttachments", "readFloat", "readFloatTexture", "fbo", "pixels", "isIE", "npotTextureCube", "cubeTexture", "isNDArrayLike", "values", "flattenUtils", "arrayShape$1", "flattenArray", "flatten1D", "nx", "out", "flatten2D", "ny", "ptr", "row", "flatten3D", "nz", "ptr_", "col", "k", "flattenRec", "shape", "level", "stride", "out_", "array_", "arrayTypes", "int8", "int16", "int32", "uint8", "uint16", "uint32", "float", "float32", "glTypes", "dynamic$1", "stream", "usageTypes", "arrayFlatten", "arrayShape", "GL_STATIC_DRAW", "GL_STREAM_DRAW", "GL_UNSIGNED_BYTE$3", "GL_FLOAT$3", "DTYPES_SIZES", "typedArrayCode", "copyArray", "inp", "transpose", "shapeX", "shapeY", "strideX", "strideY", "wrapBufferState", "stats", "destroyBuffer", "bufferCount", "bufferSet", "REGLBuffer", "destroy", "streamPool", "createStream", "buffer", "initBufferFromData", "destroyStream", "stream$$1", "initBufferFromTypedArray", "usage", "dtype", "dimension", "persist", "flatData", "dim", "typedData", "transposeData", "handle", "createBuffer", "options", "deferInit", "persistent", "reglBuffer", "byteLength", "setSubData", "subdata", "offset_", "converted", "restoreBuffers", "total", "wrapper", "points", "point", "triangles", "triangle", "primTypes", "GL_POINTS", "GL_LINES", "GL_TRIANGLES", "GL_BYTE$2", "GL_UNSIGNED_BYTE$4", "GL_SHORT$2", "GL_UNSIGNED_SHORT$2", "GL_INT$2", "GL_UNSIGNED_INT$2", "GL_ELEMENT_ARRAY_BUFFER", "GL_STREAM_DRAW$1", "GL_STATIC_DRAW$1", "wrapElementsState", "bufferState", "elementSet", "elementCount", "elementTypes", "REGLElementBuffer", "createElementStream", "initElements", "destroyElementStream", "elements", "prim", "count", "predictedType", "vertCount", "primType", "destroyElements", "createElements", "reglElements", "FLOAT", "INT", "GL_UNSIGNED_SHORT$4", "convertToHalfFloat", "ushorts", "sgn", "exp", "frac", "s", "isArrayLike", "isPow2$1", "GL_COMPRESSED_TEXTURE_FORMATS", "GL_TEXTURE_2D$1", "GL_TEXTURE_CUBE_MAP$1", "GL_TEXTURE_CUBE_MAP_POSITIVE_X$1", "GL_RGBA$1", "GL_ALPHA", "GL_RGB", "GL_LUMINANCE", "GL_LUMINANCE_ALPHA", "GL_RGBA4", "GL_RGB5_A1", "GL_RGB565", "GL_UNSIGNED_SHORT_4_4_4_4$1", "GL_UNSIGNED_SHORT_5_5_5_1$1", "GL_UNSIGNED_SHORT_5_6_5$1", "GL_UNSIGNED_INT_24_8_WEBGL$1", "GL_DEPTH_COMPONENT", "GL_DEPTH_STENCIL", "GL_SRGB_EXT", "GL_SRGB_ALPHA_EXT", "GL_HALF_FLOAT_OES$1", "GL_COMPRESSED_RGB_S3TC_DXT1_EXT", "GL_COMPRESSED_RGBA_S3TC_DXT1_EXT", "GL_COMPRESSED_RGBA_S3TC_DXT3_EXT", "GL_COMPRESSED_RGBA_S3TC_DXT5_EXT", "GL_COMPRESSED_RGB_ATC_WEBGL", "GL_COMPRESSED_RGBA_ATC_EXPLICIT_ALPHA_WEBGL", "GL_COMPRESSED_RGBA_ATC_INTERPOLATED_ALPHA_WEBGL", "GL_COMPRESSED_RGB_PVRTC_4BPPV1_IMG", "GL_COMPRESSED_RGB_PVRTC_2BPPV1_IMG", "GL_COMPRESSED_RGBA_PVRTC_4BPPV1_IMG", "GL_COMPRESSED_RGBA_PVRTC_2BPPV1_IMG", "GL_COMPRESSED_RGB_ETC1_WEBGL", "GL_UNSIGNED_BYTE$5", "GL_UNSIGNED_SHORT$3", "GL_UNSIGNED_INT$3", "GL_FLOAT$4", "GL_TEXTURE_WRAP_S", "GL_TEXTURE_WRAP_T", "GL_REPEAT", "GL_CLAMP_TO_EDGE$1", "GL_MIRRORED_REPEAT", "GL_TEXTURE_MAG_FILTER", "GL_TEXTURE_MIN_FILTER", "GL_NEAREST$1", "GL_LINEAR", "GL_NEAREST_MIPMAP_NEAREST$1", "GL_LINEAR_MIPMAP_NEAREST$1", "GL_NEAREST_MIPMAP_LINEAR$1", "GL_LINEAR_MIPMAP_LINEAR$1", "GL_GENERATE_MIPMAP_HINT", "GL_DONT_CARE", "GL_FASTEST", "GL_NICEST", "GL_TEXTURE_MAX_ANISOTROPY_EXT", "GL_UNPACK_ALIGNMENT", "GL_UNPACK_FLIP_Y_WEBGL", "GL_UNPACK_PREMULTIPLY_ALPHA_WEBGL", "GL_UNPACK_COLORSPACE_CONVERSION_WEBGL", "GL_BROWSER_DEFAULT_WEBGL", "GL_TEXTURE0$1", "MIPMAP_FILTERS", "CHANNELS_FORMAT", "FORMAT_CHANNELS", "objectName", "CANVAS_CLASS", "OFFSCREENCANVAS_CLASS", "CONTEXT2D_CLASS", "BITMAP_CLASS", "IMAGE_CLASS", "VIDEO_CLASS", "PIXEL_CLASSES", "TYPE_SIZES", "FORMAT_SIZES_SPECIAL", "isNumericArray", "arr", "isRectArray", "width", "classString", "isCanvasElement", "isOffscreenCanvas", "isContext2D", "isBitmap", "isImageElement", "isVideoElement", "isPixelData", "className", "typedArrayCode$1", "convertData", "preConvert", "image", "postConvert", "strideC", "p", "getTextureSize", "format", "height", "isMipmap", "isCube", "createTextureSet", "reglPoll", "contextState", "mipmapHint", "wrapModes", "magFilters", "minFilters", "colorSpace", "textureTypes", "textureFormats", "compressedTextureFormats", "supportedCompressedFormats", "supportedFormats", "textureFormatsInvert", "val", "textureTypesInvert", "magFiltersInvert", "minFiltersInvert", "wrapModesInvert", "colorFormats", "color", "glenum", "TexFlags", "copyFlags", "other", "parseFlags", "flags", "hasChannels", "hasFormat", "formatStr", "internalformat", "setFlags", "TexImage", "parseImage", "viewW", "viewH", "shapeC", "dd", "allocData", "setImage", "target", "miplevel", "setSubImage", "imagePool", "allocImage", "freeImage", "MipMap", "parseMipMapFromShape", "mipmap", "parseMipMapFromObject", "imgData", "setMipMap", "images", "mipPool", "allocMipMap", "freeMipMap", "TexInfo", "parseTexInfo", "minFilter", "magFilter", "wrapS", "wrapT", "wrap", "optWrapS", "optWrapT", "anisotropic", "hasMipMap", "setTexInfo", "textureCount", "textureSet", "numTexUnits", "textureUnits", "REGLTexture", "tempBind", "tempRestore", "prev", "unit", "createTexture2D", "a", "b", "reglTexture2D", "texInfo", "subimage", "x_", "y_", "level_", "imageData", "w_", "h_", "_w", "_h", "createTextureCube", "a0", "a1", "a2", "a3", "a4", "a5", "reglTextureCube", "faceInput", "radius_", "radius", "destroyTextures", "restoreTextures", "tex", "refreshTextures", "GL_RENDERBUFFER", "GL_RGBA4$1", "GL_RGB5_A1$1", "GL_RGB565$1", "GL_DEPTH_COMPONENT16", "GL_STENCIL_INDEX8", "GL_DEPTH_STENCIL$1", "GL_SRGB8_ALPHA8_EXT", "GL_RGBA32F_EXT", "GL_RGBA16F_EXT", "GL_RGB16F_EXT", "FORMAT_SIZES", "getRenderbufferSize", "wrapRenderbuffers", "formatTypes", "formatTypesInvert", "renderbufferCount", "renderbufferSet", "REGLRenderbuffer", "renderbuffer", "rb", "createRenderbuffer", "reglRenderbuffer", "restoreRenderbuffers", "GL_FRAMEBUFFER$1", "GL_RENDERBUFFER$1", "GL_TEXTURE_2D$2", "GL_TEXTURE_CUBE_MAP_POSITIVE_X$2", "GL_COLOR_ATTACHMENT0$1", "GL_DEPTH_ATTACHMENT", "GL_STENCIL_ATTACHMENT", "GL_DEPTH_STENCIL_ATTACHMENT", "GL_FRAMEBUFFER_COMPLETE$1", "GL_FRAMEBUFFER_INCOMPLETE_ATTACHMENT", "GL_FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT", "GL_FRAMEBUFFER_INCOMPLETE_DIMENSIONS", "GL_FRAMEBUFFER_UNSUPPORTED", "GL_HALF_FLOAT_OES$2", "GL_UNSIGNED_BYTE$6", "GL_FLOAT$5", "GL_RGB$1", "GL_RGBA$2", "GL_DEPTH_COMPONENT$1", "colorTextureFormatEnums", "textureFormatChannels", "textureTypeSizes", "GL_RGBA4$2", "GL_RGB5_A1$2", "GL_RGB565$2", "GL_DEPTH_COMPONENT16$1", "GL_STENCIL_INDEX8$1", "GL_DEPTH_STENCIL$2", "GL_SRGB8_ALPHA8_EXT$1", "GL_RGBA32F_EXT$1", "GL_RGBA16F_EXT$1", "GL_RGB16F_EXT$1", "colorRenderbufferFormatEnums", "statusCode", "wrapFBOState", "textureState", "renderbufferState", "framebufferState", "colorTextureFormats", "colorRenderbufferFormats", "colorTypes", "FramebufferAttachment", "decRef", "incRefAndCheckShape", "tw", "th", "attach", "location", "parseAttachment", "allocAttachment", "isTexture", "unwrapAttachment", "resizeAttachment", "framebufferCount", "framebufferSet", "REGLFramebuffer", "decFBORefs", "framebuffer", "updateFramebuffer", "colorAttachments", "status", "createFBO", "reglFramebuffer", "needsDepth", "needsStencil", "colorBuffer", "colorTexture", "colorFormat", "colorType", "colorCount", "depthBuffer", "stencilBuffer", "depthStencilBuffer", "depthStencilTexture", "depthAttachment", "stencilAttachment", "depthStencilAttachment", "commonColorAttachmentSize", "colorAttachmentSize", "createCubeFBO", "reglFramebufferCube", "params", "colorCubes", "cubeMapParams", "cube", "colors", "restoreFramebuffers", "fb", "GL_FLOAT$6", "GL_ARRAY_BUFFER$1", "AttributeRecord", "wrapAttributeState", "NUM_ATTRIBUTES", "attributeBindings", "vaoCount", "vaoSet", "state", "extVAO", "restoreVAO", "createVAO", "getVAO", "setVAOEXT", "setVAOEmulated", "destroyVAOEXT", "record", "extInstanced", "vao", "exti", "binding", "REGLVAO", "extension", "attr", "_attr", "updateVAO", "bufUpdated", "nattributes", "spec", "rec", "GL_FRAGMENT_SHADER", "GL_VERTEX_SHADER", "GL_ACTIVE_UNIFORMS", "GL_ACTIVE_ATTRIBUTES", "wrapShaderState", "fragShaders", "vertShaders", "ActiveInfo", "insertActiveInfo", "getShader", "cache", "programCache", "programList", "PROGRAM_COUNTER", "REGLProgram", "fragId", "vertId", "linkProgram", "attributeLocations", "numUniforms", "numAttributes", "m", "restoreShaders", "deleteShader", "attribLocations", "prevProgram", "idx", "GL_RGBA$3", "GL_UNSIGNED_BYTE$7", "GL_PACK_ALIGNMENT", "GL_FLOAT$7", "wrapReadPixels", "context", "glAttributes", "readPixelsImpl", "size", "readPixelsFBO", "readPixels", "slice", "join", "createEnvironment", "varCounter", "linkedNames", "linkedValues", "link", "code", "vars", "def", "scope", "entry", "exit", "entryToString", "exitToString", "save", "prop", "conditional", "thenBlock", "elseBlock", "thenToString", "elseToString", "elseClause", "globalBlock", "procedures", "proc", "arg", "body", "bodyToString", "compile", "src", "CUTE_COMPONENTS", "GL_UNSIGNED_BYTE$8", "ATTRIB_STATE_POINTER", "ATTRIB_STATE_CONSTANT", "DYN_FUNC$1", "DYN_PROP$1", "DYN_CONTEXT$1", "DYN_STATE$1", "DYN_THUNK", "DYN_CONSTANT$1", "DYN_ARRAY$1", "S_DITHER", "S_BLEND_ENABLE", "S_BLEND_COLOR", "S_BLEND_EQUATION", "S_BLEND_FUNC", "S_DEPTH_ENABLE", "S_DEPTH_FUNC", "S_DEPTH_RANGE", "S_DEPTH_MASK", "S_COLOR_MASK", "S_CULL_ENABLE", "S_CULL_FACE", "S_FRONT_FACE", "S_LINE_WIDTH", "S_POLYGON_OFFSET_ENABLE", "S_POLYGON_OFFSET_OFFSET", "S_SAMPLE_ALPHA", "S_SAMPLE_ENABLE", "S_SAMPLE_COVERAGE", "S_STENCIL_ENABLE", "S_STENCIL_MASK", "S_STENCIL_FUNC", "S_STENCIL_OPFRONT", "S_STENCIL_OPBACK", "S_SCISSOR_ENABLE", "S_SCISSOR_BOX", "S_VIEWPORT", "S_PROFILE", "S_FRAMEBUFFER", "S_VERT", "S_FRAG", "S_ELEMENTS", "S_PRIMITIVE", "S_COUNT", "S_OFFSET", "S_INSTANCES", "S_VAO", "SUFFIX_WIDTH", "SUFFIX_HEIGHT", "S_FRAMEBUFFER_WIDTH", "S_FRAMEBUFFER_HEIGHT", "S_VIEWPORT_WIDTH", "S_VIEWPORT_HEIGHT", "S_DRAWINGBUFFER", "S_DRAWINGBUFFER_WIDTH", "S_DRAWINGBUFFER_HEIGHT", "NESTED_OPTIONS", "GL_ARRAY_BUFFER$2", "GL_ELEMENT_ARRAY_BUFFER$1", "GL_FRAGMENT_SHADER$1", "GL_VERTEX_SHADER$1", "GL_TEXTURE_2D$3", "GL_TEXTURE_CUBE_MAP$2", "GL_CULL_FACE", "GL_BLEND", "GL_DITHER", "GL_STENCIL_TEST", "GL_DEPTH_TEST", "GL_SCISSOR_TEST", "GL_POLYGON_OFFSET_FILL", "GL_SAMPLE_ALPHA_TO_COVERAGE", "GL_SAMPLE_COVERAGE", "GL_FLOAT$8", "GL_FLOAT_VEC2", "GL_FLOAT_VEC3", "GL_FLOAT_VEC4", "GL_INT$3", "GL_INT_VEC2", "GL_INT_VEC3", "GL_INT_VEC4", "GL_BOOL", "GL_BOOL_VEC2", "GL_BOOL_VEC3", "GL_BOOL_VEC4", "GL_FLOAT_MAT2", "GL_FLOAT_MAT3", "GL_FLOAT_MAT4", "GL_SAMPLER_2D", "GL_SAMPLER_CUBE", "GL_TRIANGLES$1", "GL_FRONT", "GL_BACK", "GL_CW", "GL_CCW", "GL_MIN_EXT", "GL_MAX_EXT", "GL_ALWAYS", "GL_KEEP", "GL_ZERO", "GL_ONE", "GL_FUNC_ADD", "GL_LESS", "GL_FRAMEBUFFER$2", "GL_COLOR_ATTACHMENT0$2", "blendFuncs", "invalidBlendCombinations", "compareFuncs", "stencilOps", "shaderType", "orientationType", "isBufferArgs", "sortState", "Declaration", "thisDep", "contextDep", "propDep", "append", "isStatic", "decl", "createStaticDecl", "createDynamicDecl", "dyn", "numArgs", "subDyn", "subArgs", "SCOPE_DECL", "reglCore", "elementState", "uniformState", "attributeState", "shaderState", "drawState", "timer", "blendEquations", "extInstancing", "extDrawBuffers", "currentState", "nextState", "GL_STATE_NAMES", "GL_FLAGS", "GL_VARIABLES", "propName", "stateFlag", "sname", "cap", "init", "stateVariable", "func", "sharedState", "sharedConstants", "drawCallCounter", "createREGLEnvironment", "env", "SHARED", "shared", "nextVars", "currentVars", "variable", "constants", "argList", "scopeAttribs", "parseProfile", "staticOptions", "dynamicOptions", "profileEnable", "parseFramebuffer", "FRAMEBUFFER", "CONTEXT", "FRAMEBUFFER_FUNC", "FRAMEBUFFER_STATE", "parseViewportScissor", "parseBox", "box", "BOX_W", "BOX_H", "dynBox", "BOX", "BOX_X", "BOX_Y", "viewport", "prevViewport", "VIEWPORT", "parseAttribLocations", "staticProgram", "staticAttributes", "sAttributes", "bindings", "parseProgram", "parseShader", "frag", "vert", "progVar", "SHADER_STATE", "progDef", "parseDraw", "parseElements", "IS_BUFFER_ARGS", "ELEMENT_STATE", "elementDefn", "elementStream", "ifte", "parsePrimitive", "primitive", "dynPrimitive", "PRIM_TYPES", "parseParam", "isOffset", "dynValue", "OFFSET", "parseVertCount", "dynCount", "parseGLState", "STATE", "parseStatic", "parseDynamic", "COMPARE_FUNCS", "Z_NEAR", "Z_FAR", "srcRGB", "srcAlpha", "dstRGB", "dstAlpha", "BLEND_FUNCS", "read", "prefix", "suffix", "INVALID_BLEND_COMBINATIONS", "SRC_RGB", "SRC_ALPHA", "DST_RGB", "DST_ALPHA", "BLEND_EQUATIONS", "RGB", "ALPHA", "checkProp", "cmp", "ref", "mask", "assert", "fail", "zfail", "zpass", "STENCIL_OPS", "factor", "units", "FACTOR", "UNITS", "sampleValue", "sampleInvert", "VALUE", "INVERT", "parseUniforms", "staticUniforms", "dynamicUniforms", "UNIFORMS", "reglType", "ITEM", "parseAttributes", "dynamicAttributes", "attributeDefs", "attribute", "constant", "normalized", "divisor", "VALID_KEYS", "appendAttributeCode", "BUFFER_STATE", "defaultRecord", "BUFFER", "TYPE", "emitReadRecord", "parseVAO", "vaoRef", "parseContext", "staticContext", "dynamicContext", "parseArguments", "KEY_NAMES", "checkKeys", "viewportAndScissor", "draw", "copyBox", "defn", "dirty", "useVAO", "staticBindings", "emitContext", "contextEnter", "emitPollFramebuffer", "skipCheck", "GL", "EXT_DRAW_BUFFERS", "DRAW_BUFFERS", "BACK_BUFFER", "NEXT", "emitPollState", "CURRENT_VARS", "NEXT_VARS", "CURRENT_STATE", "NEXT_STATE", "CURRENT", "emitSetOptions", "filter", "flag", "injectExtensions", "emitProfile", "useScope", "incrementCounter", "STATS", "TIMER", "profileArg", "perfCounter", "CPU_START", "QUERY_COUNTER", "emitProfileStart", "emitProfileEnd", "scopeProfile", "USE_PROFILE", "start", "end", "emitAttributes", "typeLength", "emitBindAttribute", "ATTRIBUTE", "LOCATION", "BINDING", "CONST_COMPONENTS", "COMMON_KEYS", "emitBuffer", "SIZE", "DIVISOR", "emitConstant", "scopeAttrib", "emitUniforms", "infix", "uniform", "UNIFORM", "TEX_VALUE", "MAT_VALUE", "emitCheck", "checkType", "checkVector", "checkTexture", "unroll", "TEX", "matSize", "STORAGE", "emitDraw", "outer", "inner", "DRAW_STATE", "drawOptions", "emitElements", "ELEMENTS", "emitCount", "COUNT", "emitValue", "PRIMITIVE", "INSTANCES", "EXT_INSTANCING", "ELEMENT_TYPE", "elementsStatic", "emitInstancing", "drawElements", "drawArrays", "emitRegular", "createBody", "emitBody", "parentEnv", "emitDrawBody", "emitDrawProc", "drawCache", "PROG_ID", "CACHED_PROC", "emitBatchDynamicShaderBody", "all", "emitBatchBody", "contextDynamic", "BATCH_ID", "PROP_LIST", "NUM_PROPS", "PROPS", "isInnerDefn", "isOuterDefn", "progCache", "PROGRAM", "emitBatchProc", "batch", "needsContext", "needsFramebuffer", "progDefn", "batchCache", "emitScopeProc", "opt", "saveShader", "isDynamicObject", "props", "splatObject", "globals", "objectRef", "deps", "appendBlock", "compileCommand", "poll", "refresh", "common", "INSTANCING", "GL_QUERY_RESULT_EXT", "GL_QUERY_RESULT_AVAILABLE_EXT", "GL_TIME_ELAPSED_EXT", "createTimer", "queryPool", "allocQuery", "freeQuery", "query", "pendingQueries", "beginQuery", "pushScopeStats", "endQuery", "PendingStats", "pendingStatsPool", "allocPendingStats", "freePendingStats", "pendingStats", "ps", "timeSum", "queryPtr", "update", "queryTime", "startPtr", "endPtr", "GL_COLOR_BUFFER_BIT", "GL_DEPTH_BUFFER_BIT", "GL_STENCIL_BUFFER_BIT", "GL_ARRAY_BUFFER", "CONTEXT_LOST_EVENT", "CONTEXT_RESTORED_EVENT", "DYN_PROP", "DYN_CONTEXT", "DYN_STATE", "find", "haystack", "needle", "wrapREGL", "contextLost", "extensionState", "stats$$1", "START_TIME", "WIDTH", "HEIGHT", "core", "rafCallbacks", "lossCallbacks", "restoreCallbacks", "destroyCallbacks", "activeRAF", "handleRAF", "startRAF", "stopRAF", "handleContextLoss", "event", "handleContextRestored", "compileProcedure", "flattenNestedOptions", "merge", "child", "separateDynamic", "useArrays", "staticItems", "dynamicItems", "option", "compiled", "EMPTY_ARRAY", "reserve", "REGLCommand", "setFBO", "clearImpl", "_", "clearFlags", "clear", "frame", "cancel", "pendingCancel", "index", "pollViewport", "scissorBox", "now", "addListener", "callback", "callbacks", "regl", "Output", "regl", "precision", "label", "width", "height", "fbo", "index", "passes", "pass", "self", "uniforms", "props", "output_default", "import_raf_loop", "webcam_default", "deviceId", "devices", "cameras", "constraints", "stream", "video", "resolve", "reject", "screenmedia_default", "options", "resolve", "reject", "stream", "video", "err", "HydraSource", "regl", "width", "height", "pb", "label", "opts", "params", "index", "self", "webcam_default", "response", "err", "url", "vid", "onload", "img", "streamName", "nick", "video", "screenmedia_default", "track", "time", "hydra_source_default", "mouse", "mouseButtons", "ev", "b", "mouseElement", "mouseRelativeX", "mouseRelativeY", "mouse_event_default", "mouse_default", "mouseListen", "element", "callback", "buttonState", "x", "y", "mods", "attached", "updateMods", "ev", "changed", "handleEvent", "nextButtons", "nextX", "mouse_event_default", "nextY", "clearState", "handleBlur", "handleMods", "handleMouseMove", "handleMouseDown", "handleMouseUp", "attachListeners", "detachListeners", "result", "f", "import_meyda", "Audio", "numBins", "cutoff", "smooth", "max", "scale", "isDrawing", "parentEl", "stream", "audio_stream", "Meyda", "err", "level", "features", "reducer", "accumulator", "currentValue", "spacing", "bin", "index", "el", "offset", "height", "y", "yMax", "audio_default", "VideoRecorder", "stream", "self", "options", "e0", "e1", "e2", "blob", "url", "a", "d", "event", "video_recorder_default", "easing_functions_default", "t", "map", "num", "in_min", "in_max", "out_min", "out_max", "array_utils_default", "speed", "smooth", "ease", "easing_functions_default", "offset", "low", "high", "lowest", "highest", "newArr", "arr", "time", "bpm", "index", "_index", "currValue", "nextValue", "t", "val", "sandbox_default", "parent", "initialCode", "sandbox", "createSandbox", "addToContext", "name", "object", "code", "initial", "localEval", "EvalSandbox", "parent", "makeGlobal", "userProps", "sandbox_default", "properties", "property", "name", "value", "code", "eval_sandbox_default", "DEFAULT_CONVERSIONS", "ensure_decimal_dot", "val", "formatArguments", "transform", "startIndex", "synthContext", "defaultArgs", "userArgs", "generators", "src", "input", "index", "typedArg", "context", "props", "batchId", "e", "array_utils_default", "final_transform", "defaults", "DEFAULT_CONVERSIONS", "default_def", "name", "args", "x", "x1", "generate_glsl_default", "transforms", "shaderParams", "gen", "generateGlsl", "uniforms", "uniform", "fragColor", "transform", "inputs", "formatArguments", "input", "contains", "f0", "uv", "shaderString", "f1", "method", "str", "p", "c", "contains", "object", "arr", "i", "utility_functions_default", "GlslSource", "obj", "_output", "output", "glsl", "error", "self", "passes", "transforms", "transform", "shaderInfo", "generate_glsl_default", "uniforms", "uniform", "frag", "type", "utility_functions_default", "glsl_source_default", "glsl_functions_default", "GeneratorFactory", "defaultUniforms", "defaultOutput", "extendTransforms", "changeListener", "functions", "glsl_functions_default", "prev", "method", "transform", "glsl_source_default", "self", "func", "args", "obj", "processedGlsl", "processGlsl", "typeLookup", "baseArgs", "arg", "customArgs", "input", "glslFunction", "generator_factory_default", "import_regl", "Mouse", "mouse_default", "HydraRenderer", "pb", "width", "height", "numSources", "numOutputs", "makeGlobal", "autoLoop", "detectAudio", "enableStreamCapture", "canvas", "precision", "extendTransforms", "array_utils_default", "dt", "isIOS", "video_recorder_default", "e", "loop", "eval_sandbox_default", "code", "callback", "source", "output", "url", "res", "rej", "script", "err", "a", "d", "self", "blob", "that", "audio_default", "regl", "el", "index", "o", "output_default", "i", "hydra_source_default", "generator_factory_default", "type", "method", "synth", "uniforms", "hydra_synth_default", "isReduced", "toggle", "hydra_synth_default", "content", "event"] }